html,body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Open Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-size:16px;color:#2c3e50}button{-moz-appearance:button;appearance:button;-webkit-appearance:button;cursor:pointer;display:inline-block;text-align:center}button:disabled{cursor:not-allowed;opacity:.7}.card{background:#fff;border-radius:12px;box-shadow:0 4px 6px #0000001a,0 1px 3px #00000014}.container{width:100%;padding:0 1rem;margin:0 auto}input,select,textarea{font-family:inherit;font-size:inherit}:focus-visible{outline:2px solid #4a6bdf;outline-offset:2px}#app{width:100%;min-height:100vh}a,.green{text-decoration:none;color:#00bd7e;transition:.4s;padding:3px}@media (hover: hover){a:hover{background-color:#00bd7e33}}@media (min-width: 1024px){body{min-height:100vh;overflow-y:auto}#app{display:grid;grid-template-columns:1fr 1fr;padding:0 2rem}}:root{--primary-color: #4a6bdf;--primary-dark: #3755c4;--danger-color: #e74c3c;--danger-dark: #c0392b;--text-dark: #2c3e50;--text-light: #7f8c8d;--bg-light: #f8f9fa;--bg-dark: #e9ecef;--border-color: #dfe6e9;--success-color: #2ecc71;--card-shadow: 0 4px 6px rgba(0, 0, 0, .1), 0 1px 3px rgba(0, 0, 0, .08)}*{box-sizing:border-box;margin:0;padding:0}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Open Sans,Helvetica Neue,sans-serif;line-height:1.5;color:var(--text-dark);background-color:var(--bg-light)}button{cursor:pointer}.app-container{position:relative}.app-header{display:flex;justify-content:space-between;align-items:center;padding:1rem;background-color:#fff;box-shadow:0 2px 5px #0000001a;position:sticky;top:0;z-index:10}.nav-button{background:none;border:none;width:40px;height:40px;display:flex;align-items:center;justify-content:center;color:var(--text-dark);border-radius:8px;transition:background-color .2s}.nav-button:hover{background-color:var(--bg-light)}.header-title{font-size:1.25rem;font-weight:600;margin:0;flex:1;text-align:center;color:var(--text-dark)}.placeholder{width:40px}.icon{width:24px;height:24px}.menu-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#00000080;z-index:100;display:flex}.menu-container{background-color:#fff;width:280px;max-width:80%;height:100%;box-shadow:2px 0 10px #0003;animation:slideIn .3s ease forwards}@keyframes slideIn{0%{transform:translate(-100%)}to{transform:translate(0)}}.menu-header{display:flex;justify-content:space-between;align-items:center;padding:1rem;border-bottom:1px solid var(--border-color)}.menu-header h2{margin:0;font-size:1.25rem;font-weight:600}.close-menu{background:none;border:none;width:36px;height:36px;display:flex;align-items:center;justify-content:center;border-radius:50%;transition:background-color .2s}.close-menu:hover{background-color:var(--bg-light)}.menu-content{padding:1rem}.menu-item{display:flex;align-items:center;width:100%;padding:1rem;border:none;background:none;border-radius:8px;transition:background-color .2s;text-align:left;font-size:1rem}.menu-item .icon{margin-right:.75rem}.menu-item:hover{background-color:var(--bg-light)}.menu-item-danger{color:var(--danger-color)}.menu-item-danger:hover{background-color:#e74c3c1a}.join-button{display:block!important;width:100%!important;height:46px!important;margin:16px 0!important;padding:0!important;background-color:#4a6bdf!important;color:#fff!important;border:none!important;border-radius:8px!important;font-size:16px!important;font-weight:600!important;cursor:pointer!important;opacity:1!important;visibility:visible!important}[data-v-d2ecd654]:root{--primary-color: #4a6bdf;--primary-dark: #3755c4;--danger-color: #e74c3c;--text-dark: #2c3e50;--text-light: #7f8c8d;--bg-light: #f8f9fa;--border-color: #dfe6e9;--card-shadow: 0 4px 6px rgba(0, 0, 0, .1), 0 1px 3px rgba(0, 0, 0, .08)}.home[data-v-d2ecd654]{min-height:100vh;display:flex;justify-content:center;align-items:center;background-color:var(--bg-light);background-image:linear-gradient(135deg,#f5f7fa,#c3cfe2);padding:1rem;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Open Sans,Helvetica Neue,sans-serif}.join-room-container[data-v-d2ecd654]{background:#fff;padding:2rem 1.5rem;border-radius:12px;box-shadow:var(--card-shadow);width:100%;max-width:360px;text-align:center}.app-logo[data-v-d2ecd654]{display:flex;justify-content:center;margin-bottom:1.5rem}.logo-icon[data-v-d2ecd654]{width:60px;height:60px;background-color:var(--primary-color);color:#fff;border-radius:16px;display:flex;justify-content:center;align-items:center;font-size:2rem;font-weight:700;box-shadow:0 4px 10px #4a6bdf66}h1[data-v-d2ecd654]{font-size:1.8rem;color:var(--text-dark);margin:0 0 .5rem;font-weight:700}.app-description[data-v-d2ecd654]{color:var(--text-light);margin-bottom:2rem;font-size:.95rem;line-height:1.5}.join-form[data-v-d2ecd654]{display:flex;flex-direction:column;gap:1.25rem;margin-bottom:1rem}.form-group[data-v-d2ecd654]{display:flex;flex-direction:column;gap:.5rem;text-align:left}label[data-v-d2ecd654]{font-weight:600;color:var(--text-dark);font-size:.9rem}.input-container[data-v-d2ecd654]{position:relative}input[data-v-d2ecd654]{width:100%;padding:.85rem 1rem;border:2px solid var(--border-color);border-radius:8px;font-size:1rem;transition:all .2s;background-color:var(--bg-light)}input[data-v-d2ecd654]:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 0 3px #4a6bdf33;background-color:#fff}input[data-v-d2ecd654]::placeholder{color:#b2b2b2}.error-message[data-v-d2ecd654]{display:flex;align-items:center;gap:.5rem;color:var(--danger-color);font-size:.875rem;text-align:left;padding:.5rem;border-radius:6px;background-color:#e74c3c1a}.error-icon[data-v-d2ecd654]{display:inline-flex;justify-content:center;align-items:center;width:20px;height:20px;background-color:var(--danger-color);border-radius:50%;color:#fff;font-weight:700;font-size:.75rem}.info-text[data-v-d2ecd654]{font-size:.8rem;color:var(--text-light);margin-top:1rem;padding-top:1rem;border-top:1px solid var(--border-color)}@media (min-width: 640px){.join-room-container[data-v-d2ecd654]{padding:2.5rem;max-width:400px}.logo-icon[data-v-d2ecd654]{width:70px;height:70px}h1[data-v-d2ecd654]{font-size:2rem}.app-description[data-v-d2ecd654]{font-size:1rem}}.prefilled[data-v-d2ecd654]{border-color:#4a6bdf;background-color:#4a6bdf0d}[data-v-53bc58e3]:root{--primary-color: #4a6bdf;--primary-dark: #3755c4;--danger-color: #e74c3c;--danger-dark: #c0392b;--text-dark: #2c3e50;--text-light: #7f8c8d;--bg-light: #f8f9fa;--bg-dark: #e9ecef;--border-color: #dfe6e9;--success-color: #2ecc71;--card-shadow: 0 4px 6px rgba(0, 0, 0, .1), 0 1px 3px rgba(0, 0, 0, .08)}.room[data-v-53bc58e3]{min-height:100vh;padding:1rem;background-color:var(--bg-light);font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Open Sans,Helvetica Neue,sans-serif}.loading[data-v-53bc58e3],.error[data-v-53bc58e3]{display:flex;flex-direction:column;justify-content:center;align-items:center;min-height:60vh;text-align:center;padding:2rem}.loading-spinner[data-v-53bc58e3]{width:40px;height:40px;border:4px solid rgba(0,0,0,.1);border-left-color:var(--primary-color);border-radius:50%;animation:spin-53bc58e3 1s linear infinite;margin-bottom:1rem}@keyframes spin-53bc58e3{to{transform:rotate(360deg)}}.error[data-v-53bc58e3]{color:var(--danger-color)}.error-icon[data-v-53bc58e3]{width:50px;height:50px;border-radius:50%;background-color:var(--danger-color);color:#fff;font-size:2rem;font-weight:700;display:flex;justify-content:center;align-items:center;margin-bottom:1rem}.back-button[data-v-53bc58e3]{margin-top:1rem;background-color:var(--primary-color);color:#fff;border:none;border-radius:8px;padding:13.6px;height:45.58px;font-size:1rem;cursor:pointer;transition:.2s all ease;box-sizing:border-box}.back-button[data-v-53bc58e3]:hover{background-color:var(--primary-dark);transform:translateY(-2px);box-shadow:var(--card-shadow)}.room-container[data-v-53bc58e3]{max-width:100%;margin:0 auto;background:#fff;border-radius:12px;box-shadow:var(--card-shadow);padding:1.5rem;overflow:hidden}.room-info[data-v-53bc58e3]{margin-bottom:1.5rem;padding-bottom:1rem;border-bottom:1px solid var(--border-color);position:relative}.connection-status[data-v-53bc58e3]{display:inline-flex;align-items:center;margin-top:10px;padding:5px 10px;border-radius:20px;background-color:#0000000d;font-size:.75rem}.status-indicator[data-v-53bc58e3]{display:inline-block;width:8px;height:8px;border-radius:50%;margin-right:6px;background-color:#fc0}.connected .status-indicator[data-v-53bc58e3]{background-color:var(--success-color)}.disconnected .status-indicator[data-v-53bc58e3]{background-color:var(--danger-color)}.status-text[data-v-53bc58e3]{color:var(--text-dark)}h2[data-v-53bc58e3]{margin:0;font-size:1.1rem;color:var(--text-dark);font-weight:600}.room-time[data-v-53bc58e3]{font-size:.8rem;color:var(--text-light);margin-top:.25rem}.tools-section[data-v-53bc58e3]{margin-bottom:2rem}.section-title[data-v-53bc58e3]{font-size:1.2rem;color:var(--text-dark);margin-bottom:1rem;font-weight:600}.tools-grid[data-v-53bc58e3]{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:1rem}.tool-card[data-v-53bc58e3]{background-color:#fff;border-radius:12px;padding:1.2rem;cursor:pointer;transition:all .2s;border:1px solid var(--border-color);box-shadow:0 2px 4px #0000000d;display:flex;flex-direction:column;align-items:center;text-align:center}.tool-card[data-v-53bc58e3]:hover{transform:translateY(-3px);box-shadow:0 6px 10px #0000001a;border-color:var(--primary-color)}.tool-icon[data-v-53bc58e3]{font-size:2.5rem;margin-bottom:.8rem}.tool-name[data-v-53bc58e3]{font-weight:600;font-size:1rem;color:var(--text-dark);margin-bottom:.3rem}.tool-description[data-v-53bc58e3]{color:var(--text-light);font-size:.8rem}.card[data-v-53bc58e3]{background-color:#fff;border-radius:12px;overflow:hidden;box-shadow:var(--card-shadow);margin-bottom:1.5rem;transition:transform .2s}.card-header[data-v-53bc58e3]{display:flex;justify-content:space-between;align-items:center;padding:1rem 1.5rem;background-color:var(--bg-light);border-bottom:1px solid var(--border-color)}.user-count[data-v-53bc58e3]{background-color:var(--primary-color);color:#fff;padding:.25rem .5rem;border-radius:20px;font-size:.8rem;font-weight:500}.users-list[data-v-53bc58e3]{list-style:none;padding:0;margin:0;max-height:70vh;overflow-y:auto}.user-item[data-v-53bc58e3]{display:flex;align-items:center;padding:1rem 1.5rem;border-bottom:1px solid var(--border-color);transition:background-color .2s}.user-item[data-v-53bc58e3]:last-child{border-bottom:none}.user-item[data-v-53bc58e3]:hover{background-color:#00000005}.current-user[data-v-53bc58e3]{background-color:#4a6bdf1a}.user-avatar[data-v-53bc58e3]{width:40px;height:40px;border-radius:50%;background-color:var(--primary-color);color:#fff;display:flex;justify-content:center;align-items:center;font-weight:700;margin-right:1rem;font-size:1.1rem}.user-info[data-v-53bc58e3]{display:flex;flex-direction:column;flex:1}.user-name[data-v-53bc58e3]{font-weight:600;color:var(--text-dark);margin-bottom:.25rem}.join-time[data-v-53bc58e3]{color:var(--text-light);font-size:.8rem}@media (min-width: 640px){.room[data-v-53bc58e3]{padding:2rem}.room-container[data-v-53bc58e3]{max-width:800px;padding:2rem}.room-time[data-v-53bc58e3]{font-size:.875rem}.user-item[data-v-53bc58e3]{padding:1rem 2rem}.tools-grid[data-v-53bc58e3]{grid-template-columns:repeat(auto-fill,minmax(220px,1fr))}}.share-button[data-v-53bc58e3]{display:flex;align-items:center;gap:.5rem;background-color:#27ae60;color:#fff;border:none;border-radius:8px;padding:.5rem 1rem;margin-top:.75rem;font-size:.9rem;cursor:pointer;transition:background-color .2s,transform .2s}.share-button[data-v-53bc58e3]:hover{background-color:#219653;transform:translateY(-2px)}.share-icon[data-v-53bc58e3]{font-size:1.1rem}.share-success[data-v-53bc58e3]{position:fixed;bottom:2rem;left:50%;transform:translate(-50%);background-color:#2ecc71;color:#fff;padding:.75rem 1.5rem;border-radius:8px;font-size:.9rem;font-weight:500;box-shadow:0 4px 8px #0000001a;z-index:100;animation:fade-in-out-53bc58e3 3s ease-in-out}@keyframes fade-in-out-53bc58e3{0%{opacity:0;transform:translate(-50%,20px)}15%{opacity:1;transform:translate(-50%)}85%{opacity:1;transform:translate(-50%)}to{opacity:0;transform:translate(-50%,-20px)}}.photo-uploader[data-v-c59f298b]{padding:1rem}.upload-area[data-v-c59f298b]{position:relative;display:flex;flex-direction:column;align-items:center;justify-content:center;border:2px dashed #ddd;border-radius:8px;padding:2rem 1rem;margin-bottom:1rem;cursor:pointer;transition:all .2s;background-color:#f8f9fa;min-height:200px}.upload-area[data-v-c59f298b]:hover{border-color:#4a6bdf;background-color:#4a6bdf0d}.drag-active[data-v-c59f298b]{border-color:#4a6bdf;background-color:#4a6bdf1a}.file-input[data-v-c59f298b]{display:none}.upload-icon[data-v-c59f298b]{display:flex;align-items:center;justify-content:center;width:50px;height:50px;border-radius:50%;background-color:#4a6bdf1a;color:#4a6bdf;margin-bottom:1rem}.upload-text[data-v-c59f298b]{font-weight:600;color:#2c3e50;margin-bottom:.5rem;font-size:1rem}.upload-hint[data-v-c59f298b]{color:#7f8c8d;font-size:.8rem}.upload-progress[data-v-c59f298b]{width:100%;max-width:300px;text-align:center}.progress-bar[data-v-c59f298b]{height:6px;background-color:#e9ecef;border-radius:3px;overflow:hidden;margin-bottom:.5rem}.progress-inner[data-v-c59f298b]{height:100%;background-color:#4a6bdf;border-radius:3px;transition:width .3s}.progress-text[data-v-c59f298b]{color:#2c3e50;font-size:.875rem;margin-bottom:.75rem}.total-progress[data-v-c59f298b]{margin-top:.5rem;margin-bottom:1rem}.cancel-button[data-v-c59f298b]{background-color:transparent;color:#7f8c8d;border:1px solid #ddd;border-radius:4px;padding:.25rem .75rem;font-size:.875rem;cursor:pointer;transition:all .2s}.cancel-button[data-v-c59f298b]:hover{color:#e74c3c;border-color:#e74c3c}.upload-message[data-v-c59f298b]{font-size:.875rem;margin-top:.5rem;text-align:center;padding:.5rem;border-radius:4px}.upload-error[data-v-c59f298b]{color:#e74c3c;background-color:#e74c3c1a}.upload-success[data-v-c59f298b]{color:#2ecc71;background-color:#2ecc711a}/*!
 * Viewer.js v1.11.7
 * https://fengyuanchen.github.io/viewerjs
 *
 * Copyright 2015-present Chen Fengyuan
 * Released under the MIT license
 *
 * Date: 2024-11-24T04:32:14.526Z
 */.viewer-zoom-in:before,.viewer-zoom-out:before,.viewer-one-to-one:before,.viewer-reset:before,.viewer-prev:before,.viewer-play:before,.viewer-next:before,.viewer-rotate-left:before,.viewer-rotate-right:before,.viewer-flip-horizontal:before,.viewer-flip-vertical:before,.viewer-fullscreen:before,.viewer-fullscreen-exit:before,.viewer-close:before{background-image:url("data:image/svg+xml,%3Csvg xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22 viewBox%3D%220 0 560 40%22%3E%3Cpath fill%3D%22%23fff%22 d%3D%22M49.6 17.9h20.2v3.9H49.6zm123.1 2 10.9-11 2.7 2.8-8.2 8.2 8.2 8.2-2.7 2.7-10.9-10.9zm94 0-10.8-11-2.7 2.8 8.1 8.2-8.1 8.2 2.7 2.7 10.8-10.9zM212 9.3l20.1 10.6L212 30.5V9.3zm161.5 4.6-7.2 6 7.2 5.9v-4h12.4v4l7.3-5.9-7.3-6v4h-12.4v-4zm40.2 12.3 5.9 7.2 5.9-7.2h-4V13.6h4l-5.9-7.3-5.9 7.3h4v12.6h-4zm35.9-16.5h6.3v2h-4.3V16h-2V9.7Zm14 0h6.2V16h-2v-4.3h-4.2v-2Zm6.2 14V30h-6.2v-2h4.2v-4.3h2Zm-14 6.3h-6.2v-6.3h2v4.4h4.3v2Zm-438 .1v-8.3H9.6v-3.9h8.2V9.7h3.9v8.2h8.1v3.9h-8.1v8.3h-3.9zM93.6 9.7h-5.8v3.9h2V30h3.8V9.7zm16.1 0h-5.8v3.9h1.9V30h3.9V9.7zm-11.9 4.1h3.9v3.9h-3.9zm0 8.2h3.9v3.9h-3.9zm244.6-11.7 7.2 5.9-7.2 6v-3.6c-5.4-.4-7.8.8-8.7 2.8-.8 1.7-1.8 4.9 2.8 8.2-6.3-2-7.5-6.9-6-11.3 1.6-4.4 8-5 11.9-4.9v-3.1Zm147.2 13.4h6.3V30h-2v-4.3h-4.3v-2zm14 6.3v-6.3h6.2v2h-4.3V30h-1.9zm6.2-14h-6.2V9.7h1.9V14h4.3v2zm-13.9 0h-6.3v-2h4.3V9.7h2V16zm33.3 12.5 8.6-8.6-8.6-8.7 1.9-1.9 8.6 8.7 8.6-8.7 1.9 1.9-8.6 8.7 8.6 8.6-1.9 2-8.6-8.7-8.6 8.7-1.9-2zM297 10.3l-7.1 5.9 7.2 6v-3.6c5.3-.4 7.7.8 8.7 2.8.8 1.7 1.7 4.9-2.9 8.2 6.3-2 7.5-6.9 6-11.3-1.6-4.4-7.9-5-11.8-4.9v-3.1Zm-157.3-.6c2.3 0 4.4.7 6 2l2.5-3 1.9 9.2h-9.3l2.6-3.1a6.2 6.2 0 0 0-9.9 5.1c0 3.4 2.8 6.3 6.2 6.3 2.8 0 5.1-1.9 6-4.4h4c-1 4.7-5 8.3-10 8.3a10 10 0 0 1-10-10.2 10 10 0 0 1 10-10.2Z%22%2F%3E%3C%2Fsvg%3E");background-repeat:no-repeat;background-size:280px;color:transparent;display:block;font-size:0;height:20px;line-height:0;width:20px}.viewer-zoom-in:before{background-position:0 0;content:"Zoom In"}.viewer-zoom-out:before{background-position:-20px 0;content:"Zoom Out"}.viewer-one-to-one:before{background-position:-40px 0;content:"One to One"}.viewer-reset:before{background-position:-60px 0;content:"Reset"}.viewer-prev:before{background-position:-80px 0;content:"Previous"}.viewer-play:before{background-position:-100px 0;content:"Play"}.viewer-next:before{background-position:-120px 0;content:"Next"}.viewer-rotate-left:before{background-position:-140px 0;content:"Rotate Left"}.viewer-rotate-right:before{background-position:-160px 0;content:"Rotate Right"}.viewer-flip-horizontal:before{background-position:-180px 0;content:"Flip Horizontal"}.viewer-flip-vertical:before{background-position:-200px 0;content:"Flip Vertical"}.viewer-fullscreen:before{background-position:-220px 0;content:"Enter Full Screen"}.viewer-fullscreen-exit:before{background-position:-240px 0;content:"Exit Full Screen"}.viewer-close:before{background-position:-260px 0;content:"Close"}.viewer-container{bottom:0;direction:ltr;font-size:0;left:0;line-height:0;overflow:hidden;position:absolute;right:0;-webkit-tap-highlight-color:transparent;top:0;-ms-touch-action:none;touch-action:none;-webkit-touch-callout:none;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none}.viewer-container::-moz-selection,.viewer-container *::-moz-selection{background-color:transparent}.viewer-container::selection,.viewer-container *::selection{background-color:transparent}.viewer-container:focus{outline:0}.viewer-container img{display:block;height:auto;max-height:none!important;max-width:none!important;min-height:0!important;min-width:0!important;width:100%}.viewer-canvas{bottom:0;left:0;overflow:hidden;position:absolute;right:0;top:0}.viewer-canvas>img{height:auto;margin:15px auto;max-width:90%!important;width:auto}.viewer-footer{bottom:0;left:0;overflow:hidden;position:absolute;right:0;text-align:center}.viewer-navbar{background-color:#00000080;overflow:hidden}.viewer-list{box-sizing:content-box;height:50px;margin:0;overflow:hidden;padding:1px 0}.viewer-list>li{color:transparent;cursor:pointer;float:left;font-size:0;height:50px;line-height:0;opacity:.5;overflow:hidden;transition:opacity .15s;width:30px}.viewer-list>li:focus,.viewer-list>li:hover{opacity:.75}.viewer-list>li:focus{outline:0}.viewer-list>li+li{margin-left:1px}.viewer-list>.viewer-loading{position:relative}.viewer-list>.viewer-loading:after{border-width:2px;height:20px;margin-left:-10px;margin-top:-10px;width:20px}.viewer-list>.viewer-active,.viewer-list>.viewer-active:focus,.viewer-list>.viewer-active:hover{opacity:1}.viewer-player{background-color:#000;bottom:0;cursor:none;display:none;left:0;position:absolute;right:0;top:0;z-index:1}.viewer-player>img{left:0;position:absolute;top:0}.viewer-toolbar>ul{display:inline-block;margin:0 auto 5px;overflow:hidden;padding:6px 3px}.viewer-toolbar>ul>li{background-color:#00000080;border-radius:50%;cursor:pointer;float:left;height:24px;overflow:hidden;transition:background-color .15s;width:24px}.viewer-toolbar>ul>li:focus,.viewer-toolbar>ul>li:hover{background-color:#000c}.viewer-toolbar>ul>li:focus{box-shadow:0 0 3px #fff;outline:0;position:relative;z-index:1}.viewer-toolbar>ul>li:before{margin:2px}.viewer-toolbar>ul>li+li{margin-left:1px}.viewer-toolbar>ul>.viewer-small{height:18px;margin-bottom:3px;margin-top:3px;width:18px}.viewer-toolbar>ul>.viewer-small:before{margin:-1px}.viewer-toolbar>ul>.viewer-large{height:30px;margin-bottom:-3px;margin-top:-3px;width:30px}.viewer-toolbar>ul>.viewer-large:before{margin:5px}.viewer-tooltip{background-color:#000c;border-radius:10px;color:#fff;display:none;font-size:12px;height:20px;left:50%;line-height:20px;margin-left:-25px;margin-top:-10px;position:absolute;text-align:center;top:50%;width:50px}.viewer-title{color:#ccc;display:inline-block;font-size:12px;line-height:1.2;margin:5px 5%;max-width:90%;min-height:14px;opacity:.8;overflow:hidden;text-overflow:ellipsis;transition:opacity .15s;white-space:nowrap}.viewer-title:hover{opacity:1}.viewer-button{-webkit-app-region:no-drag;background-color:#00000080;border-radius:50%;cursor:pointer;height:80px;overflow:hidden;position:absolute;right:-40px;top:-40px;transition:background-color .15s;width:80px}.viewer-button:focus,.viewer-button:hover{background-color:#000c}.viewer-button:focus{box-shadow:0 0 3px #fff;outline:0}.viewer-button:before{bottom:15px;left:15px;position:absolute}.viewer-fixed{position:fixed}.viewer-open{overflow:hidden}.viewer-show{display:block}.viewer-hide{display:none}.viewer-backdrop{background-color:#00000080}.viewer-invisible{visibility:hidden}.viewer-move{cursor:move;cursor:grab}.viewer-fade{opacity:0}.viewer-in{opacity:1}.viewer-transition{transition:all .3s}@keyframes viewer-spinner{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.viewer-loading:after{animation:viewer-spinner 1s linear infinite;border:4px solid rgba(255,255,255,.1);border-left-color:#ffffff80;border-radius:50%;content:"";display:inline-block;height:40px;left:50%;margin-left:-20px;margin-top:-20px;position:absolute;top:50%;width:40px;z-index:1}@media (max-width: 767px){.viewer-hide-xs-down{display:none}}@media (max-width: 991px){.viewer-hide-sm-down{display:none}}@media (max-width: 1199px){.viewer-hide-md-down{display:none}}.viewer-container{background-color:#000000e6}.custom-viewer-controls{position:fixed;bottom:20px;right:20px;display:flex;gap:10px;z-index:1060}.custom-viewer-btn{width:40px;height:40px;color:#fff;background-color:#00000080;border:none;border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background-color .2s}.custom-viewer-btn:hover{background-color:#000c}.custom-viewer-btn svg{width:20px;height:20px;color:#fff}.custom-viewer-btn.download-btn{background-color:#2ecc71cc}.custom-viewer-btn.download-btn:hover{background-color:#2ecc71}.custom-viewer-btn.delete-btn{background-color:#e74c3ccc}.custom-viewer-btn.delete-btn:hover{background-color:#e74c3c}.side-nav-btn{position:fixed;top:50%;transform:translateY(-50%);width:50px;height:50px;background-color:#0000004d;border:none;border-radius:50%;color:#fff;cursor:pointer;display:flex;align-items:center;justify-content:center;z-index:1060;transition:background-color .2s}.side-nav-btn:hover{background-color:#0009}.side-nav-btn.prev{left:20px}.side-nav-btn.next{right:20px}.side-nav-btn svg{width:24px;height:24px}.photo-gallery[data-v-188c9d93]{width:100%}.empty-gallery[data-v-188c9d93]{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:3rem 1rem;background-color:#fff;border-radius:12px;box-shadow:0 2px 4px #0000001a;text-align:center}.empty-icon[data-v-188c9d93]{font-size:3rem;margin-bottom:1rem}.empty-text[data-v-188c9d93]{font-size:1.2rem;font-weight:600;color:#2c3e50;margin-bottom:.5rem}.empty-hint[data-v-188c9d93]{color:#7f8c8d;font-size:.9rem;max-width:300px}.gallery-grid[data-v-188c9d93]{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:.5rem}.photo-item[data-v-188c9d93]{position:relative;overflow:hidden;border-radius:8px;cursor:pointer;aspect-ratio:1 / 1;background-color:#f1f1f1}.photo-img[data-v-188c9d93]{width:100%;height:100%;object-fit:cover;transition:transform .3s}.photo-overlay[data-v-188c9d93]{position:absolute;bottom:0;left:0;right:0;background:linear-gradient(transparent,#000000b3);padding:.5rem;color:#fff;opacity:0;transition:opacity .3s}.photo-item:hover .photo-overlay[data-v-188c9d93]{opacity:1}.photo-item:hover .photo-img[data-v-188c9d93]{transform:scale(1.05)}.photo-info[data-v-188c9d93]{display:flex;flex-direction:column;gap:.25rem}.photo-user[data-v-188c9d93]{font-weight:600;font-size:.8rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.photo-time[data-v-188c9d93]{font-size:.7rem;opacity:.8}.photo-actions[data-v-188c9d93]{position:absolute;top:.5rem;right:.5rem;display:flex;gap:.5rem}.action-button[data-v-188c9d93]{width:30px;height:30px;border-radius:50%;color:#fff;border:none;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:background-color .2s}.download-button[data-v-188c9d93]{background-color:#2ecc71cc}.download-button[data-v-188c9d93]:hover{background-color:#2ecc71}.delete-button[data-v-188c9d93]{background-color:#e74c3ccc}.delete-button[data-v-188c9d93]:hover{background-color:#e74c3c}@media (min-width: 640px){.gallery-grid[data-v-188c9d93]{grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:1rem}}.photo-gallery-tool[data-v-6a2183bc]{max-width:1200px;margin:0 auto;padding:1.5rem}.loading[data-v-6a2183bc],.error[data-v-6a2183bc]{display:flex;flex-direction:column;justify-content:center;align-items:center;min-height:60vh;text-align:center;padding:2rem}.loading-spinner[data-v-6a2183bc]{width:40px;height:40px;border:4px solid rgba(0,0,0,.1);border-left-color:#4a6bdf;border-radius:50%;animation:spin-6a2183bc 1s linear infinite;margin-bottom:1rem}@keyframes spin-6a2183bc{to{transform:rotate(360deg)}}.error[data-v-6a2183bc]{color:#e74c3c}.error-icon[data-v-6a2183bc]{width:50px;height:50px;border-radius:50%;background-color:#e74c3c;color:#fff;font-size:2rem;font-weight:700;display:flex;justify-content:center;align-items:center;margin-bottom:1rem}.tool-content[data-v-6a2183bc]{display:flex;flex-direction:column;gap:1.5rem}.card[data-v-6a2183bc]{background-color:#fff;border-radius:12px;overflow:hidden;box-shadow:0 4px 6px #0000001a,0 1px 3px #00000014}.card-header[data-v-6a2183bc]{display:flex;justify-content:space-between;align-items:center;padding:1rem 1.5rem;background-color:#f8f9fa;border-bottom:1px solid #dfe6e9}h2[data-v-6a2183bc]{margin:0;font-size:1.1rem;color:#2c3e50;font-weight:600}.photo-count[data-v-6a2183bc]{background-color:#4a6bdf;color:#fff;padding:.25rem .5rem;border-radius:20px;font-size:.8rem;font-weight:500}.gallery-header[data-v-6a2183bc]{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.gallery-title[data-v-6a2183bc]{font-size:1.2rem;color:#2c3e50;font-weight:600}.gallery-actions[data-v-6a2183bc]{display:flex;gap:.5rem}.download-all-button[data-v-6a2183bc]{display:flex;align-items:center;gap:.5rem;background-color:#2ecc71;color:#fff;border:none;border-radius:8px;padding:.5rem 1rem;font-size:.9rem;cursor:pointer;transition:background-color .2s;font-weight:500}.download-all-button[data-v-6a2183bc]:hover{background-color:#27ae60}.download-all-button[data-v-6a2183bc]:disabled{background-color:#95a5a6;cursor:not-allowed}.download-progress-container[data-v-6a2183bc]{margin-bottom:1rem;padding:.75rem;background-color:#fff;border-radius:8px;box-shadow:0 1px 3px #0000001a}.download-progress-bar[data-v-6a2183bc]{height:8px;background-color:#ecf0f1;border-radius:4px;overflow:hidden;margin-bottom:.5rem}.download-progress-inner[data-v-6a2183bc]{height:100%;background-color:#2ecc71;border-radius:4px;transition:width .3s ease}.download-progress-text[data-v-6a2183bc]{font-size:.8rem;color:#7f8c8d;text-align:center}.photo-tips[data-v-6a2183bc]{background-color:#fff;border-radius:8px;padding:1rem 1.5rem;margin-top:1rem;box-shadow:0 1px 3px #0000001a}.photo-tips h3[data-v-6a2183bc]{font-size:1rem;color:#2c3e50;margin-bottom:.75rem}.photo-tips ul[data-v-6a2183bc]{padding-left:1.5rem;margin:0}.photo-tips li[data-v-6a2183bc]{color:#7f8c8d;font-size:.9rem;margin-bottom:.5rem;line-height:1.5}
