:root{
  --space:#101426;
  --space2:#171b34;
  --paper:rgba(255,255,255,.08);
  --paper2:rgba(255,255,255,.12);
  --ink:#f7f0df;
  --muted:#c9bd9e;
  --gold:#d9b46b;
  --gold2:#f0d69a;
  --line:rgba(217,180,107,.24);
  --blue:#7f9edb;
  --shadow:0 28px 80px rgba(0,0,0,.36);
  --radius:28px;
  --container:1160px;
  --serif:"Hiragino Mincho ProN","Yu Mincho","Noto Serif JP",serif;
  --sans:"Noto Sans JP",system-ui,-apple-system,BlinkMacSystemFont,sans-serif;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  color:var(--ink);
  font-family:var(--sans);
  line-height:1.9;
  letter-spacing:.04em;
  background:
    radial-gradient(circle at 15% 8%,rgba(217,180,107,.22),transparent 20rem),
    radial-gradient(circle at 82% 18%,rgba(127,158,219,.18),transparent 26rem),
    radial-gradient(circle at 50% 100%,rgba(217,180,107,.14),transparent 28rem),
    linear-gradient(135deg,#0b0e1b 0%,#12162b 45%,#090c18 100%);
  overflow-x:hidden;
}
body::before{
  content:"";
  position:fixed;inset:0;
  pointer-events:none;
  background-image:
    radial-gradient(circle,rgba(255,255,255,.58) 0 1px,transparent 1px),
    radial-gradient(circle,rgba(217,180,107,.35) 0 1px,transparent 1px);
  background-size:90px 90px,140px 140px;
  background-position:0 0,30px 60px;
  opacity:.28;
  z-index:-1;
}
a{color:inherit}
img{display:block;max-width:100%}
h1,h2,h3,p{margin-top:0}
h1,h2,h3{font-family:var(--serif);font-weight:500;line-height:1.45;letter-spacing:.07em}
h1{font-size:clamp(2.8rem,6vw,5.7rem);margin-bottom:1.2rem}
h2{font-size:clamp(2rem,4vw,3.25rem);margin-bottom:1rem}
h3{font-size:1.25rem;margin-bottom:.5rem}
p{color:var(--muted)}
code{padding:.08em .4em;border:1px solid var(--line);border-radius:8px;background:rgba(0,0,0,.18)}
.container{width:min(calc(100% - 40px),var(--container));margin-inline:auto}
.narrow{width:min(calc(100% - 40px),850px)}
.section{padding:110px 0}
.skip-link{position:fixed;top:12px;left:12px;z-index:999;padding:8px 14px;border-radius:999px;background:var(--gold);color:#111;transform:translateY(-150%);text-decoration:none}
.skip-link:focus{transform:translateY(0)}
.site-header{
  position:sticky;top:0;z-index:50;
  backdrop-filter:blur(18px);
  background:rgba(10,13,27,.68);
  border-bottom:1px solid rgba(217,180,107,.14);
}
.header-inner{display:flex;align-items:center;justify-content:space-between;padding:14px 0}
.brand{display:flex;align-items:center;gap:12px;text-decoration:none}
.brand-mark{
  width:42px;height:42px;display:grid;place-items:center;border-radius:50%;
  color:#101426;background:radial-gradient(circle,var(--gold2),var(--gold));
  box-shadow:0 0 34px rgba(217,180,107,.38);
  font-size:1.35rem;
}
.brand-text strong{display:block;font-size:.95rem;letter-spacing:.16em}
.brand-text small{display:block;color:var(--muted);font-size:.75rem}
.global-nav{display:flex;align-items:center;gap:18px;font-size:.9rem}
.global-nav a{text-decoration:none;color:var(--muted)}
.global-nav a:hover{color:var(--ink)}
.nav-cta{padding:8px 16px;border:1px solid var(--line);border-radius:999px;color:var(--ink)!important;background:rgba(217,180,107,.12)}
.menu-button{display:none;background:none;border:0;width:44px;height:44px}
.menu-button span:not(.sr-only){display:block;width:24px;height:2px;margin:5px auto;background:var(--ink)}
.sr-only{position:absolute;width:1px;height:1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap}
.hero{position:relative;min-height:780px;display:grid;align-items:center;padding:92px 0 70px;overflow:hidden}
.hero::before{
  content:"";position:absolute;inset:8% auto auto 50%;width:760px;height:760px;transform:translateX(-50%);
  border:1px solid rgba(217,180,107,.16);border-radius:50%;opacity:.55;
}
.hero-grid{position:relative;display:grid;grid-template-columns:1.05fr .95fr;gap:58px;align-items:center}
.eyebrow{color:var(--gold2);font-size:.78rem;letter-spacing:.22em;text-transform:uppercase;margin-bottom:.8rem}
.lead{font-size:1.12rem;max-width:680px;color:#e1d6bd}
.hero-actions,.apply-actions{display:flex;flex-wrap:wrap;gap:14px;margin:28px 0 12px}
.button{display:inline-flex;align-items:center;justify-content:center;min-height:50px;padding:12px 22px;border-radius:999px;text-decoration:none;border:1px solid var(--line);transition:.2s ease}
.button.primary{background:linear-gradient(135deg,var(--gold2),var(--gold));color:#101426;font-weight:700;box-shadow:0 18px 50px rgba(217,180,107,.26)}
.button.ghost{background:rgba(255,255,255,.06);color:var(--ink)}
.button.wide{width:100%}
.button:hover{transform:translateY(-2px)}
.micro-note{font-size:.86rem;color:rgba(247,240,223,.68)}
.hero-visual{display:grid;place-items:center}
.astro-wheel{
  position:relative;width:min(470px,85vw);aspect-ratio:1;border-radius:50%;
  border:1px solid rgba(217,180,107,.38);
  background:
    conic-gradient(from 0deg,rgba(217,180,107,.18),transparent 10%,rgba(127,158,219,.14) 18%,transparent 30%,rgba(217,180,107,.12) 42%,transparent 54%,rgba(255,255,255,.08) 62%,transparent 78%,rgba(217,180,107,.18)),
    radial-gradient(circle at center,rgba(255,255,255,.14),rgba(255,255,255,.02) 56%,transparent 57%);
  box-shadow:var(--shadow),inset 0 0 90px rgba(217,180,107,.12);
}
.astro-wheel::before,.astro-wheel::after{content:"";position:absolute;inset:8%;border:1px solid rgba(217,180,107,.22);border-radius:50%}
.astro-wheel::after{inset:21%;border-style:dashed;opacity:.7}
.orbit{position:absolute;inset:3%;border:1px solid rgba(255,255,255,.1);border-radius:50%}
.orbit-2{inset:15%;transform:rotate(22deg)}
.orbit-3{inset:30%;transform:rotate(-18deg)}
.planet{
  position:absolute;width:46px;height:46px;display:grid;place-items:center;border-radius:50%;
  background:rgba(10,13,27,.78);border:1px solid var(--line);color:var(--gold2);font-size:1.3rem;box-shadow:0 0 28px rgba(217,180,107,.18)
}
.p-sun{left:50%;top:-22px;transform:translateX(-50%)}
.p-moon{right:18px;top:22%}
.p-venus{right:64px;bottom:7%}
.p-mars{left:42px;bottom:12%}
.p-jupiter{left:0;top:38%}
.p-saturn{left:24%;top:22px}
.yantra-core{position:absolute;inset:28%;display:grid;place-items:center;border-radius:50%;background:rgba(10,13,27,.5);border:1px solid rgba(217,180,107,.26);overflow:hidden}
.yantra-core img{width:100%;height:100%;object-fit:cover;opacity:.94}
.intro-band{background:linear-gradient(90deg,rgba(217,180,107,.1),rgba(127,158,219,.08));border-block:1px solid rgba(217,180,107,.12)}
.two-column{display:grid;grid-template-columns:.85fr 1.15fr;gap:48px;align-items:start}
.two-column.reverse{grid-template-columns:1.05fr .95fr}
.section-heading.center{text-align:center;max-width:880px;margin-inline:auto;margin-bottom:40px}
.text-card,.note-box,.flow-card,.price-card,.apply-card,.teacher-card,.horoscope-card,.planet-card{
  background:var(--paper);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow);backdrop-filter:blur(16px)
}
.text-card{padding:34px}
.note-box{margin-top:24px;padding:20px;background:rgba(217,180,107,.09)}
.note-box strong{display:block;color:var(--gold2);margin-bottom:5px}
.dark-section{background:rgba(0,0,0,.18);border-block:1px solid rgba(217,180,107,.1)}
.planet-grid{display:grid;grid-template-columns:repeat(9,1fr);gap:12px}
.planet-card{padding:18px 12px;text-align:center}
.planet-card span{display:block;font-size:2rem;color:var(--gold2);line-height:1}
.planet-card strong{display:block;margin-top:8px}
.planet-card small{display:block;color:var(--muted);font-size:.78rem;line-height:1.6}
.flow-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.flow-card{padding:28px}
.flow-card span{display:inline-grid;place-items:center;width:46px;height:46px;margin-bottom:16px;border-radius:50%;background:rgba(217,180,107,.16);color:var(--gold2);font-family:var(--serif)}
.soft-section{background:rgba(255,255,255,.03);border-block:1px solid rgba(217,180,107,.1)}
.check-list{list-style:none;padding:0;margin:22px 0 0;color:var(--muted)}
.check-list li{position:relative;padding-left:1.8em;margin:.65em 0}
.check-list li::before{content:"✦";position:absolute;left:0;color:var(--gold2)}
.horoscope-card{padding:34px}
.mini-chart{position:relative;width:280px;max-width:100%;aspect-ratio:1;margin:0 auto 28px;border:1px solid var(--line);border-radius:50%}
.mini-chart::before,.mini-chart::after{content:"";position:absolute;inset:14%;border:1px solid rgba(217,180,107,.16);border-radius:50%}
.mini-chart span{position:absolute;left:50%;top:50%;width:1px;height:100%;background:rgba(217,180,107,.22);transform-origin:top}
.mini-chart span:nth-child(2){transform:rotate(45deg)}
.mini-chart span:nth-child(3){transform:rotate(90deg)}
.mini-chart span:nth-child(4){transform:rotate(135deg)}
.teacher-card{display:grid;grid-template-columns:260px 1fr;gap:34px;padding:34px;align-items:center}
.teacher-photo{border-radius:24px;overflow:hidden;border:1px solid var(--line);background:rgba(255,255,255,.05)}
.price-section{background:radial-gradient(circle at 76% 30%,rgba(217,180,107,.18),transparent 28rem)}
.price-grid{display:grid;grid-template-columns:1fr 420px;gap:40px;align-items:center}
.price-card{padding:34px;text-align:center}
.price-label{color:var(--gold2);margin-bottom:0}
.price{font-family:var(--serif);font-size:4rem;color:var(--ink);line-height:1.1}
.price span{font-size:1.2rem;margin-left:4px}
.regular{text-decoration:line-through;color:rgba(201,189,158,.75)}
.apply-card{padding:38px;text-align:center}
.site-footer{padding:44px 0;border-top:1px solid rgba(217,180,107,.14);background:rgba(0,0,0,.22)}
.footer-inner{display:flex;align-items:center;justify-content:space-between;gap:24px;flex-wrap:wrap}
.footer-inner nav{display:flex;gap:18px;flex-wrap:wrap}
.footer-inner a{text-decoration:none;color:var(--muted)}
.legal-page .legal-hero{padding:120px 0 40px}
.legal-card{padding:34px;background:var(--paper);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow)}
.legal-card table{width:100%;border-collapse:collapse}
.legal-card th,.legal-card td{padding:16px;border-bottom:1px solid var(--line);vertical-align:top;text-align:left}
.legal-card th{width:28%;color:var(--gold2);font-weight:500}
.legal-card h2{font-size:1.7rem;margin-top:2rem}
.legal-card ul{color:var(--muted)}
.reveal{opacity:0;transform:translateY(18px);transition:opacity .7s ease,transform .7s ease}
.reveal.is-visible{opacity:1;transform:translateY(0)}
@media (max-width:1000px){
  .global-nav{position:fixed;inset:72px 18px auto;display:none;flex-direction:column;align-items:stretch;padding:20px;border:1px solid var(--line);border-radius:20px;background:rgba(10,13,27,.96)}
  body.menu-open .global-nav{display:flex}
  .menu-button{display:block}
  .hero-grid,.two-column,.two-column.reverse,.price-grid,.teacher-card{grid-template-columns:1fr}
  .hero{min-height:auto}
  .planet-grid{grid-template-columns:repeat(3,1fr)}
  .flow-grid{grid-template-columns:1fr 1fr}
}
@media (max-width:640px){
  .section{padding:76px 0}
  .flow-grid,.planet-grid{grid-template-columns:1fr}
  .price{font-size:3.2rem}
  .legal-card th,.legal-card td{display:block;width:100%}
}


/* v43 fixed yantra placement */
.intro-grid{
  display:grid;
  grid-template-columns:1.15fr .85fr;
  gap:42px;
  align-items:center;
}
.intro-yantra{
  padding:18px;
  border:1px solid var(--line);
  border-radius:var(--radius);
  background:rgba(255,255,255,.07);
  box-shadow:var(--shadow);
  backdrop-filter:blur(16px);
}
.intro-yantra img{
  width:100%;
  aspect-ratio:1;
  object-fit:cover;
  border-radius:22px;
}
.teacher-photo img{
  width:100%;
  height:100%;
  object-fit:cover;
}
@media (max-width:1000px){
  .intro-grid{grid-template-columns:1fr}
}

.apply-actions:has(.button:only-child){
  justify-content:center;
}


/* v45 content merged from original Hridaya page */
blockquote{
  margin:22px 0 0;
  padding:18px 20px;
  border-left:3px solid var(--gold);
  background:rgba(217,180,107,.08);
  border-radius:0 18px 18px 0;
  color:var(--muted);
}
.practice-grid{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:18px;
}
.practice-message{
  margin-top:24px;
}
.begin-section{
  text-align:center;
  background:radial-gradient(circle at 50% 50%,rgba(217,180,107,.16),transparent 26rem);
}
.contact-section{
  background:rgba(255,255,255,.03);
  border-block:1px solid rgba(217,180,107,.1);
}
.line-qr{
  width:min(240px,100%);
  padding:16px;
  border:1px solid var(--line);
  border-radius:20px;
  background:rgba(255,255,255,.86);
}
.line-qr img{
  width:100%;
  border-radius:12px;
}
.caution-section{
  padding-top:70px;
}
@media (max-width:1000px){
  .practice-grid{grid-template-columns:1fr 1fr}
}
@media (max-width:640px){
  .practice-grid{grid-template-columns:1fr}
}


/* v46: LINE contact restored */
.line-contact-grid{
  display:grid;
  grid-template-columns:220px 1fr;
  gap:24px;
  align-items:center;
  margin-top:20px;
}
.line-qr{
  width:220px;
  max-width:100%;
  padding:14px;
  border:1px solid var(--line);
  border-radius:22px;
  background:rgba(255,255,255,.92);
}
.line-qr img{
  width:100%;
  border-radius:14px;
}
.line-contact-copy p{
  margin-bottom:18px;
}
.line-button{
  min-width:220px;
}
@media (max-width:640px){
  .line-contact-grid{
    grid-template-columns:1fr;
  }
  .line-qr{
    width:200px;
    margin-inline:auto;
  }
  .line-contact-copy{
    text-align:center;
  }
}

/* v47: yantra centering */
.yantra-core img,
.intro-yantra img,
.teacher-photo img{
  object-position:center center;
}


/* v48: varied section decorations */
.intro-yantra{
  overflow:hidden;
  background:
    radial-gradient(circle at 50% 42%, rgba(255,255,255,.98), rgba(248,243,232,.94) 58%, rgba(217,180,107,.12)),
    rgba(255,255,255,.07);
}
.intro-yantra img{
  object-fit:contain;
  padding:0;
  background:transparent;
}
.teacher-photo{
  aspect-ratio:1;
  display:grid;
  place-items:center;
  background:
    radial-gradient(circle at 50% 42%, rgba(255,255,255,.98), rgba(248,243,232,.94) 60%, rgba(217,180,107,.10)),
    rgba(255,255,255,.05);
}
.teacher-photo img{
  object-fit:contain;
  object-position:center center;
  width:100%;
  height:100%;
}
#puja .text-card{
  position:relative;
  overflow:hidden;
}
#puja .text-card::after{
  content:"ॐ";
  position:absolute;
  right:24px;
  bottom:8px;
  font-family:"Noto Serif Devanagari","Kohinoor Devanagari","Mangal",serif;
  font-size:7.2rem;
  line-height:1;
  color:rgba(217,180,107,.10);
  pointer-events:none;
}
#concept .text-card{
  position:relative;
  overflow:hidden;
}
#concept .text-card::after{
  content:"हृदय";
  position:absolute;
  right:24px;
  bottom:12px;
  font-family:"Noto Serif Devanagari","Kohinoor Devanagari","Mangal",serif;
  font-size:4.6rem;
  line-height:1;
  color:rgba(217,180,107,.10);
  pointer-events:none;
}
#mantra .intro-yantra,
#teacher .teacher-photo,
.intro-band .intro-yantra{
  border-color:rgba(217,180,107,.28);
}
@media (max-width:640px){
  #puja .text-card::after{font-size:5.4rem;right:16px;bottom:6px;}
  #concept .text-card::after{font-size:3.6rem;right:16px;bottom:10px;}
}


