/*
Theme Name: 動物MBTI占い
Theme URI: https://example.com
Author: AON
Description: AI × MBTI × 動物占い WordPressテーマ
Version: 1.0.0
Text Domain: animal-mbti
*/

*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
:root{
  --ink:#1a1020;--cream:#faf6f0;--gold:#d4a853;--gold-light:#f0d68a;
  --mystic:#6b3fa0;--mystic-deep:#3d1f6d;
  --aurora1:#ff6b9d;--aurora2:#c084fc;--aurora3:#60a5fa;--aurora4:#34d399;
  --card-bg:rgba(255,255,255,0.06);--glass:rgba(255,255,255,0.08);
  --radius:16px;--green:#06c755;
}
html{scroll-behavior:smooth;font-size:16px}
body{font-family:'Zen Maru Gothic',sans-serif;background:var(--ink);color:var(--cream);overflow-x:hidden;line-height:1.8}
.bg-cosmos{position:fixed;inset:0;z-index:-1;background:radial-gradient(ellipse 80% 60% at 20% 10%,rgba(107,63,160,.25),transparent),radial-gradient(ellipse 60% 50% at 80% 80%,rgba(255,107,157,.15),transparent),radial-gradient(ellipse 50% 40% at 50% 50%,rgba(96,165,250,.1),transparent),var(--ink)}
.stars{position:fixed;inset:0;z-index:-1;background-image:radial-gradient(1px 1px at 10% 20%,rgba(255,255,255,.6),transparent),radial-gradient(1px 1px at 30% 60%,rgba(255,255,255,.4),transparent),radial-gradient(1.5px 1.5px at 50% 10%,rgba(212,168,83,.7),transparent),radial-gradient(1px 1px at 70% 40%,rgba(255,255,255,.5),transparent),radial-gradient(1px 1px at 90% 70%,rgba(255,255,255,.3),transparent),radial-gradient(1.5px 1.5px at 15% 80%,rgba(192,132,252,.6),transparent);animation:twinkle 6s ease-in-out infinite alternate}
@keyframes twinkle{0%{opacity:.6}100%{opacity:1}}
header{position:fixed;top:0;left:0;right:0;z-index:100;backdrop-filter:blur(20px);background:rgba(26,16,32,.8);border-bottom:1px solid rgba(212,168,83,.15);transition:.3s}
header.scrolled{background:rgba(26,16,32,.95)}
nav{max-width:1200px;margin:0 auto;display:flex;align-items:center;justify-content:space-between;padding:12px 24px}
.logo{display:flex;align-items:center;gap:10px;text-decoration:none;color:var(--cream)}
.logo-icon{width:42px;height:42px;background:linear-gradient(135deg,var(--gold),var(--aurora1));border-radius:50%;display:grid;place-items:center;font-size:22px}
.logo-text{font-family:'Shippori Mincho',serif;font-size:1.15rem;font-weight:800;letter-spacing:.08em}
.logo-text span{display:block;font-size:.65rem;font-weight:400;color:var(--gold);letter-spacing:.15em;margin-top:-2px}
.nav-links{display:flex;gap:24px;list-style:none;align-items:center}
.nav-links a{color:rgba(250,246,240,.7);text-decoration:none;font-size:.83rem;letter-spacing:.05em;transition:.3s;position:relative}
.nav-links a:hover{color:var(--gold)}
.nav-links a::after{content:'';position:absolute;bottom:-4px;left:0;width:0;height:1.5px;background:var(--gold);transition:.3s}
.nav-links a:hover::after{width:100%}
.nav-cta{background:linear-gradient(135deg,var(--gold),#e8b84a);color:var(--ink)!important;padding:8px 20px;border-radius:100px;font-weight:700!important;font-size:.83rem;transition:transform .3s,box-shadow .3s}
.nav-cta:hover{transform:translateY(-2px);box-shadow:0 6px 20px rgba(212,168,83,.4)}
.nav-cta::after{display:none!important}
.nav-auth{display:flex;gap:10px;align-items:center}
.nav-login-btn{background:transparent;border:1px solid rgba(250,246,240,.25);color:var(--cream);padding:7px 18px;border-radius:100px;font-size:.82rem;cursor:pointer;font-family:inherit;transition:.3s}
.nav-login-btn:hover{border-color:var(--gold);color:var(--gold)}
.nav-register-btn{background:linear-gradient(135deg,var(--aurora2),var(--mystic));color:#fff;padding:7px 18px;border-radius:100px;font-size:.82rem;cursor:pointer;font-family:inherit;border:none;font-weight:600;transition:.3s}
.nav-register-btn:hover{transform:translateY(-1px);box-shadow:0 4px 16px rgba(192,132,252,.4)}
.nav-user-info{display:none;align-items:center;gap:10px;font-size:.85rem}
.nav-user-avatar{width:34px;height:34px;border-radius:50%;background:linear-gradient(135deg,var(--gold),var(--aurora1));display:grid;place-items:center;font-size:1rem}
.nav-user-name{color:var(--gold);font-weight:600}
.nav-logout{background:none;border:none;color:rgba(250,246,240,.5);font-size:.75rem;cursor:pointer;font-family:inherit;text-decoration:underline}
.nav-logout:hover{color:var(--cream)}
.hamburger{display:none;flex-direction:column;gap:5px;cursor:pointer;padding:4px}
.hamburger span{width:24px;height:2px;background:var(--cream);border-radius:2px;transition:.3s}
.modal-overlay{position:fixed;inset:0;z-index:9999;background:rgba(10,6,16,.85);backdrop-filter:blur(12px);display:none;align-items:center;justify-content:center;padding:20px;opacity:0;transition:opacity .35s}
.modal-overlay.show{display:flex;opacity:1}
.modal{background:linear-gradient(165deg,#1e1430,#150e22);border:1px solid rgba(212,168,83,.18);border-radius:20px;width:100%;max-width:440px;max-height:90vh;overflow-y:auto;position:relative;transform:translateY(20px) scale(.97);transition:transform .4s cubic-bezier(.4,0,.2,1);box-shadow:0 24px 80px rgba(0,0,0,.6)}
.modal-overlay.show .modal{transform:translateY(0) scale(1)}
.modal-close{position:absolute;top:16px;right:16px;background:none;border:none;color:rgba(250,246,240,.4);font-size:1.4rem;cursor:pointer;z-index:2;width:36px;height:36px;border-radius:50%;display:grid;place-items:center;transition:.3s}
.modal-close:hover{background:rgba(255,255,255,.08);color:var(--cream)}
.modal-header{padding:36px 36px 0;text-align:center}
.modal-header .modal-icon{font-size:2.8rem;margin-bottom:12px;display:block}
.modal-header h2{font-family:'Shippori Mincho',serif;font-size:1.5rem;font-weight:800;margin-bottom:6px}
.modal-header p{font-size:.85rem;color:rgba(250,246,240,.55)}
.modal-body{padding:28px 36px 36px}
.modal-tabs{display:flex;border-bottom:1px solid rgba(255,255,255,.08);margin-bottom:24px}
.modal-tab{flex:1;padding:12px;text-align:center;font-size:.88rem;font-weight:600;color:rgba(250,246,240,.45);cursor:pointer;border-bottom:2px solid transparent;transition:.3s;background:none;border-top:none;border-left:none;border-right:none;font-family:inherit}
.modal-tab.active{color:var(--gold);border-bottom-color:var(--gold)}
.modal-tab:hover{color:var(--cream)}
.m-form{display:none}.m-form.active{display:block}
.m-group{margin-bottom:16px}
.m-group label{display:block;font-size:.8rem;margin-bottom:5px;color:rgba(250,246,240,.65)}
.m-group label .req{color:var(--aurora1);font-size:.68rem;margin-left:4px}
.m-group input{width:100%;padding:12px 16px;background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.1);border-radius:10px;color:var(--cream);font-size:.9rem;font-family:inherit;outline:none;transition:.3s}
.m-group input:focus{border-color:var(--gold);background:rgba(255,255,255,.08)}
.m-group input::placeholder{color:rgba(250,246,240,.25)}
.m-submit{width:100%;padding:14px;border-radius:100px;border:none;font-size:.95rem;font-weight:700;cursor:pointer;font-family:inherit;letter-spacing:.06em;transition:.3s;margin-top:8px}
.m-submit.login-btn{background:linear-gradient(135deg,var(--gold),#e8b84a);color:var(--ink)}
.m-submit.register-btn{background:linear-gradient(135deg,var(--aurora2),var(--mystic));color:#fff}
.m-submit:hover{transform:translateY(-2px);box-shadow:0 6px 24px rgba(0,0,0,.3)}
.m-divider{display:flex;align-items:center;gap:12px;margin:20px 0;font-size:.75rem;color:rgba(250,246,240,.3)}
.m-divider::before,.m-divider::after{content:'';flex:1;height:1px;background:rgba(255,255,255,.08)}
.m-social{display:flex;gap:10px}
.m-social button{flex:1;padding:11px;border-radius:10px;border:1px solid rgba(255,255,255,.1);background:rgba(255,255,255,.04);color:var(--cream);font-size:.82rem;cursor:pointer;font-family:inherit;transition:.3s;display:flex;align-items:center;justify-content:center;gap:6px}
.m-social button:hover{background:rgba(255,255,255,.08);border-color:rgba(255,255,255,.2)}
.m-benefits{margin-top:20px;padding:16px;background:rgba(212,168,83,.06);border:1px solid rgba(212,168,83,.12);border-radius:12px}
.m-benefits h4{font-size:.8rem;color:var(--gold);margin-bottom:8px;display:flex;align-items:center;gap:6px}
.m-benefits ul{list-style:none;font-size:.78rem;color:rgba(250,246,240,.6)}
.m-benefits li{padding:3px 0;display:flex;align-items:center;gap:6px}
.m-benefits li::before{content:'✦';color:var(--gold);font-size:.6rem}
.m-forgot{text-align:center;margin-top:14px}
.m-forgot a{color:rgba(250,246,240,.4);font-size:.78rem;text-decoration:none;transition:.3s}
.m-forgot a:hover{color:var(--gold)}
.m-terms{font-size:.72rem;color:rgba(250,246,240,.35);text-align:center;margin-top:12px;line-height:1.6}
.m-terms a{color:var(--aurora2)}
.m-check{display:flex;align-items:center;gap:8px;margin:14px 0 4px;cursor:pointer;font-size:.82rem;color:rgba(250,246,240,.6)}
.m-check input{accent-color:var(--gold);width:16px;height:16px}
.result-locked{position:relative}
.result-locked .locked-content{filter:blur(12px);pointer-events:none;user-select:none}
.lock-overlay{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;z-index:5;background:rgba(26,16,32,.6);backdrop-filter:blur(2px);border-radius:var(--radius);text-align:center;padding:32px}
.lock-icon{font-size:3rem;margin-bottom:16px;animation:pulse 2s infinite}
@keyframes pulse{0%,100%{transform:scale(1)}50%{transform:scale(1.08)}}
.lock-overlay h3{font-family:'Shippori Mincho',serif;font-size:1.2rem;margin-bottom:8px}
.lock-overlay p{font-size:.85rem;color:rgba(250,246,240,.6);margin-bottom:20px;line-height:1.7}
.lock-overlay .btn-unlock{background:linear-gradient(135deg,var(--aurora2),var(--mystic));color:#fff;padding:14px 36px;border-radius:100px;border:none;font-size:.95rem;font-weight:700;cursor:pointer;font-family:inherit;transition:.3s}
.lock-overlay .btn-unlock:hover{transform:translateY(-2px);box-shadow:0 8px 28px rgba(192,132,252,.4)}
.hero{min-height:100vh;display:flex;align-items:center;justify-content:center;text-align:center;padding:120px 24px 80px;position:relative}
.hero-content{max-width:800px;position:relative;z-index:2}
.hero-badge{display:inline-flex;align-items:center;gap:8px;background:rgba(212,168,83,.12);border:1px solid rgba(212,168,83,.3);border-radius:100px;padding:6px 18px;font-size:.78rem;color:var(--gold);letter-spacing:.1em;margin-bottom:28px;animation:fadeUp .8s ease}
.hero-badge::before{content:'✦';font-size:.6rem}
.hero h1{font-family:'Shippori Mincho',serif;font-size:clamp(2.2rem,6vw,4.2rem);font-weight:800;line-height:1.3;margin-bottom:20px;animation:fadeUp .8s ease .1s both}
.hero h1 .accent{background:linear-gradient(135deg,var(--gold-light),var(--aurora1),var(--aurora2));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.hero p{font-size:1.05rem;color:rgba(250,246,240,.7);max-width:560px;margin:0 auto 40px;line-height:2;animation:fadeUp .8s ease .2s both}
.hero-cta-group{display:flex;gap:16px;justify-content:center;flex-wrap:wrap;animation:fadeUp .8s ease .3s both}
.btn-primary{background:linear-gradient(135deg,var(--gold),#e8b84a);color:var(--ink);padding:16px 40px;border-radius:100px;font-weight:700;font-size:1rem;text-decoration:none;letter-spacing:.08em;border:none;cursor:pointer;transition:transform .3s,box-shadow .3s;display:inline-flex;align-items:center;gap:8px}
.btn-primary:hover{transform:translateY(-3px);box-shadow:0 8px 30px rgba(212,168,83,.4)}
.btn-secondary{background:transparent;color:var(--cream);padding:16px 36px;border-radius:100px;font-weight:500;font-size:.95rem;text-decoration:none;letter-spacing:.08em;border:1px solid rgba(250,246,240,.25);transition:.3s}
.btn-secondary:hover{border-color:var(--gold);color:var(--gold)}
.hero-animals{display:flex;justify-content:center;gap:12px;margin-top:50px;flex-wrap:wrap;animation:fadeUp .8s ease .5s both}
.hero-animal{width:52px;height:52px;border-radius:50%;background:var(--glass);border:1px solid rgba(255,255,255,.1);display:grid;place-items:center;font-size:1.5rem;transition:transform .3s,border-color .3s;cursor:default}
.hero-animal:hover{transform:translateY(-6px) scale(1.1);border-color:var(--gold)}
.floating-orb{position:absolute;border-radius:50%;filter:blur(60px);pointer-events:none;animation:float 8s ease-in-out infinite}
.orb1{width:300px;height:300px;background:rgba(107,63,160,.15);top:10%;left:-5%}
.orb2{width:250px;height:250px;background:rgba(255,107,157,.1);bottom:15%;right:-5%;animation-delay:3s}
@keyframes float{0%,100%{transform:translateY(0) scale(1)}50%{transform:translateY(-30px) scale(1.05)}}
@keyframes fadeUp{from{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}
section{padding:100px 24px;position:relative}
.section-inner{max-width:1100px;margin:0 auto}
.section-label{display:inline-flex;align-items:center;gap:6px;font-size:.75rem;letter-spacing:.2em;color:var(--gold);text-transform:uppercase;margin-bottom:12px}
.section-label::before{content:'';width:20px;height:1px;background:var(--gold)}
.section-title{font-family:'Shippori Mincho',serif;font-size:clamp(1.6rem,4vw,2.4rem);font-weight:800;margin-bottom:16px;line-height:1.4}
.section-subtitle{color:rgba(250,246,240,.6);max-width:600px;font-size:.95rem;margin-bottom:48px}
.divider-glow{height:1px;background:linear-gradient(90deg,transparent,rgba(212,168,83,.3),transparent);margin:0;border:none}
.how-it-works{background:rgba(61,31,109,.1)}
.steps{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:32px}
.step{background:var(--card-bg);border:1px solid rgba(255,255,255,.06);border-radius:var(--radius);padding:36px 28px;text-align:center;position:relative;transition:.3s}
.step:hover{transform:translateY(-6px);border-color:rgba(212,168,83,.3)}
.step-number{position:absolute;top:-16px;left:50%;transform:translateX(-50%);width:32px;height:32px;border-radius:50%;background:linear-gradient(135deg,var(--mystic),var(--aurora2));display:grid;place-items:center;font-size:.8rem;font-weight:700}
.step-icon{font-size:2.8rem;margin-bottom:16px;display:block}
.step h3{font-size:1.05rem;margin-bottom:8px;font-weight:700}
.step p{font-size:.88rem;color:rgba(250,246,240,.6);line-height:1.7}
.diagnosis-section{background:linear-gradient(180deg,rgba(61,31,109,.12),rgba(255,107,157,.05))}
.diagnosis-container{max-width:700px;margin:0 auto}
.diagnosis-progress{display:flex;gap:6px;margin-bottom:32px;justify-content:center}
.diagnosis-progress .dot{width:10px;height:10px;border-radius:50%;background:rgba(255,255,255,.1);transition:.4s}
.diagnosis-progress .dot.active{background:var(--gold);box-shadow:0 0 12px rgba(212,168,83,.5)}
.diagnosis-progress .dot.done{background:var(--aurora4)}
.q-card{background:var(--card-bg);border:1px solid rgba(255,255,255,.08);border-radius:var(--radius);padding:40px;text-align:center;display:none;animation:fadeUp .5s ease}
.q-card.active{display:block}
.q-num{font-size:.78rem;color:var(--gold);letter-spacing:.15em;margin-bottom:12px}
.q-text{font-family:'Shippori Mincho',serif;font-size:1.2rem;font-weight:700;margin-bottom:28px;line-height:1.6}
.q-options{display:flex;flex-direction:column;gap:12px}
.q-option{background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.1);border-radius:12px;padding:16px 20px;cursor:pointer;font-size:.92rem;text-align:left;transition:.3s;display:flex;align-items:center;gap:12px}
.q-option:hover{border-color:var(--aurora2);background:rgba(192,132,252,.08)}
.q-option.selected{border-color:var(--gold);background:rgba(212,168,83,.1)}
.q-option .q-label{width:28px;height:28px;border-radius:50%;border:2px solid rgba(255,255,255,.2);display:grid;place-items:center;font-size:.75rem;font-weight:700;flex-shrink:0;transition:.3s}
.q-option.selected .q-label{border-color:var(--gold);background:var(--gold);color:var(--ink)}
.result-card{background:var(--card-bg);border:1px solid rgba(212,168,83,.2);border-radius:var(--radius);padding:48px;text-align:center;display:none;position:relative;overflow:hidden}
.result-card.active{display:block}
.result-card::before{content:'';position:absolute;inset:0;background:radial-gradient(circle at 50% 0%,rgba(212,168,83,.1),transparent 70%)}
.result-animal-name{font-family:'Shippori Mincho',serif;font-size:2rem;font-weight:800;position:relative;z-index:1}
.result-mbti{font-size:.88rem;color:var(--gold);letter-spacing:.18em;margin:6px 0 20px;position:relative;z-index:1}
.result-desc{font-size:.92rem;color:rgba(250,246,240,.7);line-height:1.9;max-width:520px;margin:0 auto 28px;position:relative;z-index:1}
.result-traits-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-bottom:28px;position:relative;z-index:1}
.result-trait{background:rgba(255,255,255,.04);border-radius:10px;padding:14px;text-align:center}
.result-trait .trait-label{font-size:.72rem;color:rgba(250,246,240,.45);margin-bottom:4px}
.result-trait .trait-bar{height:6px;background:rgba(255,255,255,.08);border-radius:3px;overflow:hidden;margin-bottom:4px}
.result-trait .trait-fill{height:100%;border-radius:3px;transition:width 1s ease}
.result-trait .trait-val{font-size:.82rem;font-weight:700;color:var(--gold)}
.fortune-section{background:linear-gradient(180deg,rgba(61,31,109,.15),transparent)}
.fortune-date-bar{text-align:center;margin-bottom:36px}
.fortune-date-bar .fdate{font-family:'Shippori Mincho',serif;font-size:1.3rem;font-weight:700}
.fortune-date-bar .fdate-sub{font-size:.82rem;color:rgba(250,246,240,.45);margin-top:4px}
.fortune-tabs{display:flex;gap:8px;justify-content:center;margin-bottom:32px;flex-wrap:wrap}
.fortune-tab{padding:8px 20px;border-radius:100px;border:1px solid rgba(255,255,255,.1);background:transparent;color:rgba(250,246,240,.6);font-size:.82rem;cursor:pointer;font-family:inherit;transition:.3s}
.fortune-tab.active{background:rgba(212,168,83,.15);border-color:var(--gold);color:var(--gold);font-weight:600}
.fortune-tab:hover{border-color:rgba(212,168,83,.4)}
.fortune-list{display:flex;flex-direction:column;gap:12px;max-width:800px;margin:0 auto}
.fortune-item{display:grid;grid-template-columns:48px 52px 1fr auto;align-items:center;gap:14px;background:var(--card-bg);border:1px solid rgba(255,255,255,.06);border-radius:14px;padding:18px 24px;transition:.3s}
.fortune-item:hover{border-color:rgba(212,168,83,.2);transform:translateX(4px)}
.fortune-item.rank-1{border-color:rgba(212,168,83,.3);background:rgba(212,168,83,.06)}
.fortune-item.rank-2{border-color:rgba(192,192,192,.2);background:rgba(192,192,192,.03)}
.fortune-item.rank-3{border-color:rgba(205,127,50,.2);background:rgba(205,127,50,.03)}
.f-rank{font-family:'Shippori Mincho',serif;font-weight:800;text-align:center}
.f-rank .f-rank-num{font-size:1.5rem;line-height:1}
.rank-1 .f-rank-num{background:linear-gradient(135deg,#ffd700,#ffaa00);-webkit-background-clip:text;-webkit-text-fill-color:transparent}
.rank-2 .f-rank-num{color:#c0c0c0}
.rank-3 .f-rank-num{color:#cd7f32}
.f-rank .f-rank-label{font-size:.6rem;color:rgba(250,246,240,.35);letter-spacing:.1em}
.f-info{min-width:0}
.f-info .f-name{font-weight:700;font-size:.95rem;margin-bottom:2px}
.f-info .f-mbti{font-size:.72rem;color:var(--gold);letter-spacing:.12em}
.f-info .f-msg{font-size:.8rem;color:rgba(250,246,240,.55);margin-top:6px;line-height:1.5}
.f-stars{display:flex;flex-direction:column;gap:4px;min-width:140px}
.f-star-row{display:flex;align-items:center;gap:6px;font-size:.72rem}
.f-star-label{width:28px;color:rgba(250,246,240,.45);flex-shrink:0}
.f-star-icons{display:flex;gap:1px}
.f-star-icons .star{font-size:.72rem;color:rgba(255,255,255,.15)}
.f-star-icons .star.on{color:#ffd700}
.f-score{font-size:.7rem;color:rgba(250,246,240,.4);width:16px;text-align:right}
.animal-gallery{overflow:hidden}
.animal-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:20px}
.animal-card{background:var(--card-bg);border:1px solid rgba(255,255,255,.06);border-radius:var(--radius);padding:28px 20px;text-align:center;transition:.4s cubic-bezier(.4,0,.2,1);cursor:pointer;position:relative;overflow:hidden}
.animal-card::before{content:'';position:absolute;inset:0;background:linear-gradient(135deg,var(--card-accent,rgba(212,168,83,.08)),transparent);opacity:0;transition:.4s}
.animal-card:hover{transform:translateY(-8px);border-color:var(--card-border,rgba(212,168,83,.3));box-shadow:0 12px 40px rgba(0,0,0,.3)}
.animal-card:hover::before{opacity:1}
/* Animal Photo System */
.animal-photo-wrap{width:100px;height:100px;border-radius:50%;margin:0 auto 14px;position:relative;z-index:1;overflow:hidden;border:3px solid rgba(255,255,255,.1);transition:all .4s;box-shadow:0 4px 20px rgba(0,0,0,.3)}
.animal-card:hover .animal-photo-wrap{border-color:var(--card-border,var(--gold));transform:scale(1.08);box-shadow:0 8px 30px rgba(0,0,0,.4),0 0 20px var(--card-accent,rgba(212,168,83,.2))}
.animal-photo-wrap img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .5s}
.animal-card:hover .animal-photo-wrap img{transform:scale(1.12)}
.animal-photo-wrap .photo-fallback{width:100%;height:100%;display:flex;align-items:center;justify-content:center;font-size:2.8rem;background:var(--animal-bg,linear-gradient(135deg,rgba(107,63,160,.4),rgba(212,168,83,.3)));position:absolute;inset:0}
.animal-photo-wrap img.loaded+.photo-fallback{display:none}
/* Hero animal photos */
.hero-animal{width:56px;height:56px;border-radius:50%;background:var(--glass);border:2px solid rgba(255,255,255,.1);display:grid;place-items:center;font-size:1.5rem;transition:transform .3s,border-color .3s;cursor:default;overflow:hidden;position:relative}
.hero-animal img{width:100%;height:100%;object-fit:cover;position:absolute;inset:0}
.hero-animal:hover{transform:translateY(-6px) scale(1.1);border-color:var(--gold)}
/* Fortune animal photos */
.f-animal-photo{width:48px;height:48px;border-radius:50%;overflow:hidden;border:2px solid rgba(255,255,255,.1);flex-shrink:0}
.f-animal-photo img{width:100%;height:100%;object-fit:cover}
.f-animal-photo .f-photo-fb{width:100%;height:100%;display:flex;align-items:center;justify-content:center;font-size:1.6rem;background:linear-gradient(135deg,rgba(107,63,160,.3),rgba(212,168,83,.2))}
/* Result photo */
.result-photo-wrap{width:140px;height:140px;border-radius:50%;margin:0 auto 16px;overflow:hidden;border:4px solid rgba(212,168,83,.3);box-shadow:0 0 40px rgba(212,168,83,.2),0 8px 32px rgba(0,0,0,.3);position:relative;z-index:1;animation:bounceIn .6s ease}
.result-photo-wrap img{width:100%;height:100%;object-fit:cover}
@keyframes bounceIn{0%{transform:scale(0)}60%{transform:scale(1.15)}100%{transform:scale(1)}}
.result-photo-wrap .r-photo-fb{width:100%;height:100%;display:flex;align-items:center;justify-content:center;font-size:4rem;background:linear-gradient(135deg,rgba(107,63,160,.3),rgba(212,168,83,.2))}
.animal-emoji{font-size:3rem;display:none;margin-bottom:12px;transition:.4s;position:relative;z-index:1}
.animal-card:hover .animal-emoji{transform:scale(1.15) rotate(-5deg)}
.animal-name{font-family:'Shippori Mincho',serif;font-size:1.1rem;font-weight:700;margin-bottom:4px;position:relative;z-index:1}
.animal-mbti{font-size:.72rem;letter-spacing:.15em;color:var(--gold);margin-bottom:10px;position:relative;z-index:1}
.animal-traits{position:relative;z-index:1}
.tag{display:inline-block;background:rgba(255,255,255,.06);border-radius:100px;padding:2px 10px;font-size:.7rem;margin:2px;color:rgba(250,246,240,.7)}
.animal-card[data-type="analyst"]{--card-accent:rgba(96,165,250,.12);--card-border:rgba(96,165,250,.3)}
.animal-card[data-type="diplomat"]{--card-accent:rgba(52,211,153,.12);--card-border:rgba(52,211,153,.3)}
.animal-card[data-type="sentinel"]{--card-accent:rgba(212,168,83,.12);--card-border:rgba(212,168,83,.3)}
.animal-card[data-type="explorer"]{--card-accent:rgba(255,107,157,.12);--card-border:rgba(255,107,157,.3)}
.type-filter{display:flex;gap:10px;margin-bottom:36px;flex-wrap:wrap}
.type-filter button{background:var(--glass);border:1px solid rgba(255,255,255,.1);color:var(--cream);padding:8px 20px;border-radius:100px;font-size:.82rem;cursor:pointer;transition:.3s;font-family:inherit}
.type-filter button:hover,.type-filter button.active{background:rgba(212,168,83,.15);border-color:var(--gold);color:var(--gold)}
.blog-section{background:rgba(0,0,0,.1)}
.blog-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:24px}
.blog-card{background:var(--card-bg);border:1px solid rgba(255,255,255,.06);border-radius:var(--radius);overflow:hidden;transition:.3s}
.blog-card:hover{transform:translateY(-5px);border-color:rgba(212,168,83,.2)}
.blog-thumb{height:180px;position:relative;overflow:hidden}
.blog-thumb-bg{width:100%;height:100%;display:grid;place-items:center;font-size:4rem;transition:.4s}
.blog-card:hover .blog-thumb-bg{transform:scale(1.08)}
.blog-category{position:absolute;top:12px;left:12px;background:rgba(26,16,32,.8);backdrop-filter:blur(8px);border:1px solid rgba(212,168,83,.3);border-radius:100px;padding:3px 12px;font-size:.7rem;color:var(--gold);letter-spacing:.1em}
.blog-body{padding:22px}
.blog-body h3{font-size:1rem;font-weight:700;margin-bottom:8px;line-height:1.5}
.blog-body p{font-size:.82rem;color:rgba(250,246,240,.5);line-height:1.7;margin-bottom:12px}
.blog-meta{font-size:.72rem;color:rgba(250,246,240,.35)}
.blog-more{display:inline-flex;align-items:center;gap:6px;color:var(--gold);font-size:.85rem;text-decoration:none;margin-top:32px;transition:gap .3s}
.blog-more:hover{gap:12px}
.shop-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:24px}
.shop-card{background:var(--card-bg);border:1px solid rgba(255,255,255,.06);border-radius:var(--radius);overflow:hidden;transition:.3s}
.shop-card:hover{transform:translateY(-5px)}
.shop-img{height:200px;display:grid;place-items:center;font-size:4.5rem;background:linear-gradient(135deg,rgba(107,63,160,.2),rgba(255,107,157,.1))}
.shop-info{padding:20px}
.shop-info h3{font-size:.95rem;margin-bottom:6px;font-weight:600}
.shop-info p{font-size:.78rem;color:rgba(250,246,240,.5);margin-bottom:10px}
.shop-price{font-family:'Shippori Mincho',serif;font-size:1.1rem;font-weight:700;color:var(--gold)}
.shop-price small{font-size:.72rem;font-weight:400;color:rgba(250,246,240,.5)}
.shop-btn{display:block;width:100%;background:rgba(212,168,83,.1);border:1px solid rgba(212,168,83,.3);color:var(--gold);padding:10px;border-radius:8px;margin-top:12px;font-size:.82rem;cursor:pointer;font-family:inherit;letter-spacing:.05em;transition:.3s}
.shop-btn:hover{background:rgba(212,168,83,.2)}
.testimonials{background:rgba(61,31,109,.08)}
.testimonial-scroll{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:20px}
.testimonial{background:var(--card-bg);border:1px solid rgba(255,255,255,.06);border-radius:var(--radius);padding:28px}
.testimonial-stars{color:var(--gold);font-size:.9rem;margin-bottom:10px;letter-spacing:4px}
.testimonial p{font-size:.88rem;line-height:1.8;color:rgba(250,246,240,.7);margin-bottom:14px}
.testimonial-author{font-size:.78rem;color:rgba(250,246,240,.4);display:flex;align-items:center;gap:8px}
.testimonial-avatar{width:32px;height:32px;border-radius:50%;background:linear-gradient(135deg,var(--mystic),var(--aurora2));display:grid;place-items:center;font-size:.9rem}
.contact-section{background:linear-gradient(180deg,transparent,rgba(61,31,109,.12))}
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:40px}
.line-block{background:linear-gradient(135deg,rgba(6,199,85,.1),rgba(6,199,85,.02));border:1px solid rgba(6,199,85,.25);border-radius:var(--radius);padding:40px;text-align:center;display:flex;flex-direction:column;align-items:center;justify-content:center}
.line-icon{width:64px;height:64px;border-radius:16px;background:var(--green);display:grid;place-items:center;font-size:2rem;margin-bottom:18px;box-shadow:0 4px 20px rgba(6,199,85,.3)}
.line-block h3{font-size:1.1rem;margin-bottom:8px}
.line-block p{font-size:.85rem;color:rgba(250,246,240,.6);margin-bottom:20px;line-height:1.7}
.line-btn{background:var(--green);color:#fff;padding:14px 36px;border-radius:100px;font-size:.95rem;font-weight:700;text-decoration:none;transition:.3s;display:inline-flex;align-items:center;gap:8px;border:none;cursor:pointer;font-family:inherit}
.line-btn:hover{transform:translateY(-2px);box-shadow:0 6px 20px rgba(6,199,85,.4)}
.contact-form{background:var(--card-bg);border:1px solid rgba(255,255,255,.06);border-radius:var(--radius);padding:40px}
.contact-form h3{font-family:'Shippori Mincho',serif;font-size:1.2rem;margin-bottom:24px}
.form-group{margin-bottom:18px}
.form-group label{display:block;font-size:.82rem;margin-bottom:6px;color:rgba(250,246,240,.7)}
.form-group input,.form-group select,.form-group textarea{width:100%;padding:12px 16px;background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.1);border-radius:10px;color:var(--cream);font-size:.9rem;font-family:inherit;transition:.3s;outline:none}
.form-group input:focus,.form-group select:focus,.form-group textarea:focus{border-color:var(--gold)}
.form-group textarea{resize:vertical;min-height:100px}
.form-submit{width:100%;background:linear-gradient(135deg,var(--mystic),var(--aurora2));color:#fff;padding:14px;border-radius:100px;border:none;font-size:.95rem;font-weight:700;font-family:inherit;cursor:pointer;transition:.3s}
.form-submit:hover{transform:translateY(-2px);box-shadow:0 6px 24px rgba(107,63,160,.4)}
footer{border-top:1px solid rgba(255,255,255,.06);padding:60px 24px 30px;background:rgba(0,0,0,.2)}
.footer-inner{max-width:1100px;margin:0 auto;display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:40px}
.footer-brand{font-family:'Shippori Mincho',serif;font-size:1.1rem;font-weight:700;margin-bottom:12px}
.footer-brand p{font-size:.82rem;color:rgba(250,246,240,.45);line-height:1.7;margin-top:8px;font-family:'Zen Maru Gothic',sans-serif;font-weight:400}
.footer-col h4{font-size:.82rem;color:var(--gold);letter-spacing:.1em;margin-bottom:14px}
.footer-col ul{list-style:none}.footer-col li{margin-bottom:8px}
.footer-col a{color:rgba(250,246,240,.5);text-decoration:none;font-size:.82rem;transition:.3s}
.footer-col a:hover{color:var(--gold)}
.footer-bottom{max-width:1100px;margin:40px auto 0;padding-top:20px;border-top:1px solid rgba(255,255,255,.05);display:flex;justify-content:space-between;align-items:center;font-size:.72rem;color:rgba(250,246,240,.3)}
.footer-social{display:flex;gap:12px}
.footer-social a{width:36px;height:36px;border-radius:50%;background:rgba(255,255,255,.06);display:grid;place-items:center;text-decoration:none;font-size:.9rem;transition:.3s}
.footer-social a:hover{background:rgba(212,168,83,.2)}
.reveal{opacity:0;transform:translateY(40px);transition:all .7s cubic-bezier(.4,0,.2,1)}
.reveal.visible{opacity:1;transform:translateY(0)}
.reveal-delay-1{transition-delay:.1s}.reveal-delay-2{transition-delay:.2s}.reveal-delay-3{transition-delay:.3s}
.toast{position:fixed;top:80px;right:24px;z-index:10000;background:linear-gradient(135deg,#1e1430,#2a1a3e);border:1px solid rgba(212,168,83,.3);border-radius:14px;padding:18px 24px;display:none;align-items:center;gap:12px;box-shadow:0 12px 40px rgba(0,0,0,.5);animation:slideIn .4s ease;max-width:360px}
.toast.show{display:flex}
@keyframes slideIn{from{opacity:0;transform:translateX(40px)}to{opacity:1;transform:translateX(0)}}
.toast-icon{font-size:1.6rem;flex-shrink:0}
.toast-body h4{font-size:.9rem;font-weight:700;margin-bottom:2px}
.toast-body p{font-size:.78rem;color:rgba(250,246,240,.55);line-height:1.5}
@media(max-width:900px){.contact-grid{grid-template-columns:1fr}.footer-inner{grid-template-columns:1fr 1fr}.fortune-item{grid-template-columns:36px 42px 1fr;gap:10px;padding:14px 16px}.f-stars{display:none}.f-animal-photo{width:42px;height:42px}.result-traits-grid{grid-template-columns:1fr}}
@media(max-width:768px){.nav-links{display:none;flex-direction:column;position:absolute;top:100%;left:0;right:0;background:rgba(26,16,32,.98);backdrop-filter:blur(20px);padding:20px;gap:0;border-bottom:1px solid rgba(212,168,83,.15)}.nav-links.open{display:flex}.nav-links li{padding:12px 0;border-bottom:1px solid rgba(255,255,255,.05)}.nav-links li:last-child{border:none;padding-top:16px}.hamburger{display:flex}.nav-auth{gap:6px}.hero h1{font-size:2rem}section{padding:70px 16px}.animal-grid{grid-template-columns:repeat(auto-fill,minmax(160px,1fr))}.footer-inner{grid-template-columns:1fr}.footer-bottom{flex-direction:column;gap:12px;text-align:center}.modal-body{padding:24px}.modal-header{padding:28px 24px 0}}
