@font-face{font-family:MaShanZheng;src:url(/travel/v1/fonts/MaShanZheng-subset.woff2) format("woff2");font-weight:400;font-style:normal;font-display:swap}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}body{font-family:-apple-system,BlinkMacSystemFont,PingFang SC,Hiragino Sans GB,Noto Sans CJK SC,Microsoft YaHei,Helvetica Neue,sans-serif;background:#fff8f0;color:#3e2723;min-height:100vh;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;overflow-x:hidden}#root{max-width:480px;margin:0 auto;min-height:100vh;position:relative}.app{min-height:100vh}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}@keyframes bounce{0%,to{transform:scale(1)}50%{transform:scale(1.05)}}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-8px)}}@keyframes countUp{0%{opacity:0;transform:scale(.5)}to{opacity:1;transform:scale(1)}}.cloud-bg{position:fixed;top:0;left:0;right:0;bottom:0;pointer-events:none;z-index:0;overflow:hidden}.cloud-bg:before{content:"";position:absolute;width:200%;height:200%;top:-50%;left:-50%;background:radial-gradient(ellipse 80px 40px at 20% 30%,rgba(211,47,47,.04) 0%,transparent 70%),radial-gradient(ellipse 60px 30px at 70% 20%,rgba(211,47,47,.03) 0%,transparent 70%),radial-gradient(ellipse 90px 45px at 40% 60%,rgba(255,215,0,.03) 0%,transparent 70%),radial-gradient(ellipse 70px 35px at 80% 70%,rgba(211,47,47,.04) 0%,transparent 70%),radial-gradient(ellipse 50px 25px at 10% 80%,rgba(255,215,0,.03) 0%,transparent 70%),radial-gradient(ellipse 100px 50px at 60% 90%,rgba(211,47,47,.03) 0%,transparent 70%)}.cloud-bg:after{content:"";position:absolute;top:0;left:0;right:0;bottom:0;background:radial-gradient(circle at 15% 15%,rgba(211,47,47,.02) 0%,transparent 50%),radial-gradient(circle at 85% 85%,rgba(255,215,0,.02) 0%,transparent 50%)}.page{min-height:100vh;padding:1.5rem 1rem 2rem;position:relative;z-index:1;animation:fadeIn .4s ease}.lanterns{display:flex;justify-content:space-between;padding:0 .5rem;margin-bottom:.5rem}.lantern{font-size:2rem;animation:float 3s ease-in-out infinite}.lantern-right{animation-delay:1.5s}.btn{display:inline-flex;align-items:center;justify-content:center;gap:.4rem;padding:.85rem 1.6rem;border:none;border-radius:12px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .2s ease;font-family:inherit;text-decoration:none}.btn:active{transform:scale(.97)}.btn:disabled{opacity:.6;cursor:not-allowed}.btn-gold{background:linear-gradient(135deg,gold,#ffa000);color:#3e2723;box-shadow:0 4px 15px #ffd7004d}.btn-gold:hover:not(:disabled){background:linear-gradient(135deg,#ffc107,#ff8f00);box-shadow:0 6px 20px #ffd70066}.btn-outline{background:transparent;color:#d32f2f;border:2px solid #D32F2F}.btn-outline:hover:not(:disabled){background:#ffebee}.btn-large{width:100%;padding:1rem;font-size:1.1rem;border-radius:14px}.code-card,.birthday-card,.survey-card,.result-card,.city-card,.wuxing-recap,.blessing-card{background:#fff;border-radius:16px;padding:1.5rem;box-shadow:0 2px 12px #0000000f;border:1px solid rgba(211,47,47,.08);position:relative;overflow:hidden}.code-card:before,.birthday-card:before,.survey-card:before,.city-card-top1:before{content:"";position:absolute;top:0;left:10%;right:10%;height:3px;background:linear-gradient(90deg,transparent,#D32F2F,#FFD700,#D32F2F,transparent);border-radius:0 0 4px 4px}.code-verify-page{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:100vh;padding:2rem 1rem}.code-card{width:100%;max-width:360px;text-align:center;animation:slideUp .5s ease}.horse-icon{font-size:4rem;margin-bottom:.5rem;animation:float 3s ease-in-out infinite}.code-card .title{font-family:MaShanZheng,-apple-system,sans-serif;font-size:2.2rem;color:#c41a16;font-weight:400;letter-spacing:.08em;margin-bottom:.3rem;text-shadow:1px 1px 3px rgba(0,0,0,.08)}.horse-icon-img{width:180px;height:180px;border-radius:16px;object-fit:cover;margin-bottom:.8rem;box-shadow:0 4px 20px #d32f2f1f}.code-card .subtitle{color:#8d6e63;font-size:.95rem;margin-bottom:1.5rem}.code-form{display:flex;flex-direction:column;gap:.8rem}.code-input{width:100%;padding:.9rem 1rem;border:2px solid #E0D5C8;border-radius:12px;font-size:1rem;text-align:center;background:#fffaf5;color:#3e2723;font-family:inherit;transition:border-color .2s;outline:none}.code-input:focus{border-color:#d32f2f;box-shadow:0 0 0 3px #d32f2f1a}.code-input::placeholder{color:#bcaaa4}.error-text{color:#d32f2f;font-size:.85rem;margin:-.3rem 0}.home-page{display:flex;flex-direction:column;align-items:center;text-align:center}.home-content{display:flex;flex-direction:column;align-items:center;gap:1rem;animation:slideUp .5s ease;width:100%}.calligraphy-title{font-family:MaShanZheng,-apple-system,sans-serif;font-weight:400;letter-spacing:.08em}.horse-hero{font-size:5rem;animation:float 3s ease-in-out infinite;margin-top:1rem}.horse-hero-img{width:240px;height:240px;border-radius:20px;object-fit:cover;box-shadow:0 8px 30px #d32f2f26;animation:float 3s ease-in-out infinite}.home-title{font-family:MaShanZheng,-apple-system,sans-serif;font-size:2.8rem;color:#c41a16;font-weight:400;letter-spacing:.08em;text-shadow:2px 2px 4px rgba(0,0,0,.1)}.home-subtitle{color:#8b6914;font-size:.95rem;line-height:1.6;text-align:center}.steps-intro{width:100%;display:flex;flex-direction:column;gap:.6rem;margin:.8rem 0}.step-item{display:flex;align-items:center;gap:.7rem;padding:.6rem .8rem;background:#ffffffb3;border-radius:12px;border:1px solid rgba(211,47,47,.06)}.step-num{width:28px;height:28px;border-radius:50%;background:linear-gradient(135deg,#d32f2f,#ff6f00);color:#fff;display:flex;align-items:center;justify-content:center;font-size:.8rem;font-weight:700;flex-shrink:0}.step-text{flex:1}.step-title{font-size:.9rem;font-weight:600;color:#3e2723}.step-desc{font-size:.75rem;color:#8d6e63;margin-top:.1rem}.steps-intro-sm{gap:.4rem;margin:.5rem 0}.steps-intro-sm .step-item{padding:.4rem .6rem}.steps-intro-sm .step-num{width:24px;height:24px;font-size:.7rem}.steps-intro-sm .step-title{font-size:.82rem}.steps-intro-sm .step-desc{font-size:.7rem}.birthday-page{display:flex;flex-direction:column;align-items:center}.birthday-card{width:100%;animation:slideUp .5s ease}.section-title{font-size:1.4rem;color:#d32f2f;font-weight:700;text-align:center;margin-bottom:.5rem}.section-desc{text-align:center;color:#8d6e63;font-size:.9rem;margin-bottom:1.2rem}.form-group{margin-bottom:1rem}.form-group label{display:block;font-size:.9rem;font-weight:600;color:#5d4037;margin-bottom:.4rem}.optional{font-weight:400;color:#bcaaa4;font-size:.8rem}.privacy-note{text-align:center;font-size:.75rem;color:#bcaaa4;margin-top:.8rem;line-height:1.5}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:.8rem}.select-input{width:100%;padding:.85rem 1rem;border:2px solid #E0D5C8;border-radius:12px;font-size:1rem;background:#fffaf5;color:#3e2723;font-family:inherit;-moz-appearance:none;appearance:none;-webkit-appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%238D6E63' fill='none' stroke-width='2'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 1rem center;cursor:pointer;outline:none;transition:border-color .2s;min-height:48px}.select-input:focus{border-color:#d32f2f;box-shadow:0 0 0 3px #d32f2f1a}.wuxing-result{width:100%;animation:slideUp .5s ease}.wuxing-main{display:flex;flex-direction:column;align-items:center;gap:.3rem;margin:1rem 0}.wuxing-emoji{font-size:2.5rem}.wuxing-label{display:flex;align-items:baseline;gap:.3rem}.wuxing-big{font-size:2rem;font-weight:700}.wuxing-dot{font-size:1.5rem;color:#bcaaa4}.wuxing-sub{font-size:1.3rem;font-weight:600}.tiangan-info{font-size:.9rem;color:#8d6e63;margin-top:.2rem}.wuxing-bars{margin:1.2rem 0}.bar-row{display:flex;align-items:center;gap:.6rem;margin-bottom:.6rem}.bar-label{min-width:3rem;font-size:.9rem;font-weight:500;text-align:right}.bar-track{flex:1;height:20px;background:#f5ede4;border-radius:10px;overflow:hidden}.bar-fill{height:100%;border-radius:10px;transition:width 1s ease;min-width:4px}.bar-val{min-width:2rem;font-size:.85rem;color:#8d6e63;font-weight:600;text-align:right}.wuxing-text-card{background:#fffaf5;border-radius:12px;padding:1rem;margin:1rem 0;border-left:3px solid #D32F2F}.wuxing-text-card p{font-size:.9rem;line-height:1.7;color:#5d4037}.survey-page{display:flex;flex-direction:column;align-items:center;padding-top:1rem}.progress-bar{width:100%;height:8px;background:#f5ede4;border-radius:4px;position:relative;margin-bottom:1.5rem;overflow:visible}.progress-fill{height:100%;background:linear-gradient(90deg,gold,#ffa000);border-radius:4px;transition:width .4s ease;box-shadow:0 0 8px #ffd70066}.progress-text{position:absolute;right:0;top:14px;font-size:.8rem;color:#8d6e63;font-weight:500}.survey-card{width:100%;animation:slideUp .3s ease}.survey-title{font-size:1.5rem;color:#d32f2f;font-weight:700;text-align:center;margin-bottom:1.2rem}.options{display:flex;flex-direction:column;gap:.7rem}.option-card{display:flex;align-items:center;gap:.8rem;padding:1rem;background:#fffaf5;border:2px solid #F0E6DA;border-radius:14px;cursor:pointer;transition:all .2s ease;-webkit-tap-highlight-color:transparent}.option-card:active{transform:scale(.98)}.option-card.selected{border-color:#d32f2f;background:#fff0f0;transform:scale(1.02);box-shadow:0 2px 12px #d32f2f26}.option-emoji{font-size:1.8rem;min-width:2.5rem;text-align:center}.option-text{flex:1}.option-label{font-size:1rem;font-weight:600;color:#3e2723}.option-desc{font-size:.8rem;color:#8d6e63;margin-top:.15rem}.result-page{padding-bottom:3rem}.result-content{background:#fff8f0;padding:.5rem 0}.result-header{display:flex;align-items:center;justify-content:center;gap:.8rem;margin-bottom:1rem;animation:fadeIn .5s ease}.result-header .lantern{font-size:1.5rem}.result-title{font-size:1.3rem;color:#d32f2f;font-weight:700}.wuxing-recap{padding:1rem;margin-bottom:1rem;animation:slideUp .5s ease;background:linear-gradient(135deg,#fff8f0,#fff0f0)}.wuxing-recap-main{display:flex;align-items:center;justify-content:center;gap:.3rem;margin-bottom:.8rem}.wuxing-recap-main .wuxing-emoji{font-size:1.5rem}.wuxing-recap-main .wuxing-big{font-size:1.3rem}.wuxing-recap-main .wuxing-sub{font-size:1rem}.wuxing-bars-mini{display:flex;flex-direction:column;gap:.3rem}.bar-row-mini{display:flex;align-items:center;gap:.5rem}.bar-label-mini{min-width:2.5rem;font-size:.75rem;text-align:right}.bar-track-mini{flex:1;height:10px;background:#f5ede4;border-radius:5px;overflow:hidden}.bar-fill-mini{height:100%;border-radius:5px;transition:width 1s ease;min-width:3px}.city-card{margin-bottom:1rem;animation:slideUp .6s ease}.city-card-top1{border:2px solid rgba(211,47,47,.2);box-shadow:0 4px 20px #d32f2f1a;animation-delay:.1s;animation-fill-mode:both}.city-card-sub{animation-delay:.3s;animation-fill-mode:both}.city-rank{font-size:.85rem;font-weight:600;color:#d32f2f;margin-bottom:.5rem}.city-header{display:flex;align-items:baseline;gap:.5rem;flex-wrap:wrap;margin-bottom:.5rem}.city-name{font-size:1.6rem;font-weight:700;color:#3e2723}.city-card-sub .city-name{font-size:1.3rem}.city-province{font-size:.85rem;color:#8d6e63}.city-category{font-size:.75rem;background:#ffebee;color:#d32f2f;padding:.15rem .5rem;border-radius:20px;white-space:nowrap}.city-match{display:flex;align-items:baseline;gap:.3rem;margin-bottom:.6rem}.match-num{font-size:2.2rem;font-weight:700;color:#d32f2f;animation:countUp .8s ease}.city-card-sub .match-num{font-size:1.6rem}.match-label{font-size:.85rem;color:#8d6e63}.city-desc{font-size:.9rem;line-height:1.6;color:#5d4037;margin-bottom:.8rem}.city-wuxing-reason{display:flex;gap:.5rem;padding:.8rem;background:linear-gradient(135deg,#fff8f0,#fff3e0);border-radius:10px;margin-bottom:.8rem;border-left:3px solid #FFD700}.city-wuxing-reason .reason-icon{font-size:1.2rem;flex-shrink:0}.city-wuxing-reason p{font-size:.85rem;line-height:1.6;color:#5d4037}.city-reasons{margin-bottom:.8rem}.reason-item{font-size:.85rem;color:#8d6e63;margin-bottom:.3rem}.city-details{display:flex;flex-direction:column;gap:.6rem}.detail-section{display:flex;align-items:flex-start;gap:.4rem;flex-wrap:wrap}.detail-icon{font-size:1rem;flex-shrink:0}.detail-title{font-size:.85rem;font-weight:600;color:#5d4037;min-width:4rem}.detail-text{font-size:.85rem;color:#8d6e63}.detail-tags{display:flex;flex-wrap:wrap;gap:.4rem}.tag{font-size:.75rem;padding:.2rem .6rem;background:#fff3e0;color:#e65100;border-radius:20px;white-space:nowrap}.tag-food{background:#fff0f0;color:#d32f2f}.blessing-card{text-align:center;background:linear-gradient(135deg,#ffebee,#fff8f0);border:1px solid rgba(211,47,47,.1)}.blessing-card p{font-size:.9rem;line-height:1.7;color:#5d4037}.result-blessing{margin:1rem 0}.watermark{text-align:center;color:#d7ccc8;font-size:.8rem;margin-top:.5rem;padding-bottom:.5rem}.result-actions{display:flex;flex-direction:column;gap:.8rem;margin-top:1.5rem;padding:0 .2rem}.footer-text{color:#d7ccc8;font-size:.8rem;text-align:center;margin-top:1.5rem}.back-btn{background:none;border:none;color:#8d6e63;font-size:.85rem;cursor:pointer;padding:.3rem 0;margin-bottom:.5rem;font-family:inherit;display:block}.back-btn:hover{color:#d32f2f}.grid-picker{display:grid;gap:.4rem;margin:.5rem 0}.grid-picker-item{padding:.6rem .2rem;border:1.5px solid #E0D5C8;border-radius:10px;background:#fffaf5;color:#5d4037;font-size:.9rem;font-weight:500;cursor:pointer;font-family:inherit;transition:all .15s;text-align:center;min-height:42px;display:flex;align-items:center;justify-content:center}.grid-picker-item:active{transform:scale(.95)}.grid-picker-item.active{border-color:#d32f2f;background:#d32f2f;color:#fff;font-weight:600;box-shadow:0 2px 8px #d32f2f40}.grid-picker-item.decade-btn{padding:.8rem;font-size:1rem;font-weight:600}.step-section{margin-bottom:.5rem}.step-label{display:block;font-size:.95rem;font-weight:600;color:#5d4037;margin-bottom:.3rem}.back-link{background:none;border:none;color:#bcaaa4;font-size:.8rem;cursor:pointer;padding:0;margin-bottom:.4rem;font-family:inherit}.back-link:active{color:#d32f2f}.birthday-summary{text-align:center;padding:.6rem;margin-bottom:.8rem;background:linear-gradient(135deg,#fff8f0,#ffebee);border-radius:12px;border:1px solid #F5D0C5}.summary-text{font-size:1.1rem;font-weight:600;color:#d32f2f}.summary-hint{display:block;font-size:.75rem;color:#bcaaa4;margin-top:.2rem}.shichen-hint{text-align:center;font-size:.82rem;color:#8d6e63;min-height:1.2rem;margin:.3rem 0 .5rem}.traveler-type-card{background:linear-gradient(135deg,#fff8f0,#ffebee);border-radius:16px;padding:1.2rem;margin-bottom:1rem;text-align:center;border:1px solid rgba(211,47,47,.1);animation:slideUp .5s ease}.traveler-title{font-size:.9rem;color:#8d6e63;margin-bottom:.5rem}.traveler-name{font-size:1.4rem;font-weight:700;color:#d32f2f;margin-bottom:.5rem;letter-spacing:.05em}.traveler-desc{font-size:.9rem;line-height:1.7;color:#5d4037}.city-category[data-cat=nature]{background:#e8f5e9;color:#2e7d32}.city-category[data-cat=culture]{background:#fff3e0;color:#e65100}.city-category[data-cat=beach]{background:#e3f2fd;color:#1565c0}.city-category[data-cat=food]{background:#fce4ec;color:#c62828}.city-category[data-cat=hidden]{background:#f3e5f5;color:#6a1b9a}.city-category[data-cat=city]{background:#e0f2f1;color:#00695c}@media (max-width: 380px){.page{padding:1rem .8rem 1.5rem}.home-title{font-size:1.8rem}.city-name{font-size:1.4rem}.match-num{font-size:1.8rem}}@media (min-width: 481px){body{background:#f5ede4}#root{box-shadow:0 0 30px #00000014;background:#fff8f0}}.nayin-card{background:linear-gradient(135deg,#fdf6ec,#fef0e0);border-radius:12px;padding:1rem;margin:1rem 0;border:1px solid #f0d9b5}.nayin-row{display:flex;justify-content:space-between;align-items:center;padding:.5rem 0;border-bottom:1px dashed #e8d5b8}.nayin-row:last-child{border-bottom:none}.nayin-label{color:#8b7355;font-size:.9rem;min-width:3rem}.nayin-value{color:#5a3e2b;font-weight:600;font-size:1rem}.nayin-highlight{color:#c41a16;font-size:1.2rem}.pillars-grid{display:grid;grid-template-columns:auto 1fr 1fr;gap:.3rem .8rem;font-size:.85rem;margin:.5rem 0}.pillar-label{color:#8d6e63;font-weight:500}.pillar-value{color:#3e2723;font-weight:600}.pillar-nayin{color:#a1887f;font-size:.8rem}.wuxing-dist{display:flex;gap:.5rem;justify-content:center;margin:.4rem 0;flex-wrap:wrap}.wuxing-dist-item{font-size:.82rem;padding:.2rem .5rem;border-radius:8px;background:#0000000a}.day-master-section{text-align:center;margin:.5rem 0}.day-master-tag{display:inline-flex;align-items:center;gap:.3rem;font-size:.88rem;font-weight:600;padding:.25rem .7rem;border-radius:10px;background:#d32f2f14;color:#c41a16}.day-master-desc{font-size:.78rem;color:#8d6e63;margin:.3rem 0 0;line-height:1.5}.wuxing-dist-item.empty{color:#bcaaa4;text-decoration:line-through}.wuxing-lack-note{text-align:center;font-size:.75rem;color:#d32f2f;margin:.2rem 0 0}.pillar-note{text-align:center;font-size:.72rem;color:#bcaaa4;margin:.4rem 0 0;line-height:1.4}.nayin-recap{display:flex;justify-content:center;gap:.8rem;margin-top:.5rem;flex-wrap:wrap}.nayin-tag{background:#fdf6ec;color:#8b5e3c;padding:.3rem .8rem;border-radius:20px;font-size:.85rem;border:1px solid #e8d5b8}.nayin-relation{background:#fff5f5;color:#c41a16;padding:.3rem .8rem;border-radius:20px;font-size:.85rem;border:1px solid #f0c0c0}.preview-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#000000d9;z-index:9999;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:1rem;animation:fadeIn .3s ease}.preview-tip{color:#fff;font-size:1.1rem;font-weight:500;margin-bottom:1rem;opacity:.95;text-align:center}.preview-image{max-width:92%;max-height:72vh;border-radius:8px;box-shadow:0 4px 30px #00000080;-webkit-touch-callout:default!important;user-select:auto!important;-webkit-user-select:auto!important}.preview-close{color:#ffffff80;font-size:.85rem;margin-top:1rem}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.saving-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;z-index:9998;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1rem;animation:fadeIn .2s ease}.saving-spinner{width:48px;height:48px;border:4px solid rgba(255,255,255,.3);border-top-color:gold;border-radius:50%;animation:spin .8s linear infinite}.saving-text{color:#fff;font-size:1.1rem;font-weight:500}
