.poster-builder{--color-bg: #FFFFFF;--color-surface: #F7F5F0;--color-border: #EAE6DD;--color-text-primary: #0E1414;--color-text-secondary: #6B6960;--color-accent: #E4572E;--color-accent-soft: #DCE9E2;--font-display: "Fraunces", "Times New Roman", serif;--font-body: "Inter", sans-serif;--font-mono: "JetBrains Mono", monospace;--radius-sm: 8px;--radius-md: 16px;--radius-lg: 28px;--radius-full: 9999px;--space-xs: 4px;--space-sm: 8px;--space-md: 16px;--space-lg: 24px;--space-xl: 40px;--space-2xl: 64px;--space-3xl: 96px;--transition-fast: .18s cubic-bezier(.22, 1, .36, 1);--transition-base: .32s cubic-bezier(.22, 1, .36, 1);--transition-slow: .6s cubic-bezier(.22, 1, .36, 1);min-height:100vh;background:var(--color-bg);padding:var(--space-lg) 0;font-family:var(--font-body);color:var(--color-text-primary)}.product-header{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:var(--space-lg);padding-bottom:var(--space-lg);border-bottom:1px solid var(--color-border);flex-wrap:wrap;gap:var(--space-md)}.product-header__title{font-family:var(--font-display);font-size:clamp(2rem,4vw,3.5rem);font-weight:400;letter-spacing:-.02em;line-height:1;margin:0;color:var(--color-text-primary)}.product-header__price{font-family:var(--font-display);font-style:italic;font-size:1.5rem;color:var(--color-accent);margin:4px 0 0}.product-header__meta{display:flex;gap:var(--space-sm);flex-wrap:wrap}.product-header__meta .badge{background:var(--color-surface);color:var(--color-text-secondary);border:1px solid var(--color-border);font-family:var(--font-mono);font-size:.6875rem;letter-spacing:.1em;text-transform:uppercase;padding:6px 12px;border-radius:var(--radius-full)}.step-panel__title{font-family:var(--font-display);font-size:1.75rem;font-weight:420;letter-spacing:-.015em;margin-bottom:var(--space-sm);color:var(--color-text-primary)}.step-panel__desc{color:var(--color-text-secondary);font-size:.9375rem;line-height:1.6;margin-bottom:var(--space-lg);max-width:52ch}.poster-fields{display:flex;flex-direction:column;gap:var(--space-md)}.step-indicator{display:flex;align-items:center;justify-content:center;gap:var(--space-sm);margin-bottom:var(--space-xl)}.step-indicator__item{display:flex;align-items:center;gap:var(--space-sm);cursor:pointer;transition:opacity var(--transition-fast)}.step-indicator__dot{width:34px;height:34px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-family:var(--font-mono);font-size:.75rem;font-weight:500;border:1px solid var(--color-border);background:var(--color-bg);color:var(--color-text-secondary);transition:all var(--transition-base)}.step-indicator__item--active .step-indicator__dot{background:var(--color-text-primary);border-color:var(--color-text-primary);color:var(--color-bg)}.step-indicator__item--completed .step-indicator__dot{background:transparent;border-color:var(--color-accent);color:var(--color-accent)}.step-indicator__label{font-family:var(--font-mono);font-size:.6875rem;font-weight:500;text-transform:uppercase;letter-spacing:.1em;color:var(--color-text-secondary)}.step-indicator__item--active .step-indicator__label{color:var(--color-text-primary)}.step-indicator__line{width:48px;height:1px;background:var(--color-border)}.step-indicator__item--completed~.step-indicator__line{background:var(--color-accent)}@media(max-width:768px){.step-indicator__label{display:none}.step-indicator__line{width:24px}}.poster-builder .container{width:100%;max-width:1440px;margin:0 auto;padding:0 24px}.poster-builder__layout{display:grid!important;grid-template-columns:1fr 1fr!important;gap:40px;align-items:start;width:100%}@media(max-width:768px){.poster-builder__layout{grid-template-columns:1fr!important}}.poster-builder__preview{position:sticky;top:var(--space-lg)}.poster-builder__preview-frame{display:flex;justify-content:center;align-items:center;background:transparent;border:none;border-radius:0;padding:0;min-height:auto}@font-face{font-family:Mont;src:url(Mont-Light.ttf) format("truetype");font-weight:400;font-style:normal;font-display:swap}@font-face{font-family:Mont;src:url(Mont-Bold.ttf) format("truetype");font-weight:700;font-style:normal;font-display:swap}@font-face{font-family:Mont;src:url(Mont-ExtraLight.ttf) format("truetype");font-weight:200;font-style:normal;font-display:swap}.poster-frame{box-shadow:0 12px 40px -12px #0e14141f;width:450px;margin:auto;border-radius:0;overflow:hidden}@media(max-width:480px){.poster-frame{width:100%}}.poster-inner{position:relative;width:450px;height:600px;padding:25px;background-color:#fff;overflow:hidden;font-family:Mont,sans-serif;transition:opacity .4s ease}@media(max-width:480px){.poster-inner{width:100%;height:auto;aspect-ratio:3/4;padding:20px}}.poster-logos{position:absolute;top:0;left:0;right:0;z-index:3;pointer-events:none}.poster-logo{position:absolute;height:auto}.poster-logo--left{top:25px;left:25px;width:100px}.poster-logo--right{top:25px;right:25px;width:50px}.poster-topo-bottom{position:absolute;bottom:0;left:0;width:100%;z-index:1}.poster-topo-bottom canvas{width:100%;display:block;height:70px}.poster-map-area{width:100%;height:440px;position:relative}@media(max-width:480px){.poster-map-area{height:320px}}.poster-map-container{position:absolute;top:0;left:0;width:100%;height:100%}.poster-map-container .mapboxgl-canvas{width:100%!important;height:100%!important}.poster-map-container .mapboxgl-control-container{display:none}.mapboxgl-ctrl-logo,.mapboxgl-ctrl-attrib{display:none!important}.poster-topo{position:absolute;bottom:-1px;left:0;width:100%;z-index:1}.poster-topo canvas{width:100%;display:block;height:70px}@media(max-width:480px){.poster-topo canvas{height:80px}}.poster-text-area{position:absolute;height:110px;left:25px;right:25px;bottom:25px;background-color:#fff;color:#000;display:flex;flex-direction:column;justify-content:space-between;font-family:Mont,sans-serif}@media(max-width:480px){.poster-text-area{height:80px;left:20px;right:20px;bottom:20px}}.poster-rotate-text{transform:rotate(-90deg) translateY(100%) translate(100%);position:absolute;bottom:0;right:8px;transform-origin:bottom right;font-weight:700;font-size:12px;margin-right:6px;margin-bottom:1px;font-family:Mont,sans-serif;white-space:nowrap}.poster-race-name{font-size:20px;font-weight:700;line-height:1.1;padding-top:8px;margin:0;font-family:Mont,sans-serif;text-transform:none;letter-spacing:0}.poster-date{font-size:12px;line-height:1.2;margin:0;padding:0}.poster-distance,.poster-hike{font-size:16px;line-height:1.2;margin:0;padding:0}.poster-quote{font-size:12px;line-height:1.1;max-width:60%}.poster-text-right{position:absolute;right:50px;bottom:25px;text-align:right;font-family:Mont,sans-serif;z-index:2}.poster-text-right--no-name{right:25px}@media(max-width:480px){.poster-text-right{right:45px;bottom:20px}.poster-text-right--no-name{right:20px}}.poster-bib{font-size:12px;line-height:1;margin:0;padding:0}.poster-time{font-size:27px;font-weight:700;line-height:1;margin:0;padding:0}@media(max-width:480px){.poster-race-name{font-size:14px;padding-top:6px}.poster-date{font-size:9px}.poster-distance,.poster-hike{font-size:11px}.poster-quote,.poster-bib{font-size:9px}.poster-time{font-size:19px}.poster-rotate-text{font-size:9px;margin-right:4px}.poster-logo--left{width:72px}.poster-logo--right{width:36px}.poster-text-right{right:36px}.poster-text-right--no-name{right:20px}.poster-topo canvas{height:50px}}.poster-builder__controls{display:flex;flex-direction:column;gap:var(--space-lg)}.step-panel{display:none}.step-panel--active{display:block;animation:fadeIn .4s cubic-bezier(.22,1,.36,1)}@keyframes fadeIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.theme-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:var(--space-md)}.theme-card{position:relative;border:1px solid var(--color-border);border-radius:var(--radius-sm);overflow:hidden;cursor:pointer;transition:all var(--transition-base);aspect-ratio:3 / 4;background:var(--color-bg)}.theme-card:hover{border-color:var(--color-text-primary);transform:translateY(-3px);box-shadow:0 12px 24px -12px #0e141426}.theme-card--selected{border-color:var(--color-accent);box-shadow:0 0 0 1px var(--color-accent)}.theme-card__preview{width:100%;height:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--space-md);text-align:center}.theme-card__name{font-family:var(--font-display);font-size:1.125rem;font-weight:450;margin-top:var(--space-sm);letter-spacing:-.01em}.theme-card__badge{position:absolute;top:var(--space-sm);right:var(--space-sm);font-family:var(--font-mono);font-size:.625rem;letter-spacing:.1em;text-transform:uppercase;padding:4px 10px;background:var(--color-text-primary);color:var(--color-bg);border-radius:var(--radius-full)}.gpx-dropzone{border:1.5px dashed var(--color-border);border-radius:var(--radius-md);padding:var(--space-2xl) var(--space-xl);text-align:center;cursor:pointer;transition:all var(--transition-base);position:relative;background:var(--color-surface)}.gpx-dropzone:hover,.gpx-dropzone--drag-over{border-color:var(--color-accent);background:#e4572e0a}.gpx-dropzone--has-file{border-color:var(--color-accent);border-style:solid;background:#e4572e0f}.gpx-dropzone__icon{width:48px;height:48px;margin:0 auto var(--space-md);color:var(--color-text-secondary);opacity:.6}.gpx-dropzone__text{font-size:.9375rem;color:var(--color-text-secondary);margin-bottom:var(--space-sm)}.gpx-dropzone__text strong{color:var(--color-text-primary);font-weight:500}.gpx-dropzone__hint{font-family:var(--font-mono);font-size:.6875rem;letter-spacing:.08em;text-transform:uppercase;color:var(--color-text-secondary);opacity:.7}.gpx-dropzone__filename{font-size:.875rem;font-weight:500;color:var(--color-accent);margin-top:var(--space-sm)}.gpx-dropzone input[type=file]{position:absolute;top:0;right:0;bottom:0;left:0;opacity:0;cursor:pointer}.map-styles{display:flex;gap:var(--space-sm);flex-wrap:wrap}.map-style-btn{width:60px;height:60px;border-radius:var(--radius-sm);border:1px solid var(--color-border);cursor:pointer;overflow:hidden;transition:all var(--transition-fast);background:var(--color-surface);display:flex;align-items:center;justify-content:center;font-family:var(--font-mono);font-size:.55rem;font-weight:500;letter-spacing:.08em;text-transform:uppercase;color:var(--color-text-secondary);padding:0}.map-style-btn:hover{border-color:var(--color-text-primary);transform:translateY(-2px)}.map-style-btn--selected{border-color:var(--color-accent);box-shadow:0 0 0 1px var(--color-accent)}.map-style-btn img{width:100%;height:100%;object-fit:cover}.color-picker{display:flex;gap:var(--space-sm);flex-wrap:wrap}.color-swatch{width:34px;height:34px;border-radius:50%;border:2px solid transparent;cursor:pointer;transition:all var(--transition-fast);position:relative}.color-swatch:hover{transform:scale(1.15)}.color-swatch--selected{border-color:var(--color-text-primary);box-shadow:0 0 0 2px var(--color-bg),0 0 0 3px var(--color-text-primary)}.color-swatch--light{box-shadow:inset 0 0 0 1px #0e14141f}.form-group{display:flex;flex-direction:column;gap:var(--space-xs)}.form-row{display:grid;gap:var(--space-md)}.form-row--2{grid-template-columns:1fr 1fr}.form-row--3{grid-template-columns:1fr 1fr 1fr}.toggle-row{display:flex;align-items:center;justify-content:space-between;padding:var(--space-md);background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-sm)}.toggle-switch{position:relative;width:44px;height:24px}.toggle-switch input{opacity:0;width:0;height:0}.toggle-switch__slider{position:absolute;top:0;right:0;bottom:0;left:0;background:var(--color-border);border-radius:var(--radius-full);cursor:pointer;transition:background var(--transition-fast)}.toggle-switch__slider:before{content:"";position:absolute;width:18px;height:18px;left:3px;top:3px;background:#fff;border-radius:50%;transition:transform var(--transition-fast);box-shadow:0 1px 3px #0e141426}.toggle-switch input:checked+.toggle-switch__slider{background:var(--color-accent)}.toggle-switch input:checked+.toggle-switch__slider:before{transform:translate(20px)}.step-nav{display:flex;gap:var(--space-md);margin-top:var(--space-lg)}.step-nav .btn{flex:1}.summary-card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:var(--space-lg)}.summary-row{display:flex;justify-content:space-between;align-items:center;padding:var(--space-sm) 0;border-bottom:1px solid var(--color-border)}.summary-row:last-child{border-bottom:none}.summary-row__label{font-family:var(--font-mono);font-size:.6875rem;font-weight:500;text-transform:uppercase;letter-spacing:.1em;color:var(--color-text-secondary)}.summary-row__value{font-weight:500;color:var(--color-text-primary)}.summary-price{display:flex;justify-content:space-between;align-items:baseline;margin-top:var(--space-lg);padding-top:var(--space-lg);border-top:1px solid var(--color-border)}.summary-price__label{font-family:var(--font-mono);font-size:.75rem;text-transform:uppercase;letter-spacing:.12em;color:var(--color-text-secondary)}.summary-price__value{font-family:var(--font-display);font-size:2.25rem;font-weight:420;letter-spacing:-.02em;color:var(--color-text-primary)}.gpx-btn-group{display:flex;gap:8px;flex-wrap:wrap}.gpx-btn{flex:1;min-width:80px;padding:14px 12px;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-sm);color:var(--color-text-secondary);font-family:var(--font-body);font-size:.875rem;font-weight:500;text-align:center;cursor:pointer;transition:all .2s ease}.gpx-btn:hover{border-color:var(--color-text-primary);color:var(--color-text-primary);background:var(--color-bg)}.gpx-btn--selected{border-color:var(--color-accent);color:var(--color-text-primary);background:#e4572e0f;box-shadow:0 0 0 1px var(--color-accent)}.gpx-btn__distance{display:block;font-family:var(--font-display);font-size:1.125rem;font-weight:450}.poster-notification{position:fixed;top:0;left:0;right:0;z-index:10000;transform:translateY(-100%);transition:transform .3s cubic-bezier(.22,1,.36,1);font-family:var(--font-body)}.poster-notification--visible{transform:translateY(0)}.poster-notification__content{display:flex;align-items:center;gap:12px;max-width:600px;margin:16px auto;padding:16px 20px;border-radius:var(--radius-sm);font-size:.875rem;line-height:1.4;box-shadow:0 12px 32px -12px #0e141433;border:1px solid var(--color-border)}.poster-notification--error .poster-notification__content{background:#fef5f2;border-color:#f5c7b5;color:#7a2f12}.poster-notification--success .poster-notification__content{background:#f0faf5;border-color:#c7e5d3;color:#1e5937}.poster-notification__icon{font-size:1.1rem;flex-shrink:0}.poster-notification--error .poster-notification__icon{color:#c44218}.poster-notification--success .poster-notification__icon{color:#2e7a4a}.poster-notification__message{flex:1}.poster-notification__close{background:none;border:none;font-size:1.25rem;cursor:pointer;padding:0 4px;line-height:1;opacity:.5;transition:opacity .15s;color:inherit}.poster-notification__close:hover{opacity:1}.poster-builder__loading{position:fixed;top:0;right:0;bottom:0;left:0;background:#ffffffeb;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--space-md);z-index:9999;color:var(--color-text-primary);font-family:var(--font-mono);font-size:.75rem;letter-spacing:.1em;text-transform:uppercase}.preview-toggle,.preview-close{display:none}@media(max-width:768px){.poster-builder{padding:var(--space-sm) 0}.product-header{padding-bottom:var(--space-md);margin-bottom:var(--space-md);gap:var(--space-xs)}.product-header__title{font-size:1.75rem}.product-header__price{font-size:1.125rem}.product-header__meta{gap:6px}.product-header__meta .badge{font-size:.625rem;padding:4px 10px;letter-spacing:.08em}.step-indicator{margin-bottom:var(--space-md);gap:4px}.step-indicator__item{gap:4px}.step-indicator__label{display:none}.step-indicator__dot{width:30px;height:30px;font-size:.75rem}.step-indicator__line{width:18px}.poster-builder__layout{grid-template-columns:1fr!important;gap:var(--space-md)}.poster-builder__preview{position:sticky;top:var(--space-sm);z-index:20;display:block!important;background:var(--color-bg);padding:var(--space-xs) 0;margin:calc(-1 * var(--space-xs)) 0}.poster-builder__preview-frame{background:transparent;border:none;padding:0;min-height:0}.poster-builder__controls{gap:var(--space-md)}.step-panel__title{font-size:1.25rem}.step-panel__desc{font-size:.875rem;margin-bottom:var(--space-md)}.theme-grid{grid-template-columns:repeat(2,1fr);gap:var(--space-sm)}.theme-card__name{font-size:.9375rem}.gpx-dropzone{padding:var(--space-lg) var(--space-md)}.gpx-dropzone__icon{width:40px;height:40px}.gpx-dropzone__text{font-size:.875rem}.map-styles{gap:6px;overflow-x:auto;padding-bottom:4px;scrollbar-width:none;-webkit-overflow-scrolling:touch}.map-styles::-webkit-scrollbar{display:none}.map-style-btn{width:52px;height:52px;flex-shrink:0}.color-picker{gap:10px}.color-swatch{width:32px;height:32px}.form-row--3{gap:var(--space-xs)}.input{padding:12px 14px;font-size:16px}.label{font-size:.6875rem}.toggle-row{padding:var(--space-sm) var(--space-md)}.step-nav{flex-direction:column-reverse;gap:var(--space-xs)}.step-nav .btn{width:100%;padding:14px 20px}.summary-card{padding:var(--space-md)}.summary-row{padding:10px 0}.summary-row__label{font-size:.625rem}.summary-row__value{font-size:.875rem}.summary-price__value{font-size:1.75rem}}@media(max-width:400px){.theme-grid{grid-template-columns:repeat(2,1fr)}.theme-card{aspect-ratio:4 / 5}.poster-frame{width:280px!important}.poster-inner{width:280px!important;height:373px!important}}
/*# sourceMappingURL=/cdn/shop/t/2/assets/poster-builder.css.map */
