:root{--header-height:80px}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;margin:0}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}.btn{align-items:center;border:1px solid #0000;border-radius:.375rem;box-sizing:border-box;cursor:pointer;display:inline-flex;font-family:var(--font-family);font-weight:500;gap:.5rem;justify-content:center;line-height:1.2;position:relative;text-decoration:none;transition:all .3s ease;-webkit-user-select:none;user-select:none;white-space:nowrap;z-index:1}.btn:focus{box-shadow:0 0 0 2px #61dafb33;outline:none}.btn:disabled{cursor:not-allowed;opacity:.6;pointer-events:none;transform:none!important}.btn:not(:disabled):hover{transform:translateY(-1px)}.btn:not(:disabled):active{transform:translateY(0)}.btn-sm{font-size:clamp(.75rem,2vw,.875rem);line-height:1.25rem;min-height:2rem;min-width:4rem;padding:clamp(.5rem,1.5vw,.625rem) clamp(.75rem,2vw,1rem)}.btn{font-size:clamp(.875rem,2.5vw,1rem);line-height:1.5rem;min-height:2.5rem;min-width:6rem;padding:clamp(.625rem,2vw,.75rem) clamp(1rem,3vw,1.25rem)}.btn-lg{font-size:clamp(1rem,3vw,1.125rem);line-height:1.75rem;min-height:3rem;min-width:8rem;padding:clamp(.75rem,2.5vw,1rem) clamp(1.25rem,4vw,1.5rem)}.btn-primary{background-color:var(--button-primary);border-color:var(--button-primary);color:var(--on-primary)}.btn-primary:hover:not(:disabled){background-color:var(--button-primary-hover);border-color:var(--button-primary-hover);box-shadow:0 4px 8px #1976d24d}.btn-primary:active:not(:disabled){box-shadow:0 2px 4px #1976d233}.btn-secondary{background-color:var(--button-secondary);border-color:var(--button-secondary);color:var(--on-primary)}.btn-secondary:hover:not(:disabled){background-color:var(--button-secondary-hover);border-color:var(--button-secondary-hover);box-shadow:0 4px 8px #4242424d}.btn-secondary:active:not(:disabled){box-shadow:0 2px 4px #42424233}.btn-tertiary{background-color:initial;border:1.5px solid var(--button-primary);color:var(--button-primary)}.btn-tertiary:hover:not(:disabled){background-color:#1976d214;border-color:var(--button-primary-hover);color:var(--button-primary-hover)}.btn-tertiary:active:not(:disabled){background-color:#1976d21f}.btn-danger{background-color:var(--button-danger);border-color:var(--button-danger);color:var(--on-primary)}.btn-danger:hover:not(:disabled){background-color:var(--button-danger-hover);border-color:var(--button-danger-hover);box-shadow:0 4px 8px #d32f2f4d}.btn-danger:active:not(:disabled){box-shadow:0 2px 4px #d32f2f33}.btn-success{background-color:var(--button-success);border-color:var(--button-success);color:var(--on-primary)}.btn-success:hover:not(:disabled){background-color:var(--button-success-hover);border-color:var(--button-success-hover);box-shadow:0 4px 8px #2e7d324d}.btn-success:active:not(:disabled){box-shadow:0 2px 4px #2e7d3233}.btn-warning{background-color:var(--button-warning);border-color:var(--button-warning);color:var(--on-primary)}.btn-warning:hover:not(:disabled){background-color:var(--button-warning-hover);border-color:var(--button-warning-hover);box-shadow:0 4px 8px #ed6c024d}.btn-warning:active:not(:disabled){box-shadow:0 2px 4px #ed6c0233}.btn svg{flex-shrink:0;height:1em;width:1em}.btn-sm svg{height:.875em;width:.875em}.btn-lg svg{height:1.125em;width:1.125em}.btn.loading{color:#0000;position:relative}.btn.loading:after{animation:button-spin .75s linear infinite;border:2px solid;border-radius:50%;border-right:2px solid #0000;content:"";height:1em;left:50%;margin:-.5em 0 0 -.5em;position:absolute;top:50%;width:1em}@keyframes button-spin{to{transform:rotate(1turn)}}@media screen and (max-width:440px){.btn{font-size:.875rem;min-height:2.25rem;min-width:4.5rem;padding:.5rem .75rem}.btn-sm{font-size:.75rem;min-height:1.75rem;min-width:3rem;padding:.375rem .5rem}.btn-lg{font-size:1rem;min-height:2.75rem;min-width:6rem;padding:.625rem 1rem}}@media screen and (min-width:1024px){.btn{font-size:1rem;min-height:2.5rem;min-width:6.5rem;padding:.625rem 1.25rem}.btn-sm{font-size:.875rem;min-height:2rem;min-width:4.5rem;padding:.5rem .75rem}.btn-lg{font-size:1.125rem;min-height:3rem;min-width:8.5rem;padding:.75rem 1.5rem}}@media screen and (min-width:1200px){.btn{font-size:1.125rem;min-height:2.75rem;min-width:7rem;padding:.75rem 1.5rem}.btn-sm{font-size:1rem;min-height:2.25rem;min-width:5rem;padding:.625rem 1rem}.btn-lg{font-size:1.25rem;min-height:3.25rem;min-width:9rem;padding:1rem 2rem}}@media (prefers-color-scheme:dark){.btn-tertiary{color:var(--button-primary)}.btn-tertiary:hover:not(:disabled){background-color:#1976d21a}.btn-tertiary:active:not(:disabled){background-color:#1976d226}}.login-form{background-color:var(--surface);border-radius:.75rem;color:var(--on-primary);display:flex;flex-direction:column;font-family:var(--font-family);gap:1.5rem;max-width:30rem;padding:1.5rem;width:90%}.login-title{line-height:1.4;margin:0;text-align:center;white-space:nowrap}.input-group{gap:.5rem}.password-input-container{align-items:center;display:flex;position:relative}.password-toggle-btn{background:none;border:none;border-radius:.25rem;color:var(--gray-500);cursor:pointer;padding:.25rem;position:absolute;right:.625rem;transition:color .2s ease}.login-form input{background-color:var(--gray-900);border:1px solid var(--border);border-radius:.375rem;color:var(--on-primary);font-size:1rem;padding:.625rem;width:100%}.password-input-container input{padding-right:2.5rem}.message{color:var(--error-color);font-size:.95rem;text-align:center}@media screen and (max-width:440px){.login-form{border-radius:.5rem;gap:1rem;max-width:100%;padding:1rem;width:95%}.login-title{font-size:1.75rem;line-height:1.3;padding:1rem}.input-group{gap:.375rem}.login-form input{border-radius:.25rem;font-size:.875rem;padding:.5rem}.password-input-container input{padding-right:2rem}.password-toggle-btn{font-size:.875rem;padding:.125rem;right:.5rem}.message{font-size:.875rem}}@media screen and (min-width:1024px){.login-form{border-radius:1rem;gap:1.75rem;max-width:35rem;padding:2rem;width:85%}.login-title{font-size:1.75rem;line-height:1.4}.input-group{gap:.75rem}.login-form input{border-radius:.5rem;font-size:1.125rem;padding:.875rem}.password-input-container input{padding-right:3rem}.password-toggle-btn{font-size:1rem;padding:.375rem;right:.75rem}.message{font-size:1rem}}@media screen and (min-width:1200px){.login-form{border-radius:1.25rem;gap:2rem;max-width:40rem;padding:2.5rem;width:80%}.login-title{font-size:2rem;line-height:1.4}.input-group{gap:1rem}.login-form input{border-radius:.625rem;font-size:1.25rem;padding:1rem}.password-input-container input{padding-right:3.5rem}.password-toggle-btn{font-size:1.125rem;padding:.5rem;right:1rem}.message{font-size:1.125rem}}.login-container{align-items:center;background:linear-gradient(135deg,#1a1a2e,#16213e 50%,#0f3460);bottom:0!important;box-sizing:border-box;display:flex;height:100vh!important;justify-content:center;left:0!important;margin:0!important;overflow:hidden;padding:0!important;position:fixed!important;right:0!important;top:0!important;width:100vw!important}.login-content{background:var(--surface);border-radius:0;box-shadow:none;height:100%;max-width:none;min-height:100vh;width:100%}.login-content,.login-image-section{display:flex;margin:0;overflow:hidden;padding:0}.login-image-section{background:linear-gradient(135deg,#667eea,#764ba2);flex:1 1}.login-image,.login-image-section{align-items:center;justify-content:center;position:relative}.login-image{display:flex;height:100%;margin:0;padding:0;width:100%}.login-image:before{background:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 100 100'%3E%3Cdefs%3E%3Cpattern id='a' width='10' height='10' patternUnits='userSpaceOnUse'%3E%3Cpath d='M10 0H0v10' fill='none' stroke='rgba(255,255,255,0.1)' stroke-width='.5'/%3E%3C/pattern%3E%3C/defs%3E%3Cpath fill='url(%23a)' d='M0 0h100v100H0z'/%3E%3C/svg%3E");bottom:0;content:"";left:0;opacity:.3;position:absolute;right:0;top:0}.image-placeholder{color:#fff;margin:0;position:relative;text-align:center;z-index:1}.image-placeholder .material-symbols-outlined{font-size:4rem;margin-bottom:1rem;opacity:.9}.image-placeholder h3{font-size:2rem;font-weight:300;letter-spacing:.1em;margin:0 0 .5rem}.image-placeholder p{font-size:1rem;font-weight:300;margin:0;opacity:.8}.login-form-section{align-items:center;background:var(--surface);display:flex;flex:1 1;justify-content:center;margin:0}@media screen and (max-width:440px){.login-content{flex-direction:column;min-height:100vh}.login-image-section{flex:none;min-height:7rem}.login-form-section{flex:1 1;padding:1rem}.image-placeholder .material-symbols-outlined{font-size:2rem;margin-bottom:.5rem}.image-placeholder h3{font-size:1rem}.image-placeholder p{font-size:.5rem}}@media screen and (min-width:1024px){.login-content{max-width:none}.image-placeholder .material-symbols-outlined{font-size:4.5rem}.image-placeholder h3{font-size:2.25rem}.image-placeholder p{font-size:1.1rem}}@media screen and (min-width:1200px){.login-content{max-width:none}.image-placeholder .material-symbols-outlined{font-size:5rem}.image-placeholder h3{font-size:2.5rem}.image-placeholder p{font-size:1.2rem}}@media screen and (orientation:landscape) and (max-height:600px){.login-container{min-height:100vh;padding:0!important}.login-content{min-height:100vh}}.loading-container{align-items:center;animation:fadeIn .5s ease-out;display:flex;flex-direction:column;justify-content:center;padding:3rem 2rem;text-align:center}.loading-spinner{height:80px;margin-bottom:1.5rem;position:relative;width:80px}.spinner-ring{animation:spin 1.5s linear infinite;border:3px solid #0000;border-radius:50%;height:100%;left:0;position:absolute;top:0;width:100%}.spinner-ring:first-child{animation-delay:0s;border-top-color:#4a9eff}.spinner-ring:nth-child(2){animation-delay:.5s;animation-duration:2s;border-right-color:#3a8eef}.spinner-ring:nth-child(3){animation-delay:1s;animation-duration:1.5s;border-bottom-color:#4a9eff66}.loading-message{animation:pulse 2s ease-in-out infinite;color:#ffffffb3;font-size:1.1rem;font-weight:500;margin:0}@keyframes pulse{0%,to{opacity:.7}50%{opacity:.9}}@media (max-width:768px){.loading-container{padding:2rem 1rem}.loading-spinner{height:60px;margin-bottom:1rem;width:60px}.spinner-ring{border-width:2px}.loading-message{font-size:1rem}}@media (max-width:440px){.loading-container{padding:1.5rem .5rem}.loading-spinner{height:50px;width:50px}.loading-message{font-size:.9rem}}@media (prefers-reduced-motion:reduce){.loading-container,.loading-message,.spinner-ring{animation:none}}@media (prefers-color-scheme:dark){.loading-message{color:#fffc}}.dashboard-layout{display:flex;flex-direction:column;min-height:100vh;overflow:visible;width:100%}.dashboard-main{overflow-x:hidden;overflow-y:visible;padding:1rem}.dashboard-container,.dashboard-main{display:flex;flex:1 1;flex-direction:column}.dashboard-container{background-color:var(--bg-primary);color:var(--on-primary);overflow:hidden}.dashboard-content{-ms-overflow-style:none;box-sizing:border-box;flex:1 1;min-height:0;overflow-x:hidden;overflow-y:hidden;scrollbar-width:none}.dashboard-content::-webkit-scrollbar{display:none}.dashboard-content.scrollable{-ms-overflow-style:auto;overflow-y:auto;scrollbar-width:auto}.dashboard-content.scrollable::-webkit-scrollbar{display:block;width:clamp(.5rem,1vw,.75rem)}.dashboard-content.scrollable::-webkit-scrollbar-track{background:var(--gray-900);border-radius:.25rem}.dashboard-content.scrollable::-webkit-scrollbar-thumb{background:var(--gray-600);border-radius:.25rem;-webkit-transition:background-color .2s ease;transition:background-color .2s ease}.dashboard-content.scrollable::-webkit-scrollbar-thumb:hover{background:var(--gray-500)}@media screen and (max-width:440px){.dashboard-main{padding:1rem}.dashboard-content{font-size:.9rem}}@media screen and (min-width:1024px){.dashboard-main{padding:1.5rem}.dashboard-content{font-size:1rem}}@media screen and (min-width:1200px){.dashboard-main{padding:2rem}.dashboard-content{font-size:1.1rem}}.card{margin:1rem;max-width:80%}.card p{color:var(--on-primary);font-size:1rem;line-height:1.6;margin:10px 0}.card strong{color:var(--accent-hover)}.info-section-title{border-bottom:1px solid var(--border);color:var(--accent);font-size:1.3rem;margin:30px 0 15px;padding-bottom:5px}.modal-overlay{align-items:center;animation:fadeIn .2s ease-out;background-color:#00000080;bottom:0;display:flex;height:100vh;justify-content:center;left:0;padding:1rem;pointer-events:all;position:fixed;right:0;top:0;width:100vw;z-index:999999}.modal{animation:slideIn .3s ease-out;background:var(--surface);border:1px solid var(--border);border-radius:.75rem;box-shadow:0 10px 25px #0003;display:flex;flex-direction:column;margin:0 auto;max-height:90vh;max-width:90vw;padding:0;position:relative;z-index:1000000}.modal-small{min-width:320px;width:400px}.modal-medium{min-width:480px;width:600px}.modal-large{min-width:640px;width:800px}.modal-header{align-items:center;border-bottom:1px solid var(--border);display:flex;justify-content:space-between;margin-bottom:0;min-height:3.5rem;padding:1.25rem 2rem .75rem}.modal-title{color:var(--on-primary);flex:1 1;font-size:1.25rem;font-weight:600;margin:0 auto;text-align:center}.modal-close{align-items:center;background:none;border:none;border-radius:.25rem;color:var(--on-primary);cursor:pointer;display:flex;font-size:1.5rem;font-weight:700;height:2rem;justify-content:center;line-height:1;margin-left:.5rem;padding:.25rem;transition:background-color .2s;width:2rem}.modal-close:hover{background-color:var(--shadow-light)}.modal-content{color:var(--on-primary);flex:1 1;overflow-y:auto;padding:1.25rem 2rem;text-align:center}.modal-actions{border-top:1px solid var(--border);display:flex;gap:.75rem;justify-content:space-between;margin-top:0;padding:1rem 2rem 1.5rem}.modal-action-btn{border:none;border-radius:.375rem;cursor:pointer;font-size:.875rem;font-weight:500;min-width:80px;padding:.75rem 1.5rem;transition:all .2s}.modal-action-btn.btn-small{font-size:.75rem;min-width:60px;padding:.5rem 1rem}.modal-action-btn.btn-medium{font-size:.875rem;min-width:80px;padding:.75rem 1.5rem}.modal-action-btn.btn-large{font-size:1rem;min-width:100px;padding:1rem 2rem}.modal-action-btn:disabled{cursor:not-allowed;opacity:.5}.modal-action-btn.primary{background-color:var(--button-primary);color:#fff}.modal-action-btn.primary:hover:not(:disabled){background-color:var(--button-primary-hover)}.modal-action-btn.secondary{background-color:var(--button-secondary);color:var(--on-primary)}.modal-action-btn.secondary:hover:not(:disabled){background-color:var(--button-secondary-hover)}.modal-action-btn.danger{background-color:var(--button-danger);color:#fff}.modal-action-btn.danger:hover:not(:disabled){background-color:var(--button-danger-hover)}@media screen and (max-width:440px){.modal-overlay{padding:.5rem}.modal{border-radius:.5rem;max-height:95vh;max-width:100%;width:100%}.modal-large,.modal-medium,.modal-small{min-width:auto;width:100%}.modal-header{padding:.75rem .75rem .5rem}.modal-content{padding:.75rem}.modal-actions{flex-direction:column;gap:.5rem;padding:.5rem .75rem .75rem}.modal-action-btn{font-size:.875rem;padding:.5rem 1rem;width:100%}}@media screen and (min-width:1024px){.modal-overlay{padding:1rem}.modal{border-radius:.75rem;max-height:90vh;max-width:80%}.modal-small{max-width:30rem}.modal-medium{max-width:50rem}.modal-large{max-width:70rem}.modal-header{padding:1.5rem 1.5rem 1rem}.modal-content{padding:1.5rem}.modal-actions{flex-direction:row;gap:1rem;padding:1rem 1.5rem 1.5rem}.modal-action-btn{font-size:1rem;padding:.75rem 1.5rem;width:auto}}@media screen and (min-width:1200px){.modal-overlay{padding:1.5rem}.modal{border-radius:1rem;max-height:85vh;max-width:70%}.modal-small{max-width:35rem}.modal-medium{max-width:60rem}.modal-large{max-width:80rem}.modal-header{padding:2rem 2rem 1.5rem}.modal-content{padding:2rem}.modal-actions{gap:1.5rem;padding:1.5rem 2rem 2rem}.modal-action-btn{font-size:1.125rem;padding:1rem 2rem}}.action-buttons{justify-content:center;margin:1rem;width:100%}.action-buttons,.select-btn{align-items:center;display:flex}.select-btn{gap:.375rem}.select-btn .material-icons{font-size:1.1rem}@media screen and (max-width:440px){.action-buttons{flex-direction:column;gap:.75rem;margin:.75rem}.left-buttons{align-items:center;flex-direction:column;justify-content:center;width:100%}.select-btn{gap:.25rem}.select-btn .material-icons{font-size:1rem}}@media screen and (min-width:1024px){.action-buttons{flex-direction:row;gap:1.5rem;margin:1.5rem}.left-buttons{align-items:center;flex-direction:row;justify-content:center;width:auto}.select-btn{gap:.5rem}.select-btn .material-icons{font-size:1.25rem}}@media screen and (min-width:1200px){.action-buttons{gap:2rem;margin:2rem}.select-btn{gap:.75rem}.select-btn .material-icons{font-size:1.5rem}}.alert{background:#fff;border-left:5px solid;border-radius:.5rem;box-shadow:0 2px 8px #00000014;font-size:1rem;font-weight:500;gap:.75rem;margin:1rem 0;max-width:480px;min-width:280px;padding:1rem 1.5rem;position:relative}.alert,.alert-icon{align-items:center;display:flex}.alert-icon{margin-right:.5rem}.alert-message{flex:1 1}.alert-close{background:none;border:none;border-radius:.25rem;color:#888;cursor:pointer;font-size:1.25rem;font-weight:700;padding:.25rem .5rem;transition:background .2s}.alert-close:hover{background:#eee}.alert-info{background:#e3f2fd;border-left-color:#2196f3;color:#1565c0}.alert-success{background:#e8f5e9;border-left-color:#4caf50;color:#256029}.alert-warning{background:#fff3e0;border-left-color:#ff9800;color:#b26a00}.alert-danger{background:#ffebee;border-left-color:#f44336;color:#b71c1c}.account-page-container{align-items:center;background-color:var(--bg-primary);display:flex;flex-direction:column;width:100%}.account-page-container>*{max-width:80%}.status-message{background-color:var(--surface);border-radius:10px;font-size:1.2rem;padding:20px}@media screen and (max-width:440px){.page-title{margin:1rem!important}.account-page-container>*{max-width:95%;width:100%}.status-message{border-radius:.5rem;font-size:1rem;margin:.5rem 0;padding:1rem}}@media screen and (min-width:1024px){.account-page-container{padding:1.5rem}.account-page-container>*{max-width:70%;width:100%}.status-message{border-radius:.75rem;font-size:1.25rem;margin:1rem 0;padding:1.5rem}}@media screen and (min-width:1200px){.account-page-container{padding:2rem}.account-page-container>*{max-width:60%;width:100%}.status-message{border-radius:1rem;font-size:1.375rem;margin:1.5rem 0;padding:2rem}}.fullscreen-black{background-color:#000;height:100vh;left:0;position:fixed;top:0;transform:translateZ(0);-webkit-transform:translateZ(0);width:100vw;will-change:transform;z-index:9999}.fullscreen-black,.media-box{align-items:center;display:flex;justify-content:center}.media-box{height:80vh;overflow:hidden;width:80vw}.fit-media{height:100%;object-fit:contain;width:100%}@media screen and (max-width:440px){.media-box{height:85vh;width:95vw}}@media screen and (min-width:431px) and (max-width:1023px){.media-box{height:82vh;width:85vw}}@media screen and (min-width:1024px){.media-box{height:80vh;width:80vw}}@media screen and (min-width:1200px){.media-box{height:75vh;width:75vw}}.fullscreen-black{overflow:hidden}body.fullscreen-mode{height:100%;overflow:hidden;position:fixed;width:100%}@supports (-webkit-appearance:none){.fullscreen-black{backface-visibility:hidden!important;-webkit-backface-visibility:hidden!important;contain:layout style paint!important;height:100vh!important;isolation:isolate!important;left:0!important;perspective:1000px!important;-webkit-perspective:1000px!important;position:fixed!important;top:0!important;transform:translateZ(0)!important;-webkit-transform:translateZ(0)!important;width:100vw!important;z-index:2147483647!important}.media-box{transform:translateZ(0);-webkit-transform:translateZ(0)}.fullscreen-black *{z-index:inherit!important}}@media screen and (-webkit-min-device-pixel-ratio:0){.fullscreen-black{height:100vh!important;left:0!important;position:fixed!important;top:0!important;transform:translateZ(0)!important;-webkit-transform:translateZ(0)!important;width:100vw!important;z-index:2147483647!important}}:-moz-full-screen img,:-moz-full-screen video,:-ms-fullscreen img,:-ms-fullscreen video,:-webkit-full-screen img,:-webkit-full-screen video,:fullscreen img,:fullscreen video{background-color:#000;display:block;height:auto;left:50%;margin:0;max-height:80vh;max-width:80vw;object-fit:contain;padding:0;position:fixed;top:50%;transform:translate(-50%,-50%);width:auto;z-index:9999}.media-item{height:100%}.media-image-container{display:flex;justify-content:center;max-height:calc(100% - 4rem);position:relative;width:100%}.fullscreen-icon{align-items:center;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background-color:#000000b3;border:1px solid #fff3;border-radius:.375rem;color:#fff;cursor:pointer;display:flex;height:2.25rem;justify-content:center;padding:.375rem;position:absolute;right:.75rem;top:.75rem;transition:all .2s ease;width:2.25rem;z-index:10}.fullscreen-icon:hover{background-color:#000000e6;border-color:#fff6;transform:scale(1.1)}.fullscreen-icon svg{height:1.125rem;width:1.125rem}.media-slide .media-caption{background-color:#f9fafb;border:.0625rem solid #e5e7eb;border-radius:.375rem;box-sizing:border-box;flex-shrink:0;font-size:.875rem;font-weight:600;padding:.5rem .75rem;text-align:center;width:100%}.media-slide .media-description-section{display:flex;flex:1 1;flex-direction:column;text-align:left;width:100%}@media screen and (max-width:440px){.media-image-container{aspect-ratio:16/9!important;max-height:calc(100% - 2rem)!important}.media-caption{font-size:.625rem!important;margin-bottom:.25rem!important;padding:.25rem .5rem!important}.media-description{font-size:.625rem!important;line-height:1.3!important;padding:.25rem!important}.fullscreen-icon{height:1.5rem!important;padding:.25rem!important;right:.5rem!important;top:.5rem!important;width:1.5rem!important}.fullscreen-icon svg{height:.75rem!important;width:.75rem!important}.media-item{gap:.25rem!important}}.media-slide .media-description{background-color:#f9fafb;border:auto solid var(--gray-300);border-radius:.375rem;flex:1 1;font-size:.75rem;line-height:1.5;padding:.5rem;text-align:left;white-space:pre-wrap}.media-slide .media-description::-webkit-scrollbar{width:.375rem}.media-slide .media-description::-webkit-scrollbar-track{background:#f1f1f1;border-radius:.1875rem}.media-slide .media-description::-webkit-scrollbar-thumb{background:#c1c1c1;border-radius:.1875rem}.media-slide .media-description::-webkit-scrollbar-thumb:hover{background:#a8a8a8}@media (max-width:47.9375rem){.fullscreen-icon{height:2rem;padding:.25rem;right:.5rem;top:.5rem;width:2rem}.fullscreen-icon svg{height:1rem;width:1rem}.media-caption,.media-description{font-size:.8125rem;padding:.375rem .625rem}.media-description{max-height:5rem}}.media-slideshow-wrapper{box-sizing:border-box;overflow:hidden;padding:0 3rem;position:relative}.media-slide-loading,.media-slideshow-wrapper{align-items:center;display:flex;height:100%;justify-content:center;width:100%}.media-slide-loading{background-color:#f8f9fa}.media-loading-container{align-items:center;display:flex;flex-direction:column;gap:1rem;justify-content:center}.media-loading-spinner{animation:spin 1s linear infinite;border:4px solid #e3e3e3;border-radius:50%;border-top-color:#007bff;height:40px;width:40px}.media-loading-text{color:#666;font-size:14px;font-weight:500}.media-slideshow-nav-area{align-items:center;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);cursor:pointer;display:flex;justify-content:center;position:absolute;top:.5rem;transition:all .3s ease;width:2.5rem;z-index:10}.media-slideshow-nav-area,.media-slideshow-nav-left{background:linear-gradient(90deg,#fffc,#fff6);height:calc(100% - 1rem)}.media-slideshow-nav-left{left:.5rem}.media-slideshow-nav-right{background:linear-gradient(270deg,#fffc,#fff6);height:calc(100% - 1rem);right:.5rem}.media-slideshow-nav-area:hover{transform:scale(1.05)}.media-slideshow-nav-area:hover,.media-slideshow-nav-left:hover{background:linear-gradient(90deg,#3b82f61a,#3b82f60d)}.media-slideshow-nav-right:hover{background:linear-gradient(270deg,#3b82f61a,#3b82f60d)}.media-slideshow-nav-arrow{align-items:center;background:#ffffffe6;border-radius:50%;box-shadow:0 .25rem .5rem #00000026;display:flex;height:2.5rem;justify-content:center;transition:all .3s ease;width:2.5rem}.media-slideshow-nav-area:hover .media-slideshow-nav-arrow{background:#3b82f61a;box-shadow:0 .375rem .75rem #3b82f633;transform:scale(1.1)}.media-slideshow-nav-arrow .material-symbols-outlined{color:#3b82f6;font-size:1.5rem;font-weight:600}.media-slideshow-nav-area:hover .media-slideshow-nav-arrow .material-symbols-outlined{color:#2563eb}.media-slideshow{align-items:center;box-sizing:border-box;display:flex;flex-direction:column;height:28.125rem;justify-content:center;margin:0 auto;max-height:28.125rem;max-width:50vw;min-height:11.25rem;min-width:20rem;position:relative;width:100%}@media screen and (max-width:440px){.media-slideshow{height:100%!important;margin:0!important;max-height:100%!important;max-width:100%!important;min-height:100%!important;min-width:100%!important;width:100%!important}}.media-slideshow-content{display:flex;flex-direction:column;overflow:hidden;width:100%}.viewer-section{margin-bottom:1.25rem;width:100%}.viewer-label{color:#374151;display:block;font-size:.9375rem;font-weight:600;margin-bottom:.5rem}.viewer-field{background-color:#f9fafb;border:.0625rem solid #e5e7eb;border-radius:.375rem;color:#1f2937;font-size:.9375rem;line-height:1.5;padding:.625rem .875rem}.viewer-title{background-color:#fff;border:.125rem solid #e5e7eb;color:#1a1a1a;font-size:1.125rem;font-weight:600}.viewer-thumbnail-container{background-color:#f9fafb;border:.0625rem solid #e5e7eb;border-radius:.375rem;display:flex;justify-content:center;padding:.75rem}.marker-viewer-label{align-items:center;background-color:#fff;border:.125rem solid #e5e7eb;display:flex;gap:.5rem}@media screen and (max-width:440px){.media-slideshow{height:auto!important}.marker-viewer-label{box-sizing:border-box!important;width:100%!important}.media-slideshow-nav-area{height:calc(100% - .5rem);margin:.25rem;top:.25rem}.media-slideshow-nav-left,.media-slideshow-nav-right{height:calc(100% - .5rem)}}.marker-viewer-label__dot{border-radius:50%;box-shadow:0 0 0 .0625rem #0000001a;display:inline-block;height:.875rem;width:.875rem}.marker-viewer-edit-button-wrap{display:flex;justify-content:flex-end}.marker-viewer-edit-button{align-items:center;background-color:#3b82f6;border:none;border-radius:.375rem;color:#fff;cursor:pointer;display:inline-flex;font-size:.875rem;font-weight:600;justify-content:center;line-height:1.2;min-height:2.25rem;min-width:4.5rem;padding:.5rem 1rem;text-decoration:none;transition:all .2s ease}.marker-viewer-edit-button:hover{background-color:#2563eb;transform:translateY(-.0625rem)}.media-slide{aspect-ratio:unset!important;box-sizing:border-box!important;display:flex;flex:1 1;flex-direction:column;gap:.25rem!important;height:100%!important;margin:0!important;max-height:100%!important;min-height:0;overflow-x:hidden;overflow-y:auto;text-align:center;width:100%!important}.media-slide-metadata{align-items:stretch;height:100%;justify-content:flex-start;max-height:100%}.media-slide-content{align-items:center;height:100%;justify-content:center;margin-bottom:3rem;max-height:100%}.media-slide::-webkit-scrollbar{width:.375rem}.media-slide::-webkit-scrollbar-track{background:#f1f1f1;border-radius:.25rem}.media-slide::-webkit-scrollbar-thumb{background:#c1c1c1;border-radius:.25rem}.media-slide::-webkit-scrollbar-thumb:hover{background:#a8a8a8}.media-slide-image,.media-slide-video{border-radius:.375rem;box-shadow:0 .125rem .25rem #0000001a;flex-shrink:0;height:auto;max-height:calc(100% - 1rem);max-width:100%;min-height:10rem;object-fit:contain;width:100%}.media-slide a{color:#3b82f6;display:inline-block;font-size:.875rem;text-decoration:underline;word-break:break-all}.media-slideshow-counter{animation:fadeInUp .3s ease-out;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:linear-gradient(135deg,#6b7280e6,#4b5563cc);border:.0625rem solid #ffffff4d;border-radius:1rem;bottom:1rem;box-shadow:0 .25rem .5rem #0003;color:#fff;font-size:.75rem;font-weight:600;left:50%;letter-spacing:.025rem;min-width:3rem;padding:.375rem .75rem;position:absolute;text-align:center;transform:translateX(-50%);transition:all .2s ease;z-index:5}.media-slide-audio{margin-top:.75rem;max-width:22rem;width:100%}.media-slide-file{align-items:center;color:#374151;display:flex;font-size:.875rem;gap:.375rem;justify-content:center}.media-slide-file a{color:#3b82f6;text-decoration:underline}.media-image,.media-video{border-radius:.5rem;box-shadow:0 .25rem .5rem #00000026;flex-shrink:0;max-height:calc(100% - 1rem);min-height:10rem}.media-audio{flex-shrink:0;margin-top:.75rem;max-width:26rem}.meta-item{align-items:center;border-bottom:.0625rem solid #f3f4f6;display:flex;justify-content:space-between;margin-bottom:.5rem;padding:.375rem 0}.meta-item:last-child{border-bottom:none;margin-bottom:0}.meta-label{color:#6b7280;font-size:.8125rem;font-weight:600;min-width:4rem}.meta-value{color:#1f2937;flex:1 1;font-size:.8125rem;text-align:right}.media-slide-content-wrapper{align-items:center;display:flex;flex-direction:column;height:100%;justify-content:center;padding:.5rem;width:100%}.media-item{max-width:100%}.media-audio-container,.media-file-container,.media-image-container,.media-video-container{align-items:center;display:flex;justify-content:center;max-width:100%;position:relative;width:100%}.media-image-container,.media-video-container{aspect-ratio:16/9;max-height:calc(100% - 2rem);min-height:12rem}.media-audio-container{max-width:100%;padding:1rem;width:100%}.media-file-container{padding:2rem;text-align:center;width:100%}.media-file-link{background-color:#f3f4f6;border:2px solid #e5e7eb;border-radius:.5rem;color:#3b82f6;display:inline-block;font-weight:600;padding:1rem 2rem;text-decoration:none;transition:all .2s ease}.media-file-link:hover{background-color:#e5e7eb;border-color:#d1d5db;transform:translateY(-.125rem)}.media-slideshow .media-caption{background-color:#f9fafb;border:.0625rem solid #e5e7eb;border-radius:.375rem;color:#374151;font-size:.875rem;font-weight:600;padding:.5rem;text-align:center}.media-slideshow .media-caption,.media-slideshow .media-description-section{margin-top:.5rem;max-width:100%;width:100%}@media screen and (max-width:440px){.media-slide-content-wrapper{box-sizing:border-box!important;height:100%!important;max-height:100%!important;min-height:100%!important;padding:.125rem .5rem;width:100%!important}}@media screen and (min-width:431px){.media-slide-content-wrapper{box-sizing:border-box;height:100%;max-height:100%;min-height:100%;padding:.5rem;width:100%}}@media screen and (max-width:440px){.media-slideshow{max-width:100%!important;min-width:100%!important;padding:0 0 3rem!important;position:relative!important}.media-slideshow,.media-slideshow-wrapper{box-sizing:border-box!important;height:100%!important;margin:0!important;max-height:100%!important;min-height:100%!important;width:100%!important}.media-slideshow-wrapper{overflow:hidden!important;padding:0 2rem!important}.media-slideshow-nav-area{background:linear-gradient(90deg,#ffffffe6,#ffffffb3)!important;height:calc(100% - .5rem)!important;top:.25rem!important;width:1.5rem!important}.media-slideshow-nav-left{height:calc(100% - .5rem)!important;left:.25rem!important}.media-slideshow-nav-right{height:calc(100% - .5rem)!important;right:.25rem!important}.media-slideshow-nav-arrow{height:1.5rem!important;width:1.5rem!important}.media-slideshow-nav-arrow .material-symbols-outlined{font-size:1.25rem!important}.viewer-label{display:none!important;font-size:.75rem!important;margin-bottom:.25rem!important}.viewer-field{font-size:.875rem!important;padding:.5rem .375rem!important}.viewer-field,.viewer-title{box-sizing:border-box!important;width:100%!important}.viewer-title{font-size:1rem!important}.media-slide-image,.media-slide-video{max-height:70vh!important;max-width:100%!important;min-height:15rem!important;width:100%!important}.media-slide-audio{max-width:90%!important}.media-slideshow-counter{bottom:.5rem!important;font-size:.625rem!important;min-width:2rem!important}.media-slideshow .media-caption{box-sizing:border-box!important;font-size:.75rem!important;margin-top:.125rem!important;padding:.125rem!important;width:100%!important}.marker-metadata{align-self:center!important;height:100%!important;margin-bottom:0!important;max-height:100%!important;min-height:100%!important;overflow-y:auto!important;padding:.25rem!important}.marker-metadata,.marker-metadata-row{box-sizing:border-box!important;gap:.25rem!important;width:100%!important}.marker-metadata-row{flex-direction:column!important}.marker-metadata-label-section,.marker-metadata-title-section{box-sizing:border-box!important;width:100%!important}.marker-metadata-label-section .viewer-field,.marker-metadata-title-section .viewer-field{box-sizing:border-box!important;height:2.5rem!important;min-height:2.5rem!important;width:100%!important}.viewer-section{margin-bottom:.25rem!important}.marker-metadata .viewer-section,.viewer-section{box-sizing:border-box!important;width:100%!important}.marker-metadata .viewer-section{margin-bottom:.125rem!important}.marker-viewer-edit-button{font-size:.75rem!important;min-height:2rem!important;min-width:3rem!important;padding:.5rem .75rem!important}.marker-viewer-edit-button .material-symbols-outlined{font-size:.875rem!important}}@media screen and (min-width:1024px){.media-slideshow{box-sizing:border-box;height:22.5rem;max-height:22.5rem;max-width:40rem;padding:0 0 3rem}}@media screen and (min-width:1200px){.media-slideshow{box-sizing:border-box;height:28.125rem;max-height:28.125rem;max-width:40rem;padding:0 0 3rem}}.marker-metadata{box-sizing:border-box;display:flex;flex-direction:column;gap:1rem;height:100%;overflow-x:hidden;overflow-y:auto;padding:1rem;width:100%}.marker-metadata-main-info{flex-shrink:0}.marker-metadata-row{align-items:flex-start;display:flex;gap:1rem}.marker-metadata-label-section,.marker-metadata-title-section{display:flex;flex:1 1;flex-direction:column;min-width:0}.marker-metadata-label-section .viewer-field,.marker-metadata-title-section .viewer-field{align-items:center;display:flex;flex:1 1;height:3.5rem;justify-content:flex-start;min-height:3.5rem}.marker-metadata-label-section .viewer-field{height:3.5rem;min-height:3.5rem}.marker-metadata .viewer-section{flex-shrink:0;margin-bottom:0}.marker-metadata .viewer-section:last-child{display:flex;flex-direction:column;flex-shrink:0}.marker-metadata .viewer-section:last-child .viewer-field{display:flex;flex-direction:column;flex-shrink:0;justify-content:flex-start;min-height:auto}.marker-metadata::-webkit-scrollbar{width:.375rem}.marker-metadata::-webkit-scrollbar-track{background:#f1f1f1;border-radius:.25rem}.marker-metadata::-webkit-scrollbar-thumb{background:#c1c1c1;border-radius:.25rem}.marker-metadata::-webkit-scrollbar-thumb:hover{background:#a8a8a8}.gm-style .gm-style-iw-d{box-sizing:border-box!important;height:100%!important;margin:0!important;max-height:100%!important;max-width:100%!important;overflow:hidden!important;padding:0!important;width:100%!important}.gm-style .gm-style-iw-d::-webkit-scrollbar{display:none!important}.gm-style .gm-style-iw-d{-ms-overflow-style:none!important;scrollbar-width:none!important}.gm-style .gm-style-iw-d>div,.marker-viewer-container.info-window-scrollable{box-sizing:border-box!important;height:100%!important;margin:0!important;max-height:100%!important;max-width:100%!important;padding:0!important;width:100%!important}.gm-style .gm-style-iw-c:after,.gm-style .gm-style-iw-c:before{display:none!important}.gm-style .gm-style-iw-c{margin-left:0!important;padding-left:0!important}.marker-thumbnail{border:2px solid #000;border-radius:4px;box-sizing:border-box;height:4rem;object-fit:cover;width:4rem}.marker-container,.marker-pin-container,.marker-thumbnail-container{display:inline-block;position:relative}.marker-item{transition:all .4s cubic-bezier(.4,0,.2,1)}.marker-hidden{filter:blur(2px);opacity:0;transform:scale(.3) translateY(20px)}.marker-visible{filter:blur(0);opacity:1;transform:scale(1) translateY(0)}.marker-item.marker-visible .marker-thumbnail-container{animation:thumbnailBounce .6s cubic-bezier(.68,-.55,.265,1.55) .1s both}@keyframes thumbnailBounce{0%{opacity:0;transform:scale(.8) rotate(-5deg)}50%{transform:scale(1.1) rotate(2deg)}to{opacity:1;transform:scale(1) rotate(0deg)}}.marker-item.marker-visible{animation:markerDrop .4s cubic-bezier(.25,.46,.45,.94) .05s both}@keyframes markerDrop{0%{opacity:0;transform:translateY(-30px) scale(.5)}60%{transform:translateY(5px) scale(1.1)}to{opacity:1;transform:translateY(0) scale(1)}}.marker-item.marker-visible .marker-pin-container{animation:pinDrop .4s cubic-bezier(.25,.46,.45,.94) .05s both}@keyframes pinDrop{0%{opacity:0;transform:translateY(-30px) scale(.5)}60%{transform:translateY(5px) scale(1.1)}to{opacity:1;transform:translateY(0) scale(1)}}.marker-loading{background-color:#fffc;border-radius:4px;color:#999;font-size:12px;left:50%;padding:4px 8px;position:absolute;top:50%;transform:translate(-50%,-50%);z-index:10}.marker-item:hover{transform:scale(1.05);transition:transform .2s ease}@media (max-width:1024px){.marker-thumbnail{height:3.5rem;width:3.5rem}}@media (max-width:768px){.marker-thumbnail{height:3rem;width:3rem}.marker-item{transition:all .3s cubic-bezier(.4,0,.2,1)}.marker-item.marker-visible{animation:markerDrop .3s cubic-bezier(.25,.46,.45,.94) .05s both}.marker-item.marker-visible .marker-thumbnail-container{animation:thumbnailBounce .4s cubic-bezier(.68,-.55,.265,1.55) .1s both}}@media (max-width:440px){.marker-thumbnail{height:2.5rem;width:2.5rem}.marker-loading{font-size:10px;padding:2px 6px}}.media-upload-form{margin-top:1rem}.drop-zone-container{margin-bottom:1rem}.drop-zone{border-radius:.5rem}.file-limit-info{color:#888;font-size:.875rem;margin:.5rem 0 0}.upload-error{background-color:#fee;border:1px solid #fcc;border-radius:.375rem;color:#c33;margin-top:.5rem;padding:.5rem}.upload-error p{font-size:.875rem;margin:0}.selected-files-list-vertical{gap:.75rem}.selected-file-entry{align-items:center;border-radius:.5rem;min-height:120px}.thumbnail-remove-button{font-size:.75rem;min-width:2rem;right:.5rem;top:.5rem}.selected-file-preview{align-self:center;border:1px solid #e5e7eb;box-sizing:border-box;flex:0 0 40%;min-height:120px;overflow:visible;padding:2rem;position:relative}.selected-file-preview img,.selected-file-preview video{height:auto;max-height:calc(100% - 4rem);max-width:calc(100% - 4rem);object-fit:contain;width:auto}.selected-file-preview audio{max-width:100%}.selected-file-content{align-self:center;flex:0 0 60%;gap:1rem;justify-content:center;min-height:120px;padding:.5rem 0}.form-group{align-items:flex-start;margin-bottom:0}.form-group:first-child{flex:0 0 auto;margin-bottom:.5rem}.form-group:last-child{flex:1 1;margin-bottom:0}.form-label{color:#000;display:block;font-size:.8125rem;line-height:1.2;margin-bottom:.375rem;text-align:left;width:100%}.form-input,.form-textarea{border-radius:.375rem;display:block;font-size:.875rem;line-height:1.4;padding:.5rem}.form-input{height:2.5rem;min-height:2.5rem}.form-textarea{flex:1 1;font-family:inherit;min-height:3.5rem;resize:none}@media (max-width:47.9375rem){.media-upload-form{margin-top:.75rem}.drop-zone{margin-bottom:.75rem;padding:.75rem}.selected-file-entry{align-items:stretch;flex-direction:column;gap:.75rem;min-height:auto;padding:.75rem}.selected-file-preview{flex:0 0 40%;min-height:100px;padding:1rem;width:100%}.selected-file-preview img,.selected-file-preview video{display:block;height:auto;max-height:calc(100px - 2rem);object-fit:contain;width:auto}.selected-file-content{align-self:stretch;flex:0 0 60%;gap:.75rem;height:auto;justify-content:flex-start;min-height:auto;padding:0}.form-input,.form-textarea{font-size:1rem;padding:.375rem}.form-input{height:2.25rem;min-height:2.25rem}.form-textarea{min-height:3rem}}@media (min-width:48rem){.selected-file-entry{max-width:100%}.media-meta-inputs{gap:1.25rem}}@media (orientation:landscape) and (max-height:31.25rem){.selected-file-preview img,.selected-file-preview video{display:block;height:auto;max-height:6rem;object-fit:contain;width:auto}.form-textarea{min-height:3rem}}.selected-file-content .form-group{align-items:flex-start!important;display:flex!important;flex-direction:column!important;position:relative!important}label.form-label{color:#000!important;display:block!important;font-size:.8125rem!important;font-weight:600!important;opacity:1!important;position:static!important;text-align:left!important;visibility:visible!important;width:100%!important;z-index:auto!important}.selected-file-content .form-group:last-child{margin-bottom:0}.selected-file-content .form-label{color:#000!important;display:block!important;font-size:.8125rem!important;font-weight:600!important;opacity:1!important;position:static!important;text-align:left!important;visibility:visible!important;width:100%!important;z-index:auto!important}.selected-file-content .form-input,.selected-file-content .form-textarea{background-color:#fff!important;border:1px solid #ccc!important;border-radius:.375rem!important;box-sizing:border-box!important;color:#333!important;display:block!important;font-size:.875rem!important;padding:.5rem!important;resize:vertical!important;width:100%!important}.selected-file-content .form-textarea{font-family:inherit!important;min-height:4rem!important}.media-upload-form{margin-top:16px}.drop-zone{background-color:#fafafa;border:2px dashed #ccc;border-radius:8px;color:#666;cursor:pointer;margin-bottom:16px;padding:1rem;text-align:center;transition:background-color .2s}.drop-zone:hover{background-color:#f0f0f0}.selected-files-list-vertical{display:flex;flex-direction:column;gap:12px;margin-bottom:1rem}.selected-file-entry{align-items:flex-start;background:#fff;border:1px solid #ddd;border-radius:8px;display:flex;gap:1rem;overflow:visible;padding:1rem;position:relative}.selected-file-preview{align-items:center;background-color:#f9fafb;border-radius:.375rem;display:flex;flex-shrink:0;height:80px;justify-content:center;overflow:hidden;width:120px}.selected-file-preview img,.selected-file-preview video{border-radius:.25rem;max-height:100%;object-fit:cover}.selected-file-preview audio{height:auto}.selected-file-content{display:flex;flex:1 1;flex-direction:column;gap:.5rem;min-width:0}.selected-file-title{color:#1f2937;font-size:.875rem;font-weight:600;margin:0}.selected-file-description{color:#6b7280;font-size:.8125rem;line-height:1.4;margin:0}.remove-file-button{align-items:center;border-radius:50%;box-shadow:0 1px 3px #0003;cursor:pointer;display:flex;font-size:16px;font-weight:700;height:28px;justify-content:center;position:absolute;right:6px;top:6px;width:28px;z-index:10}.selected-file-preview img,.selected-file-preview video{border-radius:6px;display:block;margin-bottom:12px;max-height:200px;max-width:100%}.selected-file-preview audio{margin-bottom:12px;width:100%}.media-meta-inputs{display:flex;flex-direction:column;gap:1rem}.form-label{color:#444;font-size:13px;font-weight:600;margin-bottom:4px}.form-input,.form-textarea{background-color:#fff;border:1px solid #ccc;border-radius:6px;box-sizing:border-box;color:#333;font-size:14px;padding:8px;resize:vertical;width:100%}.form-textarea{min-height:80px}.form-input:focus,.form-textarea:focus{border-color:#1976d2;box-shadow:0 0 0 2px #1976d226;outline:none}.form-hint{color:#666;font-size:12px;margin-top:4px}.marker-editor-thumbnail-preview{border:none!important;border-radius:4px;display:block;margin-left:auto;margin-right:auto;margin-top:8px;max-height:200px;object-fit:contain;width:100%}.thumbnail-preview-wrapper{align-items:center;background-color:#f9fafb;border:none!important;border-radius:.375rem;display:flex;justify-content:center;margin-bottom:.75rem;min-height:120px;padding:.5rem;position:relative}.thumbnail-horizontal-layout{align-items:stretch;display:flex;gap:1rem}.thumbnail-preview-section,.thumbnail-upload-section{flex:1 1;min-width:0}.thumbnail-placeholder{align-items:center;background-color:var(--gray-100);border:.1rem solid var(--gray-400);border-radius:.375rem;color:var(--gray-600);display:flex;font-size:.875rem;height:120px;justify-content:center}.thumbnail-horizontal-layout .thumbnail-preview-wrapper{align-items:center;display:flex;height:120px;justify-content:center;margin-bottom:0;min-height:120px}.thumbnail-horizontal-layout .marker-editor-thumbnail-preview{margin-top:0;max-height:100px;max-width:100%;object-fit:contain}.thumbnail-horizontal-layout .drop-zone{align-items:center;background-color:#fafafa;border:2px dashed #ccc;border-radius:.375rem;color:#666;cursor:pointer;display:flex;height:120px;justify-content:center;margin-bottom:0;min-height:120px;padding:1rem;text-align:center;transition:background-color .2s}.thumbnail-horizontal-layout .drop-zone:hover{background-color:#f0f0f0}.thumbnail-horizontal-layout .drop-zone p{font-size:.875rem;margin:0}.thumbnail-remove-button{align-items:center;background-color:#ef4444;border:none;border-radius:.25rem;color:#fff;cursor:pointer;display:inline-flex;font-size:.6875rem;font-weight:600;justify-content:center;line-height:1.2;min-height:1.5rem;min-width:2.5rem;padding:.125rem .375rem;position:absolute;right:.25rem;text-decoration:none;top:.25rem;transition:all .2s ease;z-index:10}.thumbnail-remove-button:hover{background-color:#dc2626;transform:translateY(-.0625rem)}@media (max-width:47.9375rem){.thumbnail-remove-button{font-size:.75rem;min-height:1.75rem;padding:.1875rem .5rem}.thumbnail-preview-wrapper{min-height:100px;padding:.375rem}.thumbnail-horizontal-layout{flex-direction:column;gap:.75rem}.thumbnail-preview-section,.thumbnail-upload-section{flex:none;width:100%}.thumbnail-horizontal-layout .thumbnail-preview-wrapper{height:80px;min-height:80px}.thumbnail-horizontal-layout .marker-editor-thumbnail-preview{max-height:60px}.thumbnail-horizontal-layout .drop-zone,.thumbnail-placeholder{height:80px;min-height:80px}}.thumbnail-viewer{border:2px solid #000!important;box-shadow:0 2px 8px #0000001a}.thumbnail-viewer:hover{border-color:#333!important;box-shadow:0 4px 16px #00000026;transform:translateY(-1px)}.thumbnail-image{image-orientation:initial;transition:transform .3s ease}.thumbnail-viewer:hover .thumbnail-image{transform:scale(1.02)}.thumbnail-loading{background-color:#ffffffe6;border-radius:6px;box-shadow:0 2px 4px #0000001a;color:#999;font-size:12px;left:50%;padding:6px 12px;position:absolute;top:50%;transform:translate(-50%,-50%);z-index:10}@media (max-width:768px){.thumbnail-viewer{height:4rem!important;width:4rem!important}.thumbnail-loading{font-size:11px;padding:4px 8px}}@media (max-width:440px){.thumbnail-viewer{height:3.5rem!important;width:3.5rem!important}.thumbnail-loading{font-size:10px;padding:3px 6px}}.thumbnail-uploader{display:flex;flex-direction:column;gap:.375rem;margin:0;padding:0}.thumbnail-uploader .marker-editor-label{margin:0;padding:0}.marker-editor-container{align-self:center;background-color:#fff;border:none;border-radius:.75rem;box-shadow:none;flex-direction:column;font-family:Noto Sans JP,Segoe UI,sans-serif;height:28.125rem;justify-self:center;margin:0;max-height:28.125rem;max-width:44rem;min-height:15.75rem;min-width:22rem}.marker-editor-container,.marker-editor-wrapper{box-sizing:border-box;display:flex;overflow:hidden;padding:1rem;width:100%}.marker-editor-wrapper{align-items:center;height:100%;justify-content:center;position:relative}.marker-editor-container .gm-style-iw,.marker-editor-container .gm-style-iw-d{background:#0000!important;border:none!important;border-radius:0!important;box-shadow:none!important;margin:0!important;padding:0!important}.marker-editor-container .gm-style-iw-d{overflow:hidden!important}.marker-editor-container .gm-style-iw-c,.marker-editor-container .gm-style-iw-t{background:#0000!important;border:none!important;border-radius:0!important;box-shadow:none!important;margin:0!important;padding:0!important}.gm-style-iw-ch,.gm-style-iw-ch[id]{margin:0!important;padding:0!important}.marker-editor-header{border-bottom:none;color:#1a1a1a;flex-shrink:0;font-size:1.125rem;font-weight:700;margin-bottom:0;padding-bottom:0;text-align:center;text-align:left}.marker-editor-meta-section{background-color:#f8fafc;border:.0625rem solid #e2e8f0;border-radius:.5rem;font-size:.875rem;margin-bottom:1rem;padding:.75rem}.marker-editor-meta-label{color:#475569;display:block;font-weight:600;margin-bottom:.25rem}.marker-editor-meta-value{color:#64748b;font-weight:500}.marker-editor-label{color:#374151;display:block;font-size:.875rem;font-weight:600;margin:.5rem 0 .25rem}.marker-editor-input,.marker-editor-select,.marker-editor-textarea{background-color:#fff;border:.125rem solid #d1d5db;border-radius:.375rem;box-shadow:0 .0625rem .125rem #0000000d;box-sizing:border-box;color:#1f2937;font-size:.875rem;padding:.5rem .75rem;transition:all .2s ease;width:100%}.marker-editor-input:focus,.marker-editor-select:focus,.marker-editor-textarea:focus{border-color:#3b82f6;box-shadow:0 0 0 .25rem #3b82f61a;outline:none;transform:translateY(-.0625rem)}.marker-editor-textarea{line-height:1.5;min-height:4rem;resize:vertical}.marker-editor-select{-webkit-appearance:none;appearance:none;background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 20 20'%3E%3Cpath stroke='%236b7280' stroke-linecap='round' stroke-linejoin='round' stroke-width='1.5' d='m6 8 4 4 4-4'/%3E%3C/svg%3E");background-position:right .5rem center;background-repeat:no-repeat;background-size:1.5rem;padding-right:2.5rem}.marker-editor-display-field{background-color:#f9fafb;border:.125rem solid #e5e7eb;border-radius:.375rem;color:#374151;font-size:.875rem;line-height:1.5;padding:.5rem .75rem}.marker-editor-error,.marker-editor-error-message{color:#dc2626;font-size:.75rem;font-weight:500;margin-top:.25rem}.marker-editor-error-message{align-items:center;display:flex;gap:.25rem}.marker-editor-error-message:before{color:#dc2626;content:"⚠";font-size:.75rem}.marker-editor-input-error,.marker-editor-select-error{border-color:#dc2626!important;box-shadow:0 0 0 .25rem #dc26261a!important}.marker-editor-input-error:focus,.marker-editor-select-error:focus{border-color:#dc2626!important;box-shadow:0 0 0 .25rem #dc262633!important}.marker-editor-button-save:disabled{color:#fff!important;cursor:not-allowed!important}.marker-editor-button-save:disabled,.marker-editor-button-save:disabled:hover{background-color:#9ca3af!important;box-shadow:0 .125rem .25rem #0000001a!important;transform:none!important}.marker-editor-actions{border-top:.125rem solid #e5e7eb;display:flex;gap:.75rem;justify-content:space-between;margin-top:1.5rem;padding-top:1rem}.marker-editor-button-delete,.marker-editor-button-save{align-items:center;border:none;border-radius:.375rem;box-shadow:0 .125rem .25rem #0000001a;cursor:pointer;display:inline-flex;flex:1 1;font-size:.875rem;font-weight:600;justify-content:center;line-height:1.2;min-height:2.25rem;min-width:4rem;padding:.5rem 1rem;text-decoration:none;transition:all .2s ease}.marker-editor-button-save{background-color:#3b82f6;color:#fff;white-space:nowrap}.marker-editor-button-save:hover{background-color:#2563eb;box-shadow:0 .25rem .5rem #3b82f64d;transform:translateY(-.125rem)}.marker-editor-button-delete{background-color:#ef4444;color:#fff}.marker-editor-button-delete:hover{background-color:#dc2626;box-shadow:0 .25rem .5rem #ef44444d;transform:translateY(-.125rem)}.marker-editor-meta{background-color:#f9fafb;border-radius:.25rem;color:#6b7280;font-size:.75rem;margin-top:.5rem;padding:.5rem}.marker-editor-media-section{border-top:.0625rem solid #e5e7eb;margin-top:1rem;padding-top:1rem}.marker-editor-media-section h4{color:#1f2937;font-size:.875rem;font-weight:600;margin:0 0 .75rem}.media-list{list-style:none;margin-top:.75rem;padding:0}.media-list-item{align-items:center;background-color:#f9fafb;border:.0625rem solid #e5e7eb;border-radius:.375rem;box-shadow:0 .0625rem .125rem #0000000d;display:flex;gap:.75rem;margin-bottom:.75rem;padding:.75rem;transition:all .2s ease}.media-list-item:hover{background-color:#f3f4f6;transform:translateY(-.0625rem)}.media-list-item:hover,.media-thumb{box-shadow:0 .125rem .25rem #0000001a}.media-thumb{border-radius:.25rem;max-height:4rem;max-width:4rem;object-fit:cover}.media-audio-thumb{height:auto;width:100%}.media-list-item button{background-color:#ef4444;border:none;border-radius:.25rem;color:#fff;cursor:pointer;font-size:.75rem;font-weight:600;margin-left:auto;min-width:3rem;padding:.375rem .625rem;transition:all .2s ease}.media-list-item button:hover{background-color:#dc2626;transform:translateY(-.0625rem)}.marker-editor-header-row{align-items:center;display:flex;flex-shrink:0;justify-content:space-between;margin-bottom:0}.marker-editor-creator-info{background-color:#f8fafc;border:.0625rem solid #e2e8f0;border-radius:.375rem;flex-shrink:0;padding:.5rem .75rem}.marker-editor-button-delete-top,.marker-editor-creator-info{align-items:center;display:flex;font-size:.875rem;gap:.375rem}.marker-editor-button-delete-top{background:linear-gradient(135deg,#dc2626,#b91c1c);border:none;border-radius:.375rem;box-shadow:0 .25rem .5rem #dc26264d;color:#fff;cursor:pointer;font-weight:600;padding:.5rem 1rem;transition:all .2s ease}.marker-editor-button-delete-top:hover{background:linear-gradient(135deg,#b91c1c,#991b1b);box-shadow:0 .375rem .75rem #dc262666;transform:translateY(-.125rem)}.marker-editor-progress-bar{margin:.75rem 0 1rem}.progress-bar-track{background:#e0e0e0;border-radius:.1875rem;height:.375rem;margin-bottom:.375rem;overflow:hidden;width:100%}.progress-bar-fill{background:linear-gradient(90deg,#1976d2,#1565c0);height:100%;transition:width .3s ease}.progress-bar-label{color:#555;font-size:.75rem;font-weight:500;text-align:right}.marker-editor-actions-row-2nd{align-items:flex-end;margin-top:0}.marker-editor-actions-left{display:flex;flex:1 1;gap:.5rem;justify-content:flex-start}.marker-editor-actions-center{display:flex;flex:2 1;justify-content:center}.marker-editor-actions-right{display:flex;flex:1 1;gap:.5rem;justify-content:flex-end}.marker-editor-button-back,.marker-editor-button-next,.marker-editor-button-save{border-radius:.375rem;box-shadow:0 .25rem .5rem #1976d226;font-size:.875rem;font-weight:600;min-width:6rem;padding:.625rem 1.25rem;transition:all .2s ease}.marker-editor-button-back:hover,.marker-editor-button-next:hover,.marker-editor-button-save:hover{box-shadow:0 .375rem .75rem #1976d240;transform:translateY(-.125rem)}.marker-editor-page-anim::-webkit-scrollbar{width:.375rem}.marker-editor-page-anim::-webkit-scrollbar-track{background:#f1f1f1;border-radius:.25rem}.marker-editor-page-anim::-webkit-scrollbar-thumb{background:#c1c1c1;border-radius:.25rem}.marker-editor-page-anim::-webkit-scrollbar-thumb:hover{background:#a8a8a8}.marker-editor-page-content{display:flex;flex-direction:column;gap:.5rem;height:100%}.marker-editor-thumbnail-section{display:flex;flex-direction:column;gap:.375rem;margin-bottom:0}.marker-editor-thumbnail-section .marker-editor-label{margin:0}.marker-editor-form-row{align-items:flex-start;display:flex;gap:1rem}.marker-editor-form-row .marker-editor-field{flex:1 1;min-width:0}.marker-editor-form-row .marker-editor-label{margin:.375rem 0 .25rem}.marker-editor-actions-row{align-items:flex-end;display:flex;flex-shrink:0;gap:.75rem;justify-content:space-between;margin-top:.5rem}.marker-editor-final-actions{align-items:center;display:flex;flex-shrink:0;gap:1rem;justify-content:center;margin-top:0;padding-bottom:1rem}.marker-editor-final-actions .marker-editor-button-delete-bottom,.marker-editor-final-actions .marker-editor-button-save{align-items:center;display:inline-flex;height:2.5rem;justify-content:center;min-height:2.5rem}.marker-editor-button-delete-bottom{align-items:center;background:linear-gradient(135deg,#ef4444,#dc2626);border:none;border-radius:.375rem;box-shadow:0 .25rem .5rem #ef444433;color:#fff;cursor:pointer;display:inline-flex;font-size:.875rem;font-weight:600;gap:.375rem;justify-content:center;min-width:6rem;padding:.625rem 1.25rem;transition:all .2s ease}.marker-editor-button-delete-bottom:hover{background:linear-gradient(135deg,#dc2626,#b91c1c);box-shadow:0 .375rem .75rem #ef44444d;transform:translateY(-.125rem)}.marker-editor-content{display:flex;flex:1 1;flex-direction:column;gap:1.5rem;margin:1rem 0;overflow-x:hidden;overflow-y:auto;padding-right:.5rem}.marker-editor-section{display:flex;flex-direction:column;gap:1rem;padding-bottom:1rem}.marker-editor-section:last-of-type{border-bottom:none;padding-bottom:0}.marker-editor-section-title{align-items:center;border-bottom:.125rem solid #e5e7eb;color:#1f2937;display:flex;font-size:1rem;font-weight:700;gap:.5rem;margin:0;padding-bottom:.5rem}.marker-editor-section-title:before{background:linear-gradient(135deg,#1976d2,#1565c0);border-radius:.125rem;content:"";height:1.25rem;width:.25rem}@media screen and (min-width:1200px){.marker-editor-container{height:28.125rem;max-height:28.125rem;max-width:40rem}}@media screen and (min-width:1024px){.marker-editor-container{height:22.5rem;max-height:22.5rem;max-width:40rem}}@media screen and (max-width:768px){.marker-editor-wrapper{padding:.75rem!important}.marker-editor-container{box-sizing:border-box!important;height:100%!important;margin:0!important;max-height:100%!important;max-width:100%!important;min-height:100%!important;min-width:100%!important;padding:.75rem!important;width:100%!important}div.gm-style-iw,div.gm-style-iw-c,div.gm-style-iw-d{border-radius:8px!important;box-sizing:border-box!important;height:50vh!important;max-height:50vh!important;max-width:90vw!important;opacity:1!important;overflow:visible!important;padding:0!important;width:90vw!important}}@media screen and (max-width:440px){.marker-editor-wrapper{padding:.5rem!important}.marker-editor-container{background-color:#fff!important;box-sizing:border-box!important;display:flex!important;flex-direction:column!important;height:100%!important;margin:0!important;max-height:100%!important;max-width:100%!important;min-height:100%!important;min-width:100%!important;overflow:auto!important;padding:.5rem!important;visibility:visible!important;width:100%!important}div.gm-style-iw,div.gm-style-iw-c,div.gm-style-iw-d{border-radius:8px!important;box-sizing:border-box!important;height:50vh!important;max-height:50vh!important;max-width:92vw!important;opacity:1!important;overflow:visible!important;padding:0!important;width:92vw!important}.marker-editor-header{font-size:1rem;margin-bottom:.75rem}.marker-editor-meta-section{font-size:.8125rem;margin-bottom:.75rem;padding:.5rem}.marker-editor-label{font-size:.8125rem;margin:.375rem 0 .1875rem}.marker-editor-input,.marker-editor-select,.marker-editor-textarea{font-size:.8125rem;padding:.375rem .5rem}.marker-editor-textarea{min-height:3rem}.marker-editor-display-field{font-size:.8125rem;padding:.375rem .5rem}.marker-editor-error{font-size:.6875rem}.marker-editor-actions{gap:.5rem;margin-top:1rem;padding-top:.75rem}.marker-editor-button-delete,.marker-editor-button-save{font-size:.8125rem;min-height:2rem;min-width:3.5rem;padding:.375rem .75rem}.marker-editor-meta{font-size:.6875rem;padding:.375rem}.marker-editor-media-section{margin-top:.75rem;padding-top:.75rem}.marker-editor-media-section h4{font-size:.8125rem;margin-bottom:.5rem}.media-list-item{gap:.5rem;margin-bottom:.5rem;padding:.5rem}.media-thumb{max-height:3rem;max-width:3rem}.media-list-item button{font-size:.6875rem;min-width:2.5rem;padding:.25rem .5rem}.marker-editor-creator-info{font-size:.8125rem;padding:.375rem .5rem}.marker-editor-button-delete-top{font-size:.8125rem;padding:.375rem .75rem}.marker-editor-progress-bar{margin:.5rem 0 .75rem}.progress-bar-label{font-size:.6875rem}.marker-editor-actions-row{gap:.5rem;margin-top:.375rem}.marker-editor-button-back,.marker-editor-button-next,.marker-editor-button-save{font-size:.8125rem;min-width:5rem;padding:.5rem 1rem}.marker-editor-section-title{font-size:.9375rem;padding-bottom:.375rem}.marker-editor-content{gap:1rem;margin:.75rem 0;padding-right:.375rem}.marker-editor-final-actions,.marker-editor-section{gap:.75rem;padding-bottom:.75rem}.marker-editor-final-actions .marker-editor-button-delete-bottom,.marker-editor-final-actions .marker-editor-button-save{height:2.25rem;min-height:2.25rem}.marker-editor-button-delete-bottom{font-size:.8125rem;min-width:5rem;padding:.5rem 1rem}}.map-filter-control,.map-filter-control-container{align-items:flex-end;display:flex;flex-direction:column}.map-filter-control{margin-left:auto;position:relative}.map-filter__toggle{align-items:center;background-color:#fff;border:2px solid #ddd;border-radius:.5rem;box-shadow:0 .125rem .375rem #00000026;color:#333;cursor:pointer;display:flex;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;font-size:.875rem;font-weight:500;gap:.625rem;height:2.75rem;min-width:9rem;padding:.625rem 1rem;transition:all .2s ease;-webkit-user-select:none;user-select:none}.map-filter__toggle:hover{background-color:#f8f9fa;border-color:#adb5bd;box-shadow:0 .25rem .5rem #0003;transform:translateY(-.0625rem)}.map-filter__toggle:active{transform:translateY(0)}.map-filter__label{flex:1 1;font-size:.8125rem;font-weight:600;letter-spacing:.025rem;text-align:left;text-transform:uppercase}.map-filter__badge{background-color:#007bff;border-radius:.75rem;color:#fff;font-size:.75rem;font-weight:600;min-width:1.25rem;padding:.125rem .5rem;text-align:center}.map-filter__menu{background-color:#fff;border:.125rem solid #ddd;border-radius:.5rem;box-shadow:0 .5rem 2rem #0003;margin-top:.5rem;max-height:25rem;max-width:20rem;min-width:17.5rem;opacity:0;overflow:hidden;position:absolute;right:0;top:100%;transform:translateY(-.625rem);transition:all .3s ease;visibility:hidden;z-index:1000}.map-filter__menu--open{opacity:1;transform:translateY(0);visibility:visible}.map-filter__header{align-items:center;background-color:#f8f9fa;border-bottom:.125rem solid #ddd;display:flex;justify-content:space-between;padding:1rem 1rem 1rem 1.5rem}.map-filter__title{color:#333;font-size:1rem;font-weight:600;margin:0}.map-filter__close{align-items:center;background:none;border:none;border-radius:.375rem;color:#6c757d;cursor:pointer;display:flex;height:2rem;justify-content:center;transition:all .2s ease;width:2rem}.map-filter__close:hover{background-color:#e9ecef;color:#333}.map-filter__content{max-height:18.75rem;overflow-y:auto;padding:1rem 1.25rem}.map-filter__item{align-items:center;border-radius:.375rem;cursor:pointer;display:flex;margin-bottom:.25rem;padding:.75rem 0;transition:all .2s ease}.map-filter__item:hover{background-color:#f8f9fa;padding-left:.5rem;padding-right:.5rem}.map-filter__item input[type=checkbox]{accent-color:#007bff;cursor:pointer;flex-shrink:0;height:1.125rem;margin-right:.75rem;width:1.125rem}.map-filter__color{border:.0625rem solid #0000001a;border-radius:50%;flex-shrink:0;height:1rem;margin-right:.75rem;width:1rem}.map-filter__color--all{background:linear-gradient(45deg,red,#ff8000,#ff0,#80ff00,#0f0,#00ff80,#0ff,#0080ff,#00f,#8000ff,#f0f,#ff0080);border:.0625rem solid #0003}.map-filter__text{color:#333;flex:1 1;font-size:.875rem;font-weight:500}.map-filter__empty-message{color:#6c757d;font-style:italic;margin:0;padding:1.25rem;text-align:center}.map-filter__error{color:#dc3545;font-weight:500;margin:0;padding:1.25rem}.map-filter__loading{color:#6c757d;font-style:italic;margin:0;padding:1.25rem}@media screen and (max-width:440px){.map-filter-control,.map-filter-control-container,.map-filter__menu,.map-filter__toggle{display:none!important}}@media screen and (min-width:1024px){.map-filter-control-container{margin:.75rem}.map-filter-control{margin-left:auto}.map-filter__toggle{font-size:.875rem;gap:.75rem;margin:0;min-width:9rem;padding:.75rem 1rem}.map-filter__menu{max-width:calc(100vw - 2.5rem);min-width:18.75rem}.map-filter__header{padding:1rem 1.25rem}.map-filter__title{font-size:1rem}.map-filter__content{max-height:18.75rem;padding:1rem 1.25rem}.map-filter__item{padding:.75rem 0}.map-filter__item:hover{padding-left:.5rem;padding-right:.5rem}.map-filter__text{font-size:.875rem}}@media screen and (min-width:1200px){.map-filter-control-container{margin:.5rem}.map-filter-control{margin-left:auto}.map-filter__toggle{font-size:1rem;gap:1rem;margin:0;min-width:10rem;padding:1rem 1.25rem}.map-filter__menu{max-width:calc(100vw - 3rem);min-width:21.875rem}.map-filter__header{padding:1.25rem 1.5rem}.map-filter__title{font-size:1.125rem}.map-filter__content{max-height:21.875rem;padding:1.25rem 1.5rem}.map-filter__item{padding:1rem 0}.map-filter__item:hover{padding-left:.75rem;padding-right:.75rem}.map-filter__text{font-size:1rem}}@media (prefers-reduced-motion:reduce){.map-filter__item,.map-filter__menu,.map-filter__toggle{transition:none}.map-filter__item:hover{transform:none}}@media (prefers-contrast:high){.map-filter__color,.map-filter__menu,.map-filter__toggle{border-width:.125rem}}.map-container-wrapper{background-color:#f8fafc;box-sizing:border-box;height:calc(100vh - 80px);height:calc(100vh - var(--header-height, 80px));overflow:hidden;position:relative;width:100%}.map-toggle-button{background-color:#fff;border:.0625rem solid #e5e7eb;border-radius:.375rem;box-shadow:0 .125rem .25rem #0000001a;color:#374151;cursor:pointer;font-size:.875rem;font-weight:500;left:.75rem;padding:.5rem .75rem;position:absolute;top:.75rem;transition:all .2s ease;z-index:10}.map-toggle-button:hover{background-color:#f9fafb;border-color:#d1d5db;box-shadow:0 .25rem .5rem #00000026;transform:translateY(-.0625rem)}.map-container{height:100%;overflow:hidden;width:100%}.map-body{height:100%}.map-main{height:calc(100vh - 80px);height:calc(100vh - var(--header-height, 80px))}@media (min-width:48rem){.map-body{flex-direction:row}.map-main{height:calc(100vh - 80px);height:calc(100vh - var(--header-height, 80px))}.map-toggle-button{font-size:.875rem;left:1rem;padding:.625rem 1rem;top:1rem}}@media (max-width:47.9375rem){.map-container-wrapper,.map-main{height:calc(100vh - 80px);height:calc(100vh - var(--header-height, 80px))}.map-toggle-button{font-size:.8125rem;left:.5rem;padding:.375rem .625rem;top:.5rem}}@media (orientation:landscape) and (max-height:31.25rem){.map-container-wrapper,.map-main{height:calc(100vh - 80px);height:calc(100vh - var(--header-height, 80px))}}@media screen and (min-width:1024px) and (max-height:768px){.map-container-wrapper,.map-main{height:calc(100vh - 60px);height:calc(100vh - var(--header-height, 60px))}.map-toggle-button{font-size:.75rem;left:.5rem;padding:.375rem .75rem;top:.5rem}}@media (min-width:75rem){.map-container-wrapper,.map-main{height:calc(100vh - 80px);height:calc(100vh - var(--header-height, 80px))}}@media (prefers-color-scheme:dark){.map-container-wrapper{background-color:#1f2937}.map-toggle-button{background-color:#374151;border-color:#4b5563;color:#f9fafb}.map-toggle-button:hover{background-color:#4b5563;border-color:#6b7280}}.layer-toggle-control-container{align-items:flex-end;display:flex;flex-direction:column}.material-symbols-outlined{font-variation-settings:"FILL" 0,"wght" 400,"GRAD" 0,"opsz" 40}.layer-toggle-control{align-items:center;background-color:#fff;border:2px solid #ddd;border-radius:.5rem;box-shadow:0 .125rem .375rem #00000026;color:#333;cursor:pointer;display:flex;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;font-size:.875rem;font-weight:500;gap:.625rem;height:2.75rem;margin:0;min-width:9rem;padding:.625rem 1rem;transition:all .2s ease;-webkit-user-select:none;user-select:none}.layer-toggle-control:hover{background-color:#f8f9fa;border-color:#adb5bd;box-shadow:0 .25rem .5rem #0003}.layer-toggle-control.active{background-color:#007bff;border-color:#007bff;color:#fff}.layer-toggle-control.active:hover{background-color:#0056b3;border-color:#0056b3}.toggle-icon{color:#666;flex-shrink:0;font-size:1.5rem;transition:color .2s ease}.layer-toggle-control.active .toggle-icon{color:#fff}.toggle-label{font-size:.8125rem;font-weight:600;letter-spacing:.025rem;text-transform:uppercase}@media screen and (max-width:440px){.layer-toggle-control,.layer-toggle-control-container{display:none!important}}@media screen and (min-width:1024px){.layer-toggle-control-container{margin:.75rem}.layer-toggle-control{font-size:.6875rem;gap:.375rem;margin:0;min-width:6.5rem;padding:.375rem .75rem}.toggle-icon{font-size:1.125rem}.toggle-label{font-size:.75rem}}@media screen and (min-width:1200px){.layer-toggle-control-container{margin:.5rem}}@media screen and (min-width:431px){.mobile-hamburger-control-container,.mobile-hamburger-menu{display:none!important}}@media screen and (max-width:440px){.mobile-hamburger-control-container{margin:.5rem;position:relative;z-index:1000}.mobile-hamburger-menu{position:relative;z-index:1000}.mobile-hamburger-button{align-items:center;background:#fff;border:1px solid #e5e7eb;border-radius:.5rem;box-shadow:0 2px 8px #00000026;cursor:pointer;display:flex;flex-direction:column;gap:.25rem;height:auto;justify-content:center;min-height:3.5rem;min-width:4rem;padding:.5rem;transition:all .2s ease;width:auto}.mobile-hamburger-button:hover{background:#f9fafb;transform:scale(1.02)}.mobile-hamburger-button.active{background:#3b82f6;border-color:#3b82f6}.mobile-hamburger-button.active .hamburger-line{background:#fff}.hamburger-line{background:#374151;border-radius:.0625rem;height:.125rem;transition:all .2s ease;width:1.5rem}.mobile-hamburger-button.active .hamburger-line:first-child{transform:rotate(45deg) translate(.375rem,.375rem)}.mobile-hamburger-button.active .hamburger-line:nth-child(2){opacity:0}.mobile-hamburger-button.active .hamburger-line:nth-child(3){transform:rotate(-45deg) translate(.375rem,-.375rem)}.mobile-hamburger-button p{color:#374151;font-size:.75rem;font-weight:500;line-height:1;margin:0;text-align:center;white-space:nowrap}.mobile-hamburger-button.active p{color:#fff}.mobile-hamburger-button .material-symbols-outlined{color:#374151;font-size:1.25rem}.mobile-hamburger-button.active .material-symbols-outlined{color:#fff}.mobile-hamburger-panel{animation:fadeIn .15s ease-out;background:#fff;border:1px solid #e5e7eb;border-radius:8px;box-shadow:0 4px 20px #00000026;left:.5rem;max-height:calc(100vh - 6rem);max-width:calc(100vw - 1rem);min-width:calc(100vw - 1rem);overflow:hidden;position:fixed;right:.5rem;top:10rem;width:calc(100vw - 1rem);z-index:1001}@keyframes fadeIn{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}.mobile-hamburger-header{align-items:center;background:#f8fafc;border-bottom:1px solid #e5e7eb;display:flex;justify-content:space-between;padding:.5rem}.mobile-hamburger-header h3{color:#1f2937;font-size:1rem;font-weight:600;margin:0}.mobile-hamburger-close{align-items:center;background:none;border:none;border-radius:.375rem;color:#6b7280;cursor:pointer;display:flex;height:2rem;justify-content:center;transition:all .2s ease;width:2rem}.mobile-hamburger-close:hover{background:#f3f4f6;color:#374151}.mobile-hamburger-close .material-symbols-outlined{font-size:1.25rem}.mobile-hamburger-tabs{border-bottom:1px solid #e5e7eb;display:flex}.mobile-hamburger-tab{background:none;border:none;border-bottom:2px solid #0000;color:#6b7280;cursor:pointer;flex:1 1;font-size:.875rem;font-weight:500;padding:.5rem;transition:all .2s ease}.mobile-hamburger-tab:hover{background:#f9fafb;color:#374151}.mobile-hamburger-tab.active{background:#eff6ff;border-bottom-color:#3b82f6;color:#3b82f6}.mobile-hamburger-content{max-height:calc(100vh - 12rem);overflow-y:auto;width:100%}.mobile-filter-content{height:100%;overflow-y:auto;padding:.75rem}.mobile-filter-header{align-items:center;border-bottom:1px solid #e5e7eb;display:flex;justify-content:space-between;margin-bottom:1rem;padding-bottom:.75rem}.mobile-filter-toggle-all{background:#3b82f6;border:none;border-radius:.375rem;color:#fff;cursor:pointer;font-size:.75rem;font-weight:500;padding:.5rem .75rem;transition:all .2s ease}.mobile-filter-toggle-all:hover{background:#2563eb}.mobile-filter-count{color:#6b7280;font-size:.75rem;font-weight:500}.mobile-filter-list{display:flex;flex-direction:column;gap:.5rem;max-height:calc(100vh - 16rem);overflow-y:auto;width:100%}.mobile-filter-item{align-items:center;background:#f9fafb;border:1px solid #f3f4f6;border-radius:.5rem;cursor:pointer;display:flex;gap:.75rem;padding:.75rem;transition:all .2s ease}.mobile-filter-item:hover{background:#f3f4f6;border-color:#e5e7eb}.mobile-filter-item input[type=checkbox]{accent-color:#3b82f6;height:1.25rem;width:1.25rem}.mobile-filter-color{border:1px solid #d1d5db;border-radius:50%;flex-shrink:0;height:1rem;width:1rem}.mobile-filter-name{color:#374151;flex:1 1;font-size:.875rem}.mobile-layer-content{height:100%;overflow-y:auto;padding:.75rem;width:100%}.mobile-layer-item{margin-bottom:.75rem}.mobile-layer-toggle{align-items:center;background:#f9fafb;border:1px solid #f3f4f6;border-radius:.5rem;cursor:pointer;display:flex;gap:.75rem;padding:.75rem;transition:all .2s ease}.mobile-layer-toggle:hover{background:#f3f4f6;border-color:#e5e7eb}.mobile-layer-toggle input[type=checkbox]{accent-color:#3b82f6;height:1.25rem;width:1.25rem}.mobile-layer-name{color:#374151;flex:1 1;font-size:.875rem}.mobile-error,.mobile-loading{color:#6b7280;font-size:.875rem;padding:1rem;text-align:center}.mobile-error{color:#ef4444}.mobile-hamburger-content::-webkit-scrollbar{width:.375rem}.mobile-hamburger-content::-webkit-scrollbar-track{background:#f3f4f6;border-radius:.25rem}.mobile-hamburger-content::-webkit-scrollbar-thumb{background:#d1d5db;border-radius:.25rem}.mobile-hamburger-content::-webkit-scrollbar-thumb:hover{background:#9ca3af}}.uploading-overlay{background:#ffffffd9;height:100vh;left:0;pointer-events:all;position:fixed!important;top:0;width:100vw;z-index:9999}.uploading-box{background:#fff;border-radius:12px;box-shadow:0 4px 12px #0003;left:50%;padding:24px 32px;position:absolute;text-align:center;top:50%;transform:translate(-50%,-50%)}.spinner{animation:spin 1s linear infinite;border:5px solid #ccc;border-radius:50%;border-top-color:#007bff;height:40px;margin:0 auto 16px;width:40px}@keyframes spin{to{transform:rotate(1turn)}}.uploading-box p{color:#333;font-size:16px;font-weight:700;margin:0}.map-body{background-color:var(--bg-primary);box-sizing:border-box;display:flex;flex-direction:column;height:calc(100vh - 80px);height:calc(100vh - var(--header-height, 80px));left:0;margin-top:80px;margin-top:var(--header-height,80px);overflow:hidden;position:fixed;top:0;width:100vw}@media screen and (max-width:440px){.map-body{height:calc(100vh - 60px);height:calc(100vh - var(--header-height, 60px));margin-top:60px;margin-top:var(--header-height,60px)}}@media screen and (min-width:1024px){.map-body{height:calc(100vh - 80px);height:calc(100vh - var(--header-height, 80px));margin-top:80px;margin-top:var(--header-height,80px)}}@media screen and (min-width:1200px){.map-body{height:calc(100vh - 100px);height:calc(100vh - var(--header-height, 100px));margin-top:100px;margin-top:var(--header-height,100px)}}@media screen and (min-width:1024px) and (max-height:768px){.map-body{height:calc(100vh - 60px);height:calc(100vh - var(--header-height, 60px));margin-top:60px;margin-top:var(--header-height,60px)}}.map-main{flex:1 1;height:100%;min-width:0;overflow:hidden;position:relative;width:100%}.media-thumbnail-item{align-items:center;cursor:pointer;display:flex;flex-direction:column;height:auto;text-align:center;transition:transform .2s ease,box-shadow .2s ease;width:100%}.media-thumbnail-item:hover{box-shadow:0 4px 12px #00000026;transform:translateY(-2px)}.media-thumbnail-box{align-items:center;aspect-ratio:1/1;background-color:#f0f0f0;border-radius:8px;display:flex;justify-content:center;margin-bottom:.125rem;overflow:hidden;position:relative;transition:all .3s ease;width:100%}.media-thumbnail-box:hover{background-color:#e8e8e8}.media-thumbnail-image{height:100%;image-orientation:initial;object-fit:cover;transition:transform .3s ease;width:100%}.media-thumbnail-image:hover{transform:scale(1.05)}.media-thumbnail-loading{background-color:#fffc;border-radius:4px;color:#999;font-size:clamp(10px,2vw,12px);left:50%;padding:4px 8px;position:absolute;top:50%;transform:translate(-50%,-50%);z-index:10}.media-thumbnail-icon-box{color:#555;font-size:clamp(24px,6vw,48px);transition:color .2s ease}.media-thumbnail-icon-box:hover{color:#333}.media-thumbnail-caption{color:#555;font-size:clamp(10px,2.5vw,12px);line-height:1.1;margin-top:.0625rem;max-width:100%;padding:0 .0625rem;transition:color .2s ease;word-break:break-word}.media-thumbnail-item:hover .media-thumbnail-caption{color:#333}@media (max-width:768px){.media-thumbnail-caption{font-size:clamp(9px,2.2vw,11px);margin-top:.05rem}}@media (max-width:440px){.media-thumbnail-caption{font-size:clamp(8px,2vw,10px);margin-top:.0375rem}.media-thumbnail-loading{font-size:clamp(8px,2vw,10px);padding:2px 6px}}.gallery-grid{grid-gap:clamp(1.5rem,4vw,2rem);background-color:var(--surface);border-radius:.5rem;display:grid;gap:clamp(1.5rem,4vw,2rem);grid-template-columns:repeat(auto-fill,minmax(clamp(10rem,20vw,14rem),1fr));min-height:20rem;padding:clamp(1.5rem,4vw,2rem)}.gallery-grid .mediaThumbnailItem{background:var(--surface);border:1px solid var(--border);border-radius:.375rem;overflow:hidden;transition:transform .3s ease,box-shadow .3s ease}.gallery-grid .mediaThumbnailItem:hover{box-shadow:0 clamp(.25rem,1vw,.5rem) clamp(.5rem,2vw,1rem) var(--shadow-light);transform:translateY(-.25rem)}.gallery-grid-empty{align-items:center;color:var(--gray-500);display:flex;font-size:clamp(.875rem,2.5vw,1rem);justify-content:center;min-height:20rem;padding:clamp(2rem,5vw,4rem);text-align:center}@media screen and (max-width:440px){.gallery-grid{gap:.75rem;grid-template-columns:repeat(auto-fill,minmax(6rem,1fr));padding:.75rem}.gallery-grid-empty{font-size:.875rem;min-height:15rem;padding:1.5rem}}@media screen and (min-width:1024px){.gallery-grid{gap:2rem;grid-template-columns:repeat(auto-fill,minmax(14rem,1fr));padding:2rem}.gallery-grid-empty{font-size:1rem;min-height:20rem;padding:3rem}}@media screen and (min-width:1200px){.gallery-grid{gap:2.5rem;grid-template-columns:repeat(auto-fill,minmax(16rem,1fr));padding:2.5rem}.gallery-grid-empty{font-size:1.125rem;min-height:25rem;padding:4rem}}.media-item{align-items:center;display:flex;flex-direction:column;width:100%}.media-image,.media-video{border-radius:4px;height:auto;max-width:100%;object-fit:contain;width:100%}.media-audio{width:100%}.media-caption{color:#666;color:#333;font-size:.8rem;font-size:.85rem;font-weight:600;margin-top:4px;margin-top:6px}.media-caption,.media-description{text-align:center;word-break:break-word}.media-description{color:#555;font-size:.75rem;margin-top:4px;padding:0 4px;white-space:pre-wrap}.media-description-section{margin-top:6px;text-align:left;width:100%}.media-description-label{color:#555;display:block;font-size:.75rem;font-weight:600;margin-bottom:2px}.gallery-media-item{align-items:center;display:flex;flex-direction:column;padding:clamp(.5rem,2vw,1rem);width:100%}.gallery-media-content{position:relative;width:100%}.gallery-media-content,.gallery-media-delete-button{align-items:center;display:flex;justify-content:center}.gallery-media-delete-button{background-color:var(--button-danger);color:var(--on-primary);height:clamp(2rem,5vw,2.5rem);position:absolute;right:clamp(.5rem,1.5vw,.75rem);top:clamp(.5rem,1.5vw,.75rem);width:clamp(2rem,5vw,2.5rem);z-index:10}.gallery-media-delete-button:hover{background-color:var(--button-danger-hover);opacity:1;transform:scale(1.1)}.gallery-media-delete-button:active{transform:scale(.95)}.gallery-media-image,.gallery-media-video{background:var(--surface);border-radius:.375rem;height:auto;max-width:100%;object-fit:contain;width:100%}.gallery-media-audio{border-radius:.375rem;width:100%}.gallery-media-caption{color:var(--on-primary);font-size:clamp(.75rem,2vw,.875rem);font-weight:600;line-height:1.4;margin-top:clamp(.25rem,1vw,.5rem);text-align:center;word-break:break-word}.gallery-media-description-section{margin-top:clamp(.375rem,1.5vw,.75rem);text-align:left;width:100%}.gallery-media-description{border-radius:.25rem;color:var(--gray-300);line-height:1.5;padding:clamp(.25rem,1vw,.5rem);white-space:pre-wrap;word-break:break-word}.gallery-media-description,.gallery-media-item-error,.gallery-media-unsupported{background:var(--surface);border:1px solid var(--border);font-size:clamp(.75rem,2vw,.875rem);text-align:center}.gallery-media-item-error,.gallery-media-unsupported{align-items:center;border-radius:.375rem;color:var(--error-color);display:flex;justify-content:center;min-height:clamp(8rem,20vw,12rem);padding:clamp(1rem,3vw,1.5rem)}@media screen and (max-width:440px){.gallery-media-item{padding:.5rem}.gallery-media-delete-button{height:1.75rem;right:.25rem;top:.25rem;width:1.75rem}.gallery-media-caption,.gallery-media-description{font-size:.75rem}.gallery-media-item-error,.gallery-media-unsupported{font-size:.75rem;min-height:8rem;padding:1rem}}@media screen and (min-width:1024px){.gallery-media-item{padding:1rem}.gallery-media-delete-button{height:2.5rem;right:.5rem;top:.5rem;width:2.5rem}.gallery-media-caption,.gallery-media-description{font-size:.875rem}.gallery-media-item-error,.gallery-media-unsupported{font-size:.875rem;min-height:12rem;padding:1.5rem}}@media screen and (min-width:1200px){.gallery-media-item{padding:1.25rem}.gallery-media-delete-button{height:3rem;right:.75rem;top:.75rem;width:3rem}.gallery-media-caption,.gallery-media-description{font-size:1rem}.gallery-media-item-error,.gallery-media-unsupported{font-size:1rem;min-height:15rem;padding:2rem}}.gallery-modal{align-items:center;display:flex;height:100%;justify-content:center;left:0;padding:clamp(1rem,3vw,2rem);position:fixed;top:0;width:100%;z-index:1000}.gallery-modal-overlay{-webkit-backdrop-filter:blur(.25rem);backdrop-filter:blur(.25rem);background-color:#000000b3;height:100%;left:0;position:absolute;top:0;width:100%;z-index:1}.gallery-modal-content{animation:galleryFadeIn .3s ease-in-out;background:var(--surface);border:1px solid var(--border);border-radius:.5rem;box-shadow:0 clamp(.25rem,1vw,.5rem) clamp(1rem,3vw,2rem) #0000004d;max-height:90vh;max-width:clamp(20rem,90vw,40rem);overflow-y:auto;padding:clamp(1rem,3vw,2rem);position:relative;width:100%;z-index:2}.gallery-close-button{align-items:center;border-radius:50%;display:flex;height:clamp(2rem,5vw,2.5rem);justify-content:center;position:absolute;right:clamp(.5rem,2vw,1rem);top:clamp(.5rem,2vw,1rem);transition:background-color .3s ease;width:clamp(2rem,5vw,2.5rem);z-index:3}.gallery-close-button:hover{background-color:var(--button-secondary-hover)}.gallery-modal-header{border-bottom:1px solid var(--border);margin-bottom:clamp(1rem,3vw,1.5rem);padding:clamp(.5rem,2vw,1rem);text-align:center}.gallery-modal-header h2{color:var(--on-primary);font-size:clamp(1.125rem,3vw,1.5rem);line-height:1.3;margin-bottom:clamp(.5rem,1.5vw,.75rem)}.gallery-modal-custom .modal-content{padding:0}.gallery-modal-content-wrapper{padding:1.5rem}.gallery-location-details{border-bottom:1px solid var(--border);display:flex;flex-wrap:wrap;gap:clamp(1rem,3vw,2rem);justify-content:center;margin-bottom:clamp(1rem,3vw,1.5rem);padding-bottom:clamp(.5rem,2vw,1rem)}.gallery-location-details p{color:var(--gray-400);font-size:clamp(.75rem,2vw,.875rem);margin:0}.gallery-modal-body{align-items:center;display:flex;justify-content:center;min-height:200px}@keyframes galleryFadeIn{0%{opacity:0;transform:scale(.95) translateY(-1rem)}to{opacity:1;transform:scale(1) translateY(0)}}@media screen and (max-width:440px){.gallery-modal{padding:.5rem}.gallery-modal-content{max-height:95vh;max-width:100%;padding:.75rem}.gallery-modal-header h2{font-size:1rem;margin-bottom:.5rem}.gallery-location-details{gap:.5rem;margin-bottom:.75rem;padding-bottom:.5rem}.gallery-location-details p{font-size:.75rem}.gallery-modal-body{min-height:120px}}@media screen and (min-width:1024px){.gallery-modal{padding:1rem}.gallery-modal-content{max-width:40rem;padding:2rem}.gallery-modal-header h2{font-size:1.5rem;margin-bottom:.75rem}.gallery-location-details{gap:2rem;margin-bottom:1.5rem;padding-bottom:1rem}.gallery-location-details p{font-size:.875rem}.gallery-modal-body{min-height:250px}}@media screen and (min-width:1200px){.gallery-modal{padding:1.5rem}.gallery-modal-content{max-width:50rem;padding:2.5rem}.gallery-modal-header h2{font-size:1.75rem;margin-bottom:1rem}.gallery-location-details{gap:2.5rem;margin-bottom:2rem;padding-bottom:1.5rem}.gallery-location-details p{font-size:1rem}.gallery-modal-body{min-height:300px}}.gallery-controls{display:flex;flex-direction:column;gap:clamp(.5rem,1.5vw,.75rem);margin-bottom:clamp(.5rem,1.5vw,.75rem);padding:clamp(.25rem,1vw,.5rem)}.gallery-search-section{align-items:center;display:flex;flex-wrap:wrap;gap:clamp(.25rem,1vw,.5rem)}.gallery-search-input{background:var(--surface);border:1px solid var(--border);border-radius:.375rem;color:var(--on-primary);flex:1 1;font-size:clamp(.875rem,2.5vw,1rem);min-width:clamp(8rem,20vw,14rem);padding:clamp(.375rem,1vw,.5rem);transition:border-color .3s ease,box-shadow .3s ease}.gallery-search-input:focus{border-color:var(--accent);box-shadow:0 0 0 2px #61dafb33;outline:none}.gallery-search-field-select{background:var(--surface);border:1px solid var(--border);border-radius:.375rem;color:var(--on-primary);font-size:clamp(.875rem,2.5vw,1rem);min-width:clamp(5rem,10vw,8rem);padding:clamp(.375rem,1vw,.5rem);transition:border-color .3s ease,box-shadow .3s ease}.gallery-search-field-select:focus{border-color:var(--accent);box-shadow:0 0 0 2px #61dafb33;outline:none}.gallery-sort-section{align-items:center;display:flex;flex-wrap:wrap;gap:clamp(.25rem,1vw,.5rem)}.gallery-sort-field-select,.gallery-sort-mode-select{background:var(--surface);border:1px solid var(--border);border-radius:.375rem;color:var(--on-primary);font-size:clamp(.875rem,2.5vw,1rem);min-width:clamp(5rem,10vw,8rem);padding:clamp(.375rem,1vw,.5rem);transition:border-color .3s ease,box-shadow .3s ease}.gallery-sort-field-select:focus,.gallery-sort-mode-select:focus{border-color:var(--accent);box-shadow:0 0 0 2px #61dafb33;outline:none}.gallery-search-stats{background:var(--surface);border:1px solid var(--border);border-radius:.375rem;margin-bottom:clamp(.25rem,1vw,.5rem);padding:clamp(.25rem,1vw,.5rem);text-align:center}.gallery-search-stats p{color:var(--on-primary);font-size:clamp(.875rem,2.5vw,1rem);margin:0}.gallery-no-results{color:var(--warning-color);font-weight:500}.gallery-scrollable{flex:1 1;height:100%;overflow-y:auto;scrollbar-color:var(--border) #0000;scrollbar-width:thin}.gallery-scrollable::-webkit-scrollbar{width:clamp(.25rem,1vw,.5rem)}.gallery-scrollable::-webkit-scrollbar-track{background:#0000}.gallery-scrollable::-webkit-scrollbar-thumb{background:var(--border);border-radius:.25rem}.gallery-scrollable::-webkit-scrollbar-thumb:hover{background:var(--gray-600)}.gallery-status{color:var(--on-primary);font-size:clamp(.875rem,2.5vw,1rem);padding:clamp(.75rem,2vw,1rem);text-align:center}.gallery-status.error{color:var(--error-color)}@media screen and (max-width:440px){.gallery-controls{flex-direction:column;gap:.5rem}.gallery-search-section,.gallery-sort-section{flex-direction:column;gap:.375rem;width:100%}.gallery-search-field-select,.gallery-search-input,.gallery-sort-field-select,.gallery-sort-mode-select{font-size:.875rem;min-width:0;min-width:auto;padding:.5rem;width:100%}.gallery-search-stats{margin-bottom:.25rem;padding:.25rem}.gallery-search-stats p,.gallery-status{font-size:.875rem}.gallery-status{padding:.75rem}}@media screen and (min-width:1024px){.gallery-controls{align-items:flex-start;flex-direction:row;gap:1.5rem;justify-content:space-between}.gallery-search-section,.gallery-sort-section{flex:1 1;flex-direction:row;gap:.75rem;max-width:50%}.gallery-search-field-select,.gallery-search-input,.gallery-sort-field-select,.gallery-sort-mode-select{font-size:1rem;padding:.75rem}.gallery-search-stats{margin-bottom:.5rem;padding:.5rem}.gallery-search-stats p{font-size:1rem}.gallery-status{font-size:1rem;padding:1rem}}@media screen and (min-width:1200px){.gallery-controls{gap:2rem}.gallery-search-section,.gallery-sort-section{gap:1rem}.gallery-search-field-select,.gallery-search-input,.gallery-sort-field-select,.gallery-sort-mode-select{font-size:1.125rem;padding:1rem}.gallery-search-stats{margin-bottom:.75rem;padding:.75rem}.gallery-search-stats p,.gallery-status{font-size:1.125rem}.gallery-status{padding:1.25rem}}.galleryPage{background-color:var(--bg-primary);box-sizing:border-box;color:var(--on-primary);display:flex;flex-direction:column;height:100vh;overflow:hidden;width:100%}.project-list{grid-gap:1.5rem;animation:fadeInUp .8s ease-out .4s both;display:grid;gap:1.5rem;grid-template-columns:repeat(2,1fr);margin:0 auto;max-width:1200px;padding:0;width:100%}.project-card{align-items:center;animation:cardSlideIn .6s ease-out both;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:linear-gradient(135deg,#ffffff14,#ffffff08);border:1px solid #ffffff14;border-radius:20px;color:var(--on-primary);cursor:pointer;display:flex;justify-content:center;min-height:120px;overflow:hidden;padding-left:2rem;position:relative;transition:all .4s cubic-bezier(.4,0,.2,1)}.project-card:before{background:linear-gradient(135deg,#4a9eff,#3a8eef);bottom:0;content:"";left:0;opacity:0;position:absolute;right:0;top:0;transition:opacity .4s ease;z-index:0}.project-card:focus,.project-card:hover{border-color:#4a9eff;transform:translateY(-6px) scale(1.01)}.project-card:hover:before{opacity:.08}.project-card:focus-visible{outline-offset:2px}.project-card-content{align-items:center;display:flex;gap:1.5rem;position:relative;width:100%;z-index:1}.project-icon{align-items:center;background:linear-gradient(135deg,#4a9eff,#3a8eef);border-radius:16px;display:flex;flex-shrink:0;height:60px;justify-content:center;overflow:hidden;transition:all .3s ease;width:60px}.project-card:hover .project-icon{transform:scale(1.08)}.project-icon svg{color:#fff;height:32px;width:32px}.project-icon-image{border-radius:16px;height:100%;object-fit:cover;width:100%}.project-info{flex:1 1;min-width:0}.project-name{color:var(--on-primary);font-size:1.25rem;font-weight:700;-webkit-hyphens:auto;hyphens:auto;line-height:1.3;margin:0;transition:color .3s ease;word-break:break-word}@keyframes cardSlideIn{0%{opacity:0;transform:translateY(30px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}@media screen and (max-width:440px){.project-list{gap:.75rem;grid-template-columns:1fr;max-width:100%;padding:0 .25rem;width:100%}.project-card{min-height:80px;padding:1rem}.project-card-content{gap:.5rem}.project-icon{height:40px;width:40px}.project-icon svg{height:20px;width:20px}.project-name{font-size:.875rem}}@media screen and (min-width:1024px){.project-list{gap:1.5rem;grid-template-columns:1fr;padding:0 1rem;width:100%}.project-card{min-height:120px;padding:2rem}.project-card-content{gap:1.25rem}.project-icon{height:60px;width:60px}.project-icon svg{height:32px;width:32px}.project-name{font-size:1.25rem}}@media screen and (min-width:1200px){.project-list{gap:2rem;grid-template-columns:1fr;padding:0 1.5rem;width:100%}.project-card{min-height:140px;padding:2.5rem}.project-card-content{gap:1.5rem}.project-icon{height:70px;width:70px}.project-icon svg{height:36px;width:36px}.project-name{font-size:1.5rem}}@media (prefers-reduced-motion:reduce){.project-card,.project-icon{animation:none;transition:none}.project-card:hover,.project-card:hover .project-icon{transform:none}}.project-card:focus-visible{outline:2px solid #4a9eff;outline-offset:4px}@media (prefers-color-scheme:dark){.project-card{background:linear-gradient(135deg,#ffffff0f,#ffffff05);border-color:#ffffff1f}}.select-container{align-items:center;background-color:var(--bg-primary);box-sizing:border-box;color:var(--on-primary);display:flex;flex-direction:column;font-family:var(--font-family);max-width:100%;overflow:hidden;position:relative}.projects-section{animation:fadeInUp .8s ease-out .2s both;max-width:1200px;position:relative;width:100%;z-index:1}.empty-state{animation:fadeInUp .8s ease-out;flex-direction:column;margin:4rem auto;max-width:500px;padding:4rem 2rem}.empty-state,.empty-state-icon{align-items:center;display:flex}.empty-state-icon{color:var(--gray-400);height:64px;justify-content:center;margin-bottom:2rem;opacity:.6;width:64px}.empty-state-icon svg{height:100%;width:100%}.empty-state-title{color:var(--on-primary);font-size:1.5rem;font-weight:600;line-height:1.3;margin:0 0 1rem}.empty-state-description{color:var(--gray-500);font-size:1rem;line-height:1.6;margin:0;max-width:400px}@media screen and (max-width:440px){.hero-section{margin-bottom:1.5rem}.empty-state,.projects-section{max-width:100%}.empty-state{margin:0 .75rem;padding:1rem}.empty-state-icon{height:48px;margin-bottom:1.5rem;width:48px}.empty-state-title{font-size:1.25rem;margin-bottom:.75rem}.empty-state-description{font-size:.875rem;max-width:100%}}@media screen and (min-width:1024px){.hero-section{margin-bottom:3rem}.projects-section{max-width:1200px}.empty-state{margin:0 2rem;max-width:500px;padding:3rem 2rem}.empty-state-icon{height:64px;margin-bottom:2rem;width:64px}.empty-state-title{font-size:1.75rem;margin-bottom:1.25rem}.empty-state-description{font-size:1.125rem;max-width:400px}}@media screen and (min-width:1200px){.hero-section{margin-bottom:3.5rem}.projects-section{max-width:1400px}.empty-state{margin:0 3rem;max-width:600px;padding:4rem 2.5rem}.empty-state-icon{height:80px;margin-bottom:2.5rem;width:80px}.empty-state-title{font-size:2rem;margin-bottom:1.5rem}.empty-state-description{font-size:1.25rem;max-width:500px}}@media (prefers-reduced-motion:reduce){.empty-state,.hero-section,.projects-section{animation:none}}.accordion{border:1px solid var(--border);border-radius:.5rem;margin-bottom:1rem;position:relative;z-index:1}.accordion-header{align-items:center;background:var(--surface);border:none;border-radius:.5rem .5rem 0 0;cursor:pointer;display:flex;justify-content:space-between;padding:1rem;position:relative;transition:background-color .3s ease;width:100%;z-index:2}.accordion-header:hover{background:var(--bg-primary)}.accordion-title{align-items:center;color:var(--on-primary);display:flex;font-size:1.1rem;font-weight:600;gap:.5rem}.accordion-title-icon{color:var(--on-primary);font-size:1.2rem}.accordion-icon{color:var(--on-primary);font-size:.8rem;transition:transform .3s ease}.accordion-icon.open{transform:rotate(180deg)}.accordion-content{background:var(--bg-primary);border-radius:0 0 .5rem .5rem;max-height:0;overflow:hidden;position:relative;transition:max-height .3s ease;z-index:1}.accordion-content>*{padding:1rem;position:relative;z-index:1}.accordion-content.open{max-height:none;overflow:visible}.accordion-content.open>*{max-height:60vh;overflow-x:hidden;overflow-y:auto}.accordion-content.open>::-webkit-scrollbar{width:8px}.accordion-content.open>::-webkit-scrollbar-track{background:var(--gray-900);border-radius:4px}.accordion-content.open>::-webkit-scrollbar-thumb{background:var(--gray-600);border-radius:4px}.accordion-content.open>::-webkit-scrollbar-thumb:hover{background:var(--gray-500)}.label-form{display:flex;flex-direction:column;gap:1rem;width:100%}.form-row{align-items:flex-start;display:flex;gap:1rem}.form-group{display:flex;flex:1 1;flex-direction:column;gap:.5rem}.form-group:last-child{align-items:center}.form-group label{color:var(--on-primary);font-size:.9rem;font-weight:500}.label-input{background:var(--surface);border:1px solid var(--border);border-radius:.375rem;color:var(--on-primary);font-size:.95rem;padding:.75rem;transition:border-color .3s ease}.label-input:focus{border-color:var(--accent);box-shadow:0 0 0 2px #61dafb33;outline:none}.label-input:invalid{border-color:var(--error-color)}.label-color{align-self:center;background:none;border:1px solid var(--border);border-radius:.375rem;cursor:pointer;height:2.5rem;transition:border-color .3s ease;width:3rem}.label-color:focus{border-color:var(--accent);box-shadow:0 0 0 2px #61dafb33;outline:none}.label-form-action-buttons{display:flex;gap:.75rem;justify-content:space-between}.status-message{border-radius:.25rem;font-size:.85rem;padding:.5rem;text-align:center}.status-message.error{background-color:#f443361a;color:var(--error-color)}.form-group label .material-symbols-outlined{margin-right:.5rem;vertical-align:middle}@media screen and (max-width:440px){.form-row,.label-form{gap:.75rem}.form-row{flex-direction:column}.form-group{flex:none;gap:.375rem}.form-group label,.label-input{font-size:.875rem}.label-input{padding:.625rem}.label-color{height:2rem;width:2.5rem}.label-form-action-buttons{flex-direction:column;gap:.5rem}.status-message{font-size:.8rem;padding:.375rem}}@media screen and (min-width:1024px){.form-row,.label-form{gap:1.25rem}.form-row{flex-direction:row}.form-group{flex:1 1;gap:.75rem}.form-group label,.label-input{font-size:1rem}.label-input{padding:1rem}.label-color{height:3rem;width:3.5rem}.label-form-action-buttons{flex-direction:row;gap:1rem}.status-message{font-size:.9rem;padding:.75rem}}@media screen and (min-width:1200px){.form-row,.label-form{gap:1.5rem}.form-group{gap:1rem}.form-group label,.label-input{font-size:1.125rem}.label-input{padding:1.25rem}.label-color{height:3.5rem;width:4rem}.label-form-action-buttons{gap:1.25rem}.status-message{font-size:1rem;padding:1rem}}.label-card{align-items:center;background:var(--bg-primary);border:1px solid var(--border);border-radius:.5rem;display:flex;justify-content:space-between;padding:.75rem 1rem;position:relative;transition:all .3s ease}.label-card:hover{border-color:var(--accent);box-shadow:0 2px 8px #61dafb1a}.label-badge{align-items:center;display:flex;flex:1 1;gap:.75rem}.label-color-badge{border:2px solid var(--border);border-radius:50%;display:inline-block;flex-shrink:0;height:1.25rem;width:1.25rem}.label-name{color:var(--on-primary);font-size:.95rem;font-weight:500}.label-menu{position:relative}.menu-toggle{background:none;border:none;border-radius:.25rem;color:var(--on-primary);cursor:pointer;font-size:1.2rem;padding:.5rem;transition:background-color .3s ease}.menu-dropdown,.menu-toggle:hover{background:var(--surface)}.menu-dropdown{border:1px solid var(--border);border-radius:.375rem;box-shadow:0 4px 12px #00000026;margin-top:.25rem;min-width:120px;position:absolute;right:0;top:100%;z-index:10}.menu-item{background:none;border:none;color:var(--on-primary);cursor:pointer;display:block;font-size:.9rem;padding:.75rem 1rem;text-align:left;transition:background-color .3s ease;width:100%}.menu-item:hover{background:var(--bg-primary)}.menu-item-danger{color:var(--error-color)}.menu-item-danger:hover{background:#f443361a}.button-icon,.menu-item .material-symbols-outlined{margin-right:.5rem;vertical-align:middle}.label-manager-container{gap:clamp(1rem,3vw,1.5rem)}.label-manager-container,.label-manager-header{align-items:center;display:flex;flex-direction:column;width:100%}.label-manager-header{border-bottom:1px solid var(--border);gap:clamp(.75rem,2vw,1rem);justify-content:center;margin-bottom:0;padding-bottom:clamp(1rem,3vw,1.5rem)}.label-grid{grid-gap:clamp(1rem,3vw,1.5rem);display:grid;gap:clamp(1rem,3vw,1.5rem);grid-template-columns:repeat(auto-fill,minmax(280px,1fr));justify-content:center;max-width:800px;width:100%}.empty-state{color:var(--on-primary);opacity:.7;padding:clamp(2rem,5vw,3rem);text-align:center}.empty-state .material-symbols-outlined{font-size:clamp(3rem,8vw,4rem);margin-bottom:1rem;opacity:.5}.empty-state p{font-size:clamp(1rem,2.5vw,1.125rem);margin:0}@media screen and (max-width:440px){.label-manager-container{gap:1rem}.label-manager-header{justify-content:center}.label-grid{gap:1rem;grid-template-columns:1fr}.empty-state{padding:1.5rem}.empty-state .material-symbols-outlined{font-size:3rem}.empty-state p{font-size:1rem}}@media screen and (min-width:1024px){.label-manager-container{gap:1.5rem}.label-grid{gap:1.5rem;grid-template-columns:repeat(auto-fill,minmax(320px,1fr))}.empty-state{padding:3rem}.empty-state .material-symbols-outlined{font-size:4rem}.empty-state p{font-size:1.125rem}}@media screen and (min-width:1200px){.label-manager-container{gap:2rem}.label-grid{gap:2rem;grid-template-columns:repeat(auto-fill,minmax(350px,1fr))}.empty-state{padding:4rem}.empty-state .material-symbols-outlined{font-size:4rem}.empty-state p{font-size:1.125rem}}.card{background-color:var(--surface);border-radius:10px;box-shadow:0 2px 6px #0000001a;box-sizing:border-box;padding:20px;position:relative;width:100%;z-index:1}.input{background:var(--surface);border:1px solid var(--border);border-radius:6px;color:var(--on-primary);font-size:1rem;padding:10px}.section-title{font-size:1.25rem;font-weight:700;margin-bottom:1rem}.section-title,.status-message{color:var(--on-primary);position:relative;z-index:1}.status-message{font-size:.9rem}.status-message.error{color:red}.project-form{gap:clamp(.75rem,2vw,1rem);margin-bottom:clamp(1.5rem,4vw,2rem);width:100%}.project-form,.project-form>div{display:flex;flex-direction:column;position:relative;z-index:1}.project-form>div{gap:.5rem}.project-form label{font-weight:500}.project-form input,.project-form label{color:var(--on-primary);font-size:clamp(.875rem,2.5vw,1rem);position:relative;z-index:1}.project-form input{background:var(--surface);border:1px solid var(--border);border-radius:.375rem;padding:clamp(.625rem,2vw,.75rem);transition:border-color .3s ease}.project-form input:focus{border-color:var(--accent);box-shadow:0 0 0 2px #61dafb33;outline:none}.project-form input:invalid{border-color:var(--error-color)}.project-form .status-message{border-radius:.25rem;color:var(--on-primary);font-size:clamp(.75rem,2vw,.875rem);margin-top:.5rem;padding:clamp(.5rem,1.5vw,.75rem);text-align:center}.project-form .status-message.error{background-color:#f443361a;color:var(--error-color)}.project-form .status-message.success{background-color:#4caf501a;color:var(--success-color)}@media screen and (max-width:440px){.card{border-radius:.5rem;padding:1rem}.input{font-size:.875rem;padding:.75rem}.section-title{font-size:1.125rem;margin-bottom:.75rem}.status-message{font-size:.8rem}.project-form{gap:.75rem;margin-bottom:1.5rem}.project-form>div{gap:.5rem}.project-form label{font-size:.875rem}.project-form input{font-size:.875rem;padding:.625rem}.project-form .status-message{font-size:.75rem;padding:.5rem}}@media screen and (min-width:1024px){.card{border-radius:.75rem;padding:1.5rem}.input{font-size:1rem;padding:1rem}.section-title{font-size:1.375rem;margin-bottom:1.25rem}.status-message{font-size:1rem}.project-form{gap:1.25rem;margin-bottom:2.5rem}.project-form>div{gap:1rem}.project-form label{font-size:1rem}.project-form input{font-size:1rem;padding:.75rem}.project-form .status-message{font-size:.875rem;padding:.75rem}}@media screen and (min-width:1200px){.card{border-radius:.875rem;padding:1.75rem}.input{font-size:1rem;padding:1rem}.section-title{font-size:1.375rem;margin-bottom:1.25rem}.status-message{font-size:1rem}.project-form{gap:1.25rem;margin-bottom:2.5rem}.project-form>div{gap:1rem}.project-form label{font-size:1rem}.project-form input{font-size:1rem;padding:.875rem}.project-form .status-message{font-size:.9rem;padding:.875rem}}.project-location-container{align-items:center;display:flex;flex-direction:column;gap:clamp(1rem,3vw,1.5rem);width:100%}.project-location-header{align-items:center;border-bottom:1px solid var(--border);display:flex;gap:clamp(.5rem,2vw,.75rem);justify-content:center;margin-bottom:0;padding-bottom:clamp(1rem,3vw,1.5rem);width:100%}.help-tooltip{display:inline-block;position:relative}.help-icon{align-items:center;background:var(--accent);border-radius:50%;color:#fff;cursor:help;display:inline-flex;font-size:clamp(.75rem,2vw,.8rem);font-weight:700;height:clamp(1.25rem,3vw,1.5rem);justify-content:center;transition:all .3s ease;width:clamp(1.25rem,3vw,1.5rem)}.help-icon:hover{background:var(--accent-hover);transform:scale(1.1)}.tooltip-content{background:var(--surface);border:1px solid var(--border);border-radius:.5rem;box-shadow:0 4px 12px #00000026;color:var(--on-primary);font-size:clamp(.75rem,2vw,.85rem);margin-top:.5rem;opacity:0;padding:clamp(.5rem,2vw,.75rem);top:100%;transition:all .3s ease;visibility:hidden;white-space:nowrap;z-index:10}.tooltip-content,.tooltip-content:before{left:50%;position:absolute;transform:translateX(-50%)}.tooltip-content:before{border:5px solid #0000;border-bottom:5px solid var(--border);bottom:100%;content:""}.help-tooltip:hover .tooltip-content{opacity:1;visibility:visible}.project-location-form{align-items:center;display:flex;flex-direction:column;gap:clamp(1rem,3vw,1.5rem);width:100%}.location-inputs{grid-gap:clamp(.75rem,2vw,1rem);align-items:end;display:grid;gap:clamp(.75rem,2vw,1rem);grid-template-columns:repeat(auto-fit,minmax(200px,1fr));max-width:600px;width:100%}.input-group{display:flex;flex-direction:column;gap:clamp(.5rem,1.5vw,.75rem);text-align:center}.input-group label{font-weight:500;line-height:1.4}.input-group input,.input-group label{color:var(--on-primary);font-size:clamp(.875rem,2.5vw,1rem)}.input-group input{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ffffff0d;border:1px solid #ffffff1a;border-radius:.75rem;box-sizing:border-box;padding:clamp(.75rem,2vw,1rem);text-align:center;transition:all .3s ease;width:100%}@media screen and (min-width:1024px){.input-group input{text-align:right}}.input-group input:focus{background:#ffffff1a;border-color:var(--accent);box-shadow:0 0 0 3px #61dafb26;outline:none;transform:translateY(-1px)}.input-group input:invalid{border-color:var(--error-color);box-shadow:0 0 0 3px #f4433626}.project-location-form-actions{display:flex;gap:clamp(.75rem,2vw,1rem);justify-content:center;margin-top:clamp(.5rem,1.5vw,1rem);width:100%}@media screen and (max-width:440px){.project-location-container{gap:1rem}.project-location-header{align-items:flex-start;flex-direction:column;gap:.5rem}.help-icon{font-size:.75rem;height:1.25rem;width:1.25rem}.tooltip-content{font-size:.75rem;margin-top:.375rem;padding:.5rem}.project-location-form{gap:1rem}.location-inputs{gap:.75rem;grid-template-columns:1fr}.input-group{gap:.5rem}.input-group label{font-size:.875rem}.input-group input{font-size:.875rem;padding:.75rem}.project-location-form-actions{flex-direction:column;gap:.75rem;justify-content:center}}@media screen and (min-width:1024px){.project-location-container{gap:1.5rem}.project-location-header{align-items:center;flex-direction:row;gap:1rem}.help-icon{font-size:.875rem;height:1.75rem;width:1.75rem}.tooltip-content{font-size:.9rem;margin-top:.75rem;padding:1rem}.project-location-form{gap:1.5rem}.location-inputs{gap:1.25rem;grid-template-columns:repeat(3,1fr)}.input-group{gap:.75rem}.input-group label{font-size:1rem}.input-group input{font-size:1rem;padding:1rem}.project-location-form-actions{flex-direction:row;gap:1.25rem}}@media screen and (min-width:1200px){.project-location-container{gap:2rem}.project-location-header{gap:1.25rem}.help-icon{font-size:1rem;height:2rem;width:2rem}.tooltip-content{font-size:1rem;margin-top:1rem;padding:1.25rem}.project-location-form{gap:2rem}.location-inputs{gap:1.5rem}.input-group{gap:1rem}.input-group label{font-size:1rem}.input-group input{font-size:1rem;padding:1rem}.project-location-form-actions{gap:1.5rem}}.project-detail-form{align-items:center;color:#fff!important;margin:auto;max-width:600px}.form-header{border-bottom:1px solid var(--border);margin-bottom:0;padding-bottom:clamp(1rem,3vw,1.5rem);width:100%}.section-description{color:var(--on-primary);font-size:clamp(.875rem,2.5vw,1rem);line-height:1.5;margin:0;opacity:.8;text-align:center}@media screen and (min-width:1024px){.project-detail-form{align-items:stretch;max-width:none}.project-detail-form .form-layout{grid-gap:clamp(1.5rem,3vw,2rem);align-items:start;display:grid;gap:clamp(1.5rem,3vw,2rem);grid-template-columns:1fr 1fr}.project-detail-form .form-left,.project-detail-form .form-right{display:flex;flex-direction:column;gap:clamp(1rem,2vw,1.5rem)}.project-detail-form .form-right{height:100%}.project-detail-form .form-description{display:flex;flex:0 0 80%;flex-direction:column}.project-detail-form .form-kml-settings{display:flex;flex:0 0 20%;flex-direction:column;justify-content:flex-end}.project-detail-form .form-actions{display:flex;grid-column:1/-1;justify-content:center}}.project-detail-form .form-actions{border-top:1px solid var(--border);display:flex;justify-content:center;margin-top:1rem;padding-top:1rem;width:100%}.project-detail-form .form-group{display:flex;flex-direction:column;gap:.5rem;margin-bottom:1.5rem;text-align:center;width:100%}.project-detail-form .form-label{color:#fff!important;display:block;font-size:.9rem;font-weight:600;margin-bottom:.5rem}.project-detail-form .form-textarea{background:#fff;border:1px solid #ddd;border-radius:6px;color:#333;font-family:inherit;font-size:.9rem;min-height:100px;padding:.75rem;resize:vertical;transition:border-color .2s ease;width:100%}.project-detail-form .form-textarea:focus{border-color:#007bff;box-shadow:0 0 0 2px #007bff1a;outline:none}.project-detail-form .form-textarea::placeholder{color:#999}.project-detail-form .thumbnail-section{align-items:center;display:flex;flex-direction:column;gap:1rem}.project-detail-form .thumbnail-preview{align-self:center;display:inline-block;max-width:200px;position:relative}@media screen and (min-width:1024px){.project-detail-form .thumbnail-preview{max-width:clamp(200px,30vw,300px)}}.project-detail-form .thumbnail-image{background-color:#f8f9fa;border:2px solid #ddd;border-radius:8px;box-shadow:0 2px 8px #0000001a;height:auto;object-fit:cover;transition:transform .2s ease,box-shadow .2s ease;width:100%}.project-detail-form .thumbnail-image:hover{box-shadow:0 4px 12px #00000026;transform:scale(1.02)}.project-detail-form .remove-thumbnail-btn{align-items:center;background:#dc3545;border:none;border-radius:50%;color:#fff;cursor:pointer;display:flex;font-size:14px;height:24px;justify-content:center;position:absolute;right:-8px;top:-8px;transition:background-color .2s ease;width:24px}.project-detail-form .remove-thumbnail-btn:hover{background:#c82333}.project-detail-form .form-file-input{display:none}.project-detail-form .file-input-label{align-items:center;border:2px dashed #ddd;border-radius:6px;color:#fff!important;cursor:pointer;display:inline-flex;font-size:.9rem;gap:.5rem;padding:.75rem 1rem;transition:all .2s ease}.project-detail-form .file-input-label:hover{background:#007bff1a;border-color:#007bff;color:#fff!important}.project-detail-form .file-input-label .material-symbols-outlined{font-size:1.2rem}.project-detail-form .form-checkbox-label{align-items:center;color:#fff!important;cursor:pointer;display:flex;font-size:.9rem;gap:.5rem}.project-detail-form .form-checkbox{accent-color:#007bff;cursor:pointer;height:18px;width:18px}.project-detail-form .checkbox-text{-webkit-user-select:none;user-select:none}.project-detail-form .submit-btn{background:#007bff;border:none;border-radius:6px;color:#fff;cursor:pointer;font-size:.9rem;font-weight:600;padding:.75rem 2rem;transition:background-color .2s ease}.project-detail-form .submit-btn:hover:not(:disabled){background:#0056b3}.project-detail-form .submit-btn:disabled{background:#6c757d;cursor:not-allowed}@media (max-width:768px){.project-detail-form{padding:.5rem 0}.project-detail-form .form-group{margin-bottom:1rem}.project-detail-form .thumbnail-preview{max-width:150px}.project-detail-form .submit-btn{padding:1rem;width:100%}}.public-mode-settings{align-items:center;display:flex;flex-direction:column;gap:clamp(1rem,3vw,1.5rem);text-align:center;width:100%}@media screen and (min-width:1024px){.public-mode-settings{align-items:stretch}.public-mode-layout{grid-gap:clamp(1.5rem,3vw,2rem);align-items:start;display:grid;gap:clamp(1.5rem,3vw,2rem);grid-template-columns:1fr 2fr}.public-mode-toggle-section{align-items:center;display:flex;flex-direction:column;justify-content:center;min-height:100px}.public-url-section{align-items:stretch;max-width:none}}.public-mode-header{margin-bottom:0;width:100%}.public-mode-description{border-bottom:1px solid var(--border);color:var(--on-primary);font-size:clamp(.875rem,2.5vw,1rem);line-height:1.5;margin:0;opacity:.8;padding-bottom:clamp(1rem,3vw,1.5rem);text-align:center}.public-mode-toggle{align-items:center;display:flex;gap:clamp(.75rem,2vw,1rem);justify-content:center;margin-bottom:0;width:100%}.toggle-switch{display:inline-block;height:clamp(24px,3vw,30px);position:relative;width:clamp(50px,6vw,60px)}.toggle-switch input{height:0;opacity:0;width:0}.toggle-slider{background-color:var(--border);border-radius:30px;bottom:0;cursor:pointer;left:0;right:0;top:0}.toggle-slider,.toggle-slider:before{position:absolute;transition:all .3s ease}.toggle-slider:before{background-color:var(--on-primary);border-radius:50%;bottom:3px;box-shadow:0 2px 4px #0003;content:"";height:calc(100% - 6px);left:3px;width:calc(50% - 3px)}input:checked+.toggle-slider{background-color:var(--button-primary)}input:disabled+.toggle-slider{cursor:not-allowed;opacity:.6}input:checked+.toggle-slider:before{transform:translateX(calc(100% + 6px))}.public-mode-settings .toggle-label{color:var(--on-primary);font-size:clamp(.875rem,2.5vw,1rem);font-weight:500}.public-url-section{align-items:center;display:flex;flex-direction:column;gap:clamp(.75rem,2vw,1rem);max-width:500px;width:100%}.public-url-section.disabled{opacity:.5;pointer-events:none}.public-url-label{color:var(--on-primary);display:block;font-size:clamp(.875rem,2.5vw,1rem);font-weight:500;margin-bottom:0;text-align:center}.public-url-container{align-items:stretch;display:flex;gap:clamp(.5rem,1.5vw,.75rem);width:100%}.public-url-input{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ffffff0d;border:1px solid #ffffff1a;border-radius:.75rem;color:var(--on-primary);flex:1 1;font-family:monospace;font-size:clamp(.875rem,2.5vw,1rem);padding:clamp(.75rem,2vw,1rem);transition:all .3s ease}.public-url-input:focus{background:#ffffff1a;border-color:var(--accent);box-shadow:0 0 0 3px #61dafb26;outline:none;transform:translateY(-1px)}.copy-url-button{align-items:center;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background-color:var(--button-primary);border:none;border-radius:.75rem;color:var(--on-primary);cursor:pointer;display:flex;font-size:clamp(1rem,2.5vw,1.2rem);justify-content:center;min-height:clamp(2.5rem,6vw,3rem);min-width:clamp(2.5rem,6vw,3rem);padding:clamp(.75rem,2vw,1rem);transition:all .3s ease}.copy-url-button:hover:not(:disabled){background-color:var(--button-primary-hover);box-shadow:0 6px 16px #1976d24d;transform:translateY(-2px)}.copy-url-button:active:not(:disabled){box-shadow:0 2px 4px #1976d233;transform:translateY(0)}.copy-url-button:disabled{cursor:not-allowed;opacity:.6;transform:none!important}.copy-url-button.copied{background-color:var(--button-success)}.copy-url-button.copied:hover{background-color:var(--button-success-hover)}.copy-url-button .material-icons{font-size:inherit;transition:transform .2s ease}.copy-url-button.copied .material-icons{transform:scale(1.1)}.public-url-note{color:var(--on-primary);font-size:clamp(.75rem,2vw,.875rem);line-height:1.5;margin:0;opacity:.7;text-align:center}.updating-indicator{align-items:center;color:var(--on-primary);display:flex;font-size:clamp(.875rem,2.5vw,1rem);gap:clamp(.5rem,1.5vw,.75rem);justify-content:center;margin-top:0;opacity:.7;width:100%}.rotating{animation:rotate 1s linear infinite}@keyframes rotate{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}@media screen and (max-width:440px){.public-mode-settings{gap:1rem}.public-mode-toggle{gap:.75rem}.toggle-switch{height:24px;width:50px}.public-url-section{gap:.75rem;padding-top:1rem}.public-url-container{flex-direction:column;gap:.75rem}.copy-url-button{align-self:stretch;min-height:44px}}@media screen and (min-width:1024px){.public-mode-settings{gap:1.5rem}.public-mode-toggle{gap:1rem}.toggle-switch{height:30px;width:60px}.public-url-section{gap:1rem}.public-url-container{gap:.75rem}}@media screen and (min-width:1200px){.public-mode-settings{gap:2rem}.public-mode-toggle,.public-url-section{gap:1.25rem}.public-url-container{gap:1rem}}.project-detail-container{background:linear-gradient(135deg,var(--bg-primary) 0,var(--surface) 100%);box-sizing:border-box;height:auto;min-height:100vh;overflow:visible;padding:clamp(1rem,3vw,2rem);position:relative;width:100%}.project-detail-content{display:flex;flex-direction:column;gap:clamp(1.5rem,4vw,2rem);margin:0 auto;max-width:60rem}.project-detail-content .page-title{-webkit-text-fill-color:#0000;background:linear-gradient(135deg,var(--accent),var(--button-primary));-webkit-background-clip:text;background-clip:text;color:var(--on-primary);font-size:clamp(1.5rem,4vw,2rem);font-weight:600;line-height:1.3;margin:0 0 clamp(.5rem,2vw,1rem);text-align:center}.project-detail-content .accordion{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ffffff0d;border:1px solid #ffffff1a;border-radius:1rem;margin-bottom:0;overflow:hidden;transition:all .3s ease}.project-detail-content .accordion:hover{box-shadow:0 8px 32px #0000001a;transform:translateY(-2px)}.scrollable-center-container{align-items:center;background:linear-gradient(135deg,var(--bg-primary) 0,var(--surface) 100%);box-sizing:border-box;display:flex;flex-direction:column;height:auto;max-width:100%;min-height:100vh;overflow-y:auto;padding:clamp(1rem,3vw,2rem);position:relative;width:100%;z-index:1}.scrollable-center-container>*{margin:0 auto;max-width:60rem;width:100%}.scrollable-center-container .card{margin-left:auto;margin-right:auto;width:100%}.scrollable-center-container .accordion{margin-bottom:clamp(1.5rem,4vw,2rem)}.scrollable-center-container .accordion:last-child{margin-bottom:0}.error-message{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#f443361a;border:1px solid #f4433633;border-radius:1rem;color:var(--error-color);margin:clamp(1rem,3vw,2rem);padding:clamp(2rem,5vw,4rem);text-align:center}.error-message p{line-height:1.5;margin:0}.error-message p,.loading{color:var(--on-primary);font-size:clamp(1rem,2.5vw,1.25rem)}.loading{align-items:center;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#2196f31a;border:1px solid #2196f333;border-radius:1rem;display:flex;justify-content:center;margin:clamp(1rem,3vw,2rem);padding:clamp(2rem,5vw,4rem)}@media screen and (max-width:440px){.project-detail-container{padding:.5rem;width:100%}.project-detail-content{gap:1.5rem;max-width:100%;width:100%}.project-detail-content .page-title{font-size:1.5rem}.scrollable-center-container{max-width:100%;padding:.5rem;width:100%}.scrollable-center-container>*{max-width:100%}.scrollable-center-container .accordion{margin-bottom:1.5rem}.error-message{margin:1rem;padding:1.5rem}.error-message p,.loading{font-size:1rem}.loading{margin:1rem;padding:1.5rem}}@media screen and (min-width:1024px){.project-detail-container{padding:1.5rem}.project-detail-content{gap:2rem;max-width:60rem}.project-detail-content .page-title{font-size:1.75rem}.scrollable-center-container{max-width:80rem;padding:1.5rem}.scrollable-center-container>*{max-width:60rem}.scrollable-center-container .accordion{margin-bottom:2.5rem}.error-message{margin:1.5rem;padding:3rem}.error-message p,.loading{font-size:1.25rem}.loading{margin:1.5rem;padding:3rem}}@media screen and (min-width:1200px){.project-detail-container{padding:2rem}.project-detail-content{gap:2.5rem;max-width:65rem}.project-detail-content .page-title{font-size:2rem}.scrollable-center-container{max-width:90rem;padding:2rem}.scrollable-center-container>*{max-width:65rem}.scrollable-center-container .accordion{margin-bottom:3rem}.error-message{margin:2rem;padding:4rem}.error-message p,.loading{font-size:1.375rem}.loading{margin:2rem;padding:4rem}}.project-detail-card{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ffffff0d;border:1px solid #ffffff1a;border-radius:1rem;box-shadow:0 4px 12px #00000014;box-sizing:border-box;padding:clamp(1.5rem,4vw,2rem);position:relative;transition:all .3s ease;width:100%;z-index:1}.project-detail-card:hover{border-color:#fff3;box-shadow:0 8px 32px #0000001f;transform:translateY(-2px)}.project-detail-input{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ffffff0d;border:1px solid #ffffff1a;border-radius:.75rem;box-sizing:border-box;color:var(--on-primary);font-size:clamp(.875rem,2.5vw,1rem);padding:clamp(.75rem,2vw,1rem);transition:all .3s ease;width:100%}.project-detail-input:focus{background:#ffffff1a;border-color:var(--accent);box-shadow:0 0 0 3px #61dafb26;outline:none;transform:translateY(-1px)}.project-detail-input:invalid{border-color:var(--error-color);box-shadow:0 0 0 3px #f4433626}.project-detail-section-title{font-size:clamp(1.125rem,3vw,1.375rem);font-weight:600;line-height:1.3;margin-bottom:clamp(.75rem,2vw,1.25rem)}.project-detail-section-title,.project-detail-status-message{color:var(--on-primary);position:relative;text-align:center;z-index:1}.project-detail-status-message{border:1px solid #0000;border-radius:.5rem;font-size:clamp(.875rem,2.5vw,1rem);line-height:1.5;margin:clamp(.5rem,1.5vw,.75rem) 0;padding:clamp(.75rem,2vw,1rem);transition:all .3s ease}.project-detail-status-message.error{background-color:#f443361a;border-color:#f4433633;color:var(--error-color)}.project-detail-status-message.success{background-color:#4caf501a;border-color:#4caf5033;color:var(--success-color)}.project-detail-status-message.warning{background-color:#ff98001a;border-color:#ff980033;color:var(--warning-color)}.project-detail-status-message.info{background-color:#2196f31a;border-color:#2196f333;color:var(--accent)}.project-detail-form{gap:clamp(1rem,3vw,1.5rem);width:100%}.project-detail-form,.project-detail-form>div{display:flex;flex-direction:column;position:relative;z-index:1}.project-detail-form>div{gap:clamp(.5rem,1.5vw,.75rem)}.project-detail-form label{color:var(--on-primary);font-size:clamp(.875rem,2.5vw,1rem);font-weight:500;line-height:1.4;position:relative;z-index:1}.project-detail-form input,.project-detail-form select,.project-detail-form textarea{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ffffff0d;border:1px solid #ffffff1a;border-radius:.75rem;box-sizing:border-box;color:var(--on-primary);font-size:clamp(.875rem,2.5vw,1rem);padding:clamp(.75rem,2vw,1rem);position:relative;transition:all .3s ease;width:100%;z-index:1}.project-detail-form input:focus,.project-detail-form select:focus,.project-detail-form textarea:focus{background:#ffffff1a;border-color:var(--accent);box-shadow:0 0 0 3px #61dafb26;outline:none;transform:translateY(-1px)}.project-detail-form input:invalid,.project-detail-form select:invalid,.project-detail-form textarea:invalid{border-color:var(--error-color);box-shadow:0 0 0 3px #f4433626}.project-detail-form textarea{font-family:inherit;min-height:100px;resize:vertical}.project-detail-btn{align-items:center;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:none;border-radius:.75rem;box-sizing:border-box;cursor:pointer;display:inline-flex;font-size:clamp(.875rem,2.5vw,1rem);font-weight:500;gap:.5rem;justify-content:center;min-height:44px;padding:clamp(.75rem,2vw,1rem) clamp(1rem,3vw,1.5rem);text-align:center;text-decoration:none;transition:all .3s ease}.project-detail-btn:disabled{cursor:not-allowed;opacity:.6;transform:none!important}.project-detail-btn-primary{background-color:var(--button-primary);color:var(--on-primary)}.project-detail-btn-primary:hover:not(:disabled){background-color:var(--button-primary-hover);box-shadow:0 6px 16px #1976d24d;transform:translateY(-2px)}.project-detail-btn-secondary{background:#ffffff0d;border:1px solid #ffffff1a;color:var(--on-primary)}.project-detail-btn-secondary:hover:not(:disabled){background:#ffffff1a;border-color:#fff3;box-shadow:0 6px 16px #0000001a;transform:translateY(-2px)}.project-detail-btn-success{background-color:var(--button-success);color:var(--on-primary)}.project-detail-btn-success:hover:not(:disabled){background-color:var(--button-success-hover);box-shadow:0 6px 16px #4caf504d;transform:translateY(-2px)}.project-detail-btn-danger{background-color:var(--error-color);color:var(--on-primary)}.project-detail-btn-danger:hover:not(:disabled){background-color:#c82333;box-shadow:0 6px 16px #f443364d;transform:translateY(-2px)}.project-detail-section-description{color:var(--on-primary);font-size:clamp(.875rem,2.5vw,1rem);line-height:1.5;margin:0;opacity:.8;text-align:center}@media screen and (max-width:440px){.project-detail-card{border-radius:.5rem;padding:1rem}.project-detail-input{font-size:.875rem;padding:.75rem}.project-detail-section-title{font-size:1.125rem;margin-bottom:.75rem}.project-detail-status-message{font-size:.875rem;padding:.75rem}.project-detail-form{gap:1rem;margin-bottom:1.5rem}.project-detail-form>div{gap:.5rem}.project-detail-form label{font-size:.875rem}.project-detail-form input,.project-detail-form select,.project-detail-form textarea{font-size:.875rem;padding:.75rem}.project-detail-btn{font-size:.875rem;min-height:44px;padding:.75rem 1rem}}@media screen and (min-width:1024px){.project-detail-card{border-radius:.75rem;padding:1.5rem}.project-detail-input{font-size:1rem;padding:1rem}.project-detail-section-title{font-size:1.375rem;margin-bottom:1.25rem}.project-detail-status-message{font-size:1rem;padding:1rem}.project-detail-form{gap:1.5rem}.project-detail-form>div{gap:.75rem}.project-detail-form label{font-size:1rem}.project-detail-form input,.project-detail-form select,.project-detail-form textarea{font-size:1rem;padding:1rem}.project-detail-btn{font-size:1rem;padding:1rem 1.5rem}}@media screen and (min-width:1200px){.project-detail-card{border-radius:.875rem;padding:1.75rem}.project-detail-input{font-size:1rem;padding:1rem}.project-detail-section-title{font-size:1.375rem;margin-bottom:1.25rem}.project-detail-status-message{font-size:1rem;padding:1rem}.project-detail-form{gap:1.5rem}.project-detail-form>div{gap:1rem}.project-detail-form label{font-size:1rem}.project-detail-form input,.project-detail-form select,.project-detail-form textarea{font-size:1rem;padding:1rem}.project-detail-btn{font-size:1rem;padding:1rem 1.5rem}}.project-description-overlay{align-items:center;animation:fadeIn .3s ease-out;background:#000000b3;display:flex;height:100%;justify-content:center;left:0;position:fixed;top:0;width:100%;z-index:10000}.project-description-modal{animation:slideUp .3s ease-out;background:#fff;border-radius:12px;box-shadow:0 20px 40px #0000004d;max-height:80vh;max-width:600px;overflow-y:auto;width:90%}.project-description-header{align-items:center;border-bottom:1px solid #eee;display:flex;justify-content:space-between;padding:1.5rem 1.5rem 1rem}.project-description-header h3{color:#333;font-size:1.25rem;font-weight:600;margin:0}.project-description-close{background:none;border:none;border-radius:4px;color:#666;cursor:pointer;font-size:1.5rem;padding:.25rem;transition:background-color .2s ease}.project-description-close:hover{background-color:#f5f5f5;color:#333}.project-description-content{padding:1.5rem}.project-thumbnail{margin-bottom:1.5rem;text-align:center}.project-thumbnail-image{border:2px solid #eee;border-radius:12px;box-shadow:0 4px 12px #0000001a;height:30vh;max-width:100%;object-fit:contain;transition:transform .2s ease;width:auto}.project-thumbnail-image:hover{transform:scale(1.02)}.project-description-text{color:#333;line-height:1.6}.project-description-text p{font-size:.95rem;margin-bottom:1rem}.project-description-text p:last-child{margin-bottom:0}@media screen and (max-width:440px){.project-description-modal{max-height:90vh;width:98%}.project-description-header{padding:.75rem .75rem .5rem}.project-description-header h3{font-size:1rem}.project-description-content{padding:.75rem}.project-thumbnail-image{height:auto;width:50vw}.project-description-text p{font-size:.9rem}}@media screen and (min-width:1024px){.project-description-modal{max-height:85vh;width:95%}.project-description-header{padding:1rem 1rem .75rem}.project-description-header h3{font-size:1.1rem}.project-description-content{padding:1rem}.project-thumbnail-image{height:30vh;max-width:100%;width:auto}.project-description-overlay{padding:20vh 10vw 10vh}}@media screen and (min-width:1200px){.project-description-overlay{padding:20vh 10vw 10vh}}.public-intro-animation{align-items:center;animation:fadeIn .5s ease-in-out;background:#0009;box-sizing:border-box;display:flex;height:100%;justify-content:center;left:0;pointer-events:all;position:fixed;top:0;-webkit-user-select:none;user-select:none;width:100%;z-index:9999}.public-intro-animation.fading-out{animation:fadeOut .5s ease-in-out forwards;animation:fadeOut var(--fade-out-duration,.5s) ease-in-out forwards}.intro-project-image{animation:scaleIn .8s ease-out .3s both;height:auto;max-height:100%;max-width:100%;object-fit:contain;width:auto}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes fadeOut{0%{opacity:1}to{opacity:0}}@keyframes slideUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}@keyframes scaleIn{0%{opacity:0;transform:scale(.5)}to{opacity:1;transform:scale(1)}}@keyframes fadeInUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes bounce{0%,80%,to{transform:scale(0)}40%{transform:scale(1)}}@media screen and (max-width:440px){.public-intro-animation{padding:10vw}}@media screen and (min-width:1024px){.public-intro-animation{padding:20vh 10vw 10vh}}@media screen and (min-width:1200px){.public-intro-animation{padding:20vh 10vw 10vh}}.public-map-body{background-color:var(--bg-primary);display:flex;flex-direction:column}.public-map-header{background-color:var(--bg-primary);padding:1rem 2rem;z-index:1000}.public-map-header-content{align-items:flex-start;display:flex;gap:1rem;justify-content:space-between}.public-map-header-left{flex:1 1}.public-map-description-button{align-items:center;background-color:var(--primary-color);border:2px solid #fff;border-radius:6px;color:#fff;cursor:pointer;display:flex;font-size:.9rem;font-weight:500;gap:.5rem;min-width:-webkit-fit-content;min-width:fit-content;padding:.5rem 1rem;transition:background-color .2s;white-space:nowrap}.public-map-description-button:hover{background-color:var(--primary-dark)}.public-map-description-button .material-symbols-outlined{font-size:1.1rem}.public-map-description-text{font-size:.85rem}.public-project-title{color:var(--on-primary);font-size:1.5rem;font-weight:600;margin:0}.public-project-subtitle{color:var(--on-primary);font-size:.9rem;margin:.5rem 0 0}.public-map-container{flex:1 1;position:relative}.public-map-error,.public-map-loading{align-items:center;background-color:#f5f5f5;color:#666;display:flex;font-size:1.1rem;height:100vh;justify-content:center}.public-map-error{color:#d32f2f}@media screen and (max-width:768px){.public-map-header{padding:.75rem 1rem}.public-map-header-content{gap:.5rem}.public-project-title{font-size:1.25rem}.public-project-subtitle{font-size:.8rem}.public-map-description-button{border-width:1px;font-size:.8rem;padding:.4rem .8rem}.public-map-description-button .material-symbols-outlined{font-size:1rem}.public-map-description-text{font-size:.75rem}}.app-header{background-color:var(--bg-primary);box-shadow:0 .125rem .25rem var(--shadow-light);box-sizing:border-box;color:var(--on-primary);flex-shrink:0;font-family:var(--font-family);justify-content:space-between;padding:.5rem 1rem;width:100%;z-index:10}.app-header,.header-logo-container,.header-nav-container{align-items:center;display:flex}.header-logo{font-size:1.5rem;font-weight:600;white-space:nowrap}.header-nav{align-items:center;display:flex;flex-wrap:wrap;justify-content:space-evenly}.project-nav-section{align-items:center;border-right:2px solid var(--border);display:flex;padding-right:1rem}.general-nav-section{margin-left:1rem}.general-nav-section,.nav-link{align-items:center;display:flex}.nav-link{border-radius:.25rem;color:var(--gray-400);flex-direction:column;font-size:.875rem;gap:.5rem;justify-content:center;padding:.375rem;text-decoration:none;transition:color .3s ease,-webkit-text-decoration .3s ease;transition:color .3s ease,text-decoration .3s ease;transition:color .3s ease,text-decoration .3s ease,-webkit-text-decoration .3s ease}.nav-link:focus,.nav-link:hover{color:var(--on-primary);text-decoration:none}.nav-item{align-items:center;background-color:initial;border-radius:.25rem;cursor:pointer;display:flex;flex-direction:column;gap:.125rem;height:100%;justify-content:center;max-width:4rem;min-width:3.5rem;text-align:center;transition:background-color .3s ease}.nav-item:hover{background-color:var(--gray-800)}.gallery-link,.list-link,.map-link,.settings-link{align-items:center;display:flex;flex-direction:column;gap:.125rem;height:100%;justify-content:center;text-decoration:none;width:100%}.nav-text{color:var(--on-primary);font-size:.625rem;line-height:1;max-width:100%;overflow:hidden;text-overflow:ellipsis;transition:color .3s ease;white-space:nowrap}.nav-text,.nav-text:hover{text-decoration:none}.nav-icon{color:var(--gray-400);font-size:1.75rem;text-decoration:none!important;transition:color .3s ease}.nav-item:hover .nav-icon{color:var(--on-primary)}.nav-item.active .nav-icon,.nav-item.active .nav-text{color:var(--accent);text-decoration:none!important}@media screen and (max-width:440px){.app-header{align-items:stretch;flex-direction:column;gap:.375rem;min-height:auto;padding:.375rem .75rem}.header-logo-container{justify-content:center;text-align:center}.header-logo{font-size:1.125rem}.header-nav-container{justify-content:center}.header-nav{gap:.375rem;justify-content:space-evenly}.nav-link{font-size:.75rem;padding:.25rem}.nav-icon{font-size:1.25rem}.nav-text{font-size:.5rem}.nav-item{max-width:3.5rem;min-width:3rem;padding:.125rem}}@media screen and (min-width:1024px){.app-header{align-items:center;flex-direction:row}.header-logo{font-size:1.5rem}.nav-icon{font-size:1.75rem}.nav-text{font-size:.75rem}.nav-item{align-items:center;justify-content:center}.general-nav-section,.project-nav-section{gap:.75rem}}@media screen and (min-width:1200px){.app-header{padding:.5rem 1.5rem}.header-logo{font-size:1.75rem}.nav-icon{font-size:2rem}.nav-text{font-size:.875rem}.general-nav-section,.project-nav-section{gap:2rem}}@media screen and (min-width:1024px) and (max-height:768px){.app-header{padding:.375rem .875rem}.header-logo{font-size:1rem}.nav-icon{font-size:1.5rem}.nav-text{font-size:.5rem}.account-icon{font-size:1.5rem}.account-text{font-size:.5rem}}.toast{align-items:center;animation:slideIn .3s ease;background:var(--surface);border:1px solid var(--border);border-radius:.5rem;box-shadow:0 4px 20px #0000004d;display:flex;gap:.5rem;left:1rem;max-width:300px;padding:.75rem 1rem;position:fixed;top:1rem;z-index:9999}.toast-info{border-left:4px solid var(--accent)}.toast-success{border-left:4px solid var(--success-color)}.toast-error{border-left:4px solid var(--error-color)}.toast-warning{border-left:4px solid var(--warning-color)}.toast-message{color:var(--on-primary);flex:1 1;font-size:.9rem}.toast-close{background:none;border:none;border-radius:.25rem;color:var(--on-primary);cursor:pointer;font-size:1.2rem;padding:.25rem;transition:background-color .3s ease}.toast-close:hover{background:var(--bg-primary)}.project-location-toast .toast-message{color:#222!important;font-weight:700;text-align:center;width:100%}.project-location-toast .toast-close{color:#222!important}.toast-container{display:flex;flex-direction:column;gap:.5rem;left:0;padding:1rem;pointer-events:none;position:fixed;top:0;z-index:9999}.toast-container .toast{left:auto;pointer-events:auto;position:relative;top:auto}@keyframes slideIn{0%{opacity:0;transform:translateX(-100%)}to{opacity:1;transform:translateX(0)}}:root{--bg-primary:#121212;--surface:#1e1e1e;--on-primary:#fff;--font-color:#000;--accent:#61dafb;--accent-hover:#21a1f1;--border:#333;--shadow-light:#ffffff1a;--error-color:#f44336;--success-color:#4caf50;--warning-color:#ff9800;--info-color:#2196f3;--gray-100:#f5f5f5;--gray-200:#eee;--gray-300:#e0e0e0;--gray-400:#bdbdbd;--gray-500:#9e9e9e;--gray-600:#757575;--gray-700:#616161;--gray-800:#424242;--gray-900:#212121;--button-primary:#1976d2;--button-primary-hover:#1565c0;--button-secondary:#424242;--button-secondary-hover:#616161;--button-danger:#d32f2f;--button-danger-hover:#c62828;--button-success:#2e7d32;--button-success-hover:#1b5e20;--button-warning:#ed6c02;--button-warning-hover:#e65100;--font-family:"Segoe UI",Tahoma,Geneva,Verdana,sans-serif;--mobile:480px;--tablet:768px;--desktop:1024px;--large-desktop:1200px}*,:after,:before{box-sizing:border-box;margin:0;padding:0}#root,body,html{background-color:#121212;background-color:var(--bg-primary);color:#fff;color:var(--on-primary);font-family:Segoe UI,Tahoma,Geneva,Verdana,sans-serif;font-family:var(--font-family)}#root,.App,body,html{min-height:100vh;overflow-x:hidden;overflow-y:auto;width:100%}.App{display:flex;flex-direction:column}.page-title{font-size:2rem;margin:2rem;text-align:center}.status-message{font-size:clamp(.875rem,2.5vw,1.6rem);line-height:1.4;padding:clamp(.9375rem,2vw,1.875rem)}.detail-section{margin-bottom:clamp(1.25rem,3vw,2.5rem);padding:clamp(1rem,3vw,2.5rem)}.loader{border-width:clamp(.3125rem,1vw,.4375rem);height:clamp(2.5rem,8vw,3.75rem);width:clamp(2.5rem,8vw,3.75rem)}.error,.no-projects{font-size:clamp(.875rem,2.5vw,1.6rem);line-height:1.4;padding:clamp(.625rem,2vw,1rem);text-align:center}@media screen and (max-width:440px){.detail-section{margin-bottom:1.25rem;padding:1rem}.page-title{font-size:1.5rem;margin:1.5rem}.status-message{font-size:.875rem;padding:.9375rem}.error,.no-projects{font-size:.875rem;padding:.625rem}}@media screen and (min-width:1024px){.detail-section{margin-bottom:2.5rem;padding:2.5rem}.page-title{font-size:2.25rem;margin:2.25rem}.status-message{font-size:1.5rem;padding:1.5rem}.error,.no-projects{font-size:1.5rem;padding:1rem}}@media screen and (min-width:1200px){.detail-section{margin-bottom:3rem;padding:3rem}.page-title{font-size:2.25rem;margin:2rem}.status-message{font-size:1.4rem;padding:1.5rem}.error,.no-projects{font-size:1.4rem;padding:1rem}}
/*# sourceMappingURL=main.17f907e7.css.map*/