/*
Theme Name: ブレスシフトのテーマ
*/

/*----------------------------------------
reset
----------------------------------------*/

html, body, div, p, span, applet, object, iframe,
h1, h2, h3, h4, h5, h6,
blockquote, pre,
a, abbr, acronym, address, big, cite, code,
del, dfn, em, img, ins, kbd, q, s, samp,
small, strike, strong, sub, sup, tt, var,
b, u, i, center,
dl, dt, dd, ol, ul, li,
fieldset, form, label, legend,
table, caption, tbody, tfoot, thead, tr, th, td,
article, aside, canvas, details, embed,
figure, figcaption, footer, header, hgroup,
menu, nav, output, ruby, section, summary,
time, mark, audio, video {
	margin: 0;
	padding: 0;
	border: 0;
	font-size: 100%;
	font: inherit;
	vertical-align: baseline;
}

/* HTML5 display-role reset for older browsers */
article, aside, details, figcaption, figure,
footer, header, hgroup, menu, nav, section {
	display: block;
}

ol, ul {
	list-style: none;
}

blockquote, q {
	quotes: none;
}

blockquote:before, blockquote:after,
q:before, q:after {
	content: '';
	content: none;
}

table {
	border-collapse: collapse;
	border-spacing: 0;
}

@font-face {
    font-family: 'Noto Serif JP';
    font-style: normal;
    font-weight: 200;
    font-display: swap;
    src: url(https://fonts.gstatic.com/s/notoserifjp/v33/xn7mYHs72GKoTvER4Gn3b5eMXNvMckQlPa61uNKcCqOfbtLXoH3502Rk.0.woff2) format('woff2');
    unicode-range: U +25ee8, U +25f23, U +25f5c, U +25fd4, U +25fe0, U +25ffb, U +2600c, U +26017, U +26060, U +260ed, U +26222, U +2626a, U +26270, U +26286, U +2634c, U +26402, U +2667e, U +266b0, U +2671d, U +268dd, U +268ea, U +26951, U +2696f, U +26999, U +269dd, U +26a1e, U +26a58, U +26a8c, U +26ab7, U +26aff, U +26c29, U +26c73, U +26c9e, U +26cdd, U +26e40, U +26e65, U +26f94, U +26ff6 -26ff8, U +270f4, U +2710d, U +27139, U +273da -273db, U +273fe, U +27410, U +27449, U +27614 -27615, U +27631, U +27684, U +27693, U +2770e, U +27723, U +27752, U +278b2, U +27985, U +279b4, U +27a84, U +27bb3, U +27bbe, U +27bc7, U +27c3c, U +27cb8, U +27d73, U +27da0, U +27e10, U +27eaf, U +27fb7, U +2808a, U +280bb, U +28277, U +28282, U +282f3, U +283cd, U +2840c, U +28455, U +284dc, U +2856b, U +285c8 -285c9, U +286d7, U +286fa, U +28946, U +28949, U +2896b, U +28987 -28988, U +289ba -289bb, U +28a1e, U +28a29, U +28a43, U +28a71, U +28a99, U +28acd, U +28add, U +28ae4, U +28bc1, U +28bef, U +28cdd, U +28d10, U +28d71, U +28dfb, U +28e0f, U +28e17, U +28e1f, U +28e36, U +28e89, U +28eeb, U +28ef6, U +28f32, U +28ff8, U +292a0, U +292b1, U +29490, U +295cf, U +2967f, U +296f0, U +29719, U +29750, U +29810, U +298c6, U +29a72, U +29d4b, U +29ddb, U +29e15, U +29e3d, U +29e49, U +29e8a, U +29ec4, U +29edb, U +29ee9, U +29fce, U +29fd7, U +2a01a, U +2a02f, U +2a082, U +2a0f9, U +2a190, U +2a2b2, U +2a38c, U +2a437, U +2a5f1, U +2a602, U +2a61a, U +2a6b2, U +2a9e6, U +2b746, U +2b751, U +2b753, U +2b75a, U +2b75c, U +2b765, U +2b776 -2b777, U +2b77c, U +2b782, U +2b789, U +2b78b, U +2b78e, U +2b794, U +2b7ac, U +2b7af, U +2b7bd, U +2b7c9, U +2b7cf, U +2b7d2, U +2b7d8, U +2b7f0, U +2b80d, U +2b817, U +2b81a, U +2d544, U +2e278, U +2e569, U +2e6ea, U +2f804, U +2f80f, U +2f815, U +2f818, U +2f81a, U +2f822, U +2f828, U +2f82c, U +2f833, U +2f83f, U +2f846, U +2f852, U +2f862, U +2f86d, U +2f873, U +2f877, U +2f884, U +2f899 -2f89a, U +2f8a6, U +2f8ac, U +2f8b2, U +2f8b6, U +2f8d3, U +2f8db -2f8dc, U +2f8e1, U +2f8e5, U +2f8ea, U +2f8ed, U +2f8fc, U +2f903, U +2f90b, U +2f90f, U +2f91a, U +2f920 -2f921, U +2f945, U +2f947, U +2f96c, U +2f995, U +2f9d0, U +2f9de -2f9df, U +2f9f4;
}

/*----------------------------------------
全体
----------------------------------------*/

body {
	font-family: "Shippori Mincho", serif;
	font-weight: 500;
	font-size: 18px;
	line-height: 28px;
	word-break: break-word;
	text-size-adjust: none;
}

.wrapper {
	box-sizing: border-box;
	height: 100%;
	margin: 0 auto;
	width: 1200px;
}

.sp-wrapper {
	overflow: hidden;
}

.center {
	display: block;
	margin: 0 auto;
}

.left {
	float: left;
}

.right {
	float: right;
}

.pc-left {
	float: left;
}

.pc-right {
	float: right;
}

.aligncenter {
	display: block;
	margin: 0 auto;
}

.alignleft {
	float: left;
}

.alignright {
	float: right;
}

.t-center {
	text-align: center !important;
}

.t-left {
	text-align: left !important;
}

.t-right {
	text-align: right !important;
}

.pc-t-center {
	text-align: center !important;
}

.clear {
	clear: both;
}

.inline {
	display: inline !important;
}

.inline-b {
	display: inline-block !important;
}

.block {
	display: block !important;
}

.of {
	overflow: hidden;
}

.pc-of {
	overflow: hidden;
}

.flex {
	display: flex;
	display: -ms-flexbox;
	display: -webkit-box;
	display: -webkit-flex;
	flex-wrap: wrap;
	-ms-flex-wrap: wrap;
	-webkit-flex-wrap: wrap;
}

.flex-center {
	display: flex;
	display: -ms-flexbox;
	display: -webkit-box;
	display: -webkit-flex;
	flex-wrap: wrap;
	-ms-flex-wrap: wrap;
	-webkit-flex-wrap: wrap;
	justify-content: center;
}

.flex-middle {
	align-items: center;
	display: flex;
	display: -ms-flexbox;
	display: -webkit-box;
	display: -webkit-flex;
	flex-wrap: wrap;
	-ms-flex-wrap: wrap;
	-webkit-flex-wrap: wrap;
	justify-content: space-between;
}

img,
iframe {
	display: block;
}

a:hover img {
	opacity: 0.6;
}

.img-banner {
	background-size: 100% !important;
	box-sizing: border-box;
	display: block;
	height: 0;
	overflow: hidden;
	text-indent: 100%;
	white-space: nowrap;
	width: 100%;
}

a:hover .img-banner {
	opacity: 0.6;
}

a {
	color: var(--text-light);
}

a:hover {
	color: #681da8;
}

a.bo {
	text-decoration: underline;
}

a.bo:hover {
	text-decoration: none;
}

a.no-bo {
	text-decoration: none;
}

a.no-bo:hover {
	text-decoration: underline;
}

.full {
	height: auto;
	width: 100%;
}

.full-img {
	box-sizing: border-box;
	display: block;
	width: 100%;
}

.full-img img {
	height: auto;
	width: 100%;
}

.list {
	box-sizing: border-box;
	margin-bottom: 20px;
}

.list li {
	box-sizing: border-box;
	list-style: disc !important;
	margin-left: 19px !important;
}

_::-webkit-full-page-media, _:future, :root .list li {
	margin-left: 23px !important;
}

.num-list {
	box-sizing: border-box;
	margin-bottom: 20px;
}

.num-list li {
	box-sizing: border-box;
	list-style: decimal !important;
	margin-left: 20px !important;
}

.num-list li:nth-child(n+10) {
	margin-left: 28px !important;
}

.num-list-2 {
	box-sizing: border-box;
	margin-bottom: 20px;
}

.num-list-2 li {
	box-sizing: border-box;
	padding-left: 33px;
}

.num-in {
	left: 0;
	position: absolute;
}

.check-list {
	box-sizing: border-box;
	margin-bottom: 20px;
}

.check-list li {
	box-sizing: border-box;
	margin-bottom: 10px;
	min-height: 25px;
	padding-left: 37.5px;
	position: relative;
}

.check-list li:last-child {
	margin-bottom: 0;
}

.check-list li::before {
	background: #fff;
	box-sizing: border-box;
	border: 3px solid #000;
	content: "";
	left: 0;
	height: 25px;
	position: absolute;
	top: 3px;
	width: 25px;
}

.check-list li::after {
	box-sizing: border-box;
	border-right: 4px solid #ff0000;
	border-bottom: 4px solid #ff0000;
	content: "";
	left: 12px;
	height: 22px;
	position: absolute;
	top: -1px;
	transform: rotate(45deg);
	-webkit-transform: rotate(45deg);
	width: 14px;
}

.douga {
	margin: 0 auto;
	width: 560px;
}

.douga-in {
	padding-top: 56.25%;
	position: relative;
	width: 100%;
}

.douga-in iframe {
	left: 0;
	height: 100%;
	position: absolute;
	top: 0;
	width: 100%;
}

.text-base {
	box-sizing: border-box;
	display: inline-block;
	padding-left: 18px;
	position: relative;
}

.text-base-2 {
	box-sizing: border-box;
	display: inline-block;
	padding-left: 36px;
	position: relative;
}

.text-base-3 {
	box-sizing: border-box;
	display: inline-block;
	padding-left: 54px;
	position: relative;
}

.text-base-4 {
	box-sizing: border-box;
	display: inline-block;
	padding-left: 72px;
	position: relative;
}

.text-base-5 {
	box-sizing: border-box;
	display: inline-block;
	padding-left: 90px;
	position: relative;
}

.text-in {
	left: 0;
	position: absolute;
	top: 0;
}

.indent-1 {
	box-sizing: border-box;
	display: inline-block;
	padding-left: 1em;
	text-indent: -1em;
}

.indent-2 {
	box-sizing: border-box;
	display: inline-block;
	padding-left: 2em;
	text-indent: -2em;
}

.indent-3 {
	box-sizing: border-box;
	display: inline-block;
	padding-left: 3em;
	text-indent: -3em;
}

.indent-4 {
	box-sizing: border-box;
	display: inline-block;
	padding-left: 4em;
	text-indent: -4em;
}

.indent-5 {
	box-sizing: border-box;
	display: inline-block;
	padding-left: 5em;
	text-indent: -5em;
}

.indent-6 {
	box-sizing: border-box;
	display: inline-block;
	padding-left: 6em;
	text-indent: -6em;
}

.indent-7 {
	box-sizing: border-box;
	display: inline-block;
	padding-left: 7em;
	text-indent: -7em;
}

.indent-8 {
	box-sizing: border-box;
	display: inline-block;
	padding-left: 8em;
	text-indent: -8em;
}

.indent-9 {
	box-sizing: border-box;
	display: inline-block;
	padding-left: 9em;
	text-indent: -9em;
}

.indent-10 {
	box-sizing: border-box;
	display: inline-block;
	padding-left: 10em;
	text-indent: -10em;
}

.pc {
	display: block;
}

.pc.tab {
	display: block;
}

.pc.tab.mobi {
	display: block;
}

.tab {
	display: none;
}

.tab.mobi {
	display: none;
}

.pc.mobi {
	display: block;
}

.mobi {
	display: none;
}

.first {
	margin-top: 0 !important;
}

.last {
	margin-bottom: 0 !important;
}

.m20 {
	margin: 20px !important;
}

.mt20 {
	margin-top: 20px !important;
}

.mb20 {
	margin-bottom: 20px !important;
}

.no-mt20 {
	margin-top: -20px !important;
}

.mt-20 {
	margin-top: 20px !important;
}

.mb-20 {
	margin-bottom: 20px !important;
}

.ml20 {
	margin-left: 20px !important;
}

.mr20 {
	margin-right: 20px !important;
}

.m40 {
	margin: 40px !important;
}

.mt40 {
	margin-top: 40px !important;
}

.mb40 {
	margin-bottom: 40px !important;
}

.ml40 {
	margin-left: 40px !important;
}

.mr40 {
	margin-right: 40px !important;
}

.m60 {
	margin: 60px !important;
}

.mt60 {
	margin-top: 60px !important;
}

.mt-60 {
	margin-top: 60px !important;
}

.mb60 {
	margin-bottom: 60px !important;
}

.mb-60 {
	margin-bottom: 60px !important;
}

.ml60 {
	margin-left: 60px !important;
}

.mr60 {
	margin-right: 60px !important;
}

.m80 {
	margin: 80px !important;
}

.mt80 {
	margin-top: 80px !important;
}

.mb80 {
	margin-bottom: 80px !important;
}

.ml80 {
	margin-left: 80px !important;
}

.mr80 {
	margin-right: 80px !important;
}

.m100 {
	margin: 100px !important;
}

.mt100 {
	margin-top: 100px !important;
}

.mb100 {
	margin-bottom: 100px !important;
}

.ml100 {
	margin-left: 100px !important;
}

.mr100 {
	margin-right: 100px !important;
}

.p20 {
	padding: 20px !important;
}

.pt20 {
	padding-top: 20px !important;
}

.pb20 {
	padding-bottom: 20px !important;
}

.pl20 {
	padding-left: 20px !important;
}

.pr20 {
	padding-right: 20px !important;
}

.p40 {
	padding: 40px !important;
}

.pt40 {
	padding-top: 40px !important;
}

.pb40 {
	padding-bottom: 40px !important;
}

.pl40 {
	padding-left: 40px !important;
}

.pr40 {
	padding-right: 40px !important;
}

.p60 {
	padding: 60px !important;
}

.pt60 {
	padding-top: 60px !important;
}

.pb60 {
	padding-bottom: 60px !important;
}

.pl60 {
	padding-left: 60px !important;
}

.pr60 {
	padding-right: 60px !important;
}

.p80 {
	padding: 80px !important;
}

.pt80 {
	padding-top: 80px !important;
}

.pb80 {
	padding-bottom: 80px !important;
}

.pl80 {
	padding-left: 80px !important;
}

.pr80 {
	padding-right: 80px !important;
}

.p100 {
	padding: 100px !important;
}

.pt100 {
	padding-top: 100px !important;
}

.pb100 {
	padding-bottom: 100px !important;
}

.pl100 {
	padding-left: 100px !important;
}

.pr100 {
	padding-right: 100px !important;
}

/*----------------------------------------
文字スタイル
----------------------------------------*/

.gothic {
	font-family: "游ゴシック体", YuGothic, "游ゴシック Medium", "Yu Gothic Medium", "游ゴシック", "Yu Gothic", sans-serif;
}

.minchou {
	font-family: "游明朝", "YuMincho", "ヒラギノ明朝 Pro W3", "Hiragino Mincho Pro", "ＭＳ Ｐ明朝", "MS PMincho", serif;
}

.hirago {
	font-family: "ヒラギノ角ゴ ProN","Hiragino Kaku Gothic ProN", "メイリオ", Meiryo, "游ゴシック", YuGothic, sans-serif;
}

.hiramin {
	font-family: 'ヒラギノ明朝 Pro W3', 'Hiragino Mincho Pro', '游明朝','Yu Mincho', '游明朝体', 'YuMincho','ＭＳ Ｐ明朝', 'MS PMincho', serif;
}

.sans {
	font-family: 'Noto Sans JP', sans-serif;
}

.serif {
	font-family: 'Noto Serif JP', serif;
}

.shippori {
	font-family: "Shippori Mincho", serif;
}

strong,b,.strong {
	font-weight: 700;
}

:root {
	--blue-2: #5fa6b0;
	--blue-3: #e6f3f4;
}

.red {
	color: #ff0000;
}

.blue {
	color: #0000ff;
}

.yellow {
	color: #ffff00;
}

.green {
	color: #008800;
}

.orange {
	color: #ff8800;
}

.purple {
	color: #9400d3;
}

.magenta {
	color: #F37C92;
}

.cyan {
	color: #5DBFF2;
}

.y-b {
	background: linear-gradient(transparent 50%, #ffff00 50%);
}

.fs15 {
	font-size: 15px !important;
	line-height: 25px !important;
}

.fs23 {
	font-size: 23px !important;
	line-height: 33px !important;
}

.fs30 {
	font-size: 30px !important;
	line-height: 40px !important;
}

.fs40 {
	font-size: 40px !important;
	line-height: 50px !important;
}

.fs50 {
	font-size: 50px !important;
	line-height: 60px !important;
}

[class^="icon-"], [class*=" icon-"] {
	/* use !important to prevent issues with browser extensions that change fonts */
	font-family: 'icomoon' !important;
	speak: never;
	font-style: normal;
	font-weight: normal;
	font-variant: normal;
	text-transform: none;
	line-height: 1;

	/* Better Font Rendering =========== */
	-webkit-font-smoothing: antialiased;
	-moz-osx-font-smoothing: grayscale;
}

/* > */
.icon-cheveron-up::before {
	content: "\e001";
}

/* 角が丸い> */
.icon-chevron-right::before {
	content: "\e024";
}

/* ▲ */
.icon-triangle-right::before {
	content: "\e002";
}

/* 正三角形な▲ */
.icon-triangle-1::before {
	content: "\e003";
}

/* 短めの▲ */
.icon-triangle-2::before {
	content: "\e004";
}

/* ○ */
.icon-maru-1::before {
	content: "\e005";
}

/* ● */
.icon-maru-2::before {
	content: "\e006";
}

/* ◎ */
.icon-maru-3::before {
	content: "\e007";
}

/* ◎の中の丸が黒 */
.icon-maru-4::before {
	content: "\e008";
}

/* □ */
.icon-shikaku-1::before {
	content: "\e009";
}

/* ■ */
.icon-shikaku-2::before {
	content: "\e010";
}

/* → */
.icon-yazirushi-1::before {
	content: "\e011";
}

/* 短めの→ */
.icon-yazirushi-2::before {
	content: "\e012";
}

/* かなり短めの→ */
.icon-yazirushi-3::before {
	content: "\e013";
}

/* 線だけの→ */
.icon-yazirushi-4::before {
	content: "\e014";
}

/* 本体ありの電話 */
.icon-old-phone::before {
	content: "\e015";
}

/* 受話器のみの電話 */
.icon-phone::before {
	content: "\e016";
}

/* 背景ありの手紙アイコン(簡易なデザイン) */
.icon-mail-envelope-closed2::before {
	content: "\e017";
}

/* 背景なしの手紙アイコン(簡易なデザイン) */
.icon-mail-envelope-closed3::before {
	content: "\e018";
}

/* 背景ありの手紙アイコン(複雑なデザイン) */
.icon-mail-envelope-closed::before {
	content: "\e019";
}

/* 背景なしの手紙アイコン(複雑なデザイン) */
.icon-mail-envelope-closed1::before {
	content: "\e020";
}

/* ＋ */
.icon-plus::before {
	content: "\e021";
}

/* － */
.icon-minus::before {
	content: "\e022";
}

/* × */
.icon-batsu::before {
	content: "\e023";
}

/*----------------------------------------
画像関連
----------------------------------------*/

/*----------------------------------------
header
----------------------------------------*/

header {
	box-sizing: border-box;
}

.head-in {
	background: linear-gradient(to bottom, rgba(255,255,255,0.6) 0%,rgba(255,255,255,0.6) 70%,rgba(255,255,255,0) 100%);
	box-sizing: border-box;
	left: 0;
	position: absolute;
	top: 0;
	width: 100%;
	z-index: 9990;
}

.head-in .wrapper {
	padding: 20px;
	width: 100%;
}

.head-in-logo {
	box-sizing: border-box;
	display: block;
	float: left;
	width: 168px;
}

.head-in-logo .img-banner {
	background: url(images/logo.png) no-repeat;
	padding-bottom: 14.285% !important;
}

.head-in-logo:hover .img-banner {
	background: url(images/logo-2.png) no-repeat;
	opacity: 1;
}

.head-in-in {
	box-sizing: border-box;
	float: right;
}

.head-in-in-menu {
	box-sizing: border-box;
	height: 24px;
}

.head-in-in-menu ul {
	box-sizing: border-box;
	height: 100%;
}

.head-in-in-menu ul li {
	box-sizing: border-box;
	float: left;
	font-size: 16px;
	line-height: 1.5;
	margin-right: 60px;
}

.head-in-in-menu ul li:last-child {
	margin-right: 0;
}

.head-in-in-menu ul li a {
	color: #000;
	text-decoration: none;
}

.head-in-in-menu ul li a:hover {
	color: var(--blue-2);
}

.head-fixed {
	background: #fff;
	box-sizing: border-box;
	box-shadow: 0 0 15px 0 rgba(0,0,0,0.6);
	left: 0;
	position: fixed;
	top: 0;
	width: 100%;
	z-index: 9990;
}

body#top .head-fixed {
	top: -100px;
	transition: all .5s;
	-webkit-transition: all .5s;
}

body#top .head-fixed.fixed {
	top: 0;
}

