* { box-sizing: border-box; }
        :root {
            --bg: #eef2f6;
            --panel: rgba(255, 255, 255, 0.94);
            --line: #d6dde6;
            --text: #17202b;
            --muted: #576575;
            --accent: #114e72;
            --accent-soft: rgba(17, 78, 114, 0.08);
            --ok: #0f766e;
            --warn: #a16207;
        }
        body {
            margin: 0;
            font-family: 'Hiragino Sans', 'Yu Gothic', sans-serif;
            color: var(--text);
            background:
                radial-gradient(circle at 0% 0%, rgba(17, 78, 114, 0.12), transparent 26%),
                radial-gradient(circle at 100% 0%, rgba(196, 143, 72, 0.18), transparent 32%),
                linear-gradient(180deg, #f6f8fb 0%, var(--bg) 42%, #f8fafc 100%);
            padding: 42px 16px 56px;
        }
        .shell {
            max-width: 1080px;
            margin: 0 auto;
            display: grid;
            gap: 18px;
        }
        .hero, .municipality-card {
            background: var(--panel);
            border: 1px solid var(--line);
            border-radius: 22px;
            box-shadow: 0 16px 40px rgba(23, 32, 43, 0.08);
            backdrop-filter: blur(14px);
        }
        .running-board {
            background: rgba(255, 255, 255, 0.9);
            border: 1px solid rgba(17, 78, 114, 0.14);
            border-radius: 18px;
            box-shadow: 0 10px 24px rgba(17, 78, 114, 0.08);
            padding: 16px 18px;
            display: grid;
            gap: 10px;
        }
        .running-board-head {
            display: grid;
            gap: 4px;
        }
        .running-board-title {
            font-size: 18px;
            font-weight: 700;
            line-height: 1.3;
        }
        .running-list {
            display: grid;
            grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
            gap: 8px;
        }
        .running-item {
            border-radius: 14px;
            border: 1px solid rgba(17, 78, 114, 0.12);
            background: linear-gradient(180deg, rgba(255, 255, 255, 0.96), rgba(242, 248, 252, 0.96));
            padding: 10px 12px;
            display: grid;
            gap: 6px;
        }
        .running-service {
            display: inline-flex;
            width: fit-content;
            align-items: center;
            gap: 6px;
            padding: 3px 8px;
            border-radius: 999px;
            background: rgba(17, 78, 114, 0.08);
            color: var(--accent);
            font-size: 11px;
            font-weight: 700;
        }
        .running-name {
            font-size: 15px;
            font-weight: 700;
            line-height: 1.35;
        }
        .running-item .task-row {
            gap: 5px;
        }
        .running-item .task-badge {
            width: fit-content;
        }
        .hero {
            padding: 28px;
            display: grid;
            gap: 14px;
        }
        .eyebrow {
            font-size: 12px;
            font-weight: 700;
            letter-spacing: 0.08em;
            text-transform: uppercase;
            color: var(--accent);
        }
        h1 {
            margin: 0;
            font-size: clamp(28px, 5vw, 46px);
            line-height: 1.05;
            font-family: 'Yu Mincho', 'Hiragino Mincho ProN', serif;
        }
        .hero-copy {
            max-width: 52rem;
            font-size: 15px;
            line-height: 1.8;
            color: #334155;
        }
        .hero-actions {
            display: flex;
            flex-wrap: wrap;
            gap: 14px;
            align-items: center;
        }
        .hero-cta {
            display: inline-flex;
            align-items: center;
            gap: 14px;
            padding: 14px 18px;
            border-radius: 18px;
            text-decoration: none;
            color: #fff;
            border: 1px solid rgba(17, 78, 114, 0.24);
            background:
                linear-gradient(135deg, #0f5f8b 0%, #114e72 58%, #16324f 100%);
            box-shadow: 0 16px 32px rgba(17, 78, 114, 0.22);
            transition: transform 0.16s ease, box-shadow 0.16s ease, filter 0.16s ease;
        }
        .hero-cta:hover {
            transform: translateY(-1px);
            box-shadow: 0 20px 38px rgba(17, 78, 114, 0.28);
            filter: saturate(1.04);
        }
        .hero-cta-kicker {
            display: inline-flex;
            align-items: center;
            justify-content: center;
            gap: 7px;
            min-width: 74px;
            padding: 7px 10px;
            border-radius: 999px;
            background: rgba(255, 255, 255, 0.18);
            border: 1px solid rgba(255, 255, 255, 0.18);
            font-size: 12px;
            font-weight: 700;
            letter-spacing: 0.05em;
        }
        .hero-cta-icon {
            font-size: 15px;
            line-height: 1;
        }
        .hero-cta-body {
            display: grid;
            gap: 4px;
        }
        .hero-cta-title {
            font-size: 17px;
            font-weight: 700;
            line-height: 1.35;
        }
        .hero-cta-sub {
            font-size: 13px;
            line-height: 1.6;
            color: rgba(255, 255, 255, 0.84);
        }
        .hero-cta-copy {
            max-width: 28rem;
            font-size: 13px;
            line-height: 1.8;
            color: var(--muted);
        }
        .hero-meta {
            display: flex;
            flex-wrap: wrap;
            gap: 8px;
        }
        .hero-meta-dynamic {
            display: flex;
            flex-wrap: wrap;
            gap: 8px;
        }
        .hero-meta span, .hero-meta a {
            padding: 8px 12px;
            border-radius: 999px;
            border: 1px solid var(--line);
            background: #fff;
            font-size: 13px;
            color: var(--muted);
            text-decoration: none;
        }
        .hero-meta-dynamic span {
            padding: 8px 12px;
            border-radius: 999px;
            border: 1px solid var(--line);
            background: #fff;
            font-size: 13px;
            color: var(--muted);
            text-decoration: none;
        }
        .municipality-grid {
            display: grid;
            gap: 16px;
            align-items: start;
        }
        .prefecture-section {
            display: grid;
            gap: 10px;
        }
        .prefecture-head {
            display: flex;
            align-items: center;
            justify-content: space-between;
            gap: 10px;
            flex-wrap: wrap;
        }
        .prefecture-title {
            margin: 0;
            font-size: 20px;
            line-height: 1.3;
        }
        .prefecture-count {
            display: inline-flex;
            align-items: center;
            padding: 6px 10px;
            border-radius: 999px;
            border: 1px solid rgba(17, 78, 114, 0.12);
            background: rgba(255, 255, 255, 0.86);
            color: var(--muted);
            font-size: 12px;
            font-weight: 700;
        }
        .prefecture-grid {
            display: grid;
            grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
            gap: 12px;
            align-items: start;
        }
        .loading-panel {
            grid-column: 1 / -1;
            padding: 18px 20px;
            border-radius: 18px;
            border: 1px solid var(--line);
            background: rgba(255, 255, 255, 0.86);
            color: var(--muted);
            font-size: 14px;
            line-height: 1.6;
        }
        .municipality-card {
            padding: 15px 16px;
            display: grid;
            gap: 10px;
            border-radius: 18px;
            align-content: start;
            align-self: start;
        }
        .municipality-card-live {
            border-color: rgba(29, 78, 216, 0.28);
            box-shadow: 0 18px 38px rgba(29, 78, 216, 0.12);
        }
        .municipality-head {
            display: grid;
            gap: 6px;
        }
        .municipality-name {
            margin: 0;
            font-size: 19px;
            line-height: 1.3;
        }
        .municipality-meta {
            display: flex;
            flex-wrap: wrap;
            gap: 6px 8px;
            align-items: center;
        }
        .municipality-note {
            font-size: 11px;
            color: var(--muted);
            line-height: 1.4;
        }
        .municipality-availability {
            display: inline-flex;
            align-items: center;
            padding: 4px 8px;
            border-radius: 999px;
            border: 1px solid rgba(17, 78, 114, 0.12);
            background: var(--accent-soft);
            color: var(--accent);
            font-weight: 700;
        }
        .feature-list {
            display: grid;
            gap: 6px;
            align-content: start;
        }
        .municipality-empty {
            font-size: 11px;
            line-height: 1.45;
            color: var(--muted);
            padding: 2px 0 0;
        }
        .feature-card, .feature-disabled {
            border-radius: 12px;
            border: 1px solid var(--line);
            padding: 8px 10px;
            display: grid;
            gap: 4px;
            align-content: start;
        }
        .feature-card {
            background: linear-gradient(180deg, #ffffff, #f8fbfd);
            transition: box-shadow 0.14s ease, border-color 0.14s ease;
        }
        .feature-card:hover {
            border-color: rgba(17, 78, 114, 0.34);
            box-shadow: 0 8px 18px rgba(17, 78, 114, 0.06);
        }
        .feature-disabled {
            background: linear-gradient(180deg, #fbfbfb, #f5f6f7);
            color: var(--muted);
        }
        .feature-top {
            display: grid;
            grid-template-columns: minmax(0, 1fr) auto;
            align-items: center;
            gap: 8px;
        }
        .feature-actions {
            display: inline-flex;
            align-items: center;
            gap: 6px;
            justify-content: flex-end;
            flex-wrap: wrap;
        }
        .feature-title {
            display: inline-flex;
            align-items: center;
            gap: 6px;
            font-size: 13px;
            font-weight: 700;
        }
        .feature-icon-mark {
            font-size: 15px;
            line-height: 1;
            flex: 0 0 auto;
        }
        .feature-label-text {
            line-height: 1.3;
        }
        .feature-action {
            display: inline-flex;
            align-items: center;
            justify-content: center;
            padding: 3px 8px;
            border-radius: 999px;
            border: 1px solid rgba(17, 78, 114, 0.18);
            background: rgba(17, 78, 114, 0.06);
            color: var(--accent);
            font-size: 10px;
            font-weight: 700;
            text-decoration: none;
            line-height: 1.2;
        }
        .feature-action:hover {
            border-color: rgba(17, 78, 114, 0.34);
            background: rgba(17, 78, 114, 0.1);
        }
        .status {
            flex: 0 0 auto;
            padding: 3px 7px;
            border-radius: 999px;
            font-size: 10px;
            font-weight: 700;
        }
        .status-ready {
            color: var(--ok);
            background: rgba(15, 118, 110, 0.1);
        }
        .status-pending {
            color: var(--warn);
            background: rgba(161, 98, 7, 0.1);
        }
        .status-suspended {
            color: #b45309;
            background: rgba(180, 83, 9, 0.12);
        }
        .status-unpublished {
            color: #475569;
            background: rgba(100, 116, 139, 0.12);
        }
        .status-needs-build {
            color: #b45309;
            background: rgba(245, 158, 11, 0.14);
        }
        .legend {
            display: flex;
            flex-wrap: wrap;
            gap: 8px;
        }
        .legend span {
            padding: 7px 10px;
            border-radius: 999px;
            font-size: 12px;
            color: var(--muted);
            background: var(--accent-soft);
        }
        .task-row {
            display: grid;
            gap: 4px;
            align-items: start;
        }
        .task-slot {
            display: grid;
            gap: 4px;
        }
        .task-badge {
            flex: 0 0 auto;
            display: inline-flex;
            align-items: center;
            gap: 6px;
            padding: 3px 8px;
            border-radius: 999px;
            font-size: 10px;
            font-weight: 700;
        }
        .task-running {
            color: #1d4ed8;
            background: rgba(29, 78, 216, 0.1);
        }
        .task-running::before {
            content: "";
            width: 10px;
            height: 10px;
            border-radius: 999px;
            border: 2px solid currentColor;
            border-right-color: transparent;
            animation: spin 0.8s linear infinite;
            flex: 0 0 auto;
        }
        .task-pending {
            color: #7c3aed;
            background: rgba(124, 58, 237, 0.1);
        }
        .task-done {
            color: var(--ok);
            background: rgba(15, 118, 110, 0.1);
        }
        .task-info {
            color: var(--accent);
            background: rgba(17, 78, 114, 0.1);
        }
        .task-progress {
            display: block;
            height: 5px;
            border-radius: 999px;
            overflow: hidden;
            background: rgba(148, 163, 184, 0.18);
        }
        .task-progress-bar {
            display: block;
            height: 100%;
            border-radius: inherit;
        }
        .task-progress-active .task-progress-bar {
            background: linear-gradient(90deg, rgba(37, 99, 235, 0.75), rgba(59, 130, 246, 0.92));
        }
        .task-progress-done .task-progress-bar {
            background: linear-gradient(90deg, rgba(13, 148, 136, 0.75), rgba(15, 118, 110, 0.92));
        }
        .task-progress-alert .task-progress-bar {
            background: linear-gradient(90deg, rgba(217, 119, 6, 0.75), rgba(185, 28, 28, 0.85));
        }
        .task-failed {
            color: #b45309;
            background: rgba(180, 83, 9, 0.14);
        }
        .task-stale {
            color: #b91c1c;
            background: rgba(185, 28, 28, 0.12);
        }
        .task-detail {
            display: grid;
            gap: 1px;
            font-size: 11px;
            line-height: 1.45;
            color: var(--muted);
        }
        .task-detail-line {
            white-space: nowrap;
        }
        @keyframes spin {
            to { transform: rotate(360deg); }
        }
        @media (max-width: 720px) {
            body { padding: 20px 12px 32px; }
            .running-board { padding: 14px 15px; border-radius: 16px; }
            .hero { padding: 18px; border-radius: 18px; }
            .municipality-card { padding: 14px 15px; border-radius: 16px; }
            .prefecture-grid { grid-template-columns: 1fr; }
            .running-list { grid-template-columns: 1fr; }
            .hero-actions { flex-direction: column; align-items: stretch; }
            .hero-cta { width: 100%; }
            .feature-top { grid-template-columns: 1fr; }
        }
