:root{
  --fg:#f2f5ff;
  --bg:#05060d;
  --muted:#9399c8;
  --acc:#7b5eff;
  --glow:#b8a9ff;
  --shadow:rgba(8,10,30,0.85);
}
*{box-sizing:border-box}
html,body{margin:0;padding:0;font-family:"Inter", "Noto Sans JP", system-ui, -apple-system, "Segoe UI", sans-serif;background:var(--bg);color:var(--fg);min-height:100vh;overflow-x:hidden}
body{position:relative}
a{color:var(--acc);text-decoration:none}
a:hover{text-shadow:0 0 8px rgba(123,94,255,.45)}
header{display:flex;justify-content:space-between;align-items:center;padding:24px 24px 16px;position:relative;z-index:2}
h1{margin:0;font-size:1.2rem;letter-spacing:.08em;text-transform:uppercase}
.lang{display:flex;gap:8px;align-items:center}
.lang button{border:1px solid rgba(255,255,255,.15);background:rgba(25,25,35,.85);color:var(--fg);padding:6px 12px;border-radius:999px;cursor:pointer;transition:transform .2s ease, background .2s ease}
.lang button.active{background:var(--acc);color:#05060d}
.lang button:active{transform:scale(.95)}

#camera-btn{position:fixed;top:20px;right:24px;background:rgba(15,15,28,.85);border:1px solid rgba(255,255,255,.12);color:var(--fg);padding:10px 18px;border-radius:999px;cursor:pointer;box-shadow:0 12px 24px rgba(10,10,30,.45);z-index:10;transition:transform .2s ease, box-shadow .2s ease}
#camera-btn:hover{transform:translateY(-2px);box-shadow:0 18px 34px rgba(10,10,30,.6)}
#camera-btn:active{transform:translateY(1px)}

main{max-width:1200px;margin:0 auto;padding:0 24px 120px;position:relative;z-index:1}
.hero{margin:32px 0 40px;padding:28px;border-radius:24px;background:radial-gradient(circle at 20% 20%,rgba(123,94,255,.18),rgba(20,18,33,.92));box-shadow:0 30px 60px rgba(5,5,20,.65);text-align:center}
.hero h2{font-size:2rem;margin:0 0 12px;letter-spacing:.1em}
.hero-sub{margin:0;font-size:1rem;color:var(--muted);line-height:1.5}
.hero-copy{margin:16px 0 0;font-size:.95rem;color:rgba(255,255,255,.7)}

.lead{margin:36px 0 18px;color:var(--muted)}
.grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:18px}
.card{display:block;border:1px solid rgba(255,255,255,.08);background:rgba(18,18,28,.9);border-radius:20px;padding:16px;text-decoration:none;color:inherit;transition:transform .2s ease, box-shadow .2s ease, border-color .2s ease;backdrop-filter:blur(6px)}
.card:hover{transform:translateY(-6px);box-shadow:0 18px 36px rgba(8,8,20,.6);border-color:rgba(123,94,255,.4)}
.card:active{transform:translateY(-2px)}
.card h2{margin:0 0 12px;font-size:1.1rem;display:flex;align-items:center;gap:10px}
.card p{margin:0;color:var(--muted)}
.result-em{font-size:1.5rem}

.result-card{background:rgba(15,15,26,.92);border-radius:22px;border:1px solid rgba(255,255,255,.05);padding:22px;margin:22px 0;box-shadow:0 24px 48px rgba(2,2,8,.65);backdrop-filter:blur(8px);animation:popIn .45s ease forwards;opacity:0;transform:translateY(16px)}
.result-card h3{margin:0 0 12px;font-size:1.1rem;display:flex;align-items:center;gap:10px}
.result-card p{margin:6px 0;color:rgba(242,245,255,.85)}
.keyword-list{list-style:none;padding:0;margin:10px 0 0;display:grid;gap:6px;font-size:.95rem;color:var(--muted)}
.keyword-list li::before{content:"•";margin-right:6px;color:var(--acc)}