body#top.customize-support .head-fixed.fixed {
	margin-top: 32px;
}

.customize-support .head-fixed {
	margin-top: 32px;
}

.head-fixed .wrapper {
	padding: 20px;
	width: 100%;
}

.head-fixed-logo {
	box-sizing: border-box;
	display: block;
	float: left;
	width: 168px;
}

.head-fixed-logo .img-banner {
	background: url(images/logo.png) no-repeat;
	padding-bottom: 14.285% !important;
}

.head-fixed-logo:hover .img-banner {
	background: url(images/logo-2.png) no-repeat;
	opacity: 1;
}

.head-fixed-in {
	box-sizing: border-box;
	float: right;
}

.head-fixed-in-menu {
	box-sizing: border-box;
	height: 24px;
}

.head-fixed-in-menu ul {
	box-sizing: border-box;
	height: 100%;
}

.head-fixed-in-menu ul li {
	box-sizing: border-box;
	float: left;
	font-size: 16px;
	line-height: 1.5;
	margin-right: 60px;
}

.head-fixed-in-menu ul li:last-child {
	margin-right: 0;
}

.head-fixed-in-menu ul li a {
	color: #000;
	text-decoration: none;
}

.head-fixed-in-menu ul li a:hover {
	color: var(--blue-2);
}

