/*
Theme Name: vinstay
*/

		:root {
			--black: #121212;
			--ink: #242424;
			--gray: #777;
			--light: #f4f1ec;
			--paper: #fbfaf7;
			--line: #ddd5c9;
			--gold: #b99b5f;
			--green: #4f5d54;
			--white: #fff
		}

		* {
			box-sizing: border-box
		}

		html {
			scroll-behavior: smooth
		}

		body {
			margin: 0;
			background: var(--paper);
			color: var(--ink);
			font-family: -apple-system, BlinkMacSystemFont, "Noto Sans JP", "Hiragino Kaku Gothic ProN", "Yu Gothic", Meiryo, sans-serif;
			line-height: 1.75;
			letter-spacing: .02em
		}

		a {
			color: inherit;
			text-decoration: none
		}

		.container {
			width: min(1220px, calc(100% - 48px));
			margin: auto
		}

		.serif {
			font-family: "Yu Mincho", "Hiragino Mincho ProN", "Noto Serif JP", serif;
			letter-spacing: .05em
		}

		.header {
			position: fixed;
			top: 0;
			left: 0;
			right: 0;
			z-index: 50;
			color: #fff;
			background: linear-gradient(rgba(0, 0, 0, 0.4) 40%,rgba(0, 0, 0, 0.05));
		}

		.header-inner {
			height: 86px;
			display: flex;
			align-items: center;
			justify-content: space-between;
			padding: 0 38px
		}

		.logo {
			font-size: 28px;
			font-weight: 900;
			letter-spacing: .08em
		}

		.nav {
			display: flex;
			gap: 28px;
			align-items: center;
			font-size: 12px;
			letter-spacing: .14em;
			text-transform: uppercase
		}

		.nav .contact {
			border: 1px solid currentColor;
			padding: 11px 18px;
			border-radius: 999px
		}

		.hero {
			position: relative;
			min-height: 100vh;
			background: var(--black);
			color: #fff;
			overflow: hidden
		}

		.hero-bg {
			position: absolute;
			inset: 0;
			background: linear-gradient(90deg, rgba(0, 0, 0, .72), rgba(0, 0, 0, .66) 30%, rgba(0, 0, 0, .08) 70%, rgba(0, 0, 0, .28)), url('/wp-content/themes/vinstay/images/img1.webp') center/cover no-repeat;
			animation: heroZoom 18s ease-in-out infinite alternate
		}

		@keyframes heroZoom {
			from {
				transform: scale(1)
			}

			to {
				transform: scale(1.08)
			}
		}

		.hero-content {
			position: relative;
			z-index: 2;
			min-height: 100vh;
			display: flex;
			align-items: center
		}

		.hero-text {
			max-width: 820px;
			padding-top: 60px
		}

		.kicker {
			display: flex;
			align-items: center;
			gap: 16px;
			font-size: 12px;
			letter-spacing: .24em;
			color: rgba(255, 255, 255, .72);
			text-transform: uppercase;
			margin-bottom: 30px
		}

		.kicker:before {
			content: "";
			width: 72px;
			height: 1px;
			background: var(--gold)
		}

		h1 {
			margin: 0;
			font-size: clamp(44px, 7vw, 72px);
			line-height: 1.08;
			font-weight: 500;
		}

		h1 .mark {
			color: var(--gold);
			margin-left: -4%;
		}

		h1 .fs {
			font-size:70%;
		}

		.hero-sub {
			margin: 28px 0 0;
			font-size: clamp(18px, 2vw, 27px);
			color: rgba(255, 255, 255, .86)
		}

		.hero-actions {
			display: flex;
			flex-wrap: wrap;
			gap: 18px;
			align-items: center;
			margin-top: 42px
		}

		.btn {
			display: inline-flex;
			justify-content: center;
			align-items: center;
			min-height: 58px;
			padding: 0 30px;
			border-radius: 999px;
			background: #fff;
			color: #111;
			font-weight: 800
		}

		.phone {
			font-size: 25px;
			font-weight: 800
		}

		.hero-strip {
			position: absolute;
			right: 34px;
			bottom: 34px;
			z-index: 3;
			display: grid;
			grid-template-columns: 110px 110px 110px;
			gap: 10px
		}

		.hero-thumb {
			height: 145px;
			border-radius: 16px;
			background-size: cover;
			background-position: center;
			border: 1px solid rgba(255, 255, 255, .28)
		}

		.scroll {
			position: absolute;
			right: 38px;
			bottom: 38px;
			z-index: 3;
			font-size: 11px;
			letter-spacing: .24em;
			writing-mode: vertical-rl;
			color: rgba(255, 255, 255, .62)
		}
		.scroll::before {
			content: "";
			display: block;
			width:1px;
			height:70px;
			background:rgba(255, 255, 255, .62);
			position:absolute;
			right:25px;
			z-index: 3;
		}
		.scroll::after {
			content: "";
			display: block;
			width:1px;
			height:12px;
			background:rgba(255, 255, 255, .62);
			position:absolute;
			right:21px;
			bottom: -15px;
			z-index: 3;
			transform: rotate(45deg);
		}

		section {
			padding: 120px 0;
			position: relative
		}

		.section-grid {
			display: grid;
			grid-template-columns: 330px 1fr;
			gap: 80px;
			align-items: start
		}

		.section-flex {
			display: flex;
			justify-content: flex-start;
			align-items: center;
		}

		.eyebrow {
			margin: 0 0 16px;
			font-size: 12px;
			letter-spacing: .24em;
			color: var(--gold);
			text-transform: uppercase;
			font-weight: 900
		}

		h2 {
			margin: 0;
			font-size: clamp(32px, 4.5vw, 64px);
			line-height: 1.18;
			font-weight: 500
		}

		.lead {
			margin: 22px 0 0;
			color: var(--gray);
			font-size: 17px;
			max-width: 720px
		}

		.editorial-grid {
			display: grid;
			grid-template-columns: 1.15fr .85fr;
			gap: 22px;
			margin-top: 60px
		}

		.ed-main {
			min-height: 640px;
			background: url('47122.webp') center/cover no-repeat;
			border-radius: 38px
		}

		.ed-side {
			display: grid;
			gap: 22px
		}

		.ed-img {
			min-height: 306px;
			background-size: cover;
			background-position: center;
			border-radius: 30px
		}

		.caption-row {
			display: grid;
			grid-template-columns: 1fr 1fr 1fr;
			gap: 22px;
			margin-top: 22px
		}

		.caption-card {
			padding-top: 22px;
			text-align: center;
		}

		.caption-card b {
			border-top: 1px solid var(--line);
			display: block;
			font-size: 20px;
			margin-bottom: 8px;
			margin-top:20px;
			padding-top:16px;
		}
		.caption-card p {
			color: var(--gray);
			margin: 0
		}

		.slide {
			width: 100%;
			height: 100%;
			overflow: hidden;
		}
		.swiper-slide {
			text-align: center;
			display: flex;
			justify-content: center;
			align-items: center;
		}

		.swiper-slide img {
			width: 100%;
			display: block;
		}
		.swiper-pagination{
			margin-bottom: 40px;
		}

		.problem {
			background: #fff
		}

		.problem-list {
			display: flex;
			flex-wrap: wrap;
			justify-content: center;
			gap: 36px;
			margin-top:40px;
		}
		.problem-list + .problem-list{
			margin-top:30px;
		}

		.problem-item {
			background: var(--light);
			padding: 36px 48px;
			min-height: 126px;
			display: flex;
			flex-direction: column;
			gap: 5px;
			align-items: center;
			justify-content: center;
			font-weight: 700;
			border-radius: 70% 60% 50% 50% / 50% 60% 70% 80%;
			text-align: center;
		}
		
		.problem-item:nth-of-type(2n) {
			border-radius: 70% 50% 70% 60% / 40% 80% 60% 70%;;
		}

		.problem-item span {
			color: var(--gold);
			font-weight: 900;
			display: block;
			font-size: 150%;
		}

		.reasons {
			background: var(--black);
			color: #fff
		}

		.reasons .lead {
			color: rgba(255, 255, 255, .66)
		}

		.reason-row {
			display: grid;
			grid-template-columns: repeat(3, 1fr);
			gap: 1px;
			background: rgba(255, 255, 255, .18);
			border: 1px solid rgba(255, 255, 255, .18);
			margin-top: 58px
		}

		.reason {
			background: var(--black);
			padding: 42px;
			min-height: 380px;
			display: flex;
			flex-direction: column;
			justify-content: space-between
		}

		.reason .num {
			color: var(--gold);
			font-size: 13px;
			letter-spacing: .2em
		}

		.reason h3 {
			font-size: 30px;
			line-height: 1.32;
			margin: 34px 0 18px;
			text-align:center;
		}
		.reason img{
			width:60%;
			margin: 0 auto;
			display: block;
		}
		.reason p {
			color: rgba(255, 255, 255, .68)
		}

		.photo-story {
			background: var(--light);
			overflow: hidden
		}

		.story-wrap {
			display: grid;
			grid-template-columns: .9fr 1.1fr;
			gap: 70px;
			align-items: center
		}

		.story-visual {
			position: relative;
			min-height: 650px
		}

		.story-visual .p1 {
			position: absolute;
			width: 74%;
			height: 470px;
			right: 0;
			bottom: 0;
			background: url('/wp-content/themes/vinstay/images/img12.webp') center/cover no-repeat;
			box-shadow:0 0 16px #999;
		}

		.story-visual .p2 {
			position: absolute;
			width: 56%;
			height: 330px;
			left: 0;
			top: 0;
			background: url('/wp-content/themes/vinstay/images/img11.webp') center/cover no-repeat;
			box-shadow:0 0 16px #999;
		}

		.story-points {
			display: grid;
			gap: 26px;
			margin-top: 36px
		}

		.story-point {
			border-top: 1px solid var(--line);
			padding-top: 22px
		}

		.story-point b {
			display: block;
			font-size: 20px;
			margin-bottom: 6px
		}

		.story-point span {
			color: var(--gray)
		}

		.ba {
			background: #fff
		}

		.ba-wrap {
			display: grid;
			grid-template-columns: 1fr 1fr;
			gap: 16px;
			position: relative;
			margin-top: 56px
		}

		.ba-img {
			min-height: 590px;
			background-size: cover;
			background-position: center;
			border-radius: 32px;
			position: relative;
			overflow: hidden
		}

		.ba-before {
			background-image: url('/wp-content/themes/vinstay/images/img13.webp');
		}

		.ba-after {
			background-image: url('/wp-content/themes/vinstay/images/img14.webp')
		}

		.ba-label {
			position: absolute;
			left: 24px;
			top: 24px;
			padding: 9px 14px;
			border-radius: 999px;
			background: #fff;
			font-size: 12px;
			letter-spacing: .16em;
			font-weight: 900
		}

		.same {
			position: absolute;
			left: 50%;
			top: 50%;
			transform: translate(-50%, -50%);
			background: #ffa1a1;
			width: 50px;
			height: 100px;
			clip-path: polygon(0 0, 0% 100%, 100% 50%);
		}

		.model {
			background: var(--paper)
		}

		.model-grid {
			display: grid;
			grid-template-columns: 1fr 1fr 1fr;
			gap: 18px;
			margin-top: 54px
		}

		.model-big {
			grid-column: span 2;
			min-height: 600px;
			border-radius: 36px;
			background: url('47122.webp') center/cover no-repeat
		}

		.model-small-wrap {
			display: grid;
			gap: 18px
		}

		.model-small {
			min-height: 291px;
			border-radius: 30px;
			background-size: cover;
			background-position: center
		}

		.ai {
			background: var(--green);
			color: #fff
		}

		.ai .lead {
			color: rgba(255, 255, 255, .72)
		}

		.ai-grid {
			display: grid;
			grid-template-columns: .9fr 1.1fr;
			gap: 70px;
			align-items: center
		}

		.ai-screen {
			background: #fff;
			border-radius: 34px;
			padding: 18px;
			box-shadow: 0 30px 90px rgba(0, 0, 0, .28)
		}

		.ai-screen img {
			width: 100%;
			border-radius: 24px;
			display: block
		}

		.logo-grid {
			display: grid;
			grid-template-columns: repeat(4, 1fr);
			gap: 16px;
			margin-top: 50px
		}

		.logo-box {
			height: 110px;
			display: grid;
			place-items: center;
			background: var(--paper);
			border: 1px solid var(--line);
			border-radius: 24px;
			font-size: 22px;
			font-weight: 900;
			color: var(--green)
		}

		.services {
			background: var(--light)
		}

		.service-grid {
			display: grid;
			grid-template-columns: repeat(4, 1fr);
			gap: 1px;
			background: var(--line);
			border: 1px solid var(--line);
			margin-top: 58px
		}

		.service {
			background: var(--light);
			padding: 26px;
			min-height: 190px
		}

		.service .ico {
			font-size: 28px;
			margin-bottom: 12px
		}

		.service h3 {
			margin: 0 0 8px;
			font-size: 17px
		}

		.service p {
			margin: 0;
			color: var(--gray);
			font-size: 14px
		}

		.event-list {
			display: flex;
			flex-wrap: wrap;
			gap: 12px;
			margin-top: 42px
		}

		.event {
			padding: 13px 18px;
			border-radius: 999px;
			border: 1px solid var(--line);
			background: var(--paper);
			color: var(--green);
			font-weight: 800
		}

		.flow {
			background: var(--black);
			color: #fff
		}

		.flow-list {
			display: grid;
			grid-template-columns: repeat(5, 1fr);
			gap: 1px;
			background: rgba(255, 255, 255, .18);
			border: 1px solid rgba(255, 255, 255, .18);
			margin-top: 58px
		}

		.flow-item {
			background: var(--black);
			padding: 30px 24px;
			min-height: 180px
		}

		.flow-item b {
			color: var(--gold)
		}

		.flow-item h3 {
			margin: 12px 0 6px
		}

		.flow-item p {
			color: rgba(255, 255, 255, .65)
		}

		.faq {
			background: var(--paper)
		}

		.faq-list {
			max-width: 960px;
			margin: 50px auto 0;
			border-top: 1px solid var(--line)
		}

		details {
			border-bottom: 1px solid var(--line)
		}

		summary {
			cursor: pointer;
			list-style: none;
			padding: 26px 0;
			font-weight: 900;
			font-size: 18px
		}

		details p {
			margin: 0;
			padding: 0 0 26px;
			color: var(--gray)
		}

		.cta {
			padding: 0;
			background: var(--black);
			color: #fff
		}

		.cta-inner {
			min-height: 560px;
			display: grid;
			place-items: center;
			text-align: center;
			background: linear-gradient(rgba(0, 0, 0, .55), rgba(0, 0, 0, .70)), url('47122.webp') center/cover no-repeat
		}

		.cta h2 {
			font-size: clamp(40px, 6vw, 84px)
		}

		.cta p {
			color: rgba(255, 255, 255, .72)
		}

		.footer {
			background: #0b0b0b;
			color: rgba(255, 255, 255, .58);
			padding: 34px 0;
			font-size: 13px
		}

		.footer .container {
			display: flex;
			justify-content: space-between;
			gap: 16px;
			flex-wrap: wrap
		}

		.reveal {
			opacity: 0;
			transform: translateY(35px);
			transition: opacity .85s ease, transform .85s ease
		}

		.reveal.show {
			opacity: 1;
			transform: none
		}

		.replace-note {
			display: inline-block;
			margin-top: 20px;
			padding: 10px 14px;
			background: rgba(185, 155, 95, .12);
			border: 1px solid rgba(185, 155, 95, .25);
			border-radius: 999px;
			color: #8d7040;
			font-size: 13px
		}

		@media(max-width:980px) {
			.nav a:not(.contact) {
				display: none
			}

			.section-grid,
			.story-wrap,
			.ai-grid {
				grid-template-columns: 1fr;
				gap: 38px
			}

			.editorial-grid,
			.problem-list,
			.reason-row,
			.ba-wrap,
			.model-grid,
			.logo-grid,
			.service-grid,
			.flow-list {
				grid-template-columns: 1fr 1fr
			}

			.ed-main {
				min-height: 460px
			}

			.model-big {
				grid-column: auto
			}
		}

		@media(max-width:640px) {
			.container {
				width: calc(100% - 28px)
			}

			.header-inner {
				height: 66px;
				padding: 0 18px
			}

			.logo {
				font-size: 22px
			}

			.hero-strip {
				display: none
			}

			.hero-text {
				padding-top: 90px
			}

			h1 {
				font-size: 40px
			}

			section {
				padding: 82px 0
			}

			.editorial-grid,
			.caption-row,
			.problem-list,
			.reason-row,
			.ba-wrap,
			.model-grid,
			.logo-grid,
			.service-grid,
			.flow-list {
				grid-template-columns: 1fr
			}

			.ba-img,
			.model-big {
				min-height: 360px
			}

			.story-visual {
				min-height: 500px
			}

			.story-visual .p1 {
				height: 340px
			}

			.story-visual .p2 {
				height: 260px
			}
		}