.tarot-zone{margin:60px 0}
.tarot-zone h2{margin:0 0 8px;font-size:1.4rem;letter-spacing:.08em}
.tarot-zone .small{color:var(--muted);margin:0 0 18px}
.tarot-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:18px}
.tarot-card{position:relative;perspective:1200px;border:none;background:transparent;padding:0;cursor:pointer}
.tarot-card.disabled{opacity:.25;pointer-events:none}
.tarot-card-inner{position:relative;width:100%;height:200px;transform-style:preserve-3d;transition:transform .6s ease}
.tarot-card:hover .tarot-card-inner{transform:translateY(-4px)}
.tarot-card.revealed .tarot-card-inner{transform:rotateY(180deg)}
.tarot-card-face{position:absolute;inset:0;border-radius:18px;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:16px;backface-visibility:hidden;border:1px solid rgba(255,255,255,.1);box-shadow:0 16px 32px rgba(5,5,20,.65)}
.tarot-back{background:linear-gradient(140deg,rgba(60,50,90,.9),rgba(30,28,60,.9));gap:12px;font-size:1.4rem;letter-spacing:.12em}
.tarot-back span{display:block}
.tarot-front{background:linear-gradient(150deg,rgba(20,20,32,.95),rgba(40,30,70,.9));transform:rotateY(180deg);text-align:center;gap:8px}
.tarot-front h4{margin:0;font-size:1.05rem}
.tarot-front .tarot-meaning{font-size:.95rem;color:var(--muted)}
.tarot-reset{margin-top:12px;border:1px solid rgba(255,255,255,.2);background:rgba(20,20,32,.9);color:var(--fg);padding:6px 14px;border-radius:999px;cursor:pointer;font-size:.85rem;box-shadow:0 10px 24px rgba(5,5,18,.5)}
.tarot-reset:hover{box-shadow:0 12px 28px rgba(5,5,18,.65)}

.disclaimer{margin:40px 0 0;color:var(--muted);font-size:.85rem;text-align:center}
.site-footer{margin:60px 0 30px;text-align:center;opacity:.8}
.site-footer a{color:var(--acc)}