/*----------------------------------------
TOPページ
----------------------------------------*/

body#top .sp-wrapper {
	position: relative;
}

.bg-icon.top-icon-1 {
	left: 0;
	top: 480px;
	width: 471px;
}

.bg-icon.top-icon-1::before {
	background: url(images/top-bg-img-1.png) no-repeat;
	padding-bottom: 288.53%;
}

.bg-icon.top-icon-2 {
	right: 0;
	top: 1400px;
	width: 582px;
}

.bg-icon.top-icon-2::before {
	background: url(images/top-bg-img-2.png) no-repeat;
	padding-bottom: 242.95%;
}

.bg-icon.top-icon-3 {
	bottom: -60px;
	left: 0;
	width: 471px;
}

.top-main-title {
	box-sizing: border-box;
	line-height: 0;
	text-align: center;
}

.top-main-title-in {
	box-sizing: border-box;
}

.top-main-title-in-text {
	box-sizing: border-box;
	color: var(--blue-2);
	display: inline-block;
	font-size: 28px;
	line-height: 1.5;
}


/*------------------------------
メイン
------------------------------*/

.top-main-content {
	box-sizing: border-box;
}

.top-main-content .wrapper {
	padding: 60px 0;
	position: relative;
	z-index: 2;
}

.top-main-content-main-img {
	box-sizing: border-box;
	display: block;
	float: left;
	width: 583px;
}

