:root{--c1:#26c8d8;--c2:#e8503a;--c3:#f5d23c;--c4:#f0607a;--text:#000}*,:before,:after{box-sizing:border-box;margin:0;padding:0;transition:background-color .6s,color .6s,border-color .6s}html{scroll-behavior:auto;overflow-x:hidden}body{color:var(--text);background:var(--c1);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-family:Noto Sans,sans-serif;font-weight:400;overflow-x:hidden}h1,h2,h3,h4{text-transform:uppercase;letter-spacing:.02em;font-family:Anton,sans-serif;font-weight:400}h1{font-size:56px;line-height:1.08}h2{font-size:40px;line-height:1.12}h3{font-size:28px;line-height:1.2}p{font-size:16px;line-height:1.6}a{color:var(--c2);text-decoration:none}a:hover{text-decoration:underline}button{cursor:pointer;background:var(--c2);color:#fff;border:none;border-radius:10px;padding:14px 32px;font-family:Noto Sans,sans-serif;font-size:16px;font-weight:500;transition:background-color .3s,transform .15s,opacity .3s,box-shadow .3s}button:hover{opacity:.92;transform:translateY(-2px);box-shadow:0 6px 20px #00000026}button:active{transform:translateY(0)}button:disabled{opacity:.35;cursor:not-allowed;box-shadow:none;transform:none}.cta-button{border-radius:12px;align-items:center;gap:8px;margin-top:32px;padding:16px 40px;font-size:18px;display:inline-flex}input[type=text],input[type=search]{border:2px solid var(--c2);color:#111;background:#ffffffeb;border-radius:10px;outline:none;width:100%;padding:14px 18px;font-family:Noto Sans,sans-serif;font-size:16px;transition:border-color .3s,box-shadow .3s}input[type=text]:focus,input[type=search]:focus{border-color:var(--c3);box-shadow:0 0 0 4px #f5d23c40}.step-section{justify-content:center;align-items:center;min-height:100vh;padding:60px 80px;display:flex;position:relative}.step-section:before{content:"";pointer-events:none;z-index:0;opacity:.18;position:absolute;inset:-4% 0}.step-section:first-child:before{background:radial-gradient(ellipse 30% 25% at 15% 35%, var(--c3) 0%, transparent 60%), radial-gradient(ellipse 28% 22% at 78% 65%, var(--c2) 0%, transparent 58%)}.step-section:nth-child(2):before{background:radial-gradient(ellipse 32% 24% at 72% 30%, var(--c4) 0%, transparent 58%), radial-gradient(ellipse 28% 24% at 18% 70%, var(--c3) 0%, transparent 60%)}.step-section:nth-child(3):before{background:radial-gradient(ellipse 30% 22% at 50% 35%, var(--c2) 0%, transparent 55%), radial-gradient(ellipse 26% 22% at 10% 60%, var(--c4) 0%, transparent 58%)}.step-section:nth-child(4):before{background:radial-gradient(ellipse 28% 24% at 85% 40%, var(--c3) 0%, transparent 58%), radial-gradient(ellipse 30% 22% at 25% 55%, var(--c2) 0%, transparent 55%)}.step-section:nth-child(5):before{background:radial-gradient(ellipse 30% 25% at 12% 40%, var(--c4) 0%, transparent 60%), radial-gradient(ellipse 26% 22% at 70% 60%, var(--c3) 0%, transparent 55%)}.step-section:nth-child(6):before{background:radial-gradient(ellipse 28% 22% at 60% 30%, var(--c2) 0%, transparent 58%), radial-gradient(ellipse 30% 24% at 15% 65%, var(--c4) 0%, transparent 55%)}.step-section:nth-child(7):before{background:radial-gradient(ellipse 30% 24% at 40% 35%, var(--c3) 0%, transparent 58%), radial-gradient(ellipse 28% 22% at 80% 70%, var(--c2) 0%, transparent 55%)}.step-content{z-index:2;width:100%;max-width:1100px;position:relative}.step-label{text-transform:uppercase;letter-spacing:.18em;opacity:.6;margin-bottom:10px;font-family:Noto Sans,sans-serif;font-size:13px;font-weight:500}.split-layout{grid-template-columns:1fr 1fr;align-items:center;gap:56px;display:grid}.step-hero{position:relative}.hero-logo-wrapper{justify-content:center;margin-bottom:32px;display:flex}.hero-logo{filter:drop-shadow(0 4px 24px #00000026);width:140px;height:auto;transition:transform .4s}.hero-logo:hover{transform:scale(1.04)}.hero-brand-line{justify-content:center;align-items:center;gap:18px;margin-bottom:28px;display:flex}.hero-brand-name{letter-spacing:.28em;opacity:.5;text-transform:uppercase;font-family:Noto Sans,sans-serif;font-size:13px;font-weight:600}.hero-brand-divider{opacity:.2;background:currentColor;width:40px;height:1.5px;display:block}h1 .hero-accent{background:linear-gradient(135deg, var(--c2), var(--c3), var(--c4));-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text}.upload-zone{border:3px dashed var(--c2);text-align:center;cursor:pointer;background:#ffffff0f;border-radius:20px;padding:64px 40px;transition:background-color .3s,border-color .3s,transform .2s}.upload-zone:hover{border-color:var(--c3);background:#ffffff24}.upload-zone.drag-over{border-color:var(--c3);background:#ffffff38;transform:scale(1.02)}.crop-preview-container{aspect-ratio:1;cursor:grab;border-radius:2px;width:min(300px,100vw - 76px);position:relative;overflow:hidden}.crop-preview-container:active{cursor:grabbing}.crop-preview-wrapper{justify-content:center;display:flex}.crop-preview-container img{pointer-events:none;-webkit-user-select:none;user-select:none;-webkit-user-drag:none}.zoom-controls{align-items:center;gap:12px;margin:16px 0;display:flex}.zoom-controls button{border-radius:50%;justify-content:center;align-items:center;width:38px;height:38px;padding:0;font-size:22px;line-height:1;display:flex}.zoom-controls input[type=range]{accent-color:var(--c2);flex:1}.polaroid-frame{box-sizing:border-box;background:#fff;border-radius:12px;max-width:100%;padding:10px;display:inline-block;position:relative;box-shadow:0 8px 32px #00000024,0 2px 8px #00000014}.polaroid-frame .polaroid-photo-shell{border-radius:4px}.polaroid-frame .photo-container{aspect-ratio:1;background:#eee;width:100%;position:relative;overflow:hidden}.polaroid-frame .polaroid-bottom{justify-content:space-between;align-items:center;gap:10px;min-height:72px;margin-top:8px;padding:10px 20px;display:flex}.polaroid-frame .polaroid-nickname{text-align:left;color:#111;white-space:nowrap;font-family:Anton,sans-serif;font-size:16px;line-height:1}.polaroid-frame .polaroid-flag-slot{flex-shrink:0;align-items:center;display:inline-flex}.polaroid-frame .polaroid-nickname-hand{letter-spacing:.005em;text-transform:none;color:#111;font-family:Indie Flower,Gochi Hand,Mansalva,cursive;font-weight:400;line-height:1.1}.polaroid-frame .handwriting-indie{text-shadow:.25px 0,-.25px 0;font-family:Indie Flower,cursive;font-weight:400}.polaroid-frame .handwriting-gochi{font-family:Gochi Hand,cursive;font-weight:400}.polaroid-frame .handwriting-mansalva{font-family:Mansalva,cursive;font-weight:400}.search-dropdown{border:2px solid var(--c2);z-index:50;background:#fff;border-top:none;border-radius:0 0 10px 10px;max-height:320px;position:absolute;top:100%;left:0;right:0;overflow-y:auto;box-shadow:0 12px 32px #00000024}.search-dropdown .dropdown-item{cursor:pointer;color:#111;align-items:center;gap:12px;padding:12px 18px;font-size:15px;transition:background-color .12s;display:flex}.search-dropdown .dropdown-item:hover{background:#0000000d}.country-chip{border:2px solid var(--c2);background:#ffffff2e;border-radius:30px;align-items:center;gap:10px;margin-top:16px;padding:10px 18px;font-size:16px;display:inline-flex}.country-chip .chip-remove{cursor:pointer;opacity:.5;font-size:18px;transition:opacity .15s}.country-chip .chip-remove:hover{opacity:1}.step5-title{margin-bottom:32px}.step5-subheading{margin-bottom:14px}.step5-scroll-hint{display:none}.step5-nickname-intro{margin-bottom:16px}.city-swatch-grid{grid-template-columns:repeat(auto-fill,minmax(130px,1fr));grid-auto-rows:min-content;align-items:start;gap:10px;display:grid}.city-swatch{cursor:pointer;border:3px solid #0000;border-radius:10px;align-self:start;min-height:min-content;transition:border-color .3s,transform .15s,box-shadow .3s;overflow:hidden}.city-swatch:hover{transform:scale(1.04);box-shadow:0 4px 16px #0000001f}.city-swatch.active{border-color:var(--text);box-shadow:0 0 0 3px var(--c2)}.city-swatch .swatch-colors{height:30px;display:flex}.city-swatch .swatch-colors span{flex:1}.city-swatch .swatch-name{text-align:center;color:#111;word-break:break-word;background:#ffffffeb;justify-content:center;align-items:center;min-height:2.6em;padding:6px 4px;font-size:11px;font-weight:500;line-height:1.3;display:flex}.char-counter{text-align:right;opacity:.55;margin-top:4px;font-size:13px}.char-counter.warning{color:#e8503a;opacity:1;font-weight:600}.step6-layout{grid-template-columns:minmax(0,1fr) minmax(0,1fr);align-items:center;gap:56px;min-width:0;display:grid}.step6-preview{justify-content:center;display:flex}.recap-row{border-bottom:1px solid #00000014;justify-content:space-between;align-items:center;padding:16px 0;display:flex}.recap-row .recap-label{opacity:.5;margin-bottom:4px;font-size:13px;font-weight:500}.recap-row .recap-value{align-items:center;gap:8px;font-size:16px;display:flex}.recap-row .recap-edit{color:var(--c2);cursor:pointer;font-size:14px;font-weight:500}.recap-row .recap-edit:hover{text-decoration:underline}.result-actions{flex-wrap:wrap;justify-content:center;gap:16px;margin-top:32px;display:flex}.loading-spinner{min-height:100vh;color:var(--text);opacity:.5;justify-content:center;align-items:center;font-size:18px;display:flex}.confetti-bg{pointer-events:none;z-index:0;position:absolute;inset:0;overflow:hidden}.confetti-particle{border-radius:2px;width:10px;height:10px;animation:linear infinite confetti-fall;position:absolute}.sidebar{z-index:100;flex-direction:column;align-items:center;gap:0;display:flex;position:fixed;top:50%;right:28px;transform:translateY(-50%)}.sidebar-line{z-index:0;background:#0000001f;width:2px;height:100%;position:absolute;top:0}.sidebar-dot{z-index:1;cursor:not-allowed;opacity:.3;background:#ccc;border-radius:50%;justify-content:center;align-items:center;width:16px;height:16px;margin:10px 0;transition:all .3s;display:flex;position:relative}.sidebar-dot.visited{background:var(--c2);cursor:pointer;opacity:1}.sidebar-dot.current{background:var(--c2);cursor:pointer;opacity:1;width:24px;height:24px;animation:2s ease-in-out infinite pulse}.sidebar-dot .dot-tooltip{white-space:nowrap;color:#fff;pointer-events:none;opacity:0;background:#000000d1;border-radius:6px;padding:5px 12px;font-family:Noto Sans,sans-serif;font-size:12px;transition:opacity .2s;position:absolute;right:34px}.sidebar-dot:hover .dot-tooltip{opacity:1}@keyframes confetti-fall{0%{opacity:1;transform:translateY(-10vh)rotate(0)}to{opacity:.2;transform:translateY(110vh)rotate(720deg)}}@keyframes float{0%,to{transform:translateY(0) rotate(var(--float-rot,0deg))}50%{transform:translateY(-20px) rotate(calc(var(--float-rot,0deg) + 3deg))}}@keyframes pulse{0%,to{box-shadow:0 0 0 0 var(--c2);transform:scale(1)}50%{transform:scale(1.35);box-shadow:0 0 0 10px #0000}}@media (width<=768px){h1{font-size:28px}h2{font-size:24px}h3{font-size:18px}p{font-size:15px}.step-section{padding:calc(56px + env(safe-area-inset-top,0px)) 18px 32px;min-height:100svh;scroll-margin-top:calc(52px + env(safe-area-inset-top,0px))}.step-content{max-width:100%}.step-label{font-size:11px}.split-layout{grid-template-columns:1fr;gap:24px}.split-layout>div:last-child{order:-1}button{width:100%;padding:12px 20px;font-size:15px}.cta-button{justify-content:center;width:100%;margin-top:24px;padding:14px 28px;font-size:16px}.hero-logo{width:100px}.hero-logo-wrapper{margin-bottom:20px}.hero-brand-line{gap:12px;margin-bottom:20px}.hero-brand-name{letter-spacing:.22em;font-size:11px}.hero-brand-divider{width:28px}.upload-zone{border-radius:14px;padding:36px 18px}.zoom-controls{gap:8px;margin:12px 0}.zoom-controls button{width:34px;height:34px;font-size:18px}.search-dropdown{max-height:240px}.search-dropdown .dropdown-item{padding:10px 14px;font-size:14px}.country-chip{gap:8px;padding:8px 14px;font-size:14px}.city-swatch-grid{grid-template-columns:repeat(auto-fill,minmax(85px,1fr));gap:6px}.city-swatch .swatch-colors{height:24px}.city-swatch .swatch-name{justify-content:center;align-items:center;min-height:2.8em;padding:7px 3px;font-size:10px;line-height:1.35;display:flex}#step-5.step-section{flex-direction:column;justify-content:flex-start;align-items:stretch;min-height:100svh}#step-5 .step-content{z-index:2;flex-direction:column;flex:1 1 0;width:100%;min-height:0;display:flex;position:relative}#step-5 .step-label{margin-bottom:4px}#step-5 .step5-title{flex-shrink:0;margin-bottom:8px;font-size:21px;line-height:1.1}#step-5 .step5-split.split-layout{flex-direction:column;flex:1 1 0;gap:8px;min-height:0;display:flex}#step-5 .step5-nickname-column{flex:none;order:-1}#step-5 .step5-city-column{flex-direction:column;flex:1 1 0;min-width:0;min-height:0;display:flex;overflow:hidden}#step-5 .step5-subheading{flex-shrink:0;margin-bottom:4px;font-size:14px}#step-5 .step5-scroll-hint{opacity:.5;flex-shrink:0;margin:0 0 6px;font-size:11px;line-height:1.25;display:block}#step-5 .step5-nickname-intro{margin-bottom:8px;font-size:13px}#step-5 .city-swatch-grid{-webkit-overflow-scrolling:touch;overscroll-behavior-y:contain;touch-action:pan-y;flex:1 1 0;grid-template-columns:repeat(3,minmax(0,1fr));grid-auto-rows:min-content;align-content:start;align-items:start;gap:8px;min-height:0;padding-bottom:8px;overflow-y:auto}#step-5 .step5-disclaimer{display:none}#step-5 .cta-button{margin-top:8px;padding:11px 16px}input[type=text],input[type=search]{border-radius:8px;padding:12px 14px;font-size:16px}.char-counter{font-size:12px}.polaroid-frame{border-radius:10px}#step-6{padding-bottom:40px}#step-6 .step-content{min-width:0}#step-6 h2{margin-bottom:16px!important}.step6-layout{grid-template-columns:minmax(0,1fr);gap:0;min-width:0}.step6-details{display:none}.step6-preview{box-sizing:border-box;justify-content:center;width:100%;min-width:0;max-width:100%;padding:0 2px;display:flex}#step-6 .cta-button{margin-top:16px}.result-actions{flex-direction:column;gap:10px}.result-actions button{justify-content:center;width:100%}.sidebar{right:auto;top:calc(10px + env(safe-area-inset-top,0px));-webkit-backdrop-filter:blur(16px);background:#ffffff24;border:1px solid #ffffff38;border-radius:999px;flex-direction:row;justify-content:center;align-items:center;gap:2px;width:auto;max-width:min(340px,100vw - 24px);padding:8px 14px;position:fixed;bottom:auto;left:50%;transform:translate(-50%);box-shadow:0 8px 32px #0000001f}.sidebar-line{display:none}.sidebar-dot{flex-shrink:0;width:8px;height:8px;margin:0 4px}.sidebar-dot.current{width:11px;height:11px}.sidebar-dot .dot-tooltip{font-size:11px;inset:calc(100% + 10px) auto auto 50%;transform:translate(-50%)}}@media (width<=380px){h1{font-size:24px}h2{font-size:20px}.step-section{padding:calc(52px + env(safe-area-inset-top,0px)) 14px 28px;min-height:100svh;scroll-margin-top:calc(52px + env(safe-area-inset-top,0px))}.hero-logo{width:80px}.city-swatch-grid{grid-template-columns:repeat(auto-fill,minmax(72px,1fr))}.sidebar-dot{width:7px;height:7px;margin:0 3px}.sidebar-dot.current{width:10px;height:10px}.sidebar{max-width:min(300px,100vw - 20px);padding:6px 12px}#step-5 .step5-title{font-size:19px}#step-5 .step5-scroll-hint{font-size:10px}}
