:root{--bg-color:#0f172a;--text-primary:#f8fafc;--text-secondary:#94a3b8;--glass-bg:#1e293bb3;--glass-border:#ffffff1a;--glass-shadow:0 8px 32px 0 #0000005e;--accent-color:#3b82f6;--accent-hover:#2563eb;--accent-glow:#3b82f680;--success-color:#10b981;--warning-color:#f59e0b;--danger-color:#ef4444;--touch-target-size:44px;--touch-min-spacing:8px}:root[data-theme=light]{--bg-color:#f8fafc;--text-primary:#0f172a;--text-secondary:#475569;--glass-bg:#ffffffd9;--glass-border:#0000001a;--glass-shadow:0 8px 32px 0 #0000000d;--accent-color:#2563eb;--accent-hover:#1d4ed8;--accent-glow:#2563eb4d}*{box-sizing:border-box;-webkit-tap-highlight-color:transparent;-webkit-touch-callout:none;margin:0;padding:0}html{width:100%;height:100%;overflow:hidden}body{background-color:var(--bg-color);color:var(--text-primary);background:radial-gradient(circle at top left, #1e1b4bcc, var(--bg-color) 40%), radial-gradient(circle at bottom right, #064e3bcc, var(--bg-color) 40%);-webkit-user-select:none;user-select:none;background-attachment:fixed;height:100%;min-height:100vh;font-family:Inter,system-ui,-apple-system,sans-serif;transition:background-color .3s,color .3s;overflow-x:hidden}:root[data-theme=light] body{background:radial-gradient(circle at top left, #e0f2fe, var(--bg-color) 40%), radial-gradient(circle at bottom right, #d1fae5, var(--bg-color) 40%);background-attachment:fixed}.glass-panel{background:var(--glass-bg);-webkit-backdrop-filter:blur(12px);border:1px solid var(--glass-border);box-shadow:var(--glass-shadow);border-radius:16px}.app-container{grid-template-columns:320px 1fr;gap:24px;max-width:1600px;height:100vh;margin:0 auto;padding:24px;display:grid}@media (width<=1024px){.app-container{grid-template-columns:1fr;gap:12px;max-width:100%;height:auto;padding:12px}}@media (width<=640px){.app-container{grid-template-columns:1fr;gap:8px;height:auto;padding:8px}}.sidebar{border-radius:12px;flex-direction:column;gap:24px;height:calc(100vh - 48px);padding:24px;display:flex;overflow-y:auto}@media (width<=1024px){.sidebar{border-radius:8px;gap:16px;height:auto;max-height:60vh;padding:16px;overflow-y:auto}}@media (width<=640px){.sidebar{border-radius:8px;gap:12px;max-height:none;padding:12px}}.sidebar h1{background:linear-gradient(90deg,#60a5fa,#a78bfa);-webkit-text-fill-color:transparent;-webkit-background-clip:text;margin-bottom:8px;font-size:1.5rem;font-weight:700}@media (width<=768px){.sidebar h1{font-size:1.25rem}}@media (width<=640px){.sidebar h1{font-size:1.1rem}}.sidebar p.subtitle{color:var(--text-secondary);margin-bottom:24px;font-size:.875rem}@media (width<=640px){.sidebar p.subtitle{margin-bottom:16px;font-size:.75rem}}.content{border-radius:12px;height:100%;overflow-y:auto}@media (width<=1024px){.content{height:auto;max-height:calc(100vh - 300px)}}@media (width<=640px){.content{height:auto}}@media (width<=1024px){::-webkit-scrollbar{width:6px;height:6px}}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:var(--accent-color);opacity:.6;border-radius:4px}::-webkit-scrollbar-thumb:hover{opacity:1}button,a,input[type=button],input[type=submit]{min-height:var(--touch-target-size);min-width:var(--touch-target-size);padding:max(8px, (var(--touch-target-size) - 1em) / 2) max(12px, (var(--touch-target-size) - 1em) / 2)}@media (width<=640px){button,a,input[type=button],input[type=submit]{min-width:48px;min-height:48px;font-size:16px}}input[type=text],input[type=number],input[type=date],input[type=time],select,textarea{min-height:var(--touch-target-size);padding:12px;font-size:16px}@media (width<=640px){input[type=text],input[type=number],input[type=date],input[type=time],select,textarea{min-height:48px;font-size:16px}}.modal{max-width:90vw;max-height:90vh}@media (width<=768px){.modal{max-width:95vw;max-height:95vh}}@media (width<=480px){.modal{border-radius:0;max-width:100vw;max-height:100vh}}@supports (padding:max(0px)){body{padding-left:max(12px, env(safe-area-inset-left));padding-right:max(12px, env(safe-area-inset-right));padding-top:max(12px, env(safe-area-inset-top));padding-bottom:max(12px, env(safe-area-inset-bottom))}@media (width<=640px){body{padding-left:max(8px, env(safe-area-inset-left));padding-right:max(8px, env(safe-area-inset-right));padding-top:max(8px, env(safe-area-inset-top));padding-bottom:max(8px, env(safe-area-inset-bottom))}}}@media (width<=768px) and (orientation:landscape){.app-container{grid-template-columns:1fr;gap:8px;padding:8px}.sidebar{max-height:40vh;overflow-y:auto}}.folder-picker{border:1px solid var(--glass-border);cursor:pointer;background:#0003;border-radius:8px;align-items:center;gap:12px;padding:12px;transition:all .2s;display:flex}.folder-picker:hover{border-color:var(--accent-color);background:#3b82f61a}.folder-picker .path{text-overflow:ellipsis;white-space:nowrap;flex:1;font-size:.875rem;overflow:hidden}.toggle-group{background:#0003;border-radius:8px;padding:4px;display:flex}.toggle-btn{color:var(--text-secondary);cursor:pointer;background:0 0;border:none;border-radius:6px;flex:1;padding:8px 16px;font-size:.875rem;font-weight:500;transition:all .3s}.toggle-btn.active{background:var(--accent-color);color:#fff;box-shadow:0 0 12px var(--accent-glow)}.switch-group{justify-content:space-between;align-items:center;padding:12px 0;display:flex}.switch{width:44px;height:24px;display:inline-block;position:relative}.switch input{opacity:0;width:0;height:0}.slider{cursor:pointer;background-color:#ffffff1a;border-radius:24px;transition:all .4s;position:absolute;inset:0}.slider:before{content:"";background-color:var(--text-secondary);border-radius:50%;width:18px;height:18px;transition:all .4s;position:absolute;bottom:3px;left:3px}input:checked+.slider{background-color:var(--accent-color)}input:checked+.slider:before{background-color:#fff;transform:translate(20px)}.btn-primary{background:var(--accent-color);color:#fff;cursor:pointer;border:none;border-radius:8px;justify-content:center;align-items:center;gap:8px;margin-top:auto;padding:14px 24px;font-size:1rem;font-weight:600;transition:all .3s;display:flex}.btn-primary:hover:not(:disabled){background:var(--accent-hover);box-shadow:0 0 20px var(--accent-glow);transform:translateY(-2px)}.main-content{flex-direction:column;gap:24px;height:calc(100vh - 48px);display:flex}.tabs{gap:8px;padding:12px;display:flex}.tab{color:var(--text-secondary);cursor:pointer;background:0 0;border:none;border-radius:8px;flex-direction:column;justify-content:center;align-items:center;min-width:100px;padding:8px 20px;transition:all .2s;display:flex;position:relative}.tab-title{margin-bottom:2px;font-size:.95rem;font-weight:600}.tab-subtitle{opacity:.8;font-size:.75rem}.tab:hover{color:var(--text-primary);background:#8080801a}.tab.active{color:var(--accent-color);background:#3b82f61a}.content-area{flex:1;padding:24px;position:relative;overflow-y:auto}.progress-container{flex-direction:column;justify-content:center;align-items:center;gap:24px;height:100%;display:flex}.progress-ring{border:4px solid #ffffff1a;border-top-color:var(--accent-color);border-radius:50%;width:120px;height:120px;animation:1s linear infinite spin}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.progress-text{text-align:center;font-size:1.2rem;font-weight:500}.progress-bar-bg{background:#ffffff1a;border-radius:4px;width:100%;max-width:400px;height:8px;overflow:hidden}.progress-bar-fill{background:var(--accent-color);height:100%;transition:width .3s}.data-table{border-collapse:collapse;table-layout:fixed;width:100%}.data-table th{text-align:left;color:var(--text-secondary);border-bottom:1px solid var(--glass-border);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);z-index:10;cursor:pointer;background:#1e293bf2;padding:16px;font-size:.875rem;font-weight:500;position:sticky;top:0}.data-table th:hover{color:var(--text-primary)}.data-table td{vertical-align:middle;text-overflow:ellipsis;white-space:nowrap;border-bottom:1px solid #ffffff0d;padding:12px 16px;font-size:.875rem;overflow:hidden}.data-table .col-image{width:92px}.data-table .col-name{width:33%}.data-table .col-status{width:128px}.data-table .col-size{width:90px}.data-table .col-resolution{width:116px}.data-table .col-location{width:178px}.data-table .col-date{width:148px}.data-table tr:hover{background:#ffffff05}.thumbnail-cell{width:60px}.thumbnail{object-fit:cover;cursor:pointer;border-radius:8px;width:48px;height:48px;transition:transform .2s}.thumbnail:hover{transform:scale(1.1);box-shadow:0 4px 12px #00000080}.editable-cell{cursor:pointer;align-items:center;gap:8px;display:flex}.editable-cell:hover{color:var(--accent-color)}.editable-cell input{border:1px solid var(--accent-color);color:#fff;background:#0000004d;border-radius:4px;outline:none;padding:4px 8px}.lightbox{-webkit-backdrop-filter:blur(8px);z-index:1000;-webkit-user-select:none;user-select:none;touch-action:none;background:#000000e6;flex-direction:column;justify-content:center;align-items:center;width:100vw;height:100vh;display:flex;position:fixed;top:0;left:0}.lightbox-image-wrapper{justify-content:center;align-items:center;width:100%;height:100%;display:flex}.lightbox-content{object-fit:contain;border-radius:8px;max-width:90vw;max-height:90vh;transition:transform .2s cubic-bezier(.1,.7,1,.1),margin-bottom .3s;box-shadow:0 0 40px #00000080}.lightbox-close{color:#fff;cursor:pointer;background:0 0;border:none;padding:8px;position:absolute;top:24px;right:24px}.lightbox-nav{color:#fff;cursor:pointer;background:#ffffff1a;border:none;border-radius:50%;padding:16px;transition:background .2s;position:absolute;top:50%;transform:translateY(-50%)}.lightbox-nav:hover{background:#fff3}.lightbox-nav.prev{left:24px}.lightbox-nav.next{right:24px}.lightbox-controls{z-index:10001;gap:12px;display:flex;position:absolute;bottom:24px;right:24px}.control-btn{color:#fff;cursor:pointer;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#1e293bcc;border:1px solid #ffffff1a;border-radius:50%;padding:10px;transition:all .2s}.control-btn:hover{background:#fff3}.control-btn.active{background:var(--accent-color);box-shadow:0 0 12px var(--accent-glow)}.exif-info-panel{-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border:1px solid var(--glass-border);color:#fff;z-index:10000;background:#0f172ad9;border-radius:12px;width:300px;padding:20px;transition:transform .3s cubic-bezier(.4,0,.2,1);position:absolute;top:24px;left:24px;transform:translate(-150%);box-shadow:0 8px 32px #00000080}.exif-info-panel.visible{transform:translate(0)}.exif-info-panel h3{color:var(--accent-color);margin-bottom:4px;font-size:1.1rem}.exif-info-panel .filename{color:var(--text-secondary);word-break:break-all;margin-bottom:16px;font-size:.875rem}.exif-grid{flex-direction:column;gap:12px;display:flex}.exif-item{border-bottom:1px solid #ffffff0d;justify-content:space-between;padding-bottom:8px;font-size:.875rem;display:flex}.exif-item span{color:var(--text-secondary)}.exif-item strong{text-align:right;max-width:60%;font-weight:500}.filmstrip-container{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);z-index:10000;background:#000c;align-items:center;height:100px;padding:0 24px;transition:transform .3s cubic-bezier(.4,0,.2,1);display:flex;position:absolute;bottom:0;left:0;right:0;transform:translateY(100%)}.filmstrip-container.visible{transform:translateY(0)}.filmstrip{scroll-behavior:smooth;gap:8px;width:100%;height:80px;padding-bottom:8px;display:flex;overflow:auto hidden}.filmstrip::-webkit-scrollbar{height:4px}.filmstrip-item{cursor:pointer;opacity:.5;border:2px solid #0000;border-radius:6px;flex:0 0 80px;height:60px;transition:all .2s;overflow:hidden}.filmstrip-item:hover{opacity:.8}.filmstrip-item.active{opacity:1;border-color:var(--accent-color);transform:scale(1.05)}.filmstrip-item img{object-fit:cover;width:100%;height:100%}.summary-card{text-align:center;background:#10b9811a;border:1px solid #10b98133;border-radius:16px;margin-bottom:24px;padding:48px}.summary-card h2{color:var(--success-color);margin-bottom:12px}.summary-card p{color:var(--text-secondary);font-size:1.1rem}.stat-row{justify-content:center;gap:48px;margin-top:32px;display:flex}.stat-item{flex-direction:column;align-items:center;gap:8px;display:flex}.stat-value{color:#fff;font-size:2rem;font-weight:700}.stat-label{color:var(--text-secondary);font-size:.875rem}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:#0000001a;border-radius:4px}::-webkit-scrollbar-thumb{background:#fff3;border-radius:4px}::-webkit-scrollbar-thumb:hover{background:#ffffff4d}.table-wrapper{flex-direction:column;gap:16px;height:100%;display:flex}.table-controls{border:1px solid var(--glass-border);background:#0003;border-radius:8px;flex-direction:column;align-items:stretch;gap:10px;padding:12px 16px;display:flex}.table-controls-top{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:12px;display:flex}.thumb-control-row{align-items:center;gap:12px;display:flex}.view-toggle{border:1px solid var(--glass-border);background:#00000038;border-radius:8px;gap:6px;width:fit-content;padding:4px;display:flex}.view-toggle-btn{color:var(--text-secondary);cursor:pointer;background:0 0;border:none;border-radius:6px;align-items:center;gap:6px;padding:7px 10px;font-weight:600;display:flex}.view-toggle-btn.active{background:var(--accent-color);color:#fff}.control-label{color:var(--text-secondary);font-size:.875rem}.control-value{color:var(--accent-color);min-width:40px;font-size:.875rem;font-weight:500}.thumb-slider{cursor:pointer;max-width:200px;accent-color:var(--accent-color);flex:1}.grid-sort-toolbar{flex-wrap:wrap;justify-content:flex-end;align-items:center;gap:8px;display:flex}.grid-sort-chip{border:1px solid var(--glass-border);min-width:auto;min-height:34px;color:var(--text-secondary);cursor:pointer;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ffffff0d;border-radius:999px;align-items:center;gap:8px;padding:6px 10px;font-size:.78rem;font-weight:700;transition:all .18s;display:inline-flex}.grid-sort-chip:hover{color:var(--text-primary);background:#3b82f61f;border-color:#3b82f673}.grid-sort-chip.active{color:#fff;background:linear-gradient(135deg,#3b82f6eb,#2563ebeb);border-color:#3b82f6b3;box-shadow:0 0 0 1px #3b82f633,0 8px 20px #2563eb47}.grid-sort-chip-label{white-space:nowrap;line-height:1}.grid-sort-chip-indicator{color:currentColor;background:#ffffff24;border-radius:50%;justify-content:center;align-items:center;width:18px;height:18px;font-size:.72rem;font-weight:800;display:inline-flex}.grid-sort-chip.active .grid-sort-chip-indicator{background:#ffffff42}.grid-sort-chip-order{letter-spacing:.01em;opacity:.95;font-size:.7rem;line-height:1}@media (width<=1024px){.table-controls-top{flex-direction:column;align-items:flex-start}.grid-sort-toolbar{justify-content:flex-start}}.review-filter-bar{border:1px solid var(--glass-border);background:#0003;border-radius:8px;gap:8px;width:fit-content;padding:4px;display:flex}.review-filter-btn{color:var(--text-secondary);cursor:pointer;background:0 0;border:none;border-radius:6px;padding:8px 12px;font-weight:700}.review-filter-btn.active{background:var(--accent-color);color:#fff}.table-responsive,.grid-responsive{flex:1;overflow:auto}.preview-grid{grid-template-columns:repeat(auto-fill, minmax(max(180px, calc(var(--thumb-size,48px) * 2.5)), 1fr));gap:14px;padding:2px;display:grid}.preview-card{cursor:pointer;background:#ffffff0a;border:1px solid #ffffff14;border-radius:8px;min-width:0;transition:border-color .2s,transform .2s,background .2s;overflow:hidden}.preview-card:hover{border-color:var(--accent-color);background:#ffffff12;transform:translateY(-1px)}.grid-thumbnail{width:100%;height:max(140px, calc(var(--thumb-size,48px) * 2.4));object-fit:cover;background:#0000002e;display:block}.grid-card-body{padding:10px}.grid-meta{color:var(--text-secondary);gap:3px;margin-top:8px;font-size:.78rem;display:grid}.file-name-row{align-items:center;gap:8px;width:100%;min-width:0;display:flex}.file-name-row.compact{flex-wrap:wrap;align-items:flex-start}.file-name-text{text-overflow:ellipsis;white-space:nowrap;flex:1;min-width:0;max-width:100%;overflow:hidden}.file-name-row.compact .file-name-text{flex-basis:100%}.inline-icon-btn{width:32px;height:32px;color:var(--text-secondary);cursor:pointer;background:0 0;border:1px solid #0000;border-radius:6px;flex:0 0 32px;justify-content:center;align-items:center;display:inline-flex}.inline-icon-btn:hover{color:var(--accent-color);border-color:var(--glass-border);background:#ffffff0f}.badge-btn{white-space:nowrap;justify-content:center;align-items:center;gap:6px;min-width:96px;display:inline-flex;margin-left:6px!important}.badge-btn:hover{transform:translateY(-1px)}.folder-scope-panel{border:1px solid var(--glass-border);background:#0000002e;border-radius:8px;margin-top:12px;padding:12px}.scope-toggle{cursor:pointer;color:var(--text-primary);align-items:center;gap:8px;font-weight:600;display:flex}.scope-toggle input{accent-color:var(--accent-color)}.scope-summary{color:var(--text-primary);gap:3px;margin-top:10px;display:grid}.scope-summary small{color:var(--text-secondary)}.folder-selection-actions{gap:8px;margin-top:12px;display:flex}.folder-selection-actions button{border:1px solid var(--glass-border);color:var(--text-primary);cursor:pointer;background:#ffffff0f;border-radius:6px;padding:7px 10px;font-weight:600}.folder-selection-actions button:hover{border-color:var(--accent-color)}.subfolder-list{gap:8px;max-height:180px;margin-top:10px;padding-right:4px;display:grid;overflow:auto}.subfolder-chip{width:100%;min-width:0;color:var(--text-secondary);cursor:pointer;text-align:left;background:#ffffff0a;border:1px solid #ffffff14;border-radius:8px;align-items:center;gap:8px;padding:9px 10px;display:flex}.subfolder-chip svg:first-child{opacity:0;color:var(--success-color)}.subfolder-chip.selected{border-color:var(--accent-color);color:var(--text-primary);background:#3b82f61f}.subfolder-chip.selected svg:first-child{opacity:1}.subfolder-chip span{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.export-section{flex-direction:column;gap:16px;margin-top:8px;display:flex}.divider{border:none;border-top:1px solid var(--glass-border);margin:8px 0}.section-title{color:var(--text-secondary);font-size:.9rem;font-weight:600}.btn-success{background:var(--success-color);color:#fff;cursor:pointer;border:none;border-radius:8px;justify-content:center;align-items:center;gap:8px;margin-top:8px;padding:14px 24px;font-size:1rem;font-weight:600;transition:all .3s;display:flex}.btn-success:hover:not(:disabled){background:#059669;transform:translateY(-2px);box-shadow:0 0 20px #10b98166}.btn-success:disabled{opacity:.5;cursor:not-allowed}@media (width<=900px){.app-container{grid-template-columns:1fr;height:auto;overflow-y:auto}.sidebar{height:auto;overflow:visible}.main-content{height:700px}.stat-row{flex-direction:column;gap:24px}.exif-info-panel{width:calc(100vw - 48px);max-height:50vh;overflow-y:auto}.lightbox-controls{background:#00000080;border-radius:32px;padding:8px 16px;bottom:124px;right:50%;transform:translate(50%)}}@media (width<=480px){.thumbnail-cell{display:none}.lightbox-nav{padding:8px}}.similar-groups-container{flex-direction:column;gap:24px;display:flex}.similar-group-box{border:1px solid var(--glass-border);background:#0003;border-radius:12px;overflow:hidden}.similar-group-header{color:var(--accent-color);border-bottom:1px solid var(--glass-border);background:#1e293be6;justify-content:space-between;align-items:center;padding:12px 16px;font-weight:600;display:flex}.similar-group-items{flex-wrap:wrap;gap:12px;padding:16px;display:flex}.similar-item{cursor:pointer;background:#ffffff0d;border:2px solid #0000;border-radius:8px;flex-direction:column;align-items:center;gap:8px;width:140px;padding:12px;transition:all .2s;display:flex;position:relative}.similar-item:hover{background:#ffffff1a}.similar-item.selected{border-color:var(--success-color);background:#10b9811a}.similar-thumb{object-fit:cover;border-radius:6px;width:100px;height:100px}.similar-meta{color:var(--text-secondary);text-align:center;word-break:break-all;width:100%;font-size:.75rem}.similar-check{margin-top:8px}.circle-empty{border:2px solid var(--text-secondary);border-radius:50%;width:24px;height:24px}.editable-cell{cursor:pointer;color:var(--text-secondary);font:inherit;text-align:left;background:0 0;border:none;border-radius:6px;align-items:center;gap:6px;padding:3px 6px;transition:background .15s,color .15s;display:inline-flex}.editable-cell:hover{color:var(--accent-color);background:#3b82f626}.editable-cell svg{opacity:.6;flex-shrink:0;transition:opacity .15s}.editable-cell:hover svg{opacity:1}.grid-date-cell{color:var(--text-secondary);cursor:pointer;font-size:.78rem;font:inherit;background:0 0;border:none;border-radius:4px;align-items:center;gap:4px;padding:2px 4px;transition:background .15s,color .15s;display:inline-flex}.grid-date-cell:hover{color:var(--accent-color);background:#3b82f626}.grid-date-cell svg{opacity:.6;flex-shrink:0;transition:opacity .15s}.grid-date-cell:hover svg{opacity:1}:root{--adaptive-scale:1;--adaptive-app-padding:16px;--adaptive-app-gap:14px;--sidebar-drawer-width:340px;--adaptive-table-min:760px}.top-controls{z-index:120;flex-wrap:wrap;align-items:center;gap:12px;max-width:calc(100vw - 24px);display:flex;position:absolute;top:24px;right:24px}.top-controls-history{align-items:center;gap:8px;margin-right:16px;display:flex}.top-controls-menu-btn,.top-controls-theme-btn{background:var(--glass-bg);border:1px solid var(--glass-border);cursor:pointer;width:40px;height:40px;color:var(--text-primary);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border-radius:10px;justify-content:center;align-items:center;display:flex}.top-controls-theme-btn{border-radius:50%}.sidebar-edge-toggle{color:#bfdbfef2;-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);cursor:pointer;z-index:145;background:linear-gradient(160deg,#1e293bc7,#0f172a8c);border:1px solid #94a3b847;border-left:none;border-radius:0 14px 14px 0;justify-content:center;align-items:center;width:42px;height:74px;transition:background .22s,transform .22s,box-shadow .22s,color .22s;display:inline-flex;position:fixed;top:clamp(120px,22vh,250px);left:6px;box-shadow:0 8px 24px #02061759,inset 0 1px #ffffff0f}.sidebar-edge-toggle:hover{color:#fff;background:linear-gradient(160deg,#2563ebe6,#1e40afcc);transform:translate(2px);box-shadow:0 10px 28px #2563eb66}.sidebar-edge-toggle:active{transform:translate(1px)scale(.98)}.sidebar-edge-toggle svg{filter:drop-shadow(0 1px 2px #02061773)}@media (orientation:landscape){.sidebar-edge-toggle{top:clamp(96px,24vh,220px)}}@media (orientation:portrait){.sidebar-edge-toggle{top:clamp(128px,19vh,240px)}}.sidebar-close-btn{border:1px solid var(--glass-border);width:34px;height:34px;color:var(--text-primary);cursor:pointer;z-index:2;background:#0f172a9e;border-radius:999px;justify-content:center;align-items:center;margin-left:auto;display:inline-flex;position:sticky;top:8px}.sidebar-close-btn:hover{background:#ef444447}.top-controls-select{background:var(--glass-bg);color:var(--text-primary);border:1px solid var(--glass-border);cursor:pointer;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border-radius:8px;outline:none;min-height:40px;padding:8px 12px;font-weight:500}.top-controls-auth{border-left:1px solid var(--glass-border);align-items:center;gap:12px;margin-left:12px;padding-left:12px;display:flex}.user-profile-compact{border:1px solid var(--glass-border);background:#ffffff0d;border-radius:10px;align-items:center;gap:10px;max-width:300px;padding:6px 12px;display:flex}.user-avatar-mini{object-fit:cover;border:2px solid var(--accent-color);border-radius:50%;width:32px;height:32px}.user-info-mini{flex-direction:column;flex:1;min-width:0;display:flex}.user-name-mini{color:var(--text-primary);white-space:nowrap;text-overflow:ellipsis;font-size:.85rem;font-weight:600;overflow:hidden}.user-email-mini{color:var(--text-secondary);white-space:nowrap;text-overflow:ellipsis;font-size:.75rem;overflow:hidden}.btn-logout-mini{color:var(--text-secondary);cursor:pointer;background:0 0;border:none;border-radius:6px;flex-shrink:0;justify-content:center;align-items:center;padding:4px;transition:all .2s;display:flex}.btn-logout-mini:hover{color:#ef4444;background:#ef444433}.btn-login-compact{background:linear-gradient(135deg, var(--accent-color), #2563eb);color:#fff;cursor:pointer;white-space:nowrap;border:none;border-radius:8px;align-items:center;gap:8px;padding:8px 16px;font-size:.9rem;font-weight:600;transition:all .2s;display:flex}.btn-login-compact:hover{background:linear-gradient(135deg,#2563eb,#1d4ed8);transform:translateY(-1px);box-shadow:0 4px 12px #2563eb4d}.table-responsive{-webkit-overflow-scrolling:touch;overflow:auto}.main-content,.content-area,.table-wrapper,.table-responsive,.grid-responsive{min-width:0}.drawer-layout{overflow:hidden;padding:var(--adaptive-app-padding)!important;gap:var(--adaptive-app-gap)!important;grid-template-columns:1fr!important;max-width:100%!important;height:100vh!important}.drawer-layout .main-content{width:100%;min-width:0;max-width:100%;height:calc(100vh - (var(--adaptive-app-padding) * 2))}.drawer-layout .content-area{padding:calc(10px * var(--adaptive-scale))}.drawer-layout .tabs{padding:calc(8px * var(--adaptive-scale));gap:calc(6px * var(--adaptive-scale));overflow-x:auto}.drawer-layout .tab{min-width:calc(84px * var(--adaptive-scale));padding:calc(7px * var(--adaptive-scale)) calc(10px * var(--adaptive-scale))}.sidebar-overlay{opacity:0;pointer-events:none;z-index:140;background:#02061785;border:none;margin:0;padding:0;transition:opacity .2s;position:fixed;inset:0}.sidebar-overlay.open{opacity:1;pointer-events:auto}.sidebar-drawer{width:min(var(--sidebar-drawer-width), 92vw);z-index:150;transition:transform .24s;position:fixed;top:0;bottom:0;left:0;overflow-y:auto;transform:translate(-108%);border-radius:0 14px 14px 0!important;max-height:100vh!important}.sidebar-drawer.open{transform:translate(0)}.drawer-layout .data-table{width:100%;min-width:var(--adaptive-table-min)!important}.drawer-layout .data-table .col-name{width:40%}.drawer-layout .data-table .col-date{width:132px}.drawer-layout .data-table th,.drawer-layout .data-table td{font-size:calc(.8rem * var(--adaptive-scale));padding:calc(9px * var(--adaptive-scale)) calc(11px * var(--adaptive-scale))}.drawer-layout .table-controls{padding:calc(10px * var(--adaptive-scale));gap:calc(8px * var(--adaptive-scale))}@media (width<=1024px){.top-controls{justify-content:flex-end;gap:8px;width:100%;margin-left:0;position:static}.top-controls-history{margin-right:8px}}@media (width<=640px){.top-controls{justify-content:space-between;gap:8px;width:100%;margin-left:0}.top-controls-history{gap:6px;margin-right:0}.top-controls-select{min-width:118px;min-height:38px;padding:7px 10px}.top-controls-menu-btn,.top-controls-theme-btn{width:38px;height:38px}.sidebar-edge-toggle{border-radius:0 10px 10px 0;width:36px;height:62px;top:clamp(112px,22vh,220px);left:4px}}.login-modal-overlay{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:10000;background:#00000080;justify-content:center;align-items:center;animation:.2s ease-out fadeIn;display:flex;position:fixed;inset:0}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.login-modal{background:linear-gradient(135deg,#14141ef2 0%,#1e1e2df2 100%);border:1px solid #ffffff1a;border-radius:16px;width:100%;max-width:400px;max-height:90vh;animation:.3s ease-out slideUp;overflow-y:auto;box-shadow:0 20px 60px #0000004d,inset 0 1px #ffffff1a}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.login-modal-header{background:#ffffff08;border-bottom:1px solid #ffffff1a;justify-content:space-between;align-items:center;padding:24px;display:flex}.login-modal-header h2{color:#fff;margin:0;font-size:1.5rem;font-weight:600}.close-btn{color:#fff9;cursor:pointer;background:0 0;border:none;border-radius:8px;justify-content:center;align-items:center;width:32px;height:32px;padding:0;font-size:28px;transition:all .2s;display:flex}.close-btn:hover{color:#fff;background:#ffffff1a}.login-modal-body{padding:24px}.alert{border-radius:8px;justify-content:space-between;align-items:center;margin-bottom:16px;padding:12px 16px;font-size:.95rem;animation:.2s ease-out slideDown;display:flex}@keyframes slideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.alert-error{color:#fca5a5;background:#ef44441a;border:1px solid #ef44444d}.alert-success{color:#86efac;background:#22c55e1a;border:1px solid #22c55e4d}.alert button{color:inherit;cursor:pointer;opacity:.7;background:0 0;border:none;margin-left:8px;padding:0;font-size:1.2rem;transition:opacity .2s}.alert button:hover{opacity:1}.login-form{flex-direction:column;gap:16px;display:flex}.form-group{flex-direction:column;gap:8px;display:flex}.form-group label{color:#fffc;font-size:.9rem;font-weight:500}.input-with-icon{background:#ffffff0d;border:1px solid #ffffff1a;border-radius:8px;align-items:center;gap:10px;padding:12px;transition:all .2s;display:flex}.input-with-icon:focus-within{background:#ffffff14;border-color:#ffffff4d;box-shadow:0 0 0 3px #3b82f61a}.input-with-icon svg{color:#ffffff80;flex-shrink:0}.input-with-icon input{color:#fff;background:0 0;border:none;outline:none;flex:1;font-family:inherit;font-size:1rem}.input-with-icon input::placeholder{color:#fff6}.form-group input{color:#fff;background:#ffffff0d;border:1px solid #ffffff1a;border-radius:8px;padding:12px;font-size:1rem;transition:all .2s}.form-group input:focus{background:#ffffff14;border-color:#ffffff4d;outline:none;box-shadow:0 0 0 3px #3b82f61a}.form-group input:disabled{opacity:.6;cursor:not-allowed}.btn-primary,.btn-google{cursor:pointer;border:none;border-radius:8px;justify-content:center;align-items:center;gap:10px;padding:12px 16px;font-family:inherit;font-size:1rem;font-weight:500;transition:all .2s;display:flex}.btn-primary{color:#fff;background:linear-gradient(135deg,#3b82f6 0%,#2563eb 100%)}.btn-primary:hover:not(:disabled){background:linear-gradient(135deg,#2563eb 0%,#1d4ed8 100%);transform:translateY(-2px);box-shadow:0 8px 16px #2563eb4d}.btn-primary:disabled{opacity:.6;cursor:not-allowed}.btn-google{color:#fff;background:#ffffff0d;border:1px solid #ffffff1a}.btn-google:hover:not(:disabled){background:#ffffff1a;border-color:#ffffff4d;transform:translateY(-2px)}.btn-google:disabled{opacity:.6;cursor:not-allowed}.animate-spin{animation:1s linear infinite spin}.divider{text-align:center;color:#fff6;margin:20px 0;font-size:.85rem;position:relative}.divider:before,.divider:after{content:"";background:#ffffff1a;width:calc(50% - 15px);height:1px;position:absolute;top:50%}.divider:before{left:0}.divider:after{right:0}.toggle-form{text-align:center;color:#fff9;flex-direction:column;gap:8px;margin-top:20px;font-size:.9rem;display:flex}.toggle-form button{color:#3b82f6;cursor:pointer;font-weight:600;font-size:inherit;background:0 0;border:none;padding:0;font-family:inherit;transition:all .2s}.toggle-form button:hover:not(:disabled){color:#2563eb;text-decoration:underline}.toggle-form button:disabled{opacity:.6;cursor:not-allowed}@media (width<=480px){.login-modal{max-width:calc(100% - 32px);margin:16px}.login-modal-header,.login-modal-body{padding:16px}.btn-primary,.btn-google{padding:10px 14px;font-size:.95rem}}
