@import url('https://fonts.googleapis.com/css2?family=Shippori+Mincho:wght@400;500;600;700&family=Great+Vibes&family=Cormorant+Garamond:ital,wght@0,400;0,600;1,400&display=swap');
:root{
  --pink:#F0CDD8; --lav:#E8DFF0; --blue:#D4DCF0; --cream:#FBF6F0;
  --gold:#C8A04E; --gold-d:#B8923C; --gold-l:#E2C98A;
  --ink:#5a4a63; --muted:#9a8aa3; --panel:rgba(255,255,255,.45);
}
*{margin:0;padding:0;box-sizing:border-box}
body{
  font-family:'Shippori Mincho','Noto Serif JP',serif;color:var(--ink);min-height:100vh;line-height:1.9;
  background:
    radial-gradient(900px 600px at 15% 10%, rgba(240,205,216,.7), transparent 60%),
    radial-gradient(800px 600px at 85% 30%, rgba(212,220,240,.7), transparent 60%),
    radial-gradient(700px 500px at 50% 90%, rgba(232,223,240,.7), transparent 60%),
    linear-gradient(135deg,#F5E6EE,#E8DFF0 45%,#D9E2F2);
  background-attachment:fixed;
}
a{color:var(--gold-d)}
/* 星のきらめき */
.stars{position:fixed;inset:0;pointer-events:none;z-index:0;
  background-image:radial-gradient(1.5px 1.5px at 20% 30%,#fff,transparent),radial-gradient(1px 1px at 60% 70%,var(--gold-l),transparent),radial-gradient(1.5px 1.5px at 80% 20%,#fff,transparent),radial-gradient(2px 2px at 40% 80%,var(--gold-l),transparent),radial-gradient(1px 1px at 90% 60%,#fff,transparent),radial-gradient(1.5px 1.5px at 10% 60%,#fff,transparent);
  animation:twinkle 4s ease-in-out infinite alternate}
@keyframes twinkle{from{opacity:.4}to{opacity:.9}}
.wrap{position:relative;z-index:1;max-width:1060px;margin:0 auto;padding:0 18px}
/* ヘッダー */
.header{text-align:center;padding:46px 16px 22px;position:relative}
.header .logo{font-family:'Shippori Mincho',serif;font-size:34px;font-weight:600;letter-spacing:.5em;color:var(--gold-d);text-shadow:0 1px 0 #fff}
.header .logo .en{display:block;font-family:'Great Vibes',cursive;font-size:24px;letter-spacing:.05em;color:var(--gold);margin-top:2px;font-weight:400}
.header .sub{color:var(--muted);font-size:13px;margin-top:10px;letter-spacing:.3em}
.divider{width:120px;height:1px;background:linear-gradient(90deg,transparent,var(--gold),transparent);margin:14px auto}
.nav{display:flex;justify-content:center;gap:22px;margin-top:8px;font-size:13px;letter-spacing:.1em;flex-wrap:wrap}
.nav a{color:var(--muted);text-decoration:none}.nav a:hover{color:var(--gold-d)}
/* ハンバーガーメニュー（スマホ表示時のみ） */
.menu-toggle{display:none;position:absolute;top:14px;right:14px;background:rgba(255,255,255,.55);backdrop-filter:blur(8px);border:1px solid rgba(200,160,78,.3);width:42px;height:42px;border-radius:10px;cursor:pointer;z-index:200;padding:0;align-items:center;justify-content:center}
.menu-toggle .bars{display:block;position:relative;width:22px;height:18px}
.menu-toggle .bars::before,.menu-toggle .bars::after,.menu-toggle .bars span{content:'';display:block;position:absolute;left:0;right:0;height:2px;background:var(--gold-d);border-radius:2px;transition:.25s}
.menu-toggle .bars::before{top:0}
.menu-toggle .bars span{top:8px}
.menu-toggle .bars::after{bottom:0}
.menu-toggle.open .bars::before{top:8px;transform:rotate(45deg)}
.menu-toggle.open .bars::after{bottom:8px;transform:rotate(-45deg)}
.menu-toggle.open .bars span{opacity:0}
.menu-backdrop{display:none;position:fixed;inset:0;background:rgba(36,28,56,.35);backdrop-filter:blur(2px);z-index:150}
.menu-backdrop.show{display:block}
@media(max-width:768px){
  .header{padding:18px 16px 14px}
  .header .logo{font-size:22px;letter-spacing:.25em}
  .header .logo .en{font-size:18px}
  .header .divider{margin:10px auto}
  .menu-toggle{display:flex}
  .nav{display:none;position:fixed;top:0;right:0;bottom:0;width:58%;max-width:240px;background:#fbf2e1 !important;background-image:none !important;backdrop-filter:none !important;-webkit-backdrop-filter:none !important;isolation:isolate;border-left:1px solid rgba(200,160,78,.4);box-shadow:-10px 0 40px rgba(0,0,0,.35);flex-direction:column;justify-content:flex-start;gap:0;padding:72px 0 24px;margin-top:0;font-size:15px;letter-spacing:.12em;z-index:1800;transform:translateX(100%);transition:transform .28s ease;overflow-y:auto}
  .nav.open{display:flex;transform:translateX(0)}
  .nav a{display:block;padding:14px 26px 14px 50px;color:var(--ink);border-bottom:1px solid rgba(200,160,78,.15);text-align:left}
  .nav a:hover,.nav a:active{background:rgba(200,160,78,.08);color:var(--gold-d)}
}
/* ヒーロー */
.hero{text-align:center;padding:6px 16px 26px}
.hero-img{max-width:560px;width:100%;border-radius:18px;box-shadow:0 12px 40px rgba(184,146,60,.2);margin:0 auto 18px;display:block}
.hero h1{font-family:'Great Vibes',cursive;font-size:38px;color:var(--gold-d);font-weight:400;letter-spacing:.02em}
.hero h1 .jp{display:block;font-family:'Shippori Mincho',serif;font-size:18px;letter-spacing:.3em;color:var(--ink);margin-top:4px;font-weight:500}
.hero p{color:var(--muted);font-size:14px;margin-top:12px}
/* カテゴリ */
.cat{margin:34px 0 8px}
.cat-title{text-align:center;font-size:20px;color:var(--gold-d);letter-spacing:.3em;margin-bottom:6px;font-weight:600}
.cat-title .en{display:block;font-family:'Great Vibes',cursive;font-size:18px;color:var(--gold);letter-spacing:0;font-weight:400}
.cat-line{width:80px;height:1px;background:linear-gradient(90deg,transparent,var(--gold),transparent);margin:0 auto 20px}
.grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(210px,1fr));gap:18px}
.card{background:var(--panel);backdrop-filter:blur(6px);border:1px solid rgba(200,160,78,.45);border-radius:18px;padding:26px 18px;text-decoration:none;color:var(--ink);text-align:center;transition:.25s;position:relative;box-shadow:0 6px 22px rgba(184,146,60,.1)}
.card::before{content:'';position:absolute;inset:6px;border:1px solid rgba(200,160,78,.25);border-radius:13px;pointer-events:none}
.card:hover{transform:translateY(-5px);box-shadow:0 14px 36px rgba(184,146,60,.25);border-color:var(--gold)}
.card .ic{font-size:36px;display:flex;align-items:center;justify-content:center;width:78px;height:78px;margin:0 auto 14px;border-radius:50%;background:radial-gradient(circle at 50% 40%,#FBF6F0,#F0E3CC);border:1.5px solid var(--gold);box-shadow:0 4px 14px rgba(184,146,60,.25),inset 0 0 12px rgba(255,255,255,.6)}
.card .nm{font-size:17px;font-weight:600;color:var(--gold-d);margin-bottom:8px;letter-spacing:.08em}
.card .tg{font-size:12.5px;color:var(--muted);line-height:1.7}
.footer{text-align:center;color:var(--muted);font-size:12px;padding:46px 16px 34px;margin-top:30px;border-top:1px solid rgba(200,160,78,.3)}
/* 占術ページ */
.fpanel{background:var(--panel);backdrop-filter:blur(8px);border:1px solid rgba(200,160,78,.5);border-radius:24px;padding:34px 26px;margin:24px 0;position:relative;box-shadow:0 10px 36px rgba(184,146,60,.15)}
.fpanel::before{content:'';position:absolute;inset:8px;border:1px solid rgba(200,160,78,.3);border-radius:18px;pointer-events:none}
.fpanel .ic{font-size:52px;text-align:center;display:block;margin-bottom:8px}
.fpanel h2{font-family:'Shippori Mincho',serif;color:var(--gold-d);font-size:24px;text-align:center;letter-spacing:.2em;margin-bottom:6px;font-weight:600}
.fpanel .tag{text-align:center;color:var(--muted);font-size:13px;margin-bottom:22px}
.field{margin-bottom:16px}
.field label{display:block;font-size:14px;color:var(--gold-d);margin-bottom:6px;letter-spacing:.05em}
.field input,.field select,.field textarea{width:100%;padding:13px;border:1px solid rgba(200,160,78,.5);border-radius:12px;background:rgba(255,255,255,.7);color:var(--ink);font-size:15px;font-family:inherit}
.btn-fortune{display:block;width:100%;background:linear-gradient(90deg,#C8A04E,#E2C98A,#C8A04E);color:#fff;border:none;padding:16px;border-radius:14px;font-size:18px;font-weight:600;letter-spacing:.3em;cursor:pointer;margin-top:8px;box-shadow:0 6px 18px rgba(184,146,60,.3);font-family:'Shippori Mincho',serif}
.btn-fortune:hover{filter:brightness(1.06)}
.result{margin-top:24px}
.result .keybox{text-align:center;font-size:24px;color:var(--gold-d);margin:10px 0 20px;letter-spacing:.2em;font-weight:600}
.result .sec{background:rgba(255,255,255,.6);border:1px solid rgba(200,160,78,.35);border-radius:14px;padding:18px 20px;margin-bottom:13px}
.result .sec h3{color:#c08aa0;font-size:16px;margin-bottom:6px;letter-spacing:.08em;font-weight:600}
.result .lucky{text-align:center;color:var(--gold-d);font-size:14px;margin:12px 0;background:rgba(255,255,255,.5);border-radius:10px;padding:10px}
.ai-comment{background:linear-gradient(135deg,rgba(240,205,216,.7),rgba(212,220,240,.7));border:1px solid var(--gold);border-radius:16px;padding:20px;margin-top:18px;font-size:15px;color:var(--ink);line-height:1.95;white-space:pre-wrap}
.ai-comment .lbl{color:var(--gold-d);font-weight:600;font-size:13px;display:block;margin-bottom:8px;letter-spacing:.1em}
.share{text-align:center;margin-top:20px}.share a{display:inline-block;margin:0 8px;font-size:13px;color:var(--gold-d);text-decoration:none;border:1px solid var(--gold);border-radius:20px;padding:6px 16px}
/* チャット */
.chat-fab{position:fixed;right:18px;bottom:18px;width:62px;height:62px;border-radius:50%;background:linear-gradient(135deg,#C8A04E,#E2C98A);color:#fff;border:none;font-size:28px;cursor:pointer;box-shadow:0 6px 20px rgba(184,146,60,.4);z-index:100}
.chat-box{position:fixed;right:18px;bottom:90px;width:330px;max-width:92vw;height:440px;max-height:72vh;background:var(--cream);border:1px solid var(--gold);border-radius:16px;box-shadow:0 14px 40px rgba(120,90,60,.3);display:none;flex-direction:column;overflow:hidden;z-index:100}
.chat-box.open{display:flex}
.chat-hd{background:linear-gradient(90deg,#E2C98A,#C8A04E);color:#fff;padding:13px 15px;font-weight:600;font-size:14px;display:flex;justify-content:space-between;align-items:center;letter-spacing:.1em}
.chat-hd button{background:none;border:none;color:#fff;font-size:18px;cursor:pointer}
.chat-body{flex:1;overflow-y:auto;padding:12px;background:rgba(255,255,255,.5)}
.msg{margin:8px 0;font-size:13.5px}.msg.bot .b{display:inline-block;background:#fff;border:1px solid rgba(200,160,78,.35);border-radius:12px;padding:9px 12px;max-width:88%;white-space:pre-wrap}
.msg.me{text-align:right}.msg.me .b{display:inline-block;background:linear-gradient(90deg,#E2C98A,#C8A04E);color:#fff;border-radius:12px;padding:9px 12px;max-width:88%}
.chat-input{display:flex;border-top:1px solid rgba(200,160,78,.3)}
.chat-input input{flex:1;border:none;padding:12px;font-size:14px;background:transparent;color:var(--ink);outline:none}
.chat-input button{background:var(--gold);color:#fff;border:none;padding:0 16px;cursor:pointer;font-weight:600}
@media(max-width:600px){.header .logo{font-size:26px;letter-spacing:.3em}.hero h1{font-size:30px}.grid{grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:12px}}
/* 占星術 追加メニュー（相性診断・今月の運勢） */
.astro-extra{margin-top:22px;text-align:center}
.astro-extra .ax-h{font-family:'Shippori Mincho',serif;font-size:20px;color:var(--gold);margin:0 0 4px}
.astro-extra .ax-d{font-size:13px;color:#8a82b0;margin:0 0 14px}
.astro-extra .ax-row{display:flex;gap:12px;justify-content:center;flex-wrap:wrap}
.astro-extra .field{flex:1;min-width:140px;text-align:left}
.astro-extra select{width:100%;padding:11px;border:1px solid rgba(200,160,78,.4);border-radius:10px;background:rgba(255,255,255,.6);font-size:15px;color:var(--ink);outline:none}
.ax-res{margin-top:16px;padding:18px;border-radius:14px;background:linear-gradient(135deg,rgba(240,205,216,.35),rgba(232,223,240,.35));border:1px solid rgba(200,160,78,.35)}
.ax-res .ax-title{font-family:'Shippori Mincho',serif;font-size:18px;color:var(--ink);margin-bottom:6px}
.ax-res .ax-score{font-family:'Great Vibes',cursive;font-size:56px;color:var(--gold);line-height:1}
.ax-res .ax-score span{font-family:'Shippori Mincho',serif;font-size:18px;margin-left:4px}
.ax-res .ax-elem,.ax-res .ax-theme{font-size:14px;color:#8a82b0;margin:6px 0 10px}
.ax-res p{font-size:15px;line-height:1.9;color:var(--ink);margin:0}
/* ===== カード演出（タロット等） ===== */
.card-stage{text-align:center}
.card-deck-msg{font-family:'Shippori Mincho',serif;font-size:16px;color:var(--gold);margin-bottom:18px;letter-spacing:.08em}
.card-row{display:flex;gap:16px;justify-content:center;flex-wrap:wrap;perspective:1200px;min-height:230px;align-items:flex-start}
.tcard{width:130px}
.tcard-pos{font-family:'Shippori Mincho',serif;font-size:13px;color:#8a82b0;margin-bottom:8px;opacity:0;transition:opacity .4s}
.tcard.draw .tcard-pos{opacity:1}
.tcard-inner{position:relative;width:130px;height:200px;transform-style:preserve-3d;transition:transform .75s cubic-bezier(.4,.2,.2,1);transform:translateY(40px) rotateY(0deg);opacity:.35}
.tcard.draw .tcard-inner{transform:translateY(0) rotateY(0deg);opacity:1}
.tcard.flip .tcard-inner{transform:translateY(0) rotateY(180deg)}
.tcard-face{position:absolute;inset:0;backface-visibility:hidden;border-radius:14px;display:flex;flex-direction:column;align-items:center;justify-content:center;box-shadow:0 8px 22px rgba(80,50,120,.28)}
.tcard-back{background:linear-gradient(145deg,#5a4a8c,#2e2550);border:2px solid var(--gold)}
.tback-mark{font-size:40px;color:var(--gold);opacity:.85}
.tcard-front{transform:rotateY(180deg);background:linear-gradient(160deg,#fbf6ff,#f1e8fb);border:2px solid rgba(200,160,78,.5);padding:10px}
.tcard-front .tcard-name{font-family:'Shippori Mincho',serif;font-size:17px;color:var(--ink);font-weight:700;text-align:center;line-height:1.4}
.tcard-front .tcard-ori{font-size:12px;color:#8a82b0;margin-top:6px}
.tcard-front .tcard-emoji{font-size:30px;margin-top:10px}
.tcard-front.reversed .tcard-name,.tcard-front.reversed .tcard-emoji{transform:rotate(180deg)}
/* 良いカード=光る */
.tcard.revealed .tcard-front.good{border-color:var(--gold);box-shadow:0 0 0 2px var(--gold),0 0 24px 6px rgba(232,201,138,.85),0 0 48px 12px rgba(200,160,78,.5);animation:cardGlow 2s ease-in-out infinite}
@keyframes cardGlow{0%,100%{box-shadow:0 0 0 2px var(--gold),0 0 20px 5px rgba(232,201,138,.7),0 0 40px 10px rgba(200,160,78,.4)}50%{box-shadow:0 0 0 2px var(--gold),0 0 32px 9px rgba(232,201,138,.95),0 0 60px 16px rgba(200,160,78,.6)}}
/* 悪いカード=暗くなる */
.tcard.revealed .tcard-front.bad{filter:brightness(.55) saturate(.7);background:linear-gradient(160deg,#3a3450,#262036);border-color:#544a78}
.tcard.revealed .tcard-front.bad .tcard-name,.tcard.revealed .tcard-front.bad .tcard-ori{color:#cfc7e6}
.card-readings{margin-top:24px;text-align:left}
.card-readings .reading{padding:14px 16px;border-radius:12px;margin-bottom:12px}
.card-readings .reading.good{background:linear-gradient(135deg,rgba(232,201,138,.22),rgba(240,205,216,.22));border:1px solid rgba(200,160,78,.4)}
.card-readings .reading.bad{background:rgba(58,52,80,.12);border:1px solid rgba(84,74,120,.3)}
.card-readings .rd-h{font-family:'Shippori Mincho',serif;font-size:15px;color:var(--ink);margin-bottom:6px}
.card-readings .rd-h .badge{font-size:11px;padding:2px 8px;border-radius:10px;margin-left:8px;color:#fff;font-family:sans-serif}
.card-readings .rd-h .badge.g{background:linear-gradient(90deg,#E2C98A,#C8A04E)}
.card-readings .rd-h .badge.b{background:#6b6190}
.card-readings .reading p{font-size:14px;line-height:1.9;color:var(--ink);margin:0}
@media(max-width:600px){.tcard{width:96px}.tcard-inner{width:96px;height:148px}.tcard-front .tcard-name{font-size:13px}.card-row{gap:8px}}
/* ===== 占い中 演出オーバーレイ ===== */
.cast-overlay{position:fixed;inset:0;z-index:9999;display:flex;align-items:center;justify-content:center;background:radial-gradient(circle at center,rgba(60,40,90,.85),rgba(30,20,50,.95));opacity:0;transition:opacity .45s;backdrop-filter:blur(4px)}
.cast-overlay.on{opacity:1}
.cast-inner{text-align:center;transform:scale(.85);transition:transform .5s;position:relative}
.cast-overlay.on .cast-inner{transform:scale(1)}
.cast-orb{position:relative;width:140px;height:140px;margin:0 auto 28px}
.cast-orb .orb-glow{position:absolute;inset:0;border-radius:50%;background:radial-gradient(circle at 38% 35%,#fff,rgba(232,201,138,.9) 30%,rgba(200,160,78,.5) 60%,rgba(120,90,160,.2) 100%);box-shadow:0 0 40px 14px rgba(232,201,138,.6),0 0 80px 30px rgba(200,160,78,.35);animation:orbPulse 2s ease-in-out infinite}
@keyframes orbPulse{0%,100%{transform:scale(1);box-shadow:0 0 36px 12px rgba(232,201,138,.55),0 0 70px 26px rgba(200,160,78,.3)}50%{transform:scale(1.08);box-shadow:0 0 52px 18px rgba(232,201,138,.8),0 0 100px 40px rgba(200,160,78,.45)}}
.cast-orb .orb-core{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;font-size:54px;filter:drop-shadow(0 2px 6px rgba(0,0,0,.3));animation:orbFloat 3s ease-in-out infinite}
@keyframes orbFloat{0%,100%{transform:translateY(0)}50%{transform:translateY(-6px)}}
.cast-orb .orb-star{position:absolute;color:#fff;font-size:18px;opacity:.9;animation:orbit 3.5s linear infinite}
.cast-orb .orb-star.s1{animation-duration:3s}
.cast-orb .orb-star.s2{animation-duration:4.5s;font-size:14px}
.cast-orb .orb-star.s3{animation-duration:5.5s;font-size:22px;color:#E8C98A}
@keyframes orbit{from{transform:rotate(0deg) translateX(82px) rotate(0deg)}to{transform:rotate(360deg) translateX(82px) rotate(-360deg)}}
.cast-ring{position:absolute;top:-10px;left:50%;width:200px;height:200px;margin-left:-100px;border:1px dashed rgba(232,201,138,.5);border-radius:50%;animation:ringSpin 12s linear infinite;pointer-events:none}
.cast-ring::before{content:'✦ ✧ ✦ ✧ ✦ ✧ ✦ ✧';position:absolute;top:-12px;left:0;right:0;text-align:center;color:rgba(232,201,138,.7);font-size:12px;letter-spacing:8px}
@keyframes ringSpin{from{transform:rotate(0)}to{transform:rotate(360deg)}}
.cast-msg{font-family:'Shippori Mincho',serif;font-size:20px;color:#fff;letter-spacing:.08em;margin-bottom:8px;text-shadow:0 0 12px rgba(232,201,138,.6)}
.cast-sub{font-size:14px;color:rgba(255,255,255,.8);letter-spacing:.05em;animation:subFade 1.6s ease-in-out infinite}
@keyframes subFade{0%,100%{opacity:.55}50%{opacity:1}}
/* ===== 総合占い（3占術） ===== */
.combo-hero{text-align:center;padding:30px 16px 10px}
.combo-badge{display:inline-block;font-size:13px;letter-spacing:.12em;color:var(--gold);border:1px solid rgba(200,160,78,.5);border-radius:20px;padding:5px 16px;margin-bottom:14px}
.combo-title{font-family:'Shippori Mincho',serif;font-size:34px;color:var(--ink);letter-spacing:.12em;margin:0 0 14px}
.combo-lead{font-size:14px;line-height:1.9;color:#8a82b0;max-width:560px;margin:0 auto}
.combo-step{font-family:'Shippori Mincho',serif;font-size:17px;color:var(--ink);margin-bottom:14px}
.combo-step .stepno{display:inline-block;background:linear-gradient(90deg,#E2C98A,#C8A04E);color:#fff;font-size:12px;padding:3px 10px;border-radius:10px;margin-right:8px;font-family:sans-serif;letter-spacing:.05em}
.combo-step small{color:var(--gold);font-weight:700}
.combo-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(104px,1fr));gap:10px}
.combo-card{position:relative;display:flex;flex-direction:column;align-items:center;gap:5px;padding:14px 6px;border-radius:14px;border:1.5px solid rgba(200,160,78,.25);background:rgba(255,255,255,.45);cursor:pointer;transition:.25s;text-align:center}
.combo-card .ic{font-size:26px}
.combo-card .nm{font-size:12px;color:var(--ink);line-height:1.3}
.combo-card .chk{position:absolute;top:6px;right:8px;color:#fff;background:var(--gold);width:20px;height:20px;border-radius:50%;line-height:20px;font-size:12px;opacity:0;transform:scale(.5);transition:.25s}
.combo-card.on{border-color:var(--gold);background:linear-gradient(135deg,rgba(232,201,138,.3),rgba(240,205,216,.3));box-shadow:0 4px 16px rgba(200,160,78,.3);transform:translateY(-2px)}
.combo-card.on .chk{opacity:1;transform:scale(1)}
.btn-combo{margin-top:22px;font-size:17px}
.combo-res{text-align:center}
.combo-score-wrap{margin-bottom:18px}
.combo-score-label{font-family:'Shippori Mincho',serif;font-size:15px;color:#8a82b0}
.combo-score{font-family:'Great Vibes',cursive;font-size:78px;color:var(--gold);line-height:1;text-shadow:0 2px 12px rgba(200,160,78,.4)}
.combo-score span{font-family:'Shippori Mincho',serif;font-size:22px;margin-left:6px}
.combo-intro{font-size:14px;line-height:1.95;color:var(--ink);max-width:580px;margin:0 auto 24px;text-align:left}
.combo-casts{display:flex;flex-direction:column;gap:14px;text-align:left;margin-bottom:24px}
.combo-cast{display:flex;gap:14px;padding:16px;border-radius:14px;background:linear-gradient(135deg,rgba(240,205,216,.22),rgba(232,223,240,.22));border:1px solid rgba(200,160,78,.3);opacity:0;animation:castIn .6s forwards}
@keyframes castIn{to{opacity:1;transform:translateY(0)}}
.combo-cast{transform:translateY(12px)}
.combo-cast .cc-icon{font-size:34px;flex-shrink:0}
.combo-cast .cc-name{font-family:'Shippori Mincho',serif;font-size:16px;color:var(--gold);font-weight:700}
.combo-cast .cc-key{font-size:13px;color:#8a82b0;margin:2px 0 8px}
.combo-cast p{font-size:14px;line-height:1.85;color:var(--ink);margin:0}
.combo-advice{padding:22px;border-radius:16px;background:linear-gradient(135deg,rgba(232,201,138,.28),rgba(200,160,78,.16));border:1.5px solid var(--gold);margin-bottom:18px}
.combo-advice .ca-h{font-family:'Shippori Mincho',serif;font-size:19px;color:var(--gold);margin-bottom:10px}
.combo-advice p{font-size:15px;line-height:1.95;color:var(--ink);margin:0}
.combo-closing{font-size:14px;line-height:1.95;color:#6b6390;font-style:italic;max-width:560px;margin:0 auto 18px}
@media(max-width:600px){.combo-title{font-size:26px}.combo-grid{grid-template-columns:repeat(3,1fr)}.combo-card .nm{font-size:11px}}
/* 総合占いプロモバナー（トップ） */
.combo-promo{display:block;text-decoration:none;text-align:center;margin:0 0 30px;padding:26px 20px;border-radius:18px;background:linear-gradient(135deg,#5a4a8c 0%,#7d5fa8 50%,#c8a04e 140%);box-shadow:0 10px 30px rgba(90,74,140,.35);position:relative;overflow:hidden;transition:.3s}
.combo-promo:hover{transform:translateY(-3px);box-shadow:0 14px 38px rgba(90,74,140,.45)}
.combo-promo::after{content:'✦ ✧ ✦ ✧ ✦ ✧';position:absolute;top:8px;left:0;right:0;text-align:center;color:rgba(255,255,255,.25);font-size:13px;letter-spacing:10px}
.combo-promo .cp-badge{display:inline-block;font-size:12px;letter-spacing:.12em;color:#fff;border:1px solid rgba(255,255,255,.5);border-radius:16px;padding:3px 14px;margin-bottom:10px}
.combo-promo .cp-title{font-family:'Shippori Mincho',serif;font-size:30px;color:#fff;letter-spacing:.1em;margin-bottom:10px;text-shadow:0 2px 10px rgba(0,0,0,.2)}
.combo-promo .cp-desc{font-size:13px;line-height:1.85;color:rgba(255,255,255,.92);max-width:520px;margin:0 auto 14px}
.combo-promo .cp-cta{display:inline-block;background:#fff;color:#5a4a8c;font-weight:700;font-size:15px;padding:10px 28px;border-radius:24px;letter-spacing:.05em}
/* タロット キーワードチップ */
.card-readings .rd-kw{display:flex;gap:6px;flex-wrap:wrap;margin-bottom:8px}
.card-readings .rd-kw span{font-size:11px;background:rgba(200,160,78,.18);color:#8a6d2a;border:1px solid rgba(200,160,78,.4);border-radius:10px;padding:2px 9px}
/* マイページ 鑑定履歴 */
.hist-item{padding:14px 16px;border-radius:12px;background:rgba(255,255,255,.45);border:1px solid rgba(200,160,78,.25);margin-bottom:10px}
.hist-item .hi-top{display:flex;justify-content:space-between;align-items:baseline;gap:8px}
.hist-item .hi-title{font-family:'Shippori Mincho',serif;font-size:15px;color:var(--gold);font-weight:700}
.hist-item .hi-date{font-size:11px;color:#9b93c4;white-space:nowrap}
.hist-item .hi-key{font-size:13px;color:var(--ink);margin-top:3px}
.hist-item .hi-c{font-size:12px;color:#6b6390;line-height:1.7;margin:6px 0 0}

/* ===== モンスター召喚カード（3D） ===== */
.mcard-wrap{display:flex;justify-content:center;margin:24px 0;perspective:1200px;}
.mcard{width:260px;height:347px;cursor:default;}
.mcard-inner{position:relative;width:100%;height:100%;transform-style:preserve-3d;transition:transform 1s cubic-bezier(.4,.2,.2,1);}
.mcard.flip .mcard-inner{transform:rotateY(180deg);}
.mcard.draw .mcard-inner{animation:mcardDraw .6s ease;}
@keyframes mcardDraw{0%{transform:translateY(40px) scale(.9);opacity:.5;}100%{transform:translateY(0) scale(1);opacity:1;}}
.mcard-face{position:absolute;width:100%;height:100%;backface-visibility:hidden;border-radius:18px;overflow:hidden;box-shadow:0 10px 30px rgba(80,50,120,.35);border:3px solid #C8A04E;}
.mcard-back{background:linear-gradient(135deg,#3b2a5e 0%,#5a3f86 50%,#2d2350 100%);display:flex;align-items:center;justify-content:center;}
.mback-mark{font-size:72px;color:#C8A04E;text-shadow:0 0 20px rgba(200,160,78,.8);animation:mbackGlow 2s ease-in-out infinite;}
@keyframes mbackGlow{0%,100%{opacity:.7;transform:scale(1);}50%{opacity:1;transform:scale(1.1);}}
.mcard-front{transform:rotateY(180deg);background:linear-gradient(135deg,#F0CDD8,#E8DFF0);display:flex;flex-direction:column;}
.mcard-img{flex:1;background-size:cover;background-position:center;}
.mcard-name{padding:10px;text-align:center;font-family:'Shippori Mincho',serif;font-weight:700;font-size:20px;color:#4a3a6a;background:rgba(255,255,255,.85);letter-spacing:2px;}
.mcard.revealed .mcard-front{box-shadow:0 0 40px rgba(200,160,78,.9),0 10px 30px rgba(80,50,120,.4);animation:mReveal 1s ease;}
@keyframes mReveal{0%{filter:brightness(1.6);}100%{filter:brightness(1);}}

/* === カード画像版 v2 === */
.card-v2{padding:0;overflow:hidden;text-align:center;display:flex;flex-direction:column}
.card-v2::before{inset:4px;border-radius:15px}
.card-v2 .card-thumb{display:block;width:100%;aspect-ratio:16/4.2;overflow:hidden;border-radius:17px 17px 0 0;background:#EFE7F5}
.card-v2 .card-thumb img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .3s}
.card-v2:hover .card-thumb img{transform:scale(1.05)}
.card-v2 .nm{margin:14px 0 7px;padding:0 12px}
.card-v2 .tg{padding:0 14px 18px;margin:0}

/* AI\u5bfe\u8a71\u9451\u5b9a\u30d0\u30ca\u30fc */
.chat-promo{display:block;background:linear-gradient(135deg,#2d3a5e,#5a4a9c 50%,#C8A04E)!important;margin-bottom:16px!important;position:relative;overflow:hidden}
.chat-promo::after{content:'🐉';position:absolute;right:18px;top:50%;transform:translateY(-50%);font-size:54px;opacity:.22}

/* \u547d\u5f0f\u8868 */
.meishiki{margin:14px 0 6px;padding:14px;border:1px solid rgba(200,160,78,.45);border-radius:14px;background:linear-gradient(135deg,#fbf6ee,#f3ecfb)}
.meishiki .ms-ttl{font-family:'Shippori Mincho',serif;font-size:13px;color:#8a6d2f;letter-spacing:.1em;text-align:center;margin-bottom:10px}
.ms-grid{display:flex;gap:10px;justify-content:center;flex-wrap:wrap}
.ms-cell{flex:1;min-width:90px;text-align:center;background:#fff;border:1px solid rgba(200,160,78,.3);border-radius:10px;padding:9px 6px}
.ms-cell .ms-l{display:block;font-size:11px;color:#a08abf;margin-bottom:3px}
.ms-cell .ms-v{display:block;font-size:15px;font-weight:700;color:#6d4a9c;font-family:'Shippori Mincho',serif}

/* \u4f1a\u54e1\u81ea\u52d5\u5165\u529b\u306e\u6848\u5185 */
.member-auto{background:linear-gradient(135deg,#f3ecfb,#fbf6ee);border:1px solid rgba(200,160,78,.4);border-radius:12px;padding:10px 14px;margin-bottom:14px;font-size:13px;color:#6d4a9c;line-height:1.7}
.member-auto.guest{color:#8a82b0}
.member-auto a{color:#8a6d2f;font-weight:700;text-decoration:underline}

/* \u624b\u76f8AI\u5199\u771f\u9451\u5b9a */
.palm-tabs{display:flex;gap:8px;margin-bottom:14px}
.palm-tabs .pt-btn{flex:1;padding:10px;border:1px solid rgba(200,160,78,.45);background:#fff;border-radius:10px;font-size:13px;color:#8a6d2f;cursor:pointer;font-family:inherit}
.palm-tabs .pt-btn.active{background:linear-gradient(135deg,#a06bff,#C8A04E);color:#fff;border-color:transparent}
.palm-hint{font-size:13px;color:#7a6f9c;line-height:1.7;margin:0 0 12px}
.palm-upload{display:block;border:2px dashed rgba(160,107,255,.45);border-radius:14px;padding:22px 14px;text-align:center;cursor:pointer;color:#6d4a9c;font-size:14px;background:rgba(255,255,255,.6);margin-bottom:14px}
.palm-upload:hover{background:rgba(243,236,251,.8)}

/* 占い方の説明 */
.fdesc{max-width:560px;margin:2px auto 18px;padding:12px 16px;background:rgba(255,255,255,.55);border:1px solid rgba(200,160,78,.3);border-radius:12px;font-size:13px;line-height:1.85;color:#6a6088;text-align:left}

/* SNS\u30b7\u30a7\u30a2\u30dc\u30bf\u30f3 */
.share{display:flex;flex-wrap:wrap;gap:8px;justify-content:center;margin-top:16px}
.share .sns{display:inline-block;padding:8px 16px;border-radius:22px;color:#fff;text-decoration:none;font-size:13px;font-weight:700;letter-spacing:.03em;transition:.2s}
.share .sns:hover{transform:translateY(-2px);opacity:.92}
.sns-line{background:#06C755}
.sns-x{background:#000}
.sns-th{background:#000}
.sns-ig{background:linear-gradient(45deg,#f09433,#e6683c,#dc2743,#cc2366,#bc1888)}
.sns-fb{background:#1877F2}

/* 会員登録CTA（占い結果後） */
.member-cta{margin-top:20px;padding:18px 16px;border-radius:16px;background:linear-gradient(135deg,#6d4a9c,#a06bff 60%,#C8A04E);color:#fff;text-align:center;box-shadow:0 8px 24px rgba(160,107,255,.3)}
.member-cta .mc-ttl{font-family:'Shippori Mincho',serif;font-size:16px;font-weight:700;letter-spacing:.05em;margin-bottom:8px}
.member-cta .mc-txt{font-size:12.5px;line-height:1.8;opacity:.95;margin-bottom:14px}
.member-cta .mc-btn{display:inline-block;background:#fff;color:#6d4a9c;padding:11px 28px;border-radius:26px;text-decoration:none;font-weight:700;font-size:14.5px;box-shadow:0 4px 12px rgba(0,0,0,.15)}
.member-cta .mc-btn:hover{transform:translateY(-2px)}

/* セクション本文の改行・行間を見やすく */
.result .sec div{white-space:pre-wrap;line-height:1.9}
.sec div{white-space:pre-wrap;line-height:1.9}

/* 2カラム（grid・重なり防止） */
.f2grid{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.f2grid .field{min-width:0;margin-bottom:0}
.f2grid .field input,.f2grid .field select{width:100%;box-sizing:border-box;min-width:0}
.f2grid+.field,.f2grid{margin-bottom:13px}
/* 退会リンク（控えめ） */
.withdraw-area{margin-top:30px;text-align:center}
.withdraw-link{font-size:11px;color:#b3a9cc;text-decoration:underline;cursor:pointer;background:none;border:none;font-family:inherit}
.withdraw-link:hover{color:#9b8fc0}

/* \u5e83\u544a\uff08\u63a7\u3048\u3081\uff09 */
.ur-ad{position:relative;margin:22px auto 6px;max-width:300px;text-align:center;background:rgba(255,255,255,.5);border:1px solid rgba(200,160,78,.25);border-radius:14px;padding:14px 10px 10px}
.ur-ad .ad-pr{position:absolute;top:6px;left:10px;font-size:10px;color:#b3a9cc;letter-spacing:.1em}
.ur-ad img{max-width:100%;height:auto;border-radius:8px}
.ur-ad .ad-note{font-size:11.5px;color:#8a82b0;margin-top:8px;line-height:1.6}

/* === スマホ枠重なり修正（selectはみ出し防止）=== */
.f2grid .field select,.f2grid .field input{-webkit-appearance:none;appearance:none;max-width:100%}
@media(max-width:430px){
  .f2grid{grid-template-columns:1fr !important;gap:0 !important}
  .f2grid .field{margin-bottom:13px !important}
}

/* === 入力欄はみ出し防止（保険）=== */
input:not([type=checkbox]):not([type=radio]),select,textarea{box-sizing:border-box !important;max-width:100% !important}
input[type=checkbox],input[type=radio]{width:auto !important;flex:0 0 auto}
.field,.f2grid{box-sizing:border-box;max-width:100%}
@media(max-width:768px){
  .field input:not([type=checkbox]):not([type=radio]),.field select,.field textarea{width:100% !important}
  .field input[type=checkbox],.field input[type=radio]{width:auto !important;max-width:none !important}
}