.floating-toggle{position:fixed;bottom:24px;right:24px;display:flex;align-items:center;gap:10px;z-index:15;background:rgba(18,18,28,.92);padding:10px 14px;border:1px solid rgba(255,255,255,.08);border-radius:999px;box-shadow:0 18px 32px rgba(2,2,8,.6)}
.toggle-switch{position:relative;display:inline-block;width:48px;height:26px}
.toggle-switch input{opacity:0;width:0;height:0}
.toggle-slider{position:absolute;inset:0;background:rgba(80,80,110,.5);border-radius:999px;transition:.3s}
.toggle-slider::before{content:"";position:absolute;height:20px;width:20px;left:4px;top:3px;background:#fff;border-radius:50%;transition:.3s}
.toggle-switch input:checked + .toggle-slider{background:var(--acc)}
.toggle-switch input:checked + .toggle-slider::before{transform:translateX(20px)}
.toggle-label{font-size:.9rem;color:var(--muted)}

#toast-container{position:fixed;top:20px;left:50%;transform:translateX(-50%);display:flex;flex-direction:column;gap:10px;z-index:20;pointer-events:none}
.toast{background:rgba(10,10,20,.92);padding:12px 18px;border-radius:12px;border:1px solid rgba(255,255,255,.1);color:var(--fg);box-shadow:0 18px 36px rgba(5,5,20,.6);opacity:0;transform:translateY(-10px);animation:toastIn .35s forwards}
.toast.hide{animation:toastOut .35s forwards}

.modal{position:fixed;inset:0;background:rgba(4,4,8,.8);display:flex;align-items:center;justify-content:center;z-index:30;opacity:0;pointer-events:none;transition:opacity .3s ease}
.modal:not(.hidden){opacity:1;pointer-events:auto}
.modal-content{position:relative;background:rgba(15,15,28,.95);padding:26px 32px;border-radius:18px;border:1px solid rgba(255,255,255,.08);box-shadow:0 30px 60px rgba(3,3,10,.7);min-width:280px;text-align:center}
#camera-close{position:absolute;top:12px;right:12px;border:none;background:transparent;color:var(--muted);font-size:1.2rem;cursor:pointer}

.analyzing{color:var(--muted);animation:blink 1s infinite}

#eye-cursor{position:fixed;width:26px;height:26px;border-radius:50%;border:2px solid rgba(255,255,255,.65);box-shadow:0 0 12px rgba(123,94,255,.7);pointer-events:none;z-index:8;opacity:0;transform:translate(-50%,-50%)}
#gaze-banner{position:fixed;left:50%;bottom:24px;transform:translate(-50%,40px);background:rgba(15,15,26,.92);padding:10px 22px;border-radius:999px;border:1px solid rgba(255,255,255,.08);box-shadow:0 18px 32px rgba(2,2,8,.6);opacity:0;transition:transform .4s ease, opacity .4s ease;z-index:12}
#gaze-banner.show{opacity:1;transform:translate(-50%,0)}

#idle-hint{position:fixed;right:32px;bottom:120px;background:rgba(15,15,26,.92);padding:10px 20px;border-radius:16px;border:1px solid rgba(255,255,255,.08);box-shadow:0 18px 32px rgba(2,2,8,.6);opacity:0;transform:translateY(10px);transition:opacity .3s ease,transform .3s ease;z-index:12}
#idle-hint.visible{opacity:1;transform:translateY(0)}

.hero, .result-card, .card, .tarot-card-face{position:relative;overflow:hidden}
.hero::before,.result-card::before,.card::before{content:"";position:absolute;inset:0;background:radial-gradient(circle at 20% 20%,rgba(255,255,255,.08),transparent 60%);pointer-events:none}

@keyframes popIn{to{opacity:1;transform:translateY(0)}}
@keyframes blink{0%,100%{opacity:.3}50%{opacity:1}}
@keyframes toastIn{from{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}
@keyframes toastOut{from{opacity:1;transform:translateY(0)}to{opacity:0;transform:translateY(-10px)}}

@media (max-width:720px){
  header{flex-direction:column;gap:12px}
  #camera-btn{top:16px;right:16px}
  .hero{padding:22px}
  .floating-toggle{right:16px;bottom:16px}
  .tarot-card-inner{height:180px}
}

@media (max-width:480px){
  main{padding:0 18px 110px}
  .grid{grid-template-columns:1fr;gap:14px}
  #camera-btn{font-size:.8rem;padding:8px 14px}
  #eye-cursor{display:none}
}

.hidden{display:none !important}
body.effects-off #eye-cursor{opacity:0}

:root{
  --fg:#f7f4ff;
  --bg:#04010f;
  --bg-soft:#08041a;
  --panel:rgba(20,16,44,.92);
  --panel-strong:rgba(16,12,36,.96);
  --muted:#9d98d8;
  --acc:#b184ff;
  --glow:#d8c8ff;
  --shadow:rgba(2,2,12,.85);
}

body{
  background:
    radial-gradient(circle at 12% 18%,rgba(177,132,255,.12),transparent 60%),
    radial-gradient(circle at 80% 0%,rgba(114,71,255,.18),transparent 55%),
    linear-gradient(160deg,#03010a,#09041f 55%,#04010f);
  color:var(--fg);
}
body::before,
body::after{
  content:"";
  position:fixed;
  inset:-20%;
  z-index:-1;
  pointer-events:none;
}
body::before{
  background:radial-gradient(circle at 25% 30%,rgba(177,132,255,.2),transparent 45%),
             radial-gradient(circle at 70% 65%,rgba(101,70,200,.28),transparent 55%),
             radial-gradient(circle at 50% 85%,rgba(45,34,120,.32),transparent 60%);
  filter:blur(12px);
  opacity:.7;
  animation:nebulaShift 24s ease-in-out infinite alternate;
}
body::after{
  background-image:radial-gradient(circle,rgb(255 255 255 / .45) 0 1px,transparent 1px);
  background-size:120px 120px;
  mix-blend-mode:screen;
  opacity:.25;
  animation:starTwinkle 3.5s linear infinite;
}

header{
  background:linear-gradient(135deg,rgba(15,12,34,.9),rgba(10,8,28,.6));
  border-bottom:1px solid rgba(209,194,255,.15);
  backdrop-filter:blur(12px);
  box-shadow:0 20px 45px rgba(0,0,0,.35);
  border-bottom-left-radius:22px;
  border-bottom-right-radius:22px;
  padding:26px 32px 18px;
}

.badge{
  display:inline-flex;
  align-items:center;
  gap:8px;
  padding:8px 14px;
  border-radius:999px;
  background:rgba(40,30,78,.85);
  border:1px solid rgba(209,194,255,.3);
  color:var(--fg);
  font-size:.85rem;
  letter-spacing:.08em;
  text-transform:uppercase;
  box-shadow:0 12px 28px rgba(0,0,0,.35);
  transition:transform .2s ease, box-shadow .2s ease, background .2s ease;
}
.badge:hover{transform:translateY(-1px);box-shadow:0 18px 34px rgba(0,0,0,.45);background:rgba(51,37,100,.88);}

.lang button{
  background:rgba(32,24,66,.9);
  border:1px solid rgba(209,194,255,.28);
  box-shadow:0 12px 28px rgba(0,0,0,.35);
}
.lang button.active{
  background:linear-gradient(135deg,rgba(177,132,255,.9),rgba(120,80,220,.95));
  color:#0b0518;
  box-shadow:0 16px 32px rgba(34,16,74,.6);
}

main{
  position:relative;
  z-index:0;
}
main::before{
  content:"";
  position:absolute;
  inset:0;
  background:radial-gradient(circle at 10% 10%,rgba(200,160,255,.08),transparent 55%),
             radial-gradient(circle at 90% 90%,rgba(110,70,220,.12),transparent 60%);
  opacity:.7;
  pointer-events:none;
  z-index:-1;
}

.lead{color:var(--muted);text-shadow:0 0 12px rgba(123,94,255,.18);}

.hero,
.card,
.result-card{
  background:var(--panel);
  border:1px solid rgba(210,195,255,.12);
  box-shadow:0 28px 60px rgba(2,2,20,.6);
}
.hero::before,
.card::before,
.result-card::before{background:radial-gradient(circle at 25% 25%,rgba(255,255,255,.12),transparent 60%);opacity:.6;}
.hero::after,
.card::after,
.result-card::after{
  content:"";
  position:absolute;
  inset:-40% -20%;
  background:conic-gradient(from 0deg,rgba(177,132,255,.1),rgba(58,35,120,.35),rgba(12,8,34,0));
  mix-blend-mode:screen;
  opacity:.4;
  animation:veil 26s linear infinite;
  pointer-events:none;
}

.section{margin:36px 0;display:flex;justify-content:center;}

form label{display:block;margin:24px 0 10px;font-size:.95rem;letter-spacing:.06em;color:var(--muted);}

form select,
form input,
form textarea{
  width:100%;
  padding:12px 14px;
  border-radius:14px;
  background:rgba(18,14,42,.85);
  border:1px solid rgba(209,194,255,.18);
  color:var(--fg);
  box-shadow:0 16px 32px rgba(0,0,0,.35);
  transition:border-color .2s ease, box-shadow .2s ease, transform .2s ease;
}
form select:focus,
form input:focus,
form textarea:focus{
  border-color:rgba(177,132,255,.45);
  box-shadow:0 18px 38px rgba(34,18,80,.55);
  outline:none;
}

.birth-selects{display:grid;grid-template-columns:repeat(auto-fit,minmax(120px,1fr));gap:12px;background:rgba(10,8,28,.6);padding:16px;border-radius:18px;border:1px solid rgba(209,194,255,.15);box-shadow:0 22px 40px rgba(0,0,0,.35);}
.select-block{background:rgba(24,18,52,.75);border-radius:14px;padding:10px 12px;border:1px solid rgba(209,194,255,.1);display:flex;flex-direction:column;gap:8px;box-shadow:inset 0 0 12px rgba(177,132,255,.08);}
.select-block .small{color:rgba(215,205,255,.7);font-size:.75rem;letter-spacing:.1em;text-transform:uppercase;}
.select-block select{margin:0;background:rgba(12,9,32,.85);border:1px solid rgba(209,194,255,.2);box-shadow:none;}

.primary{
  margin-top:24px;
  padding:12px 26px;
  border-radius:999px;
  border:1px solid rgba(206,186,255,.4);
  background:linear-gradient(135deg,rgba(177,132,255,.95),rgba(122,74,220,.9));
  color:#0c0316;
  font-weight:600;
  letter-spacing:.08em;
  cursor:pointer;
  box-shadow:0 22px 40px rgba(32,16,70,.55);
  transition:transform .2s ease, box-shadow .2s ease;
}
.primary:hover{transform:translateY(-2px);box-shadow:0 28px 52px rgba(37,18,80,.65);}
.primary:active{transform:translateY(0);}

.section .badge{background:rgba(32,24,66,.85);}
.section .badge:hover{background:rgba(40,28,80,.9);}

.site-footer{color:rgba(230,226,255,.7);}
.site-footer a{color:var(--acc);text-shadow:0 0 10px rgba(177,132,255,.5);}

@keyframes nebulaShift{0%{transform:translate3d(-2%,0,0);}50%{transform:translate3d(3%,1%,0);}100%{transform:translate3d(-1%,2%,0);}}
@keyframes starTwinkle{0%,100%{opacity:.22;}50%{opacity:.32;}}
@keyframes veil{0%{transform:rotate(0deg);}100%{transform:rotate(360deg);}}