.top-main-content-main-img img {
	height: auto;
	width: 100%;
}

.top-main-content-in {
	box-sizing: border-box;
	float: right;
	margin-top: 165px;
	width: calc(100% - 623px);
}

.top-main-content-in-text {
	box-sizing: border-box;
	font-size: 24px;
	line-height: 1.5;
}

.top-main-content-in-text p {
	margin-bottom: 20px;
}

.top-main-content-in-text p:last-child {
	margin-bottom: 0;
}

/*------------------------------
コメント
------------------------------*/

.top-comment-content {
	box-sizing: border-box;
	height: 400px;
}

.top-comment-content .wrapper {
	position: relative;
}

.top-comment-content .wrapper::before {
	background: url(images/top-bg.jpg) no-repeat;
	background-size: cover !important;
	background-position: top center !important;
	box-sizing: border-box;
	content: "";
	left: 50%;
	height: 100%;
	margin-left: -600px;
	position: absolute;
	top: 0;
	width: calc(50vw + 600px);
}

.top-comment-content-text {
	box-sizing: border-box;
	font-size: 24px;
	line-height: 2;
	left: 100px;
	position: absolute;
	top: 50%;
	transform: translateY(-50%);
	-webkit-transform: translateY(-50%);
	z-index: 2;
	width: calc(100% - 200px);
	z-index: 2;
}


/*----------------------------------------
個別ページ
----------------------------------------*/

.main {
	box-sizing: border-box;
	margin-top: 64px;
}

body#top .main {
	margin-top: 0;
}

.bg-icon {
	box-sizing: border-box;
	display: block;
	position: absolute;
}

.bg-icon::before {
	background-size: 100% !important;
	box-sizing: border-box;
	content: "";
	display: block;
	height: 0;
	position: relative;
	width: 100%;
}

.page-content {
	box-sizing: border-box;
}

.page-content .wrapper {
	padding: 60px 0 100px;
}

.page-content-main-title {
	box-sizing: border-box;
	line-height: 0;
	padding: 12px;
	position: relative;
    max-width: 720px;
    margin-left: auto;
    margin-right: auto;
    padding: 0 60px;
}

.page-content-main-title-in-text {
    font-size: 24px;
    font-weight: 300;
    line-height: 1.9;
	color: var(--text);
    margin-bottom: 12px;
	text-align:left;
}

.page-content-in {
	box-sizing: border-box;
	font-size: 18px;
	line-height: 1.5;
    font-family: var(--sans);
	max-width:720px;
	margin-left:auto;
	margin-right:auto;
}

.page-content-in p {
	margin-bottom: 20px;
    font-size: 14px;
    font-weight: 400;
    line-height: 2.2;
    color: var(--text-light);
}

.page-content-in p:last-child {
	margin-bottom: 0;
}

.page-content-in p + h2,
.page-content-in p + h3,
.page-content-in p + h4,
.page-content-in p + .title-2,
.page-content-in p + .title-3,
.page-content-in p + .title-4,
.page-content-in ul + h2,
.page-content-in ul + h3,
.page-content-in ul + h4,
.page-content-in ul + .title-2,
.page-content-in ul + .title-3,
.page-content-in ul + .title-4,
.page-content-in ol + h2,
.page-content-in ol + h3,
.page-content-in ol + h4,
.page-content-in ol + .title-2,
.page-content-in ol + .title-3,
.page-content-in ol + .title-4,
.page-content-in dl + h2,
.page-content-in dl + h3,
.page-content-in dl + h4,
.page-content-in dl + .title-2,
.page-content-in dl + .title-3,
.page-content-in dl + .title-4,
.page-content-in table + h2,
.page-content-in table + h3,
.page-content-in table + h4,
.page-content-in table + .title-2,
.page-content-in table + .title-3,
.page-content-in table + .title-4,
.page-content-in img + h2,
.page-content-in img + h3,
.page-content-in img + h4,
.page-content-in img + .title-2,
.page-content-in img + .title-3,
.page-content-in img + .title-4,
.page-content-in iframe + h2,
.page-content-in iframe + h3,
.page-content-in iframe + h4,
.page-content-in iframe + .title-2,
.page-content-in iframe + .title-3,
.page-content-in iframe + .title-4,
.page-content-in div + h2,
.page-content-in div + h3,
.page-content-in div + h4,
.page-content-in div + .title-2,
.page-content-in div + .title-3,
.page-content-in div + .title-4,
.page-content-in a + h2,
.page-content-in a + h3,
.page-content-in a + h4,
.page-content-in a + .title-2,
.page-content-in a + .title-3,
.page-content-in a + .title-4,
.page-content-in center + h2,
.page-content-in center + h3,
.page-content-in center + h4,
.page-content-in center + .title-2,
.page-content-in center + .title-3,
.page-content-in center + .title-4 {
	margin-top: 60px;
}

.page-content-in .title-2 {
    font-family: var(--sans);
    font-size: 26px;
    font-weight: 300;
    line-height: 2;
    color: var(--text);
    margin-bottom: 30px;
    padding-bottom: 12px;
    border-bottom: 1px solid var(--border);
}

