:root{--bg-color: #0b0c10;--text-primary: #e0e0e0;--text-secondary: #9a9a9a;--accent-color: #d4af37;--accent-glow: rgba(212, 175, 55, .4);--glass-bg: rgba(30, 30, 40, .65);--glass-border: rgba(255, 255, 255, .1);--success-color: #4caf50;--error-color: #f44336}*{box-sizing:border-box;margin:0;padding:0}body{font-family:"Noto Serif JP",serif;background-color:var(--bg-color);color:var(--text-primary);min-height:100vh;overflow-x:hidden;position:relative;background-image:linear-gradient(#0b0c10d9,#0b0c10d9),url(/logo.png);background-size:cover;background-position:center center;background-repeat:no-repeat;background-attachment:fixed}#root{min-height:100vh;display:flex;flex-direction:column}.app-container{max-width:800px;margin:0 auto;padding:2rem;width:100%;position:relative;z-index:10}.header{text-align:center;margin-bottom:3rem;animation:fadeInDown 1s ease-out}.header h1{font-family:Cinzel,serif;font-size:2.5rem;color:var(--accent-color);text-shadow:0 0 10px var(--accent-glow);margin-bottom:.5rem;letter-spacing:2px}.header p{color:var(--text-secondary);font-size:1.1rem}.glass-panel{background:var(--glass-bg);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border:1px solid var(--glass-border);border-radius:16px;padding:2rem;box-shadow:0 8px 32px #0000005e;animation:fadeIn 1s ease-out}.zodiac-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1rem;margin-top:1.5rem}@media (max-width: 600px){.zodiac-grid{grid-template-columns:repeat(2,1fr)}}.zodiac-card{background:#14141480;border:1px solid var(--glass-border);border-radius:12px;padding:1.5rem .5rem;text-align:center;cursor:pointer;transition:all .3s ease;display:flex;flex-direction:column;align-items:center;justify-content:center}.zodiac-card:hover{transform:translateY(-5px);border-color:var(--accent-color);box-shadow:0 5px 15px var(--accent-glow)}.zodiac-icon{font-family:Cinzel,serif;font-size:2rem;margin-bottom:.5rem;color:var(--accent-color)}.zodiac-name{font-size:.9rem;letter-spacing:1px}.fortune-display{text-align:center;margin-top:2rem}.tarot-card-image{width:150px;height:250px;margin:0 auto 1.5rem;background:linear-gradient(135deg,#1a1a2e,#16213e);border:2px solid var(--accent-color);border-radius:10px;box-shadow:0 0 20px var(--accent-glow);display:flex;align-items:center;justify-content:center;position:relative;overflow:hidden;animation:float 6s ease-in-out infinite}.tarot-card-image:after{content:"";position:absolute;top:-50%;left:-50%;width:200%;height:200%;background:radial-gradient(circle,rgba(255,255,255,.1) 0%,transparent 60%);transform:rotate(30deg);pointer-events:none}.tarot-name{font-family:Cinzel,serif;font-size:1.2rem;color:var(--accent-color);text-align:center}.fortune-content{font-size:1.1rem;line-height:1.8;margin:1.5rem 0;text-align:justify}.btn-group{display:flex;justify-content:center;gap:1rem;margin-top:2rem}.btn{padding:.8rem 1.5rem;border:none;border-radius:8px;font-family:"Noto Serif JP",serif;font-weight:700;font-size:1rem;cursor:pointer;transition:all .3s ease;outline:none}.btn-hit{background:#4caf5033;color:var(--success-color);border:1px solid var(--success-color)}.btn-hit:hover{background:#4caf5066;box-shadow:0 0 10px #4caf5080;transform:translateY(-2px)}.btn-miss{background:#f4433633;color:var(--error-color);border:1px solid var(--error-color)}.btn-miss:hover{background:#f4433666;box-shadow:0 0 10px #f4433680;transform:translateY(-2px)}.btn-back{background:transparent;color:var(--text-secondary);border:1px solid var(--text-secondary);margin-top:2rem}.btn-back:hover{color:var(--text-primary);border-color:var(--text-primary)}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes fadeInDown{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}@keyframes float{0%{transform:translateY(0)}50%{transform:translateY(-10px)}to{transform:translateY(0)}}.star{position:absolute;background-color:#fff;border-radius:50%;opacity:0;animation:twinkle var(--duration) linear infinite}@keyframes twinkle{0%{opacity:0}50%{opacity:var(--max-opacity)}to{opacity:0}}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#000000b3;display:flex;align-items:center;justify-content:center;z-index:100;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);animation:fadeIn .3s ease-out}.modal-content{position:relative;width:90%;max-width:400px;padding:2.5rem 2rem;text-align:center}.btn-close{position:absolute;top:10px;right:15px;background:transparent;border:none;color:var(--text-secondary);font-size:1.5rem;cursor:pointer;transition:color .2s}.btn-close:hover{color:var(--text-primary)}.text-input{width:100%;padding:.8rem;background:#0000004d;border:1px solid var(--glass-border);border-radius:8px;color:var(--text-primary);font-family:inherit;font-size:1rem;outline:none;transition:border-color .3s,box-shadow .3s}.text-input:focus{border-color:var(--accent-color);box-shadow:0 0 8px var(--accent-glow)}.btn-submit{background:var(--accent-color);color:#000;border:none;width:100%;filter:drop-shadow(0 0 5px rgba(212,175,55,.5))}.btn-submit:hover{background:#f0c950;transform:translateY(-2px);filter:drop-shadow(0 0 10px rgba(212,175,55,.8))}.btn-submit:disabled{background:var(--text-secondary);cursor:not-allowed;transform:none;filter:none}.text-btn{background:transparent;border:none;color:var(--accent-color);font-family:inherit;font-size:1rem;cursor:pointer;text-decoration:underline;text-underline-offset:4px}.text-btn:hover{color:#f0c950}.logo-link{text-decoration:none;color:inherit;display:inline-block;transition:opacity .3s ease}.logo-link:hover{opacity:.85}.site-footer{margin-top:auto;padding:3rem 2rem 2rem;background:linear-gradient(180deg,transparent 0%,rgba(0,0,0,.6) 40%);border-top:1px solid rgba(255,255,255,.06);text-align:center;position:relative}.footer-content{max-width:800px;margin:0 auto}.footer-brand{margin-bottom:1.5rem}.footer-logo{font-family:Cinzel,serif;font-size:1.4rem;color:var(--accent-color);text-decoration:none;letter-spacing:2px;text-shadow:0 0 8px var(--accent-glow);transition:all .3s ease}.footer-logo:hover{text-shadow:0 0 16px var(--accent-glow)}.footer-tagline{color:var(--text-secondary);font-size:.85rem;margin-top:.3rem}.footer-nav{margin:1.5rem 0}.footer-links{list-style:none;display:flex;flex-wrap:wrap;justify-content:center;gap:.5rem 1.5rem;padding:0}.footer-links li a{color:var(--text-secondary);text-decoration:none;font-size:.9rem;transition:color .3s ease,text-shadow .3s ease;position:relative;padding-bottom:2px}.footer-links li a:after{content:"";position:absolute;bottom:0;left:0;width:0;height:1px;background:var(--accent-color);transition:width .3s ease}.footer-links li a:hover{color:var(--accent-color)}.footer-links li a:hover:after{width:100%}.footer-divider{width:60px;height:1px;background:linear-gradient(90deg,transparent,var(--accent-color),transparent);margin:1.5rem auto}.footer-copyright{font-size:.8rem;color:#ffffff4d}.page-content{animation:fadeIn .8s ease-out}.page-section{margin-bottom:1.5rem}.section-title{font-family:Cinzel,serif;font-size:1.5rem;color:var(--accent-color);text-shadow:0 0 8px var(--accent-glow);margin-bottom:1rem}.page-divider{width:100%;height:1px;background:linear-gradient(90deg,transparent,var(--glass-border),transparent);margin:2rem 0}.page-content p{line-height:1.9;color:var(--text-primary);font-size:.95rem}.feature-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1rem;margin-top:1rem}@media (max-width: 600px){.feature-grid{grid-template-columns:1fr}}.feature-card{background:#14141e80;border:1px solid var(--glass-border);border-radius:12px;padding:1.5rem;text-align:center;transition:all .3s ease}.feature-card:hover{border-color:#d4af374d;transform:translateY(-3px);box-shadow:0 4px 15px #d4af3726}.feature-icon{font-size:2rem;display:block;margin-bottom:.7rem}.feature-card h3{font-size:1rem;color:var(--accent-color);margin-bottom:.5rem}.feature-card p{font-size:.85rem!important;color:var(--text-secondary)!important;line-height:1.5!important}.info-table{width:100%;border-collapse:collapse;margin-top:.5rem}.info-table th,.info-table td{padding:.8rem 1rem;border-bottom:1px solid var(--glass-border);text-align:left;font-size:.95rem}.info-table th{color:var(--text-secondary);font-weight:400;width:35%;white-space:nowrap}.info-table td{color:var(--text-primary)}.accent-link{color:var(--accent-color);text-decoration:none;transition:color .3s}.accent-link:hover{color:#f0c950;text-decoration:underline}.news-list{display:flex;flex-direction:column;gap:1.5rem}.news-item{background:#0f0f1966;border:1px solid var(--glass-border);border-radius:12px;padding:1.5rem;transition:all .3s ease}.news-item:hover{border-color:#d4af3740;box-shadow:0 2px 12px #0000004d}.news-meta{display:flex;align-items:center;gap:.8rem;margin-bottom:.7rem}.news-date{color:var(--text-secondary);font-size:.85rem}.news-category{background:#d4af3726;color:var(--accent-color);font-size:.75rem;padding:.2rem .6rem;border-radius:20px;border:1px solid rgba(212,175,55,.3)}.news-title{font-size:1.1rem;color:var(--text-primary);margin-bottom:.6rem}.news-body{font-size:.9rem!important;color:var(--text-secondary)!important;line-height:1.7!important}.contact-form{display:flex;flex-direction:column;gap:1.2rem;max-width:500px;margin:0 auto}.form-group{display:flex;flex-direction:column;gap:.4rem;text-align:left}.form-group label{font-size:.9rem;color:var(--text-secondary)}.required{color:var(--error-color)}.text-area{resize:vertical;min-height:120px;font-family:inherit}.contact-success{text-align:center;padding:2rem 0}.success-icon{font-size:3rem;margin-bottom:1rem}.contact-success h3{font-size:1.3rem;color:var(--accent-color);margin-bottom:1rem}.contact-success p{color:var(--text-secondary);line-height:1.8}.policy-intro{text-align:center;margin-bottom:2rem;padding-bottom:1.5rem;border-bottom:1px solid var(--glass-border)}.policy-section{padding-left:.5rem}.policy-heading{font-size:1.05rem;color:var(--accent-color);margin-bottom:.7rem;padding-left:.8rem;border-left:3px solid var(--accent-color)}.policy-list{list-style:none;padding-left:1rem;margin-top:.7rem}.policy-list li{position:relative;padding-left:1.2rem;margin-bottom:.5rem;font-size:.95rem;line-height:1.7;color:var(--text-primary)}.policy-list li:before{content:"◆";position:absolute;left:0;color:var(--accent-color);font-size:.6rem;top:.35rem}.policy-footer{text-align:right;margin-top:2rem;padding-top:1rem;border-top:1px solid var(--glass-border);color:var(--text-secondary);font-size:.85rem}@media (max-width: 600px){.footer-links{flex-direction:column;gap:.8rem}.info-table th{width:40%}.section-title{font-size:1.2rem}}
