/****************************************

	Namespace:
	fras (frebull-age-simulator)

*****************************************/

input[type='date'] {
	appearance: none; /* ブラウザのデフォルトスタイルを無効化 */
	-webkit-appearance: none;
	-moz-appearance: none;
	background-color: white;
	/* その他のスタイル指定 */
}

.fras-wrap * {
	box-sizing: border-box;
	margin: 0;
	padding: 0;
}
.fras-wrap {
	width: 100%;
	max-width: 780px;
	margin: 0 auto 60px;
	padding: 0;
}
.fras-card {
	background: rgba(255, 250, 242, 0.95);
	border: 1px solid rgba(192, 128, 64, 0.3);
	border-radius: 10px;
	padding: 20px;
}
.fras-header {
	text-align: center;
	margin-bottom: 22px;
}

.fras-header__title {
	font-size: clamp(20px, 5vw, 20px);
	font-weight: 800;
	color: #3d2b0e;
	/* line-height: 1.25; */
	margin-bottom: 6px;
}
.fras-header__sub {
	font-size: 10px;
	color: #8b6030;
	letter-spacing: 0.05em;
}
/* Tabs */
.fras-tabs {
	display: flex;
	margin-bottom: 18px;
	border-radius: 10px;
	overflow: hidden;
	border: 1.5px solid #c08040;
}
.fras-tab {
	flex: 1;
	padding: 10px 6px;
	border: none;
	background: transparent;
	color: #8b5e20;
	font-size: 14px;
	font-family: inherit;
	font-weight: bold;
	cursor: pointer;
	letter-spacing: 0.04em;
	transition: background 0.2s, color 0.2s;
	text-align: center;
}
.fras-tab.is-active {
	background: #c08040;
	color: #fff;
}
.fras-tab:not(.is-active):hover {
	background: #fdf0dc;
}
/* Input */
.fras-label {
	display: block;
	font-size: 12px;
	font-weight: bold;
	color: #5a3d15;
	letter-spacing: 0.08em;
	margin-bottom: 7px;
}
.fras-input {
	width: 100%;
	padding: 8px 16px;
	border: 2px solid #d4a96a;
	border-radius: 10px;
	font-size: 15px;
	font-family: inherit;
	background: rgba(255, 255, 255, 0.8);
	color: #3d2b0e;
	outline: none;
	transition: border 0.2s;
	-webkit-appearance: none;
}
.fras-input:focus {
	border-color: #c08040;
}
.fras-hint {
	font-size: 11px;
	color: #a08050;
	margin-top: 5px;
}
.fras-field {
	margin-bottom: 16px;
}

