:root{--color-bg: #1a0a18;--color-bg-secondary: #2a1428;--color-dark-plum: #3D1A39;--color-periwinkle: #CCCCFF;--color-periwinkle-dim: rgba(204, 204, 255, .6);--color-periwinkle-glow: rgba(204, 204, 255, .3);--color-text: #e8e0e8;--color-text-dim: rgba(232, 224, 232, .6);--color-border: rgba(204, 204, 255, .2);--color-ocean: #1a1030;--color-land: #3D1A39;--color-land-visited: #6B3D66;--color-marker: #CCCCFF;--color-path: rgba(204, 204, 255, .5);--font-mono: "Roboto Mono", monospace;--header-height: 50px;--panel-width: 320px;--spacing-xs: 4px;--spacing-sm: 8px;--spacing-md: 16px;--spacing-lg: 24px;--spacing-xl: 32px;--radius-sm: 4px;--radius-md: 8px;--radius-lg: 12px;--transition-fast: .15s ease;--transition-normal: .25s ease;--transition-slow: .4s ease}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html,body{height:100%;overflow:hidden}body{font-family:var(--font-mono);font-size:14px;background-color:var(--color-bg);color:var(--color-text);line-height:1.5}.app{display:flex;flex-direction:column;height:100vh;overflow:hidden}.header{display:flex;justify-content:space-between;align-items:center;height:var(--header-height);padding:0 var(--spacing-lg);background:var(--color-bg-secondary);border-bottom:1px solid var(--color-border);flex-shrink:0}.header__title{font-size:18px;font-weight:700;color:var(--color-periwinkle);letter-spacing:2px}.header__tagline{font-size:11px;color:var(--color-text-dim);font-weight:400;letter-spacing:.5px;margin-left:var(--spacing-md);padding-left:var(--spacing-md);border-left:1px solid var(--color-border)}.header__status{font-size:12px;color:var(--color-text-dim);text-transform:uppercase;letter-spacing:1px}.header__status span{color:var(--color-periwinkle)}.header__left{display:flex;align-items:center;gap:var(--spacing-lg)}.header__privacy{display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-xs) var(--spacing-md);background:#4caf5026;border:1px solid rgba(76,175,80,.4);border-radius:var(--radius-sm);font-size:11px}.header__privacy svg{width:14px;height:14px;color:#4caf50;flex-shrink:0}.header__privacy span{color:#81c784;font-weight:500}.header__privacy-link{color:var(--color-periwinkle);text-decoration:none;margin-left:var(--spacing-sm);padding-left:var(--spacing-sm);border-left:1px solid rgba(76,175,80,.4);transition:opacity var(--transition-fast)}.header__privacy-link:hover{opacity:.8;text-decoration:underline}.main{display:flex;flex:1;overflow:hidden;position:relative}.globe-section{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;position:relative;padding:var(--spacing-lg);overflow:hidden}.section{margin-top:var(--spacing-lg)}.section__title{font-size:11px;font-weight:600;color:var(--color-periwinkle-dim);letter-spacing:2px;margin-bottom:var(--spacing-md);text-transform:uppercase}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideIn{0%{opacity:0;transform:translate(20px)}to{opacity:1;transform:translate(0)}}.fade-in{animation:fadeIn var(--transition-normal) forwards}.slide-in{animation:slideIn var(--transition-normal) forwards}.instructions{position:absolute;top:var(--spacing-lg);left:var(--spacing-lg);background:#1a0a18f2;border:1px solid var(--color-border);border-radius:var(--radius-md);padding:var(--spacing-md) var(--spacing-lg);z-index:50;max-width:280px;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);transition:all var(--transition-normal)}.instructions.minimized{max-width:200px}.instructions.minimized .instructions__steps{display:none}.instructions__title{font-size:11px;font-weight:600;color:var(--color-periwinkle);letter-spacing:2px;margin-bottom:var(--spacing-md)}.instructions__steps{display:flex;flex-direction:column;gap:var(--spacing-sm);margin-bottom:var(--spacing-md)}.instructions__step{display:flex;align-items:center;gap:var(--spacing-sm)}.instructions__number{width:20px;height:20px;background:var(--color-dark-plum);border:1px solid var(--color-periwinkle-dim);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:10px;font-weight:700;color:var(--color-periwinkle);flex-shrink:0}.instructions__text{font-size:12px;color:var(--color-text)}.instructions__privacy{display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-sm) var(--spacing-md);background:#4caf5026;border:1px solid rgba(76,175,80,.4);border-radius:var(--radius-sm);margin-top:var(--spacing-sm)}.instructions__privacy svg{width:16px;height:16px;color:#4caf50;flex-shrink:0}.instructions__privacy span{font-size:11px;color:#81c784;font-weight:500}.add-photos-btn{position:fixed;bottom:var(--spacing-lg);left:var(--spacing-lg);display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-sm) var(--spacing-md);background:var(--color-bg);border:1px solid var(--color-border);border-radius:var(--radius-md);color:var(--color-text-dim);font-family:var(--font-mono);font-size:12px;cursor:pointer;transition:all var(--transition-fast);z-index:100}.add-photos-btn:hover{border-color:var(--color-periwinkle);color:var(--color-periwinkle);background:var(--color-bg-secondary)}.add-photos-btn svg{width:16px;height:16px}.add-photos-btn[hidden]{display:none}.wrapped-modal{position:fixed;top:0;left:0;right:0;bottom:0;z-index:1000;display:flex;align-items:center;justify-content:center}.wrapped-modal[hidden]{display:none}.wrapped-modal__backdrop{position:absolute;top:0;left:0;right:0;bottom:0;background:#000000e6;animation:fadeIn .3s ease}.wrapped-modal__content{position:relative;width:100%;max-width:500px;height:80vh;max-height:700px;background:linear-gradient(135deg,var(--color-dark-plum) 0%,var(--color-bg) 100%);border-radius:var(--radius-lg);border:1px solid var(--color-border);overflow:hidden;display:flex;flex-direction:column;animation:slideUp .4s ease}@keyframes slideUp{0%{opacity:0;transform:translateY(50px)}to{opacity:1;transform:translateY(0)}}.wrapped-modal__close{position:absolute;top:var(--spacing-md);right:var(--spacing-md);width:32px;height:32px;background:none;border:none;color:var(--color-text-dim);font-size:24px;cursor:pointer;z-index:10;transition:color var(--transition-fast)}.wrapped-modal__close:hover{color:var(--color-text)}.wrapped-slides{flex:1;position:relative;overflow:hidden}.wrapped-slide{position:absolute;top:0;left:0;right:0;bottom:0;display:flex;align-items:center;justify-content:center;padding:var(--spacing-xl);opacity:0;transform:translate(100%);transition:all .5s ease;pointer-events:none}.wrapped-slide.active{opacity:1;transform:translate(0);pointer-events:auto}.wrapped-slide.exiting{opacity:0;transform:translate(-100%)}.wrapped-slide__content{text-align:center;width:100%}.wrapped-title{font-size:48px;font-weight:700;letter-spacing:4px;color:var(--color-text);line-height:1.1}.wrapped-title--highlight{color:var(--color-periwinkle);text-shadow:0 0 40px var(--color-periwinkle-glow)}.wrapped-subtitle{margin-top:var(--spacing-lg);font-size:16px;color:var(--color-text-dim)}.wrapped-label{font-size:16px;color:var(--color-text-dim);text-transform:uppercase;letter-spacing:2px}.wrapped-big-number{font-size:120px;font-weight:700;color:var(--color-periwinkle);line-height:1;margin:var(--spacing-md) 0;text-shadow:0 0 60px var(--color-periwinkle-glow);animation:countUp .5s ease}@keyframes countUp{0%{transform:scale(.5);opacity:0}to{transform:scale(1);opacity:1}}.wrapped-flags{display:flex;justify-content:center;flex-wrap:wrap;gap:var(--spacing-sm);margin-top:var(--spacing-lg);font-size:32px}.wrapped-city-list{display:flex;flex-direction:column;gap:var(--spacing-xs);margin-top:var(--spacing-lg);max-height:200px;overflow-y:auto}.wrapped-city-item{font-size:14px;color:var(--color-text);opacity:.8}.wrapped-fun-fact{margin-top:var(--spacing-lg);font-size:14px;color:var(--color-periwinkle);font-style:italic}.wrapped-destination{font-size:48px;font-weight:700;color:var(--color-periwinkle);margin:var(--spacing-md) 0;text-transform:uppercase;letter-spacing:2px}.wrapped-personality{font-size:56px;font-weight:700;color:var(--color-periwinkle);margin:var(--spacing-md) 0;text-shadow:0 0 40px var(--color-periwinkle-glow)}.wrapped-personality-desc{font-size:14px;color:var(--color-text-dim);max-width:300px;margin:0 auto;line-height:1.6}.wrapped-summary-title{font-size:24px;font-weight:700;color:var(--color-periwinkle);letter-spacing:3px;margin-bottom:var(--spacing-xl)}.wrapped-summary-stats{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--spacing-lg);margin-bottom:var(--spacing-xl)}.wrapped-stat{display:flex;flex-direction:column;align-items:center}.wrapped-stat__value{font-size:36px;font-weight:700;color:var(--color-text)}.wrapped-stat__label{font-size:11px;color:var(--color-text-dim);text-transform:uppercase;letter-spacing:1px}.wrapped-share-btn{width:100%;padding:var(--spacing-md);background:var(--color-periwinkle);border:none;border-radius:var(--radius-md);color:var(--color-bg);font-family:var(--font-mono);font-size:14px;font-weight:600;cursor:pointer;transition:all var(--transition-fast)}.wrapped-share-btn:hover{background:var(--color-text);transform:scale(1.02)}.wrapped-replay-btn{width:100%;padding:var(--spacing-md);margin-top:var(--spacing-sm);background:transparent;border:1px solid var(--color-border);border-radius:var(--radius-md);color:var(--color-text-dim);font-family:var(--font-mono);font-size:14px;cursor:pointer;transition:all var(--transition-fast)}.wrapped-replay-btn:hover{border-color:var(--color-periwinkle);color:var(--color-periwinkle)}.wrapped-nav{padding:var(--spacing-lg);border-top:1px solid var(--color-border);display:flex;flex-direction:column;gap:var(--spacing-md)}.wrapped-nav__dots{display:flex;justify-content:center;gap:var(--spacing-sm)}.wrapped-nav__dot{width:8px;height:8px;border-radius:50%;background:var(--color-border);transition:all var(--transition-fast);cursor:pointer}.wrapped-nav__dot.active{background:var(--color-periwinkle);transform:scale(1.2)}.wrapped-nav__buttons{display:flex;gap:var(--spacing-sm)}.wrapped-nav__btn{flex:1;padding:var(--spacing-sm) var(--spacing-md);background:transparent;border:1px solid var(--color-border);border-radius:var(--radius-md);color:var(--color-text-dim);font-family:var(--font-mono);font-size:12px;cursor:pointer;transition:all var(--transition-fast)}.wrapped-nav__btn:disabled{opacity:.3;cursor:not-allowed}.wrapped-nav__btn:not(:disabled):hover{border-color:var(--color-periwinkle);color:var(--color-periwinkle)}.wrapped-nav__btn--primary{background:var(--color-periwinkle);border-color:var(--color-periwinkle);color:var(--color-bg)}.wrapped-nav__btn--primary:not(:disabled):hover{background:var(--color-text);border-color:var(--color-text);color:var(--color-bg)}.header__logo-container{display:flex;align-items:center;gap:var(--spacing-sm)}.header__logo{width:36px;height:36px;transition:transform var(--transition-fast)}.header__logo:hover{transform:rotate(-5deg) scale(1.1)}.share-dropdown{position:absolute;top:var(--spacing-md);right:56px;z-index:15}.share-dropdown__trigger{width:36px;height:36px;background:#3d1a39cc;border:1px solid var(--color-border);border-radius:var(--radius-md);color:var(--color-text-dim);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all var(--transition-fast)}.share-dropdown__trigger:hover{background:var(--color-dark-plum);color:var(--color-periwinkle);border-color:var(--color-periwinkle)}.share-dropdown__trigger svg{width:18px;height:18px}.share-dropdown__menu{position:absolute;top:100%;right:0;margin-top:var(--spacing-xs);background:var(--color-bg-secondary);border:1px solid var(--color-border);border-radius:var(--radius-md);overflow:hidden;min-width:160px;animation:fadeIn .2s ease}.share-dropdown__menu[hidden]{display:none}.share-dropdown__item{display:flex;align-items:center;gap:var(--spacing-sm);width:100%;padding:var(--spacing-sm) var(--spacing-md);background:none;border:none;color:var(--color-text);font-family:var(--font-mono);font-size:12px;cursor:pointer;text-align:left;transition:all var(--transition-fast)}.share-dropdown__item:hover{background:var(--color-dark-plum);color:var(--color-periwinkle)}.share-dropdown__item svg{width:16px;height:16px;flex-shrink:0}.share-dropdown__item+.share-dropdown__item{border-top:1px solid var(--color-border)}.feedback-btn{position:fixed;bottom:var(--spacing-lg);right:var(--spacing-lg);width:48px;height:48px;background:linear-gradient(135deg,var(--color-dark-plum) 0%,var(--color-periwinkle-glow) 100%);border:1px solid var(--color-periwinkle);border-radius:50%;color:var(--color-periwinkle);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all var(--transition-fast);z-index:500;box-shadow:0 4px 12px #0000004d}.feedback-btn:hover{transform:scale(1.1);background:var(--color-periwinkle);color:var(--color-bg)}.feedback-btn svg{width:22px;height:22px}.feedback-modal{position:fixed;top:0;left:0;right:0;bottom:0;z-index:1100;display:flex;align-items:center;justify-content:center}.feedback-modal[hidden]{display:none}.feedback-modal__backdrop{position:absolute;top:0;left:0;right:0;bottom:0;background:#000c;animation:fadeIn .2s ease}.feedback-modal__content{position:relative;width:90%;max-width:400px;background:var(--color-bg-secondary);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--spacing-xl);animation:slideUp .3s ease}.feedback-modal__close{position:absolute;top:var(--spacing-md);right:var(--spacing-md);width:32px;height:32px;background:none;border:none;color:var(--color-text-dim);font-size:24px;cursor:pointer;transition:color var(--transition-fast)}.feedback-modal__close:hover{color:var(--color-text)}.feedback-modal__title{font-size:20px;font-weight:700;color:var(--color-periwinkle);letter-spacing:1px;margin-bottom:var(--spacing-xs)}.feedback-modal__subtitle{font-size:12px;color:var(--color-text-dim);margin-bottom:var(--spacing-lg)}.feedback-form__group{margin-bottom:var(--spacing-md)}.feedback-form__label{display:block;font-size:11px;font-weight:600;color:var(--color-text-dim);text-transform:uppercase;letter-spacing:1px;margin-bottom:var(--spacing-sm)}.feedback-form__types{display:flex;gap:var(--spacing-sm)}.feedback-type{flex:1;cursor:pointer}.feedback-type input{display:none}.feedback-type__btn{display:block;padding:var(--spacing-sm) var(--spacing-md);background:#3d1a394d;border:1px solid var(--color-border);border-radius:var(--radius-sm);color:var(--color-text-dim);font-family:var(--font-mono);font-size:11px;text-align:center;transition:all var(--transition-fast)}.feedback-type input:checked+.feedback-type__btn{background:var(--color-dark-plum);border-color:var(--color-periwinkle);color:var(--color-periwinkle)}.feedback-type:hover .feedback-type__btn{border-color:var(--color-periwinkle-dim)}.feedback-form__textarea,.feedback-form__input{width:100%;padding:var(--spacing-sm) var(--spacing-md);background:var(--color-bg);border:1px solid var(--color-border);border-radius:var(--radius-sm);color:var(--color-text);font-family:var(--font-mono);font-size:12px;transition:border-color var(--transition-fast)}.feedback-form__textarea:focus,.feedback-form__input:focus{outline:none;border-color:var(--color-periwinkle)}.feedback-form__textarea{resize:vertical;min-height:80px}.feedback-form__submit{width:100%;padding:var(--spacing-md);background:var(--color-periwinkle);border:none;border-radius:var(--radius-md);color:var(--color-bg);font-family:var(--font-mono);font-size:14px;font-weight:600;cursor:pointer;transition:all var(--transition-fast)}.feedback-form__submit:hover{background:var(--color-text);transform:scale(1.02)}.feedback-modal__email{margin-top:var(--spacing-lg);padding-top:var(--spacing-md);border-top:1px solid var(--color-border);font-size:11px;color:var(--color-text-dim);text-align:center}.feedback-modal__email a{color:var(--color-periwinkle);text-decoration:none}.feedback-modal__email a:hover{text-decoration:underline}.toast{position:fixed;top:calc(var(--header-height) + var(--spacing-md));left:50%;transform:translate(-50%) translateY(-20px);background:var(--color-bg-secondary);border:1px solid var(--color-periwinkle);border-radius:var(--radius-md);padding:var(--spacing-sm) var(--spacing-lg);color:var(--color-periwinkle);font-size:13px;font-weight:500;z-index:1200;opacity:0;transition:all var(--transition-normal);box-shadow:0 4px 20px #ccccff4d;max-width:calc(100vw - 32px);text-align:center}.toast.show{opacity:1;transform:translate(-50%) translateY(0)}.toast[hidden]{display:none}.toast__message{display:flex;align-items:center;justify-content:center;gap:var(--spacing-sm)}.globe-container{width:100%;max-width:700px;aspect-ratio:1;position:relative;display:flex;align-items:center;justify-content:center}#globe{width:100%;height:100%;cursor:grab;touch-action:none}#globe:active{cursor:grabbing}.globe-ocean{fill:var(--color-ocean)}.globe-graticule{fill:none;stroke:#ccccff14;stroke-width:.5}.globe-land{fill:var(--color-land);stroke:#ccccff26;stroke-width:.5;transition:fill var(--transition-normal)}.globe-land.visited{fill:var(--color-land-visited)}.globe-marker{fill:var(--color-marker);stroke:var(--color-bg);stroke-width:2;cursor:pointer;transition:all var(--transition-fast)}.marker-group:hover .globe-marker{fill:#fff;transform:scale(1.2)}.globe-marker.hidden{display:none}.globe-marker-number{font-family:var(--font-mono);-webkit-user-select:none;user-select:none}.globe-marker-hitarea{cursor:pointer}@keyframes pulse{0%{transform:scale(1);opacity:1}to{transform:scale(2.5);opacity:0}}.globe-marker-pulse{fill:none;stroke:var(--color-periwinkle);stroke-width:2;opacity:0;pointer-events:none}.globe-marker-pulse.active{animation:pulse 1.5s ease-out infinite}.globe-path{fill:none;pointer-events:none}.globe-path.hidden{display:none}.globe-tooltip{position:absolute;background:var(--color-bg-secondary);border:1px solid var(--color-border);border-radius:var(--radius-sm);padding:var(--spacing-sm) var(--spacing-md);font-size:12px;color:var(--color-text);pointer-events:none;z-index:100;transform:translate(-50%,-100%);margin-top:-10px;white-space:nowrap;opacity:0;transition:opacity var(--transition-fast)}.globe-tooltip.visible{opacity:1}.globe-tooltip__city{font-weight:600;color:var(--color-periwinkle)}.globe-tooltip__country{color:var(--color-text-dim);margin-left:var(--spacing-xs)}.globe-tooltip__count{margin-top:var(--spacing-xs);font-size:11px;color:var(--color-text-dim)}.playback-info{position:absolute;top:20px;left:50%;transform:translate(-50%);background:var(--color-bg);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:var(--spacing-sm) var(--spacing-lg);display:flex;align-items:center;gap:var(--spacing-md);z-index:20;font-size:14px;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.playback-info[hidden]{display:none}.playback-info__flag{font-size:20px}.playback-info__location{font-weight:600;color:var(--color-periwinkle);text-transform:uppercase;letter-spacing:1px}.playback-info__date{color:var(--color-text-dim);font-size:12px;padding-left:var(--spacing-md);border-left:1px solid var(--color-border)}.playback-controls{position:absolute;bottom:20px;left:50%;transform:translate(-50%);background:var(--color-bg);border:1px solid var(--color-border);border-radius:30px;padding:var(--spacing-xs) var(--spacing-sm);display:flex;align-items:center;gap:var(--spacing-sm);z-index:20;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.playback-controls[hidden]{display:none}.playback-controls__transport{display:flex;align-items:center;gap:2px}.transport-btn{width:36px;height:36px;border-radius:50%;background:transparent;border:none;color:var(--color-text-dim);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all var(--transition-fast)}.transport-btn:hover{color:var(--color-periwinkle);background:#ccccff1a}.transport-btn:active{transform:scale(.9)}.transport-btn svg{width:16px;height:16px}.transport-btn--play{width:44px;height:44px;background:var(--color-periwinkle);color:var(--color-bg);margin:0 var(--spacing-xs)}.transport-btn--play:hover{background:var(--color-text);color:var(--color-bg)}.transport-btn--play svg{width:20px;height:20px}.transport-btn--play.playing{background:var(--color-dark-plum);color:var(--color-periwinkle);border:2px solid var(--color-periwinkle)}.playback-controls__speed{display:flex;align-items:center;gap:2px;margin-left:var(--spacing-sm);padding-left:var(--spacing-sm);border-left:1px solid var(--color-border)}.speed-btn{padding:var(--spacing-xs) var(--spacing-sm);border-radius:var(--radius-sm);background:transparent;border:none;color:var(--color-text-dim);font-family:var(--font-mono);font-size:11px;font-weight:600;cursor:pointer;transition:all var(--transition-fast)}.speed-btn:hover{color:var(--color-periwinkle)}.speed-btn.active{background:var(--color-periwinkle);color:var(--color-bg);border-radius:var(--radius-sm)}.info-panel{width:var(--panel-width);background:var(--color-bg-secondary);border-left:1px solid var(--color-border);display:flex;flex-direction:column;position:relative;transition:transform var(--transition-normal),width var(--transition-normal);flex-shrink:0;overflow:hidden}.info-panel.collapsed{width:0;transform:translate(100%)}.info-panel__toggle{position:absolute;left:-40px;top:50%;transform:translateY(-50%);width:32px;height:64px;background:var(--color-bg-secondary);border:1px solid var(--color-border);border-right:none;border-radius:var(--radius-md) 0 0 var(--radius-md);color:var(--color-periwinkle);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background var(--transition-fast)}.info-panel__toggle:hover{background:var(--color-dark-plum)}.info-panel__toggle svg{width:18px;height:18px;transition:transform var(--transition-normal)}.info-panel.collapsed .info-panel__toggle svg{transform:rotate(180deg)}.info-panel__content{padding:var(--spacing-lg);overflow-y:auto;flex:1}.info-panel__title{font-size:14px;font-weight:700;color:var(--color-periwinkle);letter-spacing:2px;margin-bottom:var(--spacing-lg);padding-bottom:var(--spacing-md);border-bottom:1px solid var(--color-border)}.stats{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--spacing-md)}.stat{background:#3d1a3980;border:1px solid var(--color-border);border-radius:var(--radius-md);padding:var(--spacing-md);text-align:center}.stat__label{display:block;font-size:10px;color:var(--color-text-dim);text-transform:uppercase;letter-spacing:1px;margin-bottom:var(--spacing-xs)}.stat__value{display:block;font-size:24px;font-weight:700;color:var(--color-periwinkle)}.device-list{display:flex;flex-direction:column;gap:var(--spacing-sm)}.device-item{display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-sm) var(--spacing-md);background:#3d1a394d;border:1px solid transparent;border-radius:var(--radius-sm);cursor:pointer;transition:all var(--transition-fast)}.device-item:hover{background:#3d1a3980;border-color:var(--color-border)}.device-item input{display:none}.device-item__radio{width:14px;height:14px;border:2px solid var(--color-periwinkle-dim);border-radius:50%;position:relative;flex-shrink:0;transition:border-color var(--transition-fast)}.device-item__radio:after{content:"";position:absolute;top:50%;left:50%;width:6px;height:6px;background:var(--color-periwinkle);border-radius:50%;transform:translate(-50%,-50%) scale(0);transition:transform var(--transition-fast)}.device-item input:checked+.device-item__radio{border-color:var(--color-periwinkle)}.device-item input:checked+.device-item__radio:after{transform:translate(-50%,-50%) scale(1)}.device-item__name{flex:1;font-size:12px;color:var(--color-text)}.device-item__count{font-size:11px;color:var(--color-text-dim)}.location-list{display:flex;flex-direction:column;gap:var(--spacing-xs);max-height:300px;overflow-y:auto}.location-list__empty{font-size:12px;color:var(--color-text-dim);font-style:italic;text-align:center;padding:var(--spacing-lg)}.location-item{display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-sm) var(--spacing-md);background:#3d1a394d;border:1px solid transparent;border-radius:var(--radius-sm);cursor:pointer;transition:all var(--transition-fast)}.location-item:hover{background:#3d1a3980;border-color:var(--color-border)}.location-item__flag{font-size:16px;flex-shrink:0}.location-item__info{flex:1;min-width:0}.location-item__city{font-size:12px;font-weight:600;color:var(--color-text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.location-item__country{font-size:10px;color:var(--color-text-dim);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.location-item__count{font-size:11px;color:var(--color-periwinkle-dim);flex-shrink:0}.location-item.highlighted{background:#ccccff26;border-color:var(--color-periwinkle)}.wrapped-trigger-btn{width:100%;margin-top:var(--spacing-lg);padding:var(--spacing-md);background:linear-gradient(135deg,var(--color-dark-plum) 0%,rgba(204,204,255,.2) 100%);border:1px solid var(--color-periwinkle);border-radius:var(--radius-md);color:var(--color-periwinkle);font-family:var(--font-mono);font-size:12px;font-weight:600;letter-spacing:1px;cursor:pointer;transition:all var(--transition-fast)}.wrapped-trigger-btn:hover{background:var(--color-periwinkle);color:var(--color-bg);transform:scale(1.02)}.wrapped-trigger-btn[hidden]{display:none}@media (hover: none) and (pointer: coarse){.device-item,.location-item{min-height:48px;padding:var(--spacing-md)}.info-panel__toggle{min-width:48px;min-height:48px}.wrapped-trigger-btn{min-height:48px}.device-item:active,.location-item:active,.wrapped-trigger-btn:active{opacity:.7;transform:scale(.98)}}.upload-zone{position:absolute;bottom:var(--spacing-lg);left:50%;transform:translate(-50%);width:90%;max-width:400px;background:#1a0a18e6;border:2px dashed var(--color-border);border-radius:var(--radius-lg);padding:var(--spacing-lg);text-align:center;cursor:pointer;transition:all var(--transition-normal);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);z-index:10}.upload-zone:hover,.upload-zone.dragover{border-color:var(--color-periwinkle);background:#3d1a3999}.upload-zone.dragover{transform:translate(-50%) scale(1.02)}.upload-zone.processing{pointer-events:none;border-style:solid;border-color:var(--color-periwinkle-dim)}.upload-zone.hidden{display:none!important;opacity:0;pointer-events:none}.upload-zone__content{display:flex;flex-direction:column;align-items:center;gap:var(--spacing-sm);pointer-events:none}.upload-zone__content *{pointer-events:none}.upload-zone__input{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}.upload-zone__icon{width:48px;height:48px;color:var(--color-periwinkle);margin-bottom:var(--spacing-sm)}.upload-zone__icon svg{width:100%;height:100%}.upload-zone__text{font-size:14px;font-weight:600;color:var(--color-periwinkle);letter-spacing:1px}.upload-zone__subtext{font-size:12px;color:var(--color-text-dim)}.upload-zone__privacy{display:flex;align-items:center;justify-content:center;gap:var(--spacing-sm);margin-top:var(--spacing-md);padding:var(--spacing-sm) var(--spacing-md);background:#4caf5026;border:1px solid rgba(76,175,80,.4);border-radius:var(--radius-sm);font-size:11px;color:#81c784;font-weight:500}.upload-zone__privacy:before{content:"";width:14px;height:14px;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%234CAF50' stroke-width='2'%3E%3Crect x='3' y='11' width='18' height='11' rx='2' ry='2'/%3E%3Cpath d='M7 11V7a5 5 0 0 1 10 0v4'/%3E%3C/svg%3E");background-size:contain;background-repeat:no-repeat;flex-shrink:0}.upload-zone__progress{display:flex;flex-direction:column;align-items:center;gap:var(--spacing-md);width:100%}.upload-zone__progress-text{font-size:12px;color:var(--color-text)}.progress-bar{width:100%;height:4px;background:var(--color-bg);border-radius:2px;overflow:hidden}.progress-bar__fill{height:100%;background:var(--color-periwinkle);border-radius:2px;width:0%;transition:width var(--transition-fast)}@keyframes processing{0%{background-position:0% 50%}to{background-position:100% 50%}}.progress-bar__fill.indeterminate{width:100%;background:linear-gradient(90deg,var(--color-periwinkle) 0%,var(--color-dark-plum) 50%,var(--color-periwinkle) 100%);background-size:200% 100%;animation:processing 1.5s ease-in-out infinite}.upload-zone__hint{margin-top:var(--spacing-md);font-size:11px;color:var(--color-text-dim);max-width:280px}.upload-zone__error{margin-top:var(--spacing-md);font-size:12px;color:#ff6b6b;display:flex;align-items:center;gap:var(--spacing-xs)}@media (max-width: 1024px){:root{--panel-width: 280px}.header{padding:0 var(--spacing-md)}.header__privacy span{max-width:180px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.instructions{max-width:240px}.wrapped-modal__content{max-width:450px}.wrapped-title{font-size:40px}.wrapped-big-number{font-size:100px}}@media (max-width: 768px){:root{--header-height: 56px;--panel-width: 100%}.header{flex-direction:row;height:48px;padding:0 var(--spacing-sm);gap:var(--spacing-sm)}.header__left{flex-direction:row;align-items:center;gap:var(--spacing-xs);flex:1}.header__logo-container{gap:var(--spacing-xs)}.header__logo{width:28px;height:28px}.header__title{font-size:12px;letter-spacing:1px}.header__privacy,.header__tagline{display:none}.header__status{font-size:9px;opacity:.7}.main{flex-direction:column}.globe-section{height:55vh;min-height:280px;padding:var(--spacing-sm)}.instructions{display:none}.playback-controls{bottom:90px!important;left:var(--spacing-sm)!important;right:auto!important;transform:none;padding:var(--spacing-xs)!important;gap:var(--spacing-xs)!important}.playback-controls__transport{gap:2px}.transport-btn{width:32px;height:32px}.transport-btn--play{width:38px;height:38px}.playback-controls__speed{display:none}.playback-info{font-size:10px;padding:var(--spacing-xs) var(--spacing-sm)!important;top:var(--spacing-sm)!important;bottom:auto!important;left:var(--spacing-sm)!important;right:auto!important;transform:none;max-width:200px;flex-direction:column;align-items:flex-start;gap:2px}.playback-info__date{border-left:none;padding-left:0;font-size:9px}.info-panel{position:fixed;bottom:0;left:0;right:0;width:100%!important;height:40vh;max-height:350px;border-left:none;border-top:1px solid var(--color-border);border-radius:var(--radius-lg) var(--radius-lg) 0 0;transform:translateY(0);transition:transform var(--transition-normal);z-index:200}.info-panel.collapsed{transform:translateY(calc(100% - 80px));width:100%!important}.info-panel.collapsed .info-panel__content{padding-top:var(--spacing-md)}.info-panel.collapsed .info-panel__title,.info-panel.collapsed .section,.info-panel.collapsed .wrapped-trigger-btn{display:none}.info-panel.collapsed .stats{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--spacing-xs)}.info-panel.collapsed .stat{padding:var(--spacing-xs)}.info-panel.collapsed .stat__label{font-size:8px}.info-panel.collapsed .stat__value{font-size:16px}.info-panel__toggle{position:absolute;left:50%;top:0;transform:translate(-50%) translateY(-100%);width:64px;height:32px;border-radius:var(--radius-md) var(--radius-md) 0 0;border-bottom:none}.info-panel__toggle svg{transform:rotate(-90deg)}.info-panel.collapsed .info-panel__toggle svg{transform:rotate(90deg)}.info-panel:before{content:"";position:absolute;top:8px;left:50%;transform:translate(-50%);width:40px;height:4px;background:var(--color-border);border-radius:2px;z-index:10}.info-panel__content{padding:var(--spacing-lg) var(--spacing-md);padding-top:calc(var(--spacing-lg) + 8px)}.info-panel__title{font-size:12px;text-align:center}.stats{gap:var(--spacing-sm)}.stat{padding:var(--spacing-sm)}.stat__label{font-size:9px}.stat__value{font-size:20px}.location-list{max-height:150px}.wrapped-trigger-btn{padding:var(--spacing-sm);font-size:11px}.upload-zone{position:absolute;top:var(--spacing-md);bottom:auto;left:50%;transform:translate(-50%);width:auto;min-width:180px;max-width:240px;min-height:auto;padding:var(--spacing-sm) var(--spacing-md);margin:0;border-width:2px}.upload-zone__icon{margin-bottom:var(--spacing-xs)}.upload-zone__icon svg{width:28px;height:28px}.upload-zone__text{font-size:13px;font-weight:600}.upload-zone__subtext{font-size:9px;padding:0;text-align:center;line-height:1.3}.upload-zone__privacy,.upload-zone__progress{display:none!important}.add-photos-btn{bottom:90px;left:50%;transform:translate(-50%);padding:var(--spacing-sm) var(--spacing-md);font-size:12px;background:var(--color-periwinkle);color:var(--color-bg);border-color:var(--color-periwinkle);z-index:201}.add-photos-btn:hover,.add-photos-btn:active{background:var(--color-text);border-color:var(--color-text)}.wrapped-modal__content{max-width:100%;width:100%;height:100%;max-height:100%;border-radius:0;border:none}.wrapped-modal__close{top:var(--spacing-sm);right:var(--spacing-sm);width:44px;height:44px;font-size:28px}.wrapped-slide{padding:var(--spacing-lg)}.wrapped-title{font-size:32px;letter-spacing:2px}.wrapped-subtitle{font-size:14px}.wrapped-big-number{font-size:80px}.wrapped-destination{font-size:32px}.wrapped-personality{font-size:36px}.wrapped-personality-desc{font-size:12px}.wrapped-summary-title{font-size:18px}.wrapped-summary-stats{gap:var(--spacing-md)}.wrapped-stat__value{font-size:28px}.wrapped-stat__label{font-size:10px}.wrapped-flags{font-size:24px}.wrapped-nav{padding:var(--spacing-md)}.wrapped-nav__btn{min-height:44px;font-size:14px}.feedback-btn{width:44px!important;height:44px!important;bottom:90px!important;right:var(--spacing-sm)!important;z-index:201}}@media (max-width: 480px){.header__title{font-size:11px;letter-spacing:.5px}.header__logo{width:24px;height:24px}.globe-section{height:50vh;min-height:240px;padding:var(--spacing-xs)}.upload-zone{min-width:180px;max-width:240px;padding:var(--spacing-sm) var(--spacing-md)}.upload-zone__icon svg{width:28px;height:28px}.upload-zone__text{font-size:12px}.upload-zone__subtext{font-size:9px}.info-panel{height:45vh;max-height:320px}.info-panel.collapsed{transform:translateY(calc(100% - 70px))}.info-panel__content{padding:var(--spacing-sm)}.stat__value{font-size:16px}.info-panel.collapsed .stat__value{font-size:14px}.add-photos-btn{bottom:80px;padding:var(--spacing-xs) var(--spacing-sm);font-size:11px}.feedback-btn{bottom:80px!important;width:40px!important;height:40px!important}.playback-controls{bottom:85px!important}.wrapped-title{font-size:28px}.wrapped-big-number{font-size:64px}.wrapped-destination{font-size:24px}.wrapped-personality{font-size:28px}.wrapped-summary-stats{gap:var(--spacing-sm)}.wrapped-stat__value{font-size:24px}.wrapped-flags{font-size:20px;gap:var(--spacing-xs)}.wrapped-city-list{max-height:120px}.wrapped-city-item{font-size:12px}}@media (hover: none) and (pointer: coarse){.transport-btn{min-width:48px;min-height:48px}.speed-btn{min-width:48px;min-height:48px;font-size:12px}.wrapped-nav__dot{width:12px;height:12px;padding:8px;box-sizing:content-box}.device-item,.location-item{min-height:48px}.info-panel__toggle{min-width:48px;min-height:48px}.transport-btn,.speed-btn,.wrapped-nav__btn,.wrapped-share-btn,.wrapped-replay-btn,.add-photos-btn,.feedback-btn,.easter-egg-btn{-webkit-tap-highlight-color:transparent;-webkit-touch-callout:none;-webkit-user-select:none;user-select:none}}@media (max-width: 768px) and (orientation: landscape){.header{height:40px;padding:0 var(--spacing-sm)}.main{flex-direction:row}.globe-section{height:100%;flex:1}.info-panel{position:relative;bottom:auto;left:auto;right:auto;width:240px!important;height:100%;max-height:none;border-radius:0;border-top:none;border-left:1px solid var(--color-border)}.info-panel.collapsed{transform:translate(calc(100% - 60px))}.info-panel__toggle{left:-32px;top:50%;transform:translateY(-50%);width:32px;height:56px;border-radius:var(--radius-md) 0 0 var(--radius-md);border-bottom:1px solid var(--color-border)}.info-panel__toggle svg{transform:rotate(0)}.info-panel.collapsed .info-panel__toggle svg{transform:rotate(180deg)}.info-panel:before{display:none}.add-photos-btn{bottom:var(--spacing-sm)!important;left:var(--spacing-sm)!important;transform:none}.feedback-btn{bottom:var(--spacing-sm)!important}.playback-controls{bottom:var(--spacing-sm)!important;left:50%!important;transform:translate(-50%)}.playback-controls__speed{display:flex}}@media (-webkit-min-device-pixel-ratio: 2),(min-resolution: 192dpi){.info-panel:before{height:3px}}@media (prefers-reduced-motion: reduce){.wrapped-slide{transition:opacity .2s ease;transform:none!important}.wrapped-slide.active,.wrapped-slide.exiting{transform:none!important}.wrapped-big-number{animation:none}.info-panel{transition:transform .2s ease}}
