/*
Theme Name: Kensapo Portal
Theme URI: https://example.com/kensapo-portal
Author: ChatGPT
Description: 県ポータル風テーマ（神奈川県トップ80%寄せ）。モバイル最適・ハンバーガー・SEO・関連記事・フッターウィジェット・CPT込み。
Version: 1.7.3
Text Domain: kensapo
*/
:root{--brand:#0066cc;--brand-dark:#004a94;--accent:#00a6d6;--bg:#f5f7fb;--ink:#1a2330;--muted:#637083;--card:#ffffff;--border:#e3e8f0}
*{box-sizing:border-box}
html,body{width:100%;overflow-x:hidden;margin:0;padding:0}
body{font-family: system-ui, -apple-system, Segoe UI, Roboto, "Noto Sans JP", Helvetica, Arial, "Hiragino Kaku Gothic ProN", Meiryo, sans-serif;color:var(--ink);background:var(--bg);line-height:1.65}
a{color:var(--brand);text-decoration:none}
a:focus,button:focus{outline:3px solid var(--accent);outline-offset:2px}
.container{max-width:1100px;margin:0 auto;padding:0 16px}
.grid{display:grid;gap:16px}
.grid-3{grid-template-columns:repeat(3,1fr)}
.grid-2{grid-template-columns:repeat(2,1fr)}
@media(max-width:960px){.grid-3{grid-template-columns:1fr 1fr}}
@media(max-width:680px){.grid-3,.grid-2{grid-template-columns:1fr}}
.header{background:#fff;border-bottom:1px solid var(--border)}
.header .inner{display:flex;align-items:center;justify-content:space-between;gap:16px}
.branding{display:flex;align-items:center;gap:12px}
.header .mast-right{display:flex;align-items:center;gap:16px}
.header .mast-right .nav ul{display:flex;gap:18px;list-style:none;margin:0;padding:0}
.header .mast-right .nav li{display:flex;align-items:center}
.header .mast-right .nav a{padding:8px 10px;border-radius:10px;color:var(--ink)}
.header .mast-right .nav a:hover{background:#f0f4fa;color:var(--brand-dark)}
.header .mast-right .nav .current-menu-item>a{background:var(--brand);color:#fff}
.header .mast-right .search-form{display:flex;gap:8px;align-items:center}
.header .mast-right .search-field{min-width:220px}
.nav[aria-label="Secondary"]{display:flex;gap:14px;overflow-x:auto;padding:8px 0 12px}
.nav[aria-label="Secondary"] a{white-space:nowrap;padding:6px 10px;border-radius:999px;background:#fff;border:1px solid var(--border);color:var(--ink)}
.nav[aria-label="Secondary"] a:hover{border-color:#cdd7e6;color:var(--brand-dark)}
.hero{background:linear-gradient(180deg,#e8f2ff,#f5f7fb)}
.hero .wrap{padding:24px 0}
.card{background:var(--card);border:1px solid var(--border);border-radius:14px;box-shadow:0 1px 2px rgba(0,0,0,.03);overflow:hidden}
.card .pad{padding:14px}
.card .meta{color:var(--muted);font-size:14px}
.badge{display:inline-block;background:#eef5ff;border:1px solid #d9e7ff;border-radius:999px;padding:2px 10px;font-size:12px;color:#1a3d6d}
.section{padding:24px 0}
.btn{display:inline-block;background:var(--brand);color:#fff;padding:10px 14px;border-radius:10px}
.btn:hover{background:var(--brand-dark)}
.footer{border-top:1px solid var(--border);background:#fff;margin-top:24px}
.footer .inner{padding:28px 16px}
.footer-widgets{display:grid;grid-template-columns:2fr 1fr 1fr;gap:24px;margin-bottom:10px}
@media(max-width:960px){ .footer-widgets{grid-template-columns:1fr 1fr} }
@media(max-width:560px){ .footer-widgets{grid-template-columns:1fr} .footer .inner nav a{display:block;margin:6px 0} }
.footer .credits{color:var(--muted);font-size:14px}
.footer .widget-title{font-size:16px;margin:0 0 8px}
.sidebar{display:flex;flex-direction:column;gap:16px}
.widget{background:#fff;border:1px solid var(--border);border-radius:12px;padding:12px}
.search-form{display:flex;gap:8px}
.search-field{flex:1;border:1px solid var(--border);border-radius:8px;padding:8px}
.search-submit{border:0;background:var(--brand);color:#fff;border-radius:8px;padding:8px 12px}
.table{width:100%;border-collapse:collapse}
.table th,.table td{padding:8px;border-bottom:1px solid var(--border);text-align:left}
.breadcrumbs{font-size:14px;color:var(--muted);margin:8px 0 12px}
.breadcrumbs a{color:var(--muted)}
/* Kanagawa-like blocks */
.section .sub{color:var(--muted);font-size:14px;margin-bottom:6px}
.tile.card h3{margin:8px 0 0;font-size:18px}
.k-tags{display:flex;gap:8px;flex-wrap:wrap;margin-top:8px}
.k-tags a{display:inline-block;padding:6px 10px;border:1px solid var(--border);border-radius:999px;background:#fff;font-size:14px}
.k-section-head{display:flex;align-items:baseline;justify-content:space-between;gap:12px;margin-bottom:8px}
.k-section-head a{font-size:14px}
.k-list{list-style:none;padding:0;margin:0}
.k-list li{padding:8px 0;border-bottom:1px solid var(--border)}
.k-two{display:grid;gap:16px;grid-template-columns:2fr 1fr}
@media(max-width:960px){.k-two{grid-template-columns:1fr}}
.alert-bar{background:#fff3cd;border:1px solid #ffe08a;padding:10px 12px;border-radius:10px;margin:10px 0}
.alert-bar strong{color:#8a6d00}
.k-video{position:relative;padding-top:56.25%;border-radius:12px;overflow:hidden;border:1px solid var(--border);background:#000}
.k-video iframe{position:absolute;inset:0;width:100%;height:100%}
.k-grid-4{display:grid;gap:16px;grid-template-columns:repeat(4,1fr)}
@media(max-width:960px){.k-grid-4{grid-template-columns:1fr 1fr}}
@media(max-width:520px){.k-grid-4{grid-template-columns:1fr}}
/* Mobile */
.menu-toggle{display:none}
@media(max-width:920px){
  .header .mast-right .nav,
  .header .mast-right .search-form,
  .header .inner .nav[aria-label="Secondary"]{display:none!important}
  .menu-toggle{display:flex;align-items:center;gap:10px;border:1px solid var(--border);background:#fff;border-radius:10px;padding:8px 10px}
  .kensapo-hamburger{display:none!important} /* MUがあってもテーマ優先 */
}
/* Drawer & overlay */
.mobile-drawer-overlay{position:fixed;inset:0;background:rgba(0,0,0,.35);opacity:0;visibility:hidden;transition:.2s;z-index:1000}
.mobile-drawer{position:fixed;top:0;left:0;width:86%;max-width:360px;height:100%;background:#fff;border-right:1px solid var(--border);transform:translateX(-100%);transition:transform .25s ease;overflow:auto;-webkit-overflow-scrolling:touch;z-index:1001}
.mobile-drawer .pad{padding:14px}
.mobile-drawer .group{border-bottom:1px solid var(--border);padding-bottom:10px;margin-bottom:10px}
.mobile-drawer h4{margin:0 0 6px;font-size:14px;color:var(--muted)}
.mobile-drawer .menu{list-style:none;margin:0;padding:0}
.mobile-drawer .menu li{border-bottom:1px solid var(--border)}
.mobile-drawer .menu a{display:block;padding:10px 0}
body.menu-open .mobile-drawer{transform:translateX(0)}
body.menu-open .mobile-drawer-overlay{opacity:1;visibility:visible}
/* Sidebar stacks on phones */
@media(max-width:880px){ .grid-2{grid-template-columns:1fr} }
/* Content video responsive */
.content .video-wrap{position:relative;padding-top:56.25%;margin:16px 0;border-radius:12px;overflow:hidden;border:1px solid var(--border);background:#000}
.content .video-wrap iframe{position:absolute;inset:0;width:100%;height:100%}
.content iframe[src*="youtube"], .content iframe[src*="vimeo"]{max-width:100%}
/* Pagination */
.pagination{display:flex;gap:8px;justify-content:center;margin:20px 0}
.pagination .page-numbers{display:inline-flex;min-width:36px;height:36px;align-items:center;justify-content:center;border-radius:10px;border:1px solid var(--border);background:#fff;padding:0 10px;color:var(--ink)}
.pagination .page-numbers:hover{border-color:#cdd7e6}
.pagination .page-numbers.current{background:var(--brand);color:#fff;border-color:var(--brand)}
.pagination .page-numbers.prev, .pagination .page-numbers.next{padding:0 12px}
.custom-logo{height:auto;display:block}