.page-content-in .title-2 .title-in {
	box-sizing: border-box;
}

.page-content-in .title-2 .title-in-text {
}

.page-content-in .title-3 {
	box-sizing: border-box;
	line-height: 0;
	margin-bottom: 20px;
	padding-bottom: 8px;
	position: relative;
}

.page-content-in .title-3 {
    font-family: var(--sans);
    font-weight: 300;
    line-height: 2;
    color: var(--text);
    margin-bottom: 30px;
    padding-bottom: 12px;
    border-bottom: 1px solid var(--border);
}

.page-content-in .title-3 .title-in {
	box-sizing: border-box;
}

.page-content-in .title-3 .title-in-text {
	box-sizing: border-box;
	display: inline-block;
	font-size: 24px;
	line-height: 1.5;
}

.page-content-in .title-4 {
	box-sizing: border-box;
	line-height: 0;
	margin-bottom: 20px;
}

.page-content-in .title-4 .title-in {
	box-sizing: border-box;
	display: inline-block;
	padding-left: 10px;
	position: relative;
}

.page-content-in img.size-thumbnail {
	height: auto;
	width: 150px;
}

.page-content-in img.size-medium {
	height: auto;
	width: 300px;
}

.page-content-in img.size-large {
	height: auto;
	width: 640px;
}

.page-content-in img.size-full {
	height: auto;
	width: 640px;
}

.page-content-in img.size-full.defo {
	height: auto;
	max-width: 640px;
	width: auto;
}

.page-content-in img.size-full.full {
	height: auto;
	width: 100%;
}

.page-content-in .douga {
	margin-bottom: 20px;
}

.page-content-in .douga:last-child {
	margin-bottom: 0;
}

.waku {
	box-sizing: border-box;
	margin-bottom: 20px;
	padding-top: 16px;
	position: relative;
}

.waku:last-child {
	margin-bottom: 0;
}

.waku-title {
	box-sizing: border-box;
	line-height: 0;
	left: 20px;
	position: absolute;
	text-align: center;
	top: 0;
	z-index: 2;
}

.waku-title-in {
	background: var(--blue-2);
	box-sizing: border-box;
	border-radius: 5px;
	display: block;
	padding: 5px 10px;
}

.waku-title-in-text {
	box-sizing: border-box;
	color: #fff;
	display: inline-block;
	font-size: 15px;
	line-height: 1.5;
}

.waku-in {
	box-sizing: border-box;
	border-color: #ccc !important;
	border: 2px solid;
	padding: 36px 20px 20px;
}

.tb-base {
	box-sizing: border-box;
	margin-bottom: 20px;
	overflow: hidden;
}

.tb-base:last-child {
	margin-bottom: 0;
}

.tb {
	box-sizing: border-box;
	width: 100%;
}

.tb.w-25 {
	width: 25%;
}

.tb.w-50 {
	width: 50%;
}

.tb.w-75 {
	width: 75%;
}

.tb.center {
	display: table;
}

.tb th {
	background: #eee;
	box-sizing: border-box;
	border-color: #000 !important;
	border: 1px solid;
	font-weight: 700;
	padding: 5px 10px;
	vertical-align: top;
	text-align: left;
	width: 30%;
}

.tb.th-50 th {
	width: 50%;
}

.tb.th-70 th {
	width: 70%;
}

.tb td {
	background: #fff;
	box-sizing: border-box;
	border-color: #000 !important;
	border: 1px solid;
	padding: 5px 10px;
	vertical-align: top;
	text-align: left;
}

.col-tb-base,
.col-tb-base-long {
	box-sizing: border-box;
	margin-bottom: 20px;
	overflow: hidden;
}

.col-tb-base:last-child,
.col-tb-base-long:last-child {
	margin-bottom: 0;
}

.col-tb {
	box-sizing: border-box;
	width: 100%;
}

.col-tb th {
	background: #eee;
	box-sizing: border-box;
	border-color: #000 !important;
	border: 1px solid;
	font-weight: 700;
	padding: 5px 10px;
	vertical-align: middle;
	text-align: center;
}

.col-tb.col-2 tr:first-child th {
	width: 50%;
}

.col-tb.col-3 tr:first-child th {
	width: 33.3%;
}

.col-tb.col-3 tr:first-child th:nth-child(2) {
	width: 33.4%;
}

.col-tb.col-3.th-first-25 tr:first-child th {
	width: auto;
}

.col-tb.col-3.th-first-25 tr:first-child th:first-child {
	width: 25%;
}

.col-tb.col-4 tr:first-child th {
	width: 25%;
}

.col-tb.col-5 tr:first-child th {
	width: 20%;
}

.col-tb td {
	background: #fff;
	box-sizing: border-box;
	border-color: #000 !important;
	border: 1px solid;
	padding: 5px 10px;
	vertical-align: middle;
	text-align: center;
}

#toc_container {
	box-sizing: border-box;
	margin-top: 60px;
}

/*----------------------------------------
404ページ
----------------------------------------*/

.page-404-content {
	box-sizing: border-box;
}

.page-404-content .wrapper {
	padding: 60px 0 100px;
}

.page-404-content-title {
	box-sizing: border-box;
	line-height: 0;
}

.page-404-content-title-in {
	box-sizing: border-box;
}

.page-404-content-title-in-text {
	box-sizing: border-box;
	display: inline-block;
	font-weight: 700;
	font-size: 30px;
	line-height: 1.5;
}

.page-404-content-text {
	box-sizing: border-box;
	font-size: 18px;
	line-height: 1.5;
	margin-top: 20px;
}

.page-404-content-text p {
	margin-bottom: 20px;
}

.page-404-content-text p:last-child {
	margin-bottom: 0;
}

/*----------------------------------------
sidebar
----------------------------------------*/


/*----------------------------------------
ページトップ
----------------------------------------*/

.pagetop {
	background: var(--blue-2);
	box-sizing: border-box;
	border-radius: 50%;
	box-shadow: 0 0 15px 0 rgba(0,0,0,0.6);
	bottom: 20px;
	cursor: pointer;
	height: 75px;
	position: fixed;
	right: 20px;
	width: 75px;
	z-index: 100;
}

.pagetop::before {
	box-sizing: border-box;
	color: #fff;
	content: "\e001";
	font-family: 'icomoon';
	font-size: 75px;
	line-height: 75px;
	position: absolute;
	text-align: center;
	width: 75px;
}

.pagetop:hover {
	opacity: 0.6;
}

/*----------------------------------------
Edge CSSハック
----------------------------------------*/

@supports (-ms-ime-align: auto) {



}

/*----------------------------------------
IE11以下 CSSハック
----------------------------------------*/

@media screen\0 {



}

/*----------------------------------------
Firefox CSSハック
----------------------------------------*/

@-moz-document url-prefix() {



}

/*----------------------------------------
Safari CSSハック
----------------------------------------*/

_::-webkit-full-page-media, _:future, :root .num-list li {
	margin-left: 30px !important;
}

_::-webkit-full-page-media, _:future, :root .num-list li:nth-child(n+10) {
	margin-left: 40px !important;
}

@import url('https://fonts.googleapis.com/css2?family=Noto+Serif+JP:wght@200;300;400&family=Noto+Sans+JP:wght@300;400&display=swap');

