*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html,body,#root{height:100%;width:100%;overflow:hidden}body{font-family:Montserrat,sans-serif;background:#f0e8d8;color:#4a4040;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}:root{--bg: #fdfcf8;--bg-gradient: radial-gradient(circle at 50% 30%, #fcfaf2 0%, #f0e8d8 100%);--surface: #FFFFFF;--accent: #b88176;--accent-dim: rgba(184, 129, 118, .2);--text-dark: #3a3030;--text-muted: rgba(58, 48, 48, .5);--glass-bg: rgba(255, 255, 255, .45);--shadow-hard: 0 20px 50px rgba(0,0,0,.12), 0 4px 12px rgba(0,0,0,.07);--shadow-soft: 0 8px 24px rgba(0,0,0,.08);--radius: 3px}.app{height:100dvh;width:100%;margin:0 auto;display:flex;flex-direction:column;overflow:hidden;position:relative}.screen{flex:1;display:flex;flex-direction:column;width:100%;height:100dvh;overflow:hidden}.hidden-input{display:none}.capture-screen{background:var(--bg-gradient);align-items:center;justify-content:space-between;padding:clamp(20px,3vh,40px) 24px clamp(16px,3vh,32px)}.capture-header{text-align:center}.monogram{font-family:Playfair Display,serif;font-style:italic;font-size:clamp(1.6rem,4vmin,2.2rem);color:var(--accent);margin-bottom:4px}h1{font-family:Playfair Display,serif;font-weight:400;font-size:clamp(1.5rem,3.5vmin,2rem);letter-spacing:.02em;color:var(--text-dark);text-align:center;line-height:1.2}.subtitle{font-family:Montserrat,sans-serif;font-size:.68rem;font-weight:500;letter-spacing:.2em;color:var(--text-muted);margin-top:4px;text-align:center}.polaroid-stack{position:relative;width:clamp(240px,62vmin,360px);aspect-ratio:240 / 290;cursor:pointer;flex-shrink:0}.stack-frame{position:absolute;top:0;right:0;bottom:0;left:0;background:#fff;border-radius:2px;box-shadow:var(--shadow-hard);padding:12px 12px 0}.stack-frame--back2{transform:rotate(-4deg) translateY(4px);opacity:.6}.stack-frame--back1{transform:rotate(2.5deg) translateY(2px);opacity:.8}.stack-frame--front{transform:rotate(-1.5deg);z-index:2;padding-bottom:0}.stack-photo{width:100%;aspect-ratio:1;background:#f0ede8;display:flex;align-items:center;justify-content:center}.stack-icon{color:var(--accent);opacity:.7}.stack-caption{height:50px;display:flex;align-items:center;justify-content:center;font-family:Georgia,Times New Roman,serif;font-style:italic;font-size:1.1rem;color:var(--text-dark);opacity:.65;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;padding:0 8px}.controls-pill{display:flex;align-items:center;gap:18px;background:var(--glass-bg);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border:1px solid rgba(255,255,255,.6);border-radius:60px;padding:10px 22px;box-shadow:0 8px 32px #0000000f}.pill-btn{background:none;border:none;display:flex;flex-direction:column;align-items:center;gap:3px;color:var(--text-dark);font-family:Montserrat,sans-serif;font-size:.6rem;font-weight:500;letter-spacing:.08em;cursor:pointer;opacity:.75;-webkit-tap-highlight-color:transparent}.pill-btn--disabled{opacity:.35;cursor:default}.shutter-btn{width:clamp(54px,7vmin,68px);height:clamp(54px,7vmin,68px);border-radius:50%;background:linear-gradient(145deg,#c4937f,#a66d5e);border:4px solid white;display:flex;align-items:center;justify-content:center;color:#fff;box-shadow:0 6px 20px #b8817680;cursor:pointer;transition:transform .15s ease;-webkit-tap-highlight-color:transparent}.shutter-btn:active{transform:scale(.92)}.footer-note{font-size:.78rem;color:var(--text-muted);display:flex;align-items:center;gap:5px;font-family:Montserrat,sans-serif}.btn-group{display:flex;flex-direction:column;gap:12px;width:100%;max-width:320px;align-items:center}.btn-primary{display:flex;align-items:center;justify-content:center;gap:10px;width:100%;padding:17px 24px;background:linear-gradient(135deg,#c4937f,#a8715f);color:#fff;border:none;border-radius:50px;font-size:.9rem;font-family:Montserrat,sans-serif;font-weight:500;letter-spacing:.12em;cursor:pointer;box-shadow:0 6px 24px #b8817666;transition:transform .12s ease,opacity .12s ease;-webkit-tap-highlight-color:transparent;-webkit-user-select:none;user-select:none}.btn-primary:active{transform:scale(.97);opacity:.9}.btn-primary:disabled{opacity:.45;cursor:not-allowed;box-shadow:none}.btn-secondary{display:flex;align-items:center;justify-content:center;gap:10px;width:100%;padding:15px 24px;background:transparent;color:var(--text-dark);border:1.5px solid rgba(58,48,48,.25);border-radius:50px;font-size:.88rem;font-family:Montserrat,sans-serif;letter-spacing:.08em;cursor:pointer;-webkit-tap-highlight-color:transparent;-webkit-user-select:none;user-select:none;transition:border-color .12s}.btn-secondary:active{border-color:#3a303080}.btn-icon{background:transparent;border:none;color:var(--text-dark);cursor:pointer;padding:8px;display:flex;align-items:center;justify-content:center;border-radius:50%;width:40px;height:40px;-webkit-tap-highlight-color:transparent}.crop-screen{background:var(--bg-gradient);padding:0}.crop-header{display:flex;align-items:center;justify-content:space-between;padding:12px 16px 4px;flex-shrink:0}.crop-title{font-family:Montserrat,sans-serif;color:var(--text-muted);font-size:.85rem;letter-spacing:.12em;text-transform:uppercase}.polaroid-wrapper{flex:1;display:flex;align-items:center;justify-content:center;padding:8px 24px;min-height:0}.polaroid-card{width:100%;max-width:340px;aspect-ratio:1200 / 1500;position:relative;border-radius:2px;box-shadow:var(--shadow-soft);transform:rotate(-.8deg);overflow:hidden}.crop-area{position:absolute;left:5%;top:4%;width:90%;height:72%;background:#000;overflow:hidden}.crop-area>div{position:absolute!important;top:0;right:0;bottom:0;left:0}.polaroid-frame-overlay{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;pointer-events:none;z-index:10}.hashtag-preview-banner{position:absolute;left:5%;top:91.33%;width:90%;height:7.33%;display:flex;align-items:center;justify-content:center;z-index:11;font-family:Georgia,Times New Roman,serif;font-style:italic;font-size:clamp(14px,2.5vw,22px);color:var(--text-dark);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.hashtag-row{display:flex;align-items:center;gap:10px;padding:6px 24px 2px;flex-shrink:0}.hashtag-label{font-family:Montserrat,sans-serif;font-size:.75rem;letter-spacing:.1em;text-transform:uppercase;color:var(--text-muted);white-space:nowrap;flex-shrink:0}.hashtag-field-wrapper{flex:1;display:flex;align-items:center;background:#3a30300d;border:1px solid rgba(58,48,48,.2);border-radius:var(--radius);padding:0 14px;transition:border-color .15s}.hashtag-field-wrapper:focus-within{border-color:var(--accent)}.hashtag-prefix{font-family:Georgia,Times New Roman,serif;font-style:italic;font-size:1.1rem;color:var(--accent);-webkit-user-select:none;user-select:none;flex-shrink:0}.hashtag-field{flex:1;background:transparent;border:none;padding:10px 0 10px 2px;font-family:Georgia,Times New Roman,serif;font-style:italic;font-size:1.1rem;color:var(--text-dark);outline:none;-webkit-tap-highlight-color:transparent}.hashtag-field::placeholder{color:#3a30304d;font-weight:400}.crop-footer{padding:8px 20px 20px;flex-shrink:0;display:flex;justify-content:center}.crop-footer .btn-primary{max-width:340px}.center-screen{align-items:center;justify-content:center;gap:20px;padding:32px;background:var(--bg-gradient)}.spinner{width:56px;height:56px;border:2px solid rgba(58,48,48,.1);border-top-color:var(--accent);border-radius:50%;animation:spin .85s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.loading-text{font-family:Playfair Display,serif;font-style:italic;color:var(--text-dark);font-size:1.1rem;letter-spacing:.02em}.loading-sub{font-family:Montserrat,sans-serif;color:var(--text-muted);font-size:.82rem;letter-spacing:.06em}.error-text{font-family:Playfair Display,serif;color:#c0595a;font-size:1.1rem;font-weight:400;text-align:center}.error-detail{font-family:Montserrat,sans-serif;color:var(--text-muted);font-size:.85rem;text-align:center;max-width:280px}.done-screen{align-items:center;justify-content:center;gap:16px;padding:28px 24px;background:var(--bg-gradient);overflow-y:auto}.done-title{font-family:Playfair Display,serif;font-style:italic;font-weight:400;color:var(--text-dark);font-size:1.8rem;letter-spacing:.02em}.done-subtitle{font-family:Montserrat,sans-serif;color:var(--text-muted);font-size:.82rem;text-align:center;max-width:260px;letter-spacing:.06em}.preview-wrapper{width:100%;max-width:360px;flex-shrink:0}.preview-img{width:100%;border-radius:2px;box-shadow:var(--shadow-hard);transform:rotate(1.2deg)}.done-screen .btn-group{flex-shrink:0}
