:root{--accent-color: #dc2814;--accent-hover: #b91f0f;--warning-bg: rgba(220, 40, 20, .1);--bg-primary: #ffffff;--bg-secondary: #fafbfc;--bg-tertiary: #e9ecef;--text-primary: #1a1a1a;--text-secondary: #6c757d;--text-tertiary: #adb5bd;--border-color: #d0d0d0;--primary-color: #dc2814;--color-success: #16a34a;--color-success-bg: #dcfce7;--color-error: #ef4444;--color-error-bg: #fee2e2;--color-warning: #f59e0b;--color-warning-bg: #fef3c7;--color-info: #3b82f6;--color-info-bg: #eff6ff;--color-gold: #d4af37;--color-silver: #a0a0a0;--color-bronze: #cd7f32;--sidebar-width: 260px;--header-height: 70px;--transition-speed: .3s;--spacing-xs: .25rem;--spacing-sm: .5rem;--spacing-md: 1rem;--spacing-lg: 1.5rem;--spacing-xl: 2rem;--spacing-xxl: 3rem;--radius-sm: 4px;--radius-md: 8px;--radius-lg: 12px;--radius-full: 50%;--shadow-sm: 0 2px 8px rgba(0,0,0,.1);--shadow-md: 0 4px 16px rgba(0,0,0,.2);--shadow-lg: 0 8px 24px rgba(0,0,0,.3);--shadow-red-sm: 0 2px 8px rgba(220, 40, 20, .3);--shadow-red-md: 0 4px 16px rgba(220, 40, 20, .4);--shadow-red-lg: 0 8px 24px rgba(220, 40, 20, .5)}:root[data-theme=dark]{--bg-primary: #1a1a1a;--bg-secondary: #2d2d2d;--bg-tertiary: #3a3a3a;--text-primary: #e8e8e8;--text-secondary: #a8a8a8;--text-tertiary: #707070;--border-color: #444444;--shadow-sm: 0 2px 8px rgba(0,0,0,.3);--shadow-md: 0 4px 16px rgba(0,0,0,.4);--shadow-lg: 0 8px 24px rgba(0,0,0,.5);--shadow-red-sm: 0 2px 8px rgba(220, 40, 20, .4);--shadow-red-md: 0 4px 16px rgba(220, 40, 20, .5);--shadow-red-lg: 0 8px 24px rgba(220, 40, 20, .6);--warning-bg: rgba(220, 40, 20, .15);--color-success: #4ade80;--color-error: #f87171;--color-warning: #fbbf24;--color-info: #60a5fa;--color-success-bg: rgba(22, 163, 74, .15);--color-error-bg: rgba(239, 68, 68, .15);--color-warning-bg: rgba(245, 158, 11, .15);--color-info-bg: rgba(59, 130, 246, .15)}@media(prefers-color-scheme:dark){:root:not([data-theme]){--bg-primary: #1a1a1a;--bg-secondary: #2d2d2d;--bg-tertiary: #3a3a3a;--text-primary: #e8e8e8;--text-secondary: #a8a8a8;--text-tertiary: #707070;--border-color: #444444;--shadow-sm: 0 2px 8px rgba(0,0,0,.3);--shadow-md: 0 4px 16px rgba(0,0,0,.4);--shadow-lg: 0 8px 24px rgba(0,0,0,.5);--shadow-red-sm: 0 2px 8px rgba(220, 40, 20, .4);--shadow-red-md: 0 4px 16px rgba(220, 40, 20, .5);--shadow-red-lg: 0 8px 24px rgba(220, 40, 20, .6);--warning-bg: rgba(220, 40, 20, .15);--color-success: #4ade80;--color-error: #f87171;--color-warning: #fbbf24;--color-info: #60a5fa;--color-success-bg: rgba(22, 163, 74, .15);--color-error-bg: rgba(239, 68, 68, .15);--color-warning-bg: rgba(245, 158, 11, .15);--color-info-bg: rgba(59, 130, 246, .15)}}*{margin:0;padding:0;box-sizing:border-box}button,input,select,textarea{font-family:inherit}body{font-family:Nunito,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;font-size:16px;font-weight:300;line-height:1.6;color:var(--text-primary);background-color:var(--bg-secondary);overflow-x:hidden}img[loading=lazy]{opacity:0;transition:opacity .3s ease-in}img[loading=lazy].loaded,img[loading=lazy]:not([src]){opacity:1}p{margin:0!important}html{scroll-behavior:smooth}.hidden{display:none!important}.page-title{font-size:2.5rem;font-weight:200;color:var(--text-primary);margin-bottom:2rem;padding-bottom:1rem;border-bottom:2px solid var(--accent-color)}.page-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem;padding-bottom:1rem;border-bottom:2px solid var(--accent-color);flex-wrap:wrap}.page-header .page-title{margin-bottom:0;border-bottom:none;padding-bottom:0}.page-subtitle{margin-bottom:2rem;color:var(--text-secondary);font-size:1rem;line-height:1.6}.my-quill-editor-content-display{white-space:pre-line;display:flow-root}.my-quill-editor-content-display strong{font-weight:600}.content-block-empty{padding:2rem;text-align:center;color:var(--text-secondary);background:var(--bg-secondary);border-radius:12px;font-size:.95rem}.my-quill-editor-content-display a{color:var(--accent-color);text-decoration:none;transition:color .2s ease,text-decoration .2s ease;position:relative}.my-quill-editor-content-display a:hover{color:var(--accent-hover);text-decoration:underline}.my-quill-editor-content-display ol{padding-left:0;margin:.75rem 0;list-style:none}.my-quill-editor-content-display ol>li{padding-left:1.5rem;position:relative}.my-quill-editor-content-display ol>li[data-list=ordered]{counter-increment:list-counter}.my-quill-editor-content-display ol>li[data-list=ordered]:before{content:counter(list-counter) ".";position:absolute;left:0;top:0;width:1.5rem;display:flex;align-items:center;justify-content:center;color:var(--text-primary);font-weight:400}.my-quill-editor-content-display ol>li[data-list=bullet]:before{content:"•";position:absolute;left:0;top:0;width:1.5rem;display:flex;align-items:center;justify-content:center;color:var(--text-primary);font-weight:400}.my-quill-editor-content-display ol:has(>li[data-list=ordered]){counter-reset:list-counter}.my-quill-editor-content-display ol ol{margin:.25rem 0}.my-quill-editor-content-display li[data-list=bullet],.my-quill-editor-content-display li[data-list=ordered]{padding-left:2rem}.my-quill-editor-content-display li[data-list=bullet].ql-indent-1,.my-quill-editor-content-display li[data-list=ordered].ql-indent-1{padding-left:4rem}.my-quill-editor-content-display li[data-list=bullet].ql-indent-2,.my-quill-editor-content-display li[data-list=ordered].ql-indent-2{padding-left:6rem}::-webkit-scrollbar{width:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--border-color);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--text-secondary)}.sidebar::-webkit-scrollbar{width:6px}.sidebar::-webkit-scrollbar-track{background:transparent}.sidebar::-webkit-scrollbar-thumb{background:var(--border-color);border-radius:3px}.sidebar::-webkit-scrollbar-thumb:hover{background:var(--text-secondary)}.main-content{margin-left:var(--sidebar-width);min-height:100vh;display:flex;flex-direction:column;transition:margin-left var(--transition-speed) ease;padding-top:0;overflow-x:hidden;overflow-x:clip;width:calc(100% - var(--sidebar-width))}.content-wrapper{display:flex;flex:1;gap:0;width:100%}.main-column{display:flex;flex-direction:column;flex:1;min-width:0}.page-content{flex:1;padding:2rem;width:100%;min-width:0;margin-bottom:3rem;position:relative}.page-content:before{content:"";position:fixed;top:0;left:var(--sidebar-width);right:var(--sidebar-width);bottom:0;background-image:url(/dist/assets/bfr_logo-white-zfbseMfK.png);background-repeat:no-repeat;background-size:75%;background-position:center center;pointer-events:none;z-index:-1;transition:left .3s ease,right .3s ease,opacity .3s ease}[data-theme=dark] .page-content:before{opacity:.01;transition:left .3s ease,right .3s ease,opacity 0s}@media(prefers-color-scheme:dark){:root:not([data-theme]) .page-content:before{opacity:.01;transition:left .3s ease,right .3s ease,opacity 0s}}.right-sidebar.collapsed~.page-content:before,.content-wrapper:has(.right-sidebar.collapsed) .page-content:before,.sidebar-collapsed .page-content:before{right:0}.footer{background:var(--bg-primary);padding:3rem 1rem;margin-top:auto;box-shadow:0 -2px 8px #0000001a}.footer-content{max-width:1400px;margin:0 auto;display:flex;flex-direction:column;align-items:center;gap:1.5rem}.footer-nav{display:flex;gap:2rem;flex-wrap:wrap;justify-content:center}.footer-link{display:inline-flex;align-items:center;gap:.35rem;color:var(--text-secondary);text-decoration:none;font-size:.95rem;transition:color .2s ease}.footer-link .material-symbols-outlined{font-size:1.1rem}.footer-link:hover{color:var(--accent-color)}.footer-copy{color:var(--text-secondary);font-size:.9rem}.overlay{display:none;position:fixed;top:0;left:0;width:100%;height:100%;background-color:#00000080;z-index:999;opacity:0;transition:opacity var(--transition-speed) ease}.overlay.active{display:block;opacity:1}.sidebar{position:fixed;top:0;left:0;width:var(--sidebar-width);height:100vh;background:var(--bg-primary);box-shadow:2px 0 8px #0000001a,-2px 0 8px #0000001a;display:flex;flex-direction:column;z-index:1000;transition:transform var(--transition-speed) ease;overflow-y:auto;-webkit-overflow-scrolling:touch}.sidebar-header{padding:24px;display:flex;flex-direction:column;justify-content:space-between;align-items:center;height:271px}.logo-link{display:block;transition:opacity .2s ease;cursor:pointer}.logo-link:hover{opacity:.8}.logo{width:160px;height:auto;object-fit:contain;display:block;transition:transform .1s ease}@keyframes heartbeat{0%{transform:scale(1)}10%{transform:scale(1.08)}20%{transform:scale(1)}30%{transform:scale(1.08)}40%{transform:scale(1)}to{transform:scale(1)}}.logo.heartbeat{animation:heartbeat 2s ease-in-out}.sidebar-nav{flex:1;padding:0 0 1.5rem;overflow-y:auto;-webkit-overflow-scrolling:touch;display:flex;flex-direction:column}.nav-item{display:flex;align-items:center;gap:1rem;padding:.75rem 1.5rem;color:var(--text-primary);text-decoration:none;transition:all .2s ease;font-weight:300;border-left:3px solid transparent;border-right:none;border-top:none;border-bottom:none}button.nav-item{width:100%;text-align:left;background:none;font-family:inherit;font-size:inherit;cursor:pointer;border-radius:0}.nav-item .material-symbols-outlined{font-size:24px;color:var(--text-secondary);transition:color .2s ease}.nav-item:hover{background-color:var(--bg-secondary);border-left-color:var(--accent-color)}.nav-item:hover .material-symbols-outlined{color:var(--accent-color)}.nav-item.active{background-color:#dc28140d;border-left-color:var(--accent-color);color:var(--accent-color);font-weight:400}.nav-item.active .material-symbols-outlined{color:var(--accent-color)}.nav-item.nav-subitem{padding-left:2.5rem;font-size:.9rem;opacity:.85;border-left-width:2px}.nav-item.nav-subitem .material-symbols-outlined{font-size:20px}.nav-item.nav-subitem:hover{opacity:1}.nav-divider{height:1px;background-color:var(--border-color);margin:.5rem 1.5rem}.nav-level{display:none;animation:navSlideIn .3s ease}.nav-level.active{display:block}.nav-level.sliding-out{animation:navSlideOut .3s ease}.nav-toggle .nav-arrow{font-size:24px;color:var(--text-secondary);transition:transform .2s ease,color .2s ease}.nav-toggle:hover .nav-arrow{transform:translate(3px);color:var(--accent-color)}@keyframes navSlideIn{0%{opacity:0;transform:translate(20px)}to{opacity:1;transform:translate(0)}}@keyframes navSlideOut{0%{opacity:1;transform:translate(0)}to{opacity:0;transform:translate(-20px)}}.burger-menu{display:none;position:fixed;top:1rem;right:1rem;left:auto;z-index:1002;background:var(--bg-primary);border:1px solid var(--border-color);border-radius:8px;cursor:pointer;padding:.75rem;color:var(--text-primary);transition:color .2s ease,border-color .2s ease;box-shadow:var(--shadow-md)}.burger-menu:hover{color:var(--accent-color);border-color:var(--accent-color)}.burger-menu .material-symbols-outlined{font-size:28px;display:block}@media(max-width:1024px){.sidebar{transform:translate(100%);left:auto;right:0;box-shadow:var(--shadow-lg);border-left:1px solid var(--border-color);border-right:none}.sidebar.active{transform:translate(0)}.sidebar-nav{padding-bottom:120px}.burger-menu{display:block}.logo{width:120px}}.theme-toggle-divider{margin-top:auto}.theme-toggle{display:flex;align-items:center;gap:1rem;width:100%}.theme-icon-dark{display:inline}.theme-icon-light,[data-theme=dark] .theme-icon-dark{display:none}[data-theme=dark] .theme-icon-light{display:inline}@media(prefers-color-scheme:dark){:root:not([data-theme]) .theme-icon-dark{display:none}:root:not([data-theme]) .theme-icon-light{display:inline}}body.sidebar-open{overflow:hidden}body.sidebar-open .burger-menu{right:calc(var(--sidebar-width) + 1rem);transition:right .3s ease}.right-sidebar{width:var(--sidebar-width);min-height:100vh;background:var(--bg-primary);box-shadow:-2px 0 8px #0000001a;flex-shrink:0;align-self:stretch;overflow:visible;position:relative;z-index:101}.right-sidebar-content{position:sticky;top:0;height:100vh;padding:1rem 1rem 2rem;overflow-y:auto;-webkit-overflow-scrolling:touch;box-sizing:border-box}.right-sidebar-title{font-size:1.5rem;font-weight:600;color:var(--text-primary);margin-bottom:1.5rem;padding-bottom:.75rem;border-bottom:2px solid var(--accent-color)}.right-sidebar-body{color:var(--text-primary);line-height:1.6}.right-sidebar-body p{margin-bottom:1rem}.right-sidebar-body p:last-child{margin-bottom:0}.sidebar-section{margin-bottom:2rem}.sidebar-section:last-child{margin-bottom:0}.sidebar-section-title{display:flex;align-items:center;gap:.5rem;font-size:1.1rem;font-weight:600;color:var(--text-primary);margin-bottom:1rem;padding-bottom:.5rem;border-bottom:2px solid var(--accent-color)}.sidebar-section-title .material-symbols-outlined{font-size:1.25rem;color:var(--accent-color)}.sidebar-items{display:flex;flex-direction:column;gap:.75rem}.sidebar-item{display:flex;flex-direction:column;gap:.5rem;padding:.75rem;background:var(--bg-secondary);border-radius:8px;text-decoration:none;transition:all .2s ease;box-shadow:var(--shadow-sm)}.sidebar-item:hover{transform:translate(-2px);box-shadow:var(--shadow-md)}.sidebar-item-countdown{font-size:.75rem;font-weight:600;color:#fff;background:var(--accent-color);padding:.25rem .5rem;border-radius:6px;white-space:nowrap;text-align:center;width:fit-content}.sidebar-item-title{font-size:.8rem;font-weight:500;color:var(--text-primary);line-height:1.2;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.sidebar-item-warning{font-size:.7rem;font-weight:500;background:var(--warning-bg);border-radius:6px;line-height:1.3;padding:.5rem;display:flex;color:var(--accent-color);align-items:center;gap:.75rem}.sidebar-item-warning:before{content:"⚠";font-size:1.3rem}.sidebar-item-countdown.cancelled{background:var(--text-secondary)}.sidebar-loading{text-align:center;padding:1rem;color:var(--text-primary);font-size:.875rem}.sidebar-empty{text-align:center;padding:1rem;color:var(--text-secondary);font-size:.875rem;font-style:italic}.right-sidebar-toggle{position:fixed;top:50%;right:var(--sidebar-width);transform:translateY(-50%);width:20px;height:64px;background:var(--bg-primary);border:0px solid var(--border-color);border-right:none;border-radius:8px 0 0 8px;cursor:pointer;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.25rem;box-shadow:-2px 0 2px #0000001a;z-index:10;overflow:hidden}.right-sidebar.collapsed .right-sidebar-toggle,.sidebar-collapsed .right-sidebar-toggle{right:0;height:150px}.right-sidebar-toggle:hover .material-symbols-outlined,.right-sidebar-toggle:hover .right-sidebar-toggle-label{color:var(--accent-color)}.right-sidebar-toggle .material-symbols-outlined{font-size:20px;color:var(--text-secondary);transition:transform .3s ease,opacity .3s ease,height .3s ease}.right-sidebar-toggle-icon-top{height:14px;opacity:1}.right-sidebar.collapsed .right-sidebar-toggle-icon-top,.sidebar-collapsed .right-sidebar-toggle-icon-top{transform:rotate(180deg)}.right-sidebar-toggle-icon-bottom{display:none;height:0;opacity:0}.right-sidebar.collapsed .right-sidebar-toggle-icon-bottom,.sidebar-collapsed .right-sidebar-toggle-icon-bottom{display:block;height:20px;opacity:1;transform:rotate(180deg)}.right-sidebar-toggle-label{font-size:.75rem;padding-top:.1rem;font-variant:small-caps;letter-spacing:.1em;color:var(--text-secondary);writing-mode:vertical-lr;text-orientation:mixed;display:flex;align-items:center;justify-content:center;height:0;overflow:hidden;opacity:0}.transitions-ready .right-sidebar-toggle-label{transition:height .15s ease,opacity .1s ease}.right-sidebar.collapsed .right-sidebar-toggle-label,.sidebar-collapsed .right-sidebar-toggle-label{height:90px;opacity:1}.transitions-ready .right-sidebar.collapsed .right-sidebar-toggle-label,.transitions-ready .sidebar-collapsed .right-sidebar-toggle-label{transition:height .3s ease,opacity .3s ease .1s}.right-sidebar.collapsed,.sidebar-collapsed .right-sidebar{margin-right:calc(-1 * var(--sidebar-width))}.transitions-ready .right-sidebar{transition:margin-right .3s ease}.transitions-ready .right-sidebar-toggle{transition:height .3s ease,right .3s ease}.sidebar-wp-list{display:flex;flex-direction:column;gap:.5rem;padding:.75rem;background:var(--bg-secondary);border-radius:8px;text-decoration:none;transition:all .2s ease;box-shadow:var(--shadow-sm)}.sidebar-wp-list:hover{transform:translate(-2px);box-shadow:var(--shadow-md)}.sidebar-wp-item{display:flex;align-items:center;gap:.5rem;min-width:0}.sidebar-wp-rank{font-size:1rem;font-weight:800;line-height:1;min-width:1.5rem;text-align:center;flex-shrink:0}.sidebar-wp-item.first .sidebar-wp-rank{color:gold;font-size:1.15rem}.sidebar-wp-item.second .sidebar-wp-rank{color:silver}.sidebar-wp-item.third .sidebar-wp-rank{color:#cd7f32}.sidebar-wp-item .user-badge{background:transparent;padding:0;min-height:0;flex:1;min-width:0}.sidebar-wp-item .user-badge-avatar{width:28px;height:28px;border-width:2px}.sidebar-wp-item .user-badge-avatar .material-symbols-outlined{font-size:16px}.sidebar-wp-item .user-badge-name{font-size:.8rem;font-weight:500}.sidebar-wp-item.first .user-badge-avatar{border-color:gold}.sidebar-wp-item.second .user-badge-avatar{border-color:silver}.sidebar-wp-item.third .user-badge-avatar{border-color:#cd7f32}.sidebar-wp-user{display:flex;align-items:center;gap:.5rem;flex:1;min-width:0}.sidebar-wp-avatar-placeholder{width:28px;height:28px;border-radius:50%;background:var(--bg-primary);display:flex;align-items:center;justify-content:center;border:2px solid var(--border-color);flex-shrink:0}.sidebar-wp-avatar-placeholder .material-symbols-outlined{font-size:16px;color:var(--text-secondary)}.sidebar-wp-name{font-size:.8rem;font-weight:500;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;min-width:0}.sidebar-wp-points{font-size:.85rem;font-weight:700;color:var(--accent-color);flex-shrink:0;min-width:1.75rem;text-align:right}@media(max-width:1300px){.right-sidebar-toggle,.right-sidebar{display:none}}.btn-primary{display:inline-flex;align-items:center;gap:.5rem;padding:.6rem .8rem;background:var(--accent-color);color:#fff;border:2px solid transparent;border-radius:8px;font-size:.9rem;font-weight:600;cursor:pointer;text-decoration:none;transition:all .2s ease;box-shadow:var(--shadow-sm)}.btn-primary:hover:not(:disabled){background:var(--accent-hover);transform:translateY(-2px);box-shadow:0 6px 16px #dc28144d}.btn-primary:disabled{opacity:.6;cursor:not-allowed;transform:none}.btn-primary .material-symbols-outlined{font-size:20px;color:#fff}.btn-secondary{display:inline-flex;align-items:center;gap:.25rem;padding:.6rem .8rem;background:var(--bg-secondary);color:var(--text-primary);border:2px solid var(--border-color);border-radius:8px;font-size:.9rem;font-weight:600;cursor:pointer;text-decoration:none;transition:all .2s ease}.btn-secondary:hover:not(:disabled){background:var(--bg-tertiary);border-color:var(--primary-color);transform:translateY(-2px);box-shadow:var(--shadow-sm)}.btn-secondary:disabled{opacity:.6;cursor:not-allowed;transform:none}.btn-secondary .material-symbols-outlined{font-size:20px;color:var(--text-primary)}.btn-login{margin-top:1.25rem;font-size:.9rem!important;font-weight:400!important}.btn-login:hover{background-color:var(--accent-hover);box-shadow:var(--shadow-md);transform:translateY(-1px)}.btn-login .material-symbols-outlined{font-size:18px}.btn-submit{width:100%;padding:.875rem 1.5rem;background-color:var(--accent-color);color:#fff;border:none;border-radius:6px;font-size:1rem;font-weight:500;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:.5rem;transition:all .2s ease;box-shadow:var(--shadow-sm)}.btn-submit:hover{background-color:var(--accent-hover);box-shadow:var(--shadow-md);transform:translateY(-1px)}.btn-submit:disabled{background-color:var(--text-secondary);cursor:not-allowed;transform:none}.btn-submit .material-symbols-outlined{font-size:20px}.btn-upload,.btn-delete{display:flex;align-items:center;gap:.5rem;padding:.75rem 1.5rem;border-radius:8px;font-size:.875rem;font-weight:500;cursor:pointer;transition:all .2s ease;border:none}.btn-upload{background:var(--primary-color);color:#fff}.btn-upload:hover{background:var(--accent-hover);transform:translateY(-1px);box-shadow:0 4px 12px #dc28144d}.btn-delete{background:var(--bg-secondary);color:var(--text-secondary)}.btn-delete:hover{background:#dc3545;color:#fff;transform:translateY(-1px)}.btn-upload .material-symbols-outlined,.btn-delete .material-symbols-outlined{font-size:20px}@media(max-width:768px){.btn-primary,.btn-secondary{font-size:.8rem;padding:.5rem .7rem}.btn-upload,.btn-delete{font-size:.8rem;padding:.625rem 1.25rem}}@media(max-width:480px){.btn-primary,.btn-secondary{font-size:.7rem;padding:.5em .5rem}.btn-upload,.btn-delete{font-size:.75rem;padding:.5rem 1rem}}.form-group{margin-bottom:1.25rem}.form-group label{display:block;margin-bottom:.5rem;font-size:.9rem;font-weight:500;color:var(--text-primary)}.form-input{width:100%;max-width:100%;padding:.75rem;border:1px solid var(--border-color);border-radius:6px;font-size:1rem;font-family:inherit;transition:all .2s ease;background-color:var(--bg-primary);color:var(--text-primary);box-sizing:border-box}input[type=date].form-input{min-width:0;min-height:48px;-webkit-appearance:none;-moz-appearance:none;appearance:none}select.form-input{cursor:pointer;-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='24' height='24' viewBox='0 0 24 24'%3E%3Cpath fill='%23666' d='M7 10l5 5 5-5z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right .75rem center;background-size:20px;padding-right:2.5rem}.form-input:focus{outline:none;border-color:var(--accent-color);box-shadow:0 0 0 3px (22rgba0,40,20,.1)}input.form-input[readonly]{background-color:var(--bg-secondary);cursor:not-allowed;opacity:.7}.form-error{display:none;padding:.75rem;margin:1rem 0;background-color:#dc28141a;border:1px solid var(--accent-color);border-radius:6px;color:var(--accent-color);font-size:.9rem}.form-error.active{display:block}.form-label{display:block;font-size:.875rem;font-weight:500;color:var(--text-primary);margin-bottom:.5rem}.password-input-wrapper{position:relative;display:flex;align-items:center}.password-input-wrapper .form-input{padding-right:3rem}.password-toggle-btn{position:absolute;right:.75rem;background:none;border:none;cursor:pointer;padding:.5rem;color:var(--text-secondary);display:flex;align-items:center;justify-content:center;transition:color .2s ease}.password-toggle-btn:hover{color:var(--text-primary)}.password-toggle-btn .material-symbols-outlined{font-size:20px}.password-display{padding:.75rem;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:6px;font-family:Courier New,monospace;font-size:1rem;color:var(--text-primary);text-align:center;letter-spacing:2px}.file-upload-area{border:2px dashed var(--border-color);border-radius:8px;padding:2rem;text-align:center;background-color:var(--bg-secondary);cursor:pointer;transition:all .2s ease}.file-upload-area:hover{border-color:var(--primary-color);background-color:#dc281408}.file-upload-area.drag-over{border-color:var(--primary-color);background-color:#dc28140d}.file-upload-placeholder{display:flex;flex-direction:column;align-items:center;gap:.75rem}.file-upload-placeholder .material-symbols-outlined{font-size:3rem;color:var(--text-secondary)}.file-upload-placeholder p{color:var(--text-primary);font-weight:500}.file-upload-placeholder .file-upload-hint{font-size:.85rem;color:var(--text-secondary);font-weight:400}.file-upload-preview{display:flex;align-items:center;gap:1rem;padding:1rem;background-color:var(--bg-primary);border-radius:6px;border:1px solid var(--border-color)}.file-upload-preview .material-symbols-outlined{font-size:2rem;color:var(--primary-color)}.file-upload-name{flex:1;text-align:left;font-weight:500;color:var(--text-primary);word-break:break-word}.file-upload-remove{background:transparent;border:none;padding:.25rem;cursor:pointer;color:var(--text-secondary);transition:color .2s ease;display:flex;align-items:center;justify-content:center}.file-upload-remove:hover{color:var(--accent-color)}.file-upload-remove .material-symbols-outlined{font-size:1.5rem}.form-section{margin-bottom:2rem;padding-bottom:2rem;border-bottom:1px solid var(--border-color)}.form-section.hidden{display:none}.form-section:not(.hidden):not(:has(~.form-section:not(.hidden))){border-bottom:none;margin-bottom:0;padding-bottom:0}.form-section-title{font-size:1.125rem;font-weight:600;color:var(--text-primary);margin-bottom:1rem;padding-bottom:.5rem}.profile-image-section{display:flex;flex-direction:column;align-items:center;gap:1.5rem}.profile-image-preview{width:150px;height:150px;border-radius:50%;overflow:hidden;border:3px solid var(--primary-color);box-shadow:0 4px 12px #dc281433;flex-shrink:0}.profile-image-preview img,.profile-image-img{width:100%;height:100%;object-fit:cover}.profile-image-placeholder{width:100%;height:100%;background:var(--bg-secondary);display:flex;align-items:center;justify-content:center}.profile-image-placeholder .material-symbols-outlined{font-size:80px;color:var(--text-secondary)}.profile-image-actions{display:flex;gap:1rem;flex-wrap:wrap;justify-content:center}.profile-image-message{margin-top:.5rem;padding:.75rem 1rem;border-radius:8px;font-size:.875rem;text-align:center;display:none}.profile-image-message.active{display:block}.profile-image-message.success{background:#d4edda;border:1px solid #c3e6cb;color:#155724}.profile-image-message.error{background:#f8d7da;border:1px solid #f5c6cb;color:#721c24}.form-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1rem}.form-grid .form-group{margin-bottom:0}.form-group-wide{grid-column:span 2}input[type=radio]{appearance:none;-webkit-appearance:none;-moz-appearance:none;width:20px;height:20px;min-width:20px;min-height:20px;border-radius:50%;background:var(--bg-secondary);border:1px solid var(--border-color);outline:none;cursor:pointer;position:relative;margin:0;transition:all .2s ease}input[type=radio]:checked{background:var(--bg-secondary);border-color:var(--border-color)}input[type=radio]:checked:after{content:"";position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:14px;height:14px;border-radius:50%;background:var(--accent-color)}.switch{position:relative;display:inline-block;width:48px;height:24px}.switch input{opacity:0;width:0;height:0}.switch-slider{position:absolute;cursor:pointer;top:0;left:0;right:0;bottom:0;background-color:var(--bg-secondary);border:1px solid var(--border-color);transition:all .3s ease;border-radius:24px}.switch-slider:before{position:absolute;content:"";height:18px;width:18px;left:2px;bottom:2px;background-color:var(--text-secondary);transition:all .3s ease;border-radius:50%}.switch input:checked+.switch-slider{background-color:var(--accent-color);border-color:var(--accent-color)}.switch input:checked+.switch-slider:before{transform:translate(24px);background-color:#fff}.switch:hover .switch-slider{box-shadow:0 0 0 3px #dc28141a}.form-checkbox{display:flex;align-items:center;justify-content:space-between;gap:1rem;cursor:pointer;padding:1rem 1.25rem;background:var(--bg-primary);border-radius:8px;transition:all .3s cubic-bezier(.4,0,.2,1);position:relative;-webkit-user-select:none;user-select:none;border:2px solid transparent;margin-bottom:1rem}.form-checkbox:last-child:not(:only-child){margin-bottom:0}.form-checkbox:hover{box-shadow:0 4px 12px #0000001a}.form-checkbox input[type=checkbox]{position:absolute;opacity:0;cursor:pointer;height:0;width:0}.form-checkbox input[type=checkbox]+span{position:relative;font-size:.95rem;color:var(--text-primary);font-weight:500;flex:1;padding-left:3.5rem}.form-checkbox input[type=checkbox]+span:before{content:"";position:absolute;left:0;top:50%;transform:translateY(-50%);width:48px;height:26px;border-radius:13px;background:var(--border-color);transition:all .3s cubic-bezier(.4,0,.2,1);box-shadow:inset 0 2px 4px #0000001a}.form-checkbox input[type=checkbox]+span:after{content:"";position:absolute;left:3px;top:50%;transform:translateY(-50%);width:20px;height:20px;border-radius:50%;background:#fff;transition:all .3s cubic-bezier(.4,0,.2,1);box-shadow:0 2px 4px #0003}.form-checkbox:hover input[type=checkbox]+span:before{background:var(--text-secondary)}.form-checkbox input[type=checkbox]:checked+span:before{background:var(--accent-color);box-shadow:0 0 0 2px #de26261a}.form-checkbox input[type=checkbox]:checked+span:after{left:25px;box-shadow:0 2px 6px #0000004d}.form-checkbox:active input[type=checkbox]+span:after{width:24px}.quill-editor{background:var(--bg-primary);border:1px solid var(--border-color);border-radius:6px}.quill-editor .ql-toolbar{border:none;border-bottom:1px solid var(--border-color);background:var(--bg-secondary);border-radius:6px 6px 0 0}.quill-editor .ql-container{border:none;font-size:1.125rem}.quill-editor .ql-container,.quill-editor .ql-editor,.ql-container,.ql-editor{font-family:Nunito,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;font-size:1rem;font-weight:400}.quill-editor .ql-editor{padding:1rem;color:var(--text-primary);line-height:1.6}.quill-editor .ql-editor.ql-blank:before{color:var(--text-secondary);font-style:normal}.ql-toolbar button{color:var(--text-primary)}.ql-toolbar button:hover,.ql-toolbar button.ql-active{color:var(--accent-color)}.ql-toolbar .ql-emoji{padding-top:0!important}.modal-container .quill-editor{display:block}.modal-container .quill-editor .ql-editor{min-height:250px}.modal-container .quill-editor-lg .ql-editor{min-height:300px}.modal-container .quill-editor-sm .ql-editor{min-height:120px}.modal-container .form-group:has(+.form-group .quill-editor){margin-bottom:0}.modal-container .form-group:has(.quill-editor){padding-bottom:45px;margin-top:-1rem}em-emoji-picker{--border-radius: 8px;--category-emoji-size: 1.5rem;--emoji-size: 1.75rem;--background-rgb: var(--bg-primary);--border-color: var(--border-color);--color-b: var(--text-primary);--color-c: var(--text-secondary);--input-border-radius: 6px;box-shadow:var(--shadow-lg)!important;border:1px solid var(--border-color)!important}@media(max-width:768px){.form-grid{grid-template-columns:1fr}.form-group-wide{grid-column:span 1}}.revoke-consent-container{display:flex;justify-content:center;margin-top:4rem}.executive-badge{display:inline-flex;align-items:center;gap:.375rem;background:linear-gradient(135deg,#dc2814,#b01f0f);color:#fff;padding:.375rem .75rem;border-radius:20px;font-size:.875rem;font-weight:600;box-shadow:0 2px 8px #dc28144d}.executive-badge .material-symbols-outlined{font-size:18px}.role-badge{display:inline-flex;align-items:center;gap:.375rem;background:var(--bg-secondary);color:var(--text-secondary);padding:.375rem .75rem;border-radius:20px;font-size:.875rem;font-weight:500;border:1px solid var(--border-color)}.role-badge .material-symbols-outlined{font-size:18px}.honor-badge{display:inline-flex;align-items:center;gap:.375rem;background:linear-gradient(135deg,#d4af37,#b8941f);color:#fff;padding:.375rem .75rem;border-radius:20px;font-size:.875rem;font-weight:500;box-shadow:0 2px 4px #d4af3733}.honor-badge .material-symbols-outlined{font-size:18px}@media(max-width:768px){.executive-badge,.role-badge,.honor-badge{font-size:.75rem;padding:.25rem .5rem;gap:.25rem}.executive-badge .material-symbols-outlined,.role-badge .material-symbols-outlined,.honor-badge .material-symbols-outlined{font-size:14px}}@media(max-width:480px){.executive-badge,.role-badge,.honor-badge{font-size:.7rem;padding:.2rem .4rem;gap:.2rem}.executive-badge .material-symbols-outlined,.role-badge .material-symbols-outlined,.honor-badge .material-symbols-outlined{font-size:12px}}.wanderpokal-badge{display:inline-flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#e8c84a,#d4af37);color:#fff;width:1.6rem;height:1.6rem;border-radius:50%;flex-shrink:0}.wanderpokal-badge .material-symbols-outlined{font-size:1.2rem}.wanderpokal-badge-detail{display:inline-flex;align-items:center;gap:.5rem;background:linear-gradient(135deg,#d4af37,#b8941f);color:#fff;padding:.5rem 1rem;border-radius:8px;font-size:.9rem;font-weight:500;margin-bottom:1rem}.wanderpokal-badge-detail .material-symbols-outlined{font-size:1.2rem}@keyframes fadeIn{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeOut{0%{opacity:1;transform:translateY(0)}to{opacity:0;transform:translateY(-10px)}}.page-content.fade-in{animation:fadeIn .4s ease}.page-content.fade-out{animation:fadeOut .2s ease}.ripple{position:relative;overflow:hidden}.ripple:after{content:"";position:absolute;top:50%;left:50%;width:0;height:0;border-radius:50%;background:#ffffff40;transform:translate(-50%,-50%);transition:width 1.2s,height 1.2s;pointer-events:none}.ripple.ripple-dark:after{background:#0000001a}.ripple.ripple-light:after{background:#ffffff4d}.ripple-effect{position:absolute;border-radius:50%;background:#ffffff4d;pointer-events:none;transform:scale(0);animation:ripple-animation 1.5s ease-out}.ripple-effect.ripple-dark{background:#0000001a}@keyframes ripple-animation{to{transform:scale(4);opacity:0}}.toast-container{position:fixed;top:2rem;right:2rem;z-index:10000;display:flex;flex-direction:column;gap:1rem;pointer-events:none}.toast{min-width:300px;max-width:400px;background:var(--bg-primary);border-radius:8px;box-shadow:0 4px 12px #00000026;display:flex;align-items:flex-start;gap:.75rem;padding:1rem;pointer-events:auto;animation:toastSlideIn .3s ease;border-left:4px solid var(--accent-color)}.toast.removing{animation:toastSlideOut .3s ease forwards}.toast-success{border-left-color:#10b981}.toast-error{border-left-color:var(--accent-color)}.toast-info{border-left-color:#3b82f6}.toast-icon{flex-shrink:0;width:24px;height:24px;display:flex;align-items:center;justify-content:center;border-radius:50%;font-size:1.25rem}.toast-success .toast-icon{color:#10b981}.toast-error .toast-icon{color:var(--accent-color)}.toast-info .toast-icon{color:#3b82f6}.toast-content{flex:1;display:flex;flex-direction:column;gap:.25rem}.toast-title{font-weight:600;font-size:.95rem;color:var(--text-primary)}.toast-message{font-size:.875rem;color:var(--text-secondary);line-height:1.4}.toast-close{flex-shrink:0;background:none;border:none;color:var(--text-secondary);cursor:pointer;padding:0;font-size:1.25rem;line-height:1;opacity:.6;transition:opacity .2s ease}.toast-close:hover{opacity:1}@keyframes toastSlideIn{0%{transform:translate(400px);opacity:0}to{transform:translate(0);opacity:1}}@keyframes toastSlideOut{0%{transform:translate(0);opacity:1}to{transform:translate(400px);opacity:0}}.spinning{animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.loading-spinner{display:flex;justify-content:center;width:100%;padding:2.5rem 1rem;box-sizing:border-box;grid-column:1 / -1}.loading-spinner .material-symbols-outlined{font-size:2rem;color:var(--accent-color)}.content-empty-state{padding:2rem 1rem;text-align:center;background:var(--bg-secondary);border-radius:var(--radius-lg);color:var(--text-secondary)}.content-empty-state .material-symbols-outlined{font-size:3rem;opacity:.5;display:block;margin:0 auto 1rem}.content-empty-state p{margin:0;font-size:.9rem;font-weight:500}.gps-routes-list{display:grid;grid-template-columns:repeat(auto-fill,minmax(350px,1fr));gap:1.5rem}.gps-routes-list .content-empty-state{grid-column:1 / -1}.gps-route-card{background:var(--bg-primary);border-radius:12px;padding:1.5rem;box-shadow:var(--shadow-sm);transition:all .2s ease}.gps-route-card:hover{box-shadow:var(--shadow-md)}.gps-route-header{display:flex;flex-direction:column;gap:0;margin-bottom:1rem;padding-bottom:1rem;border-bottom:1px solid var(--border-color)}.gps-route-header>div{width:100%}.gps-route-title{font-size:1.25rem;font-weight:600;color:var(--text-primary);margin:0 0 .25rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.gps-route-stats{display:flex;justify-content:space-between;gap:1rem;width:100%;flex-wrap:wrap;margin-top:1rem}.gps-route-stat{display:flex;align-items:center;gap:.5rem;color:var(--text-secondary);font-size:.875rem}.gps-route-stat .material-symbols-outlined{font-size:1.25rem;color:var(--accent-color)}.gps-route-preview{width:100%;margin-top:1rem;margin-bottom:1rem;border-radius:12px;overflow:hidden;background:var(--bg-primary)}.gps-route-preview-image{width:100%;height:auto;display:block;border-radius:12px}.gps-route-preview-placeholder{width:100%;height:200px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1rem;background:var(--bg-hover);color:var(--text-secondary);border-radius:12px;border:2px dashed var(--border-color)}.gps-route-preview-placeholder .material-symbols-outlined{font-size:3rem;opacity:.5}.gps-route-preview-placeholder span:last-child{font-size:.9rem;font-weight:500}.gps-route-actions{display:flex;gap:.75rem;flex-wrap:wrap;justify-content:space-between;margin-top:1rem;padding-top:1rem;border-top:1px solid var(--border-color)}.gps-route-actions-group{display:flex;gap:.75rem;flex-wrap:wrap}.gps-routes-empty{padding:4rem 2rem;text-align:center;background:var(--bg-secondary);border-radius:12px;color:var(--text-secondary)}.gps-routes-empty .material-symbols-outlined{font-size:4rem;opacity:.5;display:block;margin:0 auto 1rem}.gps-routes-empty p{margin:0;font-size:1.1rem;font-weight:500}@media(max-width:768px){.gps-routes-list{grid-template-columns:repeat(auto-fill,minmax(350px,1fr))}.gps-route-header{flex-direction:column;gap:.5rem}.gps-route-stats{display:none}}@media(max-width:480px){.gps-routes-list{grid-template-columns:repeat(auto-fill,minmax(250px,1fr))}.content-empty-state,.gps-routes-empty{padding:3rem 1.5rem}.content-empty-state .material-symbols-outlined,.gps-routes-empty .material-symbols-outlined{font-size:3rem}.gps-route-actions{flex-direction:column}.gps-route-actions-group{width:100%;flex-direction:column}.gps-route-actions .btn-sm,.gps-route-actions-group .btn-sm{width:100%;justify-content:center}}.htmx-loading-container.htmx-request>*{display:none}.htmx-loading-container.htmx-request:after{content:"progress_activity";font-family:Material Symbols Outlined;font-size:2rem;color:var(--accent-color);display:flex;justify-content:center;width:100%;padding:2.5rem 1rem;animation:spin 1s linear infinite}@keyframes modalFadeIn{0%{opacity:0}to{opacity:1}}@keyframes modalFadeOut{0%{opacity:1}to{opacity:0}}@keyframes modalSlideIn{0%{opacity:0;transform:translateY(-20px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}@keyframes modalSlideOut{0%{opacity:1;transform:translateY(0) scale(1)}to{opacity:0;transform:translateY(-20px) scale(.95)}}.modal-overlay{display:none;position:fixed;top:0;left:0;width:100%;height:100%;background-color:#000000d9;z-index:2000;align-items:center;justify-content:center}.modal-overlay.active{display:flex;animation:modalFadeIn .3s ease}.modal-overlay.closing{animation:modalFadeOut .3s ease forwards}.modal-container{background:var(--bg-primary);border-radius:12px;box-shadow:var(--shadow-lg);max-width:400px;width:90%;max-height:95vh;overflow-y:auto;-webkit-overflow-scrolling:touch;overscroll-behavior:contain}.modal-container.modal-medium{max-width:600px;width:95%}.modal-container.modal-large{max-width:800px;width:95%}.modal-container.modal-xlarge{max-width:1200px;width:95%}.modal-container.modal-container-small{max-width:450px;width:90%}.modal-overlay.active .modal-container{animation:modalSlideIn .3s ease}.modal-overlay.closing .modal-container{animation:modalSlideOut .3s ease forwards}.modal-overlay.modal-force{z-index:9999;background-color:#000000d9;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.modal-overlay.modal-force .modal-container{border:2px solid var(--primary-color)}.modal-info{margin:0 0 1.5rem;padding:1rem;background-color:#dc28141a;border-left:4px solid var(--primary-color);border-radius:4px;font-size:.95rem;line-height:1.6;color:var(--text-primary)}.form-help{display:block;margin-top:.25rem;font-size:.85rem;color:var(--text-secondary)}.modal-header{position:sticky;top:0;z-index:20;background:var(--bg-primary);padding:1.5rem;border-bottom:1px solid var(--border-color);display:flex;align-items:center;justify-content:space-between}.modal-title{font-size:1.5rem;font-weight:400;color:var(--text-primary);margin:0}.modal-close{background:none;border:none;cursor:pointer;color:var(--text-secondary);padding:.25rem;display:flex;align-items:center;justify-content:center;transition:color .2s ease}.modal-close:hover{color:var(--text-primary)}.modal-close .material-symbols-outlined{font-size:24px}.modal-body{padding:1.5rem;background:var(--bg-secondary)}.confirm-message{margin:0 0 1.5rem;font-size:1rem;line-height:1.6;color:var(--text-primary)}.modal-actions{display:flex;gap:.75rem;padding:1.5rem;justify-content:flex-end;border-top:1px solid var(--border-color)}.modal-actions button{flex:0 1 auto;min-width:120px}.modal-actions-split{justify-content:space-between}.modal-actions-left,.modal-actions-right{display:flex;gap:.75rem}.modal-actions-left{justify-content:flex-start}.modal-actions-right{justify-content:flex-end}.modal-container .ql-toolbar{position:sticky;top:calc(4.5rem + 9px);z-index:5;background:var(--bg-primary);border-top:none!important;border-left:none!important;border-right:none!important;box-shadow:0 2px 4px #0000001a}@media(max-width:768px){.modal-container{max-height:85vh;width:95%;margin:1rem}.modal-container.modal-large,.modal-container.modal-xlarge{width:95%;max-height:90vh}.modal-body{-webkit-overflow-scrolling:touch;touch-action:pan-y}.modal-header,.modal-body{padding:1rem}.modal-actions{justify-content:center;padding:1rem}.modal-container .ql-toolbar{top:calc(3.5rem + 9px)}}.modal-error{display:none;margin-bottom:1.5rem}.modal-error .error-message{display:flex;align-items:center;gap:.75rem;padding:1rem;background-color:#fee;border:1px solid #fcc;border-radius:8px;color:#c00;font-size:.9rem;line-height:1.5}.modal-error .error-message .material-symbols-outlined{flex-shrink:0;font-size:1.5rem;color:#c00}.modal-error .error-message span:last-child{flex:1}.modal-info-text{display:flex;align-items:center;gap:1rem;padding:1rem;margin-top:1.5rem;background-color:#dc281414;border-radius:8px;line-height:1.6}.modal-info-text .modal-info-icon{flex-shrink:0;font-size:2rem;color:var(--accent-color)}.modal-info-text p{margin:0;color:var(--text-primary)}.user-badge{display:inline-flex;align-items:center;min-height:38px;gap:.5rem;padding:0rem .75rem 0rem 0rem;background:var(--bg-secondary);border-radius:50px;transition:all .2s ease;max-width:100%}.user-badge-link{text-decoration:none;cursor:pointer}.user-badge-link:hover{background:var(--accent-color)}.user-badge-link:hover .user-badge-name{color:#fff}.user-badge-avatar{width:38px;height:38px;border-radius:50%;overflow:hidden;flex-shrink:0;background:var(--bg-primary);display:flex;align-items:center;justify-content:center;border:3px solid var(--accent-color)}.user-badge-avatar img{width:100%;height:100%;object-fit:cover}.user-badge-avatar .material-symbols-outlined{font-size:20px;color:var(--text-secondary)}.user-badge-name{font-size:.875rem;font-weight:500;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.user-badge.large{padding:.5rem 1rem .5rem .5rem}.user-badge.large .user-badge-avatar{width:40px;height:40px;border:2px solid var(--accent-color)}.user-badge.large .user-badge-avatar .material-symbols-outlined{font-size:24px}.user-badge.large .user-badge-name{font-size:1rem}.user-badge.small{padding:.25rem .5rem .25rem .25rem}.user-badge.small .user-badge-avatar{width:24px;height:24px;border:1.5px solid var(--accent-color)}.user-badge.small .user-badge-avatar .material-symbols-outlined{font-size:16px}.user-badge.small .user-badge-name{font-size:.75rem}.photo-wall{width:100%;height:271px;margin:0;padding:0;overflow:hidden;background:var(--bg-primary);border-bottom:1px solid var(--border-color)}.photo-wall-container{display:flex;flex-direction:row;flex-wrap:wrap;justify-content:center;align-items:flex-start;align-content:flex-start;width:100%;gap:0}.photo-wall-image{position:relative;flex-grow:1;flex-shrink:0;flex-basis:auto;width:90px;height:90px;border:1px solid var(--bg-secondary);opacity:0;background-size:cover;background-position:center;background-repeat:no-repeat;background-color:var(--bg-secondary);transition:opacity .5s ease-out,display .5s ease-out,transform .25s ease-out;transform:scale(1)}.photo-wall-image:hover{transform:scale(2);z-index:999999}.photo-wall-image.loaded{opacity:1}.photo-wall-image-overlay{position:absolute;top:0;left:0;width:100%;height:100%;background-size:cover;background-position:center;background-repeat:no-repeat;opacity:0;transition:opacity 1s ease-out;pointer-events:none}.photo-wall-image-overlay.visible{opacity:1}@media(max-width:768px){.photo-wall{display:none}}.privacy-consent-modal{z-index:99999!important;pointer-events:all!important}.privacy-consent-modal .modal-close{display:none!important}.privacy-consent-modal .modal-header{justify-content:center}.privacy-consent-modal .modal-title{text-align:center;width:100%}.privacy-consent-modal .modal-body{max-height:60vh;overflow-y:auto}.privacy-consent-modal .modal-actions{justify-content:center}.privacy-consent-modal #acceptPrivacyConsent{min-width:400px;padding:14px 24px;font-size:16px;font-weight:600}@media(max-width:768px){.privacy-consent-modal #acceptPrivacyConsent{min-width:auto;width:100%}}.privacy-consent-modal .content-block-empty,.privacy-consent-modal .content-block-error{text-align:center;padding:2rem;color:var(--text-secondary)}.privacy-consent-modal .content-block-error{color:var(--primary-color)}.breadcrumbs{display:flex;align-items:center;gap:.5rem;padding:0 0 1rem;margin:0;font-size:.9rem;color:var(--text-secondary)}.breadcrumb-item{display:flex;align-items:center;gap:.35rem}.breadcrumb-icon{font-size:1.1rem;color:var(--text-secondary);line-height:1}.breadcrumb-link{color:var(--text-secondary);text-decoration:none;transition:color .2s ease}.breadcrumb-link:hover{color:var(--primary);text-decoration:underline}.breadcrumb-separator{color:var(--text-tertiary);-webkit-user-select:none;user-select:none;display:flex;align-items:center}.breadcrumb-separator .material-symbols-outlined{font-size:1rem;line-height:1}.breadcrumb-current{color:var(--text-primary);font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:600px}@media(max-width:768px){.breadcrumbs{padding:0 0 .75rem;font-size:.85rem;overflow-x:auto;overflow-y:hidden;white-space:nowrap;-webkit-overflow-scrolling:touch;scrollbar-width:none}.breadcrumbs::-webkit-scrollbar{display:none}.breadcrumb-current{max-width:250px}}.card-container{display:flex;flex-direction:column;gap:1rem;margin-bottom:3rem}.section-stats{margin-bottom:1.5rem;padding:1rem;background:var(--bg-primary);border-radius:8px;box-shadow:var(--shadow-sm)}.section-stats-count{display:flex;align-items:center;gap:.5rem;font-size:1rem;color:var(--text-primary)}.section-stats-count .material-symbols-outlined{font-size:1.5rem;color:var(--primary-color)}.section-stats-count strong{font-weight:700}.entity-card{display:block;text-decoration:none;color:inherit;background:var(--bg-primary);border-radius:12px;transition:all .2s ease;box-shadow:var(--shadow-sm);overflow:hidden}.entity-card:hover{box-shadow:var(--shadow-md)}.entity-card-header{display:flex;align-items:center;justify-content:space-between;padding:1.25rem 1.5rem;gap:1rem;overflow:hidden}.entity-header-left{display:flex;align-items:center;gap:1rem;flex:1;min-width:0}.entity-header-info{flex:1;min-width:0}.entity-title{font-size:1.15rem;font-weight:700;color:var(--text-primary);margin:0 0 .25rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.entity-subtitle{font-size:.875rem;color:var(--text-secondary);display:flex;align-items:center;gap:.5rem;flex-wrap:wrap}.entity-subtitle span{white-space:nowrap}.entity-header-right{display:flex;align-items:center;gap:1.5rem;flex-shrink:0}.entity-stat{display:flex;align-items:center;gap:.35rem;color:var(--text-secondary);font-size:.9rem;font-weight:500}.entity-stat.has-value,.entity-stat.has-value .material-symbols-outlined{color:var(--accent-color)}.entity-card-arrow{width:40px;height:40px;border-radius:50%;background:var(--bg-secondary);display:flex;align-items:center;justify-content:center;transition:all .2s ease;flex-shrink:0}.entity-card-arrow .material-symbols-outlined{font-size:24px;color:var(--text-secondary);transition:color .2s ease}.entity-card:hover .entity-card-arrow{background:var(--accent-color)}.entity-card:hover .entity-card-arrow .material-symbols-outlined{color:#fff}.countdown-circle{width:80px;height:80px;border-radius:50%;background:linear-gradient(135deg,var(--accent-color),var(--accent-hover));display:flex;align-items:center;justify-content:center;flex-shrink:0;box-shadow:0 2px 8px #ff66004d}.image-circle{width:80px;height:80px;border-radius:50%;background:var(--bg-secondary);overflow:hidden;box-shadow:0 2px 8px #0003;display:flex;align-items:center;justify-content:center;flex-shrink:0}.active-circle{position:relative;background:linear-gradient(135deg,var(--accent-color),var(--accent-hover));overflow:visible}.active-circle:before{content:"";position:absolute;top:50%;left:50%;width:100%;height:100%;border-radius:50%;background:var(--accent-color);transform:translate(-50%,-50%);animation:circle-ripple 3s ease-out infinite;opacity:0}.active-circle:after{content:"";position:absolute;top:50%;left:50%;width:100%;height:100%;border-radius:50%;background:var(--accent-color);transform:translate(-50%,-50%);animation:circle-ripple 3s ease-out 1.5s infinite;opacity:0}@keyframes circle-ripple{0%{opacity:.4;transform:translate(-50%,-50%) scale(1)}to{opacity:0;transform:translate(-50%,-50%) scale(8)}}.cancelled-circle{background:linear-gradient(135deg,#6c757d,#5a6268);box-shadow:0 2px 8px #6c757d4d}.cancelled-circle .material-symbols-outlined{font-size:2.5rem;color:#fff}.countdown-content{display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;width:100%;height:100%;position:relative}.countdown-value{font-size:1.6rem;font-weight:700;color:#fff;line-height:1;position:absolute;top:20px;left:50%;transform:translate(-50%)}.countdown-unit{font-size:.9rem;font-weight:600;color:#fff;position:absolute;bottom:15px;left:50%;transform:translate(-50%);font-variant:small-caps}.countdown-today{font-size:1.1rem;font-weight:700;color:#fff}.circle-image{width:100%;height:100%;object-fit:cover;border:3px solid var(--border-color);border-radius:50%}.circle-placeholder-icon{font-size:2rem;color:var(--text-tertiary)}.active-icon{position:relative;z-index:1;font-size:2rem;color:#fff;animation:icon-bounce 3s ease-in-out infinite}@keyframes icon-bounce{0%,to{transform:translateY(2px) rotate(5deg)}50%{transform:translateY(-5px) rotate(-12deg)}}.cancelled-guide-badge-container{margin:1rem 0}.cancelled-reason{padding:1rem;background:var(--bg-secondary);border-radius:8px;border-left:3px solid #6c757d}.cancelled-reason-header{display:flex;align-items:center;gap:.5rem;margin-bottom:.75rem;color:var(--text-secondary);font-size:.95rem}.cancelled-reason-header .material-symbols-outlined{font-size:1.25rem;color:#6c757d}.cancelled-reason-header strong{color:var(--text-primary)}.cancelled-reason-text{color:var(--text-primary);line-height:1.6;white-space:pre-wrap}.empty-state{text-align:center;padding:3rem 1rem;color:var(--text-secondary)}.empty-state .material-symbols-outlined{font-size:4rem;color:var(--text-tertiary);margin-bottom:1rem;display:block}.empty-state p{font-size:1.1rem}.loading-state,.error-state{text-align:center;padding:3rem 1rem;color:var(--text-secondary)}.error-state .material-symbols-outlined{font-size:4rem;color:var(--accent-color);margin-bottom:1rem;display:block}@media(max-width:768px){.entity-stat{display:none}.countdown-circle,.image-circle{width:60px;height:60px}.circle-placeholder-icon,.active-icon{font-size:1.5rem}.countdown-value{font-size:1.2rem;top:10px}.countdown-unit{font-size:.8rem;bottom:5px}.countdown-today{font-size:.95rem}.entity-title{font-size:1rem;white-space:normal}.entity-subtitle{font-size:.8rem}}@media(max-width:480px){.entity-subtitle{display:none}}.card{margin-bottom:1.5rem;background:var(--bg-primary);border-radius:12px;box-shadow:var(--shadow-sm);transition:all .2s ease}.card:hover{box-shadow:var(--shadow-md)}.card-no-hover:hover{box-shadow:var(--shadow-sm)}.card-header{display:flex;align-items:center;gap:1.5rem;padding:1.5rem}.card-header-title{font-size:1.15rem;font-weight:700;color:var(--text-primary);flex:1}.card-header>.material-symbols-outlined{color:var(--accent-color)}.card-content{padding:1.5rem;border-top:1px solid var(--border-color)}.card-actions{display:flex;justify-content:flex-end;flex-wrap:wrap;gap:.75rem;padding:1.5rem;margin-top:1rem;border-top:1px solid var(--border-color)}@media(max-width:768px){.card-header,.card-content{padding:1rem}}@media(max-width:480px){.card-actions{flex-direction:column}.card-actions{width:100%;justify-content:center}}.accordion-list{display:flex;flex-direction:column;gap:1rem}.accordion{background:var(--bg-primary);border-radius:12px;box-shadow:var(--shadow-sm);overflow:hidden;transition:box-shadow .2s ease}.accordion:hover{box-shadow:var(--shadow-md)}.accordion-header{display:flex;align-items:center;gap:1.5rem;padding:1.25rem 1.5rem;cursor:pointer;-webkit-user-select:none;user-select:none;transition:background-color .2s ease}.accordion-toggle{flex-shrink:0;width:40px;height:40px;display:flex;align-items:center;justify-content:center;border-radius:50%;background:var(--bg-secondary);color:var(--text-secondary);transition:all .3s ease}.accordion.active .accordion-toggle{transform:rotate(180deg);background:var(--accent-color);color:#fff}.accordion-body{max-height:0;overflow:hidden;transition:max-height .3s ease}.accordion.active .accordion-body{max-height:2000px}.accordion-content{padding:0 1.5rem 1.5rem;border-top:1px solid var(--border-color)}.accordion-actions{display:flex;justify-content:flex-end;gap:1rem;padding-top:1.5rem;margin-top:1.5rem;border-top:1px solid var(--border-color)}@media(max-width:768px){.accordion-header{padding:1rem}.accordion-content{padding:0 1rem 1rem}}.year-month-selector{display:flex;flex-direction:column;gap:.75rem;margin-bottom:2rem;padding:1rem;background:var(--bg-primary);border-radius:10px;box-shadow:var(--shadow-sm)}.year-month-selector--sticky{position:sticky;top:1rem;z-index:100}.selector-row{display:flex;align-items:center;justify-content:space-between;gap:1rem}.selector-nav-btn{min-width:100px}.selector-nav-btn:disabled{opacity:.3;cursor:not-allowed}.selector-nav-btn .selector-arrow{font-size:20px;flex-shrink:0;line-height:1}.selector-nav-btn.selector-prev .selector-arrow{transform:rotate(90deg)}.selector-nav-btn.selector-next .selector-arrow{transform:rotate(-90deg)}.selector-nav-btn .btn-label{white-space:nowrap}.selector-nav-btn.selector-prev{justify-content:flex-start}.selector-nav-btn.selector-next{justify-content:flex-end}.selector-center{flex:1;display:flex;align-items:center;justify-content:center;gap:1rem}.year-month-selector--grid{display:grid;grid-template-columns:1fr auto 1fr;grid-template-rows:auto auto;gap:.5rem 1rem;align-items:center}.year-month-selector--grid .selector-prev{justify-self:start}.year-month-selector--grid .selector-next{justify-self:end}.year-month-selector--grid .selector-center{grid-column:2;grid-row:1 / 3}@media(max-width:768px){.year-month-selector{padding:.875rem;gap:.625rem}.selector-row{gap:.75rem}.selector-nav-btn{min-width:90px;padding:.45rem .875rem;font-size:.9rem}.selector-nav-btn .selector-arrow{font-size:18px}}@media(max-width:480px){.year-month-selector{padding:.75rem;gap:.5rem}.selector-row{gap:.5rem}.selector-nav-btn{min-width:80px;padding:.4rem .75rem;font-size:.85rem}.selector-nav-btn .selector-arrow{font-size:16px}}.search-filter{margin-bottom:2rem;position:relative}.search-filter-wrapper{position:relative;display:flex;align-items:center;background:var(--bg-primary);border:1px solid var(--border-color);border-radius:12px;padding:.75rem 1rem;min-height:64px;transition:all .2s ease}.search-filter-wrapper:focus-within{box-shadow:var(--shadow-sm)}.search-filter-wrapper .search-icon{color:var(--text-secondary);margin-right:.75rem;font-size:20px;flex-shrink:0}.search-filter-wrapper .search-filter-input{flex:1;border:none;background:transparent;font-size:1rem;font-family:inherit;color:var(--text-primary);outline:none;padding:0;min-width:0}.search-filter-wrapper .search-filter-input::placeholder{color:var(--text-secondary)}.search-filter-clear{display:flex;align-items:center;justify-content:center;background:var(--bg-secondary);border:1px solid transparent;color:var(--text-secondary);cursor:pointer;padding:.25rem;border-radius:4px;transition:all .2s ease;flex-shrink:0}.search-filter-clear:hover{background:var(--bg-secondary);border:1px solid var(--border-color);color:var(--text-primary)}.search-filter-clear .material-symbols-outlined{font-size:18px}.search-filter-results{margin-top:.5rem;font-size:.9rem;color:var(--text-secondary)}.search-filter-results .search-count{font-weight:600;color:var(--primary-color)}.search-filter-results.no-results,.search-filter-results.no-results .search-count{color:var(--accent-color)}.year-month-selector .search-filter{margin-bottom:0;width:100%}.year-month-selector .search-filter-wrapper{width:100%}@media(max-width:768px){.search-filter-wrapper{min-height:56px;padding:.5rem .75rem}.search-filter-wrapper .search-filter-input{font-size:.95rem}}.admin-controls{margin:0;transition:all .2s ease}.control-group{margin-bottom:0;padding:1.5rem;display:flex;justify-content:center}.time-period-selector{display:flex;justify-content:center;gap:1.5rem;flex-wrap:wrap}.radio-option{display:flex;align-items:center;gap:.5rem;cursor:pointer;-webkit-user-select:none;user-select:none}.radio-label{font-size:.95rem;color:var(--text-primary);cursor:pointer}.radio-option:hover .radio-label{color:var(--accent-color)}.cumulative-switch-inline{display:flex;align-items:center;gap:.75rem}.cumulative-switch-label{font-size:.95rem;color:var(--text-primary);cursor:pointer;-webkit-user-select:none;user-select:none}.year-selector-container{border-top:1px solid var(--border-color);padding:1.5rem;display:flex;justify-content:center;width:100%}.year-selector-container .year-month-selector{margin-bottom:0;padding:0;background:none;border-radius:0;box-shadow:none}#chartsContainer{display:flex;flex-direction:column;gap:2rem}.charts-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:4rem 2rem;gap:1rem;width:100%;text-align:center;grid-column:1 / -1}.loading-text{font-size:1rem;color:var(--text-secondary);font-weight:500}.chart-card{background:var(--bg-primary);border-radius:12px;padding:1.5rem;margin-bottom:2rem;box-shadow:var(--shadow-sm)}.chart-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem;gap:1rem;flex-wrap:wrap}.chart-title{font-size:1.15rem;font-weight:700;color:var(--text-primary);margin-bottom:0}.chart-hint{font-size:.875rem;color:var(--text-secondary);text-align:right;line-height:1.4}.chart-hint .material-symbols-outlined{font-size:1rem;color:var(--text-secondary);vertical-align:middle;margin-right:.25rem}.chart-container{width:100%;height:400px}.chart-container-medium{height:300px}.chart-container-large{height:500px}.chart-container-sunburst{height:600px}.chart-container-tall{height:800px}.chart-card-error{border-left:4px solid var(--color-error)}.error-table-container{margin-top:1.5rem;overflow-x:auto}.error-table{width:100%;border-collapse:collapse;font-size:.875rem}.error-table thead{background:var(--bg-secondary)}.error-table th{padding:.75rem;text-align:left;font-weight:600;color:var(--text-secondary);border-bottom:2px solid var(--border-color)}.error-table td{padding:.75rem;border-bottom:1px solid var(--border-color);color:var(--text-primary)}.error-table tr:hover{background:var(--bg-secondary)}.no-errors-message{display:flex;align-items:center;justify-content:center;gap:.5rem;padding:2rem;color:var(--color-success);font-weight:500}.no-errors-message .material-symbols-outlined{font-size:2rem}@media(max-width:768px){.control-group,.year-selector-container{padding:1rem}.time-period-selector{flex-direction:column;gap:1rem;align-items:center}.radio-label{font-size:.9rem}.chart-card{padding:1rem}.chart-header{flex-direction:column;align-items:flex-start;gap:.75rem}.chart-title{font-size:1rem}.chart-hint{text-align:left;width:100%}.chart-container,.chart-container-medium,.chart-container-large{height:300px}.chart-container-sunburst{height:400px}.chart-container-tall{height:500px}.error-table{font-size:.75rem}.error-table th,.error-table td{padding:.5rem}}.image-gallery{display:grid;grid-template-columns:repeat(auto-fill,minmax(120px,1fr));gap:1rem;padding:0}.image-card{position:relative;aspect-ratio:1;border-radius:12px;overflow:hidden;background:var(--bg-secondary);cursor:pointer;transition:transform .2s ease,box-shadow .2s ease;box-shadow:0 12px 14px -8px #00000080}.image-card:hover{box-shadow:0 12px 14px -8px #000000bf}.image-card a{display:block;width:100%;height:100%}.image-thumbnail{width:100%;height:100%;object-fit:cover;display:block}.image-badge{position:absolute;top:.5rem;right:.5rem;background:#000000b3;color:#fff;border-radius:50%;width:32px;height:32px;display:flex;align-items:center;justify-content:center;font-size:1.2rem}.image-badge .material-symbols-outlined{font-size:1.2rem}.image-placeholder{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;color:var(--text-secondary);padding:1rem}.image-placeholder .material-symbols-outlined{font-size:3rem;margin-bottom:.5rem}.image-placeholder p{margin:0;font-size:.9rem}.image-gallery-error{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:3rem 1rem;text-align:center;color:var(--error-color)}.image-gallery-error .material-symbols-outlined{font-size:4rem;margin-bottom:1rem;opacity:.5}.image-gallery-error p{margin:0;font-size:1rem}.image-gallery-error .material-symbols-outlined{color:var(--error-color)}.lg-backdrop.in{opacity:.85!important}.lg-outer .lg-inner,.lg-outer .lg-item{padding:0!important}@media(max-width:768px){.image-gallery{grid-template-columns:repeat(auto-fill,minmax(100px,1fr));gap:.75rem}}@media(max-width:480px){.image-gallery{grid-template-columns:repeat(auto-fill,minmax(80px,1fr));gap:.5rem}}.leaflet-control-layers{border-radius:8px!important;border:1px solid var(--border-color)!important;box-shadow:0 2px 8px #00000026!important;background:var(--bg-primary)!important;font-family:var(--font-family)!important}.leaflet-control-layers-toggle{background-image:none!important;width:36px!important;height:36px!important;background-color:var(--bg-primary)!important;border-radius:8px!important;text-decoration:none!important}.leaflet-control-layers-toggle:before{content:"";font-family:Material Symbols Outlined;font-size:24px;color:var(--text-primary);display:flex;align-items:center;justify-content:center;width:100%;height:100%}.leaflet-control-layers-expanded{padding:12px 16px!important;min-width:200px}.leaflet-control-layers-list{margin:0!important}.leaflet-control-layers-base{margin-bottom:0!important}.leaflet-control-layers label{display:flex!important;align-items:center!important;padding:8px 4px!important;margin:0!important;font-size:14px!important;font-weight:500!important;color:var(--text-primary)!important;cursor:pointer!important;transition:background-color .2s ease;border-radius:6px}.leaflet-control-layers label:hover{background-color:var(--bg-hover)!important}.leaflet-control-layers-selector{appearance:none;-webkit-appearance:none;-moz-appearance:none;width:20px!important;height:20px!important;border:2px solid var(--border-color)!important;border-radius:50%!important;margin:0 12px 0 0!important;padding:0!important;background-color:var(--bg-primary)!important;cursor:pointer!important;position:relative;transition:all .2s ease;flex-shrink:0}.leaflet-control-layers-selector:hover{border-color:var(--primary-color)!important}.leaflet-control-layers-selector:checked{border-color:var(--primary-color)!important;background-color:var(--primary-color)!important}.leaflet-control-layers-selector:checked:after{content:"";position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:8px;height:8px;background-color:#fff;border-radius:50%}.leaflet-control-layers-selector:focus{outline:none;box-shadow:0 0 0 3px #dc281433}.leaflet-control-layers-separator{height:0!important;border-top:1px solid var(--border-color)!important;margin:8px 0!important}.leaflet-control-layers-list{max-height:400px;overflow-y:auto}.leaflet-control-layers-list::-webkit-scrollbar{width:6px}.leaflet-control-layers-list::-webkit-scrollbar-track{background:var(--bg-secondary);border-radius:3px}.leaflet-control-layers-list::-webkit-scrollbar-thumb{background:var(--border-color);border-radius:3px}.leaflet-control-layers-list::-webkit-scrollbar-thumb:hover{background:var(--text-secondary)}.upload-info{margin-bottom:1.5rem}.upload-info p{margin:.5rem 0;font-size:.9rem;color:var(--text-secondary)}.upload-info p:first-child{margin-top:0}.upload-info p:last-child{margin-bottom:0}.dropzone{min-height:200px;border:2px dashed var(--border-color);border-radius:8px;background:var(--bg-secondary);display:flex;align-items:center;justify-content:center;transition:all .2s ease;cursor:pointer;margin:1.5rem 0}.dropzone:hover{border-color:var(--accent-color);background:var(--bg-tertiary)}.dropzone.dragover{border-color:var(--accent-color);background:#dc28140d;border-style:solid}.dropzone-content{display:flex;flex-direction:column;align-items:center;gap:1rem;padding:2rem;text-align:center}.dropzone-content .material-symbols-outlined{font-size:4rem;color:var(--accent-color)}.dropzone-content p{font-size:1rem;color:var(--text-primary);margin:0}.dropzone-link{color:var(--accent-color);text-decoration:underline;cursor:pointer}.dropzone-link:hover{text-decoration:none}.upload-progress{margin-top:1.5rem;padding:1rem;background:var(--bg-secondary);border-radius:8px}.progress-info{display:flex;justify-content:space-between;align-items:center;gap:1rem}.progress-info-top{margin-bottom:.5rem}.progress-info-bottom{margin-top:.5rem}.progress-text{font-size:.9rem;font-weight:600;color:var(--text-primary)}.progress-size,.progress-time{font-size:.85rem;color:var(--text-secondary)}.progress-percent{font-size:.9rem;font-weight:600;color:var(--text-primary)}.progress-bar-container{width:100%;height:8px;background:var(--bg-tertiary);border-radius:4px;overflow:hidden}.progress-bar{height:100%;background:var(--accent-color);border-radius:4px;transition:width .3s ease}.upload-success{margin-top:1rem;padding:1rem;background:#0596691a;border-radius:8px;color:var(--success-color, #059669);font-size:.9rem;font-weight:500}.upload-error{margin-top:1rem;padding:1rem;background:#dc26261a;border-radius:8px;color:var(--error-color);font-size:.9rem;white-space:pre-line;word-break:break-word}@media(max-width:768px){.dropzone{min-height:150px}.dropzone-content .material-symbols-outlined{font-size:3rem}.dropzone-content p{font-size:.9rem}.upload-info{font-size:.85rem}.progress-info{flex-direction:column;align-items:flex-start;gap:.25rem}.progress-info-top{margin-bottom:.25rem}.progress-info-bottom{margin-top:.25rem}}.section-nav{position:fixed;top:0;left:var(--sidebar-width);right:var(--sidebar-width);height:48px;background:var(--bg-primary);border-bottom:1px solid var(--border-color);z-index:100;display:flex;align-items:center;justify-content:center;gap:.5rem;padding:0 1rem;transform:translateY(-100%);opacity:0;transition:transform .3s ease,opacity .3s ease;box-shadow:0 2px 8px #00000026}.section-nav.visible{transform:translateY(0);opacity:1}.right-sidebar.collapsed~.section-nav,body:has(.right-sidebar.collapsed) .section-nav{right:0}.section-nav-items{display:flex;align-items:center;gap:.25rem;overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none;-ms-overflow-style:none;max-width:100%}.section-nav-items::-webkit-scrollbar{display:none}.section-nav-item{display:flex;align-items:center;gap:.35rem;padding:.5rem .75rem;font-family:inherit;font-weight:400;color:var(--text-secondary);background:transparent;border:none;border-radius:6px;cursor:pointer;white-space:nowrap;transition:background .2s ease,color .2s ease}.section-nav-item:hover{background:var(--bg-secondary);color:var(--text-primary)}.section-nav-item.active{background:var(--accent-color);color:var(--text-on-accent, #fff)}.section-nav-item .material-symbols-outlined{font-size:20px}.section-nav-divider{width:1px;height:24px;background:var(--border-color);margin:0 .25rem;flex-shrink:0}@media(max-width:1024px){.section-nav{left:0;right:0}}@media(max-width:768px){.section-nav-item{gap:0}.section-nav{padding:0 .5rem}.section-nav-item{padding:.4rem .25rem;font-size:.7rem}.section-nav-item .material-symbols-outlined{font-size:20px}}@media(max-width:600px){.section-nav{padding:0 .5rem}.section-nav-item{padding:.4rem .5rem;font-size:.75rem}.section-nav-item .material-symbols-outlined{font-size:20px}.section-nav-item span:not(.material-symbols-outlined){display:none}}.autocomplete-container{position:relative;width:100%}.autocomplete-input{width:100%}.autocomplete-dropdown{position:absolute;top:100%;left:0;right:0;max-height:200px;overflow-y:auto;background:var(--bg-primary);border:1px solid var(--border-color);border-top:none;border-radius:0 0 8px 8px;box-shadow:0 4px 12px #00000026;z-index:100;display:none}.autocomplete-dropdown.active{display:block}.autocomplete-item{padding:.625rem .875rem;cursor:pointer;transition:background-color .15s ease;font-size:.875rem;color:var(--text-primary)}.autocomplete-item:hover,.autocomplete-item.highlighted{background:var(--bg-secondary)}.autocomplete-item.selected{background:var(--accent-color);color:#fff}.autocomplete-empty{padding:.625rem .875rem;font-size:.875rem;color:var(--text-secondary);font-style:italic}.autocomplete-hint{padding:.5rem .875rem;font-size:.75rem;color:var(--text-secondary);background:var(--bg-secondary);border-top:1px solid var(--border-color)}.autocomplete-container.active .autocomplete-input{border-radius:8px 8px 0 0}.autocomplete-selected{display:none;align-items:center;gap:.5rem;padding:.75rem;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:8px;font-size:1rem;color:var(--text-primary)}.autocomplete-selected.active{display:flex}.autocomplete-selected-name{flex:1}.autocomplete-selected-clear{background:none;border:none;padding:.125rem;cursor:pointer;color:var(--text-secondary);display:flex;align-items:center;justify-content:center;transition:color .15s ease}.autocomplete-selected-clear:hover{color:var(--accent-color)}.autocomplete-selected-clear .material-symbols-outlined{font-size:1.125rem}.autocomplete-container.has-selection .autocomplete-input{display:none}.autocomplete-container.has-selection .autocomplete-selected{display:flex}@media(max-width:1023px){.hidden-below-1024{display:none!important}}.route-creator-waypoint{background:none!important;border:none!important}.route-creator-waypoint svg{filter:drop-shadow(0 2px 4px rgba(0,0,0,.3))}#createRouteModal .modal-container{width:95%;max-width:none;height:90vh;display:flex;flex-direction:column}#createRouteModal .modal-header{flex-shrink:0}#createRouteModal .modal-body{display:flex;flex-direction:column;flex:1;overflow:hidden;padding:1rem}#createRouteModal .modal-actions{flex-shrink:0}.route-creator-container{flex:1;display:flex;flex-direction:column;gap:1rem}.route-creator-toolbar{flex-shrink:0;display:flex;flex-wrap:wrap;gap:.75rem;align-items:center;background:var(--bg-secondary);border-radius:8px}.route-creator-toolbar-group{display:flex;align-items:center;gap:.5rem}.route-creator-toolbar-group.search-group{flex:1 1 0;position:relative}.route-creator-toolbar-group.title-group{flex:1 1 0}.route-creator-toolbar-label{font-size:.9rem;color:var(--text-secondary);white-space:nowrap}.route-creator-toolbar-divider{width:1px;height:24px;background:var(--border-color);margin:0 .5rem}.route-creator-main{flex:1;min-height:300px}.route-creator-map-container{height:100%;position:relative}.route-creator-map{height:100%}.route-creator-profile-select{padding:.5rem .75rem;border:1px solid var(--border-color);border-radius:6px;background:var(--bg-primary);color:var(--text-primary);font-size:.9rem;cursor:pointer;height:38px;box-sizing:border-box}.route-creator-profile-select:focus{outline:none;border-color:var(--primary-color)}.route-creator-search-wrapper{position:relative;display:flex;align-items:center;flex:1;background:var(--bg-primary);border:1px solid var(--border-color);border-radius:6px;padding-left:.5rem;transition:border-color .2s ease;height:38px;box-sizing:border-box}.route-creator-search-wrapper:focus-within{border-color:var(--primary-color)}.route-creator-search-wrapper>.material-symbols-outlined{color:var(--text-tertiary);font-size:1.25rem}.route-creator-search-input{flex:1;border:none;background:transparent;padding:.5rem;color:var(--text-primary);font-size:.9rem;min-width:0}.route-creator-search-input:focus{outline:none}.route-creator-search-input::placeholder{color:var(--text-tertiary)}.route-creator-search-btn{display:flex;align-items:center;justify-content:center;padding:.5rem;background:transparent;border:none;color:var(--primary-color);cursor:pointer;border-radius:0 5px 5px 0;transition:background-color .2s ease}.route-creator-search-btn:hover{background:#e306131a}.route-creator-search-btn:disabled{color:var(--text-tertiary);cursor:not-allowed}.route-creator-search-btn:disabled:hover{background:transparent}.route-creator-search-results{position:absolute;top:calc(100% + 2px);left:0;right:0;background:var(--bg-primary);border:1px solid var(--border-color);border-radius:6px;max-height:250px;overflow-y:auto;z-index:1100;display:none;box-shadow:0 4px 12px #00000026}.route-creator-search-results.active{display:block}.route-creator-search-result{padding:.75rem 1rem;cursor:pointer;border-bottom:1px solid var(--border-color);display:flex;align-items:flex-start;gap:.5rem;transition:background-color .15s ease}.route-creator-search-result:last-child{border-bottom:none}.route-creator-search-result:hover,.route-creator-search-result.selected{background:var(--bg-secondary)}.route-creator-search-result .material-symbols-outlined{color:var(--primary-color);font-size:1.25rem;flex-shrink:0;margin-top:.1rem}.route-creator-search-result-text{flex:1;min-width:0}.route-creator-search-result-name{font-weight:500;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.route-creator-search-result-address{font-size:.85rem;color:var(--text-secondary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.route-creator-search-loading,.route-creator-search-empty{padding:1rem;text-align:center;color:var(--text-secondary);font-size:.9rem}.route-creator-map-container{flex:1;min-height:300px;border-radius:8px;overflow:hidden;position:relative}.route-creator-map{width:100%;height:100%}.route-creator-waypoints-panel{position:absolute;top:10px;right:10px;z-index:1000;width:280px;max-height:calc(100% - 70px);display:flex;flex-direction:column;background:var(--bg-primary);border-radius:8px;box-shadow:var(--shadow-sm);overflow:visible;opacity:.9;transition:opacity .3s ease,box-shadow .3s ease}.route-creator-waypoints-panel:hover{box-shadow:var(--shadow-md);opacity:1}.route-creator-waypoints-header{display:flex;align-items:center;gap:.5rem;padding:.75rem 1rem;background:var(--bg-secondary);font-weight:600;color:var(--text-primary);border-bottom:1px solid var(--border-color);border-radius:8px 8px 0 0}.route-creator-waypoints-header .material-symbols-outlined{font-size:1.25rem;color:var(--primary-color)}.route-creator-routing-bar{position:absolute;top:10px;left:10px;z-index:1000;display:flex;flex-direction:column;gap:.25rem;padding:.5rem .75rem;background:var(--bg-primary);border-radius:8px;box-shadow:var(--shadow-sm);opacity:.9;transition:opacity .3s ease,box-shadow .3s ease}.route-creator-routing-bar:hover{box-shadow:var(--shadow-md);opacity:1}.route-creator-routing-row{display:flex;align-items:center;gap:.5rem}.route-creator-routing-group{display:flex;gap:.25rem}.route-creator-routing-divider{width:1px;height:28px;background:var(--border-color);margin:0 .25rem;align-self:center}.route-creator-routing-avoid{display:none}@media(min-width:1201px){.route-creator-routing-bar{flex-direction:row;align-items:center}.route-creator-routing-avoid{display:flex}.route-creator-routing-avoid:before{content:"";width:1px;height:28px;background:var(--border-color);margin:0 .5rem;align-self:center}}@media(max-width:1200px){.route-creator-routing-avoid{display:flex}}.route-creator-routing-item{display:flex;align-items:center;justify-content:center;width:36px;height:36px;padding:0;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:6px;cursor:pointer;transition:all .15s ease;color:var(--text-tertiary)}.route-creator-routing-item:hover{background:var(--bg-hover);border-color:var(--primary-color)}.route-creator-routing-item.active{background:var(--accent-color);border-color:var(--accent-color);color:var(--text-on-accent, #fff)}.route-creator-routing-item .material-symbols-outlined{font-size:1.25rem}.route-creator-routing-item .route-creator-curvy-icon{width:20px;height:20px}.route-creator-routing-tooltip{position:fixed;background:var(--bg-primary);border:1px solid var(--border-color);border-radius:8px;padding:.5rem .75rem;font-size:.8rem;line-height:1.5;color:var(--text-secondary);white-space:nowrap;box-shadow:0 4px 12px #00000026;opacity:0;visibility:hidden;transition:opacity .15s ease,visibility .15s ease;pointer-events:none;z-index:1001;display:flex;align-items:flex-start;gap:.5rem}.route-creator-routing-tooltip.visible{opacity:1;visibility:visible}.route-creator-routing-tooltip:before{content:"info";font-family:Material Symbols Outlined;font-size:1.1rem;color:#3b82f6;flex-shrink:0;line-height:1.3}.route-creator-routing-tooltip-content{text-align:left}.route-creator-routing-tooltip strong{display:block;color:var(--text-primary);margin-bottom:.125rem}.route-creator-waypoints-list{flex:1;overflow-y:auto;padding:.5rem;min-height:0}.route-creator-waypoints-stats{display:flex;flex-direction:column;gap:.25rem;padding:.5rem .75rem;border-top:1px solid var(--border-color);background:var(--bg-secondary);flex-shrink:0;border-radius:0 0 8px 8px;position:relative}.route-creator-stats-row{display:flex;justify-content:space-between;align-items:center}.route-creator-quota-row{padding-top:.25rem;border-top:1px solid var(--border-color);margin-top:.25rem}.route-creator-waypoints-stat{display:flex;align-items:center;gap:.25rem;font-size:.75rem;color:var(--text-primary);font-weight:600}.route-creator-waypoints-stat .material-symbols-outlined{font-size:1rem;color:var(--primary-color)}.route-creator-quota-stat{cursor:help;position:relative}.route-creator-quota-stat>span:nth-child(2){color:#22c55e;font-weight:600}.route-creator-quota-stat>.material-symbols-outlined{color:#22c55e}.route-creator-quota-stat.quota-low>span:nth-child(2){color:#f59e0b}.route-creator-quota-stat.quota-low>.material-symbols-outlined{color:#f59e0b}.route-creator-quota-stat.quota-critical>span:nth-child(2){color:#ef4444}.route-creator-quota-stat.quota-critical>.material-symbols-outlined{color:#ef4444}.route-creator-quota-tooltip{position:absolute;bottom:calc(100% + 8px);left:50%;transform:translate(-50%);background:var(--bg-primary);border:1px solid var(--border-color);border-radius:8px;padding:.75rem 1rem;font-size:.8rem;line-height:1.5;color:var(--text-secondary);box-shadow:0 4px 12px #00000026;width:280px;z-index:1000;opacity:0;visibility:hidden;transition:opacity .2s ease,visibility .2s ease;pointer-events:none}.route-creator-quota-tooltip:after{content:"";position:absolute;top:100%;left:50%;transform:translate(-50%);border:8px solid transparent;border-top-color:var(--border-color)}.route-creator-quota-tooltip:before{content:"";position:absolute;top:100%;left:50%;transform:translate(-50%);border:7px solid transparent;border-top-color:var(--bg-primary);z-index:1}.route-creator-quota-stat:hover .route-creator-quota-tooltip{opacity:1;visibility:visible}.route-creator-quota-tooltip strong{color:var(--text-primary)}#routeQuotaStatTomtom .route-creator-quota-tooltip{left:auto;right:0;transform:none}#routeQuotaStatTomtom .route-creator-quota-tooltip:after,#routeQuotaStatTomtom .route-creator-quota-tooltip:before{left:auto;right:20px;transform:none}.route-creator-waypoints-empty{padding:2rem 1rem;text-align:center;color:var(--text-tertiary);font-size:.9rem}.route-creator-waypoint-item{display:flex;align-items:center;gap:.5rem;padding:.5rem .75rem;background:var(--bg-primary);border-radius:6px;margin-bottom:.5rem;cursor:grab;transition:background-color .15s ease,box-shadow .15s ease;border:1px solid var(--border-color)}.route-creator-waypoint-item:hover{background:var(--bg-tertiary)}.route-creator-waypoint-item.dragging{opacity:.5;box-shadow:var(--shadow-md)}.route-creator-waypoint-item.drag-over{border-color:var(--primary-color);background:#e306130d}.route-creator-waypoint-drag{color:var(--text-tertiary);cursor:grab}.route-creator-waypoint-drag:active{cursor:grabbing}.route-creator-waypoint-number{width:24px;height:24px;display:flex;align-items:center;justify-content:center;border-radius:50%;font-size:.8rem;font-weight:600;flex-shrink:0}.route-creator-waypoint-number.start{background:#22c55e;color:#fff}.route-creator-waypoint-number.end{background:#e30613;color:#fff}.route-creator-waypoint-number.via{background:#3b82f6;color:#fff}.route-creator-waypoint-info{flex:1;min-width:0;overflow:hidden}.route-creator-waypoint-label{font-size:.85rem;font-weight:500;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.route-creator-waypoint-coords{font-size:.7rem;color:var(--text-tertiary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:180px}.route-creator-waypoint-delete{padding:.25rem;background:transparent;border:none;color:var(--text-tertiary);cursor:pointer;border-radius:4px;display:flex;align-items:center;justify-content:center;transition:color .15s ease,background-color .15s ease}.route-creator-waypoint-delete:hover{color:#ef4444;background:#ef44441a}.route-creator-waypoint-delete .material-symbols-outlined{font-size:1.1rem}.route-creator-stats{display:flex;flex-wrap:wrap;gap:1.5rem;background:var(--bg-secondary);border-radius:8px}.route-creator-stat{display:flex;align-items:center;gap:.5rem;font-size:.95rem;color:var(--text-secondary)}.route-creator-stat .material-symbols-outlined{font-size:1.25rem;color:var(--primary-color)}.route-creator-stat-value{font-weight:600;color:var(--text-primary)}.route-creator-hint{display:flex;align-items:center;gap:.5rem;padding:.75rem 1rem;background:#3b82f61a;border-left:3px solid #3b82f6;border-radius:0 8px 8px 0;color:var(--text-secondary);font-size:.9rem}.route-creator-hint .material-symbols-outlined{color:#3b82f6}.route-creator-title-input{flex:1;padding:.5rem .75rem;border:1px solid var(--border-color);border-radius:6px;background:var(--bg-primary);color:var(--text-primary);font-size:.9rem;height:38px;box-sizing:border-box}.route-creator-title-input:focus{outline:none;border-color:var(--primary-color)}.route-creator-error{display:none;align-items:center;gap:.5rem;padding:.75rem 1rem;background:#ef44441a;border:1px solid #ef4444;border-radius:8px;color:#ef4444;font-size:.9rem;margin-bottom:.5rem}.route-creator-error.visible{display:flex}.route-creator-error .material-symbols-outlined{font-size:1.25rem;flex-shrink:0}.route-creator-error #routeCreatorErrorText{flex:1}.route-creator-error-close{display:flex;align-items:center;justify-content:center;background:none;border:none;color:#ef4444;cursor:pointer;padding:.25rem;margin-left:auto;border-radius:4px;transition:background-color .15s ease}.route-creator-error-close:hover{background:#ef444426}.route-creator-error-close .material-symbols-outlined{font-size:1.1rem}.route-creator-type-tooltip{position:absolute;z-index:1001;background:var(--bg-primary);border:1px solid var(--border-color);border-radius:8px;box-shadow:0 4px 16px #0003;padding:.5rem;display:flex;flex-direction:column;font-family:var(--font-family);min-width:160px;transform:translate(-50%,-100%);margin-top:-12px;animation:tooltipFadeIn .15s ease}@keyframes tooltipFadeIn{0%{opacity:0;transform:translate(-50%,-100%) scale(.95)}to{opacity:1;transform:translate(-50%,-100%) scale(1)}}.route-creator-type-tooltip:after{content:"";position:absolute;top:100%;left:50%;transform:translate(-50%);border:8px solid transparent;border-top-color:var(--border-color)}.route-creator-type-tooltip:before{content:"";position:absolute;top:100%;left:50%;transform:translate(-50%);border:7px solid transparent;border-top-color:var(--bg-primary);z-index:1}.route-creator-type-tooltip-title{font-size:.75rem;color:var(--text-primary);text-transform:uppercase;letter-spacing:.5px;padding:.25rem .5rem;border-bottom:1px solid var(--border-color);margin-bottom:.25rem}.route-creator-type-btn{display:flex;align-items:center;gap:.5rem;padding:.5rem;border:none;font-family:var(--font-family);background:transparent;border-radius:6px;cursor:pointer;transition:background-color .15s ease;font-size:.9rem;color:var(--text-primary);text-align:left;width:100%}.route-creator-type-btn:hover{background:var(--bg-secondary)}.route-creator-type-btn .material-symbols-outlined{font-size:1.25rem}.route-creator-type-btn.type-start .material-symbols-outlined{color:#22c55e}.route-creator-type-btn.type-via .material-symbols-outlined{color:#3b82f6}.route-creator-type-btn.type-end .material-symbols-outlined{color:#e30613}.route-creator-type-btn.type-start:hover{background:#22c55e1a}.route-creator-type-btn.type-via:hover{background:#3b82f61a}.route-creator-type-btn.type-end:hover{background:#e306131a}.route-creator-type-tooltip.tooltip-below:after{top:auto;bottom:100%;border-top-color:transparent;border-bottom-color:var(--border-color)}.route-creator-type-tooltip.tooltip-below:before{top:auto;bottom:100%;border-top-color:transparent;border-bottom-color:var(--bg-primary)}.route-creator-poi-bar{position:absolute;bottom:10px;left:60px;right:60px;z-index:1000;display:flex;align-items:center;justify-content:center;gap:.5rem;padding:.5rem .75rem;background:var(--bg-primary);border-radius:8px;box-shadow:var(--shadow-sm);min-height:36px;width:fit-content;margin:0 auto;opacity:.9;transition:opacity .3s ease,box-shadow .3s ease}.route-creator-poi-bar:hover{box-shadow:var(--shadow-md);opacity:1}.route-creator-poi-items{display:flex;align-items:center;gap:.25rem;flex-wrap:wrap;justify-content:center}.route-creator-poi-item{display:flex;align-items:center;gap:.35rem;padding:.4rem .6rem;font-family:inherit;font-size:.8rem;font-weight:400;color:var(--text-secondary);background:transparent;border:none;border-radius:6px;cursor:pointer;white-space:nowrap;transition:background .2s ease,color .2s ease}.route-creator-poi-item:hover{background:var(--bg-primary);color:var(--text-primary)}.route-creator-poi-item.active{background:var(--accent-color);color:var(--text-on-accent, #fff)}.route-creator-poi-item .material-symbols-outlined{font-size:18px}.route-creator-poi-bar.loading .route-creator-poi-items,.route-creator-poi-bar.zoom-too-low .route-creator-poi-items{display:none}.route-creator-poi-loading,.route-creator-poi-zoom-hint{display:none;align-items:center;gap:.5rem;font-size:.85rem;color:var(--text-secondary)}.route-creator-poi-bar.loading .route-creator-poi-loading{display:flex}.route-creator-poi-bar.zoom-too-low .route-creator-poi-zoom-hint{display:block}.route-creator-poi-spinner{width:18px;height:18px;border:2px solid var(--border-color);border-top-color:var(--primary-color);border-radius:50%;animation:poiSpinner .8s linear infinite}@keyframes poiSpinner{to{transform:rotate(360deg)}}@media(max-width:768px){.route-creator-poi-item{padding:.35rem .5rem;font-size:.75rem}.route-creator-poi-item .material-symbols-outlined{font-size:16px}}@media(max-width:480px){.route-creator-poi-item span:not(.material-symbols-outlined){display:none}.route-creator-poi-item{padding:.4rem}}.route-creator-marker-tooltip{background:var(--bg-primary);border:1px solid var(--border-color);border-radius:4px;padding:.25rem .5rem;font-size:.75rem;font-weight:600;color:var(--text-primary);box-shadow:0 2px 6px #00000026;white-space:nowrap}.route-creator-marker-tooltip:before{border-top-color:var(--border-color)}.route-creator-marker-tooltip:after{content:"";position:absolute;top:100%;left:50%;transform:translate(-50%);border:6px solid transparent;border-top-color:var(--bg-primary);margin-top:-1px}.route-creator-waypoint-popup-container .leaflet-popup-content-wrapper{background:var(--bg-primary);border:1px solid var(--border-color);border-radius:8px;box-shadow:0 4px 12px #00000026}.route-creator-waypoint-popup-container .leaflet-popup-tip{background:var(--bg-primary);border:1px solid var(--border-color);border-top:none;border-left:none}.route-creator-waypoint-popup-container .leaflet-popup-content{margin:0}.route-creator-waypoint-popup{display:flex;flex-direction:column;gap:.5rem;padding:.75rem;min-width:220px}.route-creator-waypoint-popup-header{font-weight:600;font-size:.95rem;color:var(--text-primary)}.route-creator-waypoint-popup-address{font-size:.85rem;color:var(--text-secondary);line-height:1.4}.route-creator-waypoint-popup-delete{display:flex;align-items:center;justify-content:center;width:32px;height:32px;padding:0;margin-top:.25rem;background:transparent;border:1px solid var(--border-color);border-radius:6px;color:var(--text-secondary);cursor:pointer;transition:all .15s ease}.route-creator-waypoint-popup-delete:hover{background:#ef44441a;border-color:#ef4444;color:#ef4444}.route-creator-waypoint-popup-delete .material-symbols-outlined{font-size:1.25rem}.route-creator-poi-marker{background:none!important;border:none!important}.route-creator-poi-marker-inner{width:32px;height:32px;border-radius:50%;display:flex;align-items:center;justify-content:center;box-shadow:0 2px 6px #0000004d;border:2px solid white;transition:transform .15s ease}.route-creator-poi-marker-inner:hover{transform:scale(1.1)}.route-creator-poi-marker-inner .material-symbols-outlined{font-size:18px;color:#fff}.route-creator-poi-cluster{background:none!important;border:none!important}.route-creator-poi-cluster-inner{width:100%;height:100%;border-radius:50%;display:flex;flex-direction:column;align-items:center;justify-content:center;box-shadow:0 3px 8px #0006;border:3px solid white;cursor:pointer;transition:transform .15s ease;position:relative}.route-creator-poi-cluster-inner:hover{transform:scale(1.1)}.route-creator-poi-cluster-inner .material-symbols-outlined{font-size:16px;color:#fff;line-height:1}.route-creator-poi-cluster-count{font-size:10px;font-weight:700;color:#fff;line-height:1;margin-top:1px}.route-creator-poi-cluster.small .route-creator-poi-cluster-inner .material-symbols-outlined{font-size:14px}.route-creator-poi-cluster.small .route-creator-poi-cluster-count{font-size:9px}.route-creator-poi-cluster.medium .route-creator-poi-cluster-inner .material-symbols-outlined{font-size:18px}.route-creator-poi-cluster.medium .route-creator-poi-cluster-count{font-size:11px}.route-creator-poi-cluster.large .route-creator-poi-cluster-inner .material-symbols-outlined{font-size:20px}.route-creator-poi-cluster.large .route-creator-poi-cluster-count{font-size:12px}.marker-cluster-small,.marker-cluster-medium,.marker-cluster-large,.marker-cluster-small div,.marker-cluster-medium div,.marker-cluster-large div{background:transparent!important}.route-creator-poi-popup .leaflet-popup-content-wrapper{border-radius:8px;padding:0}.route-creator-poi-popup .leaflet-popup-content{margin:0;min-width:200px}.route-creator-poi-popup-content{padding:.75rem}.route-creator-poi-popup-header{display:flex;align-items:center;gap:.5rem;margin-bottom:.5rem;padding-bottom:.5rem;border-bottom:1px solid var(--border-color)}.route-creator-poi-popup-header .material-symbols-outlined{font-size:1.25rem}.route-creator-poi-popup-header strong{font-size:.95rem;color:var(--text-primary)}.route-creator-poi-popup-details{display:flex;flex-direction:column;gap:.35rem}.route-creator-poi-popup-detail{display:flex;align-items:center;gap:.35rem;font-size:.8rem;color:var(--text-secondary)}.route-creator-poi-popup-detail .material-symbols-outlined{font-size:1rem;color:var(--text-tertiary);flex-shrink:0}.route-creator-poi-popup-detail a{color:var(--primary-color);text-decoration:none}.route-creator-poi-popup-detail a:hover{text-decoration:underline}.route-creator-poi-popup-no-details{font-style:italic;font-size:.8rem;color:var(--text-tertiary)}.route-creator-poi-popup-actions{display:flex;flex-direction:column;margin-top:.75rem;padding-top:.75rem;border-top:1px solid var(--border-color)}.leaflet-container{font-family:Nunito,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif}.leaflet-routing-container{display:none!important}.leaflet-popup-content{font-family:inherit}.leaflet-interactive.route-creator-line{stroke:var(--primary-color);stroke-width:5;stroke-opacity:.8}.route-creator-type-tooltip-divider{height:1px;background:var(--border-color);margin:.5rem 0}.route-creator-type-btn.type-isochrone{justify-content:flex-start}.route-creator-type-btn.type-isochrone .material-symbols-outlined:first-child{color:#3b82f6}.route-creator-type-btn.type-isochrone:hover{background:#3b82f61a}.route-creator-type-btn.type-isochrone.disabled{opacity:.5;cursor:not-allowed}.route-creator-type-btn.type-isochrone.disabled:hover{background:transparent}.route-creator-type-btn-arrow{margin-left:auto;font-size:1rem!important;color:var(--text-tertiary);transition:transform .2s ease}.route-creator-type-btn.type-isochrone.expanded .route-creator-type-btn-arrow{transform:rotate(90deg)}.route-creator-isochrone-submenu{background:var(--bg-primary);border:1px solid var(--border-color);border-radius:8px;box-shadow:0 4px 16px #0003;padding:.5rem;min-width:200px;z-index:1002}.route-creator-isochrone-submenu-title{font-size:.75rem;color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.5px;padding:.25rem .5rem;margin-bottom:.5rem}.route-creator-isochrone-time-options{display:grid;grid-template-columns:repeat(4,1fr);gap:.25rem}.route-creator-isochrone-time-btn{padding:.5rem .75rem;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:6px;color:var(--text-primary);font-size:.85rem;font-weight:500;cursor:pointer;transition:all .15s ease;font-family:inherit}.route-creator-isochrone-time-btn:hover{background:var(--accent-color);border-color:var(--accent-color);color:var(--text-on-accent, #fff)}.route-creator-isochrone-time-selector{display:grid;grid-template-columns:repeat(4,1fr);gap:.25rem;margin-top:.5rem;padding-top:.5rem;border-top:1px solid var(--border-color)}.route-creator-poi-popup-isochrone{margin-top:.5rem;padding-top:.5rem;border-top:1px solid var(--border-color)}.route-creator-poi-popup-isochrone .route-creator-isochrone-time-selector{margin-top:.5rem;padding-top:0;border-top:none}.route-creator-poi-popup-delete-section{margin-top:.75rem;padding-top:.75rem;border-top:1px solid var(--border-color)}.route-creator-favorite-delete-btn{display:flex;align-items:center;justify-content:center;gap:.35rem;width:100%;padding:.5rem;background:transparent;border:1px solid var(--border-color);border-radius:6px;color:var(--text-secondary);font-family:var(--font-family);font-size:.8rem;cursor:pointer;transition:all .2s ease}.route-creator-favorite-delete-btn:hover{background:#ef44441a;border-color:#ef4444;color:#ef4444}.route-creator-favorite-delete-btn .material-symbols-outlined{font-size:1rem}.route-creator-poi-popup-favorite-section{margin-top:.5rem;padding-top:.5rem;border-top:1px solid var(--border-color)}.route-creator-type-btn.type-favorite .material-symbols-outlined:first-child{color:#eab308}.route-creator-type-btn.type-favorite:hover{background:#eab3081a}.route-creator-waypoint-popup-actions-vertical{display:flex;flex-direction:column;margin-top:.75rem;padding-top:.75rem;border-top:1px solid var(--border-color)}.route-creator-waypoint-popup-actions-vertical .route-creator-poi-popup-isochrone{margin-top:0;padding-top:0;border-top:none}.route-creator-waypoint-popup-favorite-info{display:flex;align-items:center;gap:.5rem;padding:.5rem;background:#eab3081a;border-radius:6px;font-size:.85rem;color:var(--text-primary);margin-top:.25rem}.route-creator-waypoint-popup-favorite-info .material-symbols-outlined{font-size:1.25rem}.route-creator-waypoint-popup-divider{height:1px;background:var(--border-color);margin:.5rem 0}.route-creator-type-btn.type-delete .material-symbols-outlined:first-child{color:#ef4444}.route-creator-type-btn.type-delete:hover{background:#ef44441a}.route-creator-favorite-dialog{position:fixed;top:0;left:0;right:0;bottom:0;z-index:10000;display:flex;align-items:center;justify-content:center;animation:fadeIn .2s ease}.route-creator-favorite-dialog.closing{animation:fadeOut .2s ease forwards}.route-creator-favorite-dialog-overlay{position:absolute;top:0;left:0;right:0;bottom:0;background:#00000080}.route-creator-favorite-dialog-content{position:relative;background:var(--bg-primary);border-radius:12px;box-shadow:0 8px 32px #0000004d;width:90%;max-width:400px;animation:slideUp .2s ease;font-family:var(--font-family)}.route-creator-favorite-dialog.closing .route-creator-favorite-dialog-content{animation:slideDown .2s ease forwards}.route-creator-favorite-dialog-header{display:flex;align-items:center;gap:.5rem;padding:1rem 1.25rem;border-bottom:1px solid var(--border-color)}.route-creator-favorite-dialog-header h3{margin:0;font-size:1.1rem;font-weight:600}.route-creator-favorite-dialog-body{padding:1.25rem}.route-creator-favorite-dialog-field{display:flex;flex-direction:column;gap:.5rem}.route-creator-favorite-dialog-field label{font-size:.875rem;font-weight:500;color:var(--text-secondary)}.route-creator-favorite-dialog-field input{padding:.75rem;border:1px solid var(--border-color);border-radius:8px;font-family:var(--font-family);font-size:1rem;background:var(--bg-secondary);color:var(--text-primary);transition:border-color .15s ease}.route-creator-favorite-dialog-field input:focus{outline:none;border-color:var(--accent-color)}.route-creator-favorite-dialog-field input.error{border-color:#ef4444;animation:shake .3s ease}.route-creator-favorite-dialog-visibility{display:flex;flex-direction:column;gap:.5rem}.route-creator-favorite-dialog-radio{display:flex;align-items:center;gap:.75rem;padding:.75rem;border:1px solid var(--border-color);border-radius:8px;cursor:pointer;transition:all .15s ease}.route-creator-favorite-dialog-radio:hover{background:var(--bg-secondary)}.route-creator-favorite-dialog-radio:has(input:checked){border-color:var(--accent-color);background:var(--bg-secondary)}.route-creator-favorite-dialog-radio input[type=radio]{display:none}.route-creator-favorite-dialog-radio-icon{display:flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:8px;flex-shrink:0}.route-creator-favorite-dialog-radio-icon.personal{background:#eab30826;color:#eab308}.route-creator-favorite-dialog-radio-icon.club{background:#dc281426;color:#ef4444}.route-creator-favorite-dialog-radio-icon .material-symbols-outlined{font-size:1.25rem}.route-creator-favorite-dialog-radio-label{display:flex;flex-direction:column;gap:.125rem}.route-creator-favorite-dialog-radio-label strong{font-size:.9rem;font-weight:500;color:var(--text-primary)}.route-creator-favorite-dialog-radio-label small{font-size:.8rem;color:var(--text-tertiary)}.route-creator-favorite-dialog-address{display:flex;align-items:flex-start;gap:.5rem;margin-top:1rem;padding:.75rem;background:var(--bg-tertiary);border-radius:8px;font-size:.875rem;color:var(--text-secondary)}.route-creator-favorite-dialog-address .material-symbols-outlined{font-size:1.1rem;color:var(--text-tertiary);flex-shrink:0;margin-top:.1rem}.route-creator-favorite-dialog-address-content{display:flex;flex-direction:column;gap:.25rem}.route-creator-favorite-dialog-address-content small{font-size:.75rem;color:var(--text-tertiary);font-family:monospace}.route-creator-favorite-dialog-actions{display:flex;justify-content:flex-end;gap:.75rem;padding:1rem 1.25rem;border-top:1px solid var(--border-color)}.route-creator-favorite-dialog-actions button{display:flex;align-items:center;gap:.4rem;padding:.6rem 1rem;border-radius:8px;font-family:var(--font-family);font-size:.9rem;font-weight:500;cursor:pointer;transition:all .15s ease}.route-creator-favorite-dialog-cancel{background:var(--bg-tertiary);border:1px solid var(--border-color);color:var(--text-primary)}.route-creator-favorite-dialog-cancel:hover{background:var(--bg-hover)}.route-creator-favorite-dialog-save.btn-primary{background:var(--accent-color);border:none;color:#fff}.route-creator-favorite-dialog-save.btn-primary:hover{background:var(--accent-hover)}.route-creator-favorite-dialog-save:disabled{opacity:.6;cursor:not-allowed}.route-creator-favorite-dialog-save .material-symbols-outlined{font-size:1.1rem}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes fadeOut{0%{opacity:1}to{opacity:0}}@keyframes shake{0%,to{transform:translate(0)}25%{transform:translate(-5px)}75%{transform:translate(5px)}}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes slideDown{0%{opacity:1;transform:translateY(0)}to{opacity:0;transform:translateY(20px)}}.rotating{animation:rotate 1s linear infinite}@keyframes rotate{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.route-creator-waypoint-favorite-star{vertical-align:middle}.route-creator-waypoint-label{display:flex;align-items:center}.route-creator-isochrone{pointer-events:auto}.route-creator-isochrone:focus,.route-creator-isochrone:active{outline:none!important}.leaflet-interactive.route-creator-isochrone:focus{outline:none!important}path.route-creator-isochrone:focus{outline:none!important;stroke-dasharray:none!important}.route-creator-isochrone-tooltip{background:var(--bg-primary);border:1px solid var(--border-color);border-radius:4px;padding:.25rem .5rem;font-size:.8rem;font-weight:600;color:var(--text-primary);box-shadow:0 2px 6px #00000026;white-space:nowrap}.route-creator-isochrone-origin{background:none!important;border:none!important}.route-creator-isochrone-origin-inner{width:36px;height:36px;border-radius:50%;background:#3b82f6;display:flex;align-items:center;justify-content:center;box-shadow:0 2px 8px #3b82f666;border:3px solid white}.route-creator-isochrone-origin-inner .material-symbols-outlined{font-size:20px;color:#fff}.route-creator-isochrone-clear-bar{position:absolute;bottom:68px;left:50%;transform:translate(-50%);z-index:1001;display:flex;align-items:center;justify-content:center;gap:.5rem;padding:.5rem 1rem;background:var(--bg-primary);border-radius:8px;box-shadow:0 2px 8px #00000026;min-height:36px;box-sizing:border-box}.route-creator-isochrone-clear-bar-loading{display:none;align-items:center;gap:.5rem;font-size:.85rem;color:var(--text-secondary)}.route-creator-isochrone-clear-bar.loading .route-creator-isochrone-clear-bar-loading{display:flex}.route-creator-isochrone-clear-bar.loading .route-creator-isochrone-clear-bar-content{display:none}.route-creator-isochrone-spinner{width:18px;height:18px;border:2px solid var(--border-color);border-top-color:#3b82f6;border-radius:50%;animation:isochroneSpinner .8s linear infinite}@keyframes isochroneSpinner{to{transform:rotate(360deg)}}.route-creator-isochrone-clear-bar-content{display:flex;align-items:center;gap:.5rem}.route-creator-isochrone-clear-bar-info{display:flex;align-items:center;gap:.35rem;font-size:.85rem;color:var(--text-secondary)}.route-creator-isochrone-clear-bar-info .material-symbols-outlined{font-size:1.1rem;color:#3b82f6}.route-creator-isochrone-clear-btn{display:flex;align-items:center;gap:.35rem;padding:.4rem .75rem;background:#ef44441a;border:1px solid #ef4444;border-radius:6px;color:#ef4444;font-size:.8rem;font-weight:500;cursor:pointer;transition:all .15s ease;font-family:inherit}.route-creator-isochrone-clear-btn:hover{background:#ef4444;color:#fff}.route-creator-isochrone-clear-btn .material-symbols-outlined{font-size:1rem}@media(max-width:768px){.route-creator-toolbar{flex-direction:column;align-items:stretch}.route-creator-toolbar-group{justify-content:center;max-width:none!important}.route-creator-toolbar-divider{width:100%;height:1px;margin:.25rem 0}.route-creator-search-wrapper{width:100%}.route-creator-stats{flex-direction:column;gap:.75rem}.route-creator-waypoints-panel{width:200px;max-height:180px}.modal-actions-split{flex-direction:column;gap:.75rem}.modal-actions-left,.modal-actions-right{width:100%;justify-content:center}}.cancellation-banner{background:var(--warning-bg);border:2px solid var(--accent-color);border-radius:12px;padding:1.25rem;margin-bottom:1.5rem}.cancellation-banner-header{display:flex;align-items:center;gap:.75rem;font-weight:600;color:var(--accent-color);font-size:1rem}.cancellation-banner-header .material-symbols-outlined{font-size:1.5rem}.cancellation-banner-reason{margin-top:1rem;padding-top:1rem;border-top:1px solid var(--accent-color);color:var(--text-primary)}.detail-edit-modal .quill-editor{display:block}.detail-edit-modal .quill-editor .ql-editor{min-height:300px}.detail-edit-modal .cancellation-reason-editor .ql-editor{min-height:120px}.detail-edit-modal .form-group:has(+.form-group .quill-editor){margin-bottom:0}.detail-edit-modal .form-group:has(.quill-editor){padding-bottom:45px;margin-top:-1rem}.detail-section-container{margin-bottom:1.5rem;padding:1rem;background:var(--bg-primary);border-radius:8px;box-shadow:var(--shadow-sm)}.detail-section-title{display:flex;align-items:center;gap:.5rem;font-size:1rem;color:var(--text-primary)}.detail-section-title .material-symbols-outlined{font-size:1.5rem;color:var(--primary-color)}.detail-section-title strong{font-weight:700}.detail-data-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:1.5rem}.detail-data-section-row{grid-column:1 / -1;display:grid;grid-template-columns:repeat(2,1fr);gap:1.5rem}.detail-data-section{display:flex;flex-direction:column;margin-bottom:3rem;padding-bottom:2rem;border-bottom:1px solid var(--border-color)}.detail-data-section:last-child{border-bottom:none;margin-bottom:2rem}.detail-data-section-wide{grid-column:1 / -1}.detail-data-section-title{display:flex;align-items:center;gap:.5rem;font-size:1.25rem;font-weight:600;color:var(--text-primary);margin-bottom:1.5rem}.detail-data-section-title .material-symbols-outlined{font-size:28px;color:var(--accent-color)}.detail-data-item{display:flex;justify-content:flex-start;align-items:flex-start;gap:1rem}.detail-data-label{font-size:1rem;color:var(--text-secondary);flex-shrink:0;min-width:200px}.detail-data-value{font-size:1rem;color:var(--text-primary);text-align:left;flex:1;word-break:break-word}.detail-description-content{font-size:1rem;color:var(--text-primary);line-height:1.6}.detail-data-subsection-divider{height:1px;background:var(--border-color);margin:.5rem 0;opacity:.5}@media(max-width:768px){.detail-data-grid,.detail-data-section-row{grid-template-columns:1fr}.detail-data-item{flex-direction:column;align-items:flex-start;gap:.25rem}.detail-data-value{text-align:left}}.detail-comments-conversation{display:flex;flex-direction:column;gap:1.5rem}.detail-comment-editor,.detail-edit-comment-editor,.detail-comment-editor .ql-editor,.detail-edit-comment-editor .ql-editor{min-height:300px}.detail-comment-bubble{display:flex;flex-direction:column;gap:.75rem;animation:fadeInUp .3s ease}@keyframes fadeInUp{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.detail-comment-bubble-content{background:var(--bg-secondary);padding:1.25rem;border-radius:4px 16px 16px;position:relative;box-shadow:0 2px 4px #00000014}.detail-comment-bubble-content:before{content:"";position:absolute;top:0;left:0;width:0;height:0;border-style:solid;border-width:0 12px 12px 0;border-color:transparent var(--bg-secondary) transparent transparent;transform:translate(-12px)}.detail-comment-bubble .user-badge{margin-top:0;margin-bottom:1rem}.detail-comment-text{line-height:1.6;color:var(--text-primary);font-size:.95rem;word-wrap:break-word}.detail-comment-text p{margin:0 0 .75rem}.detail-comment-text p:last-child{margin-bottom:0}.detail-comment-text a{color:var(--accent-color);text-decoration:none;transition:opacity .2s ease}.detail-comment-text a:hover{opacity:.8;text-decoration:underline}.detail-comment-text ul,.detail-comment-text ol{margin:.5rem 0;padding-left:1.5rem}.detail-comment-text li{margin:.25rem 0}.detail-comment-footer{display:flex;justify-content:space-between;align-items:center;gap:1rem;margin-top:.75rem}.detail-comment-timestamp{font-size:.75rem;color:var(--text-secondary);opacity:.8}.detail-comment-actions{display:flex;justify-content:flex-end;gap:.75rem}@media(max-width:768px){.detail-comments-conversation{gap:1.25rem}.detail-comment-bubble-content{padding:1rem}.detail-comment-text{font-size:.9rem}.detail-comment-footer{flex-direction:column;align-items:flex-start;gap:.75rem}.detail-comment-timestamp{font-size:.7rem}.detail-comment-actions{width:100%;justify-content:flex-start}}@media(max-width:480px){.detail-comments-conversation{gap:1rem}.detail-comment-bubble-content{padding:.875rem}.detail-comment-actions{gap:.5rem}}.detail-registrations{display:flex;flex-direction:column}.detail-registrations-list{display:flex;flex-wrap:wrap;gap:.75rem}.detail-registrations-count{width:100%;padding:1rem;color:var(--text-primary);font-size:1rem;font-weight:500;margin:0}[data-page="404"] .sidebar,[data-page="404"] .burger-menu,[data-page="404"] .right-sidebar,[data-page="404"] .overlay{display:none!important}[data-page="404"] .main-content{margin-left:0!important;width:100%!important}[data-page="404"] .content-wrapper{max-width:100%!important;margin-right:0!important}[data-page="404"] body{display:flex;flex-direction:column;min-height:100vh}[data-page="404"] main{display:flex;flex-direction:column;flex:1}[data-page="404"] .page-content{flex:1;display:flex;align-items:center;justify-content:center}.error-container{max-width:600px;margin:0 auto;padding:2rem;text-align:center}.error-logo{max-width:200px;height:auto;margin-bottom:2rem}.error-code{font-size:120px;font-weight:700;color:var(--primary-color);line-height:1;margin-bottom:1rem;text-shadow:2px 2px 4px rgba(0,0,0,.1)}.error-title{font-size:2rem;font-weight:600;color:var(--text-primary);margin-bottom:1rem}.error-message{font-size:1.125rem;color:var(--text-secondary);margin-bottom:2rem;line-height:1.6}.error-actions{display:flex;gap:1rem;justify-content:center;margin-bottom:3rem}@media(max-width:768px){.error-container{margin:2rem auto;padding:1.5rem}.error-code{font-size:80px}.error-title{font-size:1.5rem}.error-message{font-size:1rem}}@media(max-width:1024px){.main-content{margin-left:0}.content-wrapper{flex-direction:column}.page-content{padding:2rem 1.5rem}.page-title{font-size:2rem}.footer{padding:2rem 1.5rem}.footer-nav{gap:1.5rem}}@media(max-width:768px){.page-content{padding:2rem 1.5rem}.toast-container{left:1rem;right:1rem;top:1rem}.toast{min-width:auto;max-width:100%}.modal-container.modal-large{width:100%;max-width:100%;border-radius:0;max-height:100vh}em-emoji-picker{max-width:calc(100vw - 2rem);--emoji-size: 1.5rem;--category-emoji-size: 1.25rem}}@media(max-width:480px){em-emoji-picker{max-width:calc(100vw - 1rem);--emoji-size: 1.25rem;--category-emoji-size: 1rem}}@media(prefers-color-scheme:dark){em-emoji-picker{--background-rgb: 28, 28, 30}}