/* ── Reset & Base ── */
*, *::before, *::after {
  box-sizing: border-box;
  margin: 0;
  padding: 0;
}

:root {
  --bg:#FBFBFA;
  --bg-soft:#F5F4F1;
  --text:rgba(0, 0, 0, 0.72);
  --text-light:rgba(0, 0, 0, 0.42);
  --text-faint:rgba(0, 0, 0, 0.28);
	--text: #3a3a3a;
    --text-light: #7a7a7a;
    --text-faint: #a8a8a0;
	--accent:rgba(120, 105, 88, 0.55);
	--line:rgba(0, 0, 0, 0.10);
	--serif:'Noto Serif JP', serif;
	--sans:'Noto Sans JP', sans-serif;
    --border: #d8d5ce;
	
    --bg-warm: #f2efe9;
    --text: #3a3a3a;
    --text-light: #7a7a7a;
    --text-faint: #a8a8a0;
    --accent: #6b7c6e;
    --accent-light: #8a9b8d;
    --accent-warm: #7d8570;
    --border: #d8d5ce;
    --white: #fdfcfa;

}


html {
  font-size: 16px;
  scroll-behavior: smooth;
}

body {
  background-color: var(--bg);
  color: var(--text);
  font-family: var(--serif);
  font-weight: 300;
  line-height: 2.0;
  -webkit-font-smoothing: antialiased;
  overflow-x: hidden;
}

/* ── Fade-in animation ── */
.fade-in {
  opacity: 0;
  transform: translateY(18px);
  transition: opacity 0.9s ease, transform 0.9s ease;
}

.fade-in.visible {
  opacity: 1;
  transform: translateY(0);
}

/* ── Navigation ── */
nav {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  z-index: 100;
  padding: 28px 60px;
  display: flex;
  justify-content: space-between;
  align-items: center;
  background: linear-gradient(to bottom, rgba(251,251,250,0.92) 0%, rgba(251,251,250,0) 100%);
  transition: background 0.6s ease;
}

nav .logo {
  font-family: var(--serif);
  font-weight: 200;
  font-size: 0.85rem;
  letter-spacing: 0.28em;
  color: var(--text);
  text-decoration: none;
  text-transform: uppercase;
}

nav .nav-links {
  display: flex;
  gap: 40px;
  list-style: none;
}

nav .nav-links a {
  font-family: var(--sans);
  font-weight: 300;
  font-size: 0.72rem;
  letter-spacing: 0.20em;
  color: var(--text-light);
  text-decoration: none;
  text-transform: uppercase;
  transition: color 0.4s ease;
}

nav .nav-links a:hover {
  color: var(--text);
}

/* ── Hero ── */
#hero {
  position: relative;
  width: 100%;
  height: 100vh;
  min-height: 640px;
  overflow: hidden;
}

#hero .hero-image {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center 30%;
  filter: brightness(1.02) saturate(0.88);
  transform: scale(-1, 1);
}

#hero .hero-overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(
    to bottom,
    rgba(251,251,250,0.08) 0%,
    rgba(251,251,250,0.0) 40%,
    rgba(251,251,250,0.55) 100%
  );
}

#hero .hero-content {
  position: absolute;
  bottom: 13vh;
  left: 60px;
  max-width: 680px;
}

#hero .hero-label {
  font-family: var(--sans);
  font-weight: 300;
  font-size: 0.68rem;
  letter-spacing: 0.32em;
  color: var(--text-light);
  text-transform: uppercase;
  margin-bottom: 20px;
  display: block;
}

#hero h1 {
  font-family: var(--serif);
  font-weight: 200;
  font-size: clamp(1.6rem, 3.2vw, 2.6rem);
  line-height: 1.9;
  letter-spacing: 0.08em;
  color: var(--text);
}

#hero .hero-sub {
  margin-top: 24px;
  font-family: var(--sans);
  font-weight: 300;
  font-size: 0.78rem;
  letter-spacing: 0.12em;
  color: var(--text-light);
  line-height: 2.0;
}

/* ── Section common ── */
section {
  padding: 140px 60px;
}

.section-label {
  font-family: var(--sans);
  font-weight: 300;
  font-size: 0.65rem;
  letter-spacing: 0.36em;
  color: var(--text-faint);
  text-transform: uppercase;
  display: block;
  margin-bottom: 56px;
}

/* ── Philosophy ── */
#top-philosophy {
  background-color: var(--bg);
  max-width: 1100px;
  margin: 0 auto;
  padding: 140px 60px;
}

#top-philosophy .philosophy-header {
  margin-bottom: 80px;
}

#top-philosophy .philosophy-header h2 {
  font-family: var(--serif);
  font-weight: 200;
  font-size: clamp(1.3rem, 2.4vw, 2.0rem);
  line-height: 2.0;
  letter-spacing: 0.06em;
  color: var(--text);
}

.philosophy-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 60px 48px;
}

.philosophy-item {
  border-top: 1px solid var(--line);
  padding-top: 32px;
}

.philosophy-item .pillar-num {
  font-family: var(--sans);
  font-weight: 300;
  font-size: 0.62rem;
  letter-spacing: 0.28em;
  color: var(--text-faint);
  display: block;
  margin-bottom: 20px;
}

.philosophy-item h3 {
  font-family: var(--serif);
  font-weight: 300;
  font-size: 1.05rem;
  line-height: 1.9;
  letter-spacing: 0.06em;
  color: var(--text);
  margin-bottom: 16px;
}

.philosophy-item p {
  font-family: var(--sans);
  font-weight: 300;
  font-size: 0.80rem;
  line-height: 2.1;
  color: var(--text-light);
}

/* ── Threshold (迷ったとき) ── */
#top-threshold {
  background-color: var(--bg-soft);
  padding: 140px 60px;
}

#top-threshold .threshold-inner {
  max-width: 760px;
  margin: 0 auto;
  text-align: center;
}

#top-threshold h2 {
  font-family: var(--serif);
  font-weight: 200;
  font-size: clamp(1.2rem, 2.2vw, 1.85rem);
  line-height: 2.1;
  letter-spacing: 0.08em;
  color: var(--text);
  margin-bottom: 40px;
}

#top-threshold .threshold-body {
  font-family: var(--sans);
  font-weight: 300;
  font-size: 0.82rem;
  line-height: 2.2;
  color: var(--text-light);
  margin-bottom: 60px;
}

.threshold-links {
  display: flex;
  justify-content: center;
  gap: 32px;
  flex-wrap: wrap;
}

.threshold-link {
  display: inline-block;
  font-family: var(--sans);
  font-weight: 300;
  font-size: 0.72rem;
  letter-spacing: 0.22em;
  color: var(--text-light);
  text-decoration: none;
  text-transform: uppercase;
  border-bottom: 1px solid var(--line);
  padding-bottom: 4px;
  transition: color 0.4s ease, border-color 0.4s ease;
}

.threshold-link:hover {
  color: var(--text);
  border-color: var(--accent);
}

 .threshold-links a:hover { 
	color: var(--accent);
	 border-color: var(--accent);
}

/* ── Recovery Hints ── */
#top-hints {
  background-color: var(--bg);
  padding: 140px 60px;
}

#top-hints .hints-inner {
  max-width: 900px;
  margin: 0 auto;
}

#top-hints .hints-intro {
  font-family: var(--serif);
  font-weight: 200;
  font-size: clamp(1.1rem, 1.9vw, 1.55rem);
  line-height: 2.1;
  letter-spacing: 0.06em;
  color: var(--text);
  margin-bottom: 80px;
  max-width: 600px;
}