/* Button */
.fras-btn {
	width: 100%;
	padding: 10px 16px;
	background: #3d2b0e;
	color: #fff;
	border: none;
	border-radius: 100vmax;
	font-size: 16px;
	font-family: inherit;
	font-weight: bold;
	cursor: pointer;
	letter-spacing: 0.08em;
	transition: background 0.2s, transform 0.15s, box-shadow 0.2s;
	text-align: center;
}
.fras-btn:hover {
	background: #5a3d15;
	transform: translateY(-2px);
	box-shadow: 0 6px 20px rgba(61, 43, 14, 0.25);
}
.fras-btn:active {
	transform: translateY(0);
}
/* Result */
.fras-result {
	margin-top: 22px;
	animation: frasSlide 0.55s cubic-bezier(0.22, 1, 0.36, 1) both;
}
@keyframes frasSlide {
	from {
		opacity: 0;
		transform: translateY(20px) scale(0.97);
	}
	to {
		opacity: 1;
		transform: translateY(0) scale(1);
	}
}
.fras-result-card {
	padding: 20px;
	text-align: center;
	border: 2px solid transparent;
	position: relative;
	overflow: hidden;
}
.fras-face-wrap {
	margin-bottom: 10px;
	display: flex;
	justify-content: center;
}
.stage-image {
	height: 100px;
	width: auto;
}
.fras-stage-badge {
	display: inline-block;
	color: #fff;
	font-size: 12px;
	font-weight: bold;
	padding: 4px 48px;
	border-radius: 100vmax;
	letter-spacing: 0.08em;
	margin-bottom: 4px;
}
.fras-dog-age {
	font-size: 12px;
	color: #5a3d15;
}
.fras-dog-age-text {
	font-size: 14px;
}
.fras-human-age {
	line-height: 1;
	margin-bottom: 8px;
}
.fras-human-age__num {
	font-size: clamp(64px, 18vw, 80px);
	font-weight: 800;
	/* font-family: 'Georgia', serif; */
	letter-spacing: -0.02em;
}
.fras-human-age__unit {
	font-size: 14px;
	color: #5a3d15;
	font-weight: bold;
	margin-left: 2px;
}
.fras-human-age__label {
	font-size: 12px;
	color: #8b6030;
	margin-top: 4px;
}
.fras-stage-desc {
	margin-top: 20px;
	padding: 20px;
	background: rgba(255, 255, 255, 0.6);
	border-radius: 9px;
	font-size: 14px;
	color: #5a3d15;
	text-align: left;
}
/* Life stage bar */
.fras-bar-label {
	font-size: 10px;
	color: #a08050;
	letter-spacing: 0.1em;
	margin: 16px 0 6px;
	text-align: left;
}
.fras-bar {
	display: flex;
	height: 7px;
	border-radius: 99px;
	overflow: hidden;
	gap: 3px;
}
.fras-bar__seg {
	border-radius: 99px;
	transition: opacity 0.3s;
}
.fras-bar-names {
	display: flex;
	gap: 3px;
	margin-top: 4px;
}
.fras-bar-names span {
	font-size: 9px;
	color: #a08050;
	text-align: center;
}
/* Articles */
.fras-articles {
	margin-top: 22px;
}
.fras-articles__title {
	font-size: 16px;
	font-weight: bold;
	color: #3d2b0e;
	margin-bottom: 10px;
	letter-spacing: 0.05em;
}
.fras-article-list {
	display: flex;
	flex-direction: column;
	gap: 10px;
}
.fras-article-item {
	display: flex;
	align-items: center;
	gap: 10px;
	padding: 12px 20px;
	background: rgba(255, 255, 255, 0.65);
	border-radius: 0;
	border-left: 4px solid;
	text-decoration: none;
	color: inherit;
	transition: background 0.2s, transform 0.15s;
	animation: frasSlide 0.5s both;
}
.fras-article-item:hover {
	background: rgba(255, 255, 255, 0.92);
	transform: translateX(4px);
}
.fras-article-tag {
	font-size: 10px;
	font-weight: bold;
	padding: 3px 8px;
	border-radius: 4px;
	white-space: nowrap;
	letter-spacing: 0.04em;
	flex-shrink: 0;
}
.fras-article-text {
	font-size: 12px;
	color: #3d2b0e;
	flex: 1;
}
.fras-article-arr {
	color: #c08040;
	font-size: 15px;
	flex-shrink: 0;
}
/* Note */
.fras-note {
	font-size: 10px;
	color: #b09070;
	text-align: left;
	margin-top: 18px;
}
/* Zodiac */
.fras-zodiac {
	display: inline-flex;
	align-items: center;
	gap: 8px;
	margin-top: 14px;
	padding: 10px 20px;
	background: rgba(255, 255, 255, 0.55);
	border: 1.5px solid rgba(192, 128, 64, 0.3);
	border-radius: 99px;
	font-size: 13px;
	color: #5a3d15;
	letter-spacing: 0.05em;
}
.fras-zodiac__symbol {
	font-size: 22px;
	line-height: 1;
}
.fras-zodiac__name {
	font-weight: bold;
	font-size: 15px;
	color: #3d2b0e;
}
.fras-zodiac__period {
	font-size: 11px;
	color: #a08050;
	margin-left: 2px;
}
/* Hidden utility */
.fras-hidden {
	display: none !important;
}

@media (max-width: 576px) {
	#fras-input-bday {
		padding: 8px 0;
		-webkit-appearance: auto;
	}
}
