.loading{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:16px;padding:24px}.loading--fullscreen{position:fixed;top:0;left:0;right:0;bottom:0;background:#ffffffe6;z-index:9999}.loading__spinner{position:relative;display:inline-block}.loading__spinner--small{width:24px;height:24px}.loading__spinner--medium{width:40px;height:40px}.loading__spinner--large{width:64px;height:64px}.loading__spinner-circle{width:100%;height:100%;border:3px solid #e0e0e0;border-top-color:#1976d2;border-radius:50%;animation:loading-spin .8s linear infinite}@keyframes loading-spin{to{transform:rotate(360deg)}}.loading__text{margin:0;font-size:.9rem;color:#666}.skeleton{background:#e0e0e0;border-radius:4px;position:relative;overflow:hidden}.skeleton--text{height:1em;margin-bottom:8px;border-radius:4px}.skeleton--circular{border-radius:50%}.skeleton--rectangular{border-radius:4px}.skeleton--pulse{animation:skeleton-pulse 1.5s ease-in-out infinite}@keyframes skeleton-pulse{0%,to{opacity:1}50%{opacity:.4}}.skeleton--wave:after{content:"";position:absolute;top:0;left:0;right:0;bottom:0;background:linear-gradient(90deg,transparent,rgba(255,255,255,.5),transparent);animation:skeleton-wave 1.5s linear infinite}@keyframes skeleton-wave{0%{transform:translate(-100%)}to{transform:translate(100%)}}.skeleton-group{display:flex;flex-direction:column;gap:16px}.skeleton-card{border:1px solid #e0e0e0;border-radius:8px;overflow:hidden}.skeleton-card__content{padding:16px;display:flex;flex-direction:column;gap:8px}.skeleton-list-item{display:flex;align-items:center;gap:16px;padding:12px;border-bottom:1px solid #e0e0e0}.skeleton-list-item__content{flex:1;display:flex;flex-direction:column;gap:8px}.skeleton-profile{padding:24px}.skeleton-profile__header{display:flex;align-items:center;gap:16px;margin-bottom:24px}.skeleton-profile__info{flex:1;display:flex;flex-direction:column;gap:8px}.skeleton-profile__stats{display:flex;gap:24px;justify-content:space-around}.skeleton-profile__stat{display:flex;flex-direction:column;align-items:center;gap:8px}.skeleton-article{padding:24px;display:flex;flex-direction:column;gap:16px}@media (max-width: 768px){.skeleton-card__content{padding:12px}.skeleton-profile{padding:16px}.skeleton-profile__stats{gap:16px}.skeleton-article{padding:16px}}@media (prefers-reduced-motion: reduce){.loading__spinner-circle,.skeleton--pulse,.skeleton--wave:after{animation:none}.skeleton--pulse{opacity:.7}}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:10000;padding:16px;animation:modal-fade-in .2s ease-out}@keyframes modal-fade-in{0%{opacity:0}to{opacity:1}}.modal{background:#fff;border-radius:8px;box-shadow:0 8px 32px #0003;max-width:500px;width:100%;max-height:90vh;display:flex;flex-direction:column;animation:modal-slide-up .3s ease-out}@keyframes modal-slide-up{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}.modal__header{display:flex;align-items:center;justify-content:space-between;padding:20px 24px;border-bottom:1px solid #e0e0e0}.modal__title{margin:0;font-size:1.25rem;font-weight:600;color:#333}.modal__close{width:32px;height:32px;display:flex;align-items:center;justify-content:center;background:none;border:none;cursor:pointer;border-radius:4px;transition:background .2s;font-size:20px;color:#666;padding:0}.modal__close:hover{background:#f5f5f5}.modal__close:focus{outline:2px solid #1976d2;outline-offset:2px}.modal__body{padding:24px;overflow-y:auto;flex:1}.modal__message{margin:0;font-size:1rem;line-height:1.6;color:#333}.modal__footer{display:flex;align-items:center;justify-content:flex-end;gap:12px;padding:16px 24px;border-top:1px solid #e0e0e0}.modal__button{padding:10px 24px;border-radius:4px;font-size:.95rem;font-weight:500;cursor:pointer;transition:all .2s;border:none;min-width:80px;min-height:44px}.modal__button--cancel{background:#f5f5f5;color:#666}.modal__button--cancel:hover{background:#e0e0e0}.modal__button--confirm{background:#1976d2;color:#fff}.modal__button--confirm:hover{background:#1565c0}.modal__button:focus{outline:2px solid #1976d2;outline-offset:2px}.modal--warning .modal__title{color:#ff9800}.modal--warning .modal__button--confirm{background:#ff9800}.modal--warning .modal__button--confirm:hover{background:#f57c00}.modal--danger .modal__title{color:#f44336}.modal--danger .modal__button--confirm{background:#f44336}.modal--danger .modal__button--confirm:hover{background:#d32f2f}@media (max-width: 768px){.modal{max-width:none;margin:0;border-radius:8px 8px 0 0;max-height:80vh}.modal-overlay{align-items:flex-end;padding:0}.modal__header{padding:16px 20px}.modal__body{padding:20px}.modal__footer{padding:12px 20px}.modal__button{flex:1}}@media (prefers-reduced-motion: reduce){.modal-overlay,.modal{animation:none}}.app{min-height:100vh;display:flex;flex-direction:column}.main-content{flex:1;padding:2rem 1rem;max-width:1200px;margin:0 auto;width:100%}.index-container{max-width:800px;margin:0 auto}.home-popup-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:10050;display:flex;align-items:center;justify-content:center;padding:24px;background:#180c0494;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.home-popup{position:relative;max-width:min(86vw,520px);max-height:min(82vh,720px);border-radius:8px;animation:home-popup-in .22s ease-out}.home-popup__image{display:block;width:100%;max-height:min(82vh,720px);object-fit:contain;border-radius:8px;box-shadow:0 18px 48px #00000052}.home-popup__close{position:absolute;top:-14px;right:-14px;z-index:1;width:36px;height:36px;display:inline-flex;align-items:center;justify-content:center;border:1px solid rgba(255,238,204,.78);border-radius:999px;background:#3d1a06f0;color:#fff7e7;cursor:pointer;font-size:24px;line-height:1;box-shadow:0 8px 22px #00000047;transition:transform .18s ease,background .18s ease}.home-popup__close:hover{background:#8b0109;transform:scale(1.04)}.home-popup__close:focus-visible{outline:2px solid #f5cc40;outline-offset:3px}@keyframes home-popup-in{0%{opacity:0;transform:translateY(10px) scale(.98)}to{opacity:1;transform:translateY(0) scale(1)}}@media (max-width: 480px){.home-popup-overlay{padding:18px}.home-popup{max-width:92vw;max-height:76vh}.home-popup__image{max-height:76vh}.home-popup__close{top:-12px;right:-10px;width:34px;height:34px;font-size:22px}}@media (prefers-reduced-motion: reduce){.home-popup{animation:none}}.page-header{text-align:center;margin-bottom:3rem}.page-title{font-size:2.5rem;font-weight:700;color:#1a1a1a;margin-bottom:.5rem}.page-subtitle{font-size:1.1rem;color:#666;margin:0}.section-title{font-size:1.3rem;font-weight:600;color:#333;margin-bottom:1rem}.sign-type-section{margin-bottom:2rem}.sign-type-list{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:1rem}.sign-type-item{background:#fff;border:2px solid #e0e0e0;border-radius:12px;padding:1.5rem;cursor:pointer;transition:all .3s ease;text-align:center}.sign-type-item:hover{border-color:#ff6b6b;transform:translateY(-2px);box-shadow:0 4px 12px #ff6b6b33}.sign-type-item.active{border-color:#ff6b6b;background:linear-gradient(135deg,#fff5f5,#ffe0e0);box-shadow:0 4px 12px #ff6b6b4d}.sign-type-name{font-size:1.2rem;font-weight:600;color:#333;margin-bottom:.5rem}.sign-type-desc{font-size:.9rem;color:#666;margin-bottom:.5rem}.sign-type-count{font-size:.85rem;color:#999}.question-section{margin-bottom:2rem}.question-input{width:100%;padding:1rem;border:2px solid #e0e0e0;border-radius:8px;font-size:1rem;font-family:inherit;resize:vertical;transition:border-color .3s ease}.question-input:focus{outline:none;border-color:#ff6b6b}.question-hint{text-align:right;font-size:.85rem;color:#999;margin-top:.5rem}.draw-section{text-align:center;margin-bottom:3rem}.draw-button{background:linear-gradient(135deg,#ff6b6b,#ff8e8e);color:#fff;border:none;border-radius:50px;padding:1.2rem 3rem;font-size:1.3rem;font-weight:600;cursor:pointer;transition:all .3s ease;display:inline-flex;align-items:center;gap:.5rem;box-shadow:0 4px 15px #ff6b6b66}.draw-button:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 6px 20px #ff6b6b80}.draw-button:active:not(:disabled){transform:translateY(0)}.draw-button:disabled{opacity:.6;cursor:not-allowed}.draw-button.drawing{background:linear-gradient(135deg,orange,#ffb84d)}.draw-icon{font-size:1.5rem;display:inline-block}.draw-icon.spinning{animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.sign-result{background:#fff;border-radius:16px;padding:2rem;box-shadow:0 4px 20px #0000001a;animation:fadeInUp .5s ease}@keyframes fadeInUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.sign-result-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem;padding-bottom:1rem;border-bottom:2px solid #f0f0f0}.sign-result-title{font-size:1.5rem;font-weight:600;color:#333;margin:0}.sign-level{padding:.5rem 1rem;border-radius:20px;font-size:.9rem;font-weight:600}.sign-level-excellent{background:linear-gradient(135deg,gold,#ffed4e);color:#8b4513}.sign-level-good{background:linear-gradient(135deg,#90ee90,#b4f0b4);color:#2d5016}.sign-level-fair{background:linear-gradient(135deg,#87ceeb,#a8d8f0);color:#1e4d6b}.sign-level-poor{background:linear-gradient(135deg,#dcdcdc,#f0f0f0);color:#666}.sign-content-box{background:linear-gradient(135deg,#fff9e6,#fffaf0);border-left:4px solid #ff6b6b;padding:1.5rem;margin-bottom:1.5rem;border-radius:8px}.sign-title{font-size:1.3rem;font-weight:600;color:#333;margin-bottom:1rem;text-align:center}.sign-content{font-size:1.1rem;line-height:1.8;color:#555;text-align:center;white-space:pre-line}.sign-interpretation-box{background:#f8f9fa;padding:1.5rem;margin-bottom:1.5rem;border-radius:8px}.interpretation-title{font-size:1.1rem;font-weight:600;color:#333;margin-bottom:1rem}.interpretation-content{font-size:1rem;line-height:1.8;color:#555;white-space:pre-line}.ai-interpret-section{text-align:center;margin-bottom:1.5rem}.ai-interpret-button{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:50px;padding:1rem 2rem;font-size:1.1rem;font-weight:600;cursor:pointer;transition:all .3s ease;display:inline-flex;align-items:center;gap:.5rem;box-shadow:0 4px 15px #667eea66}.ai-interpret-button:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 6px 20px #667eea80}.ai-interpret-button:disabled{opacity:.6;cursor:not-allowed}.ai-icon{font-size:1.3rem}.vip-badge{background:gold;color:#8b4513;padding:.2rem .6rem;border-radius:12px;font-size:.75rem;font-weight:700;margin-left:.5rem}.result-actions{display:flex;gap:1rem;justify-content:center}.action-button{padding:.8rem 2rem;border-radius:50px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .3s ease;border:none}.action-button.primary{background:linear-gradient(135deg,#ff6b6b,#ff8e8e);color:#fff;box-shadow:0 2px 10px #ff6b6b4d}.action-button.primary:hover{transform:translateY(-2px);box-shadow:0 4px 15px #ff6b6b66}.action-button.secondary{background:#fff;color:#666;border:2px solid #e0e0e0}.action-button.secondary:hover{border-color:#ff6b6b;color:#ff6b6b}.ai-loading{text-align:center;padding:2rem}.ai-loading p{margin-top:1rem;color:#666}.ai-result{padding:1rem 0}.ai-interpretation,.ai-advice,.ai-lucky{margin-bottom:1.5rem}.ai-result h4{font-size:1.1rem;font-weight:600;color:#333;margin-bottom:.8rem}.ai-result p{font-size:1rem;line-height:1.8;color:#555;white-space:pre-line}.lucky-numbers,.lucky-colors{display:flex;gap:.8rem;flex-wrap:wrap}.lucky-number,.lucky-color{background:linear-gradient(135deg,gold,#ffed4e);color:#8b4513;padding:.5rem 1rem;border-radius:20px;font-weight:600}.vip-tip{background:linear-gradient(135deg,#fff9e6,#fffaf0);border:2px solid #ffd700;border-radius:8px;padding:1.5rem;text-align:center;margin-top:1.5rem}.vip-tip p{margin-bottom:1rem;color:#8b4513;font-weight:600}.upgrade-vip-button{background:linear-gradient(135deg,gold,#ffed4e);color:#8b4513;border:none;border-radius:50px;padding:.8rem 2rem;font-size:1rem;font-weight:600;cursor:pointer;transition:all .3s ease}.upgrade-vip-button:hover{transform:translateY(-2px);box-shadow:0 4px 15px #ffd70066}.ai-error{text-align:center;padding:2rem;color:#999}@media (max-width: 768px){.page-title{font-size:2rem}.page-subtitle{font-size:1rem}.sign-type-list{grid-template-columns:1fr}.draw-button{padding:1rem 2rem;font-size:1.1rem}.sign-result{padding:1.5rem}.sign-result-header{flex-direction:column;align-items:flex-start;gap:.5rem}.result-actions{flex-direction:column}.action-button{width:100%}}
