:root {
  --ink: #19322b;
  --deep: #102a23;
  --green: #25483e;
  --green-2: #416458;
  --paper: #f8f5ee;
  --paper-2: #efede4;
  --white: #fffdf8;
  --vermillion: #b75645;
  --pink: #ddc5be;
  --line: rgba(25, 50, 43, .16);
  --serif: "Noto Serif JP", "Yu Mincho", serif;
  --sans: "Noto Sans JP", "Yu Gothic", sans-serif;
  --shadow: 0 24px 80px rgba(13, 40, 31, .12);
}

* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body { margin: 0; color: var(--ink); background: var(--paper); font-family: var(--sans); font-size: 16px; line-height: 1.9; -webkit-font-smoothing: antialiased; }
a { color: inherit; text-decoration: none; }
img { max-width: 100%; display: block; }
button { font: inherit; }
.sr-only { position: absolute; width: 1px; height: 1px; padding: 0; margin: -1px; overflow: hidden; clip: rect(0, 0, 0, 0); white-space: nowrap; border: 0; }
.draft-ribbon { position: fixed; z-index: 1000; top: 20px; right: -37px; width: 148px; padding: 4px 0; transform: rotate(45deg); text-align: center; font-size: 10px; letter-spacing: .22em; color: #fff; background: var(--vermillion); box-shadow: 0 3px 12px rgba(0,0,0,.18); }

.site-header { position: absolute; z-index: 20; inset: 0 0 auto; height: 100px; padding: 0 6vw; display: flex; align-items: center; justify-content: space-between; color: var(--white); border-bottom: 1px solid rgba(255,255,255,.18); }
.site-header.is-scrolled { position: fixed; height: 76px; color: var(--ink); background: rgba(248,245,238,.93); border-color: var(--line); backdrop-filter: blur(12px); box-shadow: 0 4px 24px rgba(15, 36, 29, .08); animation: headerIn .35s ease; }
@keyframes headerIn { from { transform: translateY(-100%); } }
.brand { display: flex; align-items: center; gap: 11px; }
.brand-mark { width: 46px; height: 46px; display: grid; place-items: center; border: 1px solid currentColor; border-radius: 50%; font-family: var(--serif); font-size: 20px; }
.brand b { display: block; font: 500 18px/1.3 var(--serif); letter-spacing: .16em; }
.brand small { display: block; margin-top: 3px; font-size: 8px; line-height: 1; letter-spacing: .28em; opacity: .75; }
.global-nav { display: flex; align-items: center; gap: clamp(18px, 2.6vw, 40px); font-size: 12px; letter-spacing: .06em; }
.global-nav > a:not(.nav-cta) { position: relative; }
.global-nav > a:not(.nav-cta)::after { content: ""; position: absolute; left: 0; right: 100%; bottom: -7px; height: 1px; background: currentColor; transition: right .25s ease; }
.global-nav > a:hover::after { right: 0; }
.nav-cta { padding: 11px 20px; color: #fff; border: 1px solid rgba(255,255,255,.65); border-radius: 999px; transition: .25s; }
.site-header.is-scrolled .nav-cta { color: #fff; background: var(--green); border-color: var(--green); }
.nav-cta:hover { transform: translateY(-2px); }
.menu-button { display: none; }

.hero { position: relative; min-height: 790px; height: 100vh; max-height: 980px; display: grid; align-items: center; color: var(--white); background: var(--deep) url("assets/hero-isejingu.png") center / cover no-repeat; overflow: hidden; }
.hero-shade { position: absolute; inset: 0; background: linear-gradient(90deg, rgba(8,27,22,.75) 0%, rgba(8,27,22,.42) 48%, rgba(8,27,22,.05) 76%), linear-gradient(0deg, rgba(8,27,22,.38), transparent 38%); }
.hero::before { content: ""; position: absolute; inset: 130px auto 8% 5vw; width: 1px; background: linear-gradient(transparent, rgba(255,255,255,.45), transparent); }
.hero-content { position: relative; z-index: 2; width: min(86vw, 1160px); margin: 65px auto 0; }
.eyebrow, .section-kicker { margin: 0 0 23px; color: var(--vermillion); font-size: 11px; font-weight: 600; letter-spacing: .25em; }
.hero .eyebrow { color: #ead8d1; }
.hero h1 { margin: 0; font: 500 clamp(42px, 5vw, 74px)/1.45 var(--serif); letter-spacing: .06em; text-shadow: 0 2px 24px rgba(0,0,0,.18); }
.hero h1 em { color: #f1d4cb; font-style: normal; }
.hero-copy { margin: 28px 0 0; font-family: var(--serif); font-size: clamp(14px, 1.4vw, 18px); line-height: 2.05; letter-spacing: .05em; }
.hero-actions { margin-top: 36px; display: flex; align-items: center; gap: 34px; }
.button { min-height: 56px; padding: 0 28px; display: inline-flex; align-items: center; justify-content: center; gap: 12px; border-radius: 2px; font-size: 13px; font-weight: 500; letter-spacing: .08em; transition: transform .25s ease, box-shadow .25s ease, background .25s ease; }
.button:hover { transform: translateY(-3px); box-shadow: 0 14px 32px rgba(0,0,0,.2); }
.button-line { color: #fff; background: #2e9d63; }
.button-line > span { color: #fff; font-size: 12px; }
.text-link { padding: 10px 0; border-bottom: 1px solid rgba(255,255,255,.42); font-size: 12px; letter-spacing: .08em; }
.text-link span { margin-left: 15px; }
.hero-note { margin: 17px 0 0 5px; font-size: 10px; letter-spacing: .12em; opacity: .72; }
.scroll-guide { position: absolute; z-index: 2; right: 4.5vw; bottom: 0; display: flex; flex-direction: column; align-items: center; gap: 10px; }
.scroll-guide span { writing-mode: vertical-rl; font-size: 8px; letter-spacing: .28em; }
.scroll-guide i { display: block; width: 1px; height: 78px; background: rgba(255,255,255,.6); transform-origin: top; animation: scrollLine 2s infinite; }
@keyframes scrollLine { 0% { transform: scaleY(0); } 45% { transform: scaleY(1); } 100% { transform: scaleY(1); opacity: 0; } }
.hero-petals i { position: absolute; z-index: 2; width: 8px; height: 5px; border-radius: 80% 0 80% 0; background: #f1d6d0; opacity: .6; animation: petal 10s linear infinite; }
.hero-petals i:nth-child(1) { left: 36%; top: 20%; }
.hero-petals i:nth-child(2) { left: 52%; top: 9%; animation-delay: -4s; }
.hero-petals i:nth-child(3) { left: 70%; top: 27%; animation-delay: -7s; }
@keyframes petal { to { transform: translate(80px, 60vh) rotate(420deg); opacity: 0; } }

.section { padding: 130px max(7vw, 30px); }
.section-soft { padding: 130px max(7vw, 30px); background: var(--paper-2); }
.section-deep { padding: 130px max(7vw, 30px); color: var(--white); background: var(--deep); }
.section-title { margin: 0; font: 500 clamp(32px, 4vw, 52px)/1.65 var(--serif); letter-spacing: .06em; }
.intro-grid { width: min(1050px, 100%); margin: 0 auto; display: grid; grid-template-columns: .9fr 1.1fr; gap: 12%; align-items: start; }
.intro > .section-kicker { width: min(1050px, 100%); margin: 0 auto 35px; }
.intro-copy { padding-top: 8px; color: #41554f; font-family: var(--serif); }
.intro-copy p { margin: 0 0 24px; }
.intro-copy .accent-copy { margin-top: 42px; color: var(--vermillion); font-size: 19px; }
.center-heading { text-align: center; }
.center-heading h2 { margin: 0; font: 500 clamp(28px, 3.4vw, 43px)/1.55 var(--serif); letter-spacing: .06em; }
.center-heading.light .section-kicker { color: #cdaea6; }
.worry-list { width: min(1100px, 100%); margin: 70px auto 0; display: grid; grid-template-columns: repeat(3, 1fr); gap: 22px; }
.worry-card { position: relative; min-height: 330px; padding: 36px 34px; background: rgba(255,255,255,.66); border: 1px solid rgba(255,255,255,.85); box-shadow: 0 16px 55px rgba(35,58,50,.06); overflow: hidden; }
.worry-card > span { font: 500 11px var(--serif); color: var(--vermillion); }
.worry-card > i { position: absolute; top: 22px; right: 28px; font: normal 80px/1 var(--serif); color: rgba(183,86,69,.08); }
.worry-card h3 { margin: 52px 0 20px; font: 500 23px/1.7 var(--serif); letter-spacing: .05em; }
.worry-card p { margin: 0; color: #66716e; font-size: 13px; line-height: 1.9; }

.about { position: relative; min-height: 760px; display: grid; grid-template-columns: .95fr 1.05fr; align-items: center; gap: 10%; overflow: hidden; }
.about::before { content: "みちひらき"; position: absolute; right: -1%; bottom: -90px; font: 500 140px var(--serif); letter-spacing: .15em; color: rgba(25,50,43,.035); white-space: nowrap; }
.about-content { max-width: 520px; justify-self: end; }
.about-content > p:not(.section-kicker) { margin: 30px 0 0; color: #51645e; }
.about-sign { margin-top: 42px; padding-top: 22px; border-top: 1px solid var(--line); }
.about-sign span { font: 500 17px var(--serif); letter-spacing: .2em; }
.about-sign small { margin-left: 15px; color: #78847f; font-size: 9px; letter-spacing: .2em; }
.mirror-visual { position: relative; justify-self: start; width: min(410px, 36vw); aspect-ratio: 1; padding: 24px; border-radius: 50%; background: linear-gradient(135deg, #9e8370, #ead8bd 40%, #735d4d 70%, #d8be94); box-shadow: 0 40px 90px rgba(29,55,46,.2), inset 0 0 0 3px rgba(255,255,255,.35); }
.mirror-sky { width: 100%; height: 100%; overflow: hidden; border-radius: 50%; background: radial-gradient(circle at 68% 24%, #fff4d8 0 3%, transparent 4%), linear-gradient(155deg, #b7c9c7 0 42%, #d8e3df 43% 57%, #9fbcad 58% 70%, #5f806d 71%); box-shadow: inset 0 0 42px rgba(13,42,31,.3); }
.mirror-sky::before, .mirror-sky::after { content: ""; position: absolute; width: 45%; height: 38%; border-radius: 50%; border-top: 12px solid #483b34; transform: rotate(-25deg); }
.mirror-sky::before { right: 4%; top: 4%; }
.mirror-sky::after { right: 10%; top: 14%; border-top-width: 5px; }
.mirror-sky span::before, .mirror-sky span::after { content: "✿"; position: absolute; color: #e7c7c1; font-size: 54px; text-shadow: 45px -8px 0 #efd8d2, 75px 24px 0 #e5c1bb, 18px 41px 0 #f1d8d1; }
.mirror-sky span::before { right: 26%; top: 7%; }
.mirror-sky span::after { right: 8%; top: 20%; font-size: 34px; }
.mirror-visual > p { position: absolute; left: -40px; bottom: 25px; margin: 0; padding: 9px 15px; color: var(--white); background: var(--green); font: 400 12px var(--serif); letter-spacing: .14em; }

.change-list { width: min(1080px, 100%); margin: 75px auto 0; display: grid; grid-template-columns: repeat(3, 1fr); }
.change-item { min-height: 350px; padding: 10px 42px 30px; border-left: 1px solid rgba(255,255,255,.18); }
.change-item:last-child { border-right: 1px solid rgba(255,255,255,.18); }
.change-item > b { display: block; margin-bottom: 65px; color: #c6a69d; font: 400 54px var(--serif); opacity: .6; }
.change-item span { color: #c4b5ad; font-size: 9px; letter-spacing: .25em; }
.change-item h3 { margin: 8px 0 20px; font: 500 26px var(--serif); letter-spacing: .1em; }
.change-item p { margin: 0; color: rgba(255,255,255,.65); font-size: 13px; }

.session { display: grid; grid-template-columns: .75fr 1.25fr; gap: 8%; align-items: start; }
.session-heading { padding-top: 25px; }
.session-heading > p:last-child { margin-top: 28px; color: #66736f; font-size: 14px; }
.session-card { position: relative; padding: 50px 55px 55px; background: var(--white); border: 1px solid rgba(35,66,56,.12); box-shadow: var(--shadow); }
.provisional { position: absolute; top: 0; right: 0; margin: 0; padding: 5px 13px; color: #fff; background: var(--vermillion); font-size: 9px; letter-spacing: .15em; }
.session-top { display: flex; align-items: end; justify-content: space-between; gap: 20px; padding-bottom: 30px; border-bottom: 1px solid var(--line); }
.session-top small { color: var(--vermillion); font-size: 10px; letter-spacing: .14em; }
.session-top h3 { margin: 8px 0 0; font: 500 26px var(--serif); letter-spacing: .06em; }
.duration { margin: 0; line-height: 1; white-space: nowrap; }
.duration b { font: 500 42px var(--serif); }
.session-points { margin: 30px 0; padding: 0; list-style: none; }
.session-points li { display: flex; gap: 20px; padding: 14px 0; border-bottom: 1px dotted var(--line); font-size: 13px; }
.session-points span { color: var(--vermillion); font: 500 11px var(--serif); }
.session-meta { margin: 0 0 28px; }
.session-meta > div { display: grid; grid-template-columns: 90px 1fr; align-items: baseline; padding: 7px 0; }
.session-meta dt { color: #78837f; font-size: 11px; }
.session-meta dd { margin: 0; font-size: 14px; }
.session-meta strong { font: 500 24px var(--serif); }
.session-meta small { margin-left: 7px; color: #7a8581; }
.button-dark { width: 100%; color: #fff; background: var(--green); }
.button-dark span { margin-left: auto; }

.profile { display: grid; grid-template-columns: .8fr 1.2fr; gap: 9%; align-items: center; }
.profile-photo { justify-self: end; width: min(410px, 100%); }
.photo-placeholder { position: relative; aspect-ratio: .82; display: flex; flex-direction: column; align-items: center; justify-content: end; padding: 40px; color: #fff; background: linear-gradient(165deg, rgba(29,65,53,.18), rgba(11,40,31,.78)), url("assets/hero-isejingu.png") 68% center / cover; box-shadow: var(--shadow); }
.photo-placeholder::before { content: ""; position: absolute; top: 21%; left: 50%; width: 120px; height: 120px; transform: translateX(-50%); border: 1px solid rgba(255,255,255,.45); border-radius: 50%; }
.photo-placeholder::after { content: ""; position: absolute; top: 49%; left: 50%; width: 180px; height: 105px; transform: translateX(-50%); border: 1px solid rgba(255,255,255,.35); border-radius: 50% 50% 0 0; border-bottom: 0; }
.photo-placeholder span { font: 500 22px var(--serif); letter-spacing: .18em; }
.photo-placeholder small { font-size: 8px; letter-spacing: .26em; opacity: .75; }
.profile-photo > p { margin: 8px 0 0; color: #7b8581; font-size: 9px; text-align: center; }
.profile-copy { max-width: 580px; }
.profile-copy h2 { margin: 0; font: 500 38px var(--serif); letter-spacing: .12em; }
.profile-copy h2 small { font: 400 12px var(--sans); letter-spacing: .08em; }
.profile-role { margin: 4px 0 30px; color: var(--vermillion); font-size: 11px; letter-spacing: .12em; }
.profile-copy > p:not(.section-kicker):not(.profile-role) { color: #566762; }
.profile-copy blockquote { margin: 36px 0; padding: 24px 0 24px 28px; border-left: 2px solid var(--vermillion); color: var(--green); font: 500 19px/1.9 var(--serif); }
.instagram-link { display: inline-block; padding-bottom: 5px; border-bottom: 1px solid var(--ink); font-size: 12px; letter-spacing: .06em; }
.instagram-link span { margin-left: 18px; }

.flow-list { width: min(1050px, 100%); margin: 70px auto 0; padding: 0; display: grid; grid-template-columns: repeat(3, 1fr); list-style: none; }
.flow-list li { position: relative; padding: 0 45px; text-align: center; }
.flow-list li:not(:last-child)::after { content: "→"; position: absolute; top: 80px; right: -10px; color: #a5aca8; font: 300 25px var(--serif); }
.flow-list li > span { color: var(--vermillion); font: 500 11px var(--serif); }
.flow-icon { width: 90px; height: 90px; margin: 18px auto 25px; display: grid; place-items: center; border: 1px solid var(--line); border-radius: 50%; font: 500 14px var(--serif); color: var(--green); }
.flow-list h3 { margin: 0 0 12px; font: 500 19px var(--serif); }
.flow-list p { margin: 0; color: #697570; font-size: 12px; }

.faq { display: grid; grid-template-columns: .65fr 1.35fr; gap: 10%; align-items: start; }
.faq-list { border-top: 1px solid var(--line); }
.faq-list details { border-bottom: 1px solid var(--line); }
.faq-list summary { position: relative; padding: 28px 50px 28px 0; cursor: pointer; list-style: none; font-family: var(--serif); font-size: 15px; }
.faq-list summary::-webkit-details-marker { display: none; }
.faq-list summary span { margin-right: 20px; color: var(--vermillion); font: 500 19px var(--serif); }
.faq-list summary::after { content: "+"; position: absolute; right: 8px; top: 27px; color: var(--green); font: 300 24px/1 var(--sans); transition: transform .2s; }
.faq-list details[open] summary::after { transform: rotate(45deg); }
.faq-list details p { margin: -5px 0 0; padding: 0 45px 28px 43px; color: #68736f; font-size: 13px; }

.contact { position: relative; min-height: 670px; padding: 120px 25px; display: grid; place-items: center; color: var(--white); text-align: center; background: linear-gradient(rgba(12,40,31,.86), rgba(12,40,31,.9)), url("assets/hero-isejingu.png") center 52% / cover fixed; overflow: hidden; }
.contact-ring { position: absolute; width: 510px; height: 510px; border: 1px solid rgba(255,255,255,.16); border-radius: 50%; }
.contact-ring::before, .contact-ring::after { content: ""; position: absolute; inset: 35px; border: 1px solid rgba(255,255,255,.09); border-radius: 50%; }
.contact-ring::after { inset: 70px; }
.contact-content { position: relative; z-index: 2; }
.contact .section-kicker { color: #dfbeb5; }
.contact h2 { margin: 0; font: 500 clamp(37px, 5vw, 58px)/1.6 var(--serif); letter-spacing: .1em; }
.contact p:not(.section-kicker) { margin: 24px 0 32px; color: rgba(255,255,255,.75); font-size: 14px; }
.button-large { min-width: 300px; min-height: 64px; }
.contact-content > small { display: block; margin-top: 14px; color: rgba(255,255,255,.52); font-size: 9px; }
.site-footer { min-height: 190px; padding: 45px 7vw; display: grid; grid-template-columns: 1fr auto 1fr; align-items: center; gap: 30px; color: #c8d0cd; background: #0b201a; }
.footer-brand { color: #edf1ef; }
.footer-info { display: flex; gap: 25px; font-size: 10px; letter-spacing: .05em; }
.footer-info p { margin: 0; }
.copyright { margin: 0; justify-self: end; font-size: 9px; letter-spacing: .16em; }
.mobile-line { display: none; }
.toast { position: fixed; z-index: 1001; left: 50%; bottom: 24px; padding: 12px 20px; transform: translate(-50%, 30px); color: #fff; background: rgba(15,43,34,.95); border-radius: 3px; font-size: 11px; opacity: 0; pointer-events: none; transition: .3s; box-shadow: 0 10px 30px rgba(0,0,0,.2); }
.toast.show { transform: translate(-50%, 0); opacity: 1; }
.reveal { opacity: 0; transform: translateY(24px); transition: opacity .8s ease, transform .8s ease; }
.reveal.visible { opacity: 1; transform: none; }

@media (max-width: 900px) {
  .site-header { height: 78px; padding: 0 22px; }
  .site-header.is-scrolled { height: 68px; }
  .brand-mark { width: 39px; height: 39px; font-size: 17px; }
  .brand b { font-size: 15px; }
  .menu-button { position: relative; z-index: 22; width: 42px; height: 42px; padding: 10px 7px; display: flex; flex-direction: column; justify-content: center; gap: 5px; color: inherit; background: none; border: 0; }
  .menu-button span:not(.sr-only) { width: 27px; height: 1px; background: currentColor; transition: .25s; }
  .menu-button[aria-expanded="true"] span:nth-child(1) { transform: translateY(6px) rotate(45deg); }
  .menu-button[aria-expanded="true"] span:nth-child(2) { opacity: 0; }
  .menu-button[aria-expanded="true"] span:nth-child(3) { transform: translateY(-6px) rotate(-45deg); }
  .global-nav { position: fixed; z-index: 21; inset: 0; padding: 110px 32px 50px; display: flex; flex-direction: column; align-items: stretch; justify-content: center; gap: 0; color: var(--white); background: rgba(13,43,34,.98); visibility: hidden; opacity: 0; transition: .25s; }
  .global-nav.open { visibility: visible; opacity: 1; }
  .global-nav a { padding: 17px 0; border-bottom: 1px solid rgba(255,255,255,.15); font: 400 18px var(--serif); }
  .global-nav .nav-cta { margin-top: 25px; padding: 15px; text-align: center; color: #fff !important; border: 0; background: #2e9d63 !important; }
  .site-header:has(.global-nav.open) { color: #fff; }
  .hero { min-height: 720px; max-height: none; background-position: 64% center; }
  .hero-shade { background: linear-gradient(90deg, rgba(8,27,22,.82), rgba(8,27,22,.28)), linear-gradient(0deg, rgba(8,27,22,.45), transparent 45%); }
  .hero-content { width: calc(100% - 48px); margin-top: 45px; }
  .hero h1 { font-size: clamp(38px, 10vw, 56px); }
  .hero-actions { align-items: flex-start; flex-direction: column; gap: 16px; }
  .hero-note { display: none; }
  .section, .section-soft, .section-deep { padding: 95px 24px; }
  .intro-grid, .about, .session, .profile, .faq { grid-template-columns: 1fr; gap: 55px; }
  .intro-copy { padding: 0; }
  .worry-list { grid-template-columns: 1fr; max-width: 580px; }
  .worry-card { min-height: auto; }
  .about { min-height: auto; }
  .about-content { justify-self: start; }
  .mirror-visual { justify-self: center; width: min(410px, 78vw); }
  .change-list { grid-template-columns: 1fr; max-width: 580px; }
  .change-item { min-height: 0; padding: 35px 20px; display: grid; grid-template-columns: 80px 1fr; border-left: 0; border-top: 1px solid rgba(255,255,255,.18); }
  .change-item:last-child { border-right: 0; border-bottom: 1px solid rgba(255,255,255,.18); }
  .change-item > b { margin: 0; }
  .session-heading { padding: 0; }
  .profile-photo { justify-self: center; }
  .profile-copy { max-width: none; }
  .flow-list { grid-template-columns: 1fr; max-width: 500px; gap: 70px; }
  .flow-list li:not(:last-child)::after { content: "↓"; top: auto; right: 50%; bottom: -48px; }
  .faq { gap: 30px; }
  .site-footer { padding-bottom: 100px; grid-template-columns: 1fr; justify-items: center; text-align: center; }
  .copyright { justify-self: center; }
  .mobile-line { position: fixed; z-index: 19; left: 12px; right: 12px; bottom: 10px; min-height: 54px; padding: 0 20px; display: flex; align-items: center; justify-content: center; gap: 25px; color: #fff; background: #2e9d63; border-radius: 3px; box-shadow: 0 10px 30px rgba(8,42,28,.27); font-size: 13px; font-weight: 500; letter-spacing: .05em; }
  .mobile-line.is-hidden { opacity: 0; pointer-events: none; }
}

@media (max-width: 560px) {
  body { font-size: 14px; }
  .draft-ribbon { top: 175px; right: -43px; }
  .hero { min-height: 750px; background-position: 69% center; }
  .hero::before { display: none; }
  .hero-content { width: calc(100% - 40px); }
  .hero h1 { font-size: 31px; line-height: 1.62; letter-spacing: 0; }
  .hero-copy br { display: none; }
  .button { width: 100%; }
  .text-link { font-size: 11px; }
  .scroll-guide { right: 18px; }
  .section-title { font-size: 31px; }
  .intro-grid { gap: 35px; }
  .intro-copy .accent-copy { font-size: 16px; }
  .worry-list { margin-top: 45px; }
  .worry-card { padding: 30px 28px; }
  .worry-card h3 { margin-top: 30px; }
  .about::before { font-size: 70px; }
  .mirror-visual { width: 82vw; padding: 17px; }
  .mirror-visual > p { left: -6px; bottom: 16px; }
  .change-item { grid-template-columns: 62px 1fr; padding-left: 0; padding-right: 0; }
  .change-item > b { font-size: 44px; }
  .session-card { padding: 42px 24px 30px; }
  .session-top { align-items: flex-start; }
  .session-top h3 { font-size: 21px; }
  .duration b { font-size: 34px; }
  .session-points li { gap: 13px; }
  .profile-copy h2 { font-size: 31px; }
  .profile-copy h2 small { display: block; margin-top: 6px; }
  .profile-copy blockquote { font-size: 16px; }
  .faq-list summary { padding-right: 38px; font-size: 14px; }
  .faq-list summary span { margin-right: 9px; }
  .faq-list details p { padding-left: 0; }
  .contact { min-height: 620px; background-attachment: scroll; }
  .contact-ring { width: 90vw; height: 90vw; }
  .contact h2 { font-size: 35px; }
  .button-large { min-width: 0; }
  .footer-info { flex-direction: column; gap: 0; }
}

@media (prefers-reduced-motion: reduce) {
  html { scroll-behavior: auto; }
  *, *::before, *::after { animation-duration: .01ms !important; animation-iteration-count: 1 !important; transition-duration: .01ms !important; }
  .reveal { opacity: 1; transform: none; }
}
