@charset "UTF-8";
/* ==========================================================================
   神公・社 サイト共通スタイル
   ========================================================================== */

@import url('https://fonts.googleapis.com/css2?family=Shippori+Mincho+B1:wght@400;500;600;700;800&family=Zen+Kaku+Gothic+New:wght@400;500;700;900&family=Zen+Maru+Gothic:wght@400;500;700;900&display=swap');

:root{
  /* --- raw brand palette --- */
  --c-ink:#332850;
  --c-indigo:#473864;
  --c-indigo-2:#534074;
  --c-gold:#c9a227;
  --c-gold-bright:#e8c547;
  --c-shu:#a3402e;
  --c-shu-bright:#c2543e;
  --c-washi:#f6f1e4;
  --c-paper:#fbf8f1;
  --c-sage:#4f7058;
  --c-sage-deep:#3a5340;
  --c-sage-light:#a9c2a0;
  --c-sage-pale:#e8eee2;
  --c-butter:#d9a632;
  --c-inksoft:#33392f;

  /* --- type scale --- */
  --font-display:'Shippori Mincho B1', serif;
  --font-body:'Zen Kaku Gothic New', sans-serif;
  --font-round:'Zen Maru Gothic', sans-serif;

  --space-1:.5rem;
  --space-2:1rem;
  --space-3:1.75rem;
  --space-4:2.75rem;
  --space-5:4.5rem;
  --space-6:7rem;

  --radius-s:4px;
  --radius-m:10px;
  --radius-l:24px;

  --maxw:1120px;
}

/* theme: dark / uranai (占い) ----------------------------------------- */
body.theme-dark{
  --bg:var(--c-ink);
  --bg-deep:#291f47;
  --bg-elev:var(--c-indigo);
  --bg-elev-2:var(--c-indigo-2);
  --text:var(--c-washi);
  --text-muted:#bcb6a3;
  --accent:var(--c-gold);
  --accent-bright:var(--c-gold-bright);
  --cta:var(--c-shu);
  --cta-bright:var(--c-shu-bright);
  --card-bg:var(--c-indigo-2);
  --border:rgba(201,162,39,.28);
  --hairline:rgba(246,241,228,.14);
}

/* theme: light / taiso (体操) ------------------------------------------ */
body.theme-light{
  --bg:var(--c-paper);
  --bg-deep:#f1ece0;
  --bg-elev:#ffffff;
  --bg-elev-2:var(--c-sage-pale);
  --text:var(--c-inksoft);
  --text-muted:#6d7563;
  --accent:var(--c-sage);
  --accent-bright:var(--c-butter);
  --cta:var(--c-sage);
  --cta-bright:var(--c-sage-deep);
  --card-bg:var(--c-sage-pale);
  --border:rgba(79,112,88,.28);
  --hairline:rgba(51,57,47,.14);
}

/* theme: neutral / 会社概要・鑑定士紹介 ---------------------------------- */
body.theme-neutral{
  --bg:var(--c-washi);
  --bg-deep:#ece5d2;
  --bg-elev:#ffffff;
  --bg-elev-2:#efe8d6;
  --text:var(--c-inksoft);
  --text-muted:#736b56;
  --accent:var(--c-gold);
  --accent-bright:var(--c-gold-bright);
  --cta:var(--c-shu);
  --cta-bright:var(--c-shu-bright);
  --card-bg:#ffffff;
  --border:rgba(201,162,39,.35);
  --hairline:rgba(51,57,47,.12);
}

/* theme: sun / 占い鑑定（陽だまり版） -------------------------------------- */
body.theme-sun{
  --bg:#fbf1de;
  --bg-deep:#f0dcb4;
  --bg-elev:#fffbf2;
  --bg-elev-2:#f7e7c4;
  --text:#3b2a18;
  --text-muted:#8a6f4d;
  --accent:#c9772b;
  --accent-bright:#e8821c;
  --cta:#c2541c;
  --cta-bright:#a84314;
  --card-bg:#fbe9c9;
  --border:rgba(194,97,30,.32);
  --hairline:rgba(59,42,24,.14);
}

*,*::before,*::after{ box-sizing:border-box; }
html{ scroll-behavior:smooth; }
@media (prefers-reduced-motion:reduce){
  html{ scroll-behavior:auto; }
  *{ animation-duration:.001ms !important; animation-iteration-count:1 !important; transition-duration:.001ms !important; }
}

