/**
 * 花火大会 持ち物＆服装チェッカー 専用スタイル
 * - 夜空×花火カラー、リスト型UI
 */

:root {
	--hnc-night-deep: #0F1740;
	--hnc-night: #1C2A66;
	--hnc-firework-red: #FF4B6E;
	--hnc-firework-yellow: #FFB923;
	--hnc-firework-blue: #4FC0E0;
	--hnc-firework-pink: #FF7BC1;
	--hnc-must: #C0392B;
	--hnc-rec: #DAA520;
	--hnc-nice: #4A8FE8;
}

.hnc-input-section {
	padding: 16px 20px;
}

.hnc-section-heading {
	font-family: var(--font-display);
	font-size: 16px;
	font-weight: 700;
	color: var(--color-text);
	margin: 0 0 12px;
	padding-left: 10px;
	border-left: 4px solid var(--hnc-firework-red);
}

.hnc-form-grid {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 12px 18px;
}

@media (max-width: 700px) {
	.hnc-form-grid {
		grid-template-columns: 1fr 1fr;
	}
}

@media (max-width: 460px) {
	.hnc-form-grid {
		grid-template-columns: 1fr;
	}
}

.hnc-form-group {
	display: flex;
	flex-direction: column;
	gap: 6px;
}

.hnc-form-label {
	font-size: 13px;
	font-weight: 600;
	color: var(--color-text);
}

.hnc-form-select {
	padding: 10px 12px;
	font-size: 14px;
	border: 1px solid var(--color-border);
	border-radius: 6px;
	background: var(--color-bg);
	font-family: inherit;
	cursor: pointer;
}

.hnc-form-select:focus {
	outline: none;
	border-color: var(--hnc-firework-red);
}

.hnc-action {
	padding: 18px 20px;
	text-align: center;
}

.hnc-action-btn {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	padding: 14px 36px;
	font-family: var(--font-display);
	font-size: 15px;
	font-weight: 700;
	color: #FFFFFF;
	background: linear-gradient(135deg, var(--hnc-firework-red) 0%, var(--hnc-firework-pink) 100%);
	border: none;
	border-radius: 28px;
	cursor: pointer;
	box-shadow: 0 4px 14px rgba(255, 75, 110, 0.30);
	letter-spacing: 0.04em;
}

.hnc-action-btn:hover {
	transform: translateY(-1px);
	filter: brightness(1.06);
}

/* ========================================
   結果セクション
   ======================================== */
