.ybr-section { padding: 60px 0; }
.ybr .hero-title { color: #fff; }
.ybr .card-desc-mb { margin-bottom: 16px; }
.ybr .legend-dot-0 { background-color: #e2e8f0; }
.ybr .legend-dot-u1 { background-color: #93c5fd; }
.ybr .legend-dot-u2 { background-color: #3b82f6; }
.ybr .legend-dot-u3 { background-color: #2563eb; }
.ybr .legend-dot-u4 { background-color: #1e40af; }
.ybr .legend-dot-o1 { background-color: #6ee7b7; }
.ybr .legend-dot-o2 { background-color: #10b981; }
.ybr .legend-dot-o3 { background-color: #059669; }
.ybr .legend-dot-o4 { background-color: #047857; }

.ybr {
	--ybr-bg-body: #f1f5f9;
	--ybr-text-main: #334155;
	--ybr-text-dark: #1e293b;
	--ybr-text-muted: #64748b;
	--ybr-text-light: #94a3b8;
	--ybr-color-primary: #1e3a8a;
	--ybr-color-secondary: #3b82f6;
	--ybr-color-emerald: #10b981;
	--ybr-color-amber: #f59e0b;
	--ybr-color-slate: #94a3b8;
	--ybr-border-color: #f1f5f9;
	--ybr-card-bg: #ffffff;
	font-size: 16px;
	font-family: 'Noto Sans JP', sans-serif;
	color: var(--ybr-text-main);
	-webkit-font-smoothing: antialiased;
}
.ybr *, .ybr *::before, .ybr *::after { box-sizing: border-box; }
.ybr .font-oswald { font-family: 'Oswald', sans-serif; }
.ybr ::-webkit-scrollbar { width: 6px; height: 6px; }
.ybr ::-webkit-scrollbar-track { background: transparent; }
.ybr ::-webkit-scrollbar-thumb { background: #cbd5e1; border-radius: 3px; }
.ybr ::-webkit-scrollbar-thumb:hover { background: #94a3b8; }
.ybr .ybr-container { max-width: 1152px; margin: 0 auto; padding: 0 16px; position: relative; z-index: 10; width: 100%; }
.ybr .ybr-header { background: linear-gradient(to bottom right, #0f172a, var(--ybr-color-primary), #1e3a8a); color: white; padding: 40px 0; position: relative; overflow: hidden; box-shadow: 0 10px 15px -3px rgba(0, 0, 0, 0.1); }
.ybr .header-bg-circle-1 { position: absolute; top: -80px; right: -80px; width: 384px; height: 384px; border-radius: 50%; background: white; opacity: 0.05; filter: blur(40px); pointer-events: none; }
.ybr .header-bg-circle-2 { position: absolute; bottom: -80px; left: -80px; width: 288px; height: 288px; border-radius: 50%; background: #60a5fa; opacity: 0.1; filter: blur(40px); pointer-events: none; }
.ybr .header-content { text-align: center; }
.ybr .hero-badge { display: inline-flex; align-items: center; gap: 8px; padding: 6px 16px; border-radius: 9999px; border: 1px solid rgba(255, 255, 255, 0.2); background: rgba(255, 255, 255, 0.1); backdrop-filter: blur(4px); margin-bottom: 24px; }
.ybr .hero-badge span { font-size: 14px; letter-spacing: 0.2em; color: #dbeafe; text-transform: uppercase; }
.ybr .hero-title { font-size: 30px; font-weight: 900; letter-spacing: -0.025em; margin: 0 0 8px 0; }
.ybr .hero-subtitle { color: #bfdbfe; font-size: 16px; letter-spacing: 0.1em; font-weight: 500; margin: 0 0 24px 0; }
.ybr .amount-wrapper { margin-bottom: 16px; }
.ybr .amount-label { font-size: 16px; letter-spacing: 0.2em; color: #93c5fd; text-transform: uppercase; margin: 0 0 12px 0; }
.ybr .amount-value { display: flex; align-items: flex-start; justify-content: center; font-size: 40px; font-weight: 700; letter-spacing: -0.05em; text-shadow: 0 4px 6px rgba(0,0,0,0.1); line-height: 1; white-space: nowrap; }
.ybr .amount-value .currency { font-size: 20px; font-weight: 400; color: #93c5fd; margin-top: 4px; margin-right: 4px; }
.ybr .amount-value .dash { font-size: 20px; font-weight: 400; color: #93c5fd; margin-top: auto; margin-bottom: 4px; margin-left: 4px; }
.ybr .hero-stats { display: flex; flex-wrap: wrap; justify-content: center; gap: 32px; margin-top: 32px; padding-top: 32px; border-top: 1px solid rgba(255, 255, 255, 0.1); }
.ybr .stat-item { text-align: center; }
.ybr .stat-label { display: flex; align-items: center; justify-content: center; gap: 8px; color: #bfdbfe; font-size: 14px; letter-spacing: 0.05em; margin-bottom: 4px; }
.ybr .stat-value { font-size: 36px; font-weight: 700; color: white; }
.ybr .stat-unit { font-family: 'Noto Sans JP', sans-serif; font-size: 18px; font-weight: 400; color: #bfdbfe; margin-left: 4px; }
.ybr .ybr-main-content { margin-top: 32px; padding-bottom: 40px; position: relative; z-index: 20; }
.ybr .section-mb { margin-bottom: 40px; }
.ybr .section-header { display: flex; align-items: center; gap: 12px; margin-bottom: 16px; padding-left: 8px; }
.ybr .section-line { width: 6px; height: 24px; background-color: var(--ybr-color-secondary); border-radius: 9999px; }
.ybr .section-title { font-size: 20px; font-weight: 700; color: var(--ybr-text-dark); margin: 0; }
.ybr .grid-5 { display: grid; grid-template-columns: repeat(2, 1fr); gap: 16px; }
.ybr .grid-2 { display: grid; grid-template-columns: 1fr; gap: 24px; }
.ybr .grid-2-inner { display: flex; flex-direction: column; gap: 24px; }
.ybr .grid-2-inner > .ybr-card { flex: 1; }
.ybr .ybr-card { background-color: var(--ybr-card-bg); border-radius: 16px; padding: 20px; box-shadow: 0 1px 2px 0 rgba(0, 0, 0, 0.05); border: 1px solid var(--ybr-border-color); display: flex; flex-direction: column; }
.ybr .card-stat { position: relative; overflow: hidden; transition: transform 0.2s ease, box-shadow 0.2s ease; }
.ybr .card-stat:hover { transform: translateY(-2px); box-shadow: 0 10px 15px -3px rgba(0, 0, 0, 0.1), 0 4px 6px -2px rgba(0, 0, 0, 0.05); }
.ybr .card-bg-shape { position: absolute; top: -16px; right: -16px; width: 64px; height: 64px; border-bottom-left-radius: 9999px; }
.ybr .card-stat-content { position: relative; z-index: 10; }
.ybr .card-stat-title { font-size: 14px; font-weight: 700; color: var(--ybr-text-muted); margin: 0 0 4px 0; display: flex; align-items: center; gap: 4px; }
.ybr .color-dot { width: 8px; height: 8px; border-radius: 50%; display: inline-block; }
.ybr .card-stat-val { font-size: 24px; font-weight: 700; color: var(--ybr-text-dark); margin: 0; letter-spacing: -0.025em; }
.ybr .card-stat-foot { margin-top: 12px; display: flex; align-items: center; justify-content: space-between; font-size: 13px; color: var(--ybr-text-light); }
.ybr .ratio-badge { font-weight: 700; padding: 2px 8px; border-radius: 4px; }
.ybr .card-header-inner { margin-bottom: 24px; }
.ybr .card-title-inner { font-size: 20px; font-weight: 700; color: var(--ybr-text-dark); margin: 0 0 4px 0; display: flex; align-items: center; gap: 8px; }
.ybr .card-title-inner.small { font-size: 18px; }
.ybr .card-desc { font-size: 13px; color: var(--ybr-text-muted); margin: 0; }
.ybr .chart-wrap { position: relative; flex-grow: 1; width: 100%; }
.ybr .min-h-400 { min-height: 400px; }
.ybr .min-h-140 { min-height: 140px; }
.ybr .h-48 { height: 192px; margin-bottom: 16px; }
.ybr .h-64 { height: 256px; }
.ybr .legend-list { display: flex; flex-direction: column; gap: 8px; margin-top: auto; }
.ybr .legend-item { display: flex; align-items: center; justify-content: space-between; font-size: 14px; background-color: #f8fafc; padding: 10px; border-radius: 4px; }
.ybr .legend-label { display: flex; align-items: center; gap: 8px; font-weight: 500; }
.ybr .legend-dot { width: 10px; height: 10px; border-radius: 50%; }
.ybr .legend-stats { display: flex; gap: 12px; }
.ybr .legend-count { color: var(--ybr-text-muted); }
.ybr .legend-pct { font-weight: 700; width: 48px; text-align: right; }
.ybr .icon-blue { color: #bfdbfe; width: 16px; height: 16px; }
.ybr .icon-blue-lg { color: #bfdbfe; width: 24px; height: 24px; }
.ybr .icon-primary { color: var(--ybr-color-primary); width: 16px; height: 16px; }
.ybr .icon-secondary { color: var(--ybr-color-secondary); width: 20px; height: 20px; }
.ybr .icon-secondary-sm { color: var(--ybr-color-secondary); width: 16px; height: 16px; }
.ybr .icon-emerald { color: var(--ybr-color-emerald); width: 16px; height: 16px; }
.ybr .bg-u-light { background-color: #eff6ff; }
.ybr .text-u-dark { color: #2563eb; }
.ybr .bg-u-main { background-color: var(--ybr-color-primary); }
.ybr .bg-n-light { background-color: #eff6ff; }
.ybr .text-n-dark { color: #2563eb; }
.ybr .bg-n-main { background-color: var(--ybr-color-secondary); }
.ybr .bg-o-light { background-color: #ecfdf5; }
.ybr .text-o-dark { color: #059669; }
.ybr .bg-o-main { background-color: var(--ybr-color-emerald); }
.ybr .bg-k-light { background-color: #fffbeb; }
.ybr .text-k-dark { color: #d97706; }
.ybr .bg-k-main { background-color: var(--ybr-color-amber); }
.ybr .bg-q-light { background-color: #f8fafc; }
.ybr .text-q-dark { color: var(--ybr-text-muted); }
.ybr .bg-q-main { background-color: var(--ybr-color-slate); }

@media (min-width: 640px) {
	.ybr .ybr-container { padding: 0 24px; }
	.ybr .hero-title { font-size: 48px; }
	.ybr .amount-value { font-size: 56px; }
}
@media (min-width: 768px) {
	.ybr .ybr-header { padding: 48px 0; }
	.ybr .hero-subtitle { font-size: 18px; }
	.ybr .amount-value { font-size: 72px; }
	.ybr .amount-value .currency, .ybr .amount-value .dash { font-size: 32px; margin-top: 12px; margin-bottom: 12px; }
	.ybr .stat-label { font-size: 16px; }
	.ybr .stat-value { font-size: 48px; }
	.ybr .stat-unit { font-size: 20px; }
	.ybr .hero-stats { gap: 64px; }
	.ybr .grid-5 { grid-template-columns: repeat(3, 1fr); }
	.ybr .card-stat-val { font-size: 30px; }
	.ybr .h-64 { height: 320px; }
}
@media (min-width: 1024px) {
	.ybr .ybr-header { padding: 56px 0; }
	.ybr .hero-title { font-size: 56px; }
	.ybr .hero-subtitle { font-size: 20px; }
	.ybr .ybr-container { padding: 0 32px; }
	.ybr .amount-value { font-size: 88px; }
	.ybr .amount-value .currency, .ybr .amount-value .dash { font-size: 40px; }
	.ybr .stat-value { font-size: 56px; }
	.ybr .section-title { font-size: 24px; }
	.ybr .card-title-inner { font-size: 24px; }
	.ybr .card-stat-val { font-size: 34px; }
	.ybr .grid-5 { grid-template-columns: repeat(5, 1fr); }
	.ybr .grid-2 { grid-template-columns: repeat(2, 1fr); }
}