body{
  margin:0;
  background:var(--bg);
  color:var(--text);
  font-family:var(--font-body);
  font-size:16px;
  line-height:1.9;
  letter-spacing:.02em;
  -webkit-font-smoothing:antialiased;
  transition:background .4s ease;
}

img{ max-width:100%; display:block; }
a{ color:inherit; text-decoration:none; }
ul{ margin:0; padding:0; list-style:none; }
h1,h2,h3,h4{ margin:0; font-family:var(--font-display); font-weight:700; letter-spacing:.04em; }
p{ margin:0; }
button{ font-family:inherit; }

.wrap{
  max-width:var(--maxw);
  margin:0 auto;
  padding:0 var(--space-3);
}

/* --- eyebrow / section heading --------------------------------------- */
.eyebrow{
  display:inline-flex;
  align-items:center;
  gap:.6em;
  font-family:var(--font-body);
  font-size:.78rem;
  letter-spacing:.32em;
  color:var(--accent);
  font-weight:700;
  margin-bottom:var(--space-2);
}
.eyebrow::before{
  content:"";
  width:18px; height:18px;
  background:url('../images/mark-gold.svg') center/contain no-repeat;
  display:inline-block;
}
body.theme-light .eyebrow::before{ background-image:url('../images/mark-sage.svg'); }
.section-title{
  font-size:clamp(1.6rem,3.4vw,2.5rem);
  line-height:1.5;
  margin-bottom:var(--space-2);
}
.section-lead{
  color:var(--text-muted);
  max-width:46em;
  font-size:.98rem;
}
section{ padding:var(--space-6) 0; }
.section-head{ margin-bottom:var(--space-4); }
.section-head.center{ text-align:center; }
.section-head.center .section-lead{ margin-inline:auto; }

hr.divider{
  border:none;
  height:1px;
  background:var(--hairline);
  margin:0;
}

/* --- header ------------------------------------------------------------ */
.site-header{
  position:sticky; top:0; z-index:100;
  background:color-mix(in srgb, var(--bg) 88%, transparent);
  backdrop-filter:blur(10px);
  border-bottom:1px solid var(--hairline);
}
.site-header .wrap{
  display:flex; align-items:center; justify-content:space-between;
  padding-top:.9rem; padding-bottom:.9rem;
  max-width:1280px;
}
.brand{ display:flex; align-items:center; gap:.7rem; }
.brand img{ width:34px; height:34px; }
.brand .brand-text{ display:flex; flex-direction:column; line-height:1.25; }
.brand .brand-text .ja{ font-family:var(--font-display); font-weight:700; font-size:1.05rem; letter-spacing:.08em; }
.brand .brand-text .en{ font-size:.6rem; letter-spacing:.22em; color:var(--text-muted); }

.nav-toggle{
  display:none;
  width:42px; height:42px;
  border:1px solid var(--border);
  border-radius:50%;
  background:transparent;
  position:relative;
  cursor:pointer;
}
.nav-toggle span,.nav-toggle span::before,.nav-toggle span::after{
  content:""; position:absolute; left:11px; width:20px; height:2px; background:var(--text);
  transition:transform .3s ease, opacity .3s ease;
}
.nav-toggle span{ top:20px; }
.nav-toggle span::before{ top:-6px; }
.nav-toggle span::after{ top:6px; }
.nav-toggle.open span{ background:transparent; }
.nav-toggle.open span::before{ transform:translateY(6px) rotate(45deg); }
.nav-toggle.open span::after{ transform:translateY(-6px) rotate(-45deg); }

