@charset "UTF-8";
/*
Theme Name: MY THEME 
Author: Zenshin
Description: オリジナルテーマ
Version: 1.0
*/
img {
    max-width: 100%;
    height: auto;
	vertical-align: bottom;
}

.img-full img {
	width: 100%;
	height: auto;
	text-align: center;
	vertical-align: bottom;
}


@media screen and (max-width: 780px) {
	.flex_res{
		flex-direction: column;
		align-items: center;
	}
}

.flex_hanyo{
	display: flex;
	justify-content: center;
}

.flex {
	display: flex;
	justify-content: space-between;
	flex-wrap: wrap;
}

.flex-center {
	display: flex;
	justify-content: center;
}

.flex-base {
	width: 100%;
	display: flex;
	flex-wrap: wrap;
	margin-bottom: 3%;
}

.alignleft {
	float: left;
	margin-left: 0;
	margin-right: 1em;
}

.alignright {
	float: right;
	margin-left: 1em;
	margin-right: 0;
}

.aligncenter {
	margin-left: auto;
	margin-right: auto;
}

.wp-block-categories.aligncenter,
.wp-block-latest-posts.aligncenter,
.wp-block-archives.aligncenter,
.wp-block-tag-cloud.aligncenter,
.wp-block-latest-comments.aligncenter,
.wp-block-rss.aligncenter {
	text-align: center;
}

figure {
	margin-left: 0;
	margin-right: 0;
}

body {
	box-sizing: border-box;
}

body *,
body *::before,
body *::after {
	box-sizing: inherit;
}

ul {
	padding-inline-start: 1rem;
}

pre {
	font-family: unset;
}

/* 変数 */
:root {
	--f1: 2.44em;
	/* 39.04px */
	--f2: 1.95em;
	/* 31.2px */
	--f3: 1.56em;
	/* 24.96px */
	--f4: 1.25em;
	/* 20px */
	--f5: 1em;
	/* 16px */
	--f6: 0.8em;
	/* 12.8px */

	--f7: 0.66em;
	/* 12.8px */

	--basecolor: #63a211;
	/* 基本色 */
	--gradient: linear-gradient(81.7deg, rgba(34, 126, 34, 1) 8.1%, rgba(99, 162, 17, 1) 86.5%);

	--myfont: "Noto Sans JP", sans-serif;
	--myw: 720px;
	/*標準幅*/
}


/* フォント */
body {
	font-family: var(--myfont);
	font-size: 21px;
}

p {
	line-height: 1.8;
	font-size: var(--f5);
}


h1 {
	font-size: var(--f1);
	font-weight: 300;
}

h2 {
	font-size: var(--f3);
	margin-block-start: 0;
}

h3 {
	font-size: var(--f3);
}

h4 {
	font-size: var(--f4);
}

h5 {
	font-size: var(--f5);
}

h6 {
	font-size: var(--f6);
}

.text_item_double_L{
	width: 55%;
	padding: 30px 0;
	margin: 0 auto;
}

.text_item_double_L p{
	font-size: 18px;
}

.text_img_double_R{
	display: flex;
	justify-content: center;
	align-items: center;
	width: 45%;
	padding: 30px 0;
	margin-left: 8%;
}

.text_img_double_R img{
	vertical-align: middle;
}
.title_wrapper{
	margin-right: 50%;
}

.title_img{
	display: flex;
	justify-content: center;
	align-items: center;
	margin: 30px 0;
}

.top_assist_text{
	font-size: 14px;
	/* margin-top: 35px; */
}

@media screen and (max-width: 780px) {
	.text_item_double_L{
		width: 100%;
		display: flex;
		flex-direction: column; /* 要素を縦方向に並べる */
		justify-content: center; /* 横方向（左右方向）の中央揃え */
		align-items: center; /* 縦方向（上下方向）の中央揃え */
		padding: 0;
	}
	.text_img_double_R{
		width: 70%;
		margin-left: 0;
		margin-bottom: 10px;
	}
	.title_img{
		width: 70%;
		margin: 20px 0 30px 0;
	}
	.text_item_double_L p{
		font-size: 14px;
	}
	.title_wrapper{
		width: 100%;
		display: flex;
		flex-direction: column; /* 要素を縦方向に並べる */
		justify-content: center; /* 横方向（左右方向）の中央揃え */
		align-items: center; /* 縦方向（上下方向）の中央揃え */
	}
	.osirase_img{
		width: 50%;
	}
}


/* 横幅 */
body {
	margin: 0;
}


.alignfull {
	width: 100%;
	height: auto;
	overflow: hidden;
}

.alignwide {
	margin-top: 5%;
	padding-left: 25%;
	padding-right: 25%;
}

/*スマホ*/
@media (max-width: 600px) {
	.alignwide {
		padding-left: 20px;
		padding-right: 20px;
	}
}

@media (min-width: 1320px) {}


/*配置*/
.center {
	text-align: center;
}

.space-between {
	justify-content: space-between;
}

/* ポジション */
.relative {
	position: relative;
}

.top {
	vertical-align: top;
}

/*リンク*/
a {
	color: inherit;
	text-decoration: none;
}

a:hover {
	color: inherit;
	opacity: 0.7;
}

/*色*/
.white {
	color: white;
}

.red {
	color: red;
}

.green {
	color: green;
}

.grey {
	background-color: #F2F2F2;
	padding-bottom: 5%;
}

.white-bg {
	background-color: white;
}

/*スマホ限定/PC限定*/
/*フッターの画像切替のみに使用 bootstrapのxlに対応*/

@media only screen and (max-width:768px) {
	.sp-md {
		display: block;
	}

}

/*-----マージン共通-----*/
.margin_hanyo {
	margin-top: 120px;
}

.margin_hanyo_sub2 {
	margin-top: 100px;
}

.margin_right_pc{
	margin-right: 20px;
}

.margin_hanyo_bottom {
	margin-bottom: 5%;
}

@media screen and (max-width: 780px) {
	.margin_hanyo{
		margin-top: 50px;
	}
	.margin_hanyo_sub {
		margin-top: 10px;
	}
	.margin_hanyo_sub2 {
		margin-top: 50px;
	}
	.margin_top_res{
		margin-top: 15px;
	}
	.margin_right_pc{
		margin-right: 0;
	}
}

p {
	font-size: 21px;
}