/* v53: マントラ・ヤントラ見出しだけ少し控えめに調整 */
#mantra h2 {
  font-size: clamp(1.65rem, 3.2vw, 2.4rem);
  line-height: 1.45;
}


/* v54: コラム導線 */
.container.narrow {
  max-width: 860px;
}
.button-row {
  margin-top: 1.8rem;
}
.text-link {
  display: inline-flex;
  align-items: center;
  gap: .4rem;
  font-weight: 600;
  text-decoration: none;
  border-bottom: 1px solid currentColor;
}
.text-link::after {
  content: "→";
}


/* v55: 元のプジャ補足コラム本文を反映 */
.column-hero {
  position: relative;
  overflow: hidden;
  padding-top: 130px;
  padding-bottom: 70px;
  background:
    radial-gradient(circle at 20% 10%, rgba(217,180,107,.22), transparent 34%),
    linear-gradient(135deg, var(--space), var(--space2));
}
.column-hero .section-heading {
  position: relative;
  z-index: 1;
}
.column-hero h1 {
  font-size: clamp(2.3rem, 6vw, 4.4rem);
  line-height: 1.18;
  margin: .4rem 0 1rem;
  color: var(--ink);
}
.column-symbol {
  color: var(--gold2);
  font-size: clamp(2rem, 6vw, 4.8rem);
  line-height: 1;
  letter-spacing: .08em;
  margin: .6rem 0 1rem;
}
.column-article {
  max-width: 920px;
  margin: 0 auto;
}
.article-section {
  margin-top: 3.4rem;
  padding-top: 2.2rem;
  border-top: 1px solid var(--line);
}
.article-number {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 3.2rem;
  height: 3.2rem;
  border: 1px solid var(--line);
  border-radius: 999px;
  color: var(--gold2);
  font-weight: 700;
  letter-spacing: .08em;
  margin-bottom: 1.1rem;
}
.column-article h2 {
  font-size: clamp(1.45rem, 3vw, 2.15rem);
  line-height: 1.45;
  margin: 0 0 1.2rem;
}
.story-block {
  padding: 2rem;
  border: 1px solid var(--line);
  border-radius: 28px;
  background: rgba(217,180,107,.06);
}
.story-block blockquote {
  margin: 1.6rem 0;
}
.end-symbol {
  text-align: center;
  margin: 2.2rem 0;
  opacity: .9;
}
.signature {
  text-align: right;
  font-family: serif;
  font-size: 1.15rem;
  color: var(--gold2);
}
.column-buttons {
  display: flex;
  flex-wrap: wrap;
  gap: 1rem;
  margin-top: 3rem;
}
@media (max-width: 640px) {
  .story-block {
    padding: 1.4rem;
    border-radius: 22px;
  }
  .column-buttons .button {
    width: 100%;
    justify-content: center;
  }
}