.main-nav ul{ display:flex; align-items:center; gap:1.9rem; }
.main-nav a{
  font-size:.86rem; letter-spacing:.06em; white-space:nowrap;
  padding:.3rem 0; border-bottom:1px solid transparent;
  transition:color .25s ease, border-color .25s ease;
}
.main-nav a:hover, .main-nav a.is-active{ color:var(--accent-bright); border-color:var(--accent-bright); }
.main-nav .nav-cta{
  background:var(--cta); color:#fff; padding:.6rem 1.2rem; border-radius:999px;
  font-weight:700; border:1px solid transparent;
}
.main-nav .nav-cta:hover{ background:var(--cta-bright); border-color:var(--cta-bright); color:#fff; }

@media (max-width:880px){
  .nav-toggle{ display:block; }
  .main-nav{
    position:fixed; inset:64px 0 0 0; background:var(--bg);
    transform:translateY(-12px); opacity:0; pointer-events:none;
    transition:opacity .3s ease, transform .3s ease;
    overflow-y:auto; padding:var(--space-4) 0;
    z-index:99;
  }
  .main-nav.open{ opacity:1; transform:translateY(0); pointer-events:auto; }
  .main-nav ul{ flex-direction:column; align-items:flex-start; gap:0; padding:0 var(--space-3); }
  .main-nav li{ width:100%; border-bottom:1px solid var(--hairline); }
  .main-nav a{ display:block; padding:1.1rem 0; font-size:1rem; }
  .main-nav .nav-cta{ display:inline-block; margin-top:1.4rem; }
}

/* --- buttons ------------------------------------------------------------ */
.btn{
  display:inline-flex; align-items:center; gap:.6em;
  padding:.95rem 2rem; border-radius:999px;
  font-size:.92rem; font-weight:700; letter-spacing:.08em;
  border:1px solid currentColor; cursor:pointer; transition:all .25s ease;
}
.btn-solid{ background:var(--cta); color:#fff; border-color:var(--cta); }
.btn-solid:hover{ background:var(--cta-bright); border-color:var(--cta-bright); transform:translateY(-2px); }
.btn-outline{ background:transparent; color:var(--text); border-color:var(--border); }
.btn-outline:hover{ border-color:var(--accent-bright); color:var(--accent-bright); transform:translateY(-2px); }
.btn-arrow{ transition:transform .25s ease; }
.btn:hover .btn-arrow{ transform:translateX(4px); }

/* --- mark / compass ------------------------------------------------------ */
.mark{
  width:1em; height:1em; display:inline-block;
  background:url('../images/mark-gold.svg') center/contain no-repeat;
}
body.theme-light .mark{ background-image:url('../images/mark-sage.svg'); }
.mark-spin{ animation:spin 60s linear infinite; }
@keyframes spin{ to{ transform:rotate(360deg); } }

/* --- footer --------------------------------------------------------------- */
.site-footer{
  background:var(--bg-deep);
  border-top:1px solid var(--hairline);
  padding:var(--space-5) 0 var(--space-3);
}
.footer-grid{
  display:grid; grid-template-columns:1.3fr 1fr 1fr; gap:var(--space-4);
  margin-bottom:var(--space-4);
}
.footer-brand{ display:flex; gap:.8rem; align-items:flex-start; }
.footer-brand img{ width:38px; height:38px; margin-top:.2rem; }
.footer-brand .ja{ font-family:var(--font-display); font-size:1.1rem; letter-spacing:.08em; }
.footer-brand p{ color:var(--text-muted); font-size:.82rem; margin-top:.5rem; line-height:1.8; }
.footer-col h5{ font-family:var(--font-body); font-size:.78rem; letter-spacing:.18em; color:var(--accent); margin-bottom:1rem; }
.footer-col a, .footer-col p{ display:block; font-size:.86rem; color:var(--text-muted); margin-bottom:.6rem; }
.footer-col a:hover{ color:var(--accent-bright); }
.footer-sns{ display:flex; gap:.8rem; margin-top:.4rem; }
.footer-sns a{
  width:36px; height:36px; border-radius:50%; border:1px solid var(--border);
  display:flex; align-items:center; justify-content:center; font-size:.95rem;
  margin-bottom:0;
}
.footer-sns a:hover{ background:var(--accent); color:#241c38; border-color:var(--accent); }
.footer-bottom{
  display:flex; justify-content:space-between; align-items:center; flex-wrap:wrap; gap:.6rem;
  padding-top:var(--space-3); border-top:1px solid var(--hairline);
  font-size:.74rem; color:var(--text-muted); letter-spacing:.05em;
}
@media (max-width:760px){
  .footer-grid{ grid-template-columns:1fr; gap:var(--space-3); }
}

/* --- cards / generic ------------------------------------------------------ */
.card{
  background:var(--card-bg); border:1px solid var(--border);
  border-radius:var(--radius-l); padding:var(--space-3);
}

/* ==========================================================================
   ページ固有コンポーネント
   ========================================================================== */

/* --- home hero ------------------------------------------------------------ */
.home-hero{
  position:relative;
  min-height:92vh;
  display:flex; flex-direction:column; align-items:center; justify-content:center;
  text-align:center;
  overflow:hidden;
  background:
    radial-gradient(ellipse at 50% 18%, rgba(220,245,255,.55), transparent 55%),
    linear-gradient(180deg, #3a6a96 0%, #4480b8 40%, #5298d0 70%, #6ab4e8 100%);
  padding:var(--space-5) var(--space-3);
}
.home-hero::before{
  content:"";
  position:absolute; inset:0;
  background-image:radial-gradient(rgba(246,241,228,.5) 1px, transparent 1px);
  background-size:46px 46px;
  opacity:.06;
  pointer-events:none;
}
.home-hero .hero-mark{
  width:120px; height:120px;
  background:url('../images/mark-gold.svg') center/contain no-repeat;
  margin-bottom:var(--space-3);
  animation:spin 70s linear infinite;
}
.home-hero .hero-eyebrow{
  font-size:.78rem; letter-spacing:.4em; color:var(--c-gold); margin-bottom:1.2rem;
}
.home-hero h1{
  font-size:clamp(2.1rem,5.4vw,3.7rem);
  color:#e8f4ff; line-height:1.55; margin-bottom:1.3rem;
}
.home-hero h1 em{ font-style:normal; color:var(--c-gold-bright); }
.home-hero .hero-sub{
  color:#a8c8e8; max-width:34em; margin:0 auto var(--space-4); font-size:1rem; line-height:2;
}
.scroll-cue{
  position:absolute; bottom:2.2rem; left:50%; transform:translateX(-50%);
  font-size:.7rem; letter-spacing:.3em; color:#7d7a6b; display:flex; flex-direction:column; align-items:center; gap:.5rem;
}
.scroll-cue::after{ content:""; width:1px; height:34px; background:linear-gradient(var(--c-gold), transparent); animation:scrollcue 2.2s ease-in-out infinite; }
@keyframes scrollcue{ 0%{opacity:0;transform:scaleY(.3);transform-origin:top;} 50%{opacity:1;transform:scaleY(1);transform-origin:top;} 100%{opacity:0;transform:scaleY(.3);transform-origin:bottom;} }

/* --- two doors ------------------------------------------------------------ */
.doors{ background:var(--c-ink); padding:0 0 var(--space-6); }
.doors-grid{ display:grid; grid-template-columns:1fr 1fr; gap:1px; background:var(--hairline); border:1px solid var(--hairline); border-radius:var(--radius-l); overflow:hidden; }
.door{
  position:relative; padding:var(--space-5) var(--space-4); min-height:420px;
  display:flex; flex-direction:column; justify-content:flex-end;
  transition:padding .35s ease;
}
.door .door-eyebrow{ font-size:.72rem; letter-spacing:.32em; margin-bottom:.8rem; }
.door h2{ font-size:clamp(1.5rem,2.6vw,2.05rem); line-height:1.6; margin-bottom:.9rem; }
.door p{ font-size:.92rem; line-height:1.95; margin-bottom:1.8rem; }
.door .door-mark{ position:absolute; top:var(--space-4); right:var(--space-4); width:46px; height:46px; opacity:.85; }
.door-uranai{ background:linear-gradient(160deg,#fbe9c9,#f3d9a6); color:#3b2a18; }
.door-uranai .door-eyebrow{ color:#a8631f; }
.door-uranai p{ color:#7a5f3e; }
.door-uranai .door-mark{ background:url('../images/mark-gold.svg') center/contain no-repeat; }
.door-taiso{ background:linear-gradient(160deg,#fbf8f1,#eef2e9); color:var(--c-inksoft); }
.door-taiso .door-eyebrow{ color:var(--c-sage); }
.door-taiso p{ color:#5c6354; }
.door-taiso .door-mark{ background:url('../images/mark-sage.svg') center/contain no-repeat; }
.door .btn{ align-self:flex-start; }
.door-uranai .btn{ color:#3b2a18; border-color:rgba(59,42,24,.35); }
.door-uranai .btn:hover{ color:#a84314; border-color:#a84314; }
.door-taiso .btn{ color:var(--c-inksoft); border-color:rgba(51,57,47,.35); }
.door-taiso .btn:hover{ color:var(--c-sage-deep); border-color:var(--c-sage-deep); }
.door:hover{ padding-left:calc(var(--space-4) + 8px); }
@media (max-width:760px){
  .doors-grid{ grid-template-columns:1fr; }
  .door{ min-height:320px; padding:var(--space-4); }
}

/* --- intro strip (home) ---------------------------------------------------- */
.intro-strip{ background:var(--c-washi); color:var(--c-inksoft); padding:var(--space-5) 0; text-align:center; }
.intro-strip .wrap{ max-width:760px; }
.intro-strip .eyebrow::before{ background-image:url('../images/mark-gold.svg'); }
.intro-strip p{ font-size:1rem; line-height:2.1; color:#564f3c; }

/* --- notices ---------------------------------------------------------------- */
.notice-grid{ display:grid; grid-template-columns:repeat(2,1fr); gap:var(--space-3); }
.notice-card{ background:var(--card-bg); border:1px solid var(--border); border-radius:var(--radius-m); padding:var(--space-3); }
.notice-card .tag{ display:inline-block; font-size:.7rem; letter-spacing:.12em; color:var(--accent); border:1px solid var(--border); border-radius:999px; padding:.25em .9em; margin-bottom:1rem; }
.notice-card h3{ font-size:1.05rem; margin-bottom:.8rem; line-height:1.6; }
.notice-card p{ font-size:.88rem; color:var(--text-muted); line-height:1.95; }
@media (max-width:700px){ .notice-grid{ grid-template-columns:1fr; } }

/* --- philosophy (omoi) ------------------------------------------------------ */
.omoi{ position:relative; padding-left:var(--space-4); border-left:1px solid var(--border); }
.omoi p{ font-size:1.02rem; line-height:2.3; color:var(--text); margin-bottom:1.5rem; }
.omoi p.emph{ font-family:var(--font-display); font-size:1.3rem; color:var(--accent-bright); line-height:1.9; margin:2.2rem 0; }
@media (max-width:700px){ .omoi{ padding-left:var(--space-2); } }

/* --- kanji grid --------------------------------------------------------------- */
.kanji-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:var(--space-3); }
.kanji-card{ background:var(--card-bg); border:1px solid var(--border); border-radius:var(--radius-l); padding:var(--space-4) var(--space-3); text-align:center; }
.kanji-card .glyph{ font-family:var(--font-display); font-size:4.2rem; color:var(--accent-bright); line-height:1; margin-bottom:1rem; }
.kanji-card h4{ font-size:.95rem; letter-spacing:.1em; margin-bottom:1rem; color:var(--text); }
.kanji-card p{ font-size:.84rem; line-height:1.95; color:var(--text-muted); text-align:left; }
@media (max-width:820px){ .kanji-grid{ grid-template-columns:1fr; } }

/* --- owner --------------------------------------------------------------------- */
.owner-block{ display:grid; grid-template-columns:260px 1fr; gap:var(--space-4); align-items:center; }
.owner-photo{
  width:100%; aspect-ratio:1; border-radius:50%; overflow:hidden;
  border:1px solid var(--border); background:var(--card-bg);
  display:flex; align-items:center; justify-content:center;
}
.owner-photo img{ width:100%; height:100%; object-fit:cover; }
.owner-photo .ph-fallback{ font-family:var(--font-display); font-size:.78rem; letter-spacing:.18em; color:var(--text-muted); text-align:center; padding:1.5rem; }
.owner-copy .role{ font-size:.78rem; letter-spacing:.2em; color:var(--accent); margin-bottom:.6rem; display:block; }
.owner-copy h3{ font-size:1.5rem; margin-bottom:1.2rem; }
.owner-copy p{ font-size:.95rem; line-height:2.1; color:var(--text-muted); margin-bottom:1rem; }
.owner-copy p.signature{ color:var(--accent-bright); font-family:var(--font-display); font-size:1.1rem; }
@media (max-width:700px){ .owner-block{ grid-template-columns:1fr; } .owner-photo{ width:180px; margin:0 auto; } }

/* --- access -------------------------------------------------------------------- */
.access-grid{ display:grid; grid-template-columns:1fr 1fr; gap:var(--space-4); align-items:start; }
.access-card dl{ display:grid; grid-template-columns:max-content 1fr; gap:.8rem 1.4rem; font-size:.92rem; }
.access-card dt{ color:var(--accent); letter-spacing:.08em; font-size:.78rem; padding-top:.15rem; }
.access-card dd{ margin:0; line-height:1.9; }
.access-note{ font-size:.82rem; color:var(--text-muted); margin-top:1.2rem; line-height:1.9; }
.access-compass{
  aspect-ratio:1; max-width:260px; margin:0 auto; border-radius:50%;
  border:1px solid var(--border); display:flex; align-items:center; justify-content:center; position:relative;
}
.access-compass .mark{ width:64px; height:64px; }
.access-compass::before{ content:"N"; position:absolute; top:14px; font-size:.72rem; letter-spacing:.1em; color:var(--text-muted); }
@media (max-width:760px){ .access-grid{ grid-template-columns:1fr; } }

/* --- staff preview (uranai page) ------------------------------------------------ */
.staff-preview-row{ display:flex; gap:1.1rem; flex-wrap:wrap; margin-bottom:var(--space-3); }
.avatar-chip{
  width:64px; height:64px; border-radius:50%; border:1px solid var(--border);
  background:var(--card-bg); display:flex; align-items:center; justify-content:center;
  font-family:var(--font-display); font-size:.85rem; color:var(--text-muted); overflow:hidden;
}
.avatar-chip img{ width:100%; height:100%; object-fit:cover; }

/* --- schedule table -------------------------------------------------------------- */
.schedule-wrap{ overflow-x:auto; border:1px solid var(--border); border-radius:var(--radius-m); }
table.schedule{ border-collapse:collapse; width:100%; min-width:620px; font-size:.86rem; }
table.schedule th, table.schedule td{ border:1px solid var(--hairline); padding:.85rem .7rem; text-align:center; vertical-align:top; }
table.schedule thead th{ background:var(--bg-elev-2); color:var(--accent); font-weight:700; letter-spacing:.06em; font-size:.8rem; }
table.schedule td .name{ display:block; font-size:.84rem; margin-top:.2rem; }
table.schedule td .name.tbd{ color:var(--text-muted); }
.schedule-note{ font-size:.82rem; color:var(--text-muted); margin-top:1rem; line-height:1.9; }

/* --- reserve --------------------------------------------------------------------- */
.reserve-grid{ display:grid; grid-template-columns:1fr 1fr; gap:var(--space-3); }
.reserve-card{ background:var(--card-bg); border:1px solid var(--border); border-radius:var(--radius-l); padding:var(--space-4); }
.reserve-card .ic{ width:42px; height:42px; margin-bottom:1.2rem; }
.reserve-card h3{ font-size:1.15rem; margin-bottom:1rem; }
.reserve-card ul{ font-size:.86rem; color:var(--text-muted); line-height:2.1; margin-bottom:1.4rem; }
.reserve-card li::before{ content:"・"; color:var(--accent); }
.reserve-card .btn{ width:100%; justify-content:center; }
.pay-list{ display:flex; flex-wrap:wrap; gap:.7rem; margin-top:1.4rem; }
.pay-list span{ font-size:.78rem; border:1px solid var(--border); border-radius:999px; padding:.4em 1em; color:var(--text-muted); }
@media (max-width:700px){ .reserve-grid{ grid-template-columns:1fr; } }

/* --- horoscope ------------------------------------------------------------------- */
.horo-card{ display:flex; gap:var(--space-3); align-items:center; background:var(--card-bg); border:1px solid var(--border); border-radius:var(--radius-l); padding:var(--space-3); }
.horo-card .horo-mark{ width:64px; height:64px; flex:none; }
.horo-card h3{ font-size:1.1rem; margin-bottom:.5rem; }
.horo-card p{ font-size:.86rem; color:var(--text-muted); }
@media (max-width:600px){ .horo-card{ flex-direction:column; align-items:flex-start; } }

/* --- testimonial ------------------------------------------------------------------ */
.testimonial{ background:var(--card-bg); border:1px solid var(--border); border-radius:var(--radius-l); padding:var(--space-4); position:relative; }
.testimonial .quote-mark{ font-family:var(--font-display); font-size:3.4rem; color:var(--accent); line-height:1; opacity:.5; margin-bottom:.6rem; }
.testimonial p.body-text{ font-size:.96rem; line-height:2.05; margin-bottom:1.6rem; }
.testimonial .meta{ display:flex; justify-content:space-between; flex-wrap:wrap; gap:.6rem; font-size:.78rem; color:var(--text-muted); border-top:1px solid var(--hairline); padding-top:1.1rem; }

/* --- sns ------------------------------------------------------------------------- */
.sns-row{ display:flex; gap:1rem; }
.sns-row a{ width:46px; height:46px; border-radius:50%; border:1px solid var(--border); display:flex; align-items:center; justify-content:center; font-size:1.05rem; transition:all .25s ease; }
.sns-row a:hover{ background:var(--accent); color:#241c38; border-color:var(--accent); }

/* --- kanteishi page --------------------------------------------------------------- */
.staff-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:var(--space-3); }
.staff-card{ background:var(--card-bg); border:1px solid var(--border); border-radius:var(--radius-l); padding:var(--space-3); }
.staff-card .photo{ width:96px; height:96px; border-radius:50%; overflow:hidden; border:1px solid var(--border); background:var(--bg-elev-2); display:flex; align-items:center; justify-content:center; margin-bottom:1.2rem; }
.staff-card .photo img{ width:100%; height:100%; object-fit:cover; }
.staff-card .photo .mark{ width:34px; height:34px; opacity:.6; }
.staff-card h3{ font-size:1.1rem; margin-bottom:.7rem; }
.staff-card .tags{ display:flex; flex-wrap:wrap; gap:.4rem; margin-bottom:1rem; }
.staff-card .tags span{ font-size:.7rem; border:1px solid var(--border); border-radius:999px; padding:.25em .8em; color:var(--text-muted); }
.staff-card p.bio{ font-size:.85rem; line-height:1.95; color:var(--text-muted); white-space:pre-line; }
.staff-card.placeholder p.bio{ font-style:normal; }
@media (max-width:920px){ .staff-grid{ grid-template-columns:repeat(2,1fr); } }
@media (max-width:600px){ .staff-grid{ grid-template-columns:1fr; } }

/* --- taiso: service steps ------------------------------------------------------- */
.service-steps{ display:flex; flex-direction:column; gap:0; }
.step{ display:grid; grid-template-columns:96px 1fr; gap:var(--space-3); padding:var(--space-4) 0; border-bottom:1px solid var(--hairline); }
.step:last-child{ border-bottom:none; }
.step-num{ font-family:var(--font-round); font-size:2.3rem; font-weight:900; color:var(--accent); opacity:.85; line-height:1; }
.step-num small{ display:block; font-family:var(--font-body); font-size:.66rem; font-weight:700; letter-spacing:.18em; color:var(--text-muted); margin-top:.5rem; }
.step h3{ font-size:1.2rem; margin-bottom:.5rem; }
.step .step-tag{ font-family:var(--font-round); font-size:.72rem; font-weight:700; letter-spacing:.1em; color:var(--accent); background:var(--bg-elev-2); display:inline-block; padding:.3em 1em; border-radius:999px; margin-bottom:.9rem; }
.step p{ font-size:.92rem; line-height:2.05; color:var(--text-muted); }
.step ul.points{ margin-top:1rem; display:flex; flex-wrap:wrap; gap:.6rem; }
.step ul.points li{ font-size:.78rem; background:var(--bg-elev-2); border-radius:999px; padding:.4em 1.1em; color:var(--text); }
@media (max-width:620px){ .step{ grid-template-columns:1fr; gap:.8rem; } }

/* --- taiso: stamp / achievement badge -------------------------------------------- */
.stamp{
  display:inline-flex; align-items:center; gap:.6rem;
  background:var(--c-butter); color:#fff; font-family:var(--font-round); font-weight:900;
  border-radius:999px; padding:.5em 1.3em .5em 1em; font-size:.85rem; letter-spacing:.04em;
}
.stamp .mark{ width:20px; height:20px; background:url('../images/mark-sage.svg') center/contain no-repeat; filter:brightness(0) invert(1); }

/* --- taiso: instructor ------------------------------------------------------------ */
.instructor{ display:grid; grid-template-columns:240px 1fr; gap:var(--space-4); align-items:center; }
.instructor-photo{ width:100%; aspect-ratio:1; border-radius:var(--radius-l); overflow:hidden; border:1px solid var(--border); background:var(--card-bg); display:flex; align-items:center; justify-content:center; }
.instructor-photo img{ width:100%; height:100%; object-fit:cover; }
.instructor-copy h3{ font-size:1.4rem; margin-bottom:.4rem; }
.instructor-copy .role{ font-size:.82rem; color:var(--accent); letter-spacing:.08em; display:block; margin-bottom:1.2rem; }
.instructor-copy p{ font-size:.93rem; line-height:2.1; color:var(--text-muted); }
@media (max-width:700px){ .instructor{ grid-template-columns:1fr; } .instructor-photo{ max-width:220px; margin:0 auto; } }

/* --- taiso: cta banner ------------------------------------------------------------- */
.cta-banner{
  background:linear-gradient(135deg,var(--c-sage),var(--c-sage-deep));
  border-radius:var(--radius-l); padding:var(--space-5) var(--space-4); color:#fff; text-align:center;
}
.cta-banner .mark{ width:54px; height:54px; margin:0 auto 1.2rem; background:url('../images/mark-sage.svg') center/contain no-repeat; filter:brightness(0) invert(1); opacity:.9; }
.cta-banner h3{ font-size:1.5rem; margin-bottom:.9rem; }
.cta-banner p{ font-size:.92rem; opacity:.92; max-width:34em; margin:0 auto 1.8rem; line-height:2; }
.cta-banner .btn-solid{ background:#fff; color:var(--c-sage-deep); border-color:#fff; }
.cta-banner .btn-solid:hover{ background:var(--c-butter); color:#fff; border-color:var(--c-butter); }

/* --- audience note box -------------------------------------------------------------- */
.note-box{ background:var(--bg-elev-2); border-radius:var(--radius-m); padding:var(--space-3); font-size:.86rem; line-height:2; color:var(--text-muted); border-left:3px solid var(--accent); }

/* --- company overview table ----------------------------------------------------------- */
.overview-table{ width:100%; border-collapse:collapse; }
.overview-table tr{ border-bottom:1px solid var(--hairline); }
.overview-table tr:last-child{ border-bottom:none; }
.overview-table th, .overview-table td{ text-align:left; padding:1.3rem .6rem; vertical-align:top; font-weight:400; }
.overview-table th{ width:9em; color:var(--accent); font-size:.84rem; letter-spacing:.1em; }
.overview-table td{ font-size:.94rem; line-height:1.95; }
.overview-table td ul li{ position:relative; padding-left:1.2em; margin-bottom:.3em; }
.overview-table td ul li::before{ content:"・"; position:absolute; left:0; color:var(--accent); }
@media (max-width:620px){
  .overview-table th, .overview-table td{ display:block; width:auto; padding:.3rem .6rem; }
  .overview-table th{ padding-top:1.2rem; }
}

/* --- business list (会社概要内 事業内容カード) ----------------------------------------- */
.biz-grid{ display:grid; grid-template-columns:1fr 1fr; gap:var(--space-3); }
.biz-card{ border-radius:var(--radius-l); padding:var(--space-4); border:1px solid var(--border); }
.biz-card.biz-uranai{ background:linear-gradient(160deg,#fbe9c9,#f3d9a6); color:#3b2a18; }
.biz-card.biz-uranai p{ color:#7a5f3e; }
.biz-card.biz-taiso{ background:linear-gradient(160deg,#fbf8f1,#eef2e9); color:var(--c-inksoft); }
.biz-card.biz-taiso p{ color:#5c6354; }
.biz-card h3{ font-size:1.15rem; margin-bottom:.9rem; }
.biz-card p{ font-size:.88rem; line-height:2; margin-bottom:1.4rem; }
.biz-uranai .btn{ color:#3b2a18; border-color:rgba(59,42,24,.35); }
.biz-uranai .btn:hover{ color:#a84314; border-color:#a84314; }
.biz-taiso .btn{ color:var(--c-inksoft); border-color:rgba(51,57,47,.35); }
.biz-taiso .btn:hover{ color:var(--c-sage-deep); border-color:var(--c-sage-deep); }
@media (max-width:700px){ .biz-grid{ grid-template-columns:1fr; } }

/* --- utility --------------------------------------------------------------- */
.muted{ color:var(--text-muted); }
.center{ text-align:center; }
.reveal{ opacity:0; transform:translateY(22px); transition:opacity .7s ease, transform .7s ease; }
.reveal.is-visible{ opacity:1; transform:translateY(0); }