.hnc-result-section {
	padding: 16px 20px;
	background: linear-gradient(180deg, #FFF0F4 0%, #FFFFFF 60%);
	border-top: 1px solid var(--color-border);
}

.hnc-result-heading {
	font-family: var(--font-display);
	font-size: 18px;
	font-weight: 700;
	color: var(--hnc-night);
	margin: 0 0 14px;
	text-align: center;
}

.hnc-summary {
	display: grid;
	grid-template-columns: repeat(4, 1fr);
	gap: 8px;
	padding: 12px;
	background:
		radial-gradient(circle at 20% 30%, rgba(255, 75, 110, 0.10) 0, transparent 40%),
		radial-gradient(circle at 80% 70%, rgba(79, 192, 224, 0.10) 0, transparent 40%),
		linear-gradient(135deg, #1C2A66 0%, #0F1740 100%);
	color: #FFFFFF;
	border-radius: 10px;
	margin-bottom: 16px;
}

@media (max-width: 460px) {
	.hnc-summary {
		grid-template-columns: repeat(2, 1fr);
	}
}

.hnc-summary-stat {
	text-align: center;
	padding: 6px 4px;
}

.hnc-summary-stat-num {
	display: block;
	font-family: var(--font-display);
	font-size: 26px;
	font-weight: 800;
	line-height: 1;
}

.hnc-summary-stat--must .hnc-summary-stat-num { color: #FF7B8E; }
.hnc-summary-stat--rec .hnc-summary-stat-num { color: var(--hnc-firework-yellow); }
.hnc-summary-stat--nice .hnc-summary-stat-num { color: var(--hnc-firework-blue); }

.hnc-summary-stat-label {
	display: block;
	margin-top: 4px;
	font-size: 11px;
	letter-spacing: 0.05em;
	color: rgba(255, 255, 255, 0.85);
}

/* チェックリストグループ */
.hnc-checklist-group {
	margin-bottom: 16px;
	background: #FFFFFF;
	border: 1px solid var(--color-border);
	border-radius: 10px;
	overflow: hidden;
}

.hnc-checklist-title {
	margin: 0;
	padding: 10px 14px;
	font-family: var(--font-display);
	font-size: 14px;
	font-weight: 700;
	color: #FFFFFF;
}

.hnc-checklist-group--must .hnc-checklist-title {
	background: linear-gradient(90deg, var(--hnc-must) 0%, #8E1F14 100%);
}

.hnc-checklist-group--rec .hnc-checklist-title {
	background: linear-gradient(90deg, var(--hnc-rec) 0%, #B58A23 100%);
}

.hnc-checklist-group--nice .hnc-checklist-title {
	background: linear-gradient(90deg, var(--hnc-nice) 0%, #2E6FB5 100%);
}

.hnc-item-list {
	list-style: none;
	padding: 0;
	margin: 0;
}

.hnc-item {
	display: flex;
	align-items: flex-start;
	gap: 10px;
	padding: 10px 14px;
	border-bottom: 1px solid var(--color-border-light, #EAE7E0);
	cursor: pointer;
	transition: background 0.15s ease;
}

.hnc-item:last-child {
	border-bottom: none;
}

.hnc-item:hover {
	background: #FAFAF8;
}

.hnc-item-check {
	flex-shrink: 0;
	width: 20px;
	height: 20px;
	border: 2px solid var(--color-border);
	border-radius: 4px;
	background: #FFFFFF;
	display: flex;
	align-items: center;
	justify-content: center;
	font-family: var(--font-display);
	font-size: 12px;
	font-weight: 800;
	color: transparent;
	margin-top: 1px;
}

.hnc-item.is-checked .hnc-item-check {
	background: var(--color-text);
	border-color: var(--color-text);
	color: #FFFFFF;
}

.hnc-item.is-checked .hnc-item-name {
	text-decoration: line-through;
	color: var(--color-text-muted);
}

.hnc-item-body {
	flex: 1;
	min-width: 0;
}

.hnc-item-name {
	font-weight: 600;
	color: var(--color-text);
	font-size: 14px;
}

.hnc-item-note {
	margin-top: 2px;
	font-size: 11.5px;
	color: var(--color-text-secondary);
	line-height: 1.5;
}

/* ========================================
   アドバイスセクション
   ======================================== */
.hnc-advice-section {
	padding: 14px 16px;
	background: #F7F4FF;
	border: 1px solid #D9CBFF;
	border-left: 4px solid #8A4FFF;
	border-radius: 8px;
	margin-bottom: 16px;
}

.hnc-advice-title {
	font-family: var(--font-display);
	font-size: 14px;
	font-weight: 700;
	color: #2D1B5C;
	margin: 0 0 8px;
}

.hnc-advice-list {
	list-style: none;
	padding: 0;
	margin: 0;
	display: flex;
	flex-direction: column;
	gap: 6px;
}

.hnc-advice-list li {
	padding-left: 18px;
	position: relative;
	font-size: 13px;
	line-height: 1.7;
	color: var(--color-text);
}

.hnc-advice-list li::before {
	content: '';
	position: absolute;
	left: 0;
	top: 0.55em;
	width: 8px;
	height: 8px;
	background: #8A4FFF;
	border-radius: 50%;
}

.hnc-advice-list strong {
	color: #5C2BCC;
}

/* ========================================
   アクション
   ======================================== */
.hnc-actions {
	display: flex;
	gap: 10px;
	justify-content: center;
	flex-wrap: wrap;
	margin-top: 10px;
}

.hnc-btn-copy,
.hnc-btn-print {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	padding: 10px 22px;
	font-family: var(--font-display);
	font-size: 13.5px;
	font-weight: 700;
	border-radius: 22px;
	cursor: pointer;
	border: none;
	letter-spacing: 0.04em;
}

.hnc-btn-copy {
	background: linear-gradient(135deg, var(--hnc-firework-red) 0%, var(--hnc-firework-pink) 100%);
	color: #FFFFFF;
}

.hnc-btn-print {
	background: #FFFFFF;
	color: var(--color-text);
	border: 1px solid var(--color-border);
}

.hnc-btn-copy:hover,
.hnc-btn-print:hover {
	filter: brightness(1.06);
}

@media print {
	.page-header, .breadcrumb, .card, .hnc-input-section, .hnc-action, .hnc-actions { display: none !important; }
	.hnc-result-section { background: #FFFFFF !important; padding: 0; }
	.hnc-summary { background: #F0F0F0 !important; color: #000 !important; }
	.hnc-checklist-title { background: #E0E0E0 !important; color: #000 !important; }
}
