: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);--color-success: #4CAF50;--color-periwinkle-bright: #E0E0FF;--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}[hidden]{display:none!important}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__right{display:flex;align-items:center;gap:var(--spacing-md)}.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;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-md) var(--spacing-lg);background:var(--color-periwinkle);border:2px solid var(--color-periwinkle);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);z-index:100;box-shadow:0 4px 20px #ccccff4d;animation:cta-pulse 2s ease-in-out infinite}.add-photos-btn:hover{background:var(--color-text);border-color:var(--color-text);color:var(--color-bg);transform:translateY(-2px);box-shadow:0 6px 25px #ccccff80}.add-photos-btn svg{width:18px;height:18px}@keyframes cta-pulse{0%,to{box-shadow:0 4px 20px #ccccff4d}50%{box-shadow:0 4px 30px #ccccff80}}.add-photos-btn[hidden]{display:none}.add-photos-btn.faded{opacity:0;pointer-events:none;transition:opacity .3s ease}.wrapped-modal{position:fixed;inset:0;z-index:1000;display:flex;align-items:center;justify-content:center}.wrapped-modal[hidden]{display:none}.wrapped-modal__backdrop{position:absolute;inset: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;inset: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;inset:0;z-index:1100;display:flex;align-items:center;justify-content:center}.feedback-modal[hidden]{display:none}.feedback-modal__backdrop{position:absolute;inset: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)}.demo-badge{position:absolute;top:var(--spacing-md);left:50%;transform:translate(-50%);z-index:100;background:linear-gradient(135deg,#3d1a39fa,#1a0a18fa);border:2px solid var(--color-periwinkle);border-radius:var(--radius-lg);padding:var(--spacing-md) var(--spacing-lg);box-shadow:0 4px 30px #ccccff4d,0 0 60px #ccccff1a,inset 0 1px #ffffff1a;max-width:400px;opacity:0;transition:opacity .4s ease-out,transform .4s ease-out}.demo-badge.visible{opacity:1;animation:demoBadgeGlow 3s ease-in-out infinite}@keyframes demoBadgeGlow{0%,to{box-shadow:0 4px 30px #ccccff4d,0 0 60px #ccccff1a,inset 0 1px #ffffff1a}50%{box-shadow:0 4px 40px #ccf6,0 0 80px #ccf3,inset 0 1px #ffffff26}}.demo-badge__content{display:flex;flex-direction:column;align-items:center;gap:var(--spacing-sm);text-align:center}.demo-badge__hero{display:flex;align-items:center;gap:var(--spacing-sm)}.demo-badge__icon{font-size:32px;animation:hatBounce 2s ease-in-out infinite}@keyframes hatBounce{0%,to{transform:translateY(0) rotate(0)}25%{transform:translateY(-3px) rotate(-5deg)}75%{transform:translateY(-3px) rotate(5deg)}}.demo-badge__title-group{display:flex;flex-direction:column;align-items:flex-start}.demo-badge__eyebrow{font-size:9px;font-weight:600;color:var(--color-periwinkle-dim);letter-spacing:3px;text-transform:uppercase}.demo-badge__title{font-size:16px;font-weight:700;color:var(--color-periwinkle);letter-spacing:1px;line-height:1.2}.demo-badge__details{display:flex;flex-direction:column;gap:4px;padding-top:var(--spacing-xs);border-top:1px solid var(--color-border);width:100%}.demo-badge__traveler{font-size:11px;color:var(--color-text);font-style:italic}.demo-badge__cta{font-size:10px;color:var(--color-periwinkle);font-weight:500;opacity:.8}.demo-badge[hidden]{display:none}.demo-badge.fading{opacity:0;transform:translate(-50%) translateY(-20px) scale(.95);pointer-events:none;transition:opacity .4s ease,transform .4s ease}.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;will-change:transform;transform:translateZ(0)}#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);user-select:none}.globe-marker-hitarea{cursor:pointer}.globe-marker-ring{pointer-events:none}.globe-marker-city{pointer-events:none;user-select:none}@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)}.globe-tooltip.has-thumbnails{white-space:normal;min-width:120px;max-width:200px;padding:var(--spacing-sm)}.globe-tooltip__thumbnails{display:grid;grid-template-columns:repeat(2,1fr);gap:4px;margin-bottom:var(--spacing-sm);border-radius:var(--radius-sm);overflow:hidden}.globe-tooltip__thumb{width:100%;aspect-ratio:1;object-fit:cover;border-radius:2px;background:var(--color-bg)}.globe-tooltip__more{font-size:10px;color:var(--color-text-dim);text-align:center;margin-bottom:var(--spacing-xs)}.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;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;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)}.flying-plane{pointer-events:none;filter:drop-shadow(0 2px 4px rgba(0,0,0,.3))}.flying-plane circle{filter:drop-shadow(0 0 6px rgba(255,255,255,.8))}.flying-plane text{font-size:12px}@keyframes pathPulse{0%,to{opacity:.8;stroke-width:3}50%{opacity:1;stroke-width:4}}.path-layer path{pointer-events:none}.plane-layer{pointer-events:none}.path-layer circle{filter:drop-shadow(0 1px 3px rgba(0,0,0,.3))}.path-layer text{pointer-events:none;user-select:none}.playback-progress{position:absolute;bottom:80px;left:50%;transform:translate(-50%);display:flex;align-items:center;gap:4px;z-index:15}.playback-progress__dot{width:8px;height:8px;border-radius:50%;background:#ccccff4d;transition:all .3s ease}.playback-progress__dot.visited{background:var(--color-periwinkle)}.playback-progress__dot.current{background:#fff;transform:scale(1.3);box-shadow:0 0 10px #fffc}.playback-info.animating{background:#1a0a18f2;border-color:var(--color-periwinkle);box-shadow:0 0 20px #ccccff4d}.playback-info.animating .playback-info__location{animation:locationPulse 2s ease-in-out infinite}@keyframes locationPulse{0%,to{text-shadow:0 0 0 transparent}50%{text-shadow:0 0 10px rgba(204,204,255,.5)}}.playback-controls__export{margin-left:var(--spacing-sm);padding-left:var(--spacing-sm);border-left:1px solid var(--color-border);display:flex;gap:var(--spacing-xs)}.view-toggle-btn,.export-gif-btn{display:flex;align-items:center;gap:4px;padding:var(--spacing-xs) var(--spacing-sm);border-radius:var(--radius-sm);font-family:var(--font-mono);font-size:11px;font-weight:600;cursor:pointer;transition:all var(--transition-fast)}.export-gif-btn{background:#4caf5033;border:1px solid rgba(76,175,80,.4);color:#81c784}.view-toggle-btn{background:#ccf3;border:1px solid rgba(204,204,255,.4);color:var(--color-periwinkle)}.view-toggle-btn:hover:not(:disabled){background:#ccccff4d;border-color:#ccf9}.view-toggle-btn.active{background:#ccf6;border-color:var(--color-periwinkle);color:#fff}.export-gif-btn:hover:not(:disabled){background:#4caf504d;border-color:#4caf5099}.view-toggle-btn:disabled,.export-gif-btn:disabled{opacity:.5;cursor:not-allowed}.view-toggle-btn svg,.export-gif-btn svg{width:14px;height:14px}.gif-export-modal{position:fixed;inset:0;z-index:1000;display:flex;align-items:center;justify-content:center;background:#000c;backdrop-filter:blur(4px)}.gif-export-modal[hidden]{display:none}.gif-export-modal__content{background:var(--color-bg);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--spacing-xl);text-align:center;min-width:280px}.gif-export-modal__spinner{width:48px;height:48px;border:3px solid var(--color-periwinkle-dim);border-top-color:var(--color-periwinkle);border-radius:50%;margin:0 auto var(--spacing-md);animation:spin 1s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.gif-export-modal__status{font-size:14px;color:var(--color-text);margin-bottom:var(--spacing-md)}.gif-export-modal__progress{width:100%;height:6px;background:var(--color-bg-secondary);border-radius:3px;overflow:hidden;margin-bottom:var(--spacing-lg)}.gif-export-modal__progress-bar{height:100%;background:var(--color-periwinkle);border-radius:3px;width:0%;transition:width .3s ease}.gif-export-modal__cancel{padding:var(--spacing-sm) var(--spacing-lg);background:none;border:1px solid var(--color-border);border-radius:var(--radius-sm);color:var(--color-text);font-family:inherit;font-size:13px;cursor:pointer;transition:all var(--transition-fast)}.gif-export-modal__cancel:hover{background:#ffffff1a}.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__header,.info-panel__handle{display:none}.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}.fun-facts{margin-top:var(--spacing-md)}.fun-facts__toggle{width:100%;display:flex;align-items:center;justify-content:space-between;padding:var(--spacing-sm) 0;background:none;border:none;cursor:pointer;color:var(--color-periwinkle)}.fun-facts__title{font-size:11px;font-weight:700;letter-spacing:1px}.fun-facts__chevron{width:16px;height:16px;transition:transform var(--transition-fast)}.fun-facts.collapsed .fun-facts__chevron{transform:rotate(-90deg)}.fun-facts__content{display:flex;flex-direction:column;gap:var(--spacing-xs);padding-top:var(--spacing-sm);overflow:hidden;transition:max-height var(--transition-normal),opacity var(--transition-fast);max-height:500px;opacity:1}.fun-facts.collapsed .fun-facts__content{max-height:0;opacity:0;padding-top:0}.fun-fact{display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-sm) var(--spacing-md);background:#3d1a394d;border-radius:var(--radius-sm);border:1px solid transparent;transition:all var(--transition-fast)}.fun-fact:hover{background:#3d1a3980;border-color:var(--color-border)}.fun-fact__icon{font-size:16px;flex-shrink:0;width:24px;text-align:center}.fun-fact__info{flex:1;min-width:0;display:flex;flex-direction:column;gap:2px}.fun-fact__label{font-size:10px;color:var(--color-text-dim);text-transform:uppercase;letter-spacing:.5px}.fun-fact__value{font-size:12px;color:var(--color-text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.date-filter{margin-top:var(--spacing-md)}.date-range-filter{display:flex;flex-direction:column;gap:var(--spacing-md)}.date-range-filter__labels{display:flex;align-items:center;justify-content:space-between;gap:var(--spacing-sm);font-size:11px}.date-range-filter__start,.date-range-filter__end{color:var(--color-periwinkle);font-weight:600;min-width:80px}.date-range-filter__end{text-align:right}.date-range-filter__separator{color:var(--color-text-dim);font-size:10px}.date-range-filter__slider-container{position:relative;height:24px}.date-range-filter__track{position:absolute;top:50%;left:0;right:0;height:6px;background:#3d1a3980;border-radius:3px;transform:translateY(-50%)}.date-range-filter__range{position:absolute;height:100%;background:var(--color-periwinkle);border-radius:3px;opacity:.6}.date-range-filter__input{position:absolute;top:0;left:0;width:100%;height:100%;-webkit-appearance:none;appearance:none;background:transparent;pointer-events:none;margin:0}.date-range-filter__input::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;width:18px;height:18px;background:var(--color-periwinkle);border:2px solid var(--color-bg);border-radius:50%;cursor:pointer;pointer-events:auto;box-shadow:0 2px 4px #0000004d;transition:transform var(--transition-fast),background var(--transition-fast)}.date-range-filter__input::-moz-range-thumb{width:18px;height:18px;background:var(--color-periwinkle);border:2px solid var(--color-bg);border-radius:50%;cursor:pointer;pointer-events:auto;box-shadow:0 2px 4px #0000004d;transition:transform var(--transition-fast),background var(--transition-fast)}.date-range-filter__input::-webkit-slider-thumb:hover{transform:scale(1.15);background:#e0e0ff}.date-range-filter__input::-moz-range-thumb:hover{transform:scale(1.15);background:#e0e0ff}.date-range-filter__info{display:flex;align-items:center;justify-content:space-between}.date-range-filter__count{font-size:10px;color:var(--color-text-dim)}.date-range-filter__reset{background:none;border:1px solid var(--color-periwinkle-dim);color:var(--color-periwinkle);font-family:var(--font-mono);font-size:10px;padding:4px 8px;border-radius:var(--radius-sm);cursor:pointer;transition:all var(--transition-fast)}.date-range-filter__reset:hover{background:var(--color-periwinkle);color:var(--color-bg)}.date-range-filter__reset[hidden]{display:none}.trip-filter{margin-top:var(--spacing-md)}.trip-list{display:flex;flex-direction:column;gap:var(--spacing-sm);max-height:200px;overflow-y:auto}.trip-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)}.trip-item:hover{background:#3d1a3980;border-color:var(--color-border)}.trip-item input{display:none}.trip-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)}.trip-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)}.trip-item input:checked+.trip-item__radio{border-color:var(--color-periwinkle)}.trip-item input:checked+.trip-item__radio:after{transform:translate(-50%,-50%) scale(1)}.trip-item__color{width:12px;height:12px;border-radius:50%;flex-shrink:0}.trip-item__info{flex:1;min-width:0;display:flex;flex-direction:column;gap:2px}.trip-item__name{flex:1;font-size:12px;color:var(--color-text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.trip-item__dates{font-size:10px;color:var(--color-text-dim)}.trip-item__count{font-size:11px;color:var(--color-text-dim);flex-shrink:0}.trip-gap-control{margin-top:var(--spacing-md);padding-top:var(--spacing-md);border-top:1px solid var(--color-border)}.trip-gap-control__label{display:flex;align-items:center;justify-content:space-between;font-size:10px;color:var(--color-text-dim);margin-bottom:var(--spacing-xs)}.trip-gap-control__value{color:var(--color-periwinkle);font-weight:600}.trip-gap-control__slider{width:100%;-webkit-appearance:none;appearance:none;height:4px;background:#3d1a3980;border-radius:2px;outline:none}.trip-gap-control__slider::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;width:14px;height:14px;background:var(--color-periwinkle);border-radius:50%;cursor:pointer;transition:transform var(--transition-fast)}.trip-gap-control__slider::-moz-range-thumb{width:14px;height:14px;background:var(--color-periwinkle);border:none;border-radius:50%;cursor:pointer}.trip-gap-control__slider::-webkit-slider-thumb:hover{transform:scale(1.15)}.trip-gap-control__slider::-moz-range-thumb:hover{transform:scale(1.15)}@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)}}.color-by-device-toggle{margin-top:12px;padding-top:12px;border-top:1px solid var(--color-border)}.toggle-switch{display:flex;align-items:center;gap:10px;cursor:pointer;user-select:none}.toggle-switch input{display:none}.toggle-slider{position:relative;width:36px;height:20px;background:var(--color-bg-tertiary);border-radius:10px;transition:background var(--transition-fast)}.toggle-slider:before{content:"";position:absolute;top:2px;left:2px;width:16px;height:16px;background:var(--color-text-muted);border-radius:50%;transition:transform var(--transition-fast),background var(--transition-fast)}.toggle-switch input:checked+.toggle-slider{background:var(--color-periwinkle)}.toggle-switch input:checked+.toggle-slider:before{transform:translate(16px);background:var(--color-bg-primary)}.toggle-label{font-size:12px;color:var(--color-text-secondary)}.device-legend{margin-top:12px;display:flex;flex-direction:column;gap:6px}.device-legend-item{display:flex;align-items:center;gap:8px;font-size:11px;color:var(--color-text-secondary)}.device-legend-color{width:12px;height:12px;border-radius:50%;flex-shrink:0;border:1px solid rgba(255,255,255,.2)}.device-legend-name{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.device-legend-multi{font-style:italic;color:var(--color-text-muted)}.upload-zone{position:absolute;bottom:var(--spacing-lg);left:50%;transform:translate(-50%);width:90%;max-width:520px;background:#1a0a18e6;border:2px dashed var(--color-border);border-radius:var(--radius-lg);padding:var(--spacing-md) var(--spacing-lg);text-align:center;cursor:pointer;transition:all var(--transition-normal);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:40px;height:40px;color:var(--color-periwinkle);margin-bottom:var(--spacing-xs)}.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__text--mobile,.upload-zone__subtext--mobile{display:none}.upload-zone__privacy{display:flex;align-items:center;justify-content:center;gap:var(--spacing-sm);margin-top: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;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[hidden]{display:none!important}.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)}.upload-zone__divider{display:flex;align-items:center;width:100%;margin:var(--spacing-sm) 0;gap:var(--spacing-md)}.upload-zone__divider:before,.upload-zone__divider:after{content:"";flex:1;height:1px;background:var(--color-border)}.upload-zone__divider span{font-size:11px;color:var(--color-text-dim);text-transform:uppercase;letter-spacing:1px}.google-drive-btn{display:flex;align-items:center;justify-content:center;gap:var(--spacing-sm);width:100%;padding:var(--spacing-sm) var(--spacing-md);background:#4285f426;border:1px solid rgba(66,133,244,.4);border-radius:var(--radius-sm);color:#8ab4f8;font-family:inherit;font-size:13px;font-weight:500;cursor:pointer;transition:all var(--transition-fast);pointer-events:auto}.google-drive-btn:hover:not(:disabled){background:#4285f440;border-color:#4285f499}.google-drive-btn:active:not(:disabled){transform:scale(.98)}.google-drive-btn:disabled{opacity:.7;cursor:not-allowed}.google-drive-btn__icon{width:18px;height:18px;flex-shrink:0}.google-drive-btn.loading{background:#4285f41a}.google-drive-btn__spinner{width:16px;height:16px;flex-shrink:0;animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.google-photos-btn{display:flex;align-items:center;justify-content:center;gap:var(--spacing-sm);width:100%;padding:var(--spacing-sm) var(--spacing-md);margin-top:var(--spacing-xs);background:#ea433526;border:1px solid rgba(234,67,53,.4);border-radius:var(--radius-sm);color:#f28b82;font-family:inherit;font-size:13px;font-weight:500;cursor:pointer;transition:all var(--transition-fast);pointer-events:auto}.google-photos-btn:hover:not(:disabled){background:#ea433540;border-color:#ea433599}.google-photos-btn:active:not(:disabled){transform:scale(.98)}.google-photos-btn:disabled{opacity:.7;cursor:not-allowed}.google-photos-btn__icon{width:18px;height:18px;flex-shrink:0}.google-photos-btn.loading{background:#ea43351a}.google-photos-btn__spinner{width:16px;height:16px;flex-shrink:0;animation:spin 1s linear infinite}.google-photos-modal{position:fixed;inset:0;z-index:1000;display:flex;align-items:center;justify-content:center}.google-photos-modal__backdrop{position:absolute;inset:0;background:#000c;backdrop-filter:blur(4px)}.google-photos-modal__content{position:relative;width:90%;max-width:800px;max-height:80vh;background:var(--color-bg);border:1px solid var(--color-border);border-radius:var(--radius-lg);display:flex;flex-direction:column;overflow:hidden}.google-photos-modal__header{display:flex;align-items:center;justify-content:space-between;padding:var(--spacing-md) var(--spacing-lg);border-bottom:1px solid var(--color-border)}.google-photos-modal__title{margin:0;font-size:18px;font-weight:600;color:var(--color-text)}.google-photos-modal__close{width:32px;height:32px;border:none;background:none;color:var(--color-text-dim);font-size:24px;cursor:pointer;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-sm);transition:all var(--transition-fast)}.google-photos-modal__close:hover{background:#ffffff1a;color:var(--color-text)}.google-photos-modal__body{flex:1;overflow-y:auto;padding:var(--spacing-md)}.google-photos-modal__grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(100px,1fr));gap:var(--spacing-sm)}.google-photos-modal__item{position:relative;aspect-ratio:1;border-radius:var(--radius-sm);overflow:hidden;cursor:pointer;border:2px solid transparent;transition:all var(--transition-fast)}.google-photos-modal__item img{width:100%;height:100%;object-fit:cover}.google-photos-modal__item:hover{border-color:var(--color-periwinkle-dim)}.google-photos-modal__item.selected{border-color:var(--color-periwinkle)}.google-photos-modal__check{position:absolute;top:4px;right:4px;width:24px;height:24px;background:var(--color-periwinkle);border-radius:50%;display:flex;align-items:center;justify-content:center;opacity:0;transform:scale(.8);transition:all var(--transition-fast)}.google-photos-modal__item.selected .google-photos-modal__check{opacity:1;transform:scale(1)}.google-photos-modal__check svg{width:14px;height:14px;color:var(--color-bg)}.google-photos-modal__loading{display:flex;align-items:center;justify-content:center;gap:var(--spacing-sm);padding:var(--spacing-lg);color:var(--color-text-dim);font-size:13px}.google-photos-modal__spinner{width:16px;height:16px;border:2px solid var(--color-periwinkle-dim);border-top-color:var(--color-periwinkle);border-radius:50%;animation:spin 1s linear infinite}.google-photos-modal__empty,.google-photos-modal__error{text-align:center;padding:var(--spacing-xl);color:var(--color-text-dim)}.google-photos-modal__error{color:#ff6b6b}.google-photos-modal__footer{display:flex;align-items:center;justify-content:space-between;padding:var(--spacing-md) var(--spacing-lg);border-top:1px solid var(--color-border);background:#1a0a1880}.google-photos-modal__count{font-size:13px;color:var(--color-text-dim)}.google-photos-modal__actions{display:flex;gap:var(--spacing-sm)}.google-photos-modal__btn{padding:var(--spacing-sm) var(--spacing-lg);border-radius:var(--radius-sm);font-family:inherit;font-size:13px;font-weight:500;cursor:pointer;transition:all var(--transition-fast)}.google-photos-modal__btn--cancel{background:none;border:1px solid var(--color-border);color:var(--color-text)}.google-photos-modal__btn--cancel:hover{background:#ffffff1a}.google-photos-modal__btn--import{background:var(--color-periwinkle);border:1px solid var(--color-periwinkle);color:var(--color-bg)}.google-photos-modal__btn--import:hover:not(:disabled){background:#e0e0ff}.google-photos-modal__btn--import:disabled{opacity:.5;cursor:not-allowed}@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}.header__right{flex-shrink:0;gap:var(--spacing-xs)}.header__status{display:none}.sign-in-btn{padding:6px 10px;font-size:10px}.sign-in-btn svg{width:14px;height:14px}.sign-in-btn span{display:none}.user-menu__trigger{padding:4px}.user-menu__avatar{width:24px;height:24px}.user-menu__chevron{display:none}.user-menu__dropdown{width:calc(100vw - 32px);max-width:300px;right:8px}.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{display:none}.info-panel__header{display:flex;justify-content:center;align-items:center;padding:var(--spacing-md);cursor:pointer;-webkit-tap-highlight-color:transparent;min-height:44px}.info-panel__handle{display:block;width:40px;height:4px;background:var(--color-border);border-radius:2px}.info-panel__content{padding:0 var(--spacing-md) var(--spacing-lg)}.info-panel__title{font-size:12px;text-align:center;margin-bottom:var(--spacing-md);padding-bottom:var(--spacing-md);border-bottom:1px solid var(--color-border)}.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__text--desktop,.upload-zone__subtext--desktop{display:none!important}.upload-zone__text--mobile,.upload-zone__subtext--mobile{display:block!important}.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)}.demo-badge{top:var(--spacing-sm);right:var(--spacing-sm);left:auto;transform:none;padding:var(--spacing-sm);max-width:200px}.demo-badge__hero{gap:var(--spacing-xs)}.demo-badge__icon{font-size:20px}.demo-badge__eyebrow{font-size:7px;letter-spacing:2px}.demo-badge__title{font-size:11px}.demo-badge__details{padding-top:var(--spacing-xs)}.demo-badge__traveler{font-size:9px}.demo-badge__cta{font-size:8px}.demo-badge.fading{opacity:0;transform:translateY(-20px) scale(.95);pointer-events:none}.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;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}}.auth-modal{position:fixed;inset:0;z-index:1000;display:flex;align-items:center;justify-content:center;padding:16px}.auth-modal__backdrop{position:absolute;inset:0;background:#000000bf;backdrop-filter:blur(4px)}.auth-modal__content{position:relative;width:100%;max-width:420px;background:linear-gradient(135deg,var(--color-dark-plum) 0%,var(--color-bg) 100%);border:1px solid var(--color-periwinkle-dim);border-radius:16px;padding:32px;box-shadow:0 24px 48px #0006;animation:auth-modal-enter .3s ease}@keyframes auth-modal-enter{0%{opacity:0;transform:scale(.95) translateY(10px)}to{opacity:1;transform:scale(1) translateY(0)}}.auth-modal__close{position:absolute;top:16px;right:16px;width:32px;height:32px;border:none;background:transparent;color:var(--color-periwinkle-dim);font-size:24px;cursor:pointer;display:flex;align-items:center;justify-content:center;border-radius:50%;transition:all .2s ease}.auth-modal__close:hover{background:#ccccff1a;color:var(--color-periwinkle)}.auth-modal__header{text-align:center;margin-bottom:24px}.auth-modal__title{font-family:var(--font-mono);font-size:20px;font-weight:600;color:var(--color-periwinkle);margin:0 0 8px;letter-spacing:.5px}.auth-modal__subtitle{font-size:14px;color:var(--color-periwinkle-dim);margin:0}.auth-modal__privacy{display:flex;align-items:center;gap:10px;padding:12px 16px;background:#0003;border-radius:8px;margin-bottom:24px}.auth-modal__privacy-icon{width:20px;height:20px;flex-shrink:0;color:var(--color-success)}.auth-modal__privacy span{font-size:12px;color:var(--color-periwinkle-dim);line-height:1.4}.auth-modal__buttons{display:flex;flex-direction:column;gap:16px}.auth-modal__buttons.hidden{display:none}.auth-modal__btn{display:flex;align-items:center;justify-content:center;gap:12px;width:100%;padding:14px 20px;border:none;border-radius:8px;font-family:var(--font-mono);font-size:14px;font-weight:500;cursor:pointer;transition:all .2s ease}.auth-modal__btn-icon{width:20px;height:20px;flex-shrink:0}.auth-modal__btn--google{background:#fff;color:#1a1a1a}.auth-modal__btn--google:hover{background:#f5f5f5;box-shadow:0 2px 8px #0003}.auth-modal__btn--email{background:var(--color-periwinkle);color:var(--color-bg)}.auth-modal__btn--email:hover{background:var(--color-periwinkle-bright)}.auth-modal__btn--secondary{background:transparent;border:1px solid var(--color-periwinkle-dim);color:var(--color-periwinkle)}.auth-modal__btn--secondary:hover{background:#ccccff1a}.auth-modal__divider{display:flex;align-items:center;gap:16px;color:var(--color-periwinkle-dim);font-size:12px;text-transform:uppercase;letter-spacing:1px}.auth-modal__divider:before,.auth-modal__divider:after{content:"";flex:1;height:1px;background:var(--color-periwinkle-dim);opacity:.3}.auth-modal__email-form{display:flex;flex-direction:column;gap:12px}.auth-modal__input{width:100%;padding:14px 16px;background:#0000004d;border:1px solid var(--color-periwinkle-dim);border-radius:8px;font-family:var(--font-mono);font-size:14px;color:var(--color-periwinkle);outline:none;transition:all .2s ease}.auth-modal__input:focus{border-color:var(--color-periwinkle);box-shadow:0 0 0 3px #ccccff1a}.auth-modal__input::placeholder{color:var(--color-periwinkle-dim);opacity:.6}.auth-modal__email-note{font-size:12px;color:var(--color-periwinkle-dim);text-align:center;margin:0}.auth-modal__magic-link-sent{text-align:center;padding:20px 0}.auth-modal__success-icon{width:64px;height:64px;margin:0 auto 16px;color:var(--color-success)}.auth-modal__success-icon svg{width:100%;height:100%}.auth-modal__magic-link-sent h3{font-family:var(--font-mono);font-size:18px;color:var(--color-periwinkle);margin:0 0 12px}.auth-modal__magic-link-sent p{font-size:14px;color:var(--color-periwinkle-dim);margin:0 0 8px}.auth-modal__magic-link-sent strong{color:var(--color-periwinkle)}.auth-modal__magic-link-sent .auth-modal__btn--secondary{margin-top:20px}.auth-modal__loading{display:flex;flex-direction:column;align-items:center;gap:16px;padding:40px 0}.auth-modal__spinner{width:40px;height:40px;border:3px solid var(--color-periwinkle-dim);border-top-color:var(--color-periwinkle);border-radius:50%;animation:auth-spinner 1s linear infinite}@keyframes auth-spinner{to{transform:rotate(360deg)}}.auth-modal__loading p{font-size:14px;color:var(--color-periwinkle-dim);margin:0}.auth-modal__error{margin-top:16px;padding:12px 16px;background:#ff6b6b1a;border:1px solid rgba(255,107,107,.3);border-radius:8px}.auth-modal__error p{font-size:13px;color:#ff6b6b;margin:0;text-align:center}.auth-modal__skip{text-align:center;margin-top:24px;padding-top:16px;border-top:1px solid rgba(204,204,255,.1)}.auth-modal__skip-btn{background:none;border:none;color:var(--color-periwinkle-dim);font-family:var(--font-mono);font-size:13px;cursor:pointer;padding:8px 16px;border-radius:4px;transition:all .2s ease}.auth-modal__skip-btn:hover{color:var(--color-periwinkle);background:#ccccff1a}.user-menu{position:relative}.user-menu__trigger{display:flex;align-items:center;gap:8px;padding:6px 10px 6px 6px;background:#ccccff1a;border:1px solid var(--color-periwinkle-dim);border-radius:24px;cursor:pointer;transition:all .2s ease}.user-menu__trigger:hover{background:#ccccff26;border-color:var(--color-periwinkle)}.user-menu__avatar{width:28px;height:28px;border-radius:50%;object-fit:cover}.user-menu__chevron{width:16px;height:16px;color:var(--color-periwinkle-dim);transition:transform .2s ease}.user-menu__dropdown{position:absolute;top:calc(100% + 8px);right:0;width:280px;background:var(--color-dark-plum);border:1px solid var(--color-periwinkle-dim);border-radius:12px;box-shadow:0 8px 32px #0006;overflow:hidden;z-index:100;animation:user-menu-enter .2s ease}@keyframes user-menu-enter{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.user-menu__header{display:flex;align-items:center;gap:12px;padding:16px;background:#0003}.user-menu__dropdown-avatar{width:40px;height:40px;border-radius:50%;object-fit:cover}.user-menu__user-info{display:flex;flex-direction:column;gap:2px;min-width:0}.user-menu__name{font-family:var(--font-mono);font-size:14px;font-weight:500;color:var(--color-periwinkle);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.user-menu__email{font-size:12px;color:var(--color-periwinkle-dim);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.user-menu__divider{height:1px;background:var(--color-periwinkle-dim);opacity:.2;margin:0}.user-menu__nav{padding:8px}.user-menu__item{display:flex;align-items:center;gap:12px;width:100%;padding:10px 12px;background:none;border:none;border-radius:8px;font-family:var(--font-mono);font-size:13px;color:var(--color-periwinkle);cursor:pointer;text-align:left;transition:all .2s ease}.user-menu__item:hover{background:#ccccff1a}.user-menu__item svg{width:18px;height:18px;flex-shrink:0;color:var(--color-periwinkle-dim)}.user-menu__item--danger{color:#ff6b6b}.user-menu__item--danger svg{color:#ff6b6b}.user-menu__item--danger:hover{background:#ff6b6b1a}.user-menu__badge{margin-left:auto;padding:2px 8px;background:var(--color-periwinkle);color:var(--color-bg);font-size:11px;font-weight:600;border-radius:10px}.sign-in-btn{display:flex;align-items:center;gap:8px;padding:8px 16px;background:transparent;border:1px solid var(--color-periwinkle-dim);border-radius:20px;color:var(--color-periwinkle);font-family:var(--font-mono);font-size:12px;cursor:pointer;transition:all .2s ease}.sign-in-btn:hover{background:#ccccff1a;border-color:var(--color-periwinkle)}.sign-in-btn svg{width:16px;height:16px}@media(max-width:480px){.auth-modal__content{padding:24px 20px;border-radius:12px;margin:0;max-height:calc(100vh - 32px);overflow-y:auto}.auth-modal__title{font-size:18px}.auth-modal__btn{padding:12px 16px;font-size:13px}.user-menu__dropdown{width:260px;right:-8px}}.invite-modal{position:fixed;inset:0;z-index:1000;display:flex;align-items:center;justify-content:center;padding:16px}.invite-modal__backdrop{position:absolute;inset:0;background:#000000bf;backdrop-filter:blur(4px)}.invite-modal__content{position:relative;width:100%;max-width:440px;background:linear-gradient(135deg,var(--color-dark-plum) 0%,var(--color-bg) 100%);border:1px solid var(--color-periwinkle-dim);border-radius:16px;padding:32px;box-shadow:0 24px 48px #0006;animation:auth-modal-enter .3s ease;max-height:calc(100vh - 32px);overflow-y:auto}.invite-modal__close{position:absolute;top:16px;right:16px;width:32px;height:32px;border:none;background:transparent;color:var(--color-periwinkle-dim);font-size:24px;cursor:pointer;display:flex;align-items:center;justify-content:center;border-radius:50%;transition:all .2s ease}.invite-modal__close:hover{background:#ccccff1a;color:var(--color-periwinkle)}.invite-modal__header{text-align:center;margin-bottom:20px}.invite-modal__title{font-family:var(--font-mono);font-size:20px;font-weight:600;color:var(--color-periwinkle);margin:0 0 8px}.invite-modal__subtitle{font-size:14px;color:var(--color-periwinkle-dim);margin:0}.invite-modal__passport-info{display:flex;align-items:center;gap:8px;padding:12px 16px;background:#0003;border-radius:8px;margin-bottom:20px}.invite-modal__passport-label{font-size:12px;color:var(--color-periwinkle-dim)}.invite-modal__passport-title{font-size:14px;font-weight:500;color:var(--color-periwinkle)}.invite-modal__form{display:flex;flex-direction:column;gap:16px}.invite-modal__form.hidden{display:none}.invite-modal__form-group{display:flex;flex-direction:column;gap:8px}.invite-modal__label{font-size:12px;font-weight:500;color:var(--color-periwinkle-dim);text-transform:uppercase;letter-spacing:1px}.invite-modal__input{width:100%;padding:14px 16px;background:#0000004d;border:1px solid var(--color-periwinkle-dim);border-radius:8px;font-family:var(--font-mono);font-size:14px;color:var(--color-periwinkle);outline:none;transition:all .2s ease}.invite-modal__input:focus{border-color:var(--color-periwinkle);box-shadow:0 0 0 3px #ccccff1a}.invite-modal__input::placeholder{color:var(--color-periwinkle-dim);opacity:.6}.invite-modal__privacy{display:flex;align-items:flex-start;gap:10px;padding:12px 16px;background:#0003;border-radius:8px}.invite-modal__privacy-icon{width:18px;height:18px;flex-shrink:0;color:var(--color-success);margin-top:2px}.invite-modal__privacy span{font-size:12px;color:var(--color-periwinkle-dim);line-height:1.4}.invite-modal__btn{display:flex;align-items:center;justify-content:center;gap:10px;width:100%;padding:14px 20px;border:none;border-radius:8px;font-family:var(--font-mono);font-size:14px;font-weight:500;cursor:pointer;transition:all .2s ease}.invite-modal__btn svg{width:18px;height:18px}.invite-modal__btn--primary{background:var(--color-periwinkle);color:var(--color-bg)}.invite-modal__btn--primary:hover{background:var(--color-periwinkle-bright)}.invite-modal__btn--secondary{background:transparent;border:1px solid var(--color-periwinkle-dim);color:var(--color-periwinkle)}.invite-modal__btn--secondary:hover{background:#ccccff1a}.invite-modal__loading{display:flex;flex-direction:column;align-items:center;gap:16px;padding:40px 0}.invite-modal__spinner{width:40px;height:40px;border:3px solid var(--color-periwinkle-dim);border-top-color:var(--color-periwinkle);border-radius:50%;animation:auth-spinner 1s linear infinite}.invite-modal__loading p{font-size:14px;color:var(--color-periwinkle-dim);margin:0}.invite-modal__success{text-align:center;padding:20px 0}.invite-modal__success-icon{width:64px;height:64px;margin:0 auto 16px;color:var(--color-success)}.invite-modal__success-icon svg{width:100%;height:100%}.invite-modal__success h3{font-family:var(--font-mono);font-size:18px;color:var(--color-periwinkle);margin:0 0 12px}.invite-modal__success p{font-size:14px;color:var(--color-periwinkle-dim);margin:0 0 20px}.invite-modal__error{margin-top:12px;padding:12px 16px;background:#ff6b6b1a;border:1px solid rgba(255,107,107,.3);border-radius:8px}.invite-modal__error p{font-size:13px;color:#ff6b6b;margin:0;text-align:center}.invite-modal__sent{margin-top:24px;padding-top:20px;border-top:1px solid rgba(204,204,255,.1)}.invite-modal__sent-title{font-family:var(--font-mono);font-size:12px;font-weight:600;color:var(--color-periwinkle-dim);text-transform:uppercase;letter-spacing:1px;margin:0 0 12px}.invite-modal__sent-list{display:flex;flex-direction:column;gap:8px}.invite-sent-item{display:flex;align-items:center;justify-content:space-between;padding:10px 12px;background:#0003;border-radius:8px}.invite-sent-item__info{display:flex;flex-direction:column;gap:2px}.invite-sent-item__email{font-size:13px;color:var(--color-periwinkle)}.invite-sent-item__status{font-size:11px;color:var(--color-periwinkle-dim)}.invite-sent-item__cancel{width:28px;height:28px;background:transparent;border:none;color:var(--color-periwinkle-dim);cursor:pointer;border-radius:4px;display:flex;align-items:center;justify-content:center;transition:all .2s ease}.invite-sent-item__cancel:hover{background:#ff6b6b33;color:#ff6b6b}.invite-sent-item__cancel svg{width:16px;height:16px}.invitation-banner{position:fixed;top:calc(var(--header-height, 50px) + 8px);left:50%;transform:translate(-50%);z-index:900;background:linear-gradient(135deg,var(--color-dark-plum) 0%,rgba(61,26,57,.95) 100%);border:1px solid var(--color-periwinkle);border-radius:12px;padding:12px 16px;box-shadow:0 8px 32px #0006;max-width:calc(100vw - 32px);width:max-content;animation:banner-slide-in .4s ease}@keyframes banner-slide-in{0%{opacity:0;transform:translate(-50%) translateY(-20px)}to{opacity:1;transform:translate(-50%) translateY(0)}}.invitation-banner__content{display:flex;align-items:center;gap:12px}.invitation-banner__icon{width:32px;height:32px;background:#ccccff1a;border-radius:8px;display:flex;align-items:center;justify-content:center;color:var(--color-periwinkle)}.invitation-banner__icon svg{width:18px;height:18px}.invitation-banner__text{display:flex;flex-direction:column;gap:2px}.invitation-banner__title{font-family:var(--font-mono);font-size:13px;font-weight:500;color:var(--color-periwinkle)}.invitation-banner__subtitle{font-size:11px;color:var(--color-periwinkle-dim)}.invitation-banner__actions{display:flex;gap:8px;margin-left:8px}.invitation-banner__btn{padding:6px 12px;border-radius:6px;font-family:var(--font-mono);font-size:12px;font-weight:500;cursor:pointer;transition:all .2s ease}.invitation-banner__btn--accept{background:var(--color-periwinkle);border:none;color:var(--color-bg)}.invitation-banner__btn--accept:hover{background:var(--color-periwinkle-bright)}.invitation-banner__btn--decline{background:transparent;border:1px solid var(--color-periwinkle-dim);color:var(--color-periwinkle-dim)}.invitation-banner__btn--decline:hover{border-color:#ff6b6b;color:#ff6b6b}.invitation-banner__close{position:absolute;top:8px;right:8px;width:20px;height:20px;background:transparent;border:none;color:var(--color-periwinkle-dim);cursor:pointer;display:flex;align-items:center;justify-content:center;border-radius:4px;transition:all .2s ease}.invitation-banner__close:hover{background:#ccccff1a;color:var(--color-periwinkle)}.invitation-banner__close svg{width:14px;height:14px}.invitation-banner__count{position:absolute;top:-6px;right:-6px;background:var(--color-periwinkle);color:var(--color-bg);font-size:10px;font-weight:600;padding:2px 6px;border-radius:10px;min-width:18px;text-align:center}@media(max-width:480px){.invitation-banner{left:16px;right:16px;transform:none;width:auto}.invitation-banner__content{flex-wrap:wrap}.invitation-banner__actions{width:100%;margin-left:0;margin-top:8px}.invitation-banner__btn{flex:1}}
