.calculator-container{height:100dvh;display:flex;flex-direction:column;overflow:hidden}.calculator-content{flex:1;display:flex;flex-direction:column;width:100%;height:100%;overflow:hidden}.calculator-header{flex-shrink:0;z-index:50;padding-bottom:.5rem}.calculator-body{flex:1;overflow-y:auto;overflow-x:hidden}.calculator-body:not(.has-step-indicator):not(.has-fixed-header) .calculator-screen{justify-content:center}.calculator-screen{flex:1;display:flex;flex-direction:column;padding:1rem 24px 7rem;animation:slideIn .3s ease-out}.calculator-screen>*{max-width:400px;margin-left:auto;margin-right:auto;width:100%}.calculator-screen.exiting{animation:slideOut .3s ease-out}@keyframes slideIn{0%{opacity:0;transform:translateX(20px)}to{opacity:1;transform:translateX(0)}}@keyframes slideOut{0%{opacity:1;transform:translateX(0)}to{opacity:0;transform:translateX(-20px)}}.step-indicator-row{display:flex;align-items:center;justify-content:center;position:relative;padding:1.5rem 24px .5rem}.step-indicator{text-align:center}.start-over-button,.step-indicator{font-family:var(--font-sans);font-size:13px;color:var(--muted)}.start-over-button{position:absolute;right:24px;top:50%;transform:translateY(-50%);background:none;border:none;cursor:pointer;padding:.25rem .5rem;transition:color .2s}.start-over-button:hover{color:var(--coral)}.screen-header{text-align:center;margin-bottom:0;padding:0 24px 1rem}.calculator-body .screen-header{margin-bottom:2rem;padding:0}.screen-header h1{font-family:var(--font-serif);font-size:1.75rem;margin:0 0 .5rem;line-height:1.2}.screen-header p{color:var(--muted);margin:0;font-size:.95rem}.dob-pickers{display:flex;flex-direction:column;gap:12px}.dob-picker-wrapper{position:relative}.dob-picker-button{width:100%;display:flex;align-items:center;justify-content:space-between;padding:14px 18px;background:rgba(255,255,255,.65);border:1px solid rgba(34,40,30,.12);border-radius:12px;cursor:pointer;transition:all .2s}.dob-picker-button:hover{background:rgba(255,255,255,.85);border-color:rgba(34,40,30,.2)}.dob-picker-button.active{background:rgba(255,255,255,.95);border-color:var(--coral);box-shadow:0 0 0 2px rgba(242,140,127,.15)}.dob-picker-button .picker-label{font-size:.85rem;color:var(--muted);font-weight:500}.dob-picker-button .picker-value{font-size:1rem;font-weight:500;color:var(--muted)}.dob-picker-button.has-value .picker-value{color:var(--ink)}.dob-popup{position:absolute;top:calc(100% + 8px);left:0;right:0;background:white;border:1px solid rgba(34,40,30,.12);border-radius:14px;box-shadow:0 12px 40px rgba(20,24,18,.15);z-index:100;overflow:hidden;animation:popupIn .2s ease-out}@keyframes popupIn{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.popup-header{padding:12px 16px;font-size:.85rem;font-weight:600;color:var(--muted);border-bottom:1px solid rgba(34,40,30,.08);text-align:center}.popup-content{max-height:280px;overflow-y:auto;overscroll-behavior:contain}.popup-grid{display:grid;grid-template-columns:repeat(5,minmax(56px,1fr));gap:6px;padding:12px}.popup-item.grid-item{padding:10px 8px;font-size:.9rem;font-weight:500;color:var(--ink);background:transparent;border:none;border-radius:8px;cursor:pointer;transition:all .15s;text-align:center}.popup-item.grid-item:hover{background:rgba(242,140,127,.1)}.popup-item.grid-item.selected{background:var(--coral);color:white}.popup-item.grid-item.empty{cursor:default;pointer-events:none}.popup-list{display:flex;flex-direction:column;padding:4px}.popup-item.list-item{padding:12px 16px;font-size:.95rem;font-weight:500;color:var(--ink);background:transparent;border:none;border-radius:8px;cursor:pointer;transition:all .15s;text-align:right}.popup-item.list-item:hover{background:rgba(242,140,127,.1)}.popup-item.list-item.selected{background:var(--coral);color:white}.focus-list{display:flex;flex-direction:column;gap:6px}.focus-item{display:flex;align-items:center;gap:10px;padding:10px 14px;background:rgba(255,255,255,.65);border:1px solid rgba(34,40,30,.08);border-radius:10px;cursor:pointer;transition:all .2s}.focus-item:hover{background:rgba(255,255,255,.85);border-color:rgba(34,40,30,.15)}.focus-item.selected{background:rgba(255,255,255,.95);border-color:var(--coral);box-shadow:0 0 0 2px rgba(242,140,127,.15)}.focus-icon{width:28px;height:28px;display:flex;align-items:center;justify-content:center;border-radius:8px;background:rgba(242,140,127,.1);color:var(--coral);flex-shrink:0}.focus-item.selected .focus-icon{background:var(--coral);color:white}.focus-title{font-weight:500;font-size:.95rem;color:var(--ink)}.photo-dropzone{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:32px 24px;background:rgba(255,255,255,.5);border:2px dashed rgba(34,40,30,.15);border-radius:16px;cursor:pointer;transition:all .2s;margin-bottom:12px}.photo-dropzone:hover{background:rgba(255,255,255,.7);border-color:rgba(34,40,30,.25)}.photo-dropzone.dragging{background:rgba(242,140,127,.08);border-color:var(--coral);border-style:solid}.dropzone-content{display:flex;flex-direction:column;align-items:center;gap:8px;pointer-events:none}.dropzone-icon{width:32px;height:32px;color:var(--coral);margin-bottom:4px}.dropzone-text{font-size:1rem;font-weight:500;color:var(--ink);margin:0}.dropzone-hint{font-size:.85rem;color:var(--muted);margin:0}.photo-camera-button{display:flex;align-items:center;justify-content:center;gap:8px;width:100%;padding:12px 20px;background:rgba(255,255,255,.75);border:1px solid rgba(34,40,30,.12);border-radius:12px;font-size:.95rem;font-weight:500;color:var(--ink);cursor:pointer;transition:all .2s;margin-bottom:16px}.photo-camera-button:hover{background:rgba(255,255,255,.9);border-color:rgba(34,40,30,.2)}.photo-camera-button svg{width:18px;height:18px;color:var(--coral)}.photo-preview{position:relative;margin-bottom:1.5rem}.photo-preview img{width:100%;max-width:200px;margin:0 auto;display:block;border-radius:16px;border:1px solid rgba(34,40,30,.1)}.photo-remove{position:absolute;top:8px;right:calc(50% - 100px + 8px);width:28px;height:28px;border-radius:50%;background:rgba(0,0,0,.6);border:none;color:white;cursor:pointer;display:flex;align-items:center;justify-content:center}.photo-disclaimer{font-size:.85rem;color:var(--muted);text-align:center;line-height:1.5;padding:12px 16px;background:rgba(255,255,255,.5);border-radius:10px;margin-bottom:1.5rem}.skip-button{display:block;width:100%;padding:14px;background:transparent;border:1px dashed rgba(34,40,30,.2);border-radius:12px;font-size:.95rem;color:var(--muted);cursor:pointer;transition:all .2s}.skip-button:hover{background:rgba(255,255,255,.5);border-color:rgba(34,40,30,.3)}.reveal-container{text-align:center;padding:2rem 0}.angel-number-reveal{font-family:var(--font-serif);font-size:120px;line-height:1;color:var(--ink);margin:0 0 1rem;animation:numberReveal .6s ease-out}@keyframes numberReveal{0%{opacity:0;transform:scale(.5)}50%{transform:scale(1.1)}to{opacity:1;transform:scale(1)}}.archetype-name{font-size:1.25rem;font-weight:500;color:var(--coral);margin-bottom:1rem}.archetype-message{color:var(--muted);line-height:1.6;margin-bottom:2rem}.reveal-container .nav-button{margin:0 auto}.loading-text{text-align:center;padding:3rem 0}.loading-text p{font-size:1.1rem;color:var(--muted);margin:0;animation:loadingPulse 2s ease-in-out infinite}@keyframes loadingPulse{0%,to{opacity:.5}50%{opacity:1}}.insights-screen{display:flex;flex-direction:column;justify-content:flex-start}.insights-screen .screen-header{flex-shrink:0}.insights-scroll{padding-bottom:7rem}.insights-nav{position:fixed;bottom:0;left:0;right:0;display:flex;justify-content:center;padding:2rem 24px;background:linear-gradient(to bottom,transparent 0,var(--bg) 40%);z-index:100}.insights-nav-inner{display:flex;justify-content:space-between;gap:12px;width:100%;max-width:400px}.insights-content{padding:.5rem 0}.insights-message{font-size:1.05rem;line-height:1.75;color:var(--ink);margin-bottom:2rem}.insights-section{margin-bottom:1.5rem}.insights-section h3{font-size:.85rem;font-weight:600;text-transform:uppercase;letter-spacing:.5px;color:var(--coral);margin:0 0 .75rem}.insights-section li,.insights-section p{color:var(--muted);line-height:1.6}.insights-section ul{margin:0;padding:0 0 0 1.25rem}.insights-section li,.pain-point{margin-bottom:.5rem}.pain-point{font-size:1.1rem;color:var(--coral);font-weight:500}.email-form{gap:1rem;animation:fadeSlideUp .8s ease-out .4s both}.email-form,.form-field{display:flex;flex-direction:column}.form-field{gap:6px}.form-field label{font-size:.9rem;font-weight:600;color:var(--ink)}.form-field input{padding:14px 16px;font-size:1rem;border:1px solid rgba(34,40,30,.15);border-radius:12px;background:rgba(255,255,255,.7);transition:border-color .2s,box-shadow .2s}.form-field input:focus{outline:none;border-color:var(--coral);box-shadow:0 0 0 3px rgba(242,140,127,.15)}.privacy-note{font-size:.85rem;color:var(--muted);margin-top:.5rem}.privacy-note,.thank-you-container{text-align:center}.summary-card{background:rgba(255,255,255,.75);border:1px solid rgba(34,40,30,.1);border-radius:16px;padding:1.5rem;margin:1.5rem 0}.summary-row{display:flex;justify-content:space-between;padding:.5rem 0;border-bottom:1px solid rgba(34,40,30,.06)}.summary-row:last-child{border-bottom:none}.summary-label{color:var(--muted);font-size:.9rem}.summary-value{font-weight:500;color:var(--ink)}.countdown-text{font-size:.95rem;color:var(--muted);margin:1.5rem 0}.nav-buttons{position:fixed;bottom:0;left:0;right:0;display:flex;justify-content:center;padding:2rem 24px;background:linear-gradient(to bottom,transparent 0,var(--bg) 40%);z-index:100}.nav-buttons-inner{display:flex;justify-content:space-between;gap:12px;width:100%;max-width:400px}.nav-button{display:flex;align-items:center;justify-content:center;gap:8px;height:48px;border-radius:12px;font-size:.95rem;font-weight:600;cursor:pointer;transition:all .2s}.nav-button.back{background:rgba(255,255,255,.7);border:1px solid rgba(34,40,30,.12);color:var(--muted);width:48px}.nav-button.back:hover{background:rgba(255,255,255,.9)}.nav-button.next{background:var(--coral);border:1px solid rgba(242,140,127,.35);color:white;box-shadow:0 10px 30px rgba(242,140,127,.2);padding:0 24px;margin-left:auto}.nav-button.next:hover{filter:brightness(1.05)}.nav-button.next:disabled{opacity:.5;cursor:not-allowed}.nav-button.secondary{background:rgba(255,255,255,.7);border:1px solid rgba(34,40,30,.12);color:var(--ink)}.nav-button.secondary:hover{background:rgba(255,255,255,.9)}.check-circle{width:64px;height:64px;margin:0 auto 1rem;border-radius:50%;background:linear-gradient(135deg,#dcfce7,#bbf7d0);display:flex;align-items:center;justify-content:center}.check-icon{width:32px;height:32px;color:#16a34a}.go-home-link{display:block;text-align:center;margin-top:1.5rem;font-size:.9rem;color:var(--muted);text-decoration:none;transition:color .2s}.go-home-link:hover{color:var(--coral)}.app-cta{margin-top:2rem;padding-top:1.5rem;border-top:1px solid rgba(34,40,30,.08)}.app-cta p{color:var(--muted);font-size:.95rem;margin-bottom:1rem}.app-cta-primary{background:linear-gradient(135deg,rgba(255,255,255,.8),rgba(255,245,240,.7));border-radius:16px;padding:1.5rem;margin-top:1.5rem;border:1px solid rgba(242,140,127,.2);border-top:none}.app-cta-primary h3{font-family:var(--font-serif);font-size:1.1rem;color:var(--ink);margin:0 0 .5rem}.app-cta-primary p{margin-bottom:1.25rem}.app-cta-primary .cta-button{width:100%;justify-content:center}.angel-number-badge{display:inline-flex;align-items:center;justify-content:center;width:72px;height:72px;margin-bottom:1rem;font-family:var(--font-serif);font-size:2rem;background:linear-gradient(135deg,var(--coral) 0,#e8a090 100%);color:white;border-radius:50%;box-shadow:0 8px 30px rgba(242,140,127,.3)}.email-screen{position:relative;overflow:visible}.email-screen:after,.email-screen:before{content:"";position:absolute;border-radius:50%;filter:blur(60px);opacity:.4;pointer-events:none;z-index:-1}.email-screen:before{width:250px;height:250px;background:radial-gradient(circle,rgba(242,140,127,.5) 0,transparent 70%);top:20px;right:-60px;animation:orbFloat1 8s ease-in-out infinite}.email-screen:after{width:200px;height:200px;background:radial-gradient(circle,rgba(255,200,150,.4) 0,transparent 70%);bottom:150px;left:-50px;animation:orbFloat2 10s ease-in-out infinite}@keyframes orbFloat1{0%,to{transform:translate(0) scale(1)}50%{transform:translate(-30px,30px) scale(1.1)}}@keyframes orbFloat2{0%,to{transform:translate(0) scale(1)}50%{transform:translate(20px,-20px) scale(1.15)}}.email-screen .screen-header{margin-bottom:1rem;animation:fadeSlideUp .6s ease-out}.angel-badge{position:relative;display:inline-flex;align-items:center;justify-content:center;width:80px;height:80px;margin-bottom:1rem;animation:badgeEntrance .8s ease-out,badgeFloat 4s ease-in-out .8s infinite}.angel-badge-number{position:relative;z-index:1;font-family:var(--font-serif);font-size:2.5rem;font-weight:500;background:linear-gradient(135deg,var(--coral) 0,#e8a090 50%,var(--coral) 100%);background-size:200% 200%;-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;animation:gradientShift 3s ease-in-out infinite;text-shadow:none;filter:drop-shadow(0 0 20px rgba(242,140,127,.4))}.angel-badge-glow{position:absolute;inset:-10px;background:radial-gradient(circle,rgba(242,140,127,.4) 0,rgba(255,200,150,.2) 40%,transparent 70%);border-radius:50%;animation:badgePulse 2s ease-in-out infinite}.angel-badge:before{content:"";position:absolute;inset:-20px;border-radius:50%;background:conic-gradient(from 0deg,transparent 0,rgba(242,140,127,.2) 25%,transparent 50%,rgba(255,200,150,.2) 75%,transparent 100%);animation:ringRotate 8s linear infinite}@keyframes badgeEntrance{0%{opacity:0;transform:scale(.3) rotate(-10deg)}60%{transform:scale(1.1) rotate(3deg)}to{opacity:1;transform:scale(1) rotate(0deg)}}@keyframes badgeFloat{0%,to{transform:translateY(0)}50%{transform:translateY(-6px)}}@keyframes badgePulse{0%,to{transform:scale(1);opacity:.6}50%{transform:scale(1.4);opacity:.2}}@keyframes gradientShift{0%,to{background-position:0 50%}50%{background-position:100% 50%}}@keyframes ringRotate{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}.sparkles{position:absolute;inset:0;pointer-events:none;overflow:hidden}.sparkle{position:absolute;font-size:1rem;color:var(--coral);opacity:0;animation:sparkleFloat 4s ease-in-out infinite}.sparkle-1{top:5%;left:10%;animation-delay:0s}.sparkle-2{top:15%;right:15%;animation-delay:.8s;font-size:.75rem}.sparkle-3{top:35%;left:5%;animation-delay:1.6s;font-size:.85rem}.sparkle-4{top:25%;right:8%;animation-delay:2.4s}.sparkle-5{top:45%;right:20%;animation-delay:3.2s;font-size:.7rem}.sparkle-6{top:55%;left:12%;animation-delay:1.2s;font-size:1.1rem}.sparkle-7{top:8%;left:30%;animation-delay:2s;font-size:.65rem}.sparkle-8{top:60%;right:5%;animation-delay:2.8s;font-size:.9rem}@keyframes sparkleFloat{0%,to{opacity:0;transform:translateY(0) scale(.5)}20%{opacity:.8;transform:translateY(-5px) scale(1)}80%{opacity:.6;transform:translateY(-15px) scale(.8)}}.shimmer-button{position:relative;overflow:hidden}.shimmer-button:after{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.3) 50%,transparent);animation:shimmer 3s ease-in-out infinite}.shimmer-button:disabled:after{animation:none;opacity:0}@keyframes shimmer{0%{left:-100%}50%,to{left:100%}}.email-hook{font-size:.95rem;color:var(--coral);font-weight:500;margin-bottom:.5rem}.sales-pitch{font-size:1rem;line-height:1.7;color:var(--ink);margin-bottom:1.5rem;padding:1.25rem 1.25rem 1.25rem 1.5rem;background:linear-gradient(135deg,rgba(255,255,255,.7),rgba(255,245,240,.6));border-radius:16px;border-left:3px solid var(--coral);box-shadow:0 4px 20px rgba(242,140,127,.1),inset 0 1px 0 rgba(255,255,255,.8);position:relative;animation:fadeSlideUp .8s ease-out .2s both}.sales-pitch:before{content:'"';position:absolute;top:-8px;left:12px;font-family:var(--font-serif);font-size:3rem;color:var(--coral);opacity:.2;line-height:1}@keyframes fadeSlideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.form-row{display:flex;flex-direction:column;gap:1rem}.form-error{font-size:.9rem;color:#dc2626;margin:0}.confirm-dialog-backdrop{position:fixed;inset:0;background:rgba(0,0,0,.5);display:flex;align-items:center;justify-content:center;z-index:1000;padding:24px;animation:fadeIn .2s ease-out}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.confirm-dialog{background:white;border-radius:16px;padding:24px;max-width:340px;width:100%;box-shadow:0 20px 60px rgba(0,0,0,.2);animation:dialogIn .2s ease-out}@keyframes dialogIn{0%{opacity:0;transform:scale(.95) translateY(10px)}to{opacity:1;transform:scale(1) translateY(0)}}.confirm-dialog-title{font-family:var(--font-serif);font-size:1.25rem;margin:0 0 .5rem;color:var(--ink)}.confirm-dialog-message{font-size:.95rem;color:var(--muted);line-height:1.5;margin:0 0 1.5rem}.confirm-dialog-buttons{display:flex;gap:12px}.confirm-dialog-button{flex:1;padding:12px 16px;border-radius:10px;font-size:.95rem;font-weight:600;cursor:pointer;transition:all .2s}.confirm-dialog-button.cancel{background:rgba(34,40,30,.08);border:none;color:var(--ink)}.confirm-dialog-button.cancel:hover{background:rgba(34,40,30,.12)}.confirm-dialog-button.confirm{background:var(--coral);border:none;color:white}.confirm-dialog-button.confirm:hover{filter:brightness(1.05)}.email-screen>*,.insights-screen>*{max-width:580px}@media (max-width:480px){.calculator-content{padding:0 16px}.screen-header h1{font-size:1.5rem}.angel-number-reveal{font-size:90px}.dob-input{width:60px;height:50px;font-size:1.1rem}.dob-input.year{width:80px}}