*,:before,:after{box-sizing:border-box;margin:0;padding:0}:root{--cream:#fdfbf7;--cream-dark:#f5f0e8;--blush:#f2c4ce;--blush-dark:#e8a5b4;--sage:#9caf88;--sage-dark:#7a9167;--dusty-rose:#c9837a;--gold:#c9a96e;--gold-light:#e8d5a3;--charcoal:#2d2d2d;--soft-brown:#6b4f3a;--white:#fff;--font-serif:"Playfair Display", Georgia, serif;--font-script:"Dancing Script", cursive;--font-sans:"Inter", system-ui, sans-serif;--radius-sm:12px;--radius-md:20px;--radius-lg:28px;--radius-xl:36px;--shadow-soft:0 4px 24px #00000014;--shadow-medium:0 8px 40px #0000001f;--shadow-glow:0 0 40px #f2c4ce66}html{-webkit-text-size-adjust:100%;font-size:16px}body{font-family:var(--font-sans);background-color:var(--cream);color:var(--charcoal);min-height:100dvh;line-height:1.6;overflow-x:hidden}#root{flex-direction:column;min-height:100dvh;display:flex}::-webkit-scrollbar{width:6px}::-webkit-scrollbar-track{background:var(--cream-dark)}::-webkit-scrollbar-thumb{background:var(--blush-dark);border-radius:3px}.app-wrapper{flex-direction:column;flex:1;align-items:center;min-height:100dvh;padding:20px 20px 50px;display:flex;position:relative}.container{width:100%;max-width:480px;padding:0 20px}@media (width>=400px){.container{padding:0 24px}}.app-header{text-align:center;z-index:1;width:100%;padding:28px 20px;position:relative}.app-title{font-family:var(--font-serif);color:var(--soft-brown);letter-spacing:-.5px;font-size:clamp(2rem,7vw,2.8rem);font-weight:700;line-height:1.15}.app-title em{color:var(--dusty-rose);font-style:italic}.app-subtitle{font-family:var(--font-sans);color:var(--sage-dark);letter-spacing:.5px;margin-top:10px;margin-bottom:20px;font-size:.875rem;font-weight:400}.card{-webkit-backdrop-filter:blur(12px);border-radius:var(--radius-xl);box-shadow:var(--shadow-soft);background:#ffffffb8;border:1px solid #ffffffe6;margin-bottom:20px;padding:28px;scroll-margin-top:80px}.card-title{font-family:var(--font-serif);color:var(--soft-brown);text-align:center;margin-bottom:20px;font-size:1.1rem;font-weight:600}.preview-slots{justify-content:center;align-items:center;gap:12px;padding:8px 0;display:flex}.preview-slot{background:var(--cream-dark);border:2px dashed var(--blush-dark);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:72px;height:72px;font-size:2rem;transition:all .3s;display:flex;position:relative}.preview-slot.filled{border:2px solid var(--blush);background:linear-gradient(135deg,#fff5f8,#fff9f5);box-shadow:0 4px 16px #f2c4ce80}.preview-slot .slot-number{color:var(--blush-dark);background:var(--cream);letter-spacing:.5px;white-space:nowrap;border-radius:10px;padding:1px 6px;font-size:.6rem;font-weight:600;position:absolute;bottom:-8px;left:50%;transform:translate(-50%)}.bouquet-visualizer{flex-direction:column;align-items:center;padding:8px 0 0;display:flex}.bouquet-shape-wrap{justify-content:center;align-items:flex-end;width:220px;height:280px;display:flex;position:relative}.bouquet-flowers-area{pointer-events:none;z-index:30;height:65%;position:absolute;top:0;left:0;right:0}.bouquet-flower-emoji{transform-origin:bottom;will-change:transform, opacity;-webkit-user-select:none;user-select:none;line-height:1;display:block;position:absolute}.bouquet-shape-img{z-index:20;filter:drop-shadow(0 6px 16px #00000024);width:110px;height:auto;position:relative}.vase-hint{color:var(--sage-dark);text-align:center;margin-top:16px;margin-bottom:12px;font-size:.8rem;font-style:italic}#build-btn{background:var(--sage);color:#fff;letter-spacing:.02em;border:none;font-weight:600;transition:all .25s cubic-bezier(.175,.885,.32,1.275);box-shadow:0 4px 12px #879a7540}#build-btn:hover:not(:disabled){background:#7a9167;transform:translateY(-2px);box-shadow:0 6px 16px #879a7559}#build-btn:active:not(:disabled){transform:translateY(1px)}.emoji-grid{grid-template-columns:repeat(3,1fr);gap:10px;display:grid}.emoji-btn{aspect-ratio:1;border-radius:var(--radius-md);background:var(--cream-dark);cursor:pointer;-webkit-tap-highlight-color:transparent;-webkit-user-select:none;user-select:none;border:2px solid #0000;justify-content:center;align-items:center;font-size:2.5rem;transition:all .2s cubic-bezier(.34,1.56,.64,1);display:flex;position:relative}.emoji-btn:hover:not(:disabled){box-shadow:var(--shadow-soft);background:#fff;transform:scale(1.08)}.emoji-btn:active:not(:disabled){transform:scale(.95)}.emoji-btn.selected{border-color:var(--blush-dark);background:linear-gradient(135deg,#fff0f5,#fff8f0);transform:scale(1.05);box-shadow:0 4px 16px #f2c4ce99,inset 0 1px #fffc}.emoji-btn.selected:after{content:"✓";color:var(--white);background:var(--dusty-rose);text-align:center;border-radius:50%;justify-content:center;align-items:center;width:14px;height:14px;font-size:.55rem;font-weight:700;line-height:14px;display:flex;position:absolute;top:4px;right:4px}.emoji-btn:disabled{opacity:.45;cursor:not-allowed;transform:none}.name-section{flex-direction:column;gap:10px;display:flex}.input-label{font-family:var(--font-serif);color:var(--soft-brown);font-size:.9rem;font-weight:600}.name-input{border-radius:var(--radius-md);border:2px solid var(--cream-dark);width:100%;font-family:var(--font-sans);color:var(--charcoal);appearance:none;background:#fffc;outline:none;padding:14px 18px;font-size:1rem;transition:border-color .2s,box-shadow .2s}.name-input:focus{border-color:var(--blush-dark);box-shadow:0 0 0 4px #f2c4ce40}.name-input::placeholder{color:#bbb;font-style:italic}.btn{font-family:var(--font-sans);letter-spacing:.3px;cursor:pointer;-webkit-tap-highlight-color:transparent;-webkit-user-select:none;user-select:none;white-space:nowrap;border:none;border-radius:100px;justify-content:center;align-items:center;gap:8px;padding:14px 28px;font-size:.95rem;font-weight:600;transition:all .2s cubic-bezier(.34,1.56,.64,1);display:inline-flex}.btn:active{transform:scale(.96)}.btn-primary{background:linear-gradient(135deg, var(--dusty-rose), #b86b5a);color:var(--white);box-shadow:0 4px 20px #c9837a73}.btn-primary:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 6px 28px #c9837a99}.btn-primary:disabled{opacity:.5;cursor:not-allowed;box-shadow:none;transform:none}.btn-secondary{background:linear-gradient(135deg, var(--sage), var(--sage-dark));color:var(--white);box-shadow:0 4px 20px #9caf8873}.btn-secondary:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 6px 28px #9caf8899}.btn-secondary:disabled{opacity:.5;cursor:not-allowed;box-shadow:none;transform:none}.btn-ghost{color:var(--soft-brown);border:1.5px solid var(--blush);background:#ffffffb3}.btn-ghost:hover{box-shadow:var(--shadow-soft);background:#fffffff2}.btn-full{width:100%;padding:16px 28px;font-size:1rem}.btn-loading{pointer-events:none;opacity:.8}.action-area{flex-direction:column;gap:10px;padding-top:4px;display:flex}.action-row{gap:10px;display:flex}.action-row .btn{flex:1}.progress-bar-wrap{background:var(--cream-dark);border-radius:100px;height:6px;margin-bottom:8px;overflow:hidden}.progress-bar{background:linear-gradient(90deg, var(--blush), var(--dusty-rose));border-radius:100px;height:100%;transition:width .4s}.status-text{text-align:center;color:var(--sage-dark);font-size:.78rem;font-style:italic}.polaroid-wrapper{pointer-events:none;z-index:-1;position:fixed;top:-9999px;left:-9999px}.polaroid{background:#fff;border-radius:4px;width:360px;padding:24px 24px 60px;position:relative;overflow:hidden;box-shadow:0 8px 40px #0000002e}.polaroid-inner{background:linear-gradient(145deg,#fff9f5,#fff5f8,#f8fff5);border-radius:2px;flex-direction:column;align-items:center;gap:16px;min-height:280px;padding:40px 20px 30px;display:flex;position:relative;overflow:hidden}.polaroid-flowers{align-items:flex-end;gap:8px;font-size:3.5rem;display:flex}.polaroid-flowers span:first-child{display:block;transform:rotate(-12deg)}.polaroid-flowers span:nth-child(2){display:block;transform:translateY(-10px)}.polaroid-flowers span:nth-child(3){display:block;transform:rotate(12deg)}.polaroid-vase{margin-top:-8px}.polaroid-greeting{color:var(--dusty-rose);text-align:center;margin-top:8px;font-family:Dancing Script,cursive;font-size:1.8rem;font-weight:700;line-height:1.2}.polaroid-love{color:var(--soft-brown);text-align:center;font-family:Dancing Script,cursive;font-size:1.2rem}.polaroid-footer{text-align:center;padding:12px 24px 0}.polaroid-footer-text{font-family:var(--font-sans);color:#aaa;letter-spacing:1px;text-transform:uppercase;font-size:.65rem}.floral-bg{pointer-events:none;z-index:0;position:fixed;inset:0;overflow:hidden}.floral-bg svg{opacity:.12;position:absolute}.floral-top-left{top:-20px;left:-20px;transform:rotate(0)}.floral-top-right{top:-20px;right:-20px;transform:rotate(90deg)}.floral-bottom-left{bottom:-20px;left:-20px;transform:rotate(270deg)}.floral-bottom-right{bottom:-20px;right:-20px;transform:rotate(180deg)}.toast{background:var(--charcoal);color:#fff;z-index:3000;text-align:center;width:auto;min-width:200px;max-width:calc(100vw - 40px);box-shadow:var(--shadow-medium);pointer-events:none;border-radius:100px;padding:12px 24px;font-size:.85rem;font-weight:500;position:fixed;bottom:24px;left:50%;transform:translate(-50%)}.reset-link{text-align:center;color:var(--sage-dark);cursor:pointer;font-size:.78rem;font-family:var(--font-sans);background:0 0;border:none;padding:4px;text-decoration:underline}.reset-link:hover{color:var(--dusty-rose)}@keyframes floatUp{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}@keyframes pulse-soft{0%,to{transform:scale(1)}50%{transform:scale(1.04)}}@keyframes fadeIn{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}.fade-in{animation:.5s forwards fadeIn}.color-picker-wrap{border-top:1px dashed var(--cream-dark);margin-top:20px;padding-top:16px}.step-label-mini{font-family:var(--font-sans);color:var(--sage-dark);text-transform:uppercase;letter-spacing:.05em;justify-content:center;align-items:center;gap:8px;margin-bottom:14px;font-size:.75rem;font-weight:700;display:flex}.step-number-pill{background:var(--sage-light);color:var(--sage-dark);border-radius:99px;padding:2px 8px;font-size:.7rem}.color-swatches{flex-wrap:wrap;justify-content:center;gap:12px;display:flex}.color-swatch{cursor:pointer;border:3px solid #fff;border-radius:50%;width:32px;height:32px;padding:0;transition:transform .2s,box-shadow .2s,border-color .2s;box-shadow:0 2px 8px #0000001a}.color-swatch:hover{transform:scale(1.15);box-shadow:0 4px 12px #00000026}.color-swatch.active{border-color:var(--sage);box-shadow:0 0 0 2px white, 0 0 0 4px var(--sage);transform:scale(1.1)}.spinner{border:2.5px solid #fff6;border-top-color:#fff;border-radius:50%;flex-shrink:0;width:18px;height:18px;animation:.7s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}@media (width>=480px){.container{padding:0 28px}.card{padding:32px}.emoji-btn{font-size:2.2rem}}@media (width<=360px){.emoji-btn{font-size:1.7rem}.preview-slot{width:64px;height:64px;font-size:1.8rem}}.modal-overlay{-webkit-backdrop-filter:blur(8px);z-index:2000;background:#2b3e3666;justify-content:center;align-items:center;padding:20px;display:flex;position:fixed;inset:0}.modal-card{background:var(--cream);border-radius:24px;width:100%;max-width:400px;position:relative;overflow:hidden;box-shadow:0 20px 40px #0003}.modal-close{width:32px;height:32px;color:var(--sage-dark);cursor:pointer;z-index:10;background:#0000000d;border:none;border-radius:50%;justify-content:center;align-items:center;font-size:20px;display:flex;position:absolute;top:16px;right:16px}.modal-content{text-align:center;padding:32px 24px}.modal-title{color:var(--sage-dark);margin-bottom:8px;font-family:Playfair Display,serif;font-size:1.5rem;font-weight:700}.modal-instruction{color:var(--sage-dark);opacity:.8;margin-bottom:24px;font-size:.9rem;line-height:1.5}.modal-image-wrap{background:#fff;border-radius:12px;margin:0 auto;padding:12px;display:inline-block;box-shadow:0 4px 12px #0000000d}.modal-image{-webkit-user-select:none;user-select:none;-webkit-touch-callout:default;border-radius:4px;max-width:100%;height:auto;display:block}
