@charset "UTF-8";
/* ============================================================
   SipsTool 会員ログインページ — 全面リニューアル (2026-05-22)
   基準  : www.sipstool.jp トップページのデザインテイスト
   tokens: #EEBF04 (accent) / #1f2937 (text) / Inter + Noto Sans JP
   注意  : 認証 iframe (aspkanri/disp_renew.php) は機能保全。ガワのみ刷新。
   ============================================================ */
@import url('https://fonts.googleapis.com/css2?family=Inter:wght@400;600;700;800&family=Noto+Sans+JP:wght@400;500;700&display=swap');

/* ---- reset ---- */
* { box-sizing: border-box; }
html, body { margin: 0; padding: 0; }

body#login {
	font-family: "Inter", "Noto Sans JP", -apple-system, BlinkMacSystemFont,
		"Segoe UI", "Hiragino Kaku Gothic ProN", "Yu Gothic", Meiryo, sans-serif;
	font-feature-settings: "palt";
	color: #1f2937;
	background: #f4f6f8;
	line-height: 1.8;
	-webkit-text-size-adjust: 100%;
	-webkit-font-smoothing: antialiased;
}
body#login img { max-width: 100%; height: auto; vertical-align: bottom; }
body#login a { color: #1f2937; }

/* ============================================================
   Buttons (shared)
   ============================================================ */
.btn {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: 0.375rem;
	min-height: 46px;
	padding: 0.625rem 1.5rem;
	font-family: inherit;
	font-size: 0.95rem;
	font-weight: 700;
	line-height: 1.3;
	text-decoration: none;
	border-radius: 999px;
	border: 2px solid transparent;
	cursor: pointer;
	white-space: nowrap;
	transition: transform 0.15s ease, box-shadow 0.15s ease,
		background 0.15s ease, border-color 0.15s ease;
}
.btn-primary {
	background: #EEBF04;
	color: #1f2937;
	border-color: #EEBF04;
	box-shadow: 0 2px 6px rgba(238, 191, 4, 0.30);
}
.btn-primary:hover {
	background: #d4ab03;
	border-color: #d4ab03;
	transform: translateY(-1px);
	box-shadow: 0 4px 12px rgba(238, 191, 4, 0.42);
}
.btn-ghost {
	background: #ffffff;
	color: #1f2937;
	border-color: #d1d5db;
}
.btn-ghost:hover {
	background: #f9fafb;
	border-color: #9ca3af;
	transform: translateY(-1px);
}
.btn-block { width: 100%; }

/* ============================================================
   Header
   ============================================================ */
.site-header {
	background: #ffffff;
	border-bottom: 1px solid #e5e7eb;
	box-shadow: 0 1px 3px rgba(17, 24, 39, 0.04);
}
.header-inner {
	max-width: 1120px;
	margin: 0 auto;
	padding: 0.875rem 1.5rem;
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 1rem;
}
.site-logo {
	display: inline-flex;
	align-items: center;
	gap: 0.5rem;
	text-decoration: none;
}
.site-logo-text {
	font-size: 1.25rem;
	font-weight: 800;
	letter-spacing: 0.01em;
	color: #111827;
}
.header-actions {
	display: flex;
	align-items: center;
	gap: 0.625rem;
}

/* ============================================================
   Hero
   ============================================================ */