.hints-list {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 0;
}

.hint-item {
  padding: 40px 0;
  border-top: 1px solid var(--line);
  display: flex;
  align-items: flex-start;
  gap: 24px;
}

.hint-item:nth-child(odd) {
  padding-right: 48px;
  border-right: 1px solid var(--line);
}

.hint-item:nth-child(even) {
  padding-left: 48px;
}

.hint-num {
  font-family: var(--sans);
  font-weight: 300;
  font-size: 0.60rem;
  letter-spacing: 0.22em;
  color: var(--text-faint);
  padding-top: 4px;
  flex-shrink: 0;
  min-width: 28px;
}

.hint-text {
  font-family: var(--sans);
  font-weight: 300;
  font-size: 0.82rem;
  line-height: 2.1;
  color: var(--text-light);
}

/* ── Interlude (mid-page image) ── */
#interlude {
  padding: 0;
  height: 52vh;
  min-height: 320px;
  overflow: hidden;
  position: relative;
}

#interlude img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center 55%;
  filter: brightness(1.04) saturate(0.82);
}

#interlude .interlude-overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(
    to bottom,
    rgba(251,251,250,0.48) 0%,
    rgba(251,251,250,0.0) 30%,
    rgba(251,251,250,0.0) 70%,
    rgba(251,251,250,0.52) 100%
  );
}

.threshold-links a {
    font-size: 12px;
    font-weight: 300;
    color: var(--text-light);
    text-decoration: none;
    border-bottom: 1px solid #d8d5ce;
    padding-bottom: 4px;
    letter-spacing: 0.05em;
    transition: color 0.3s, border-color 0.3s;
}

/* ── Closing ── */
#closing {
  background-color: var(--bg);
  padding: 140px 60px;
  text-align: center;
}

#closing .closing-inner {
  max-width: 680px;
  margin: 0 auto;
}

#closing h2 {
  font-family: var(--serif);
  font-weight: 200;
  font-size: clamp(1.2rem, 2.0vw, 1.75rem);
  line-height: 2.2;
  letter-spacing: 0.08em;
  color: var(--text);
  margin-bottom: 36px;
}

#closing p {
  font-family: var(--sans);
  font-weight: 300;
  font-size: 0.80rem;
  line-height: 2.2;
  color: var(--text-light);
  margin-bottom: 56px;
}

.cta-quiet {
  display: inline-block;
  font-family: var(--sans);
  font-weight: 300;
  font-size: 0.72rem;
  letter-spacing: 0.28em;
  color: var(--text-light);
  text-decoration: none;
  text-transform: uppercase;
  border: 1px solid var(--line);
  padding: 16px 40px;
  transition: color 0.5s ease, border-color 0.5s ease;
}

.cta-quiet:hover {
  color: var(--text);
  border-color: var(--accent);
}

/* ── Footer ── */
footer {
  background-color: var(--bg-soft);
  padding: 64px 60px;
  border-top: 1px solid var(--line);
}

.footer-inner {
  max-width: 1100px;
  margin: 0 auto;
  display: flex;
  justify-content: space-between;
  align-items: flex-end;
  flex-wrap: wrap;
  gap: 32px;
}

.footer-brand .brand-name {
  font-family: var(--serif);
  font-weight: 200;
  font-size: 0.80rem;
  letter-spacing: 0.30em;
  color: var(--text-light);
  text-transform: uppercase;
  display: block;
  margin-bottom: 8px;
}

.footer-brand .brand-tagline {
  font-family: var(--sans);
  font-weight: 300;
  font-size: 0.68rem;
  letter-spacing: 0.14em;
  color: var(--text-faint);
  line-height: 1.9;
}

.footer-note {
  font-family: var(--sans);
  font-weight: 300;
  font-size: 0.65rem;
  letter-spacing: 0.10em;
  color: var(--text-faint);
  text-align: right;
  line-height: 1.9;
}

.hints-grid { display: grid; grid-template-columns: 1fr 1fr; }
.hints-item {
    padding: 32px 40px;
    border-top: 1px solid #d8d5ce;
}
.hints-item:nth-child(odd) { border-right: 1px solid #d8d5ce; }
.hints-item .item-dash {
    font-size: 14px; color: var(--text-faint); margin-bottom: 12px;
}
.hints-item .item-text {
    font-size: 14px; font-weight: 300; line-height: 2; color: var(--text-light);
}

.closing-cta {
    display: inline-block; text-decoration: none;
    font-size: 12px; font-weight: 300; letter-spacing: 0.08em; color: var(--text-light);
    padding: 16px 40px; border: 1px solid #d8d5ce;
    transition: all 0.4s ease;
  }

.closing-cta:hover { background: var(--accent); color: var(--white); border-color: var(--accent); }

.threshold-links a {
    font-size: 12px;
    font-weight: 300;
    color: var(--text-light);
    text-decoration: none;
    border-bottom: 1px solid #d8d5ce;
    padding-bottom: 4px;
    letter-spacing: 0.05em;
    transition: color 0.3s, border-color 0.3s;
}

.footer-about a {
    font-size: 11px;
    font-weight: 300;
    color: var(--text-light);
    text-decoration: none;
    border-bottom: 1px solid var(--border);
}

.footer-note{
	width:100%;
	text-align:center;
}

/* ===== SECOND PAGE: RB TOWA ===== */
.second-hero {
  padding: 100px 60px 60px;
  max-width: 720px;
  margin: 0 auto;
}
.second-hero .page-label {
  font-size: 11px;
  font-weight: 300;
  letter-spacing: 0.2em;
  color: var(--text-faint);
  margin-bottom: 40px;
}
.second-hero h1 {
  font-family: var(--sans);
  font-size: 26px;
  font-weight: 300;
  line-height: 2;
  color: var(--text);
  margin-bottom: 20px;
}
.common-sub-top-message {
  font-family: var(--sans);
  font-size: 16px;
  font-weight: 300;
  line-height: 2;
  color: var(--text);
  margin-bottom: 85px;
}
.second-hero .subtitle {
  font-size: 14px;
  font-weight: 400;
  line-height: 2.2;
  color: var(--text-light);
}

.essay-section {
  max-width: 620px;
  margin: 0 auto;
  padding: 40px 60px;
}
.essay-section h2 {
  font-family: var(--sans);
  font-size: 15px;
  font-weight: 400;
  letter-spacing: 0.05em;
  color: var(--accent);
  margin-bottom: 30px;
  padding-bottom: 12px;
  border-bottom: 1px solid var(--border);
}
.essay-section p {
  font-size: 14px;
  font-weight: 300;
  line-height: 2.4;
  color: var(--text);
  margin-bottom: 16px;
}
.essay-section p.emphasis {
  font-weight: 400;
  color: var(--accent-warm);
}

.section-divider {
  max-width: 620px;
  margin: 40px auto;
  height: 1px;
  background: linear-gradient(90deg, transparent, var(--border), transparent);
}

/* Photo break */
.photo-break {
  max-width: 800px;
  margin: 60px auto;
  padding: 0 60px;
}
.photo-break .photo-placeholder {
  width: 100%;
  aspect-ratio: 16/7;
/*  background: linear-gradient(135deg, #d4dbd5, #e8e4dc, #c8cfc9);*/
  border-radius: 2px;
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--text-faint);
  font-size: 11px;
  letter-spacing: 0.15em;
  font-weight: 300;
}

