*,*:before,*:after{margin:0;padding:0;box-sizing:border-box}html,body{height:100%;overflow:hidden;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}button{border:none;background:none;cursor:pointer;touch-action:manipulation;font:inherit;color:inherit}a{touch-action:manipulation}select{font:inherit;color:inherit}ul,ol{list-style:none}[data-theme=dark]{--bg-primary: #1a1f2b;--bg-secondary: #222a35;--bg-tertiary: #2a3344;--bg-panel: rgba(34, 42, 53, .85);--bg-panel-hover: rgba(42, 51, 68, .9);--border-primary: rgba(90, 130, 170, .2);--border-accent: rgba(90, 170, 230, .35);--text-primary: #e6edf3;--text-secondary: #8b949e;--text-muted: #5a6370;--text-accent: #58a6ff;--accent-primary: #58a6ff;--accent-secondary: #3fb950;--accent-warning: #d29922;--accent-danger: #f85149;--target-tone: #58a6ff;--target-octave: #d2a8ff;--target-quint: #e3b341;--gauge-bg: rgba(42, 52, 68, .6);--gauge-line: rgba(90, 130, 170, .15);--gauge-center: rgba(88, 166, 255, .8);--gauge-needle: #58a6ff;--gauge-positive: #3fb950;--gauge-negative: #f85149;--handpan-outer: rgba(90, 130, 170, .25);--handpan-inner: rgba(90, 130, 170, .15);--handpan-glow: rgba(88, 166, 255, .08);--shadow-subtle: 0 1px 3px rgba(0, 0, 0, .25);--shadow-medium: 0 4px 12px rgba(0, 0, 0, .3);--shadow-glow: 0 0 20px rgba(88, 166, 255, .15);--spectrum-bar: rgba(88, 166, 255, .85);--spectrum-bar-peak: #3fb950;--spectrum-bg: rgba(34, 42, 53, .6);--mic-active: #3fb950;--mic-pulse: rgba(63, 185, 80, .3)}[data-theme=light]{--bg-primary: #e6eaf0;--bg-secondary: #ffffff;--bg-tertiary: #dce1e85c;--bg-panel: rgba(255, 255, 255, .95);--bg-panel-hover: rgba(240, 243, 248, .95);--border-primary: rgba(50, 70, 100, .22);--border-accent: rgba(40, 100, 180, .35);--text-primary: #15181e;--text-secondary: #4a515a;--text-muted: #707b89;--text-accent: #0969da;--accent-primary: #0969da;--accent-secondary: #1a7f37;--accent-warning: #bf8700;--accent-danger: #cf222e;--target-tone: #0969da;--target-octave: #8250df;--target-quint: #9a6700;--gauge-bg: rgba(220, 228, 236, .7);--gauge-line: rgba(50, 70, 100, .18);--gauge-center: rgba(9, 105, 218, .7);--gauge-needle: #0969da;--gauge-positive: #1a7f37;--gauge-negative: #cf222e;--handpan-outer: rgba(50, 70, 100, .25);--handpan-inner: rgba(50, 70, 100, .15);--handpan-glow: rgba(9, 105, 218, .08);--shadow-subtle: 0 2px 6px rgba(0, 0, 0, .06), 0 1px 2px rgba(0, 0, 0, .04);--shadow-medium: 0 8px 24px rgba(0, 0, 0, .08), 0 2px 8px rgba(0, 0, 0, .04);--shadow-glow: 0 0 24px rgba(9, 105, 218, .12);--spectrum-bar: rgba(9, 105, 218, .85);--spectrum-bar-peak: #1a7f37;--spectrum-bg: rgba(230, 236, 242, .6);--mic-active: #1a7f37;--mic-pulse: rgba(26, 127, 55, .3)}body{font-family:Inter,system-ui,-apple-system,sans-serif;background:var(--bg-primary);color:var(--text-primary);transition:background .3s ease,color .3s ease}#app{width:100vw;height:100vh;min-width:320px;display:flex;flex-direction:column}.header{display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:8px 12px;row-gap:10px;padding:8px 20px;background:var(--bg-secondary);border-bottom:1px solid var(--border-primary);flex-shrink:0;z-index:10;width:100%;max-width:100%;min-width:0;box-sizing:border-box;overflow-x:clip}.header__controls{display:flex;flex-wrap:wrap;align-items:center;gap:10px 14px;flex:1 1 320px;min-width:0;max-width:100%;justify-content:center}.header__actions{display:flex;align-items:center;gap:6px;flex-shrink:0;margin-left:auto}.main{flex:1;display:flex;padding:12px;gap:12px;min-height:0;overflow:hidden}.panel-left{display:flex;align-items:center;justify-content:center;flex:0 0 auto;width:38%;min-width:280px;max-width:480px;min-height:0;overflow:hidden}.panel-left.panel-left--chladni-off{display:none!important}.panel-right{flex:1;display:flex;flex-direction:column;gap:0;min-width:0;min-height:0;overflow-y:auto}.gauges-section{display:flex;flex-direction:column;gap:6px;flex:2.4;min-height:0}.gauge-row{display:flex;align-items:center;gap:8px;flex:1;min-height:0}.spectrum-section{display:flex;flex-direction:column;gap:6px;flex:2.6;min-height:0;margin-top:8px}.header-freq-desk{display:flex}@media(max-width:1024px){.header-freq-desk{display:none!important}.header{display:grid;grid-template-columns:minmax(0,1fr) auto;grid-template-rows:auto auto;column-gap:12px;row-gap:10px;align-items:center;padding:6px 12px}.header__brand{grid-column:1;grid-row:1;justify-self:start;margin-right:0}.header__actions{grid-column:2;grid-row:1;justify-self:end;margin-left:0}.header__controls{grid-column:1 / -1;grid-row:2;width:100%;max-width:100%;flex-wrap:wrap;gap:8px;justify-content:center}.panel-left{display:none!important}.main,.panel-right{min-width:0}.header #note-selector.selector{display:grid;grid-template-columns:repeat(6,minmax(0,1fr));grid-auto-rows:auto;align-items:stretch;justify-items:stretch;gap:1px}.header #octave-selector.selector{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));grid-auto-rows:auto;align-items:stretch;justify-items:stretch;gap:1px}.header #note-selector .selector__btn,.header #octave-selector .selector__btn{min-width:0;width:100%;box-sizing:border-box}}@media(max-width:600px){.panel-left{display:none}.main{flex-direction:column;padding:8px;gap:8px;overflow-y:auto}.panel-right{overflow-y:visible}.header{padding:6px 10px}.header .control-group__label{display:none}.header__controls{display:flex;flex-wrap:nowrap;align-items:center;justify-content:center;width:100%;max-width:100%;margin-inline:auto;gap:6px}.header__controls>.control-group{flex:0 1 auto;min-width:0;display:flex;flex-direction:column;align-items:center}.header__controls>.divider{flex-shrink:0;align-self:center}.selector__btn{padding:4px 7px;font-size:12px;min-width:26px}.footer{flex-direction:column;gap:4px;align-items:center;padding:6px 12px}.footer__links{gap:10px}}.footer{display:flex;align-items:center;justify-content:space-between;padding:6px 20px;background:var(--bg-secondary);border-top:1px solid var(--border-primary);flex-shrink:0;z-index:10}.footer__copyright{font-size:11px;color:var(--text-muted);letter-spacing:.02em;display:flex;align-items:center;gap:3px}.footer__heart{vertical-align:-1px}.footer__socials{display:flex;align-items:center;gap:10px}.footer__socials-label{font-size:11px;color:var(--text-muted);margin-right:2px}.footer__social{display:flex;align-items:center;justify-content:center;color:var(--text-muted);transition:color .15s ease}.footer__social:hover{color:var(--accent-primary)}.footer__links{display:flex;align-items:center;gap:16px}.footer__link{font-size:11px;color:var(--text-secondary);text-decoration:none;transition:color .15s ease;cursor:pointer}.footer__link:hover{color:var(--accent-primary)}.footer__link-soon{position:relative;cursor:default}.footer__link-soon:after{content:"In progress";position:absolute;bottom:100%;left:50%;transform:translate(-50%) translateY(4px);margin-bottom:8px;background:var(--bg-card, #1e293b);color:var(--text-primary, #fff);border:1px solid var(--border-color, rgba(255,255,255,.1));padding:4px 8px;border-radius:6px;font-size:11px;font-weight:500;white-space:nowrap;opacity:0;pointer-events:none;transition:opacity .2s ease,transform .2s ease;box-shadow:0 4px 12px #00000026;z-index:50}.footer__link-soon:hover{color:var(--text-secondary)}.footer__link-soon:hover:after{opacity:1;transform:translate(-50%) translateY(0)}.header__brand{display:flex;align-items:center;flex-shrink:0;margin-right:20px;-webkit-user-select:none;user-select:none;cursor:pointer;transition:opacity .2s ease}.header__brand:hover{opacity:.8}.brand-zen{font-family:Inter,system-ui,sans-serif;font-size:18px;font-weight:700;color:var(--accent-primary);letter-spacing:-.02em}.brand-tuner{font-family:Inter,system-ui,sans-serif;font-size:18px;font-weight:700;color:var(--text-primary);opacity:.7;letter-spacing:-.02em}.control-group{display:flex;flex-wrap:wrap;align-items:center;gap:4px 6px;min-width:0;max-width:100%}.control-group__label{font-size:11px;font-weight:500;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.05em;margin-right:4px;white-space:nowrap}.selector{display:flex;flex-wrap:wrap;align-items:center;justify-content:center;background:var(--bg-tertiary);border-radius:6px;padding:2px;gap:1px;min-width:0;max-width:100%}.selector__btn{padding:5px 10px;font-size:13px;font-weight:500;border-radius:5px;color:var(--text-secondary);transition:all .15s ease;min-width:32px;text-align:center}.selector__btn:hover{color:var(--text-primary);background:var(--bg-panel-hover)}.selector__btn--active,.selector__btn--active:hover{background:var(--accent-primary);color:#fff;box-shadow:var(--shadow-subtle)}.freq-input{display:flex;align-items:center;gap:4px;background:var(--bg-tertiary);border-radius:6px;padding:4px 8px}.freq-input__field{font-family:JetBrains Mono,monospace;font-size:15px;font-weight:500;color:var(--text-accent);background:transparent;border:none;outline:none;width:48px;text-align:center;appearance:textfield;-moz-appearance:textfield}.freq-input__field::-webkit-inner-spin-button,.freq-input__field::-webkit-outer-spin-button{-webkit-appearance:none;margin:0}.freq-input__field:focus{background:#ffffff0d;border-radius:3px}.freq-input__unit{font-size:11px;color:var(--text-secondary);font-weight:500}.icon-btn{display:flex;align-items:center;justify-content:center;width:34px;height:34px;border-radius:6px;color:var(--text-secondary);transition:all .15s ease}.icon-btn:hover{color:var(--text-primary);background:var(--bg-tertiary)}.icon-btn svg{width:18px;height:18px}.mic-wrapper{position:relative;display:inline-flex}.mic-btn--error{color:#ef4444;background:#ef44441a}.mic-btn--error:hover{color:#ef4444;background:#ef444433}.mic-error-tooltip{position:absolute;top:100%;right:0;margin-top:8px;background:#ef4444;color:#fff;font-size:11px;padding:6px 10px;border-radius:6px;white-space:nowrap;z-index:1000;box-shadow:0 4px 6px -1px #0000001a}.mic-error-tooltip:before{content:"";position:absolute;bottom:100%;right:12px;border-width:5px;border-style:solid;border-color:transparent transparent #ef4444 transparent}.lang-select-wrap{position:relative}.lang-select{appearance:none;-webkit-appearance:none;background:var(--bg-tertiary);color:var(--text-secondary);border:1px solid var(--border-primary);border-radius:6px;padding:5px 24px 5px 8px;font-size:12px;font-weight:500;cursor:pointer;outline:none;transition:all .15s ease;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6'%3E%3Cpath d='M1 1l4 4 4-4' stroke='%238b949e' fill='none' stroke-width='1.5'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 6px center}.lang-select:hover{border-color:var(--border-accent);color:var(--text-primary)}.lang-select:focus{border-color:var(--accent-primary)}.handpan{width:100%;height:100%;display:flex;align-items:center;justify-content:center;padding:12px;position:relative}.handpan svg{width:100%;height:100%;max-width:100%;max-height:100%;position:relative;z-index:1}.handpan-chladni-canvas.handpan-chladni-canvas--off{opacity:0;visibility:hidden}.handpan-chladni-canvas{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:100%;height:100%;pointer-events:none;z-index:2;transition:opacity .2s ease,visibility .2s ease}.note-label{display:flex;flex-direction:column;align-items:center;justify-content:center;aspect-ratio:1;height:100%;min-width:0;background:var(--bg-panel);border:1px solid var(--border-primary);border-radius:10px;padding:8px;flex-shrink:0;container-type:inline-size}.note-label--current{border-color:var(--border-primary);opacity:.65}.note-label__note{font-size:38cqw;font-weight:700;line-height:1;color:var(--text-primary)}.note-label__sub{font-size:22cqw;font-weight:600;color:var(--text-accent);line-height:1}.note-label__freq{font-family:JetBrains Mono,monospace;font-size:14cqw;color:var(--text-secondary);margin-top:4px;line-height:1;display:inline-flex;align-items:flex-start;flex-wrap:nowrap;gap:.12em;max-width:100%}.note-label__freq--muted{opacity:.3}.note-label__freq-val{font-variant-numeric:tabular-nums}.note-label__freq-hz{font-size:.68em;font-weight:600;letter-spacing:.04em;line-height:1;margin-top:.1em;text-transform:uppercase;color:var(--text-muted)}.note-label__type{font-size:11cqw;font-weight:600;text-transform:uppercase;letter-spacing:.08em;color:var(--text-muted);margin-top:3px}.note-label__type--tone{color:var(--target-tone)}.note-label__type--octave{color:var(--target-octave)}.note-label__type--quint{color:var(--target-quint)}.gauge{flex:1;height:100%;background:var(--bg-panel);border:1px solid var(--border-primary);border-radius:8px;position:relative;overflow:hidden;min-height:40px;display:flex;flex-direction:column;min-width:0;transition:box-shadow .28s ease,background-color .28s ease}.gauge--in-zone[data-category=tone]{border-width:2px;border-style:solid;border-color:color-mix(in srgb,var(--target-tone) 78%,transparent);background-color:color-mix(in srgb,var(--target-tone) 14%,transparent);box-shadow:inset 0 0 32px color-mix(in srgb,var(--target-tone) 16%,transparent)}.gauge--in-zone[data-category=octave]{border-width:2px;border-style:solid;border-color:color-mix(in srgb,var(--target-octave) 78%,transparent);background-color:color-mix(in srgb,var(--target-octave) 14%,transparent);box-shadow:inset 0 0 32px color-mix(in srgb,var(--target-octave) 16%,transparent)}.gauge--in-zone[data-category=quint]{border-width:2px;border-style:solid;border-color:color-mix(in srgb,var(--target-quint) 78%,transparent);background-color:color-mix(in srgb,var(--target-quint) 14%,transparent);box-shadow:inset 0 0 32px color-mix(in srgb,var(--target-quint) 16%,transparent)}.gauge-mobile-line{display:none;flex-shrink:0}.gauge-mobile-line__left,.gauge-mobile-line__right{display:flex;flex-direction:row;align-items:flex-start;gap:6px;min-width:0}.gauge-mobile-line__left{justify-content:flex-start}.gauge-mobile-line__center{display:flex;align-items:flex-start;justify-content:center;flex-shrink:0}.gauge-mobile-line__right{justify-content:flex-end;text-align:right}.gauge-mobile-line__note{color:var(--text-primary);font-weight:700}.gauge-mobile-line__note--hero{line-height:1;flex-shrink:0}.gauge-mobile-line__oct{font-size:.78em;font-weight:600;color:var(--text-accent);margin-left:.04em}.gauge-mobile-line__oct--cts{margin-left:.06em}.gauge-mobile-line__freq{font-family:JetBrains Mono,monospace;font-size:.92em;font-weight:500;color:var(--text-secondary);display:inline-flex;align-items:flex-start;line-height:1;gap:.15em}.gauge-mobile-line__freq-val{font-variant-numeric:tabular-nums}.gauge-mobile-line__freq-hz{font-size:.68em;font-weight:600;letter-spacing:.04em;line-height:1;margin-top:.02em;text-transform:uppercase;color:var(--text-muted)}.gauge-mobile-line__type{text-transform:uppercase;letter-spacing:.05em;font-size:.88em;font-weight:700;color:var(--text-muted)}.gauge-mobile-line__type--tone{color:var(--target-tone)}.gauge-mobile-line__type--octave{color:var(--target-octave)}.gauge-mobile-line__type--quint{color:var(--target-quint)}.gauge-mobile-line__muted{opacity:.45}.gauge-canvas-wrap{flex:1;min-height:0;min-width:0;position:relative}.gauge canvas{width:100%;height:100%;display:block}@media(max-width:600px){.gauge-row>.note-label{display:none!important}.gauge-mobile-line{display:grid;grid-template-columns:1fr auto 1fr;align-items:start;column-gap:8px;width:100%;box-sizing:border-box;padding:6px 5px 4px;font-size:13px;font-weight:600;line-height:1.25;color:var(--text-secondary)}.gauge-mobile-line__left{justify-self:start}.gauge-mobile-line__center{justify-self:center}.gauge-mobile-line__right{justify-self:end}.gauge-mobile-line__left,.gauge-mobile-line__right{gap:7px;align-items:flex-start}.gauge-mobile-line__center{padding-top:0}.gauge-mobile-line__note--hero{font-size:clamp(1.35rem,4.8vw,1.65rem);font-weight:800;letter-spacing:-.02em}.gauge-mobile-line__note--hero .gauge-mobile-line__oct{font-size:.58em;font-weight:700}.gauge{min-height:50px}.gauge-canvas-wrap{min-height:40px}}.spectrum-panel{background:var(--bg-panel);border:1px solid var(--border-primary);border-radius:8px;display:flex;align-items:center;justify-content:center;position:relative;overflow:hidden;min-height:60px;flex:1.75}.spectrum-panel__label{font-size:11px;font-weight:500;color:var(--text-muted);text-transform:uppercase;letter-spacing:.1em;position:absolute;top:6px;left:10px;pointer-events:none;opacity:.6}.spectrum-panel canvas{width:100%;height:100%;display:block;position:absolute;top:0;left:0}.spectrum-tooltip{position:fixed;pointer-events:none;background:var(--bg-panel);border:1px solid var(--border-primary);border-radius:6px;padding:8px 12px;box-shadow:var(--shadow-medium);font-family:Inter,system-ui,sans-serif;transform:translate(-50%,-10px);z-index:10000;display:none;flex-direction:column;align-items:center;gap:2px}.spectrum-tooltip.visible{display:flex}.spectrum-tooltip__main{font-family:Inter,system-ui,sans-serif;font-size:14px;font-weight:700}.spectrum-tooltip__main .note-part{color:var(--text-primary)}.spectrum-tooltip__main .cents-part{color:var(--text-muted);font-weight:600}.spectrum-tooltip__sub{font-family:JetBrains Mono,monospace;font-size:12px;color:var(--text-muted);font-weight:600}.spectrogram-panel{background:var(--bg-panel);border:1px solid var(--border-primary);border-radius:8px;display:flex;align-items:center;justify-content:center;position:relative;overflow:hidden;min-height:60px;flex:2.1}.spectrogram-panel__label{font-size:11px;font-weight:500;color:var(--text-muted);text-transform:uppercase;letter-spacing:.1em;position:absolute;top:6px;left:10px;pointer-events:none;opacity:.6;z-index:2}.spectrogram-hover-line{display:none;position:absolute;top:0;left:0;width:0;height:100%;border-left:1px dashed var(--text-primary);opacity:.4;pointer-events:none;z-index:1}.spectrogram-panel canvas{width:100%;height:100%;display:block;position:absolute;top:0;left:0}.mic-btn{position:relative}.mic-btn--active{color:var(--mic-active)!important}.mic-btn__pulse{position:absolute;top:4px;right:4px;width:8px;height:8px;border-radius:50%;background:var(--mic-active);animation:mic-pulse 1.5s ease-in-out infinite}@keyframes mic-pulse{0%,to{box-shadow:0 0 0 0 var(--mic-pulse);opacity:1}50%{box-shadow:0 0 0 6px transparent;opacity:.7}}.divider{width:1px;height:20px;background:var(--border-primary);flex-shrink:0}.settings-overlay{position:fixed;inset:0;z-index:1000;display:flex;align-items:center;justify-content:center;background:#0000;-webkit-backdrop-filter:blur(0px);backdrop-filter:blur(0px);transition:background .25s ease,backdrop-filter .25s ease;pointer-events:none}.settings-overlay--visible{background:#00000073;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);pointer-events:auto}.settings-modal{background:var(--bg-secondary);border:1px solid var(--border-accent);border-radius:16px;box-shadow:0 24px 80px #00000059,0 0 0 1px #ffffff0d inset,var(--shadow-glow);width:520px;max-width:calc(100vw - 40px);max-height:85vh;display:flex;flex-direction:column;overflow:hidden;opacity:0;transform:translateY(20px) scale(.96);transition:opacity .25s ease,transform .25s ease}.settings-modal--visible{opacity:1;transform:translateY(0) scale(1)}.settings-modal__header{display:flex;align-items:center;justify-content:space-between;padding:20px 24px 12px;border-bottom:1px solid var(--border-primary)}.settings-modal__title{font-family:Inter,system-ui,sans-serif;font-size:17px;font-weight:700;color:var(--text-primary);letter-spacing:-.01em;margin:0}.settings-modal__close{display:flex;align-items:center;justify-content:center;width:30px;height:30px;border-radius:8px;color:var(--text-secondary);transition:all .15s ease;background:transparent;border:none;cursor:pointer;padding:0}.settings-modal__close:hover{background:var(--bg-tertiary);color:var(--text-primary)}.settings-modal__close svg{width:16px;height:16px}.settings-modal__body{padding:0 24px;overflow-y:auto;flex:1;scrollbar-width:thin;scrollbar-color:var(--border-accent) transparent}.settings-modal__body::-webkit-scrollbar{width:6px}.settings-modal__body::-webkit-scrollbar-track{background:transparent}.settings-modal__body::-webkit-scrollbar-thumb{background-color:var(--border-primary);border-radius:3px}.settings-modal__body::-webkit-scrollbar-thumb:hover{background-color:var(--text-secondary)}.settings-section{padding:0;border-bottom:1px solid var(--border-primary)}.settings-section:last-child{border-bottom:none}.settings-section[open]{padding-bottom:12px}.settings-section__summary{display:flex;align-items:center;justify-content:space-between;padding:16px 0;cursor:pointer;list-style:none;-webkit-user-select:none;user-select:none;position:sticky;top:0;background:var(--bg-secondary);z-index:10}.settings-section__summary::-webkit-details-marker{display:none}.settings-section__title{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--accent-primary);margin:0;padding:0;border:none}.settings-section__icon{width:16px;height:16px;color:var(--text-secondary);transition:transform .2s ease}.settings-section[open] .settings-section__icon{transform:rotate(180deg)}.settings-section__content{animation:fadeIn .2s ease}@keyframes fadeIn{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}.settings-row{display:flex;align-items:center;justify-content:space-between;gap:16px;padding:12px 0;border-bottom:1px solid rgba(128,128,128,.06)}.settings-row:last-child{border-bottom:none}.settings-row__info{display:flex;flex-direction:column;gap:2px;flex:1}.settings-row__label{font-size:13px;font-weight:500;color:var(--text-primary)}.settings-row__hint{font-size:11px;color:var(--text-muted);line-height:1.35}.settings-row__control{display:flex;align-items:center;justify-content:flex-end;gap:12px;min-width:140px}.settings-row__value{font-family:JetBrains Mono,monospace;font-size:12px;font-weight:500;color:var(--text-accent);min-width:64px;text-align:right;white-space:nowrap;flex-shrink:0}.settings-slider{-webkit-appearance:none;appearance:none;flex:1;height:4px;border-radius:2px;background:var(--bg-tertiary);outline:none;transition:background .15s ease;cursor:pointer}.settings-slider::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;width:16px;height:16px;border-radius:50%;background:var(--accent-primary);border:2px solid var(--bg-secondary);box-shadow:0 1px 4px #00000040,var(--shadow-glow);cursor:pointer;transition:transform .12s ease,box-shadow .12s ease}.settings-slider::-webkit-slider-thumb:hover{transform:scale(1.15);box-shadow:0 2px 8px #0000004d,var(--shadow-glow)}.settings-slider::-webkit-slider-thumb:active{transform:scale(1.05)}.settings-slider::-moz-range-thumb{width:16px;height:16px;border-radius:50%;background:var(--accent-primary);border:2px solid var(--bg-secondary);box-shadow:0 1px 4px #00000040;cursor:pointer}.settings-slider-wrap{flex:1;display:flex;flex-direction:column;gap:0;position:relative}.settings-slider-wrap .settings-slider{flex:none;width:100%}.settings-slider-ticks{display:flex;justify-content:space-between;padding:3px 7px 0;pointer-events:none}.settings-slider-ticks span{width:2px;height:6px;border-radius:1px;background:var(--text-muted);opacity:.35}.settings-number-input{display:flex;align-items:center;gap:4px;background:var(--bg-tertiary);border:1px solid var(--border-primary);border-radius:8px;padding:5px 10px;transition:border-color .15s ease}.settings-number-input:focus-within{border-color:var(--accent-primary)}.settings-num-field{font-family:JetBrains Mono,monospace;font-size:13px;font-weight:500;color:var(--text-accent);background:transparent;border:none;outline:none;width:64px;text-align:center;appearance:textfield;-moz-appearance:textfield}.settings-num-field::-webkit-inner-spin-button,.settings-num-field::-webkit-outer-spin-button{-webkit-appearance:none;margin:0}.settings-num-unit{font-size:11px;color:var(--text-secondary);font-weight:500}.settings-modal__footer{display:flex;align-items:center;justify-content:space-between;padding:12px 24px 20px;border-top:1px solid var(--border-primary)}.settings-modal__footer-right{display:flex;align-items:center;gap:8px}.settings-btn{font-family:Inter,system-ui,sans-serif;font-size:13px;font-weight:500;border:none;border-radius:8px;padding:8px 18px;cursor:pointer;transition:all .15s ease;white-space:nowrap}.settings-btn--primary{background:var(--accent-primary);color:#fff;box-shadow:0 2px 8px #58a6ff40}.settings-btn--primary:hover{filter:brightness(1.1);box-shadow:0 4px 16px #58a6ff59;transform:translateY(-1px)}.settings-btn--primary:active{transform:translateY(0)}.settings-btn--secondary{background:transparent;color:var(--accent-warning);border:1px solid var(--border-primary)}.settings-btn--secondary:hover{background:var(--bg-tertiary);border-color:var(--accent-warning)}.settings-btn--ghost{background:transparent;color:var(--text-secondary)}.settings-btn--ghost:hover{background:var(--bg-tertiary);color:var(--text-primary)}.settings-toggle{display:inline-flex;align-items:center;cursor:pointer;position:relative}.settings-toggle input{position:absolute;opacity:0;width:0;height:0}.settings-toggle__track{display:flex;align-items:center;width:40px;height:22px;border-radius:11px;background:var(--bg-tertiary);border:1px solid var(--border-primary);transition:background .2s ease,border-color .2s ease;position:relative}.settings-toggle__thumb{position:absolute;left:3px;width:14px;height:14px;border-radius:50%;background:var(--text-muted);transition:left .2s ease,background .2s ease;box-shadow:0 1px 3px #0000004d}.settings-toggle input:checked+.settings-toggle__track{background:var(--accent-primary);border-color:var(--accent-primary)}.settings-toggle input:checked+.settings-toggle__track .settings-toggle__thumb{left:21px;background:#fff}:root{--landing-bg: #0a0e17;--landing-accent: #3b82f6;--landing-accent-glow: rgba(59, 130, 246, .4);--landing-card-bg: rgba(255, 255, 255, .03);--landing-card-border: rgba(255, 255, 255, .08);--landing-text-primary: #ffffff;--landing-text-secondary: #94a3b8}[data-theme=light]{--landing-bg: #f8fafc;--landing-accent: #2563eb;--landing-accent-glow: rgba(37, 99, 235, .2);--landing-card-bg: rgba(255, 255, 255, .7);--landing-card-border: rgba(0, 0, 0, .05);--landing-text-primary: #0f172a;--landing-text-secondary: #475569}#app:has(.landing-page){min-width:0;width:100%;max-width:100%;scrollbar-gutter:stable;overflow-x:hidden;overflow-y:auto;-webkit-overflow-scrolling:touch}.landing-page{background-color:var(--landing-bg);color:var(--landing-text-primary);min-height:100vh;font-family:Inter,sans-serif;overflow-x:hidden}.landing-header{position:fixed;top:0;left:0;width:100%;padding:1rem 2rem;display:flex;justify-content:space-between;align-items:center;z-index:100;background:#0a0e17cc;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border-bottom:1px solid var(--landing-card-border)}[data-theme=light] .landing-header{background:#f8fafccc}.landing-header .logo{font-weight:700;font-size:1.25rem;letter-spacing:-.02em;display:flex;align-items:center;gap:.5rem}.beta-badge{font-size:.65rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em;padding:2px 6px;border-radius:6px;background:#3b82f626;color:var(--landing-accent);border:1px solid rgba(59,130,246,.3);display:inline-flex;align-items:center}.support-unread-badge{position:absolute;top:-6px;right:-6px;background:#ef4444;color:#fff;border-radius:50%;min-width:20px;height:20px;font-size:.7rem;font-weight:700;display:flex;align-items:center;justify-content:center;padding:0 3px;box-sizing:border-box;visibility:hidden;opacity:0;transition:opacity .2s ease}.support-unread-badge.visible{visibility:visible;opacity:1}.dev-badge{font-size:.65rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em;padding:2px 6px;border-radius:6px;background:#f59e0b26;color:#f59e0b;border:1px solid rgba(245,158,11,.3);display:inline-flex;align-items:center}.ready-badge{font-size:.65rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em;padding:2px 6px;border-radius:6px;background:#10b98126;color:#10b981;border:1px solid rgba(16,185,129,.3);display:inline-flex;align-items:center}.landing-header nav,.landing-nav{display:flex;align-items:center;gap:1.5rem}.landing-header-right{display:none;align-items:center;gap:.25rem;flex-shrink:0}.theme-toggle-btn{display:flex;align-items:center;justify-content:center;width:38px;height:38px;border-radius:8px;background:transparent;border:none;cursor:pointer;color:var(--landing-text-secondary);transition:background .2s ease,color .2s ease;flex-shrink:0}.theme-toggle-btn:hover{background:var(--landing-card-bg);color:var(--landing-text-primary)}.theme-toggle-btn .theme-icon-light{display:none}.theme-toggle-btn .theme-icon-dark,[data-theme=light] .theme-toggle-btn .theme-icon-light{display:block}[data-theme=light] .theme-toggle-btn .theme-icon-dark{display:none}.landing-header nav a{color:var(--landing-text-secondary);text-decoration:none;font-size:.95rem;font-weight:500;transition:color .2s ease}.landing-header nav a:hover{color:var(--landing-text-primary)}.btn-primary-landing{background:var(--landing-accent);color:#fff;border:none;padding:.6rem 1.2rem;border-radius:8px;font-weight:600;cursor:pointer;transition:all .3s ease;box-shadow:0 4px 14px 0 var(--landing-accent-glow)}.btn-primary-landing:hover{transform:translateY(-1px);box-shadow:0 6px 20px 0 var(--landing-accent-glow)}.hero-section{padding:10rem 2rem 5rem;text-align:center;position:relative;max-width:1200px;margin:0 auto}.hero-glow{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:120vw;height:120vw;max-width:1200px;max-height:1200px;background:radial-gradient(circle,var(--landing-accent-glow) 0%,transparent 60%);z-index:0;pointer-events:none;opacity:.8}.hero-content{position:relative;z-index:1}.hero-title{font-size:clamp(2rem,8vw,4.5rem);font-weight:700;line-height:1.1;letter-spacing:-.03em;margin-bottom:1.5rem;background:linear-gradient(to right,var(--landing-text-primary),var(--landing-text-secondary));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;word-break:break-word}.hero-subtitle{font-size:clamp(1.1rem,2vw,1.25rem);color:var(--landing-text-secondary);max-width:800px;margin:0 auto 3rem;line-height:1.6}.hero-actions{display:flex;justify-content:center;gap:1rem;flex-wrap:wrap}.btn-secondary-landing{background:transparent;color:var(--landing-text-primary);border:1px solid var(--landing-card-border);padding:.6rem 1.2rem;border-radius:8px;font-weight:600;cursor:pointer;transition:all .2s ease}.btn-secondary-landing:hover{background:var(--landing-card-bg)}.hero-mockup-wrapper{margin-top:5rem;position:relative;z-index:2;border-radius:16px;padding:8px;background:linear-gradient(180deg,#ffffff1a,#fff0);box-shadow:0 25px 50px -12px #00000080}.hero-mockup-inner{aspect-ratio:16/9;background-color:var(--bg-card);border-radius:12px;border:1px solid var(--border-color);overflow:hidden;position:relative;display:flex;align-items:center;justify-content:center;color:var(--text-muted)}.hero-poster,.hero-video{position:absolute;top:0;left:0;width:100%;height:100%;object-fit:cover;object-position:top left;display:block}.hero-poster{z-index:1}.hero-video{z-index:2;opacity:0;transition:opacity 1.2s ease-in-out;pointer-events:none}.hero-video.video-loaded{opacity:1}.hero-caption{text-align:center;margin-top:.5rem;font-size:.9rem;color:var(--landing-text-secondary);font-weight:500;opacity:.4}.hamburger-btn{display:none;flex-direction:column;justify-content:space-around;width:44px;height:44px;background:transparent;border:none;cursor:pointer;padding:10px;border-radius:8px;transition:background .2s ease;flex-shrink:0}.hamburger-btn:hover{background:var(--landing-card-bg)}.hamburger-btn span{display:block;width:100%;height:2px;background:var(--landing-text-primary);border-radius:2px;transition:all .3s ease;transform-origin:center}.hamburger-btn.open span:nth-child(1){transform:translateY(7px) rotate(45deg)}.hamburger-btn.open span:nth-child(2){opacity:0;transform:scaleX(0)}.hamburger-btn.open span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}.mobile-nav-overlay{display:none;position:fixed;inset:0;background:#00000080;z-index:90;backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);opacity:0;pointer-events:none;transition:opacity .3s ease}.mobile-nav-overlay.open{opacity:1;pointer-events:auto}.mobile-nav-drawer{display:none;position:fixed;top:0;right:-100%;width:min(280px,85vw);height:100%;background:var(--landing-bg);border-left:1px solid var(--landing-card-border);z-index:95;padding:5rem 1.5rem 2rem;flex-direction:column;gap:.5rem;transition:right .35s cubic-bezier(.4,0,.2,1);box-shadow:-20px 0 60px #0000004d}[data-theme=light] .mobile-nav-drawer{background:#f8fafc}.mobile-nav-drawer.open{right:0}.mobile-nav-drawer a,.mobile-nav-drawer button{display:block;width:100%;padding:.875rem 1rem;font-size:1rem;font-weight:500;color:var(--landing-text-secondary);text-decoration:none;border-radius:10px;transition:all .2s ease;text-align:center;border:none;background:transparent;cursor:pointer;min-height:44px}.mobile-nav-drawer a:hover,.mobile-nav-drawer button:hover{color:var(--landing-text-primary);background:var(--landing-card-bg)}.mobile-nav-drawer .btn-primary-landing{margin-top:1rem;width:100%;text-align:center;display:block;min-height:48px;font-size:1rem}.mobile-nav-drawer .btn-secondary-landing{border:1px solid var(--landing-card-border);min-height:48px;font-size:1rem;text-align:center}@media(max-width:1024px){.testimonials-grid{grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:1.5rem}}@media(max-width:768px){.landing-header{padding:0;height:60px;display:flex;align-items:center;padding:0 1rem}.landing-header .logo{font-size:1.15rem}.landing-nav{display:none!important}.landing-header-right,.hamburger-btn,.mobile-nav-overlay,.mobile-nav-drawer{display:flex}.hero-section{padding:6rem 1.25rem 4rem}.hero-title{font-size:clamp(1.75rem,9vw,2.75rem);margin-bottom:1rem}.hero-subtitle{font-size:1rem;margin-bottom:2rem;padding:0 .25rem}.hero-actions{flex-direction:column;align-items:stretch;gap:.75rem}.hero-actions button,.hero-actions a{width:100%;min-height:48px;font-size:1rem;padding:.875rem 1.5rem;justify-content:center;display:flex;align-items:center}.hero-mockup-wrapper{margin-top:3rem;border-radius:12px}.features-section,.testimonials-section{padding:2rem 1.25rem}.roadmap-section{padding:2rem 1.25rem 4rem}.section-title{font-size:clamp(1.5rem,6vw,2rem);margin-bottom:1.25rem}.feature-card{padding:1.5rem}.feature-icon{width:52px;height:52px}.feature-card>.feature-icon{margin-bottom:1rem}.feature-card-head{gap:.75rem;margin-bottom:.85rem;align-items:flex-start}.feature-card h3{font-size:1.2rem}.testimonials-grid{grid-template-columns:1fr;gap:1rem}.testimonial-card{padding:1.5rem}.testimonial-text{font-size:1rem;margin-bottom:1.25rem}.roadmap-timeline{padding-left:1.5rem}.timeline-item{padding-left:1.75rem;padding-bottom:2rem}.timeline-dot{left:-1.85rem}.timeline-content h4{font-size:1.1rem}.auth-modal{margin:0 1rem;padding:2rem 1.5rem;max-width:calc(100vw - 2rem);border-radius:16px}.auth-modal-header h2{font-size:1.25rem;margin-bottom:1.5rem}}@media(max-width:480px){.landing-header{padding:0 .875rem}.landing-header .logo{font-size:1rem}.hero-section{padding:5.5rem 1rem 3rem}.hero-title{font-size:clamp(1.5rem,8vw,2.25rem)}.hero-subtitle{font-size:.95rem}.features-section,.testimonials-section{padding:2rem 1rem}.roadmap-section{padding:2rem 1rem 4rem}.section-title{font-size:clamp(1.35rem,5.5vw,1.75rem)}.feature-card,.testimonial-card{padding:1.25rem}.btn-primary-landing,.btn-secondary-landing{min-height:48px}}.landing-footer{display:flex;flex-wrap:wrap;gap:1rem;align-items:center;justify-content:space-between}@media(max-width:768px){.landing-footer{flex-direction:column;align-items:center;text-align:center;gap:1rem;padding:1.5rem 1.25rem calc(1.5rem + env(safe-area-inset-bottom,16px)) 1.25rem!important}.landing-footer .footer__copyright{display:flex;flex-direction:column;align-items:center;gap:2px;font-size:12px}.footer__copy-line{display:flex;align-items:center;gap:4px;white-space:nowrap}.landing-footer .footer__socials{justify-content:center;gap:16px}.landing-footer .footer__links{justify-content:center;flex-wrap:wrap;gap:12px}.landing-footer .footer__social{width:36px;height:36px;display:flex;align-items:center;justify-content:center}.landing-footer .footer__social svg{width:22px;height:22px}}.features-section{padding:3rem 2rem;background:var(--landing-bg)}.container{max-width:1200px;margin:0 auto}.section-title{font-size:2.5rem;font-weight:700;text-align:center;margin-bottom:4rem;background:linear-gradient(135deg,var(--landing-text-primary),var(--landing-text-secondary));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.features-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:1.5rem}@media(max-width:1024px){.features-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:1.25rem}}@media(max-width:640px){.features-grid{grid-template-columns:1fr;gap:.875rem}}.feature-card{background:var(--landing-card-bg);border:1px solid var(--landing-card-border);border-radius:16px;padding:2.5rem 2rem;transition:transform .3s ease,box-shadow .3s ease;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);box-shadow:var(--shadow-subtle)}.feature-card:hover{transform:translateY(-5px);box-shadow:0 10px 30px #0003;border-color:#ffffff26}.feature-card-head{display:flex;align-items:center;gap:1rem;margin-bottom:1rem}.feature-card-head h3{margin-bottom:0;flex:1;min-width:0}.feature-icon{width:64px;height:64px;border-radius:16px;flex-shrink:0;display:flex;align-items:center;justify-content:center;color:#fff}.feature-card>.feature-icon{margin-bottom:1.5rem}.bg-gradient-1{background:linear-gradient(135deg,#3b82f6,#8b5cf6)}.bg-gradient-2{background:linear-gradient(135deg,#10b981,#0ea5e9)}.bg-gradient-3{background:linear-gradient(135deg,#f59e0b,#ef4444)}.bg-gradient-4{background:linear-gradient(135deg,#a855f7,#ec4899)}.bg-gradient-star{background:linear-gradient(135deg,#f59e0b,#fbbf24,#f97316)}.feature-card--star{border-color:#fbbf244d;background:linear-gradient(145deg,rgba(245,158,11,.07) 0%,var(--landing-card-bg) 60%);position:relative;overflow:hidden}.feature-card--star:before{content:"";position:absolute;inset:0;border-radius:inherit;border:1px solid rgba(251,191,36,.25);pointer-events:none}.feature-card--star:hover{border-color:#fbbf248c;box-shadow:0 10px 40px #f59e0b2e}.feature-card--blue{border-color:#3b82f640;background:linear-gradient(145deg,rgba(59,130,246,.07) 0%,var(--landing-card-bg) 60%)}.feature-card--blue:hover{border-color:#3b82f680;box-shadow:0 10px 40px #3b82f626}.feature-card--green{border-color:#10b98140;background:linear-gradient(145deg,rgba(16,185,129,.07) 0%,var(--landing-card-bg) 60%)}.feature-card--green:hover{border-color:#10b98180;box-shadow:0 10px 40px #10b98126}.feature-card--amber{border-color:#f59e0b40;background:linear-gradient(145deg,rgba(245,158,11,.07) 0%,var(--landing-card-bg) 60%)}.feature-card--amber:hover{border-color:#f59e0b80;box-shadow:0 10px 40px #f59e0b24}.feature-card h3{font-size:1.5rem;margin-bottom:1rem;font-weight:600}.feature-card p{color:var(--landing-text-secondary);line-height:1.6}.testimonials-section{padding:6rem 2rem;background:linear-gradient(to bottom,var(--landing-bg),rgba(59,130,246,.05))}.testimonials-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(350px,1fr));gap:2rem}.testimonial-card{background:var(--landing-card-bg);border:1px solid var(--landing-card-border);border-radius:20px;padding:2.5rem;transition:transform .3s ease,box-shadow .3s ease;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);box-shadow:var(--shadow-subtle)}.testimonial-card:hover{transform:translateY(-5px);box-shadow:0 10px 30px #0003;border-color:#ffffff26}.testimonial-text{font-size:1.1rem;font-style:italic;line-height:1.7;margin-bottom:2rem;color:var(--landing-text-primary)}.testimonial-author{display:flex;align-items:center;gap:1rem}.author-avatar{width:50px;height:50px;border-radius:50%;background:#333}.testimonial-author h4{margin:0;font-size:1rem;font-weight:600}.testimonial-author p{margin:0;font-size:.85rem;color:var(--landing-text-secondary)}.roadmap-section{padding:6rem 2rem 10rem;background:var(--landing-bg)}.roadmap-timeline{max-width:800px;margin:0 auto;position:relative;padding-left:2rem}.roadmap-timeline:before{content:"";position:absolute;left:0;top:0;height:100%;width:2px;background:var(--landing-card-border)}.timeline-item{position:relative;padding-bottom:3rem;padding-left:2.5rem}.timeline-item:last-child{padding-bottom:0}.timeline-dot{position:absolute;left:-2.35rem;top:5px;width:16px;height:16px;border-radius:50%;background:var(--landing-bg);border:3px solid var(--landing-text-secondary);transition:all .3s ease}.timeline-item.active .timeline-dot{border-color:var(--landing-accent);background:var(--landing-accent);box-shadow:0 0 15px var(--landing-accent-glow)}.timeline-content h4{font-size:1.25rem;margin-bottom:.5rem;color:var(--landing-text-primary)}.timeline-item.active .timeline-content h4{color:var(--landing-accent)}.timeline-content p{color:var(--landing-text-secondary);line-height:1.5}.auth-modal-overlay{position:fixed;inset:0;background:#000000bf;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center;z-index:1000;opacity:1;visibility:visible;transition:opacity .3s ease,visibility .3s ease}.auth-modal-overlay.hidden{opacity:0;visibility:hidden}.auth-modal{background:var(--bg-secondary);border:1px solid var(--border-primary);border-radius:16px;padding:2.5rem;width:100%;max-width:420px;position:relative;box-shadow:0 25px 50px -12px #00000080;transform:translateY(0);transition:transform .3s ease}.auth-modal-overlay.hidden .auth-modal{transform:translateY(20px)}.auth-close-btn{position:absolute;top:1rem;right:1.25rem;background:none;border:none;color:var(--text-muted);font-size:1.5rem;cursor:pointer;padding:.25rem;transition:color .2s ease}.auth-close-btn:hover{color:var(--text-primary)}.auth-modal-header h2{font-size:1.5rem;font-weight:700;margin-bottom:2rem;color:var(--text-primary);text-align:center}.auth-form .form-group{margin-bottom:1.5rem}.auth-form label{display:block;font-size:.85rem;font-weight:500;margin-bottom:.5rem;color:var(--text-secondary)}.auth-form input{width:100%;background:var(--bg-tertiary);border:1px solid var(--border-primary);color:var(--text-primary);padding:.75rem 1rem;border-radius:8px;font-family:Inter,sans-serif;font-size:16px;transition:border-color .2s ease,box-shadow .2s ease}.auth-form input:focus{outline:none;border-color:var(--accent-primary);box-shadow:0 0 0 3px #58a6ff26}.auth-otp-spam-hint{margin:.5rem 0 0;font-size:.8rem;line-height:1.4;color:var(--landing-text-secondary, var(--text-secondary));text-align:center}.auth-otp-input::placeholder{color:var(--landing-text-secondary, var(--text-secondary));opacity:.55;letter-spacing:.28rem;font-weight:600}.auth-submit-btn{width:100%;margin-top:1rem;padding:.85rem;font-size:1rem}.auth-submit-btn:disabled{opacity:.7;cursor:not-allowed}.auth-switch{margin-top:1.5rem;text-align:center}.auth-follow-us{display:flex;align-items:center;justify-content:center;gap:.75rem;margin-top:1.25rem;padding-top:1.25rem;border-top:1px solid var(--landing-card-border)}.auth-follow-label{font-size:.8rem;color:var(--landing-text-secondary);white-space:nowrap}.auth-social-links{display:flex;gap:.5rem;align-items:center}.auth-social-link{display:flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:8px;background:#ffffff0d;border:1px solid var(--landing-card-border);color:var(--landing-text-secondary);text-decoration:none;transition:background .2s,color .2s,border-color .2s}.auth-social-link:hover{background:#ffffff1a;color:var(--landing-text-primary);border-color:#fff3}.text-btn{background:none;border:none;color:var(--text-accent);font-size:.85rem;cursor:pointer;transition:color .2s ease}.text-btn:hover{text-decoration:underline}.auth-error{background:#ef44441a;color:#ef4444;padding:.75rem;border-radius:8px;font-size:.85rem;margin-bottom:1.5rem;text-align:center;border:1px solid rgba(239,68,68,.2)}.auth-error.hidden{display:none}.landing-footer .footer__copyright,.landing-footer .footer__socials-label,.landing-footer .footer__link{font-size:14px}.landing-footer .footer__social svg{width:20px;height:20px}@media(max-width:768px){.landing-footer .footer__copyright{white-space:normal;font-size:13px;color:var(--landing-text-secondary);order:1}.landing-footer .footer__socials{order:3}.landing-footer .footer__links{order:2}}@media(max-width:768px){.features-section,.testimonials-section{padding:1.5rem 1.25rem}.roadmap-section{padding:1.5rem 1.25rem 3.5rem}.section-title{margin-bottom:1.75rem}}@media(max-width:480px){.features-section,.testimonials-section{padding:1.25rem 1rem}.roadmap-section{padding:1.25rem 1rem 3rem}.section-title{margin-bottom:1.5rem}}@media(max-width:768px){.roadmap-timeline{padding-left:3.5rem}.timeline-dot{left:-2.1rem}}@media(max-width:480px){.roadmap-timeline{padding-left:3rem}}@media(max-width:768px){.hero-actions{align-items:center}.hero-actions button,.hero-actions a{width:70%;min-width:200px}}@keyframes timeline-pulse{0%,to{box-shadow:0 0 0 0 var(--landing-accent-glow);border-color:var(--landing-accent);background:var(--landing-bg)}50%{box-shadow:0 0 0 6px transparent;border-color:var(--landing-accent);background:#3b82f640}}.timeline-dot--pulse{border-color:var(--landing-accent);animation:timeline-pulse 2s ease-in-out infinite}.timeline-dot--infinity{width:24px;height:24px;left:-2.55rem;background:linear-gradient(135deg,#a855f7,#3b82f6,#10b981);border-color:transparent;color:#fff;font-size:13px;font-weight:700;line-height:1;display:flex;align-items:center;justify-content:center;box-shadow:0 0 18px #a855f773}.timeline-item--infinity .timeline-content p{font-style:italic}.timeline-infinity-title{background:linear-gradient(90deg,#a855f7,#3b82f6,#10b981);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.timeline-dot--check{background:#10b981;border-color:#10b981;box-shadow:0 0 12px #10b98173}.timeline-dot--check:after{content:"✓";position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);font-size:10px;font-weight:700;color:#fff;line-height:1}.profile-page-root{min-height:100vh;display:flex;flex-direction:column}.profile-main{flex:1;margin-top:100px;padding:1rem 1.5rem 3rem}.profile-welcome-section{display:flex;justify-content:space-between;align-items:center;margin-bottom:2.5rem;flex-wrap:wrap;gap:1.5rem}.profile-welcome-info{display:flex;align-items:center;gap:1.25rem}.profile-avatar{width:56px;height:56px;border-radius:50%;background:linear-gradient(135deg,var(--landing-accent),#a855f7);display:flex;align-items:center;justify-content:center;flex-shrink:0;overflow:hidden;font-size:1.4rem;font-weight:700;color:#fff}.profile-avatar img{width:100%;height:100%;object-fit:cover}.ps-avatar-preview-wrap{width:64px;height:64px;border-radius:50%;overflow:hidden;box-sizing:border-box;border:2px solid var(--border-primary);display:flex;align-items:center;justify-content:center;flex-shrink:0}.ps-avatar-preview-wrap--photo{background:var(--bg-tertiary)}.profile-avatar.ps-avatar-preview-wrap{font-size:1.55rem}.profile-welcome-title{font-size:clamp(1.5rem,5vw,2rem);margin:0 0 .25rem;color:var(--landing-text-primary)}.profile-welcome-sub{color:var(--landing-text-secondary);margin:0;font-size:clamp(.9rem,3vw,1rem)}.profile-welcome-actions{display:flex;gap:.75rem;flex-wrap:wrap}.profile-nav-btn{display:flex;align-items:center;gap:.5rem;padding:.5rem 1rem}.profile-features-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:2rem}@media(max-width:1023px){.profile-features-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}.profile-feature-card{display:flex;flex-direction:column;height:100%;position:relative}.online-badge{position:absolute;top:1rem;right:1rem;display:flex;align-items:center;gap:5px;padding:3px 10px 3px 8px;background:#ffffff0f;border:1px solid rgba(255,255,255,.1);border-radius:20px;font-size:.78rem;font-weight:500;color:var(--landing-text-secondary);line-height:1;-webkit-user-select:none;user-select:none}[data-theme=light] .online-badge{background:#0000000a;border-color:#0000001a}.online-badge--live{background:linear-gradient(135deg,#22c55e2e,#34d3991a);border:1px solid rgba(74,222,128,.42);color:#bbf7d0;box-shadow:0 0 0 1px #22c55e0f inset,0 2px 14px #22c55e1f}[data-theme=light] .online-badge--live{background:linear-gradient(135deg,#16a34a24,#22c55e14);border-color:#16a34a61;color:#166534;box-shadow:0 0 0 1px #16a34a0f inset,0 2px 12px #16a34a1a}.profile-card-header{display:flex;align-items:flex-start;gap:1.25rem;margin-bottom:1.5rem}.profile-card-header .feature-icon{margin-bottom:0;flex-shrink:0;width:56px;height:56px}.profile-card-title-block{display:flex;flex-direction:column;align-items:flex-start;gap:.5rem;min-width:0;flex:1;align-self:center}.profile-card-title-block:has(.beta-badge),.profile-card-title-block:has(.dev-badge){align-self:flex-start}.profile-card-header h3{margin-bottom:0;font-size:1.4rem;line-height:1.2}.profile-card-title-block .beta-badge,.profile-card-title-block .dev-badge{flex-shrink:0}.profile-card-desc{flex:1;margin-bottom:2rem}.profile-card-disabled{opacity:.7}.profile-rejected-banner{display:flex;align-items:flex-start;gap:.5rem;background:#ef44441a;border:1px solid rgba(239,68,68,.3);border-radius:8px;padding:.75rem 1rem;margin-bottom:1rem;font-size:.9rem;color:var(--accent-danger, #ef4444);line-height:1.5}.profile-rejected-banner svg{flex-shrink:0;margin-top:2px}.profile-settings-overlay{position:fixed;inset:0;background:#0009;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);z-index:2000;display:flex;align-items:center;justify-content:center;padding:1rem}.profile-settings-modal{background:var(--bg-panel);border:1px solid var(--border-primary);border-radius:16px;width:100%;max-width:860px;max-height:90vh;display:flex;flex-direction:column;overflow:hidden;position:relative;box-shadow:var(--shadow-medium);color:var(--text-primary)}.profile-settings-header{padding:1.5rem 2rem;border-bottom:1px solid var(--border-primary);display:flex;justify-content:space-between;align-items:center;background:var(--bg-tertiary)}.profile-settings-header h2{margin:0;font-size:1.4rem;color:var(--text-primary)}.profile-settings-close{background:none;border:none;color:var(--text-secondary);cursor:pointer;padding:.5rem;transition:color .2s}.profile-settings-close:hover{color:var(--accent-danger)}.profile-settings-main{display:flex;flex:1;overflow:hidden}.profile-settings-sidebar{width:180px;flex-shrink:0;border-right:1px solid var(--border-primary);padding:1rem 0;display:flex;flex-direction:column;gap:.5rem;background:var(--bg-secondary);overflow-y:auto}.profile-settings-tab{background:none;border:none;border-left:3px solid transparent;padding:.75rem 1.5rem;text-align:left;color:var(--text-secondary);cursor:pointer;font-size:.95rem;transition:all .2s ease;width:100%;box-sizing:border-box}.profile-settings-tab:hover{color:var(--text-primary);background:var(--bg-tertiary)}.profile-settings-tab.active{color:var(--accent-primary);border-left-color:var(--accent-primary);font-weight:500;background:var(--bg-tertiary)}.profile-settings-body{flex:1;overflow-y:auto;padding:1.5rem 2rem 0rem;background:var(--bg-secondary);min-width:0;touch-action:manipulation;-webkit-overflow-scrolling:touch}.ps-form-group{margin-bottom:1.25rem}.ps-form-group label{display:block;font-size:.85rem;color:var(--text-secondary);margin-bottom:.35rem;font-weight:500}.ps-fest-dates-row{display:grid;grid-template-columns:1fr 1fr;gap:.75rem;margin-bottom:1.25rem}.ps-fest-dates-row .ps-form-group{margin-bottom:0}@media(max-width:520px){.ps-fest-dates-row{grid-template-columns:1fr}}.ps-combobox{position:relative;width:100%;z-index:1}.ps-combobox.ps-combobox--open{z-index:40}.ps-combobox .ps-input{width:100%}.ps-combobox-dropdown{position:absolute;left:0;right:0;top:calc(100% + 4px);width:100%;box-sizing:border-box;margin:0;padding:.3rem 0;max-height:200px;overflow-y:auto;-webkit-overflow-scrolling:touch;background:var(--bg-tertiary);border:1px solid var(--border-primary);border-radius:10px;box-shadow:0 16px 48px #0000008c}.ps-combobox-dropdown--hidden{display:none!important}.ps-combobox-item{display:block;width:100%;text-align:left;padding:.5rem .9rem;border:none;background:transparent;color:var(--text-primary);font-size:.92rem;line-height:1.35;cursor:pointer;font-family:inherit}.ps-combobox-item:hover,.ps-combobox-item.ps-combobox-item--active{background:#58a6ff24;color:var(--accent-primary)}.ps-combobox-more{padding:.4rem .9rem .35rem;font-size:.72rem;line-height:1.35;color:var(--text-secondary);border-top:1px solid var(--border-primary);margin-top:.2rem}.ps-combobox-empty{padding:.65rem .9rem;font-size:.85rem;line-height:1.4;color:var(--text-secondary)}.ps-input,.ps-select,.ps-textarea{width:100%;background:var(--bg-tertiary);border:1px solid var(--border-primary);border-radius:8px;padding:.65rem .85rem;color:var(--text-primary);font-size:.95rem;font-family:inherit;outline:none;transition:border-color .2s}.ps-input::placeholder,.ps-textarea::placeholder{color:var(--text-muted)}.ps-input:focus,.ps-select:focus,.ps-textarea:focus{border-color:var(--accent-primary)}.ps-textarea{resize:vertical;min-height:80px}.ps-toggle{position:relative;width:44px;height:24px;background:var(--border-primary);border-radius:12px;cursor:pointer;transition:background .2s;border:none;flex-shrink:0;-webkit-tap-highlight-color:transparent}.ps-toggle:focus{outline:none}.ps-toggle:focus-visible{outline:2px solid var(--accent-primary);outline-offset:2px}.ps-toggle.active{background:var(--accent-primary)}.ps-toggle:after{content:"";position:absolute;top:2px;left:2px;width:20px;height:20px;background:#fff;border-radius:50%;transition:transform .2s}.ps-toggle.active:after{transform:translate(20px)}.ps-footer{padding:1rem 2rem;border-top:1px solid var(--border-primary);display:flex;flex-direction:column;align-items:stretch;gap:.75rem;background:var(--bg-secondary)}.ps-footer-buttons{display:flex;justify-content:flex-end;gap:.75rem;flex-wrap:wrap}.ps-save-error{display:none;padding:.65rem .9rem;border-radius:8px;font-size:.875rem;line-height:1.45;color:var(--text-primary);background:color-mix(in srgb,var(--accent-danger, #ef4444) 14%,var(--bg-tertiary, #1a1d24));border:1px solid color-mix(in srgb,var(--accent-danger, #ef4444) 40%,transparent)}.ps-footer-btn{padding:.5rem 1.25rem}.ps-lang-select{display:flex;align-items:center;gap:.5rem}.ps-lang-flag{font-size:1.25rem;line-height:1}.ps-subscription-block{margin-top:1.5rem;margin-bottom:1rem;padding:1rem 1.25rem;border-radius:10px;background:var(--bg-tertiary);border:1px solid var(--border-primary)}.ps-sub-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:.5rem}.ps-sub-label{font-size:.85rem;font-weight:600;color:var(--text-primary)}.ps-sub-badge{font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em;padding:2px 8px;border-radius:20px}.ps-sub-badge--free{background:#94a3b826;color:#94a3b8;border:1px solid rgba(148,163,184,.3)}.ps-sub-badge--beta_tester{background:#58a6ff26;color:var(--accent-primary);border:1px solid rgba(88,166,255,.3)}.ps-sub-badge--pro,.ps-sub-badge--premium{background:#7c5cfc26;color:#7c5cfc;border:1px solid rgba(124,92,252,.3)}.ps-sub-desc{font-size:.82rem;color:var(--text-secondary);margin:0 0 .5rem;line-height:1.5}.ps-sub-meta{display:flex;gap:.4rem;font-size:.78rem;color:var(--text-secondary)}.ps-world-container{display:flex;flex-direction:column;height:100%}.ps-world-scroll{flex:1;overflow-y:auto;padding-top:.5rem}.ps-marker-preview-sticky{position:sticky;top:0;z-index:10;background:var(--bg-secondary);border-bottom:1px solid var(--border-primary);padding:.75rem 0;margin-bottom:1rem}.ps-map-preview-caption{font-size:.72rem;font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:var(--text-secondary);text-align:center;margin:.5rem 0 .65rem}.ps-profile-popup-preview-host{display:flex;justify-content:center;padding:0 0 .25rem;pointer-events:none}.user-profile-popup.user-profile-popup--settings-preview{position:relative!important;inset:auto!important;transform:none!important;width:340px;max-width:100%;margin:0 auto;animation:none!important;z-index:1;box-sizing:border-box;backdrop-filter:none!important;-webkit-backdrop-filter:none!important}.user-profile-popup.user-profile-popup--settings-preview:before,.user-profile-popup.user-profile-popup--settings-preview:after{display:none!important;content:none!important}.ps-marker-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:.5rem;margin-top:.35rem}.ps-marker-card{display:flex;flex-direction:column;align-items:center;gap:.35rem;padding:.65rem .35rem;border-radius:10px;border:1px solid var(--border-primary);background:var(--bg-tertiary);cursor:pointer;transition:all .2s;-webkit-tap-highlight-color:transparent}.ps-marker-card:focus{outline:none}.ps-marker-card:focus-visible{outline:2px solid var(--accent-primary);outline-offset:2px}@media(hover:hover)and (pointer:fine){.ps-marker-card:hover{border-color:var(--accent-primary);background:var(--bg-panel)}}.ps-marker-card.active{border-color:var(--accent-primary);background:#58a6ff14;box-shadow:0 0 0 2px #58a6ff40}.ps-marker-card .zen-marker{transition:none}.ps-marker-card .zen-marker:hover{transform:none;z-index:auto}.ps-marker-card .zen-marker svg{width:16px;height:16px;color:#fff}.ps-marker-card-label{font-size:.7rem;font-weight:500;color:var(--text-secondary);text-align:center;line-height:1.2}.ps-marker-card.active .ps-marker-card-label{color:var(--accent-primary)}.ps-marker-card--disabled{opacity:.4;cursor:not-allowed;pointer-events:none}.ps-marker-preview-bottom{border-top:1px solid var(--border-primary);padding-top:1.25rem;margin-top:.5rem}.ps-moderation-notice{margin-top:.65rem;padding:.65rem .85rem;border-radius:8px;font-size:.82rem;line-height:1.5}.ps-moderation-warn{background:#f59e0b1a;border:1px solid rgba(245,158,11,.3);color:var(--accent-warning, #f59e0b);margin-bottom:1rem}.ps-moderation-pending{background:#58a6ff1a;border:1px solid rgba(88,166,255,.3);color:var(--accent-primary)}.ps-moderation-rejected{background:#ef44441a;border:1px solid rgba(239,68,68,.3);color:var(--accent-danger, #ef4444)}.ps-moderation-approved{background:#10b9811a;border:1px solid rgba(16,185,129,.3);color:var(--text-primary)}.ps-required{color:var(--accent-danger, #ef4444);font-weight:700}.ps-hint{font-size:.78rem;color:var(--text-secondary);margin-top:.25rem;line-height:1.4}.ps-toggle-row{display:flex;align-items:center;justify-content:space-between;padding:.75rem 0}.ps-char-counter{text-align:right;font-size:.75rem;color:var(--text-muted);margin-top:.25rem}.ps-char-counter.ps-char-danger{color:var(--accent-danger, #ef4444);font-weight:600}.ps-instrument-row{display:flex;gap:.4rem;align-items:center;margin-bottom:.5rem;flex-wrap:wrap}.ps-instrument-row .ps-select,.ps-instrument-row .ps-input{flex:1;min-width:0;padding:.5rem .6rem;font-size:.85rem}.ps-instrument-row .ps-inst-notes{text-align:center;-moz-appearance:textfield;-webkit-appearance:none;appearance:textfield}.ps-instrument-row .ps-inst-notes::-webkit-inner-spin-button,.ps-instrument-row .ps-inst-notes::-webkit-outer-spin-button{-webkit-appearance:none;margin:0}.ps-inst-label{font-size:.68rem;color:var(--text-secondary);text-align:center}.ps-inst-remove{background:none;border:1px solid var(--accent-danger, #ef4444);color:var(--accent-danger, #ef4444);border-radius:6px;width:28px;height:28px;cursor:pointer;font-size:1rem;display:flex;align-items:center;justify-content:center;transition:.2s;flex-shrink:0}.ps-inst-remove:hover{background:var(--accent-danger, #ef4444);color:#fff}.ps-add-instrument{width:100%;padding:.5rem;font-size:.85rem;margin-top:.35rem}.ps-add-instrument:disabled{opacity:.5;cursor:not-allowed}.ps-minimap-wrapper{position:relative;margin:.75rem 0;border-radius:10px;overflow:hidden;border:1px solid var(--border-primary)}.ps-minimap{width:100%;height:200px}.ps-minimap-crosshair{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);font-size:1.5rem;font-weight:700;color:var(--accent-danger, #ef4444);z-index:1000;pointer-events:none;text-shadow:0 0 6px rgba(0,0,0,.5);line-height:1}.ps-minimap-lock{position:absolute;inset:0;z-index:1001;display:flex;align-items:center;justify-content:center;background:#00000073;color:#fff;font-size:.85rem;font-weight:500;cursor:pointer;text-shadow:0 1px 4px rgba(0,0,0,.6);transition:background .2s;user-select:none;-webkit-user-select:none;padding:0 1rem;text-align:center}.ps-minimap-lock:hover{background:#0000004d}.ps-social-input-wrap{display:flex;align-items:center;background:var(--bg-tertiary);border:1px solid var(--border-primary);border-radius:8px;overflow:hidden;transition:border-color .2s}.ps-social-input-wrap:focus-within{border-color:var(--accent-primary)}.ps-social-prefix{padding:.65rem 0 .65rem .85rem;font-size:.82rem;color:var(--text-muted);white-space:nowrap;-webkit-user-select:none;user-select:none;flex-shrink:0}.ps-social-input{border:none!important;background:transparent!important;padding-left:0!important;flex:1}.ps-social-input:focus{border-color:transparent!important}.ps-under-dev{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:3rem 1rem;gap:.75rem;color:var(--text-secondary);text-align:center}.ps-under-dev span{font-size:2.5rem}.ps-under-dev p{font-size:.95rem;margin:0}.ps-service-cards{display:flex;gap:.5rem;flex-wrap:wrap;margin-top:.35rem}.ps-service-card{display:flex;align-items:center;gap:.5rem;padding:.55rem .85rem;border-radius:8px;background:var(--bg-tertiary);border:1px solid var(--border-primary);font-size:.85rem;color:var(--text-primary)}.ps-service-icon{font-size:1.1rem}.ps-service-name{font-weight:500}.ps-confirm-dialog{background:var(--bg-panel);border:1px solid var(--border-primary);border-radius:14px;padding:2rem;max-width:400px;text-align:center;box-shadow:var(--shadow-medium);color:var(--text-primary)}.ps-confirm-dialog h3{margin:0 0 .5rem;font-size:1.15rem}.ps-confirm-dialog p{font-size:.88rem;color:var(--text-secondary);margin:0 0 1.5rem;line-height:1.5}.ps-confirm-actions{display:flex;gap:.75rem;justify-content:center}.ps-contacts-spoiler{margin-top:1rem;border-radius:8px;border:1px solid var(--border-primary);overflow:hidden}.ps-contacts-summary{padding:.75rem 1rem;cursor:pointer;font-size:.875rem;font-weight:600;color:var(--text-secondary);list-style:none;display:flex;align-items:center;gap:.4rem;-webkit-user-select:none;user-select:none;background:var(--bg-tertiary);transition:background .15s}.ps-contacts-summary:hover{background:var(--bg-panel)}.ps-contacts-summary:before{content:"▶";font-size:.6rem;transition:transform .2s;display:inline-block}details[open] .ps-contacts-summary:before{transform:rotate(90deg)}.ps-contacts-body{padding:.75rem 1rem .5rem;background:var(--bg-secondary)}@media(max-width:768px){.profile-main{margin-top:80px;padding:1rem 1rem 2rem}.profile-welcome-section{flex-direction:column;align-items:flex-start}.ps-marker-grid{grid-template-columns:repeat(3,1fr)}}@media(max-width:640px){.profile-features-grid{grid-template-columns:1fr}.profile-settings-overlay{padding:max(12px,env(safe-area-inset-top,0px)) .75rem max(12px,env(safe-area-inset-bottom,0px));align-items:center;justify-content:center}.profile-settings-modal{border-radius:16px;width:100%;height:min(82vh,calc(100vh - 2rem));max-height:min(82vh,calc(100vh - 2rem));min-height:0}.profile-settings-header{padding:.65rem 1rem;flex-shrink:0}.profile-settings-header h2{font-size:1.1rem;line-height:1.25}.profile-settings-close{padding:.35rem}.profile-settings-main{flex-direction:column;flex:1;min-height:0}.profile-settings-sidebar{width:100%;flex-direction:row;flex-shrink:0;border-right:none;border-bottom:1px solid var(--border-primary);padding:0;gap:0;overflow-y:visible;overflow-x:auto}.profile-settings-tab{flex:1;text-align:center;padding:.5rem .35rem;border-left:none;border-bottom:2px solid transparent;font-size:.82rem;white-space:nowrap}.profile-settings-tab.active{border-left-color:transparent;border-bottom-color:var(--accent-primary)}.profile-settings-body{padding:1rem 1rem 1.25rem;flex:1;min-height:0}.ps-footer{padding:.55rem 1rem;flex-shrink:0;gap:.5rem}.ps-footer-buttons{justify-content:center}.ps-footer-btn{padding:.4rem 1rem;font-size:.875rem;min-width:auto}.ps-marker-grid{grid-template-columns:repeat(2,1fr)}.ps-instrument-row{flex-wrap:wrap}.ps-instrument-row .ps-select{min-width:calc(50% - .4rem)}.profile-settings-body .ps-input,.profile-settings-body .ps-select,.profile-settings-body .ps-textarea,.profile-settings-body .ps-social-input{font-size:16px}}.leaflet-pane,.leaflet-tile,.leaflet-marker-icon,.leaflet-marker-shadow,.leaflet-tile-container,.leaflet-pane>svg,.leaflet-pane>canvas,.leaflet-zoom-box,.leaflet-image-layer,.leaflet-layer{position:absolute;left:0;top:0}.leaflet-container{overflow:hidden}.leaflet-tile,.leaflet-marker-icon,.leaflet-marker-shadow{-webkit-user-select:none;-moz-user-select:none;user-select:none;-webkit-user-drag:none}.leaflet-tile::selection{background:transparent}.leaflet-safari .leaflet-tile{image-rendering:-webkit-optimize-contrast}.leaflet-safari .leaflet-tile-container{width:1600px;height:1600px;-webkit-transform-origin:0 0}.leaflet-marker-icon,.leaflet-marker-shadow{display:block}.leaflet-container .leaflet-overlay-pane svg{max-width:none!important;max-height:none!important}.leaflet-container .leaflet-marker-pane img,.leaflet-container .leaflet-shadow-pane img,.leaflet-container .leaflet-tile-pane img,.leaflet-container img.leaflet-image-layer,.leaflet-container .leaflet-tile{max-width:none!important;max-height:none!important;width:auto;padding:0}.leaflet-container img.leaflet-tile{mix-blend-mode:plus-lighter}.leaflet-container.leaflet-touch-zoom{-ms-touch-action:pan-x pan-y;touch-action:pan-x pan-y}.leaflet-container.leaflet-touch-drag{-ms-touch-action:pinch-zoom;touch-action:none;touch-action:pinch-zoom}.leaflet-container.leaflet-touch-drag.leaflet-touch-zoom{-ms-touch-action:none;touch-action:none}.leaflet-container{-webkit-tap-highlight-color:transparent}.leaflet-container a{-webkit-tap-highlight-color:rgba(51,181,229,.4)}.leaflet-tile{filter:inherit;visibility:hidden}.leaflet-tile-loaded{visibility:inherit}.leaflet-zoom-box{width:0;height:0;-moz-box-sizing:border-box;box-sizing:border-box;z-index:800}.leaflet-overlay-pane svg{-moz-user-select:none}.leaflet-pane{z-index:400}.leaflet-tile-pane{z-index:200}.leaflet-overlay-pane{z-index:400}.leaflet-shadow-pane{z-index:500}.leaflet-marker-pane{z-index:600}.leaflet-tooltip-pane{z-index:650}.leaflet-popup-pane{z-index:700}.leaflet-map-pane canvas{z-index:100}.leaflet-map-pane svg{z-index:200}.leaflet-vml-shape{width:1px;height:1px}.lvml{behavior:url(#default#VML);display:inline-block;position:absolute}.leaflet-control{position:relative;z-index:800;pointer-events:visiblePainted;pointer-events:auto}.leaflet-top,.leaflet-bottom{position:absolute;z-index:1000;pointer-events:none}.leaflet-top{top:0}.leaflet-right{right:0}.leaflet-bottom{bottom:0}.leaflet-left{left:0}.leaflet-control{float:left;clear:both}.leaflet-right .leaflet-control{float:right}.leaflet-top .leaflet-control{margin-top:10px}.leaflet-bottom .leaflet-control{margin-bottom:10px}.leaflet-left .leaflet-control{margin-left:10px}.leaflet-right .leaflet-control{margin-right:10px}.leaflet-fade-anim .leaflet-popup{opacity:0;-webkit-transition:opacity .2s linear;-moz-transition:opacity .2s linear;transition:opacity .2s linear}.leaflet-fade-anim .leaflet-map-pane .leaflet-popup{opacity:1}.leaflet-zoom-animated{-webkit-transform-origin:0 0;-ms-transform-origin:0 0;transform-origin:0 0}svg.leaflet-zoom-animated{will-change:transform}.leaflet-zoom-anim .leaflet-zoom-animated{-webkit-transition:-webkit-transform .25s cubic-bezier(0,0,.25,1);-moz-transition:-moz-transform .25s cubic-bezier(0,0,.25,1);transition:transform .25s cubic-bezier(0,0,.25,1)}.leaflet-zoom-anim .leaflet-tile,.leaflet-pan-anim .leaflet-tile{-webkit-transition:none;-moz-transition:none;transition:none}.leaflet-zoom-anim .leaflet-zoom-hide{visibility:hidden}.leaflet-interactive{cursor:pointer}.leaflet-grab{cursor:-webkit-grab;cursor:-moz-grab;cursor:grab}.leaflet-crosshair,.leaflet-crosshair .leaflet-interactive{cursor:crosshair}.leaflet-popup-pane,.leaflet-control{cursor:auto}.leaflet-dragging .leaflet-grab,.leaflet-dragging .leaflet-grab .leaflet-interactive,.leaflet-dragging .leaflet-marker-draggable{cursor:move;cursor:-webkit-grabbing;cursor:-moz-grabbing;cursor:grabbing}.leaflet-marker-icon,.leaflet-marker-shadow,.leaflet-image-layer,.leaflet-pane>svg path,.leaflet-tile-container{pointer-events:none}.leaflet-marker-icon.leaflet-interactive,.leaflet-image-layer.leaflet-interactive,.leaflet-pane>svg path.leaflet-interactive,svg.leaflet-image-layer.leaflet-interactive path{pointer-events:visiblePainted;pointer-events:auto}.leaflet-container{background:#ddd;outline-offset:1px}.leaflet-container a{color:#0078a8}.leaflet-zoom-box{border:2px dotted #38f;background:#ffffff80}.leaflet-container{font-family:Helvetica Neue,Arial,Helvetica,sans-serif;font-size:12px;font-size:.75rem;line-height:1.5}.leaflet-bar{box-shadow:0 1px 5px #000000a6;border-radius:4px}.leaflet-bar a{background-color:#fff;border-bottom:1px solid #ccc;width:26px;height:26px;line-height:26px;display:block;text-align:center;text-decoration:none;color:#000}.leaflet-bar a,.leaflet-control-layers-toggle{background-position:50% 50%;background-repeat:no-repeat;display:block}.leaflet-bar a:hover,.leaflet-bar a:focus{background-color:#f4f4f4}.leaflet-bar a:first-child{border-top-left-radius:4px;border-top-right-radius:4px}.leaflet-bar a:last-child{border-bottom-left-radius:4px;border-bottom-right-radius:4px;border-bottom:none}.leaflet-bar a.leaflet-disabled{cursor:default;background-color:#f4f4f4;color:#bbb}.leaflet-touch .leaflet-bar a{width:30px;height:30px;line-height:30px}.leaflet-touch .leaflet-bar a:first-child{border-top-left-radius:2px;border-top-right-radius:2px}.leaflet-touch .leaflet-bar a:last-child{border-bottom-left-radius:2px;border-bottom-right-radius:2px}.leaflet-control-zoom-in,.leaflet-control-zoom-out{font:700 18px Lucida Console,Monaco,monospace;text-indent:1px}.leaflet-touch .leaflet-control-zoom-in,.leaflet-touch .leaflet-control-zoom-out{font-size:22px}.leaflet-control-layers{box-shadow:0 1px 5px #0006;background:#fff;border-radius:5px}.leaflet-control-layers-toggle{background-image:url(data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAABoAAAAaCAQAAAADQ4RFAAACf0lEQVR4AY1UM3gkARTePdvdoTxXKc+qTl3aU5U6b2Kbkz3Gtq3Zw6ziLGNPzrYx7946Tr6/ee/XeCQ4D3ykPtL5tHno4n0d/h3+xfuWHGLX81cn7r0iTNzjr7LrlxCqPtkbTQEHeqOrTy4Yyt3VCi/IOB0v7rVC7q45Q3Gr5K6jt+3Gl5nCoDD4MtO+j96Wu8atmhGqcNGHObuf8OM/x3AMx38+4Z2sPqzCxRFK2aF2e5Jol56XTLyggAMTL56XOMoS1W4pOyjUcGGQdZxU6qRh7B9Zp+PfpOFlqt0zyDZckPi1ttmIp03jX8gyJ8a/PG2yutpS/Vol7peZIbZcKBAEEheEIAgFbDkz5H6Zrkm2hVWGiXKiF4Ycw0RWKdtC16Q7qe3X4iOMxruonzegJzWaXFrU9utOSsLUmrc0YjeWYjCW4PDMADElpJSSQ0vQvA1Tm6/JlKnqFs1EGyZiFCqnRZTEJJJiKRYzVYzJck2Rm6P4iH+cmSY0YzimYa8l0EtTODFWhcMIMVqdsI2uiTvKmTisIDHJ3od5GILVhBCarCfVRmo4uTjkhrhzkiBV7SsaqS+TzrzM1qpGGUFt28pIySQHR6h7F6KSwGWm97ay+Z+ZqMcEjEWebE7wxCSQwpkhJqoZA5ivCdZDjJepuJ9IQjGGUmuXJdBFUygxVqVsxFsLMbDe8ZbDYVCGKxs+W080max1hFCarCfV+C1KATwcnvE9gRRuMP2prdbWGowm1KB1y+zwMMENkM755cJ2yPDtqhTI6ED1M/82yIDtC/4j4BijjeObflpO9I9MwXTCsSX8jWAFeHr05WoLTJ5G8IQVS/7vwR6ohirYM7f6HzYpogfS3R2OAAAAAElFTkSuQmCC);width:36px;height:36px}.leaflet-retina .leaflet-control-layers-toggle{background-image:url(data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAADQAAAA0CAQAAABvcdNgAAAEsklEQVR4AWL4TydIhpZK1kpWOlg0w3ZXP6D2soBtG42jeI6ZmQTHzAxiTbSJsYLjO9HhP+WOmcuhciVnmHVQcJnp7DFvScowZorad/+V/fVzMdMT2g9Cv9guXGv/7pYOrXh2U+RRR3dSd9JRx6bIFc/ekqHI29JC6pJ5ZEh1yWkhkbcFeSjxgx3L2m1cb1C7bceyxA+CNjT/Ifff+/kDk2u/w/33/IeCMOSaWZ4glosqT3DNnNZQ7Cs58/3Ce5HL78iZH/vKVIaYlqzfdLu8Vi7dnvUbEza5Idt36tquZFldl6N5Z/POLof0XLK61mZCmJSWjVF9tEjUluu74IUXvgttuVIHE7YxSkaYhJZam7yiM9Pv82JYfl9nptxZaxMJE4YSPty+vF0+Y2up9d3wwijfjZbabqm/3bZ9ecKHsiGmRflnn1MW4pjHf9oLufyn2z3y1D6n8g8TZhxyzipLNPnAUpsOiuWimg52psrTZYnOWYNDTMuWBWa0tJb4rgq1UvmutpaYEbZlwU3CLJm/ayYjHW5/h7xWLn9Hh1vepDkyf7dE7MtT5LR4e7yYpHrkhOUpEfssBLq2pPhAqoSWKUkk7EDqkmK6RrCEzqDjhNDWNE+XSMvkJRDWlZTmCW0l0PHQGRZY5t1L83kT0Y3l2SItk5JAWHl2dCOBm+fPu3fo5/3v61RMCO9Jx2EEYYhb0rmNQMX/vm7gqOEJLcXTGw3CAuRNeyaPWwjR8PRqKQ1PDA/dpv+on9Shox52WFnx0KY8onHayrJzm87i5h9xGw/tfkev0jGsQizqezUKjk12hBMKJ4kbCqGPVNXudyyrShovGw5CgxsRICxF6aRmSjlBnHRzg7Gx8fKqEubI2rahQYdR1YgDIRQO7JvQyD52hoIQx0mxa0ODtW2Iozn1le2iIRdzwWewedyZzewidueOGqlsn1MvcnQpuVwLGG3/IR1hIKxCjelIDZ8ldqWz25jWAsnldEnK0Zxro19TGVb2ffIZEsIO89EIEDvKMPrzmBOQcKQ+rroye6NgRRxqR4U8EAkz0CL6uSGOm6KQCdWjvjRiSP1BPalCRS5iQYiEIvxuBMJEWgzSoHADcVMuN7IuqqTeyUPq22qFimFtxDyBBJEwNyt6TM88blFHao/6tWWhuuOM4SAK4EI4QmFHA+SEyWlp4EQoJ13cYGzMu7yszEIBOm2rVmHUNqwAIQabISNMRstmdhNWcFLsSm+0tjJH1MdRxO5Nx0WDMhCtgD6OKgZeljJqJKc9po8juskR9XN0Y1lZ3mWjLR9JCO1jRDMd0fpYC2VnvjBSEFg7wBENc0R9HFlb0xvF1+TBEpF68d+DHR6IOWVv2BECtxo46hOFUBd/APU57WIoEwJhIi2CdpyZX0m93BZicktMj1AS9dClteUFAUNUIEygRZCtik5zSxI9MubTBH1GOiHsiLJ3OCoSZkILa9PxiN0EbvhsAo8tdAf9Seepd36lGWHmtNANTv5Jd0z4QYyeo/UEJqxKRpg5LZx6btLPsOaEmdMyxYdlc8LMaJnikDlhclqmPiQnTEpLUIZEwkRagjYkEibQErwhkTAKCLQEbUgkzJQWc/0PstHHcfEdQ+UAAAAASUVORK5CYII=);background-size:26px 26px}.leaflet-touch .leaflet-control-layers-toggle{width:44px;height:44px}.leaflet-control-layers .leaflet-control-layers-list,.leaflet-control-layers-expanded .leaflet-control-layers-toggle{display:none}.leaflet-control-layers-expanded .leaflet-control-layers-list{display:block;position:relative}.leaflet-control-layers-expanded{padding:6px 10px 6px 6px;color:#333;background:#fff}.leaflet-control-layers-scrollbar{overflow-y:scroll;overflow-x:hidden;padding-right:5px}.leaflet-control-layers-selector{margin-top:2px;position:relative;top:1px}.leaflet-control-layers label{display:block;font-size:13px;font-size:1.08333em}.leaflet-control-layers-separator{height:0;border-top:1px solid #ddd;margin:5px -10px 5px -6px}.leaflet-default-icon-path{background-image:url(data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAABkAAAApCAYAAADAk4LOAAAFgUlEQVR4Aa1XA5BjWRTN2oW17d3YaZtr2962HUzbDNpjszW24mRt28p47v7zq/bXZtrp/lWnXr337j3nPCe85NcypgSFdugCpW5YoDAMRaIMqRi6aKq5E3YqDQO3qAwjVWrD8Ncq/RBpykd8oZUb/kaJutow8r1aP9II0WmLKLIsJyv1w/kqw9Ch2MYdB++12Onxee/QMwvf4/Dk/Lfp/i4nxTXtOoQ4pW5Aj7wpici1A9erdAN2OH64x8OSP9j3Ft3b7aWkTg/Fm91siTra0f9on5sQr9INejH6CUUUpavjFNq1B+Oadhxmnfa8RfEmN8VNAsQhPqF55xHkMzz3jSmChWU6f7/XZKNH+9+hBLOHYozuKQPxyMPUKkrX/K0uWnfFaJGS1QPRtZsOPtr3NsW0uyh6NNCOkU3Yz+bXbT3I8G3xE5EXLXtCXbbqwCO9zPQYPRTZ5vIDXD7U+w7rFDEoUUf7ibHIR4y6bLVPXrz8JVZEql13trxwue/uDivd3fkWRbS6/IA2bID4uk0UpF1N8qLlbBlXs4Ee7HLTfV1j54APvODnSfOWBqtKVvjgLKzF5YdEk5ewRkGlK0i33Eofffc7HT56jD7/6U+qH3Cx7SBLNntH5YIPvODnyfIXZYRVDPqgHtLs5ABHD3YzLuespb7t79FY34DjMwrVrcTuwlT55YMPvOBnRrJ4VXTdNnYug5ucHLBjEpt30701A3Ts+HEa73u6dT3FNWwflY86eMHPk+Yu+i6pzUpRrW7SNDg5JHR4KapmM5Wv2E8Tfcb1HoqqHMHU+uWDD7zg54mz5/2BSnizi9T1Dg4QQXLToGNCkb6tb1NU+QAlGr1++eADrzhn/u8Q2YZhQVlZ5+CAOtqfbhmaUCS1ezNFVm2imDbPmPng5wmz+gwh+oHDce0eUtQ6OGDIyR0uUhUsoO3vfDmmgOezH0mZN59x7MBi++WDL1g/eEiU3avlidO671bkLfwbw5XV2P8Pzo0ydy4t2/0eu33xYSOMOD8hTf4CrBtGMSoXfPLchX+J0ruSePw3LZeK0juPJbYzrhkH0io7B3k164hiGvawhOKMLkrQLyVpZg8rHFW7E2uHOL888IBPlNZ1FPzstSJM694fWr6RwpvcJK60+0HCILTBzZLFNdtAzJaohze60T8qBzyh5ZuOg5e7uwQppofEmf2++DYvmySqGBuKaicF1blQjhuHdvCIMvp8whTTfZzI7RldpwtSzL+F1+wkdZ2TBOW2gIF88PBTzD/gpeREAMEbxnJcaJHNHrpzji0gQCS6hdkEeYt9DF/2qPcEC8RM28Hwmr3sdNyht00byAut2k3gufWNtgtOEOFGUwcXWNDbdNbpgBGxEvKkOQsxivJx33iow0Vw5S6SVTrpVq11ysA2Rp7gTfPfktc6zhtXBBC+adRLshf6sG2RfHPZ5EAc4sVZ83yCN00Fk/4kggu40ZTvIEm5g24qtU4KjBrx/BTTH8ifVASAG7gKrnWxJDcU7x8X6Ecczhm3o6YicvsLXWfh3Ch1W0k8x0nXF+0fFxgt4phz8QvypiwCCFKMqXCnqXExjq10beH+UUA7+nG6mdG/Pu0f3LgFcGrl2s0kNNjpmoJ9o4B29CMO8dMT4Q5ox8uitF6fqsrJOr8qnwNbRzv6hSnG5wP+64C7h9lp30hKNtKdWjtdkbuPA19nJ7Tz3zR/ibgARbhb4AlhavcBebmTHcFl2fvYEnW0ox9xMxKBS8btJ+KiEbq9zA4RthQXDhPa0T9TEe69gWupwc6uBUphquXgf+/FrIjweHQS4/pduMe5ERUMHUd9xv8ZR98CxkS4F2n3EUrUZ10EYNw7BWm9x1GiPssi3GgiGRDKWRYZfXlON+dfNbM+GgIwYdwAAAAASUVORK5CYII=)}.leaflet-container .leaflet-control-attribution{background:#fff;background:#fffc;margin:0}.leaflet-control-attribution,.leaflet-control-scale-line{padding:0 5px;color:#333;line-height:1.4}.leaflet-control-attribution a{text-decoration:none}.leaflet-control-attribution a:hover,.leaflet-control-attribution a:focus{text-decoration:underline}.leaflet-attribution-flag{display:inline!important;vertical-align:baseline!important;width:1em;height:.6669em}.leaflet-left .leaflet-control-scale{margin-left:5px}.leaflet-bottom .leaflet-control-scale{margin-bottom:5px}.leaflet-control-scale-line{border:2px solid #777;border-top:none;line-height:1.1;padding:2px 5px 1px;white-space:nowrap;-moz-box-sizing:border-box;box-sizing:border-box;background:#fffc;text-shadow:1px 1px #fff}.leaflet-control-scale-line:not(:first-child){border-top:2px solid #777;border-bottom:none;margin-top:-2px}.leaflet-control-scale-line:not(:first-child):not(:last-child){border-bottom:2px solid #777}.leaflet-touch .leaflet-control-attribution,.leaflet-touch .leaflet-control-layers,.leaflet-touch .leaflet-bar{box-shadow:none}.leaflet-touch .leaflet-control-layers,.leaflet-touch .leaflet-bar{border:2px solid rgba(0,0,0,.2);background-clip:padding-box}.leaflet-popup{position:absolute;text-align:center;margin-bottom:20px}.leaflet-popup-content-wrapper{padding:1px;text-align:left;border-radius:12px}.leaflet-popup-content{margin:13px 24px 13px 20px;line-height:1.3;font-size:13px;font-size:1.08333em;min-height:1px}.leaflet-popup-content p{margin:1.3em 0}.leaflet-popup-tip-container{width:40px;height:20px;position:absolute;left:50%;margin-top:-1px;margin-left:-20px;overflow:hidden;pointer-events:none}.leaflet-popup-tip{width:17px;height:17px;padding:1px;margin:-10px auto 0;pointer-events:auto;-webkit-transform:rotate(45deg);-moz-transform:rotate(45deg);-ms-transform:rotate(45deg);transform:rotate(45deg)}.leaflet-popup-content-wrapper,.leaflet-popup-tip{background:#fff;color:#333;box-shadow:0 3px 14px #0006}.leaflet-container a.leaflet-popup-close-button{position:absolute;top:0;right:0;border:none;text-align:center;width:24px;height:24px;font:16px/24px Tahoma,Verdana,sans-serif;color:#757575;text-decoration:none;background:transparent}.leaflet-container a.leaflet-popup-close-button:hover,.leaflet-container a.leaflet-popup-close-button:focus{color:#585858}.leaflet-popup-scrolled{overflow:auto}.leaflet-oldie .leaflet-popup-content-wrapper{-ms-zoom:1}.leaflet-oldie .leaflet-popup-tip{width:24px;margin:0 auto;-ms-filter:"progid:DXImageTransform.Microsoft.Matrix(M11=0.70710678, M12=0.70710678, M21=-0.70710678, M22=0.70710678)";filter:progid:DXImageTransform.Microsoft.Matrix(M11=.70710678,M12=.70710678,M21=-.70710678,M22=.70710678)}.leaflet-oldie .leaflet-control-zoom,.leaflet-oldie .leaflet-control-layers,.leaflet-oldie .leaflet-popup-content-wrapper,.leaflet-oldie .leaflet-popup-tip{border:1px solid #999}.leaflet-div-icon{background:#fff;border:1px solid #666}.leaflet-tooltip{position:absolute;padding:6px;background-color:#fff;border:1px solid #fff;border-radius:3px;color:#222;white-space:nowrap;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none;pointer-events:none;box-shadow:0 1px 3px #0006}.leaflet-tooltip.leaflet-interactive{cursor:pointer;pointer-events:auto}.leaflet-tooltip-top:before,.leaflet-tooltip-bottom:before,.leaflet-tooltip-left:before,.leaflet-tooltip-right:before{position:absolute;pointer-events:none;border:6px solid transparent;background:transparent;content:""}.leaflet-tooltip-bottom{margin-top:6px}.leaflet-tooltip-top{margin-top:-6px}.leaflet-tooltip-bottom:before,.leaflet-tooltip-top:before{left:50%;margin-left:-6px}.leaflet-tooltip-top:before{bottom:0;margin-bottom:-12px;border-top-color:#fff}.leaflet-tooltip-bottom:before{top:0;margin-top:-12px;margin-left:-6px;border-bottom-color:#fff}.leaflet-tooltip-left{margin-left:-6px}.leaflet-tooltip-right{margin-left:6px}.leaflet-tooltip-left:before,.leaflet-tooltip-right:before{top:50%;margin-top:-6px}.leaflet-tooltip-left:before{right:0;margin-right:-12px;border-left-color:#fff}.leaflet-tooltip-right:before{left:0;margin-left:-12px;border-right-color:#fff}@media print{.leaflet-control{-webkit-print-color-adjust:exact;print-color-adjust:exact}}.world-container{width:100%;height:100vh;position:relative;overflow:hidden;display:flex;background-color:var(--bg-primary)}.world-map-wrapper{flex-grow:1;position:relative;height:100%;z-index:1}.world-no-marker-banner{position:absolute;left:50%;bottom:max(20px,env(safe-area-inset-bottom,0px));transform:translate(-50%);z-index:500;max-width:min(520px,calc(100% - 32px));padding:10px 14px;border-radius:12px;background:#161b228c;border:1px solid rgba(255,255,255,.12);backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);box-shadow:0 4px 24px #00000040;display:flex;flex-direction:column;align-items:center;gap:8px;text-align:center;pointer-events:auto}.world-no-marker-banner[hidden]{display:none!important;visibility:hidden;pointer-events:none}[data-theme=light] .world-no-marker-banner{background:#ffffffb8;border-color:#00000014;box-shadow:0 4px 20px #00000014}.world-no-marker-banner__text{margin:0;font-size:.82rem;line-height:1.45;color:var(--text-secondary)}.world-no-marker-banner__actions{display:flex;flex-wrap:wrap;gap:8px;justify-content:center;align-items:center}.world-no-marker-banner__btn{margin:0;padding:8px 14px;border-radius:10px;cursor:pointer;font:inherit;font-size:.82rem;font-weight:600;border:1px solid transparent;transition:background .2s,color .2s,border-color .2s}.world-no-marker-banner__btn--primary{background:var(--accent-primary);color:#fff;border-color:var(--accent-primary)}.world-no-marker-banner__btn--primary:hover{filter:brightness(1.08)}#zenworld-map{width:100%;height:100%}[data-theme=dark] #zenworld-map{background-color:#1a1a1a}[data-theme=dark] .leaflet-tile-pane{filter:brightness(.6) invert(1) contrast(3) hue-rotate(200deg) saturate(.3) brightness(.7)}[data-theme=light] .leaflet-tile-pane{filter:none}.glass-panel{background:var(--bg-panel);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);border:1px solid var(--border-primary);box-shadow:var(--shadow-medium);border-radius:12px}.world-top-bar{position:absolute;top:20px;left:20px;z-index:1000;display:flex;flex-direction:row;align-items:center;justify-content:space-between;padding:10px;gap:20px;width:max-content;transition:transform .3s cubic-bezier(.16,1,.3,1),left .3s cubic-bezier(.16,1,.3,1)}.world-top-bar.glass-panel{border-radius:20px}.top-bar-actions{display:flex;align-items:center;gap:10px}.square-btn{width:38px;height:38px;border-radius:10px;background:var(--bg-tertiary);border:1px solid var(--border-primary);color:var(--text-primary);display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s cubic-bezier(.4,0,.2,1)}.square-btn:hover{background:var(--accent-primary);border-color:var(--accent-primary);color:#fff;transform:translateY(-2px);box-shadow:0 4px 12px #0003}.square-btn svg{transition:transform .3s ease}.square-btn:hover svg{transform:scale(1.1)}[data-theme=dark] .world-top-bar .theme-icon-light,[data-theme=light] .world-top-bar .theme-icon-dark{display:none}.world-chatbox{position:absolute;top:20px;right:20px;width:360px;height:80vh;max-height:800px;z-index:1000;display:flex;flex-direction:column;overflow:hidden;transition:transform .4s cubic-bezier(.16,1,.3,1),opacity .4s ease}@media(min-width:769px){.world-chatbox.collapsed{transform:translate(calc(100% + 40px));opacity:0;pointer-events:none}}.chat-restore-btn{position:absolute;top:20px;right:20px;width:56px;height:56px;border-radius:16px;background:var(--bg-panel);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border:1px solid var(--border-primary);color:var(--text-primary);display:none;align-items:center;justify-content:center;z-index:999;cursor:pointer;box-shadow:var(--shadow-medium);transition:background .2s,transform .2s}.chat-restore-btn svg{width:28px;height:28px;stroke:var(--accent-primary)}.chat-restore-btn:hover{background:var(--bg-tertiary);transform:scale(1.05)}@media(min-width:769px){.chat-restore-btn.visible{display:flex;animation:restore-reveal .45s cubic-bezier(.16,1,.3,1) forwards}}@keyframes restore-reveal{0%{transform:translate(100px) scale(.8);opacity:0}to{transform:translate(0) scale(1);opacity:1}}.filter-toggle-btn{position:absolute;top:90px;left:20px;width:44px;height:44px;border-radius:12px;background:var(--bg-panel);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border:1px solid var(--border-primary);color:var(--text-secondary);display:flex;align-items:center;justify-content:center;z-index:999;cursor:pointer;box-shadow:var(--shadow-medium);transition:background .2s,transform .2s,color .2s,border-color .2s}.filter-toggle-btn svg{width:18px;height:18px}.filter-toggle-btn:hover{background:var(--bg-tertiary);transform:scale(1.05)}.filter-toggle-btn.active{color:var(--accent-primary);border-color:var(--accent-primary)}.filter-panel{position:absolute;top:90px;left:74px;z-index:999;padding:6px;border-radius:14px;flex-direction:column;gap:5px;min-width:140px;animation:filter-panel-reveal .2s cubic-bezier(.16,1,.3,1) forwards}@keyframes filter-panel-reveal{0%{opacity:0;transform:translate(-6px) scale(.97)}to{opacity:1;transform:translate(0) scale(1)}}.filter-type-btn{display:flex;align-items:center;gap:7px;padding:5px 8px;border-radius:8px;border:1px solid transparent;background:transparent;color:var(--text-secondary);font-size:.8rem;font-weight:500;cursor:pointer;transition:background .15s,color .15s,border-color .15s;white-space:nowrap;width:100%;text-align:left}.filter-type-icon{display:flex;align-items:center;flex-shrink:0;opacity:.4;color:var(--type-color);transition:opacity .15s}.filter-type-btn.active{background:color-mix(in srgb,var(--type-color) 12%,transparent);border-color:color-mix(in srgb,var(--type-color) 30%,transparent);color:var(--text-primary)}.filter-type-btn.active .filter-type-icon{opacity:1}.filter-type-btn:hover:not(.active){background:var(--bg-tertiary)}@media(max-width:1024px){#world-chat-collapse-btn{display:none!important}}.chat-header{padding:16px;border-bottom:1px solid var(--border-primary);font-weight:600;color:var(--text-primary);display:flex;justify-content:space-between;align-items:center;flex-shrink:0}.chat-rooms{display:flex;gap:8px;padding:12px 16px;overflow-x:auto;border-bottom:1px solid var(--border-primary);flex-shrink:0}.chat-rooms button{background:var(--bg-tertiary);border:1px solid var(--border-primary);color:var(--text-secondary);padding:8px 12px;border-radius:18px;font-size:1rem;cursor:pointer;white-space:nowrap;transition:all .3s cubic-bezier(.4,0,.2,1);flex-shrink:0;display:flex;align-items:center;justify-content:center;gap:0}.chat-rooms button span{display:none;font-size:.85rem;font-weight:600;margin-left:0}.chat-rooms button.active{background:var(--accent-primary);color:#fff;border-color:var(--accent-primary);padding:8px 16px;gap:8px}.chat-rooms button.active span{display:inline-block}.chat-messages{flex-grow:1;padding:16px;overflow-y:auto;display:flex;flex-direction:column;gap:12px}.chat-message{display:flex;flex-direction:row;align-items:flex-end;gap:8px;width:100%}.chat-message.self{justify-content:flex-end}.chat-message-avatar{width:32px;height:32px;border-radius:50%;background:var(--bg-tertiary);flex-shrink:0;display:flex;align-items:center;justify-content:center;overflow:hidden;color:var(--text-muted)}.chat-message-avatar svg{width:20px;height:20px}.chat-message-avatar .chat-message-avatar-img{width:100%;height:100%;object-fit:cover;border-radius:50%;display:block}.chat-message-avatar .chat-message-avatar-fallback{display:flex;align-items:center;justify-content:center;width:100%;height:100%;color:var(--text-muted)}.chat-message-bubble{background:var(--bg-tertiary);color:var(--text-primary);padding:6px 12px 6px 14px;border-radius:16px 16px 16px 4px;max-width:82%;font-size:.95rem;line-height:1.4;position:relative;min-width:60px}@media(min-width:1025px){.chat-message-bubble{font-size:.88rem}}.chat-message.self .chat-message-bubble{background:var(--accent-primary);color:#fff;border-radius:16px 16px 4px}.chat-message-header{display:flex;align-items:center;justify-content:space-between;gap:6px;margin-bottom:2px;min-width:0}.chat-message-header .chat-message-sender{margin-bottom:0;flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.chat-message-sender{font-size:.85rem;font-weight:700;margin-bottom:2px}.chat-message-text{white-space:pre-wrap;word-break:break-word}.chat-message-spacer{display:inline-block;width:44px;height:1px}.chat-message-meta{position:absolute;bottom:4px;right:10px;display:flex;align-items:center;justify-content:flex-end;max-width:calc(100% - 16px)}.chat-message-meta .chat-message-time{font-size:.65rem;color:var(--text-muted);opacity:.8;line-height:1}.chat-message.self .chat-message-meta .chat-message-time{color:#ffffffbf}.chat-message-header .chat-msg-report-wrap{position:relative;flex-shrink:0;z-index:2}.chat-msg-report-toggle{width:26px;height:22px;border-radius:8px;border:1px solid var(--border-primary);background:var(--bg-secondary);color:var(--text-secondary);padding:0;cursor:pointer;display:flex;align-items:center;justify-content:center;opacity:0;pointer-events:none;transition:opacity .15s ease,background .15s ease,color .15s ease,border-color .15s ease}.chat-msg-report-icon{display:flex;align-items:center;justify-content:center}.chat-msg-report-dots{display:block;vertical-align:middle}.chat-msg-report-wrap.is-open .chat-msg-report-toggle,.chat-msg-report-toggle:focus-visible{opacity:1;pointer-events:auto}@media(hover:hover){.chat-message:not(.self):hover .chat-msg-report-toggle{opacity:1;pointer-events:auto}}@media(hover:none){.chat-message:not(.self) .chat-msg-report-toggle{opacity:.5;pointer-events:auto}}.chat-msg-report-toggle:hover{background:var(--bg-tertiary);color:var(--text-primary);border-color:var(--border-primary)}.chat-msg-report-popover{display:none;position:absolute;top:calc(100% + 4px);right:0;z-index:5;background:var(--bg-panel);border:1px solid var(--border-primary);border-radius:8px;padding:6px;box-shadow:var(--shadow-medium)}.chat-msg-report-wrap.is-open .chat-msg-report-popover{display:block}.chat-msg-report-open{background:none;border:none;color:var(--text-primary);font-size:.8rem;font-weight:600;cursor:pointer;padding:6px 10px;border-radius:6px;white-space:nowrap}.chat-msg-report-open:hover{background:var(--bg-tertiary);color:var(--accent-danger)}.chat-sanction-notice{width:100%;padding:12px 14px;font-size:.85rem;line-height:1.45;color:var(--text-secondary);text-align:center;border:1px solid var(--border-primary);border-radius:10px;background:#ff475714}.world-chat-report-modal{position:absolute;inset:0;z-index:50;display:flex;align-items:center;justify-content:center;padding:12px}.world-chat-report-modal[hidden]{display:none!important}.world-chat-report-modal__backdrop{position:absolute;inset:0;background:#0000008c;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.world-chat-report-modal__panel{position:relative;z-index:1;width:100%;max-width:320px;background:var(--bg-panel);border:1px solid var(--border-primary);border-radius:12px;padding:1rem 1.1rem;box-shadow:var(--shadow-medium)}.world-chat-report-modal__panel h3{margin:0 0 .75rem;font-size:1rem;font-weight:700;color:var(--text-primary)}.world-chat-report-reasons{display:flex;flex-direction:column;gap:.45rem;margin-bottom:1rem}.world-chat-report-label{display:flex;align-items:center;gap:.5rem;font-size:.88rem;color:var(--text-primary);cursor:pointer}.world-chat-report-label input{accent-color:var(--accent-primary)}.world-chat-report-actions{display:flex;gap:.5rem;justify-content:flex-end}.world-chat-report-btn{padding:.45rem .85rem;border-radius:8px;font-size:.85rem;font-weight:600;cursor:pointer;border:1px solid transparent}.world-chat-report-btn--ghost{background:transparent;border-color:var(--border-primary);color:var(--text-secondary)}.world-chat-report-btn--primary{background:var(--accent-primary);color:#fff}.world-chat-report-btn--primary:hover{opacity:.92}.chat-container{position:relative}.chat-date-separator{align-self:center;background:#0006;color:#ffffffd9;font-size:.75rem;padding:4px 10px;border-radius:12px;margin:8px 0;pointer-events:none}.chat-scroll-btn{position:absolute;bottom:80px;right:20px;width:40px;height:40px;border-radius:50%;background:var(--bg-panel);border:1px solid var(--border-primary);color:var(--text-primary);display:flex;align-items:center;justify-content:center;cursor:pointer;opacity:0;pointer-events:none;transition:all .2s;box-shadow:0 4px 12px #0006;z-index:10}.chat-scroll-btn.visible{opacity:1;pointer-events:auto}.chat-input-area{padding:16px;border-top:1px solid var(--border-primary);display:flex;gap:8px;flex-shrink:0;align-items:flex-end}.chat-input-wrap{flex:1;min-width:0;display:flex;flex-direction:column;gap:2px}.world-chat-char-counter{display:none;text-align:right;font-size:.72rem;color:var(--text-muted);line-height:1.2;padding-right:4px}.world-chat-char-counter.world-chat-char-counter--visible{display:block}.world-chat-char-counter.world-chat-char-counter--danger{color:var(--accent-danger);font-weight:600}.chat-input-area textarea{flex-grow:1;background:var(--bg-tertiary);border:1px solid var(--border-primary);color:var(--text-primary);padding:10px 16px;border-radius:18px;font-size:16px;outline:none;transition:border-color .2s;font-family:inherit;resize:none;line-height:1.4;min-height:44px;max-height:110px;overflow-y:auto;box-sizing:border-box}@media(min-width:1025px){.chat-input-area textarea{font-size:.9rem}}.chat-input-area textarea::-webkit-scrollbar{width:0px;background:transparent}.chat-input-area textarea:focus{border-color:var(--accent-primary)}.chat-input-area button{background:var(--accent-primary);color:#fff;border:none;width:40px;height:40px;border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:transform .2s}.chat-input-area button:hover{transform:scale(1.05)}.chat-banned-message{padding:16px;text-align:center;color:var(--accent-danger);font-size:.9rem;background:#f851491a;border-top:1px solid rgba(248,81,73,.2);border-radius:0 0 12px 12px}.chat-btn-login,.chat-btn-register{border:none!important;border-radius:8px!important;font-weight:600!important;cursor:pointer!important;transition:all .2s ease!important;color:#fff!important;display:flex!important;align-items:center!important;justify-content:center!important}.chat-btn-login{background:#3fb950!important;box-shadow:0 4px 12px #3fb95033!important}.chat-btn-login:hover{filter:brightness(1.1)!important;transform:translateY(-2px)!important}.chat-btn-register{background:#58a6ff!important;box-shadow:0 4px 12px #58a6ff33!important}.chat-btn-register:hover{filter:brightness(1.1)!important;transform:translateY(-2px)!important}.zen-marker{width:28px;height:28px;border-radius:50%;border:2px solid white;box-shadow:0 3px 8px #0000004d;position:relative;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:transform .2s cubic-bezier(.175,.885,.32,1.275);background:linear-gradient(135deg,#3498db,#2980b9)}.zen-marker svg{width:16px;height:16px;color:#fff;stroke-width:2.5px;position:relative;z-index:2}@media(hover:hover)and (pointer:fine){.zen-marker:hover{transform:scale(1.15) translateY(-2px);z-index:1001}}.zen-marker.player{background:linear-gradient(135deg,#0984e3,#2d3436)}.zen-marker.musician{background:linear-gradient(135deg,#a15bff,#7d21f3)}.zen-marker.travel{background:linear-gradient(135deg,#ffc04c,#ff8255f5)}.zen-marker.maker{background:linear-gradient(135deg,#f90,#e65100)}.zen-marker.school{background:linear-gradient(135deg,#6c5ce7,#00d2ff)}.zen-marker.star{background:linear-gradient(135deg,#ffe000,#ffb900);box-shadow:0 0 15px #ffe00080,0 3px 8px #0000004d}.zen-marker.star svg{color:#430}.zen-marker.shop{background:linear-gradient(135deg,#00c853,#1b5e20)}.zen-marker.fest{background:linear-gradient(135deg,#e84118,#c23616)}.zen-marker.concert{background:linear-gradient(135deg,#fd79a8,#e84393)}.zen-marker.online:before{content:"";position:absolute;top:50%;left:50%;width:30px;height:30px;margin-top:-15px;margin-left:-15px;border-radius:50%;background:#2ecc7166;border:2px solid #2ecc71;z-index:1;animation:pulsar 2.2s infinite cubic-bezier(.45,.05,.55,.95);pointer-events:none}@keyframes pulsar{0%{transform:scale(.85);opacity:.8}to{transform:scale(1.8);opacity:0}}.chat-bubble-popup{position:absolute;top:-27px;left:75%;transform:translate(-50%) scale(0);display:flex;align-items:center;justify-content:center;animation:message-pop-up 3.8s cubic-bezier(.1,.9,.2,1) forwards;z-index:1000}.chat-bubble-popup svg{width:24px;height:24px;stroke:#3498db;stroke-width:2.3;fill:#fff;filter:drop-shadow(1px 0 0 white) drop-shadow(-1px 0 0 white) drop-shadow(0 1px 0 white) drop-shadow(0 -1px 0 white)}@keyframes message-pop-up{0%{transform:translate(-50%) scale(0) translateY(20px);opacity:0}10%{transform:translate(-50%) scale(1.1) translateY(0);opacity:1}15%{transform:translate(-50%) scale(1) translateY(0);opacity:1}60%{transform:translate(-50%) scale(1) translateY(0);opacity:1}to{transform:translate(-50%) scale(1) translateY(-50px);opacity:0}}.mobile-world-nav{display:none}@media(max-width:1024px)and (orientation:portrait),(max-width:768px){.world-top-bar{position:fixed;left:16px;right:16px;top:12px;width:auto;transform:none;justify-content:space-between}.world-chatbox{position:fixed;left:50%;top:auto;bottom:85px;width:calc(100% - 20px);max-width:500px;height:60vh;max-height:60vh;border-radius:20px;transform:translate(-50%) scale(.96);opacity:0;pointer-events:none;transition:transform .55s cubic-bezier(.16,1,.3,1),opacity .55s cubic-bezier(.16,1,.3,1);border:1px solid var(--border-primary);box-shadow:0 -10px 40px #000c}.world-chatbox.open{transform:translate(-50%) scale(1);opacity:1;pointer-events:auto;animation:chat-reveal .4s cubic-bezier(.16,1,.3,1) forwards}@keyframes chat-reveal{0%{transform:translate(-50%,40px) scale(.96);opacity:0}to{transform:translate(-50%) scale(1);opacity:1}}.mobile-world-nav{display:flex;position:fixed;bottom:16px;left:50%;transform:translate(-50%);background:var(--bg-panel);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);padding:6px 20px;border-radius:12px;gap:24px;z-index:2000;box-shadow:var(--shadow-medium);border:1px solid var(--border-primary)}.nav-btn{background:transparent;border:none;color:var(--text-muted);display:flex;flex-direction:column;align-items:center;gap:2px;font-size:.7rem;cursor:pointer;padding:4px 0;transition:color .2s}.nav-btn svg{width:22px;height:22px;stroke:currentColor}.nav-btn.active{color:var(--accent-primary)}.world-no-marker-banner{left:auto;right:max(16px,env(safe-area-inset-right,0px));top:calc(92px + env(safe-area-inset-top,0px));bottom:auto;transform:none;max-width:min(300px,calc(100vw - 32px));align-items:stretch;text-align:left;z-index:1100}.world-map-wrapper{height:100%;width:100%}}@media(max-width:480px){.world-top-bar .beta-badge,#world-market-top-btn{display:none}}.user-profile-popup{position:fixed;z-index:3000;width:340px;background:var(--bg-panel);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border:1px solid var(--border-primary);border-radius:16px;box-shadow:0 8px 32px #00000059,0 2px 8px #00000026;padding:16px;animation:upp-enter .3s cubic-bezier(.16,1,.3,1) forwards;overflow:hidden}.user-profile-popup.centered{left:50%!important;top:auto!important;bottom:20px;transform:translate(-50%);width:calc(100vw - 32px);max-width:400px}.user-profile-popup:after,.user-profile-popup:before{content:"";position:absolute;display:none;width:0;height:0;border-style:solid}.user-profile-popup.above:after,.user-profile-popup.above:before{display:block;top:100%;left:var(--arrow-x, 50%);transform:translate(-50%)}.user-profile-popup.above:after{border-width:14px 10px 0 10px;border-color:var(--border-primary) transparent transparent transparent}.user-profile-popup.above:before{border-width:13px 9px 0 9px;border-color:var(--bg-panel) transparent transparent transparent;margin-top:-1px;z-index:1}.user-profile-popup.below:after,.user-profile-popup.below:before{display:block;bottom:100%;left:var(--arrow-x, 50%);transform:translate(-50%)}.user-profile-popup.below:after{border-width:0 10px 14px 10px;border-color:transparent transparent var(--border-primary) transparent}.user-profile-popup.below:before{border-width:0 9px 13px 9px;border-color:transparent transparent var(--bg-panel) transparent;margin-bottom:-1px;z-index:1}@keyframes upp-enter{0%{opacity:0;transform:scale(.92) translateY(8px)}to{opacity:1;transform:scale(1) translateY(0)}}.user-profile-popup.centered{animation-name:upp-enter-centered}@keyframes upp-enter-centered{0%{opacity:0;transform:translate(-50%) translateY(24px) scale(.95)}to{opacity:1;transform:translate(-50%) translateY(0) scale(1)}}.upp-close{position:absolute;top:10px;right:10px;background:none;border:none;color:var(--text-muted);cursor:pointer;padding:4px;border-radius:6px;display:flex;align-items:center;justify-content:center;transition:color .2s,background .2s;z-index:2}.upp-close:hover{color:var(--text-primary);background:var(--bg-tertiary)}.upp-compact-body{display:flex;flex-direction:column;gap:10px}.upp-main-row{display:flex;gap:14px;align-items:flex-start}.upp-avatar-col{display:flex;flex-direction:column;align-items:center;gap:8px;flex-shrink:0}.upp-avatar{width:56px;height:56px;border-radius:50%;background:var(--bg-tertiary);display:flex;align-items:center;justify-content:center;border:2px solid var(--border-primary);flex-shrink:0;position:relative}.upp-online-dot{position:absolute;bottom:2px;right:2px;width:12px;height:12px;background:#2ecc71;border:2px solid var(--bg-panel);border-radius:50%;z-index:5;box-shadow:0 0 10px #2ecc7166}.upp-avatar img{width:100%;height:100%;object-fit:cover}.upp-avatar svg{width:30px;height:30px;color:var(--text-muted)}.upp-social-row{display:flex;gap:4px;flex-wrap:wrap;justify-content:center;max-width:86px}.upp-social-icon{width:28px;height:28px;display:flex;align-items:center;justify-content:center;border-radius:6px;color:var(--text-muted);transition:color .2s,background .2s,transform .2s;text-decoration:none}.upp-social-icon:hover{background:var(--bg-tertiary)}.upp-social-icon svg{width:17px;height:17px}.upp-social-icon:hover{color:var(--text-accent);transform:scale(1.2)}.upp-social-icon[data-social=instagram]:hover{color:#e1306c}.upp-social-icon[data-social=tiktok]:hover{color:#ff0050}.upp-social-icon[data-social=facebook]:hover{color:#1877f2}.upp-social-icon[data-social=youtube]:hover{color:red}.upp-social-icon[data-social=telegram]:hover{color:#08c}.upp-info-col{flex:1;min-width:0;display:flex;flex-direction:column;gap:4px}.upp-name{font-size:1rem;font-weight:700;color:var(--text-primary);line-height:1.2;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;padding-right:24px}.upp-type-row{display:flex;gap:6px;align-items:center;flex-wrap:wrap}.upp-type-badge{display:inline-block;padding:2px 8px;border-radius:10px;font-size:.7rem;font-weight:600;color:#fff;letter-spacing:.02em;line-height:1.5}.upp-exp-badge{display:inline-block;padding:2px 8px;border-radius:10px;font-size:.7rem;font-weight:600;color:var(--exp-color);background:color-mix(in srgb,var(--exp-color) 15%,transparent);border:1px solid color-mix(in srgb,var(--exp-color) 30%,transparent);line-height:1.5}.upp-location{display:flex;align-items:center;gap:4px;font-size:.78rem;color:var(--text-secondary)}.upp-location svg{flex-shrink:0;color:var(--text-muted)}.upp-jam-badge{font-size:.72rem;color:var(--accent-secondary);font-weight:600}.upp-about-preview{font-size:.72rem;color:var(--text-secondary);display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;line-height:1.4;margin-top:2px}.upp-fest-dates{display:flex;align-items:center;gap:5px;font-size:.72rem;color:var(--text-secondary);margin-top:2px;line-height:1.35}.upp-fest-dates svg{flex-shrink:0;opacity:.6}.upp-fest-dates span{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.upm-fest-dates{margin:0;font-size:.95rem;color:var(--text-secondary)}.upp-handpans{display:flex;align-items:center;gap:5px;font-size:.72rem;color:var(--text-secondary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin-top:2px}.upp-handpans svg{flex-shrink:0;opacity:.6}.upp-handpans span{overflow:hidden;text-overflow:ellipsis}.upp-popup-actions{display:flex;gap:6px;justify-content:center;margin-top:0}.upp-popup-actions-right{display:inline-flex}.upp-btn{display:inline-flex;align-items:center;gap:5px;padding:5px 10px;border-radius:8px;font-size:.75rem;font-weight:600;border:1px solid var(--border-primary);background:var(--bg-tertiary);color:var(--text-primary);cursor:pointer;transition:all .2s;white-space:nowrap}.upp-btn:hover{background:var(--accent-primary);color:#fff;border-color:var(--accent-primary);transform:translateY(-1px);box-shadow:0 3px 8px #0003}.upp-btn svg{flex-shrink:0}.upp-btn-map:hover{background:#0984e3;border-color:#0984e3}.upp-error{text-align:center;color:var(--text-muted);padding:16px 0;font-size:.85rem}.upp-skeleton{display:flex;gap:14px;align-items:flex-start}.upp-skel-avatar{width:56px;height:56px;border-radius:50%;flex-shrink:0}.upp-skel-lines{flex:1;display:flex;flex-direction:column;gap:8px;padding-top:4px}.upp-skel-line{height:12px;border-radius:6px}.upp-skel-line.w70{width:70%}.upp-skel-line.w50{width:50%}.upp-skel-line.w40{width:40%}.shimmer{background:linear-gradient(90deg,var(--bg-tertiary) 25%,color-mix(in srgb,var(--bg-tertiary) 60%,var(--text-muted)) 50%,var(--bg-tertiary) 75%);background-size:200% 100%;animation:shimmer 1.5s infinite}@keyframes shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.user-profile-modal{position:fixed;inset:0;z-index:4000;display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity .28s ease}.user-profile-modal.visible{opacity:1}.user-profile-modal.closing{opacity:0;transition:opacity .25s ease}.upm-overlay{position:absolute;inset:0;background:#0000008c;backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px)}.upm-card{position:relative;width:90vw;max-width:520px;max-height:85vh;overflow-y:auto;background:var(--bg-secondary);border:1px solid var(--border-primary);border-radius:20px;box-shadow:0 24px 64px #00000073;z-index:1;animation:upm-card-enter .35s cubic-bezier(.16,1,.3,1) forwards}.user-profile-modal.closing .upm-card{animation:upm-card-exit .25s ease forwards}@keyframes upm-card-enter{0%{opacity:0;transform:scale(.93) translateY(20px)}to{opacity:1;transform:scale(1) translateY(0)}}@keyframes upm-card-exit{0%{opacity:1;transform:scale(1) translateY(0)}to{opacity:0;transform:scale(.95) translateY(10px)}}.upm-card::-webkit-scrollbar{width:0;background:transparent}.upm-close{position:absolute;top:16px;right:16px;background:var(--bg-tertiary);border:1px solid var(--border-primary);color:var(--text-secondary);width:36px;height:36px;border-radius:10px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s;z-index:2}.upm-close:hover{color:var(--text-primary);background:var(--bg-panel-hover);transform:scale(1.05)}.upm-header{display:flex;gap:20px;align-items:center;padding:28px 28px 20px}.upm-avatar-wrap{flex-shrink:0}.upm-avatar{width:80px;height:80px;border-radius:50%;background:var(--bg-tertiary);display:flex;align-items:center;justify-content:center;border:3px solid var(--border-primary);position:relative}.upm-avatar img{width:100%;height:100%;object-fit:cover}.upm-avatar svg{width:44px;height:44px;color:var(--text-muted)}.upm-header-info{flex:1;min-width:0}.upm-name{font-size:1.35rem;font-weight:700;color:var(--text-primary);margin:0 0 6px;line-height:1.2;padding-right:36px}.upm-badges{display:flex;gap:6px;flex-wrap:wrap;align-items:center;margin-bottom:6px}.upm-status-online{display:inline-flex;align-items:center;gap:4px;font-size:.72rem;font-weight:700;color:#2ecc71;text-transform:uppercase;letter-spacing:.04em;margin-bottom:4px}.upm-status-online:before{content:"";width:8px;height:8px;background:#2ecc71;border-radius:50%;display:inline-block}.upm-type-badge{display:inline-block;padding:3px 10px;border-radius:12px;font-size:.75rem;font-weight:600;color:#fff}.upm-exp-badge{display:inline-block;padding:3px 10px;border-radius:12px;font-size:.75rem;font-weight:600;color:var(--exp-color);background:color-mix(in srgb,var(--exp-color) 15%,transparent);border:1px solid color-mix(in srgb,var(--exp-color) 30%,transparent)}.upm-jam-badge{font-size:.75rem;font-weight:600;color:var(--accent-secondary)}.upm-location{display:flex;align-items:center;gap:4px;font-size:.85rem;color:var(--text-secondary);margin-top:2px}.upm-location svg{flex-shrink:0;color:var(--text-muted)}.upm-section{padding:0 28px 18px}.upm-section-title{font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--text-muted);margin:0 0 8px}.upm-about{font-size:.9rem;color:var(--text-primary);line-height:1.55;margin:0;white-space:pre-wrap}.upm-handpans-container{display:flex;flex-wrap:wrap;gap:8px}.upm-handpan-badge{background:color-mix(in srgb,var(--accent-primary) 15%,transparent);border:1px solid color-mix(in srgb,var(--accent-primary) 30%,transparent);color:var(--accent-primary);padding:4px 12px;border-radius:12px;font-size:.8rem;font-weight:600}[data-theme=dark] .upm-handpan-badge{background:color-mix(in srgb,var(--accent-primary) 20%,transparent);color:#58a6ff}.upm-contacts{display:flex;flex-direction:column;gap:8px}.upm-contact-row{display:flex;align-items:center;gap:10px}.upm-contact-icon{display:flex;align-items:center;justify-content:center;flex-shrink:0;color:var(--text-secondary)}.upm-contact-icon svg{width:16px;height:16px}.upm-contact-link{font-size:.875rem;color:var(--text-secondary);text-decoration:none;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;transition:color .15s}.upm-contact-link:hover{color:var(--text-primary);text-decoration:underline}.upm-socials{display:flex;flex-wrap:wrap;gap:10px}.upm-social-link{display:inline-flex;align-items:center;gap:8px;width:auto;text-decoration:none;color:var(--text-secondary);font-size:.85rem;padding:8px 14px;border-radius:12px;transition:all .2s;background:var(--bg-tertiary);border:1px solid transparent}.upm-social-link svg{width:18px;height:18px;flex-shrink:0}.upm-social-link:hover{border-color:var(--border-accent);background:var(--bg-panel-hover);color:var(--text-primary)}.upm-social-link[data-social=instagram]:hover svg{color:#e1306c}.upm-social-link[data-social=tiktok]:hover svg{color:#ff0050}.upm-social-link[data-social=facebook]:hover svg{color:#1877f2}.upm-social-link[data-social=youtube]:hover svg{color:red}.upm-social-link[data-social=telegram]:hover svg{color:#08c}@media(max-width:600px){.upm-socials{gap:8px}.upm-social-link{padding:9px;gap:0}.upm-social-link span{display:none}.upm-social-link svg{width:20px;height:20px}}.upm-footer{padding:12px 28px 24px;display:flex;gap:10px;justify-content:center}.upm-btn{display:inline-flex;align-items:center;gap:6px;padding:10px 18px;border-radius:12px;font-size:.85rem;font-weight:600;border:1px solid var(--border-primary);background:var(--bg-tertiary);color:var(--text-primary);cursor:pointer;transition:all .2s}.upm-btn:hover{background:var(--accent-primary);color:#fff;border-color:var(--accent-primary);transform:translateY(-1px);box-shadow:0 4px 12px #00000040}.upm-btn svg{flex-shrink:0}.upm-btn-map:hover{background:#0984e3;border-color:#0984e3}.upm-loading{padding:40px}[data-theme=light] .user-profile-popup{box-shadow:0 8px 32px #0000001f,0 2px 8px #0000000f}[data-theme=light] .upm-card{box-shadow:0 24px 64px #00000026}[data-theme=light] .upm-overlay{background:#0000004d}@media(max-width:768px){.user-profile-popup{width:calc(100vw - 32px);max-width:400px}.upm-header{padding:20px 20px 16px;gap:14px}.upm-avatar{width:64px;height:64px}.upm-name{font-size:1.15rem}.upm-section{padding:0 20px 14px}.upm-footer{padding:10px 20px 20px}.upm-card{max-width:calc(100vw - 24px);max-height:80vh;border-radius:16px}.upm-close{top:12px;right:12px;width:32px;height:32px}}@media(max-width:480px){.upp-compact-body{gap:8px}.upp-main-row{gap:10px}.upp-avatar,.upp-skel-avatar{width:48px;height:48px}.upm-header{flex-direction:column;text-align:center;align-items:center}.upm-badges,.upm-location{justify-content:center}.upm-name{padding-right:0}.upm-footer{justify-content:center}}