.hero {
	background: linear-gradient(180deg, #ffffff 0%, #f4f6f8 100%);
	border-bottom: 1px solid #eef0f2;
}
.hero-inner {
	max-width: 1120px;
	margin: 0 auto;
	padding: 3.25rem 1.5rem 2.75rem;
	text-align: center;
}
.hero-eyebrow {
	display: inline-block;
	margin: 0 0 0.875rem;
	padding: 0.3rem 0.9rem;
	background: rgba(238, 191, 4, 0.16);
	color: #8a6d00;
	font-size: 0.8125rem;
	font-weight: 700;
	letter-spacing: 0.04em;
	border-radius: 999px;
}
.hero-title {
	margin: 0 0 1rem;
	font-size: 2rem;
	font-weight: 800;
	line-height: 1.4;
	color: #111827;
}
.hero-lead {
	margin: 0 auto;
	color: #4b5563;
	font-size: 1.0625rem;
}

/* ============================================================
   Login section (2 columns)
   ============================================================ */
.login-section {
	max-width: 1120px;
	margin: 0 auto;
	padding: 3rem 1.5rem 3.5rem;
}
.login-grid {
	display: grid;
	grid-template-columns: 1fr 400px;
	gap: 2.5rem;
	align-items: start;
}

/* ---- left: promo ---- */
.promo { padding-top: 0.5rem; }
.promo-title {
	margin: 0 0 1rem;
	font-size: 1.5rem;
	font-weight: 800;
	line-height: 1.45;
	color: #111827;
}
.promo-text {
	margin: 0 0 1.5rem;
	color: #374151;
	font-size: 1rem;
}
.promo-list { margin: 0; padding: 0; list-style: none; }
.promo-list li {
	display: flex;
	align-items: flex-start;
	gap: 0.625rem;
	padding: 0.7rem 0;
	border-bottom: 1px dashed #e5e7eb;
	font-size: 0.975rem;
	color: #1f2937;
}
.promo-list li:last-child { border-bottom: 0; }
.promo-ico {
	flex: none;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 22px;
	height: 22px;
	margin-top: 0.2rem;
	background: #EEBF04;
	color: #1f2937;
	font-size: 0.8rem;
	font-weight: 800;
	border-radius: 50%;
}

/* ---- right: login card ---- */
.login-card {
	background: #ffffff;
	border: 1px solid #e5e7eb;
	border-top: 4px solid #EEBF04;
	border-radius: 14px;
	padding: 1.75rem 1.5rem 1.5rem;
	box-shadow: 0 10px 30px rgba(17, 24, 39, 0.09);
}
.login-frame {
	border: 1px solid #e5e7eb;
	border-radius: 10px;
	background: #f8f8f8;
	overflow: hidden;
	/* フォーム(iframe)と枠線の間に余白 */
	padding: 1em;
}
/* 認証フォーム — src/動作は HTML 側で保全。ここは外枠サイズのみ。
   高さはリニューアル版トップの login modal (350px / SP 380px) に合わせる */
.auth-iframe {
	display: block;
	width: 100%;
	height: 350px;
	border: 0;
}
.login-card-actions {
	display: flex;
	flex-direction: column;
	gap: 0.625rem;
	margin-top: 1.25rem;
}
.login-card-tel {
	margin: 1rem 0 0;
	text-align: center;
	font-size: 0.875rem;
	color: #6b7280;
}
.login-card-tel a {
	font-weight: 700;
	color: #1f2937;
	text-decoration: none;
}

/* ============================================================
   Footer
   ============================================================ */
.site-footer {
	background: #1f2937;
	color: #d1d5db;
	margin-top: 1rem;
}
.footer-inner {
	max-width: 1120px;
	margin: 0 auto;
	padding: 2.5rem 1.5rem 2rem;
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
	gap: 1.75rem;
}
.footer-brand { flex: 1 1 380px; min-width: 0; }
.footer-logo {
	display: inline-block;
	font-size: 1.25rem;
	font-weight: 800;
	letter-spacing: 0.01em;
	color: #ffffff;
	text-decoration: none;
}
.footer-tagline {
	margin: 0.5rem 0 0.875rem;
	font-size: 0.9rem;
	color: #e5e7eb;
}
.footer-address,
.footer-contact {
	margin: 0.15rem 0;
	font-size: 0.8125rem;
	color: #9ca3af;
}
.footer-actions {
	flex: none;
	display: flex;
	flex-direction: column;
	gap: 0.625rem;
	align-content: flex-start;
}
.footer-actions .btn { min-width: 160px; }
.footer-copy {
	border-top: 1px solid #374151;
	padding: 1rem 1.5rem;
	text-align: center;
	font-size: 0.75rem;
	color: #9ca3af;
}

/* ============================================================
   Responsive
   ============================================================ */
/* PC 表示ではヒーローの見出し・リード文を 1 行で表示 */
@media (min-width: 901px) {
	.hero-title,
	.hero-lead { white-space: nowrap; }
}

@media (max-width: 900px) {
	.login-grid {
		grid-template-columns: 1fr;
		gap: 2rem;
	}
	.login-card {
		width: 100%;
		max-width: 460px;
		margin: 0 auto;
	}
	.promo {
		max-width: 560px;
		margin: 0 auto;
	}
}

@media (max-width: 600px) {
	.header-inner { padding: 0.75rem 1rem; }
	.site-logo-text { font-size: 1.125rem; }
	.header-actions .btn {
		min-height: 40px;
		padding: 0.5rem 0.9rem;
		font-size: 0.85rem;
	}
	.hero-inner { padding: 2.5rem 1.25rem 2.25rem; }
	.hero-title { font-size: 1.5rem; }
	.hero-lead { font-size: 1rem; }
	.login-section { padding: 2.25rem 1.25rem 2.75rem; }
	.login-card { padding: 1.5rem 1.125rem 1.25rem; }
	.auth-iframe { height: 380px; }
	.footer-inner {
		flex-direction: column;
		gap: 1.5rem;
		padding: 2.25rem 1.25rem 1.75rem;
	}
	/* 縦並び時は flex-basis:380px が高さに化けて巨大な余白を生むため解除 */
	.footer-brand { flex: none; }
	.footer-actions { width: 100%; }
	.footer-actions .btn { width: 100%; }
}

@media (max-width: 480px) {
	/* スマホでは資料請求はカード/フッターに集約しヘッダーを簡素化 */
	.header-actions .btn-ghost { display: none; }
}