.page-content-in p .tx-m{
	font-size:15px
}

.page-content-in p.tx-m{
	font-size:15px
}

.page-content .second-hero{
	padding:0 60px 60px;
}

/* Blog navigation cards */
.blog-nav {
  max-width: 620px;
  margin: 60px auto 80px;
  padding: 0 60px;
}
.blog-nav h2 {
  font-size: 14px;
  font-weight: 400;
  color: var(--accent);
  letter-spacing: 0.05em;
  margin-bottom: 40px;
}
.blog-nav-item {
  display: block;
  text-decoration: none;
  padding: 28px 0;
  border-bottom: 1px solid var(--border);
  transition: all 0.4s ease;
  cursor: pointer;
}
.blog-nav-item:first-of-type {
  border-top: 1px solid var(--border);
}
.blog-nav-item:hover {
  padding-left: 12px;
}
.blog-nav-item .item-number {
  font-family: var(--serif);
  font-size: 12px;
  color: var(--text-faint);
  letter-spacing: 0.1em;
  margin-bottom: 8px;
}
.blog-nav-item .item-title {
  font-size: 15px;
  font-weight: 400;
  color: var(--text);
  margin-bottom: 8px;
  transition: color 0.3s;
}
.blog-nav-item:hover .item-title {
  color: var(--accent);
}
.blog-nav-item .item-desc {
  font-size: 12px;
  font-weight: 300;
  color: var(--text-light);
  line-height: 1.8;
}

.quiet-note {
  max-width: 620px;
  margin: 0 auto 100px;
  padding: 0 60px;
  font-size: 12px;
  font-weight: 200;
  color: var(--text-faint);
  line-height: 2;
}

/* ===== BLOG PAGE ===== */
.blog-hero {
  padding: 100px 60px 40px;
  max-width: 720px;
  margin: 0 auto;
}
.blog-hero .blog-label {
  font-size: 11px;
  font-weight: 300;
  letter-spacing: 0.2em;
  color: var(--text-faint);
  margin-bottom: 16px;
}
.blog-hero h1 {
  font-family: var(--sans);
  font-size: 24px;
  font-weight: 300;
  line-height: 1.9;
  color: var(--text);
  margin-bottom: 12px;
}
.blog-hero .blog-subtitle {
  font-size: 13px;
  font-weight: 200;
  color: var(--text-light);
  line-height: 2;
}

.blog-photo {
  max-width: 720px;
  margin: 40px auto;
  padding: 0 60px;
}
.blog-photo .photo-placeholder {
  width: 100%;
  aspect-ratio: 16/8;
  background: linear-gradient(135deg, #cdd5ce, #e2ddd5, #bec7bf);
  border-radius: 2px;
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--text-faint);
  font-size: 11px;
  letter-spacing: 0.15em;
  font-weight: 300;
}

/* Video placeholder */
.video-section {
  max-width: 620px;
  margin: 40px auto;
  padding: 0 60px;
}
.video-placeholder {
  width: 100%;
  aspect-ratio: 16/9;
  background: #e8e5df;
  border-radius: 2px;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 12px;
  color: var(--text-faint);
  font-size: 11px;
  letter-spacing: 0.1em;
  font-weight: 300;
}
.video-placeholder .play-icon {
  width: 48px;
  height: 48px;
  border: 1.5px solid var(--text-faint);
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
}
.video-placeholder .play-icon::after {
  content: '';
  display: block;
  width: 0;
  height: 0;
  border-left: 14px solid var(--text-faint);
  border-top: 8px solid transparent;
  border-bottom: 8px solid transparent;
  margin-left: 3px;
}

.blog-body {
  max-width: 620px;
  margin: 0 auto;
  padding: 20px 60px 40px;
}
.blog-body h2 {
  font-size: 15px;
  font-weight: 400;
  color: var(--accent);
  margin: 48px 0 24px;
  padding-bottom: 10px;
  border-bottom: 1px solid var(--border);
}
.blog-body p {
  font-size: 14px;
  font-weight: 300;
  line-height: 2.4;
  color: var(--text);
  margin-bottom: 14px;
}

/* Blog bottom navigation */
.blog-bottom {
  max-width: 620px;
  margin: 60px auto 40px;
  padding: 0 60px;
}
.blog-bottom-label {
  font-size: 11px;
  font-weight: 300;
  letter-spacing: 0.15em;
  color: var(--text-faint);
  margin-bottom: 20px;
}
.blog-bottom-link {
  display: block;
  text-decoration: none;
  padding: 16px 0;
  border-bottom: 1px solid var(--border);
  transition: padding-left 0.3s;
}
.blog-bottom-link:first-of-type {
  border-top: 1px solid var(--border);
}
.blog-bottom-link:hover { padding-left: 8px; }
.blog-bottom-link span {
  font-size: 13px;
  font-weight: 300;
  color: var(--text-light);
  transition: color 0.3s;
}
.blog-bottom-link:hover span { color: var(--accent); }

/* 7-day program link */
.program-link {
  max-width: 620px;
  margin: 60px auto 100px;
  padding: 32px 60px;
}
.program-link-inner {
  padding: 32px;
  background: var(--bg-warm);
  border-left: 2px solid var(--border);
}
.program-link-inner .link-label {
  font-size: 11px;
  font-weight: 300;
  letter-spacing: 0.15em;
  color: var(--text-faint);
  margin-bottom: 12px;
}
.program-link-inner .link-title {
  font-size: 14px;
  font-weight: 400;
  color: var(--text);
  margin-bottom: 8px;
  line-height: 1.8;
}
.program-link-inner .link-desc {
  font-size: 12px;
  font-weight: 200;
  color: var(--text-light);
  line-height: 2;
  margin-bottom: 16px;
}
.program-link-inner a {
  font-size: 12px;
  font-weight: 300;
  color: var(--accent);
  text-decoration: none;
  letter-spacing: 0.05em;
  border-bottom: 1px solid var(--border);
  padding-bottom: 2px;
  transition: border-color 0.3s;
}
.program-link-inner a:hover {
  border-color: var(--accent);
}


/* ── Responsive ── */
@media (max-width: 900px) {
  nav {
    padding: 22px 28px;
  }

  nav .nav-links {
    gap: 24px;
  }

  #hero .hero-content {
    left: 28px;
    right: 28px;
    bottom: 20vh;
    max-width: none;
  }

  section {
    padding: 100px 28px;
  }

  #top-philosophy {
    padding: 100px 28px;
  }

  .philosophy-grid {
    grid-template-columns: 1fr;
    gap: 40px;
  }

  #top-threshold {
    padding: 100px 28px;
  }

  #top-hints {
    padding: 100px 28px;
  }

  .hints-list {
    grid-template-columns: 1fr;
  }

  .hint-item:nth-child(odd) {
    padding-right: 0;
    border-right: none;
  }

  .hint-item:nth-child(even) {
    padding-left: 0;
  }

  #closing {
    padding: 100px 28px;
  }

  footer {
    padding: 52px 28px;
  }

  .footer-inner {
    flex-direction: column;
    align-items: flex-start;
  }

  .footer-note {
  }
}

@media (max-width: 600px) {
  nav .nav-links {
    display: none;
  }

  #hero h1 {
    font-size: 1.45rem;
  }
}


.program-link {
    max-width: 620px;
    margin: 60px auto 100px;
    padding: 32px 60px;
}