/* ベーシックプラン用。汎用CSS */
/* width指定 */
.w-10 {width: 10%}
.w-15 {width: 15%}
.w-20 {width: 20%}
.w-25 {width: 25%}
.w-30 {width: 30%}
.w-33 {width: 33%} /* flexの3等分用 */
.w-40 {width: 40%}
.w-45 {width: 45%}
.w-48 {width: 48%} /* flexの2等分用 */
.w-50 {width: 50%}
.w-60 {width: 60%}
.w-65 {width: 65%} /* flexの2:1の比率用 */
.w-70 {width: 70%}
.w-75 {width: 75%}
.w-80 {width: 80%} /* 基本のサイズ */
.w-90 {width: 90%}
.w-95 {width: 95%}
.w-100 {width: 100%}
.w-fit {width: fit-content}
/* 余白 */
.p-10 {padding: 10px}
.p-15 {padding: 15px}
.p-20 {padding: 20px}
.p-30 {padding: 30px}
.p-60 {padding: 60px}
/* flexなど位置系 */
.flex-center {display: flex;justify-content: center;align-items: center;gap: 2%}
.flex-between {display: flex;justify-content: space-between;align-items: center;}
.column {display: flex;flex-direction: column;align-items: center;gap: 2%}
.flex-start {display: flex;justify-content: flex-start;align-items: center;gap: 2%}
.flex-end {display: flex;justify-content: flex-end;align-items: center;gap: 2%}
.right {text-align: right;}
.center {text-align: center;}
.left {text-align: left;}
/* font-size汎用 */
.font14 {font-size: 14px}
.font16 {font-size: 16px}
.font18 {font-size: 18px}
.font20 {font-size: 20px}
.font24 {font-size: 24px}
.font30 {font-size: 30px;font-weight: bold}
.font40 {font-size: 40px;font-weight: bold}
/* その他汎用 marginやpaddingそのほか */
.style-none {list-style: none;padding: 0;}
.bold {font-weight: bold}
.m-auto {margin: auto}
.m-0 {margin: 0}
.m-l-3 {margin-left: 3%}
.m-l-5 {margin-left: 5%}
.m-t-5 {margin-top: 5%;}
.p-l-8 {padding: 0 0 0 8%;}
.p-l-15px {padding-left: 15px;}
.p-b-5 {padding-bottom: 5px;}
.p-t-5 {padding-top: 5px;}
.vertical-top {vertical-align: top;}
.p-y-10 {padding: 10px 0;}
/* レスポ化用汎用 */
@media only screen and (min-width: 769px) {
	.sp {display: none} /* SP表示（769px未満で表示） */
}
@media only screen and (max-width: 768px) {
	.pc {display: none} /* PC表示（768px以上で表示） */
	.sp-column {display: flex;flex-direction: column;align-items: center;}
	.hamburger_menu_btn_wrap.sp {display: block;}
	.sp-w-70 {width: 70%;}
}
@media only screen and (min-width: 561px) {
	.sm {display: none} /* スマホ表示（561px未満で表示） */
}
@media only screen and (max-width: 560px) {
	.extra {display: none} /* それ以外表示（560px以上で表示） */
	.sm-column {display: flex;flex-direction: column;align-items: center;}
	.sm-w-90 {width: 90%;}
}
/* header */
.myhead {padding: 2% 0;background-color: #f0f8ff;box-shadow: 1px 2px 9px rgba(0,0,0,0.4)}
/*-----ハンバーガーメニュー-----*/
.hamburger_menu_btn_wrap {display: none;margin-right: 1.4%;margin-left: auto;position: fixed;right: 0;top: 15%;}
.hamburger_menu_btn {width: 30px;height: 24px;position: relative;cursor: pointer;z-index: 1001;display: flex;flex-direction: column;justify-content: space-between;}
.hamburger_menu_btn span {display: block;width: 100%;height: 3px;background-color: #0a4bc1;border-radius: 2px;transition: all 0.3s ease;}
.hamburger_menu_btn.active span:nth-child(1) {transform: translateY(10.5px) rotate(45deg);}
.hamburger_menu_btn.active span:nth-child(2) {opacity: 0;}
.hamburger_menu_btn.active span:nth-child(3) {transform: translateY(-10.5px) rotate(-45deg);}
.hamburger_window {position: fixed;top: 0;right: -300px;width: 300px;height: 100vh;background-color: rgba(30, 30, 30, 0.95);padding-top: 80px;box-sizing: border-box;transition: right 0.5s ease;z-index: 1000;visibility: hidden;overflow-y: auto;}
.hamburger_window.open {right: 0;visibility: visible;}
.hamburger_list_item {list-style: none;padding: 0;margin: 0;}
.hamburger_list_item li {border-bottom: 1px solid rgba(255, 255, 255, 0.2);}
.hamburger_list_item li:first-child {border-top: 1px solid rgba(255, 255, 255, 0.2);}
.hamburger_list_item li a {display: block;padding: 15px 20px;color: white;text-decoration: none;font-size: 1.1rem;transition: background-color 0.3s ease;}
.hamburger_list_item li a:hover {background-color: rgba(255, 255, 255, 0.1);}
.hamburger_background {position: fixed;top: 0;left: 0;width: 100vw;height: 100vh;background-color: rgba(0, 0, 0, 0.5);z-index: 999;opacity: 0;visibility: hidden;transition: opacity 0.5s ease;}
.hamburger_background.open {opacity: 1;visibility: visible;}
/* footer */
.myfoot {background-color: #0071bc;padding: 20px 0 0;}
.sp-li {background-color: #fff;color: #0071bc;margin-bottom: 10px;width: 100%;text-align: center;font-weight: bold}
@media only screen and (max-width: 850px) {
	.c-width {width: 90% !important;margin: auto;}
	.pc-850 {display: none !important;}
}
@media only screen and (min-width: 851px) {
	.sp-850 {display: none !important;}
}
/* front-page */
.bg-sky {background-color: #f0f8ff}
.bg-blue {background-color: #0071bc}
.bg-white {background-color: #fff}
.font-blue {color: #0071bc}
.arrow-button {background-color: #3a75bb;color: #fff;width: fit-content;padding: 1px 6px;border-radius: 100%;}
.arrow-button-wh {background-color: #fff;color: #3a75bb;width: fit-content;padding: 1px 6px;border-radius: 100%;}
.b-tandb-wh {border-top: 1px solid #fff;border-bottom: 1px solid #fff;}
/* お知らせ欄 */
.l-font {font-size: 120px;font-weight: bold;color: white;text-align: center;margin: 0;line-height: 1.0;}
.s-font {font-size: 18px;color: white;text-align: right;margin-right: 115px;}
@media only screen and (max-width: 900px) {
	.pc-900 {display: none !important;}
	.sp-900-column {flex-direction: column;}
	.sp-900-w-100 {width: 100%;}
	.sp-900-w-90 {width: 90%;}
	.l-font {font-size: 80px;}
	.s-font {text-align: center;margin-right: 0;}
}
@media only screen and (min-width: 901px) {
	.sp-900 {display: none !important;}
}
/* overview */
.font-pale {color: #2e3192;}
.b-b-blue {border-bottom: 1px solid #29abe2;font-weight: normal}
.b-b-ash {border-bottom: 1px solid #ccc}
.normal {font-weight: normal}
/* contact */
.cform {width: 100%}
.cform tbody {width: 100%}
.cform tr {width: 100%;}
.bg-form {background-color: #0071bc;color: #fff;padding: 10px 25px 10px 25px;}
.bg-form p,.border-form p {margin: 0; font-size: 18px;}
.b-b-black {border-bottom: 1px solid #000}
.required-srt {background-color: #c1272d;padding: 2px 15px;border-radius: 12px;font-size: 16px !important;}
.border-form input[type="text"],.border-form textarea {width: 90%;margin:10px 0 10px 4%;}
.border-form input[type="tel"],.border-form input[type="email"] {width: 60%;margin:10px 0 10px 4%;}
.zip-code {width:40%}
.short input[type="text"] {width: 80% !important;margin: 10px 0 10px 11%}
.short {display: flex;justify-content: flex-start;gap: 15px;align-items: center;}
.credential {font-size: 14px;margin: 0;}
.a-tag {color: #29abe2}
.a-tag:hover {opacity: 0.6;color: #0071bc;}
.sending-button {background: url('./image/contact/bg-but.png');background-repeat: no-repeat;background-position: center bottom;padding: 40px 0 30px;background-size: 40%;}
.sending-button p {margin: 0;font-size: 24px;text-align: center;}
.sending-button input {color:#fff;background-color: #0071bc;border: none;box-shadow: none;}
.wpcf7-spinner {display: none !important;}
@media only screen and (max-width: 1200px) and (min-width: 769px) {
	.zip-code {width:60%}
	.short input[type="text"] {width: 80% !important;margin: 10px 0 10px 12%}
}
@media only screen and (max-width: 768px) and (min-width: 561px) {
	.sp-w-90 {width: 90%}
	.cform tr {display: flex;flex-direction: column;align-items: center;justify-content: center;}
	.bg-form {width: 100%;}
	.border-form {width: 100%;text-align: center;}
	.border-form input[type="text"],.border-form textarea {width: 90%;margin:10px auto;}
	.border-form input[type="tel"],.border-form input[type="email"] {width: 90%;margin:10px auto;}
	.zip-code {width: 100%}
	.short input[type="text"] {width: 90% !important;margin: 10px auto}
	.short {flex-direction: column;}
	.credential {width: 90%;}
}
@media only screen and (max-width: 560px) {
	.sp-w-90 {width: 95%}
	.cform tr {display: flex;flex-direction: column;align-items: center;justify-content: center;}
	.bg-form {width: 100%;}
	.border-form {width: 100%;text-align: center;}
	.border-form input[type="text"],.border-form textarea {width: 90%;margin:10px auto;}
	.border-form input[type="tel"],.border-form input[type="email"] {width: 90%;margin:10px auto;}
	.zip-code {width: 100%}
	.short input[type="text"] {width: 90% !important;margin: 10px auto}
	.short {flex-direction: column;}
	.credential {width: 90%;}
}
/* recruit */
.bef-hash {margin-left: 8%;position: relative;}
.bef-hash::before {width: 3.5vw;height: 2px;background-color: #0071bc;position: absolute;content:'';top: 50%;left: -8.7%;}
.f-ash {color: #999;}
.table-pad {padding-top: 15px;padding-bottom: 15px;}
@media only screen and (max-width: 560px) {
	.sm-bg-ash {background-color: #999;}
	.sm-f-white {color: #fff;}
	.sm-w-100 {width: 100% !important; text-align: center !important;}
}
/* equip */
.bg-ash {background-color: #ccc;}
/* products */
.bef-half-square {position: relative;margin-left: 35px;}
.bef-half-square::before {position: absolute;content: '';width: 15px;height: 30px;top: 25%;left: -30px;background-color: #0071bc;}
/* sending-button */
.send-btn-wrap {position: relative;}
.send-btn-wrap input[type="submit"] {position: absolute;inset: 0;opacity: 0;z-index: 2;}
.fake-btn {display: block;padding: 22px 70px 22px 40px;border-radius: 999px;background: #0071bc;color: #fff;position: relative;width: 25%;margin: auto;text-align: center;}
.fake-btn .arrow {position: absolute;right: 18px;top: 50%;transform: translateY(-50%);background: #fff;color: #0071bc;width: 42px;height: 42px;border-radius: 50%;display: flex;align-items: center;justify-content: center;padding: 25px;}
@media only screen and (max-width: 1300px) and (min-width: 1000px) {.fake-btn {width: 50%;}}
@media only screen and (max-width: 1000px) and (min-width: 700px) {.fake-btn {width: 60%;}}
@media only screen and (max-width: 700px) and (min-width: 500px) {.fake-btn {width: 70%;}}
@media only screen and (max-width: 500px) {.fake-btn {width: 80%;}}

/* 2026-06 front-page recreation */
body {
	font-family: "Zen Kaku Gothic New", "Noto Sans JP", sans-serif;
	background: #ffffff;
	color: #264257;
}

.pet-menu-open {
	overflow: hidden;
}

.pet-site-header {
	position: fixed;
	top: 0;
	left: 0;
	right: 0;
	z-index: 1000;
	padding: 20px 0;
	background: rgba(255, 255, 255, 0.5);
	transition: background-color 0.3s ease, box-shadow 0.3s ease, padding 0.3s ease;
}

.pet-site-header.is-scrolled {
	background: rgba(255, 255, 255, 0.92);
	backdrop-filter: blur(10px);
	box-shadow: 0 12px 30px rgba(15, 74, 108, 0.12);
	padding: 12px 0;
}

.pet-site-header__inner,
.pet-shell {
	width: min(1200px, calc(100% - 32px));
	margin: 0 auto;
}

.pet-site-header__inner {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 24px;
}

.pet-brand {
	display: inline-flex;
	align-items: center;
	gap: 14px;
}

.pet-brand__icon {
	width: 52px;
	height: 52px;
	border-radius: 50%;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	font-size: 28px;
	background: #e6f7ff;
	border: 2px solid rgba(0, 163, 224, 0.16);
	flex-shrink: 0;
}

.pet-brand__name {
	margin: 0;
	font-size: 24px;
	font-weight: 900;
	line-height: 1.2;
	color: #00a3e0;
}

.pet-brand__sub {
	margin: 4px 0 0;
	font-size: 12px;
	color: #4f7d96;
	letter-spacing: 0.08em;
}

.pet-site-nav {
	display: flex;
	align-items: center;
	gap: 28px;
}

.pet-site-nav__link {
	font-size: 14px;
	font-weight: 700;
	position: relative;
	padding-bottom: 4px;
}

.pet-site-nav__link::after {
	content: "";
	position: absolute;
	left: 0;
	bottom: 0;
	width: 0;
	height: 2px;
	background: #00a3e0;
	transition: width 0.25s ease;
}

.pet-site-nav__link:hover::after {
	width: 100%;
}

.pet-site-nav__link--cta,
.pet-site-nav__link--cta:hover {
	padding: 12px 20px;
	border-radius: 999px;
	background: #00a3e0;
	color: #ffffff;
	box-shadow: 0 14px 30px rgba(0, 163, 224, 0.28);
}

.pet-site-nav__link--cta::after {
	display: none;
}

.pet-menu-button {
	display: none;
	width: 48px;
	height: 48px;
	padding: 0;
	border: 0;
	background: transparent;
	flex-direction: column;
	justify-content: center;
	gap: 6px;
}

.pet-menu-button span {
	display: block;
	width: 28px;
	height: 3px;
	margin: 0 auto;
	border-radius: 999px;
	background: #29526a;
}

.pet-mobile-menu {
	position: fixed;
	inset: 0;
	z-index: 1100;
	background: rgba(20, 48, 63, 0.35);
	opacity: 0;
	transition: opacity 0.25s ease;
}

.pet-mobile-menu.is-open {
	opacity: 1;
}

.pet-mobile-menu__panel {
	margin-left: auto;
	width: min(360px, 100%);
	min-height: 100%;
	padding: 28px 24px 32px;
	background: #ffffff;
	transform: translateX(100%);
	transition: transform 0.25s ease;
}

.pet-mobile-menu.is-open .pet-mobile-menu__panel {
	transform: translateX(0);
}

.pet-mobile-menu__head {
	display: flex;
	align-items: center;
	justify-content: space-between;
	margin-bottom: 28px;
}

.pet-mobile-menu__title {
	font-size: 14px;
	font-weight: 900;
	letter-spacing: 0.18em;
	color: #00a3e0;
	text-transform: uppercase;
}

.pet-mobile-menu__close {
	border: 0;
	background: transparent;
	font-size: 36px;
	line-height: 1;
	color: #29526a;
}

.pet-mobile-menu__nav {
	display: flex;
	flex-direction: column;
	gap: 12px;
}

.pet-mobile-menu__link {
	padding: 16px 18px;
	border-radius: 18px;
	background: #f8fdff;
	border: 1px solid #d8edf8;
	font-weight: 700;
}

.pet-mobile-menu__link--cta {
	background: #00a3e0;
	color: #ffffff;
	border-color: #00a3e0;
}

.pet-home {
	overflow: hidden;
}

.pet-hero {
	position: relative;
	height: min(90vh, 900px);
	min-height: 640px;
	display: flex;
	align-items: center;
	justify-content: center;
}

.pet-hero__slides,
.pet-hero__slide,
.pet-hero__overlay {
	position: absolute;
	inset: 0;
}

.pet-hero__slide {
	background-size: cover;
	background-position: center;
	opacity: 0;
	transition: opacity 1s ease;
}

.pet-hero__slide.is-active {
	opacity: 1;
}

.pet-hero__overlay {
	background: linear-gradient(to bottom, rgba(12, 36, 51, 0.18), rgba(12, 36, 51, 0.08), rgba(12, 36, 51, 0.6));
	z-index: 1;
}

.pet-hero__content {
	position: relative;
	z-index: 2;
	margin-top: auto;
	padding: 0 16px 110px;
	text-align: center;
	color: #ffffff;
}

.pet-hero__eyebrow {
	margin: 0 0 12px;
	font-size: clamp(14px, 2vw, 22px);
	font-weight: 700;
	letter-spacing: 0.28em;
	text-shadow: 0 2px 14px rgba(0, 0, 0, 0.48);
}

.pet-hero__title {
	margin: 0;
	font-size: clamp(42px, 7vw, 60px);
	font-weight: 900;
	line-height: 1.15;
	text-shadow: 0 4px 24px rgba(0, 0, 0, 0.52);
}

.pet-hero__dots {
	position: absolute;
	left: 50%;
	bottom: 36px;
	z-index: 2;
	display: flex;
	gap: 10px;
	transform: translateX(-50%);
}

.pet-hero__dot {
	width: 10px;
	height: 10px;
	padding: 0;
	border: 0;
	border-radius: 999px;
	background: rgba(255, 255, 255, 0.5);
	transition: width 0.3s ease, background-color 0.3s ease;
}

.pet-hero__dot.is-active {
	width: 34px;
	background: #ffffff;
}

.pet-section {
	padding: 96px 0;
}

.pet-shell--narrow {
	width: min(920px, calc(100% - 32px));
}

.pet-heading {
	display: flex;
	align-items: center;
	gap: 14px;
	margin-bottom: 32px;
}

.pet-heading__tag,
.pet-chip {
	display: inline-flex;
	align-items: center;
	padding: 8px 18px;
	border-radius: 999px;
	background: #00a3e0;
	color: #ffffff;
	font-size: 12px;
	font-weight: 900;
	letter-spacing: 0.16em;
	text-transform: uppercase;
}

.pet-heading__title,
.pet-review__body h2,
.pet-award h2,
.pet-cta h2 {
	margin: 0;
	font-size: clamp(32px, 4vw, 40px);
	font-weight: 900;
	line-height: 1.2;
}

.pet-card {
	border: 2px solid #e6f7ff;
	background: #f8fdff;
	box-shadow: 0 20px 50px rgba(24, 109, 159, 0.08);
}

.pet-card--feature {
	padding: clamp(32px, 5vw, 40px);
	border-radius: 48px;
}

.pet-card__title {
	margin: 0 0 24px;
	padding-left: 22px;
	border-left: 8px solid #00a3e0;
	font-size: clamp(24px, 3vw, 24px);
	font-weight: 700;
	line-height: 1.5;
	color: #00a3e0;
}

.pet-copy p {
	margin: 0 0 18px;
	font-size: clamp(16px, 1.65vw, 20px);
	line-height: 2;
	color: #516a7c;
}

.pet-copy p:last-child {
	margin-bottom: 0;
}

.pet-section--review {
	background: rgba(230, 247, 255, 0.42);
}

.pet-review {
	display: grid;
	grid-template-columns: minmax(280px, 1fr) minmax(280px, 1fr);
	align-items: center;
	gap: 56px;
}

.pet-review__visual {
	aspect-ratio: 1 / 1;
	border-radius: 60px;
	background: linear-gradient(180deg, #ffffff, #eef9ff);
	border: 4px solid #ffffff;
	box-shadow: inset 0 6px 30px rgba(0, 0, 0, 0.06);
	display: flex;
	align-items: center;
	justify-content: center;
}

.pet-paw {
	position: relative;
	width: 100%;
	height: auto;
}

.pet-paw span {
	position: absolute;
	display: block;
	background: #00a3e0;
}

.pet-paw span:nth-child(1) {
	left: 48px;
	bottom: 14px;
	width: 86px;
	height: 68px;
	border-radius: 50px 50px 42px 42px;
}

.pet-paw span:nth-child(2),
.pet-paw span:nth-child(3),
.pet-paw span:nth-child(4),
.pet-paw span:nth-child(5) {
	width: 34px;
	height: 42px;
	border-radius: 50%;
	top: 28px;
}

.pet-paw span:nth-child(2) { left: 18px; top: 70px; }
.pet-paw span:nth-child(3) { left: 52px; top: 24px; }
.pet-paw span:nth-child(4) { left: 94px; top: 18px; }
.pet-paw span:nth-child(5) { left: 130px; top: 62px; }

.pet-award {
	text-align: center;
}

.pet-award__icon {
	width: 82px;
	height: 82px;
	margin: 0 auto 28px;
	border-radius: 50%;
	display: flex;
	align-items: center;
	justify-content: center;
	font-size: 38px;
	background: #fff8e8;
	color: #d8a33b;
	border: 1px solid #f2dfb2;
}

.pet-card--award {
	margin: 28px 0 34px;
	padding: clamp(28px, 5vw, 52px);
	border-radius: 56px;
	background: #fffcf5;
	border-color: #fff2ca;
}

.pet-card--award p {
	margin: 0;
	font-size: clamp(22px, 2.7vw, 24px);
	line-height: 1.8;
}

.pet-photo-placeholder {
	aspect-ratio: 16 / 9;
	border-radius: 40px;
	border: 2px dashed #b3e0f5;
	background: #f8fdff;
	display: flex;
	align-items: center;
	justify-content: center;
}

.pet-photo-placeholder span {
	font-size: 13px;
	font-weight: 900;
	letter-spacing: 0.26em;
	color: #9bcfe7;
}

.pet-section--cta {
	background: linear-gradient(135deg, #ebf7fd 0%, #f4fbff 50%, #d8f0fa 100%);
}

.pet-cta {
	position: relative;
	padding: clamp(48px, 8vw, 88px);
	border-radius: 60px;
	background: #00a3e0;
	text-align: center;
	color: #ffffff;
	overflow: hidden;
	box-shadow: 0 28px 60px rgba(82, 170, 214, 0.35);
}

.pet-cta__shape {
	position: absolute;
	background: rgba(255, 255, 255, 0.14);
	pointer-events: none;
}

.pet-cta__shape--dog {
	left: -20px;
	bottom: -40px;
	width: 280px;
	height: 220px;
	border-radius: 55% 45% 35% 30%;
}

.pet-cta__shape--cat {
	top: -30px;
	right: -16px;
	width: 180px;
	height: 240px;
	border-radius: 48% 48% 40% 40%;
}

.pet-cta__button {
	position: relative;
	z-index: 1;
	display: inline-flex;
	align-items: center;
	gap: 18px;
	margin-top: 36px;
	padding: 22px 34px;
	border-radius: 999px;
	background: #ffffff;
	color: #00a3e0;
	font-size: clamp(18px, 2.5vw, 34px);
	font-weight: 900;
	box-shadow: 0 18px 36px rgba(20, 83, 115, 0.2);
}

.pet-cta__button-icon,
.pet-cta__button-arrow {
	font-size: 1.1em;
	line-height: 1;
}

.pet-section--banners {
	padding-top: 48px;
	background: #f8fdff;
}

.pet-banner-grid {
	display: grid;
	grid-template-columns: repeat(3, minmax(0, 1fr));
	align-items: center;
	gap: 24px;
}

.pet-banner {
	aspect-ratio: 16 / 8;
	padding: 22px;
	border-radius: 28px;
	border: 2px solid #e6f7ff;
	background: linear-gradient(135deg, rgba(0, 163, 224, 0.12), rgba(255, 255, 255, 0.96)), #ffffff;
	box-shadow: 0 14px 30px rgba(24, 109, 159, 0.08);
	display: flex;
	flex-direction: column;
	justify-content: flex-end;
}

.pet-banner__label {
	font-size: 11px;
	font-weight: 900;
	letter-spacing: 0.16em;
	color: #7ba6bc;
	text-transform: uppercase;
}

.pet-banner strong {
	margin-top: 8px;
	font-size: 28px;
	line-height: 1.3;
}

.pet-section--news-list {
	padding-top: 0;
	background: #f8fdff;
}

.pet-news {
	display: grid;
	grid-template-columns: 320px minmax(0, 1fr);
	gap: 40px;
	padding: 72px clamp(24px, 5vw, 48px);
	border-radius: 52px;
	background: #00a3e0;
	color: #ffffff;
}

.pet-news__headline {
	margin: 0;
	font-size: clamp(72px, 10vw, 130px);
	font-weight: 900;
	line-height: 0.92;
}

.pet-news__subhead {
	margin: 6px 0 0;
	font-size: 18px;
	font-weight: 700;
}

.pet-news__more {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	margin-top: 30px;
	padding: 14px 24px;
	border-radius: 999px;
	background: #ffffff;
	color: #00a3e0;
	font-size: 14px;
	font-weight: 900;
}

.pet-news__more--mobile {
	display: none;
}

.pet-news-item {
	display: grid;
	grid-template-columns: 130px minmax(0, 1fr) 54px;
	align-items: center;
	gap: 18px;
	padding: 18px 0;
	border-top: 1px solid rgba(255, 255, 255, 0.4);
	border-bottom: 1px solid rgba(255, 255, 255, 0.4);
}

.pet-news-item + .pet-news-item {
	margin-top: -1px;
}

.pet-news-item__date,
.pet-news-item__title {
	margin: 0;
}

.pet-news-item__date {
	font-size: 16px;
	font-weight: 700;
}

.pet-news-item__title {
	font-size: 18px;
	font-weight: 700;
	line-height: 1.6;
}

.pet-news-item__arrow {
	width: 42px;
	height: 42px;
	border-radius: 50%;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	background: #ffffff;
	color: #00a3e0;
	font-size: 26px;
	font-weight: 700;
}

.pet-news__empty {
	margin: 0;
	padding: 16px 0;
	font-size: 18px;
}

.pet-site-footer {
	background: #e8f5fc;
	border-top: 1px solid #b3dcf0;
}

.pet-site-footer__inner {
	width: min(1200px, calc(100% - 32px));
	margin: 0 auto;
	padding: 56px 0 40px;
	display: grid;
	grid-template-columns: 1.15fr 1fr 1fr;
	gap: 40px;
}

.pet-brand--footer .pet-brand__icon {
	background: #ffffff;
}

.pet-site-footer__address p,
.pet-site-footer__info p {
	margin: 0 0 8px;
	font-size: 15px;
	line-height: 1.9;
	color: #567285;
}

.pet-site-footer__contact,
.pet-site-footer__mail {
	display: inline-flex;
	margin-top: 18px;
	padding: 14px 22px;
	border-radius: 999px;
	background: #00a3e0;
	color: #ffffff;
	font-size: 14px;
	font-weight: 900;
}

.pet-site-footer__menu h3,
.pet-site-footer__info h3 {
	margin: 0 0 18px;
	font-size: 12px;
	font-weight: 900;
	letter-spacing: 0.18em;
	color: #7f9aac;
	text-transform: uppercase;
}

.pet-site-footer__chips {
	display: flex;
	flex-wrap: wrap;
	gap: 10px;
}

.pet-site-footer__chips a {
	padding: 12px 16px;
	border-radius: 14px;
	background: #ffffff;
	border: 1px solid #c8e6f5;
	font-size: 14px;
	font-weight: 700;
	color: #006fa6;
}

.pet-site-footer__copyright {
	padding: 0 16px 24px;
	text-align: center;
}

.pet-site-footer__copyright p {
	margin: 0;
	font-size: 12px;
	color: #7f9aac;
}

@media only screen and (max-width: 1024px) {
	.pet-site-nav {
		display: none;
	}

	.pet-menu-button {
		display: inline-flex;
	}

	.pet-review,
	.pet-news,
	.pet-site-footer__inner {
		grid-template-columns: 1fr;
	}

	.pet-banner-grid {
		grid-template-columns: 1fr;
	}
}

@media only screen and (max-width: 768px) {
	.pet-site-header {
		padding: 14px 0;
	}

	.pet-brand__icon {
		width: 46px;
		height: 46px;
		font-size: 24px;
	}

	.pet-brand__name {
		font-size: 18px;
	}

	.pet-hero {
		min-height: 560px;
	}

	.pet-hero__content {
		padding-bottom: 92px;
	}

	.pet-hero__eyebrow {
		letter-spacing: 0.16em;
	}

	.pet-section {
		padding: 72px 0;
	}

	.pet-heading {
		flex-direction: column;
		align-items: flex-start;
	}

	.pet-card--feature,
	.pet-cta,
	.pet-news {
		border-radius: 34px;
	}

	.pet-news-item {
		grid-template-columns: 1fr 44px;
	}

	.pet-news-item__date,
	.pet-news-item__title {
		grid-column: 1 / 2;
	}

	.pet-news-item__arrow {
		grid-column: 2 / 3;
		grid-row: 1 / 3;
	}

	.pet-news__more--desktop {
		display: none;
	}

	.pet-news__more--mobile {
		display: inline-flex;
	}
}

/* 2026-06 about page recreation */
.pet-about-page {
	background: #ffffff;
}

.pet-about-shell {
	width: min(1024px, calc(100% - 32px));
}

.pet-about-hero {
	position: relative;
	min-height: 420px;
	padding-top: 88px;
	display: flex;
	align-items: flex-end;
	overflow: hidden;
}

.pet-about-hero__media,
.pet-about-hero__overlay {
	position: absolute;
	inset: 0;
}

.pet-about-hero__media {
	background-size: cover;
	background-position: center;
	transform: scale(1.02);
}

.pet-about-hero__overlay--bottom {
	background: linear-gradient(to top, rgba(255, 255, 255, 1), rgba(255, 255, 255, 0.18), rgba(255, 255, 255, 0));
}

.pet-about-hero__overlay--top {
	background: linear-gradient(to bottom, rgba(0, 0, 0, 0.24), rgba(0, 0, 0, 0));
}

.pet-about-hero__content {
	position: relative;
	z-index: 1;
	padding-bottom: 56px;
}

.pet-about-hero__breadcrumb {
	display: flex;
	align-items: center;
	gap: 8px;
	margin-bottom: 14px;
	font-size: 14px;
	color: #5b7180;
}

.pet-about-hero__breadcrumb a:hover {
	color: #00a3e0;
}

.pet-about-hero__breadcrumb span:last-child {
	color: #00a3e0;
	font-weight: 700;
}

.pet-about-hero h1 {
	margin: 0;
	font-size: clamp(38px, 6vw, 62px);
	font-weight: 900;
	color: #223847;
}

.pet-about-hero__line {
	width: 68px;
	height: 6px;
	margin-top: 18px;
	border-radius: 999px;
	background: #00a3e0;
}

.pet-about-section {
	padding-top: 88px;
}

.pet-about-heading {
	margin-bottom: 52px;
}

.pet-about-heading--center {
	text-align: center;
}

.pet-about-heading__tag {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	padding: 10px 18px;
	border-radius: 999px;
	background: #e6f7ff;
	color: #00a3e0;
	font-size: 12px;
	font-weight: 900;
	letter-spacing: 0.16em;
	text-transform: uppercase;
	margin-bottom: 18px;
}

.pet-about-heading__tag--light {
	background: #ffffff;
	border: 1px solid #d0edfa;
}

.pet-about-heading h2 {
	margin: 0;
	font-size: clamp(32px, 4vw, 52px);
	font-weight: 900;
	color: #223847;
}

.pet-about-block + .pet-about-block {
	margin-top: 72px;
}

.pet-about-block__head {
	display: flex;
	align-items: center;
	gap: 16px;
	margin-bottom: 28px;
}

.pet-about-block__number {
	width: 48px;
	height: 48px;
	border-radius: 50%;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	background: #00a3e0;
	color: #ffffff;
	font-size: 18px;
	font-weight: 900;
	flex-shrink: 0;
}

.pet-about-block__head h3 {
	margin: 0;
	font-size: clamp(28px, 3vw, 40px);
	font-weight: 900;
	color: #223847;
}

.pet-about-block__body {
	padding-left: 64px;
}

.pet-about-message {
	padding: clamp(28px, 4vw, 44px);
	border-radius: 32px;
	background: #f8fdff;
	border: 1px solid #e6f7ff;
}

.pet-about-message p {
	margin: 0 0 18px;
	font-size: clamp(16px, 1.5vw, 18px);
	line-height: 2.15;
	color: #516a7c;
}

.pet-about-message p:last-child {
	margin-bottom: 0;
}

.pet-about-overview {
	display: flex;
	flex-direction: column;
	gap: 16px;
}

.pet-about-overview__item {
	background: #ffffff;
	border: 1px solid #e6f7ff;
	border-radius: 22px;
	box-shadow: 0 12px 26px rgba(17, 99, 145, 0.06);
	overflow: hidden;
}

.pet-about-overview__item {
	display: grid;
	grid-template-columns: 220px minmax(0, 1fr);
}

.pet-about-overview__label {
	display: flex;
	align-items: center;
	gap: 12px;
	padding: 22px 24px;
	background: #f0faff;
	border-right: 1px solid #e6f7ff;
	font-size: 14px;
	font-weight: 700;
	color: #425867;
}

.pet-about-overview__badge {
	width: 28px;
	height: 28px;
	border-radius: 50%;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	background: #00a3e0;
	color: #ffffff;
	font-size: 12px;
	font-weight: 900;
	flex-shrink: 0;
}

.pet-about-overview__content {
	padding: 22px 24px;
}

.pet-about-overview__content p,
.pet-about-overview__content li {
	margin: 0;
	font-size: 15px;
	line-height: 1.95;
	color: #516a7c;
}

.pet-about-overview__content ul {
	margin: 0;
	padding-left: 0;
	list-style: none;
	display: flex;
	flex-direction: column;
	gap: 8px;
}

.pet-about-overview__note {
	margin-top: 12px !important;
	color: #00a3e0 !important;
	font-weight: 700;
}

.pet-about-officers {
	background: #f0faff;
}

.pet-about-officers__grid {
	display: grid;
	grid-template-columns: repeat(3, minmax(0, 1fr));
	gap: 24px;
	margin-bottom: 40px;
}

.pet-about-card {
	background: #ffffff;
	border: 1px solid #e6f7ff;
	border-radius: 32px;
	overflow: hidden;
	box-shadow: 0 16px 36px rgba(17, 99, 145, 0.08);
}

.pet-about-card__photo {
	aspect-ratio: 4 / 3;
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	gap: 8px;
	background: #f0faff;
	border-bottom: 1px solid #e6f7ff;
}

.pet-about-card__photo-icon {
	font-size: 44px;
	line-height: 1;
	opacity: 0.45;
}

.pet-about-card__photo span {
	font-size: 11px;
	font-weight: 900;
	letter-spacing: 0.18em;
	color: #b3d8ee;
}

.pet-about-card__photo img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	display: block;
}

.pet-about-card__body {
	padding: 24px;
}

.pet-about-card__role,
.pet-about-row__role {
	display: inline-flex;
	align-items: center;
	padding: 7px 14px;
	border-radius: 999px;
	font-size: 12px;
	font-weight: 900;
}

.pet-about-card__role {
	background: #00a3e0;
	color: #ffffff;
}

.pet-about-card h3,
.pet-about-row h3 {
	margin: 14px 0 6px;
	font-size: 24px;
	font-weight: 900;
	color: #223847;
}

.pet-about-card__company {
	margin: 0 0 20px;
	font-size: 14px;
	line-height: 1.7;
	color: #5b7180;
}

.pet-about-card__meta {
	padding-top: 18px;
	border-top: 1px solid #e6f7ff;
	display: flex;
	flex-direction: column;
	gap: 10px;
}

.pet-about-card__meta p,
.pet-about-row__details p {
	margin: 0;
	font-size: 14px;
	line-height: 1.8;
	color: #516a7c;
}

.pet-about-row__details strong,
.pet-about-card__meta strong {
	display: inline-block;
	min-width: 10px;
	margin-right: 8px;
	color: #00a3e0;
	font-weight: 900;
}
.pet-about-officers__list {
	display: flex;
	flex-direction: column;
	gap: 16px;
}

.pet-about-row {
	display: grid;
	grid-template-columns: 240px 1px minmax(0, 1fr);
	align-items: center;
	gap: 24px;
	padding: 26px;
	border-radius: 22px;
	background: #ffffff;
	border: 1px solid #e6f7ff;
	box-shadow: 0 12px 26px rgba(17, 99, 145, 0.06);
}

.pet-about-row__role {
	background: #e6f7ff;
	color: #00a3e0;
}

.pet-about-row__identity h3 {
	margin-bottom: 0;
}

.pet-about-row__divider {
	width: 1px;
	height: 56px;
	background: #e6f7ff;
}

.pet-about-row__details {
	display: flex;
	flex-direction: column;
	gap: 8px;
}

.pet-about-row__contact {
	display: flex;
	flex-wrap: wrap;
	gap: 12px 28px;
}

@media only screen and (max-width: 1024px) {
	.pet-about-officers__grid {
		grid-template-columns: 1fr;
	}

	.pet-about-row {
		grid-template-columns: 1fr;
		gap: 16px;
	}

	.pet-about-row__divider {
		display: none;
	}
}

@media only screen and (max-width: 768px) {
	.pet-about-hero {
		min-height: 340px;
		padding-top: 76px;
	}

	.pet-about-hero__content {
		padding-bottom: 36px;
	}

	.pet-about-block__head {
		align-items: flex-start;
	}

	.pet-about-block__body {
		padding-left: 0;
	}

	.pet-about-overview__item {
		grid-template-columns: 1fr;
	}

	.pet-about-overview__label {
		border-right: 0;
		border-bottom: 1px solid #e6f7ff;
	}
}

/* 2026-06 join page recreation */
.pet-join-page {
	background: #ffffff;
}

.pet-join-shell {
	width: min(1040px, calc(100% - 32px));
}

.pet-join-hero {
	position: relative;
	min-height: 420px;
	padding-top: 88px;
	display: flex;
	align-items: flex-end;
	overflow: hidden;
}

.pet-join-hero__bg,
.pet-join-hero__overlay {
	position: absolute;
	inset: 0;
}

.pet-join-hero__bg {
	background: linear-gradient(135deg, #a8d8f0 0%, #d6effa 50%, #b8e0ee 100%);
}

.pet-join-hero__animals {
	position: absolute;
	inset: 0;
	display: flex;
	align-items: center;
	justify-content: center;
	gap: 56px;
	opacity: 0.18;
}

.pet-join-hero__dog,
.pet-join-hero__cat {
	position: relative;
	background: #00a3e0;
}

.pet-join-hero__dog {
	width: 220px;
	height: 110px;
	border-radius: 50% 50% 42% 42%;
}

.pet-join-hero__dog::before {
	content: "";
	position: absolute;
	right: -36px;
	top: -34px;
	width: 96px;
	height: 96px;
	border-radius: 50%;
	background: #00a3e0;
}

.pet-join-hero__dog::after {
	content: "";
	position: absolute;
	left: -16px;
	top: 14px;
	width: 34px;
	height: 88px;
	border-radius: 999px;
	border: 16px solid #00a3e0;
	border-right: 0;
	border-bottom: 0;
	background: transparent;
	transform: rotate(-30deg);
}

.pet-join-hero__cat {
	width: 150px;
	height: 150px;
	border-radius: 46% 46% 42% 42%;
}

.pet-join-hero__cat::before,
.pet-join-hero__cat::after {
	content: "";
	position: absolute;
	top: -28px;
	width: 0;
	height: 0;
	border-left: 20px solid transparent;
	border-right: 20px solid transparent;
	border-bottom: 34px solid #00a3e0;
}

.pet-join-hero__cat::before {
	left: 22px;
	transform: rotate(-12deg);
}

.pet-join-hero__cat::after {
	right: 22px;
	transform: rotate(12deg);
}

.pet-join-hero__overlay--bottom {
	background: linear-gradient(to top, rgba(255, 255, 255, 1), rgba(255, 255, 255, 0.1), rgba(255, 255, 255, 0));
}

.pet-join-hero__overlay--top {
	background: linear-gradient(to bottom, rgba(0, 0, 0, 0.24), rgba(0, 0, 0, 0));
}

.pet-join-hero__content {
	position: relative;
	z-index: 1;
	padding-bottom: 56px;
}

.pet-join-hero__breadcrumb {
	display: flex;
	align-items: center;
	gap: 8px;
	margin-bottom: 14px;
	font-size: 14px;
	color: #5b7180;
}

.pet-join-hero__breadcrumb a:hover {
	color: #00a3e0;
}

.pet-join-hero__breadcrumb span:last-child {
	color: #00a3e0;
	font-weight: 700;
}

.pet-join-hero h1 {
	margin: 0;
	font-size: clamp(38px, 6vw, 50px);
	font-weight: 900;
	color: #223847;
}

.pet-join-hero__line {
	width: 68px;
	height: 6px;
	margin-top: 18px;
	border-radius: 999px;
	background: #00a3e0;
}

.pet-join-heading {
	margin-bottom: 48px;
}

.pet-join-heading--center {
	text-align: center;
}

.pet-join-heading__tag {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	padding: 10px 18px;
	border-radius: 999px;
	background: #e6f7ff;
	color: #00a3e0;
	font-size: 12px;
	font-weight: 900;
	letter-spacing: 0.16em;
	text-transform: uppercase;
	margin-bottom: 18px;
}

.pet-join-heading__tag--light {
	background: #ffffff;
	border: 1px solid #d0edfa;
}

.pet-join-heading h2 {
	margin: 0;
	font-size: clamp(32px, 4vw, 40px);
	font-weight: 900;
	color: #223847;
}

.pet-join-heading__sub {
	margin: 16px 0 0;
	font-size: 22px;
	font-weight: 900;
	color: #00a3e0;
}

.pet-join-intro__lead {
	margin: 0;
	text-align: center;
	font-size: clamp(26px, 3vw, 40px);
	font-weight: 900;
	color: #00a3e0;
}

.pet-join-benefits {
	background: #f0faff;
}

.pet-join-benefits__grid {
	display: grid;
	grid-template-columns: repeat(3, minmax(0, 1fr));
	gap: 20px;
}

.pet-join-benefit-card {
	background: #ffffff;
	border: 1px solid #e6f7ff;
	border-radius: 22px;
	box-shadow: 0 12px 26px rgba(17, 99, 145, 0.06);
	padding: 24px;
	display: flex;
	align-items: flex-start;
	gap: 16px;
}

.pet-join-benefit-card__icon {
	width: 40px;
	height: 40px;
	border-radius: 50%;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	background: #e6f7ff;
	color: #00a3e0;
	font-size: 16px;
	font-weight: 900;
	flex-shrink: 0;
}

.pet-join-benefit-card p {
	margin: 0;
	font-size: 15px;
	line-height: 1.9;
	color: #516a7c;
	font-weight: 700;
}

.pet-join-fees__panel {
	padding: 38px 24px;
	border-radius: 40px;
	border: 2px solid #d0edfa;
	background: #f0faff;
	text-align: center;
}

.pet-join-fees__caption {
	margin: 0 0 28px;
	font-size: 22px;
	font-weight: 900;
	color: #5b7180;
}

.pet-join-fees__cards {
	display: flex;
	align-items: center;
	justify-content: center;
	gap: 28px;
}

.pet-join-fees__card {
	min-width: 180px;
	padding: 26px 28px;
	border-radius: 22px;
	border: 1px solid #b3dcf0;
	background: #ffffff;
	box-shadow: 0 14px 28px rgba(17, 99, 145, 0.08);
}

.pet-join-fees__label {
	display: block;
	margin-bottom: 12px;
	font-size: 12px;
	font-weight: 900;
	letter-spacing: 0.14em;
	color: #00a3e0;
	text-transform: uppercase;
}

.pet-join-fees__card p {
	margin: 0;
	font-size: 52px;
	font-weight: 900;
	color: #223847;
	line-height: 1;
}

.pet-join-fees__card p span {
	font-size: 28px;
	color: #6b7e8a;
}

.pet-join-fees__separator {
	font-size: 36px;
	font-weight: 900;
	color: #94aebb;
}

.pet-join-fees__note {
	margin-top: 20px;
	padding: 18px 24px;
	border-radius: 18px;
	border: 1px solid #f2e1aa;
	background: #fffbf0;
	text-align: center;
}

.pet-join-fees__note p,
.pet-join-notes__item p {
	margin: 0;
	font-size: 15px;
	line-height: 1.9;
	color: #516a7c;
}

.pet-join-notes {
	background: #f8fdff;
}

.pet-join-notes__box {
	padding: 34px;
	border-radius: 22px;
	border: 1px solid #e6f7ff;
	background: #ffffff;
	box-shadow: 0 12px 26px rgba(17, 99, 145, 0.05);
	display: flex;
	flex-direction: column;
	gap: 20px;
}

.pet-join-notes__item {
	display: flex;
	align-items: flex-start;
	gap: 12px;
}

.pet-join-notes__icon {
	width: 24px;
	height: 24px;
	border-radius: 50%;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	background: #f7d98d;
	color: #9a6a00;
	font-size: 14px;
	font-weight: 900;
	flex-shrink: 0;
	margin-top: 3px;
}

.pet-join-contact__banner {
	margin-bottom: 28px;
	padding: 22px 28px;
	border-radius: 20px;
	background: #00a3e0;
	color: #ffffff;
}

.pet-join-contact__banner p {
	margin: 0;
	font-size: 16px;
	line-height: 1.8;
	font-weight: 900;
}

.pet-join-contact__grid {
	display: grid;
	grid-template-columns: repeat(2, minmax(0, 1fr));
	gap: 20px;
}

.pet-join-contact-card {
	padding: 24px;
	border-radius: 22px;
	background: #ffffff;
	border: 1px solid #e6f7ff;
	box-shadow: 0 12px 26px rgba(17, 99, 145, 0.06);
}

.pet-join-contact-card.is-main {
	border-color: #00a3e0;
	box-shadow: 0 0 0 1px rgba(0, 163, 224, 0.2), 0 12px 26px rgba(17, 99, 145, 0.06);
}

.pet-join-contact-card__head {
	display: flex;
	align-items: center;
	gap: 12px;
	margin-bottom: 16px;
}

.pet-join-contact-card__role {
	padding: 7px 14px;
	border-radius: 999px;
	background: #e6f7ff;
	color: #00a3e0;
	font-size: 12px;
	font-weight: 900;
}

.pet-join-contact-card.is-main .pet-join-contact-card__role {
	background: #00a3e0;
	color: #ffffff;
}

.pet-join-contact-card__name {
	font-size: 20px;
	font-weight: 900;
	color: #223847;
}

.pet-join-contact-card__body {
	display: flex;
	flex-direction: column;
	gap: 8px;
}

.pet-join-contact-card__body p {
	margin: 0;
	font-size: 14px;
	line-height: 1.8;
	color: #516a7c;
}

.pet-join-contact-card__body strong {
	display: inline-block;
	min-width: 18px;
	margin-right: 8px;
	color: #00a3e0;
	font-weight: 900;
}

.pet-join-contact-card__row {
	display: flex;
	flex-wrap: wrap;
	gap: 12px 24px;
}

.pet-join-special {
	background: #f0faff;
}

.pet-join-special__grid {
	display: grid;
	grid-template-columns: repeat(3, minmax(0, 1fr));
	gap: 20px;
	margin-bottom: 34px;
}

.pet-join-special-card {
	padding: 24px;
	border-radius: 22px;
	border: 2px solid #d5edf8;
	background: #ffffff;
	box-shadow: 0 12px 26px rgba(17, 99, 145, 0.05);
}

.pet-join-special-card__badge {
	display: inline-flex;
	padding: 7px 12px;
	border-radius: 999px;
	background: #00a3e0;
	color: #ffffff;
	font-size: 12px;
	font-weight: 900;
	margin-bottom: 16px;
}

.pet-join-special-card p {
	margin: 0;
	font-size: 16px;
	line-height: 1.8;
	font-weight: 700;
	color: #223847;
}

.pet-join-special__list {
	padding: 28px;
	border-radius: 22px;
	border: 1px solid #e6f7ff;
	background: #ffffff;
	box-shadow: 0 12px 26px rgba(17, 99, 145, 0.05);
	display: flex;
	flex-direction: column;
	gap: 16px;
}

.pet-join-special__item {
	display: flex;
	align-items: flex-start;
	gap: 12px;
}

.pet-join-special__check {
	width: 22px;
	height: 22px;
	border-radius: 50%;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	background: #00a3e0;
	color: #ffffff;
	font-size: 13px;
	font-weight: 900;
	flex-shrink: 0;
	margin-top: 2px;
}

.pet-join-special__item p {
	margin: 0;
	font-size: 16px;
	line-height: 1.8;
	color: #516a7c;
}

.pet-join-download__panel {
	position: relative;
	padding: 56px 28px;
	border-radius: 48px;
	background: linear-gradient(135deg, #00a3e0 0%, #0080b5 100%);
	color: #ffffff;
	text-align: center;
	overflow: hidden;
	box-shadow: 0 24px 54px rgba(70, 157, 208, 0.34);
}

.pet-join-download__panel::before {
	content: "";
	position: absolute;
	inset: 0;
	background:
		radial-gradient(circle at 10% 20%, rgba(255,255,255,0.08) 0 14px, transparent 15px),
		radial-gradient(circle at 24% 16%, rgba(255,255,255,0.08) 0 10px, transparent 11px),
		radial-gradient(circle at 40% 26%, rgba(255,255,255,0.08) 0 14px, transparent 15px),
		radial-gradient(circle at 72% 18%, rgba(255,255,255,0.08) 0 12px, transparent 13px),
		radial-gradient(circle at 86% 24%, rgba(255,255,255,0.08) 0 14px, transparent 15px),
		radial-gradient(circle at 18% 74%, rgba(255,255,255,0.08) 0 12px, transparent 13px),
		radial-gradient(circle at 52% 78%, rgba(255,255,255,0.08) 0 14px, transparent 15px),
		radial-gradient(circle at 80% 72%, rgba(255,255,255,0.08) 0 12px, transparent 13px);
	pointer-events: none;
}

.pet-join-download__icon,
.pet-join-download__button {
	position: relative;
	z-index: 1;
}

.pet-join-download__icon {
	width: 64px;
	height: 64px;
	margin: 0 auto 24px;
	border-radius: 50%;
	display: flex;
	align-items: center;
	justify-content: center;
	background: rgba(255, 255, 255, 0.18);
	font-size: 30px;
	font-weight: 900;
}

.pet-join-download__panel h2 {
	position: relative;
	z-index: 1;
	margin: 0 0 32px;
	font-size: clamp(30px, 4vw, 40px);
	font-weight: 900;
}

.pet-join-download__button {
	display: inline-flex;
	align-items: center;
	gap: 14px;
	padding: 20px 34px;
	border-radius: 999px;
	background: #ffffff;
	color: #00a3e0;
	font-size: clamp(18px, 2.4vw, 30px);
	font-weight: 900;
	box-shadow: 0 16px 32px rgba(16, 72, 105, 0.22);
}

@media only screen and (max-width: 1024px) {
	.pet-join-benefits__grid,
	.pet-join-special__grid {
		grid-template-columns: repeat(2, minmax(0, 1fr));
	}
}

@media only screen and (max-width: 768px) {
	.pet-join-hero {
		min-height: 340px;
		padding-top: 76px;
	}

	.pet-join-hero__content {
		padding-bottom: 36px;
	}

	.pet-join-hero__animals {
		gap: 28px;
	}

	.pet-join-hero__dog {
		width: 150px;
		height: 76px;
	}

	.pet-join-hero__dog::before {
		width: 64px;
		height: 64px;
		right: -24px;
		top: -22px;
	}

	.pet-join-hero__cat {
		width: 98px;
		height: 98px;
	}

	.pet-join-benefits__grid,
	.pet-join-contact__grid,
	.pet-join-special__grid {
		grid-template-columns: 1fr;
	}

	.pet-join-fees__cards {
		flex-direction: column;
	}

	.pet-join-fees__separator {
		display: none;
	}
}
