body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;margin:0}.app{background-color:#f5f5f5;min-height:100vh;text-align:center}.app-header{background-color:#282c34;color:#fff;padding:20px}.social-login{margin:20px;padding:20px}.social-button{background-color:#4caf50;border:none;border-radius:4px;color:#fff;cursor:pointer;font-size:16px;padding:10px 20px;transition:background-color .3s}.social-button:hover{background-color:#45a049}.message-container{background-color:#fff;border-radius:8px;box-shadow:0 2px 4px #0000001a;margin:40px auto;max-width:600px;padding:20px}.message{background-color:#e8f5e9;border-radius:4px;color:#333;font-size:1.2em;margin:20px 0;padding:15px}.app{display:flex;flex-direction:column;height:100vh}.content{flex:1 1;overflow-y:auto;padding-bottom:60px}.tab-bar{background:linear-gradient(135deg,#1a1a2e,#16213e 50%,#0f3460);border-top:2px solid gold;bottom:0;box-shadow:0 -4px 20px #0000004d;height:60px;justify-content:space-around;left:0;position:fixed;right:0;z-index:1000}.tab-bar,.tab-item{align-items:center;display:flex}.tab-item{border-radius:8px;color:#ccc;cursor:pointer;flex-direction:column;justify-content:center;min-width:80px;padding:5px;position:relative;transition:all .3s}.tab-item:hover{background-color:#ffd7001a;color:gold;transform:translateY(-2px)}.tab-item.active{background:#ffd70026;box-shadow:0 0 15px #ffd70066;color:gold}.tab-item.active:before{background:gold;border-radius:2px;content:"";height:3px;left:50%;position:absolute;top:-2px;transform:translateX(-50%);width:20px}.tab-icon{font-size:24px;margin-bottom:2px}.tab-title{font-size:12px;font-weight:500;white-space:nowrap}@media (max-width:768px){.tab-item{min-width:60px}.tab-icon{font-size:20px}.tab-title{font-size:10px}}.daily-fortune-page{background:linear-gradient(135deg,#667eea,#764ba2);color:#333;margin:0 auto;max-width:600px;min-height:100vh;padding:20px}.fortune-header{color:#fff;padding:20px 0 30px;text-align:center}.fortune-header h1{font-size:28px;font-weight:600;margin:0 0 8px;text-shadow:0 2px 4px #0000004d}.fortune-subtitle{font-size:16px;margin:0 0 16px;opacity:.9}.date-info{background:#ffffff1a;border-radius:20px;display:inline-block;font-size:14px;opacity:.8;padding:8px 16px}.fortune-input-section{background:#fff;border-radius:16px;box-shadow:0 8px 32px #0000001a;margin-bottom:20px;padding:24px}.input-group{margin-bottom:20px}.input-group label{color:#333;display:block;font-size:16px;font-weight:600;margin-bottom:8px}.input-group textarea{border:2px solid #e8e8e8;border-radius:8px;box-sizing:border-box;font-family:inherit;font-size:16px;min-height:100px;padding:12px;resize:vertical;width:100%}.input-group textarea:focus{border-color:#667eea;box-shadow:0 0 0 3px #667eea1a;outline:none}.permission-status{background:#f8f9fa;border-radius:8px;margin-bottom:24px;padding:16px}.status-item{padding:8px 0}.status-item:not(:last-child){border-bottom:1px solid #e9ecef;margin-bottom:8px;padding-bottom:16px}.setup-btn{transition:background .2s}.setup-btn:hover{background:#138496}.fortune-btn{background:linear-gradient(45deg,#667eea,#764ba2);border:none;border-radius:12px;box-shadow:0 4px 16px #667eea4d;color:#fff;cursor:pointer;font-size:18px;font-weight:600;padding:16px 24px;transition:all .3s;width:100%}.fortune-btn:hover:not(:disabled){box-shadow:0 6px 20px #667eea66;transform:translateY(-2px)}.fortune-btn:disabled{cursor:not-allowed;opacity:.6;transform:none}.usage-status{border-left:4px solid #667eea}.fortune-result{background:#fff;border-radius:16px;box-shadow:0 8px 32px #0000001a;margin-bottom:20px;overflow:hidden}.result-header{background:linear-gradient(45deg,#667eea,#764ba2);text-align:center}.result-header h3{margin:0 0 8px}.result-time{font-size:14px;opacity:.9}.result-content{padding:24px}.result-section{margin-bottom:24px}.result-section:last-child{margin-bottom:0}.result-section h4{color:#333;font-size:16px;font-weight:600;margin:0 0 12px}.result-section p{color:#666;line-height:1.6;margin:0}.result-section ul{color:#666;margin:0;padding-left:20px}.result-section li{margin-bottom:4px}.result-grid{grid-gap:20px;display:grid;gap:20px;grid-template-columns:1fr 1fr;margin-bottom:24px}.result-section.suitable{background:#f0f9ff;border-left:4px solid #10b981;border-radius:8px;padding:16px}.result-section.avoid{background:#fef2f2;border-left:4px solid #ef4444;border-radius:8px;padding:16px}.result-section.lucky{background:#fefce8;border-left:4px solid #eab308;border-radius:8px;padding:16px;text-align:center}.lucky-value{color:#333!important;font-size:18px!important;font-weight:600!important;margin-top:8px!important}.result-footer{background:#f8f9fa;border-top:1px solid #e9ecef;padding:16px 24px;text-align:center}.result-footer p{color:#6c757d;font-size:14px;font-style:italic;margin:0}.divination-animation{align-items:center;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#000000b3;bottom:0;display:flex;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:1000}.divination-container{background:linear-gradient(135deg,#1a1a2e,#16213e 50%,#0f3460);border:2px solid #ffd7004d;border-radius:20px;box-shadow:0 20px 60px #00000080;max-width:400px;padding:40px;text-align:center;width:90%}.divination-step{color:#fff}.divination-step p{color:gold;font-size:16px;font-weight:500;margin:20px 0 0}.incense-animation{align-items:center;display:flex;gap:10px;justify-content:center;margin-bottom:10px}.incense-stick{animation:flicker 2s infinite;font-size:30px}.smoke{animation:float 3s ease-in-out infinite;font-size:24px}@keyframes flicker{0%,to{opacity:1}50%{opacity:.7}}.sticks-container{grid-gap:8px;display:grid;gap:8px;grid-template-columns:repeat(7,1fr);margin:20px auto;max-width:280px}.divination-stick{animation:shake .8s ease-in-out infinite;animation-delay:calc(var(--i)*.1s);font-size:20px}.divination-stick:first-child{animation-delay:.1s}.divination-stick:nth-child(2){animation-delay:.2s}.divination-stick:nth-child(3){animation-delay:.3s}.divination-stick:nth-child(4){animation-delay:.4s}.divination-stick:nth-child(5){animation-delay:.5s}.divination-stick:nth-child(6){animation-delay:.6s}.divination-stick:nth-child(7){animation-delay:.7s}@keyframes shake{0%,to{transform:translateX(0) rotate(0deg)}25%{transform:translateX(-2px) rotate(-2deg)}75%{transform:translateX(2px) rotate(2deg)}}.selected-sticks{display:flex;gap:20px;justify-content:center;margin:20px 0}.selected-stick{animation:glow 2s infinite;background:#ffd7001a;border:2px solid gold;border-radius:12px;padding:16px;text-align:center}.stick-number{color:gold;font-size:18px;font-weight:700;margin-bottom:8px}.stick-visual{animation:pulse 1.5s infinite;font-size:24px}@keyframes glow{0%,to{border-color:gold;box-shadow:0 0 10px #ffd70080}50%{border-color:#ffed4e;box-shadow:0 0 20px #ffd700cc}}@keyframes pulse{0%,to{transform:scale(1)}50%{transform:scale(1.1)}}@media (max-width:768px){.daily-fortune-page{padding:16px}.fortune-header h1{font-size:24px}.fortune-input-section,.result-content{padding:20px}.result-grid{gap:16px;grid-template-columns:1fr}.status-item{align-items:flex-start;flex-direction:column;gap:8px}.status-item span:first-child{margin-right:0}}.bazi-modal-overlay{align-items:center;background:#0009;bottom:0;display:flex;justify-content:center;left:0;padding:20px;position:fixed;right:0;top:0;z-index:1000}.bazi-modal{background:#fff;border-radius:12px;box-shadow:0 10px 30px #0000004d;max-height:90vh;max-width:400px;overflow-y:auto;width:100%}.bazi-modal-header{border-bottom:1px solid #f0f0f0;padding:24px 24px 16px;text-align:center}.bazi-modal-header h2{color:#333;font-size:20px;font-weight:600;margin:0 0 8px}.bazi-subtitle{color:#666;font-size:14px;line-height:1.4;margin:0}.bazi-form{padding:24px}.form-group{margin-bottom:20px}.form-group label{color:#333;display:block;font-size:14px;font-weight:500;margin-bottom:8px}.form-group input,.form-group select{background:#fff;border:1px solid #d9d9d9;border-radius:6px;box-sizing:border-box;font-size:16px;padding:12px;width:100%}.form-group input:focus,.form-group select:focus{border-color:#1890ff;box-shadow:0 0 0 2px #1890ff33;outline:none}.gender-options{display:flex;gap:16px}.radio-option{align-items:center;cursor:pointer;display:flex!important;font-weight:400!important;margin-bottom:0!important}.radio-option input[type=\"radio\"]{margin:0 8px 0 0!important;padding:0!important;width:auto!important}.radio-option span{font-size:16px}.form-actions{display:flex;gap:12px;margin-top:32px}.btn-cancel,.btn-submit{border:none;border-radius:6px;cursor:pointer;flex:1 1;font-size:16px;padding:12px 24px;transition:all .2s}.btn-cancel{background:#f5f5f5;color:#333}.btn-cancel:hover{background:#e8e8e8}.btn-submit{background:#1890ff;color:#fff}.btn-submit:hover{background:#40a9ff}.ganZhi-select{font-family:SimSun,宋体,serif;font-size:14px}.bazi-preview{background:linear-gradient(135deg,#fff9e6,#f0f9ff);border:2px solid gold;border-radius:12px;margin:20px 0;padding:20px;text-align:center}.bazi-preview h4{color:#d4af37;font-size:16px;font-weight:600;margin:0 0 16px}.bazi-pillars{grid-gap:12px;display:grid;gap:12px;grid-template-columns:repeat(4,1fr);margin-bottom:16px}.pillar{align-items:center;background:#ffd7001a;border:1px solid gold;border-radius:8px;display:flex;flex-direction:column;gap:4px;padding:12px 8px}.pillar-label{color:#8b6914;font-size:12px;font-weight:500}.pillar-value{color:#d4af37;font-family:SimSun,宋体,serif;font-size:18px;font-weight:700}.hour-name{color:#8b6914;font-size:14px;font-style:italic;margin:0}.bazi-hint{background:#f9f9f9;margin-top:0;padding:16px 24px 24px}.bazi-hint p{color:#666;font-size:13px;line-height:1.4;margin:0;text-align:center}@media (max-width:768px){.bazi-modal-overlay{padding:10px}.bazi-modal{max-height:95vh}.bazi-modal-header{padding:20px 20px 12px}.bazi-form{padding:20px}.form-group{margin-bottom:16px}.form-actions{flex-direction:column;margin-top:24px}.btn-cancel,.btn-submit{padding:14px 24px}.bazi-pillars{gap:8px;grid-template-columns:repeat(2,1fr)}.pillar{padding:8px}.pillar-value{font-size:16px}}.fengshui-master-page{background:linear-gradient(135deg,#4facfe,#00f2fe);margin:0 auto;max-width:600px;min-height:100vh;padding:20px}.fengshui-header{color:#fff;padding:20px 0 30px;text-align:center}.fengshui-header h1{font-size:28px;font-weight:600;margin:0 0 8px;text-shadow:0 2px 4px #0000004d}.fengshui-subtitle{font-size:16px;margin:0;opacity:.9}.upload-section{background:#fff;border-radius:16px;box-shadow:0 8px 32px #0000001a;margin-bottom:20px;padding:24px}.upload-area{border:2px dashed #d0d7de;border-radius:12px;cursor:pointer;padding:40px 20px;text-align:center;transition:all .3s}.upload-area:hover{background-color:#f8fbff;border-color:#4facfe}.upload-icon{font-size:48px;margin-bottom:16px}.upload-area p{color:#333;font-size:18px;font-weight:500;margin:0 0 8px}.upload-hint{color:#666;font-size:14px}.image-preview{position:relative;text-align:center}.image-container{display:inline-block;position:relative}.image-preview img{border-radius:12px;box-shadow:0 4px 16px #0000001a;max-height:400px;max-width:100%}.object-marker{animation:marker-pulse 2s infinite;border:2px solid;border-radius:4px;pointer-events:none;position:absolute}.object-label{border-radius:12px;box-shadow:0 2px 4px #0003;color:#fff;font-size:12px;font-weight:500;left:0;padding:2px 8px;position:absolute;top:-25px;white-space:nowrap}@keyframes marker-pulse{0%,to{opacity:.8;transform:scale(1)}50%{opacity:1;transform:scale(1.02)}}.change-image-btn{background:#000000b3;border:none;border-radius:6px;color:#fff;cursor:pointer;font-size:12px;padding:8px 12px;position:absolute;right:10px;top:10px}.analysis-section{background:#fff;border-radius:16px;box-shadow:0 8px 32px #0000001a;margin-bottom:20px;padding:24px}.permission-check{background:#f8f9fa;border-radius:8px;margin-bottom:20px;padding:16px}.status-item{align-items:center;display:flex;justify-content:space-between}.status-icon{font-size:16px;margin-right:8px}.setup-btn{background:#17a2b8;border-radius:4px;color:#fff;font-size:12px;padding:6px 12px}.analyze-btn,.get-suggestions-btn{background:linear-gradient(45deg,#4facfe,#00f2fe);border:none;border-radius:12px;box-shadow:0 4px 16px #4facfe4d;color:#fff;cursor:pointer;font-size:18px;font-weight:600;padding:16px 24px;transition:all .3s;width:100%}.analyze-btn:hover:not(:disabled),.get-suggestions-btn:hover:not(:disabled){box-shadow:0 6px 20px #4facfe66;transform:translateY(-2px)}.analyze-btn:disabled,.get-suggestions-btn:disabled{cursor:not-allowed;opacity:.6;transform:none}.usage-status{align-items:center;background:#f8f9fa;border-left:4px solid #4facfe;border-radius:8px;display:flex;justify-content:space-between;margin-bottom:16px;padding:12px 16px}.usage-text{color:#333;font-size:14px;font-weight:600}.usage-hint{background:#e9ecef;border-radius:12px;color:#666;font-size:12px;padding:4px 8px}.analysis-result{background:#fff;border-radius:16px;box-shadow:0 8px 32px #0000001a;margin-bottom:20px;overflow:hidden}.result-header{align-items:center;background:linear-gradient(45deg,#4facfe,#00f2fe);color:#fff;display:flex;justify-content:space-between;padding:20px 24px}.result-header h3{font-size:20px;font-weight:600;margin:0}.overall-score{align-items:center;display:flex;font-size:16px;gap:8px}.score{color:gold;font-size:24px;font-weight:700}.goal-input-section,.objects-section,.suggestions-section{padding:24px}.goal-input-section h4,.objects-section h4,.suggestions-section h4{color:#333;font-size:18px;font-weight:600;margin:0 0 16px}.objects-grid{grid-gap:12px;display:grid;gap:12px;grid-template-columns:repeat(auto-fit,minmax(150px,1fr))}.object-card{background:#f8f9fa;border-radius:8px;padding:16px;text-align:center}.object-name{color:#333;font-size:16px;font-weight:600;margin-bottom:8px}.object-element{border-radius:12px;color:#fff;display:inline-block;font-size:14px;font-weight:500;margin-bottom:8px;padding:4px 12px}.object-confidence{color:#666;font-size:12px}.goal-input-section textarea{border:2px solid #e8e8e8;border-radius:8px;box-sizing:border-box;font-family:inherit;font-size:16px;margin-bottom:16px;min-height:80px;padding:12px;resize:vertical;width:100%}.goal-input-section textarea:focus{border-color:#4facfe;box-shadow:0 0 0 3px #4facfe1a;outline:none}.suggestion-card{background:#f8f9fa;border-left:4px solid #4facfe;border-radius:12px;margin-bottom:16px;padding:20px}.suggestion-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:16px}.object-tag{background:#4facfe;border-radius:12px;color:#fff;font-size:14px;font-weight:500;padding:4px 12px}.suggestion-cartoon{font-size:24px}.suggestion-content>div{margin-bottom:12px}.suggestion-content>div:last-child{margin-bottom:0}.suggestion-content strong{color:#333;font-size:14px}.suggestion-content p{color:#666;line-height:1.5;margin:4px 0 0}.yijing-quote{background:#fff3cd;border-left:3px solid #ffc107;border-radius:8px;padding:12px}.quote-text{color:#856404!important;font-style:italic}@media (max-width:768px){.fengshui-master-page{padding:16px}.fengshui-header h1{font-size:24px}.analysis-section,.goal-input-section,.objects-section,.suggestions-section,.upload-section{padding:20px}.result-header{flex-direction:column;gap:12px;text-align:center}.objects-grid{grid-template-columns:repeat(auto-fit,minmax(120px,1fr))}.suggestion-header{align-items:flex-start;flex-direction:column;gap:8px}}.profile-page{background:linear-gradient(135deg,#a8edea,#fed6e3);margin:0 auto;max-width:600px;min-height:100vh;padding:20px}.profile-loading{align-items:center;color:#666;display:flex;font-size:18px;height:100vh;justify-content:center}.profile-header{color:#333;padding:20px 0 30px;text-align:center}.profile-header h1{color:#2c3e50;font-size:28px;font-weight:600;margin:0 0 8px}.profile-subtitle{color:#7f8c8d;font-size:16px;margin:0}.profile-card{background:#fff;border-radius:16px;box-shadow:0 8px 32px #0000001a;margin-bottom:20px;padding:24px}.user-info{align-items:center;display:flex;gap:20px}.user-avatar{flex-shrink:0}.avatar-circle{align-items:center;background:linear-gradient(45deg,#a8edea,#fed6e3);border-radius:50%;display:flex;font-size:24px;height:60px;justify-content:center;overflow:hidden;width:60px}.avatar-circle img{border-radius:50%;height:100%;object-fit:cover;width:100%}.user-details h3{color:#2c3e50;font-size:20px;font-weight:600;margin:0 0 8px}.user-status{color:#7f8c8d;line-height:1.5;margin:0 0 8px}.join-date{color:#95a5a6;font-size:14px}.user-provider{align-items:center;color:#7f8c8d;display:flex;font-size:14px;gap:6px;margin:4px 0}.user-provider .provider-icon{font-size:16px}.card-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:20px}.card-header h3{color:#2c3e50;font-size:18px;font-weight:600;margin:0}.edit-btn{background:#3498db;border:none;border-radius:6px;color:#fff;cursor:pointer;font-size:14px;padding:6px 12px;transition:background .2s}.edit-btn:hover{background:#2980b9}.bazi-details{display:flex;flex-direction:column;gap:12px}.bazi-item,.location-item{align-items:center;border-bottom:1px solid #ecf0f1;display:flex;justify-content:space-between;padding:8px 0}.bazi-item:last-child,.location-item:last-child{border-bottom:none}.label{color:#7f8c8d;font-weight:500}.value{color:#2c3e50;font-weight:600}.setup-prompt{background:linear-gradient(45deg,#fff3cd,#ffeeba)!important;border-left:4px solid #ffc107;text-align:center}.prompt-content{align-items:center;display:flex;flex-direction:column;gap:16px}.prompt-icon{font-size:48px}.prompt-content h3{color:#856404;font-size:20px;margin:0}.prompt-content p{color:#856404;line-height:1.5;margin:0}.setup-btn{background:#ffc107;border:none;border-radius:8px;color:#856404;cursor:pointer;font-size:16px;font-weight:600;padding:12px 24px;transition:all .2s}.setup-btn:hover{background:#e0a800;transform:translateY(-1px)}.permissions-list{display:flex;flex-direction:column;gap:16px}.permission-item{align-items:center;background:#f8f9fa;border-radius:8px;display:flex;justify-content:space-between;padding:16px}.permission-info{align-items:center;display:flex;flex:1 1;gap:12px}.permission-icon{font-size:20px}.permission-details{display:flex;flex-direction:column;gap:4px}.permission-name{color:#2c3e50;font-weight:600}.permission-desc{color:#7f8c8d;font-size:14px}.permission-btn{background:#27ae60;border:none;border-radius:6px;color:#fff;cursor:pointer;font-size:14px;padding:8px 16px;transition:background .2s}.permission-btn:hover{background:#229954}.energy-btn{animation:energy-glow 3s ease-in-out infinite!important;background:linear-gradient(45deg,#ff6b6b,#ffd93d,#6bcf7f,#4d96ff)!important;background-size:300% 300%!important;box-shadow:0 4px 15px #ff6b6b66!important;font-weight:600!important;overflow:hidden!important;position:relative!important}.energy-btn:before{animation:energy-shine 2s linear infinite;background:linear-gradient(45deg,#0000,#ffffff4d,#0000);content:"";height:200%;left:-50%;position:absolute;top:-50%;transform:rotate(45deg);width:200%}.energy-btn:hover{animation-duration:1.5s!important;box-shadow:0 6px 20px #ff6b6b99!important;transform:translateY(-2px)!important}@keyframes energy-glow{0%,to{background-position:0 50%;box-shadow:0 4px 15px #ff6b6b66}25%{background-position:100% 50%;box-shadow:0 4px 15px #ffd93d66}50%{background-position:200% 50%;box-shadow:0 4px 15px #6bcf7f66}75%{background-position:300% 50%;box-shadow:0 4px 15px #4d96ff66}}@keyframes energy-shine{0%{transform:translateX(-100%) translateY(-100%) rotate(45deg)}to{transform:translateX(100%) translateY(100%) rotate(45deg)}}.location-details{display:flex;flex-direction:column;gap:12px}.no-location{color:#7f8c8d;font-style:italic;margin:0;padding:20px;text-align:center}.settings-list{display:flex;flex-direction:column;gap:12px}.setting-item{align-items:center;border:none;border-radius:8px;cursor:pointer;display:flex;font-size:16px;gap:12px;padding:16px;text-align:left;transition:all .2s;width:100%}.setting-item.danger{background:#fff5f5;border:1px solid #feb2b2;color:#e53e3e}.setting-item.danger:hover{background:#fed7d7}.setting-item.logout{background:#f0f8ff;border:1px solid #b3d9ff;color:#4a90e2}.setting-item.logout:hover{background:#e6f3ff;transform:translateY(-1px)}.setting-icon{font-size:20px}.setting-text{font-weight:500}.about{background:linear-gradient(45deg,#e3f2fd,#f3e5f5)!important;text-align:center}.about-content h3{color:#2c3e50;font-size:20px;margin:0 0 16px}.about-content p{color:#7f8c8d;line-height:1.5;margin:8px 0}.confirm-dialog-overlay{align-items:center;background:#0009;bottom:0;display:flex;justify-content:center;left:0;padding:20px;position:fixed;right:0;top:0;z-index:1000}.confirm-dialog{background:#fff;border-radius:12px;box-shadow:0 10px 30px #0000004d;max-width:400px;padding:24px;width:100%}.confirm-dialog h3{color:#e53e3e;font-size:20px;margin:0 0 16px;text-align:center}.confirm-dialog p{color:#666;line-height:1.5;margin:0 0 24px;text-align:center}.dialog-actions{display:flex;gap:12px}.cancel-btn,.confirm-btn{border:none;border-radius:6px;cursor:pointer;flex:1 1;font-size:16px;padding:12px 24px;transition:all .2s}.cancel-btn{background:#f5f5f5;color:#333}.cancel-btn:hover{background:#e8e8e8}.confirm-btn{background:#e53e3e;color:#fff}.confirm-btn:hover{background:#c53030}@media (max-width:768px){.profile-page{padding:16px}.profile-header h1{font-size:24px}.profile-card{padding:20px}.user-info{flex-direction:column;gap:16px;text-align:center}.permission-item{align-items:flex-start;flex-direction:column;gap:12px}.permission-info{width:100%}.card-header{gap:12px}.bazi-item,.card-header,.location-item{align-items:flex-start;flex-direction:column}.bazi-item,.location-item{gap:4px}}.login-container{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);display:flex;flex-direction:column;justify-content:center;min-height:100vh;padding:20px;position:relative}.login-container:before{background-image:radial-gradient(circle at 20% 20%,#ffd7001a 0,#0000 50%),radial-gradient(circle at 80% 80%,#dc143c1a 0,#0000 50%),radial-gradient(circle at 40% 70%,#ff8c001a 0,#0000 50%);bottom:0;content:"";left:0;pointer-events:none;position:absolute;right:0;top:0}.login-header{margin-bottom:40px;text-align:center;z-index:1}.logo-container{margin-bottom:16px}.logo{animation:float 3s ease-in-out infinite;font-size:4rem;margin-bottom:8px}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}.app-title{-webkit-text-fill-color:#0000;background:linear-gradient(45deg,gold,orange);-webkit-background-clip:text;background-clip:text;color:#fff;font-size:2.5rem;font-weight:700;margin:0;text-shadow:0 2px 4px #0000004d}.app-subtitle{color:#ffffffe6;font-size:1rem;margin:8px 0 0;text-shadow:0 1px 2px #0000004d}.login-content{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#fffffff2;border:1px solid #fff3;border-radius:20px;box-shadow:0 8px 32px #0000001a;max-width:400px;padding:32px 24px;width:100%;z-index:1}.welcome-text{margin-bottom:32px;text-align:center}.welcome-text h2{color:#333;font-size:1.5rem;margin:0 0 8px}.welcome-text p{color:#666;font-size:.9rem;margin:0}.login-methods{display:flex;flex-direction:column;gap:16px;margin-bottom:32px}.google-login-btn{background:linear-gradient(45deg,#4285f4,#34a853);border:none;border-radius:12px;box-shadow:0 4px 12px #4285f44d;font-size:1rem;font-weight:500;height:50px;transition:all .3s ease}.google-login-btn:hover{box-shadow:0 6px 20px #4285f466;transform:translateY(-2px)}.guest-login-btn{background:linear-gradient(45deg,#ff6b6b,#feca57);border:none;border-radius:12px;box-shadow:0 4px 12px #ff6b6b4d;color:#fff;font-size:1rem;font-weight:500;height:50px;transition:all .3s ease}.guest-login-btn:hover{box-shadow:0 6px 20px #ff6b6b66;transform:translateY(-2px)}.google-icon,.guest-icon{font-size:1.1rem;margin-right:8px}.login-features{background:#ffd7001a;border-radius:12px;margin-bottom:20px;padding:20px}.login-features h3{color:#333;font-size:1.1rem;margin:0 0 12px;text-align:center}.login-features ul{list-style:none;margin:0;padding:0}.login-features li{color:#555;font-size:.9rem;margin:8px 0;padding-left:8px;position:relative}.login-footer{text-align:center;z-index:1}.login-footer p{color:#fffc;font-size:.8rem;margin:0}.loading-overlay{align-items:center;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#000000b3;bottom:0;display:flex;flex-direction:column;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:1000}.loading-overlay p{color:#fff;font-size:1rem;margin-top:16px}@media (max-width:480px){.login-container{padding:16px}.app-title{font-size:2rem}.login-content{padding:24px 20px}.google-login-btn,.guest-login-btn{font-size:.9rem;height:48px}}.auth-callback-container{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);display:flex;justify-content:center;min-height:100vh;padding:20px;position:relative}.auth-callback-container:before{background-image:radial-gradient(circle at 20% 20%,#ffd7001a 0,#0000 50%),radial-gradient(circle at 80% 80%,#dc143c1a 0,#0000 50%);bottom:0;content:"";left:0;pointer-events:none;position:absolute;right:0;top:0}.auth-callback-content{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#fffffff2;border:1px solid #fff3;border-radius:20px;box-shadow:0 8px 32px #0000001a;max-width:400px;padding:40px 30px;text-align:center;width:100%;z-index:1}.auth-callback-icon{align-items:center;display:flex;height:60px;justify-content:center;margin-bottom:24px}.loading-spinner{animation:spin 1s linear infinite;font-size:2rem}@keyframes spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}.error-icon,.success-icon{animation:scaleIn .5s ease-out;font-size:3rem}@keyframes scaleIn{0%{opacity:0;transform:scale(0)}to{opacity:1;transform:scale(1)}}.auth-callback-message h2{color:#333;font-size:1.4rem;font-weight:600;margin:0 0 12px}.auth-callback-message p{color:#666;font-size:.9rem;line-height:1.5;margin:0}.loading-animation{margin-top:32px}.fortune-symbols{display:flex;gap:16px;justify-content:center;margin-bottom:20px}.symbol{animation:bounce 2s infinite;font-size:1.5rem}.symbol:first-child{animation-delay:0s}.symbol:nth-child(2){animation-delay:.2s}.symbol:nth-child(3){animation-delay:.4s}.symbol:nth-child(4){animation-delay:.6s}@keyframes bounce{0%,20%,50%,80%,to{transform:translateY(0)}40%{transform:translateY(-10px)}60%{transform:translateY(-5px)}}@media (max-width:480px){.auth-callback-content{padding:30px 20px}.auth-callback-message h2{font-size:1.2rem}.fortune-symbols{gap:12px}.symbol{font-size:1.2rem}}
/*# sourceMappingURL=main.9ce958bc.css.map*/