:root {
  --orange:#0EA5A4;--orange-light:#5CC8C7;--orange-pale:#EBF7F7;--orange-dark:#0A7E7D;
  --brown:#1A3333;--cream:#F8FAFC;--warm-gray:#6B7280;--text:#111827;--text-light:#6B7280;
  --green:#16A34A;--green-light:#DCFCE7;--blue:#3B5BDB;--blue-light:#EBF0FE;
  --purple:#6741D9;--purple-light:#F3EFFF;--red:#C0392B;--red-light:#FDECEA;
  --border:#E5E7EB;
}
*{margin:0;padding:0;box-sizing:border-box;}
body{font-family:'Noto Sans JP',sans-serif;background:var(--cream);color:var(--text);line-height:1.7;}

/* HEADER */
header{background:white;border-bottom:3px solid var(--orange);position:sticky;top:0;z-index:100;box-shadow:0 2px 16px rgba(232,114,42,0.12);}
.header-inner{max-width:1000px;margin:0 auto;padding:12px 20px;display:flex;align-items:center;justify-content:space-between;gap:12px;}
.logo{display:flex;align-items:baseline;gap:8px;text-decoration:none;}
.logo-main{font-family:'Noto Serif JP',serif;font-size:1.35rem;font-weight:700;color:var(--orange);}
.logo-sub{font-size:0.65rem;color:var(--warm-gray);letter-spacing:0.1em;}
.header-nav{display:flex;gap:8px;}
.header-nav a{font-size:0.75rem;color:var(--text-light);text-decoration:none;padding:4px 10px;border-radius:20px;border:1px solid var(--border);white-space:nowrap;}
.header-nav a:hover{border-color:var(--orange);color:var(--orange);}

/* BREADCRUMB */
.breadcrumb{background:var(--cream);border-bottom:1px solid var(--border);padding:8px 20px;}
.breadcrumb-inner{max-width:1000px;margin:0 auto;font-size:0.74rem;color:var(--warm-gray);}
.breadcrumb-inner a{color:var(--text-light);text-decoration:none;}
.breadcrumb-inner a:hover{color:var(--orange);}
.breadcrumb-inner span{margin:0 5px;}

/* HERO */
.hero{background:linear-gradient(150deg,#FFFFFF 0%,#F8FAFC 50%,#F1F5F9 100%);padding:44px 20px 36px;text-align:center;}
.hero-eyebrow{display:inline-flex;align-items:center;gap:6px;background:var(--orange);color:white;font-size:0.7rem;font-weight:700;padding:5px 14px;border-radius:20px;margin-bottom:14px;}
.hero h1{font-family:'Noto Serif JP',serif;font-size:clamp(1.3rem,4vw,1.9rem);font-weight:700;color:var(--brown);line-height:1.5;margin-bottom:8px;}
.hero h1 em{color:var(--orange);font-style:normal;}
.hero-desc{font-size:0.84rem;color:var(--text-light);max-width:520px;margin:0 auto 28px;}

/* KU HERO */
.ku-hero{background:linear-gradient(150deg,#FFFFFF 0%,#F8FAFC 60%,#F1F5F9 100%);padding:32px 20px 28px;}
.ku-hero-inner{max-width:1000px;margin:0 auto;}
.ku-hero h1{font-family:'Noto Serif JP',serif;font-size:clamp(1.15rem,3.5vw,1.6rem);font-weight:700;color:var(--brown);line-height:1.5;margin-bottom:10px;}
.ku-intro-text{font-size:0.84rem;color:var(--text-light);max-width:760px;line-height:1.8;}
.ku-stats{display:flex;gap:20px;margin-top:16px;flex-wrap:wrap;}
.ku-stat{background:white;border-radius:10px;padding:10px 16px;border:1.5px solid var(--border);}
.ku-stat-num{font-family:'Noto Serif JP',serif;font-size:1.2rem;font-weight:700;color:var(--orange);}
.ku-stat-label{font-size:0.68rem;color:var(--warm-gray);}

/* SEARCH */
.search-wrap{background:white;border-radius:20px;padding:22px;max-width:600px;margin:0 auto;box-shadow:0 6px 32px rgba(92,61,46,0.13);}
.search-tabs{display:flex;margin-bottom:16px;border:1.5px solid var(--border);border-radius:10px;overflow:hidden;}
.search-tab{flex:1;padding:9px;font-size:0.82rem;font-weight:700;font-family:inherit;border:none;background:white;color:var(--warm-gray);cursor:pointer;}
.search-tab.active{background:var(--orange);color:white;}
.search-panel{display:none;}
.search-panel.active{display:block;}
.zip-row{display:flex;gap:10px;}
.zip-input{flex:1;border:2px solid var(--border);border-radius:10px;padding:11px 14px;font-size:1rem;font-family:inherit;color:var(--text);outline:none;}
.zip-input:focus{border-color:var(--orange);}
.zip-btn{background:var(--orange);color:white;border:none;border-radius:10px;padding:11px 20px;font-size:0.88rem;font-weight:700;font-family:inherit;cursor:pointer;white-space:nowrap;}
.zip-hint{font-size:0.72rem;color:var(--warm-gray);margin-top:8px;}
.search-label{font-size:0.74rem;font-weight:700;color:var(--warm-gray);letter-spacing:0.1em;margin-bottom:10px;}
.ku-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:6px;}
.ku-btn{border:1.5px solid var(--border);background:white;color:var(--text-light);font-size:0.76rem;padding:7px 4px;border-radius:8px;cursor:pointer;font-family:inherit;text-align:center;}
.ku-btn:hover{border-color:var(--orange-light);background:var(--orange-pale);color:var(--orange-dark);}
.ku-btn.active{border-color:var(--orange);background:var(--orange);color:white;font-weight:700;}

/* STATS BAR */
.stats-bar{background:var(--brown);padding:14px 20px;}
.stats-inner{max-width:1000px;margin:0 auto;display:flex;justify-content:center;gap:40px;flex-wrap:wrap;}
.stat-item{text-align:center;color:white;}
.stat-num{font-family:'Noto Serif JP',serif;font-size:1.3rem;font-weight:700;color:var(--orange-light);}
.stat-label{font-size:0.67rem;opacity:0.8;letter-spacing:0.08em;}

/* MAIN */
.main{max-width:1000px;margin:0 auto;padding:28px 20px 64px;}
.section-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px;flex-wrap:wrap;gap:8px;}
.section-title{font-family:'Noto Serif JP',serif;font-size:1.05rem;font-weight:700;color:var(--brown);}
.section-title::before{content:'▎';color:var(--orange);margin-right:6px;}
.result-count{font-size:0.78rem;color:var(--warm-gray);}
.empty-state{text-align:center;padding:52px 20px;color:var(--warm-gray);}
.empty-icon{font-size:2.8rem;margin-bottom:12px;}
.empty-text{font-size:0.88rem;line-height:1.8;}

/* 委託事業者カード */
.cards{display:flex;flex-direction:column;gap:13px;}
.card{background:white;border-radius:15px;overflow:hidden;box-shadow:0 2px 10px rgba(92,61,46,0.07);border:1.5px solid var(--border);animation:fadeUp 0.35s ease both;}
.card:hover{box-shadow:0 5px 20px rgba(92,61,46,0.12);transform:translateY(-2px);}
@keyframes fadeUp{from{opacity:0;transform:translateY(10px);}to{opacity:1;transform:translateY(0);}}
.card:nth-child(1){animation-delay:.03s}.card:nth-child(2){animation-delay:.06s}.card:nth-child(3){animation-delay:.09s}
.card:nth-child(4){animation-delay:.12s}.card:nth-child(5){animation-delay:.15s}.card:nth-child(6){animation-delay:.18s}
.card-main{padding:16px 16px 12px;display:flex;gap:13px;align-items:flex-start;}
.card-icon{width:46px;height:46px;border-radius:11px;display:flex;align-items:center;justify-content:center;font-size:1.25rem;flex-shrink:0;background:var(--orange-pale);}
.card-body{flex:1;min-width:0;}
.card-name-row{display:flex;align-items:center;gap:6px;flex-wrap:wrap;margin-bottom:3px;}
.card-name{font-family:'Noto Serif JP',serif;font-size:0.98rem;font-weight:700;color:var(--brown);}
.badge{font-size:0.6rem;font-weight:700;padding:2px 7px;border-radius:4px;white-space:nowrap;}
.badge-pr{background:#FFF3CD;color:#856404;border:1px solid #FFDCA0;font-weight:700;}
.badge-seido{background:var(--green-light);color:var(--green);}
.badge-private{background:var(--blue-light);color:var(--blue);}
.badge-local{background:var(--purple-light);color:var(--purple);}
.badge-partial{background:#FEF9E7;color:#9A7D0A;border:1px solid #F9E79F;}
.card-brand{font-size:0.71rem;color:var(--warm-gray);margin-bottom:5px;}
.card-address{font-size:0.76rem;color:var(--text-light);margin-bottom:5px;}
.card-areas-label{font-size:0.68rem;color:var(--warm-gray);margin-bottom:3px;}
.card-areas span{background:var(--orange-pale);color:var(--orange-dark);padding:1px 7px;border-radius:10px;margin:2px 2px 2px 0;display:inline-block;font-size:0.66rem;}
.card-footer{display:flex;gap:8px;padding:11px 16px;border-top:1px solid var(--border);background:#FDFAF7;flex-wrap:wrap;align-items:center;}
.card-mieta{font-size:0.68rem;color:var(--warm-gray);margin-left:auto;}
.btn-call{background:var(--green);color:white;border:none;border-radius:8px;padding:9px 14px;font-size:0.8rem;font-weight:700;font-family:inherit;cursor:pointer;text-decoration:none;display:flex;align-items:center;gap:5px;white-space:nowrap;}
.btn-call:hover{background:#4a7a4c;}
.btn-map{background:white;color:var(--text-light);border:1.5px solid var(--border);border-radius:8px;padding:7px 12px;font-size:0.76rem;font-family:inherit;text-decoration:none;display:flex;align-items:center;gap:4px;white-space:nowrap;}
.btn-map:hover{border-color:var(--orange);color:var(--orange);}
.btn-detail{background:var(--orange-pale);color:var(--orange);border:1.5px solid #ffdcb8;border-radius:8px;padding:7px 12px;font-size:0.76rem;font-weight:700;font-family:inherit;text-decoration:none;display:flex;align-items:center;gap:4px;white-space:nowrap;}
.btn-detail:hover{background:#ffe8cc;border-color:var(--orange);}
.badge-meal{background:#e8f8f0;color:#1a7a4a;border:1px solid #b8e8cc;}
.btn-web{background:white;color:var(--blue);border:1.5px solid var(--blue-light);border-radius:8px;padding:7px 12px;font-size:0.76rem;font-family:inherit;text-decoration:none;display:flex;align-items:center;gap:4px;white-space:nowrap;}

/* 民間カード */
.private-section{margin-top:36px;}
.private-section-title{font-family:'Noto Serif JP',serif;font-size:1.05rem;font-weight:700;color:var(--brown);margin-bottom:6px;}
.private-section-title::before{content:'▎';color:var(--blue);margin-right:6px;}
.private-note{font-size:0.76rem;color:var(--text-light);margin-bottom:14px;padding:10px 14px;background:var(--blue-light);border-radius:8px;border-left:3px solid var(--blue);}
.private-cards{display:flex;flex-direction:column;gap:13px;}
.private-card{background:white;border-radius:15px;overflow:hidden;border:1.5px solid #c5d0f0;box-shadow:0 2px 10px rgba(59,91,219,0.07);animation:fadeUp 0.35s ease both;}
.private-card-main{padding:16px;}
.private-card-name-row{display:flex;align-items:center;gap:6px;flex-wrap:wrap;margin-bottom:8px;}
.private-card-name{font-family:'Noto Serif JP',serif;font-size:0.98rem;font-weight:700;color:var(--brown);}
.private-specs{display:grid;grid-template-columns:repeat(2,1fr);gap:6px;margin-bottom:10px;}
.spec-item{background:var(--cream);border-radius:8px;padding:8px 10px;}
.spec-label{font-size:0.64rem;color:var(--warm-gray);margin-bottom:2px;}
.spec-value{font-size:0.76rem;color:var(--text);font-weight:500;}
.private-coverage{font-size:0.73rem;color:var(--text-light);margin-bottom:6px;}
.private-notes{font-size:0.72rem;color:var(--text-light);background:var(--orange-pale);border-radius:6px;padding:7px 10px;}
.allergy-warning{font-size:0.71rem;color:var(--red);background:var(--red-light);border-radius:6px;padding:6px 10px;margin-top:6px;}
.private-card-footer{display:flex;gap:8px;padding:11px 16px;border-top:1px solid #c5d0f0;background:#f5f7ff;flex-wrap:wrap;}

/* 地域包括 */
.houkatsu-section{margin-top:36px;}
.houkatsu-title{font-family:'Noto Serif JP',serif;font-size:0.95rem;font-weight:700;color:var(--brown);margin-bottom:12px;}
.houkatsu-title::before{content:'▎';color:var(--blue);margin-right:6px;}
.houkatsu-intro{font-size:0.76rem;color:var(--text-light);margin-bottom:12px;padding:10px 14px;background:var(--blue-light);border-radius:8px;border-left:3px solid var(--blue);}
.houkatsu-cards{display:flex;flex-direction:column;gap:9px;}
.houkatsu-card{background:var(--blue-light);border:1.5px solid #c5d0f0;border-radius:12px;padding:14px 16px;display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap;}
.houkatsu-info{flex:1;min-width:0;}
.houkatsu-name{font-size:0.88rem;font-weight:700;color:var(--blue);margin-bottom:2px;}
.houkatsu-address{font-size:0.72rem;color:var(--text-light);}
.btn-houkatsu{background:var(--blue);color:white;border:none;border-radius:8px;padding:9px 14px;font-size:0.8rem;font-weight:700;font-family:inherit;text-decoration:none;display:flex;align-items:center;gap:5px;white-space:nowrap;flex-shrink:0;}

/* 比較表 */
.compare-section{background:white;border-radius:16px;padding:28px;margin-top:40px;border:1.5px solid var(--border);}
.compare-title{font-family:'Noto Serif JP',serif;font-size:1rem;font-weight:700;color:var(--brown);margin-bottom:16px;}
.compare-title::before{content:'▎';color:var(--orange);margin-right:6px;}
.compare-table{width:100%;border-collapse:collapse;font-size:0.78rem;}
.compare-table th{background:var(--brown);color:white;padding:9px 12px;text-align:left;}
.compare-table th:first-child{border-radius:8px 0 0 0;}
.compare-table th:last-child{border-radius:0 8px 0 0;}
.compare-table td{padding:8px 12px;border-bottom:1px solid var(--border);vertical-align:top;line-height:1.5;}
.compare-table tr:last-child td{border-bottom:none;}
.compare-table tr:nth-child(even) td{background:#fdfaf7;}
.tag-seido{color:var(--green);font-weight:700;}
.tag-private{color:var(--blue);font-weight:700;}

/* 制度説明 */
.seido-section{background:white;border-radius:16px;padding:32px 28px;margin-top:40px;border:1.5px solid var(--border);}
.seido-header{text-align:center;margin-bottom:28px;}
.seido-tag{display:inline-block;background:var(--orange);color:white;font-size:0.7rem;font-weight:700;padding:4px 14px;border-radius:20px;margin-bottom:10px;}
.seido-title{font-family:'Noto Serif JP',serif;font-size:1.15rem;font-weight:700;color:var(--brown);margin-bottom:8px;}
.seido-subtitle{font-size:0.82rem;color:var(--text-light);}
.seido-alert{background:#FEF9E7;border:1.5px solid #F9E79F;border-radius:12px;padding:16px 18px;margin-bottom:24px;font-size:0.82rem;color:#7D6608;line-height:1.7;}
.seido-alert strong{color:#5D4E08;}
.seido-blocks{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-bottom:24px;}
.seido-block{background:var(--cream);border-radius:12px;padding:18px;}
.seido-block-title{font-size:0.82rem;font-weight:700;color:var(--brown);margin-bottom:10px;}
.seido-block ul{padding-left:0;list-style:none;}
.seido-block ul li{font-size:0.78rem;color:var(--text-light);padding:4px 0;border-bottom:1px solid var(--border);line-height:1.6;}
.seido-block ul li:last-child{border-bottom:none;}
.seido-block ul li::before{content:"・";color:var(--orange);}
.seido-price{background:var(--green-light);border:1.5px solid #b8d9b9;border-radius:12px;padding:16px 18px;margin-bottom:24px;}
.seido-price-title{font-size:0.84rem;font-weight:700;color:var(--green);margin-bottom:8px;}
.seido-price p{font-size:0.78rem;color:var(--text-light);line-height:1.7;}
.seido-flow-title{font-size:0.88rem;font-weight:700;color:var(--brown);margin-bottom:14px;}
.flow-steps{display:flex;flex-direction:column;}
.flow-step{display:flex;gap:14px;align-items:flex-start;padding:12px 0;border-bottom:1px dashed var(--border);}
.flow-step:last-child{border-bottom:none;}
.flow-num{width:28px;height:28px;background:var(--orange);color:white;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:0.82rem;font-weight:700;flex-shrink:0;margin-top:2px;}
.flow-title{font-size:0.84rem;font-weight:700;color:var(--text);margin-bottom:3px;}
.flow-desc{font-size:0.76rem;color:var(--text-light);line-height:1.6;}
.seido-cta{background:var(--orange-pale);border-radius:12px;padding:18px;text-align:center;margin-top:24px;}
.seido-cta p{font-size:0.82rem;color:var(--text-light);margin-bottom:10px;}
.btn-scroll{background:var(--orange);color:white;border:none;border-radius:10px;padding:12px 24px;font-size:0.88rem;font-weight:700;font-family:inherit;cursor:pointer;}
.seido-source{font-size:0.7rem;color:var(--warm-gray);text-align:center;margin-top:20px;}
.seido-source a{color:var(--orange);}

/* 大阪市ハブ ページ */
.hub-intro{background:white;border-radius:16px;padding:28px;margin-bottom:32px;border:1.5px solid var(--border);}
.hub-intro p{font-size:0.86rem;color:var(--text-light);line-height:1.9;margin-bottom:12px;}
.hub-intro p:last-child{margin-bottom:0;}
.ward-grid-section{margin-bottom:36px;}
.ward-grid-title{font-family:'Noto Serif JP',serif;font-size:1.05rem;font-weight:700;color:var(--brown);margin-bottom:14px;}
.ward-grid-title::before{content:'▎';color:var(--orange);margin-right:6px;}
.ward-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:8px;}
.ward-item{display:block;background:white;border:1.5px solid var(--border);border-radius:10px;padding:10px 8px;text-align:center;text-decoration:none;color:var(--text-light);font-size:0.8rem;transition:all 0.2s;}
.ward-item:hover{border-color:var(--orange);background:var(--orange-pale);color:var(--orange-dark);transform:translateY(-1px);}
.ward-item-count{display:block;font-size:0.64rem;color:var(--warm-gray);margin-top:2px;}

/* ガイドページ */
.guide-hero{background:linear-gradient(150deg,#FFFFFF 0%,#F8FAFC 60%,#F1F5F9 100%);padding:36px 20px 28px;}
.guide-hero-inner{max-width:1000px;margin:0 auto;}
.guide-tag{display:inline-block;background:var(--orange);color:white;font-size:0.7rem;font-weight:700;padding:4px 14px;border-radius:20px;margin-bottom:12px;}
.guide-hero h1{font-family:'Noto Serif JP',serif;font-size:clamp(1.1rem,3.5vw,1.55rem);font-weight:700;color:var(--brown);line-height:1.5;margin-bottom:8px;}
.guide-hero-desc{font-size:0.82rem;color:var(--text-light);}
.guide-toc{background:white;border-radius:12px;padding:20px;margin-bottom:32px;border:1.5px solid var(--border);}
.guide-toc-title{font-size:0.8rem;font-weight:700;color:var(--brown);margin-bottom:10px;}
.guide-toc ol{padding-left:18px;}
.guide-toc li{font-size:0.8rem;color:var(--text-light);padding:3px 0;}
.guide-toc a{color:var(--orange);text-decoration:none;}
.guide-toc a:hover{text-decoration:underline;}
.guide-section{background:white;border-radius:16px;padding:28px;margin-bottom:24px;border:1.5px solid var(--border);}
.guide-section h2{font-family:'Noto Serif JP',serif;font-size:1.05rem;font-weight:700;color:var(--brown);margin-bottom:14px;padding-bottom:10px;border-bottom:2px solid var(--orange-pale);}
.guide-section h2::before{content:'▎';color:var(--orange);margin-right:6px;}
.guide-section p{font-size:0.84rem;color:var(--text-light);line-height:1.9;margin-bottom:12px;}
.guide-section p:last-child{margin-bottom:0;}
.guide-section h3{font-size:0.9rem;font-weight:700;color:var(--brown);margin:16px 0 8px;}
.meal-types{display:grid;grid-template-columns:repeat(2,1fr);gap:10px;margin-top:12px;}
.meal-type-item{background:var(--cream);border-radius:10px;padding:12px 14px;border:1.5px solid var(--border);}
.meal-type-name{font-size:0.82rem;font-weight:700;color:var(--brown);margin-bottom:4px;}
.meal-type-desc{font-size:0.74rem;color:var(--text-light);line-height:1.6;}
.guide-checklist{list-style:none;padding:0;margin-top:10px;}
.guide-checklist li{font-size:0.82rem;color:var(--text-light);padding:7px 0;border-bottom:1px solid var(--border);display:flex;align-items:flex-start;gap:8px;line-height:1.6;}
.guide-checklist li:last-child{border-bottom:none;}
.guide-checklist li::before{content:"✓";color:var(--green);font-weight:700;flex-shrink:0;margin-top:1px;}
.guide-compare-mini{overflow-x:auto;margin-top:12px;}
.guide-cta{background:var(--orange-pale);border-radius:12px;padding:24px;text-align:center;margin-top:32px;border:1.5px solid var(--orange-light);}
.guide-cta p{font-size:0.84rem;color:var(--text-light);margin-bottom:12px;}
.btn-orange{background:var(--orange);color:white;border:none;border-radius:10px;padding:12px 28px;font-size:0.9rem;font-weight:700;font-family:inherit;cursor:pointer;text-decoration:none;display:inline-block;}
.btn-orange:hover{background:var(--orange-dark);}

/* 食形態フィルターバー */
.meal-filter-bar{display:flex;gap:7px;flex-wrap:wrap;margin-bottom:14px;padding:12px 0 4px;}
.filter-tag-btn{background:white;border:1.5px solid var(--border);border-radius:20px;padding:5px 14px;font-size:0.76rem;font-family:inherit;cursor:pointer;color:var(--text-light);transition:all 0.2s;white-space:nowrap;}
.filter-tag-btn:hover{border-color:var(--orange-light);background:var(--orange-pale);color:var(--orange-dark);}
.filter-tag-btn.active{background:var(--orange);border-color:var(--orange);color:white;font-weight:700;}
.filter-empty{color:var(--text-light);font-size:0.84rem;padding:24px 0;text-align:center;}

/* 比較ボタン */
.btn-compare{background:white;color:var(--brown);border:1.5px solid var(--border);border-radius:8px;padding:7px 12px;font-size:0.76rem;font-weight:700;font-family:inherit;cursor:pointer;white-space:nowrap;transition:all 0.2s;}
.btn-compare:hover{border-color:var(--orange);color:var(--orange);background:var(--orange-pale);}
.btn-compare-active{background:var(--orange-pale);color:var(--orange);border-color:var(--orange);}

/* 比較ページ テーブル */
.compare-list-table{width:100%;border-collapse:collapse;font-size:0.8rem;background:white;border-radius:12px;overflow:hidden;border:1.5px solid var(--border);}
.compare-list-table th{background:var(--brown);color:white;padding:10px 12px;text-align:left;font-size:0.75rem;font-weight:700;}
.compare-list-table td{padding:10px 12px;border-bottom:1px solid var(--border);vertical-align:top;line-height:1.5;}
.compare-list-table tr:last-child td{border-bottom:none;}
.compare-list-table tr:nth-child(even) td{background:#fdfaf7;}
.compare-memo{width:100%;min-width:120px;border:1.5px solid var(--border);border-radius:6px;padding:5px 8px;font-size:0.76rem;font-family:inherit;resize:vertical;min-height:48px;}
.compare-memo:focus{outline:none;border-color:var(--orange);}
.btn-remove{background:none;border:1.5px solid #fca5a5;color:#dc2626;border-radius:6px;padding:4px 10px;font-size:0.72rem;cursor:pointer;font-family:inherit;}
.btn-remove:hover{background:#fef2f2;}

/* ページナビ */
.page-nav{background:white;border-radius:12px;padding:18px;margin-top:32px;border:1.5px solid var(--border);}
.page-nav-title{font-size:0.78rem;font-weight:700;color:var(--warm-gray);margin-bottom:10px;}
.page-nav-links{display:flex;gap:10px;flex-wrap:wrap;}
.page-nav-links a{font-size:0.78rem;color:var(--text-light);text-decoration:none;padding:6px 12px;border-radius:8px;border:1.5px solid var(--border);}
.page-nav-links a:hover{border-color:var(--orange);color:var(--orange);}

/* フッター */
footer{background:var(--brown);color:rgba(255,255,255,0.7);padding:28px 20px;text-align:center;font-size:0.73rem;line-height:1.9;}
footer a{color:var(--orange-light);text-decoration:none;}

/* ── トップページ 主導線 UI ── */
.tp-inner{max-width:1000px;margin:0 auto;}

/* A: 食形態・制限食で探す */
.meal-search-section{background:#fff;padding:36px 20px 32px;border-bottom:1.5px solid var(--border);}
.tp-section-title{font-family:'Noto Serif JP',serif;font-size:1.05rem;font-weight:700;color:var(--brown);margin-bottom:8px;}
.tp-section-title::before{content:'▎';color:var(--orange);margin-right:6px;}
.tp-section-desc{font-size:0.82rem;color:var(--text-light);line-height:1.7;margin-bottom:18px;}
.meal-btn-grid{display:flex;flex-wrap:wrap;gap:10px;}
.meal-type-btn{display:inline-flex;align-items:center;gap:8px;background:#fff;border:2px solid var(--border);border-radius:10px;padding:11px 20px;text-decoration:none;color:var(--text);font-size:0.88rem;font-weight:500;transition:all 0.2s;}
.meal-type-btn:hover{border-color:var(--orange);background:var(--orange-pale);color:var(--orange-dark);}
.meal-type-btn--limited{border-color:#d4c5bb;color:var(--text-light);}
.meal-type-btn--limited:hover{border-color:var(--brown);background:#f9f4f0;color:var(--brown);}

/* B: 補助導線カード */
.sub-nav-section{background:var(--cream);padding:20px 20px 24px;}
.sub-nav-cards{display:flex;gap:14px;}
.sub-nav-card{flex:1;min-width:0;background:#fff;border:1.5px solid var(--border);border-radius:14px;padding:18px 20px;text-decoration:none;color:var(--text);display:flex;align-items:center;gap:14px;transition:all 0.2s;}
.sub-nav-card:hover{border-color:var(--orange-light);box-shadow:0 4px 16px rgba(232,114,42,0.10);transform:translateY(-1px);}
.sub-nav-card-icon{font-size:1.6rem;flex-shrink:0;line-height:1;}
.sub-nav-card-body{flex:1;min-width:0;}
.sub-nav-card-title{font-family:'Noto Serif JP',serif;font-size:0.88rem;font-weight:700;color:var(--brown);margin-bottom:3px;}
.sub-nav-card-desc{font-size:0.74rem;color:var(--text-light);line-height:1.6;margin:0;}
.sub-nav-card-arrow{font-size:1.05rem;color:var(--orange-light);flex-shrink:0;}

/* C: ケアマネジャー向けツール */
.caremanager-section{background:#EEF4FF;border-top:1.5px solid #C8D8F5;border-bottom:1.5px solid #C8D8F5;padding:28px 20px;}
.caremanager-inner{display:flex;align-items:center;justify-content:space-between;gap:20px;flex-wrap:wrap;}
.caremanager-body{flex:1;min-width:0;}
.caremanager-label{font-size:0.68rem;font-weight:700;color:#3B5BDB;letter-spacing:0.1em;margin-bottom:4px;}
.caremanager-title{font-family:'Noto Serif JP',serif;font-size:0.95rem;font-weight:700;color:var(--brown);margin-bottom:6px;}
.caremanager-desc{font-size:0.79rem;color:var(--text-light);line-height:1.7;margin:0;}
.btn-caremanager{background:#3B5BDB;color:#fff;border-radius:10px;padding:12px 24px;font-size:0.86rem;font-weight:700;text-decoration:none;display:inline-block;white-space:nowrap;transition:background 0.2s;flex-shrink:0;}
.btn-caremanager:hover{background:#2a4db8;}

/* 検索セクション（郵便番号・区から探す） */
.tp-search-section{background:linear-gradient(150deg,#FFFFFF 0%,#F8FAFC 50%,#F1F5F9 100%);padding:36px 20px 40px;}
.tp-search-title{font-family:'Noto Serif JP',serif;font-size:0.95rem;font-weight:700;color:var(--brown);text-align:center;margin-bottom:20px;}
.tp-search-title::before{content:'▎';color:var(--orange);margin-right:6px;}

@media(max-width:640px){
  .sub-nav-cards{flex-direction:column;}
  .caremanager-inner{flex-direction:column;align-items:flex-start;}
  .btn-caremanager{width:100%;text-align:center;box-sizing:border-box;}
  .meal-type-btn{flex:1;min-width:calc(50% - 5px);justify-content:center;}
}

@media(max-width:600px){
  .header-nav{display:none;}
  .ku-btn{font-size:0.7rem;padding:6px 2px;}
  .stats-inner{gap:18px;}
  .seido-blocks{grid-template-columns:1fr;}
  .private-specs{grid-template-columns:1fr;}
  .houkatsu-card{flex-direction:column;align-items:flex-start;}
  .compare-table{font-size:0.7rem;}
  .ward-grid{grid-template-columns:repeat(3,1fr);}
  .meal-types{grid-template-columns:1fr;}
  .ku-stats{gap:10px;}
}

/* ══════════════════════════════
   HERO SPLIT（トップページ）
══════════════════════════════ */

/* ── 左右分割レイアウト ── */
.hero-split{display:grid;grid-template-columns:1fr 1fr;min-height:88vh;max-height:960px;}

/* ── 左カラム ── */
.hero-left{
  background:linear-gradient(150deg,#FFFFFF 0%,#F8FAFC 60%,#F1F5F9 100%);
  padding:52px 40px 52px 80px;
  display:flex;flex-direction:column;justify-content:center;gap:18px;
}
.hero-h1{font-family:'Noto Serif JP',serif;font-size:clamp(1.5rem,3vw,2.2rem);font-weight:700;color:var(--brown);line-height:1.35;}
.hero-h1 em{color:var(--orange);font-style:normal;}
.hero-desc-text{font-size:0.86rem;color:var(--text-light);line-height:1.85;max-width:420px;}

/* 検索カード */
.hero-search-card{background:white;border-radius:18px;padding:20px;box-shadow:0 6px 32px rgba(92,61,46,0.13);max-width:460px;}

/* 統計行 */
.hero-stats-row{display:flex;align-items:center;gap:0;max-width:460px;}
.hero-stat{flex:1;text-align:center;}
.hero-stat-num{display:block;font-family:'Noto Serif JP',serif;font-size:1.25rem;font-weight:700;color:var(--orange);line-height:1.1;}
.hero-stat-label{font-size:0.62rem;color:var(--warm-gray);letter-spacing:0.05em;}
.hero-stat-div{width:1px;height:28px;background:var(--border);}

/* ── 右カラム ── */
.hero-right{
  background:#F1F5F9;
  border-left:1.5px solid #E2E8F0;
  overflow:hidden;
}

/* ベントーグリッド */
.hero-bento-grid{
  position:absolute;inset:0;
  display:grid;
  grid-template-columns:repeat(3,1fr);
  grid-template-rows:repeat(2,1fr);
  gap:14px;
  padding:48px;
}
.hero-bento-card{
  border-radius:18px;overflow:hidden;
  display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;
  box-shadow:0 8px 28px rgba(0,0,0,0.10);
  animation:bentoin 0.6s ease both;
}
.hero-bento-card--wide{grid-column:span 2;flex-direction:row;gap:14px;}
.hero-bento-card--orange{background:linear-gradient(135deg,#FF8C42,#E85D04);}
.hero-bento-card--amber{background:linear-gradient(135deg,#F4A261,#E76F51);}
.hero-bento-card--teal{background:linear-gradient(135deg,#2A9D8F,#264653);}
.hero-bento-card--warm{background:linear-gradient(135deg,#E9C46A,#F4A261);}
.hero-bento-card--blue{background:linear-gradient(135deg,#A8DADC,#457B9D);}
.hero-bento-card:nth-child(1){animation-delay:.1s;}
.hero-bento-card:nth-child(2){animation-delay:.2s;}
.hero-bento-card:nth-child(3){animation-delay:.25s;}
.hero-bento-card:nth-child(4){animation-delay:.3s;}
.hero-bento-card:nth-child(5){animation-delay:.35s;}
@keyframes bentoin{from{opacity:0;transform:translateY(16px) scale(0.96);}to{opacity:1;transform:translateY(0) scale(1);}}
.hero-bento-icon{font-size:2.2rem;}
.hero-bento-card--wide .hero-bento-icon{font-size:2.8rem;}
.hero-bento-label{font-size:0.72rem;font-weight:700;color:rgba(255,255,255,0.92);letter-spacing:0.04em;}
/* ベントーカードをリンクとして使う場合 */
a.hero-bento-card{text-decoration:none;cursor:pointer;}
a.hero-bento-card:hover{filter:brightness(1.1);transform:scale(1.03);transition:filter 0.2s,transform 0.2s;}

/* フローティングバッジ */
.hero-float-badge{
  position:absolute;
  background:white;border-radius:14px;padding:11px 15px;
  box-shadow:0 8px 28px rgba(0,0,0,0.14);
  display:flex;align-items:center;gap:10px;
  animation:floatbadge 4s ease-in-out infinite;
}
.hero-float-badge--top{top:28px;right:28px;animation-delay:.4s;}
.hero-float-badge--bottom{bottom:52px;left:24px;animation-delay:1.6s;}
@keyframes floatbadge{0%,100%{transform:translateY(0);}50%{transform:translateY(-7px);}}
.hero-float-icon{font-size:1.3rem;}
.hero-float-text strong{display:block;font-size:0.78rem;font-weight:700;color:var(--text);}
.hero-float-text span{font-size:0.67rem;color:var(--warm-gray);}

/* ── FEATURES STRIP ── */
.features-strip{background:var(--brown);padding:16px 20px;}
.features-inner{max-width:1000px;margin:0 auto;display:flex;justify-content:center;align-items:center;gap:0;flex-wrap:wrap;}
.feature-item{display:flex;align-items:center;gap:8px;color:white;padding:6px 20px;}
.feature-item span:first-child{font-size:1.1rem;}
.feature-item span:last-child{font-size:0.8rem;font-weight:500;white-space:nowrap;}
.feature-divider{width:1px;height:22px;background:rgba(255,255,255,0.25);}

/* ── SLIM CAREMANAGER BANNER ── */
.slim-caremanager{background:#EEF4FF;border-bottom:1.5px solid #C8D8F5;padding:14px 20px;}
.slim-caremanager-inner{max-width:1000px;margin:0 auto;display:flex;align-items:center;justify-content:space-between;gap:16px;flex-wrap:wrap;}
.slim-caremanager-body{flex:1;min-width:0;display:flex;align-items:center;gap:10px;flex-wrap:wrap;}
.slim-caremanager-label{font-size:0.72rem;font-weight:700;color:var(--blue);white-space:nowrap;}
.slim-caremanager-text{font-size:0.78rem;color:var(--text-light);}
.slim-caremanager-link{background:var(--blue);color:white;border-radius:8px;padding:8px 16px;font-size:0.8rem;font-weight:700;text-decoration:none;white-space:nowrap;transition:background 0.2s;flex-shrink:0;}
.slim-caremanager-link:hover{background:#2a4db8;}

/* ku-btn を <a> タグでも正しく表示 */
a.ku-btn{display:block;text-decoration:none;}

/* ── Hero 右カラム：特徴パネル ── */
.hero-features-panel{
  height:100%;display:flex;flex-direction:column;justify-content:center;
  padding:44px 40px 44px 36px;gap:16px;
}
.hero-features-heading{
  font-size:0.68rem;font-weight:700;color:var(--warm-gray);letter-spacing:0.12em;
  text-transform:uppercase;margin-bottom:2px;
}
.hero-feature-list{display:flex;flex-direction:column;gap:10px;}
.hero-feature-item{
  display:flex;align-items:flex-start;gap:13px;
  background:white;border-radius:12px;padding:13px 14px;
  border:1.5px solid var(--border);
  box-shadow:0 2px 8px rgba(92,61,46,0.05);
  text-decoration:none;color:var(--text);
  transition:border-color 0.2s,box-shadow 0.2s,transform 0.2s;
}
.hero-feature-item:hover{
  border-color:var(--orange-light);
  box-shadow:0 4px 16px rgba(232,114,42,0.10);
  transform:translateY(-1px);
}
.hero-feature-icon-wrap{
  width:42px;height:42px;border-radius:11px;flex-shrink:0;
  display:flex;align-items:center;justify-content:center;font-size:1.25rem;
}
.hfi--orange{background:var(--orange-pale);box-shadow:0 0 0 1.5px #7DD8D7 inset;}
.hfi--green{background:var(--green-light);box-shadow:0 0 0 1.5px #b8d9b9 inset;}
.hfi--blue{background:var(--blue-light);box-shadow:0 0 0 1.5px #c5d0f0 inset;}
.hfi--amber{background:#FEF9E7;box-shadow:0 0 0 1.5px #F9E79F inset;}
.hero-feature-item > div{flex:1;min-width:0;}
.hero-feature-title{font-size:0.84rem;font-weight:700;color:var(--brown);margin-bottom:3px;}
.hero-feature-desc{font-size:0.72rem;color:var(--text-light);line-height:1.6;margin:0;}
.hero-feature-arrow{font-size:1.1rem;color:var(--orange-light);flex-shrink:0;align-self:center;}

/* ── ブランド概要表（大阪市全体ページ） ── */
.brand-overview-table{width:100%;border-collapse:collapse;font-size:0.8rem;background:white;border-radius:10px;overflow:hidden;border:1.5px solid var(--border);}
.brand-overview-table th{background:var(--brown);color:white;padding:9px 12px;text-align:left;font-size:0.75rem;font-weight:700;white-space:nowrap;}
.brand-overview-table td{padding:10px 12px;border-bottom:1px solid var(--border);vertical-align:middle;line-height:1.5;}
.brand-overview-table tr:last-child td{border-bottom:none;}
.brand-overview-table tr:nth-child(even) td{background:#fafbfc;}
.brand-price-note{font-size:0.72rem;color:var(--warm-gray);margin-top:10px;line-height:1.7;}

/* ── 全国・宅配食サービス（大阪市全体・区ページ共通） ── */
.national-list{display:flex;flex-direction:column;gap:10px;}
.national-card{background:white;border:1.5px solid #C5D0F0;border-radius:12px;padding:14px 16px;box-shadow:0 2px 6px rgba(59,91,219,0.05);}
.national-card-head{display:flex;align-items:center;gap:8px;flex-wrap:wrap;margin-bottom:2px;}
.national-card-name{font-family:'Noto Serif JP',serif;font-size:0.95rem;font-weight:700;color:var(--brown);}
.national-card-note{font-size:0.75rem;color:var(--text-light);line-height:1.7;margin-top:4px;}
.national-card-link{display:inline-block;margin-top:10px;font-size:0.78rem;color:var(--blue);text-decoration:none;border:1px solid var(--blue-light);border-radius:6px;padding:4px 12px;background:white;transition:background 0.2s;}
.national-card-link:hover{background:var(--blue-light);}

/* ── 店舗カード内 価格行 ── */
.store-price-row{display:flex;flex-wrap:wrap;align-items:center;gap:10px;padding:8px 10px;background:#F8FAFC;border-radius:7px;margin-bottom:10px;border:1px solid var(--border);}
.store-price-item{font-size:0.8rem;color:var(--text);white-space:nowrap;}
.store-price-label{font-size:0.66rem;color:var(--warm-gray);margin-right:4px;font-weight:700;}
.store-price-note{font-size:0.66rem;color:var(--warm-gray);margin-left:auto;white-space:nowrap;}

/* ── 民間サービス一覧（トップページ） ── */
.private-nav-section{background:var(--cream);padding:36px 20px 40px;border-top:1.5px solid var(--border);}
.private-list{display:flex;flex-direction:column;gap:12px;margin-top:4px;}
.private-list-card{
  background:white;border:1.5px solid #C5D0F0;border-radius:14px;
  padding:16px 18px;box-shadow:0 2px 8px rgba(59,91,219,0.06);
}
.private-list-head{display:flex;align-items:center;gap:8px;flex-wrap:wrap;margin-bottom:2px;}
.private-list-name{font-family:'Noto Serif JP',serif;font-size:0.98rem;font-weight:700;color:var(--brown);}
.private-list-note{font-size:0.76rem;color:var(--text-light);line-height:1.7;margin-top:4px;}

/* ── ケアマネ1行ヒント ── */
.tp-caremanager-hint{margin-top:16px;font-size:0.76rem;color:var(--warm-gray);}
.tp-caremanager-hint a{color:var(--orange);text-decoration:none;}
.tp-caremanager-hint a:hover{text-decoration:underline;}

/* ── 区から探すセクション ── */
.ku-nav-section{background:white;padding:36px 20px 40px;border-top:1.5px solid var(--border);}
.ku-nav-grid{
  display:grid;grid-template-columns:repeat(6,1fr);gap:7px;margin-top:4px;
}
.ku-nav-item{
  display:block;background:var(--cream);border:1.5px solid var(--border);
  border-radius:9px;padding:10px 6px;text-align:center;
  text-decoration:none;color:var(--text-light);font-size:0.78rem;
  transition:all 0.18s;
}
.ku-nav-item:hover{
  border-color:var(--orange);background:var(--orange-pale);
  color:var(--orange-dark);transform:translateY(-1px);
}

@media(max-width:860px){.ku-nav-grid{grid-template-columns:repeat(4,1fr);}}
@media(max-width:480px){.ku-nav-grid{grid-template-columns:repeat(3,1fr);}}

/* ── Hero レスポンシブ ── */
@media(max-width:860px){
  .hero-split{grid-template-columns:1fr;min-height:auto;max-height:none;}
  .hero-left{padding:40px 20px;align-items:stretch;}
  .hero-search-card{max-width:100%;}
  .hero-stats-row{max-width:100%;}
  .hero-right{display:none;}
}
@media(max-width:600px){
  .features-inner{gap:0;}
  .feature-item{padding:4px 10px;}
  .feature-divider{height:16px;}
  .slim-caremanager-inner{flex-direction:column;align-items:flex-start;}
  .slim-caremanager-link{width:100%;text-align:center;box-sizing:border-box;}
}

/* ══════════════════════════════
   区ページ 新UI
══════════════════════════════ */

/* フィルターバー */
.ku-filter-bar{background:white;border:1.5px solid var(--border);border-radius:14px;padding:14px 16px;margin-bottom:16px;display:flex;flex-direction:column;gap:10px;}
.ku-filter-row{display:flex;align-items:center;gap:10px;flex-wrap:wrap;}
.ku-filter-label{font-size:0.68rem;font-weight:700;color:var(--warm-gray);letter-spacing:0.08em;white-space:nowrap;min-width:40px;}
.ku-filter-chips{display:flex;flex-wrap:wrap;gap:6px;flex:1;}
.ku-meal-chip,.ku-type-chip{background:white;border:1.5px solid var(--border);border-radius:20px;padding:5px 13px;font-size:0.75rem;font-family:inherit;cursor:pointer;color:var(--text-light);transition:all 0.2s;white-space:nowrap;}
.ku-meal-chip:hover,.ku-type-chip:hover{border-color:var(--orange-light);background:var(--orange-pale);color:var(--orange-dark);}
.ku-meal-chip.active{background:var(--orange);border-color:var(--orange);color:white;font-weight:700;}
.ku-type-chip.active{background:var(--brown);border-color:var(--brown);color:white;font-weight:700;}

/* 並び替え */
.ku-sort-wrap{display:flex;align-items:center;gap:6px;margin-left:auto;}
.ku-sort-label{font-size:0.68rem;color:var(--warm-gray);white-space:nowrap;}
.ku-sort-select{border:1.5px solid var(--border);border-radius:8px;padding:4px 8px;font-size:0.75rem;font-family:inherit;color:var(--text);background:white;cursor:pointer;outline:none;}
.ku-sort-select:focus{border-color:var(--orange);}

/* 件数バー */
.ku-count-bar{display:flex;align-items:baseline;gap:8px;margin-bottom:14px;padding:0 2px;}
.ku-count-main{font-family:'Noto Serif JP',serif;font-size:1rem;font-weight:700;color:var(--brown);}
.ku-count-sub{font-size:0.73rem;color:var(--warm-gray);}

/* セクションヘッダー */
.ku-section-header{display:flex;align-items:center;gap:10px;margin-bottom:12px;flex-wrap:wrap;}
.ku-section-title{font-family:'Noto Serif JP',serif;font-size:0.95rem;font-weight:700;color:var(--brown);}
.ku-section-title::before{content:'▎';color:var(--orange);margin-right:6px;}
.ku-section-title--private::before{color:var(--blue);}
.ku-section-note{font-size:0.68rem;color:var(--warm-gray);background:var(--cream);border:1px solid var(--border);border-radius:10px;padding:2px 9px;}

/* 委託カード */
.ku-cards{display:flex;flex-direction:column;gap:11px;}
.ku-card{background:white;border-radius:14px;overflow:hidden;border:1.5px solid var(--border);box-shadow:0 2px 8px rgba(92,61,46,0.06);transition:box-shadow 0.2s,transform 0.2s;animation:fadeUp 0.3s ease both;}
.ku-card:hover{box-shadow:0 6px 22px rgba(92,61,46,0.12);transform:translateY(-2px);}
.ku-card-inner{padding:14px 16px 10px;display:flex;gap:12px;align-items:flex-start;}
.ku-card-icon-col{flex-shrink:0;}
.ku-card-body{flex:1;min-width:0;}
.ku-card-name-row{display:flex;align-items:center;gap:6px;flex-wrap:wrap;margin-bottom:4px;}
.ku-card-brand{font-size:0.7rem;color:var(--warm-gray);margin-bottom:6px;}
.ku-card-tags{display:flex;flex-wrap:wrap;gap:5px;align-items:center;}
.ku-anpi-badge{font-size:0.67rem;font-weight:700;color:var(--green);background:var(--green-light);border:1px solid #b8d9b9;border-radius:10px;padding:2px 8px;white-space:nowrap;}
.ku-meal-tag{font-size:0.67rem;color:#1a7a4a;background:#e8f8f0;border:1px solid #b8e8cc;border-radius:10px;padding:2px 8px;white-space:nowrap;}
.ku-meal-tag--empty{color:var(--warm-gray);background:var(--cream);border-color:var(--border);}
.ku-card-actions{display:flex;gap:7px;padding:10px 14px;border-top:1px solid var(--border);background:#FDFAF7;flex-wrap:wrap;align-items:center;}

/* フィルター空状態 */
.ku-filter-empty{color:var(--text-light);font-size:0.84rem;padding:28px 16px;text-align:center;display:flex;flex-direction:column;align-items:center;gap:12px;}
.ku-reset-btn{background:var(--orange-pale);color:var(--orange);border:1.5px solid var(--orange-light);border-radius:8px;padding:7px 18px;font-size:0.78rem;font-weight:700;font-family:inherit;cursor:pointer;}
.ku-reset-btn:hover{background:var(--orange);color:white;}

/* ケアマネ導線バナー */
.ku-caremanager-banner{display:flex;align-items:center;justify-content:space-between;gap:14px;flex-wrap:wrap;background:#EEF4FF;border:1.5px solid #C8D8F5;border-radius:12px;padding:14px 18px;margin:24px 0;}
.ku-caremanager-banner-body{flex:1;min-width:0;}
.ku-caremanager-banner-label{display:block;font-size:0.68rem;font-weight:700;color:var(--blue);letter-spacing:0.06em;margin-bottom:3px;}
.ku-caremanager-banner-text{font-size:0.78rem;color:var(--text-light);line-height:1.6;}
.ku-caremanager-banner-link{background:var(--blue);color:white;border-radius:9px;padding:9px 16px;font-size:0.8rem;font-weight:700;text-decoration:none;white-space:nowrap;transition:background 0.2s;flex-shrink:0;}
.ku-caremanager-banner-link:hover{background:#2a4db8;}

/* 民間配食セクション */
.ku-section-private{margin-top:28px;}
.ku-private-note{font-size:0.76rem;color:var(--text-light);margin-bottom:12px;padding:10px 14px;background:var(--blue-light);border-radius:8px;border-left:3px solid var(--blue);}
.ku-private-cards{display:flex;flex-direction:column;gap:11px;}
.ku-private-card{background:white;border-radius:14px;overflow:hidden;border:1.5px solid #c5d0f0;box-shadow:0 2px 8px rgba(59,91,219,0.07);animation:fadeUp 0.3s ease both;}
.ku-spec-chips{display:flex;flex-wrap:wrap;gap:5px;margin:6px 0;}
.ku-spec-chip{font-size:0.67rem;color:var(--text-light);background:var(--cream);border:1px solid var(--border);border-radius:8px;padding:2px 8px;white-space:nowrap;}
.ku-private-notes{font-size:0.72rem;color:var(--text-light);background:var(--orange-pale);border-radius:6px;padding:7px 10px;margin-top:6px;}
.ku-private-coverage{font-size:0.71rem;color:var(--red);background:var(--red-light);border-radius:6px;padding:5px 9px;margin-top:5px;}

/* 地域包括セクション */
.ku-houkatsu-section{margin-top:28px;}
.ku-houkatsu-title{font-family:'Noto Serif JP',serif;font-size:0.92rem;font-weight:700;color:var(--brown);margin-bottom:10px;}

/* 補助セクション */
.ku-aux-section{margin-top:32px;}
.ku-aux-cards{display:flex;gap:12px;margin-bottom:20px;flex-wrap:wrap;}
.ku-aux-card{flex:1;min-width:220px;display:flex;align-items:center;gap:12px;background:white;border:1.5px solid var(--border);border-radius:12px;padding:14px 16px;text-decoration:none;color:var(--text);transition:all 0.2s;}
.ku-aux-card:hover{border-color:var(--orange-light);box-shadow:0 4px 14px rgba(232,114,42,0.10);transform:translateY(-1px);}
.ku-aux-icon{font-size:1.5rem;flex-shrink:0;}
.ku-aux-body{flex:1;min-width:0;}
.ku-aux-title{font-size:0.84rem;font-weight:700;color:var(--brown);margin-bottom:2px;}
.ku-aux-desc{font-size:0.72rem;color:var(--warm-gray);}
.ku-aux-arrow{font-size:1rem;color:var(--orange-light);flex-shrink:0;}
.ku-other-wards{background:white;border:1.5px solid var(--border);border-radius:12px;padding:16px;}
.ku-other-wards-title{font-size:0.76rem;font-weight:700;color:var(--warm-gray);margin-bottom:10px;}
.ku-other-wards-grid{display:flex;flex-wrap:wrap;gap:6px;}
.ku-other-ward-link{font-size:0.75rem;color:var(--text-light);text-decoration:none;padding:4px 10px;border:1.5px solid var(--border);border-radius:7px;background:var(--cream);transition:all 0.15s;}
.ku-other-ward-link:hover{border-color:var(--orange);color:var(--orange);background:var(--orange-pale);}

/* ── ツールバー（フィルター + 件数） ── */
.ku-tool-bar{
  display:flex;align-items:center;justify-content:space-between;
  gap:12px;flex-wrap:wrap;margin-bottom:16px;
}
.ku-tool-filters{display:flex;gap:8px;flex-wrap:wrap;}
.ku-filter-chip{
  background:white;border:1.5px solid var(--border);border-radius:20px;
  padding:6px 16px;font-size:0.78rem;font-family:inherit;cursor:pointer;
  color:var(--text-light);transition:all 0.18s;white-space:nowrap;
}
.ku-filter-chip:hover{border-color:var(--orange);color:var(--orange);}
.ku-filter-chip.active{
  background:var(--orange);border-color:var(--orange);
  color:white;font-weight:700;
}
.ku-tool-count{font-size:0.78rem;color:var(--warm-gray);white-space:nowrap;}
.ku-tool-count strong{color:var(--text);font-size:0.88rem;}

/* ── カード本体レイアウト ── */
.ku-card-main{padding:16px 18px 14px;}

/* ── 情報チップ行 ── */
.store-chips{display:flex;flex-wrap:wrap;gap:6px;margin:8px 0 12px;}
.store-chip{
  font-size:0.72rem;padding:3px 10px;border-radius:10px;
  background:var(--cream);color:var(--text-light);
  border:1px solid var(--border);white-space:nowrap;
}
.store-chip--area{background:#F0F4FF;color:#3551A8;border-color:#C8D3F5;}
.store-chip--delivery{background:#FEF9EC;color:#7A5A00;border-color:#EDD890;}
.store-chip--anpi{background:var(--green-light);color:#166534;border-color:#86EFAC;}
.store-chip--warn{background:var(--red-light);color:var(--red);border-color:#FCA5A5;}

/* ── 電話番号（メイン表示） ── */
.store-tel-row{
  display:flex;align-items:baseline;gap:8px;
  background:var(--cream);border-radius:8px;padding:10px 12px;
  border:1px solid var(--border);
}
.store-tel-label{
  font-size:0.68rem;font-weight:700;color:var(--warm-gray);
  letter-spacing:0.08em;white-space:nowrap;
}
.store-tel-num{
  font-size:1.05rem;font-weight:700;color:var(--text);
  letter-spacing:0.04em;
}
.store-tel-label--fax{margin-left:10px;color:var(--text-light);}
.store-tel-num--fax{font-size:0.88rem;color:var(--text-light);font-weight:500;}

/* ── CTA ボタン ── */
.btn-call--full{flex:2;min-width:0;justify-content:center;font-size:0.88rem;padding:11px 16px;}
.btn-web--full{
  flex:1;min-width:0;justify-content:center;text-align:center;
  background:white;color:var(--blue);border:1.5px solid var(--blue-light);
  border-radius:8px;padding:10px 14px;font-size:0.82rem;
  font-family:inherit;text-decoration:none;display:flex;
  align-items:center;gap:5px;white-space:nowrap;
}
.btn-web--full:hover{background:var(--blue-light);}

/* ── 民間カード ノート ── */
.private-card-note{
  font-size:0.74rem;color:var(--text-light);line-height:1.6;
  background:var(--cream);border-radius:6px;padding:7px 10px;margin-top:4px;
}

/* 区ページ レスポンシブ */
@media(max-width:600px){
  .ku-filter-row{flex-wrap:wrap;}
  .ku-sort-wrap{margin-left:0;width:100%;}
  .ku-caremanager-banner{flex-direction:column;align-items:flex-start;}
  .ku-caremanager-banner-link{width:100%;text-align:center;box-sizing:border-box;}
  .ku-aux-cards{flex-direction:column;}
  .ku-aux-card{min-width:0;}
}

/* ══════════════════════════════════════════
   大阪市ハブページ（osaka/index.html）
══════════════════════════════════════════ */

/* ── ヒーロー ── */
.ku-hero{background:var(--cream);border-bottom:1px solid var(--border);padding:40px 20px 32px;}
.ku-hero-inner{max-width:760px;margin:0 auto;}
.ku-hero h1{font-size:1.5rem;font-weight:700;color:var(--text);margin:8px 0 12px;}
.ku-intro-text{font-size:0.88rem;color:var(--text-light);line-height:1.8;margin:0 0 20px;}
.ku-stats{display:flex;gap:24px;flex-wrap:wrap;}
.ku-stat{display:flex;flex-direction:column;align-items:center;min-width:70px;}
.ku-stat-num{font-size:2rem;font-weight:700;color:var(--orange);line-height:1;}
.ku-stat-label{font-size:0.72rem;color:var(--text-light);margin-top:2px;}

/* ── 区グリッド ── */
.ward-grid-section{background:#fff;border:1px solid var(--border);border-radius:14px;padding:24px;margin-bottom:0;}
.ward-grid-title{font-size:1rem;font-weight:700;color:var(--text);margin-bottom:14px;}
.ward-grid{display:grid;grid-template-columns:repeat(6,1fr);gap:8px;}
.ward-item{
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  padding:10px 6px;background:var(--cream);border:1px solid var(--border);
  border-radius:8px;text-align:center;text-decoration:none;
  color:var(--text);font-size:0.82rem;font-weight:500;transition:background .15s;
}
.ward-item:hover{background:var(--orange-pale);border-color:var(--orange);}
.ward-item-count{font-size:0.68rem;color:var(--text-light);margin-top:3px;font-weight:400;}

/* ── ハブ内コンテンツ枠 ── */
.hub-intro{
  background:#fff;border:1px solid var(--border);border-radius:14px;
  padding:24px;
}
.compare-title{font-size:1rem;font-weight:700;color:var(--text);}

/* ── 制度比較テーブル ── */
.compare-table{
  width:100%;border-collapse:collapse;font-size:0.82rem;
}
.compare-table th,.compare-table td{
  border:1px solid var(--border);padding:9px 12px;text-align:left;
}
.compare-table th{
  background:var(--cream);font-weight:600;color:var(--text);
}
.compare-table tr:nth-child(even) td{background:#FAFAFA;}

/* ── ブランド概要テーブル ── */
.brand-overview-table{
  width:100%;border-collapse:collapse;font-size:0.82rem;white-space:nowrap;
}
.brand-overview-table th,.brand-overview-table td{
  border:1px solid var(--border);padding:9px 12px;text-align:left;
}
.brand-overview-table th{
  background:var(--cream);font-weight:600;color:var(--text);
}
.brand-overview-table tr:nth-child(even) td{background:#FAFAFA;}
.brand-overview-table td:first-child{white-space:normal;min-width:140px;}
.brand-price-note{font-size:0.72rem;color:var(--text-light);margin-top:8px;line-height:1.6;}

/* ── 全国サービス一覧 ── */
.national-list{display:flex;flex-direction:column;gap:12px;}
.national-card{
  border:1px solid var(--border);border-radius:10px;padding:16px;background:#fff;
}
.national-card-head{display:flex;align-items:center;gap:8px;flex-wrap:wrap;margin-bottom:8px;}
.national-card-name{font-size:0.95rem;font-weight:700;color:var(--text);}
.national-card-note{font-size:0.78rem;color:var(--text-light);margin:4px 0 8px;line-height:1.6;}
.national-card-link{
  display:inline-flex;align-items:center;gap:5px;
  background:var(--blue-light);color:var(--blue);border-radius:7px;
  padding:7px 14px;font-size:0.8rem;font-weight:600;text-decoration:none;
}
.national-card-link:hover{background:#d5e4fb;}

/* ── ページナビ ── */
.page-nav{background:var(--cream);border-radius:10px;padding:18px 20px;}
.page-nav-title{font-size:0.78rem;font-weight:700;color:var(--text-light);margin-bottom:10px;}
.page-nav-links{display:flex;gap:12px;flex-wrap:wrap;}
.page-nav-links a{font-size:0.82rem;color:var(--orange);text-decoration:none;}
.page-nav-links a:hover{text-decoration:underline;}

/* ── ハブページ レスポンシブ ── */
@media(max-width:700px){
  .ward-grid{grid-template-columns:repeat(4,1fr);}
}
@media(max-width:480px){
  .ward-grid{grid-template-columns:repeat(3,1fr);}
  .ku-hero h1{font-size:1.2rem;}
}

/* ══════════════════════════════════════════
   種別タグバッジ
══════════════════════════════════════════ */
.badge-type-local{background:#EBF7F7;color:#0A7E7D;}
.badge-type-national{background:#FEF3C7;color:#92400E;}
.badge-type-frozen{background:#EDE9FE;color:#5B21B6;}
.badge-type-coop{background:#DCFCE7;color:#166534;}
.badge-no-cert{background:#E0E7FF;color:#3730A3;}

/* ══════════════════════════════════════════
   区ページ フィルターバー（種別チップ）
══════════════════════════════════════════ */
.ku-filter-bar{
  display:flex;flex-direction:column;gap:10px;
  background:#fff;border:1px solid var(--border);border-radius:12px;
  padding:14px 16px;margin-bottom:16px;
}
.ku-type-chips{display:flex;gap:6px;flex-wrap:wrap;}
.ku-type-chip{
  display:inline-flex;align-items:center;gap:5px;
  padding:6px 12px;border-radius:20px;border:1.5px solid var(--border);
  background:#fff;color:var(--text-light);font-size:0.8rem;font-weight:500;
  cursor:pointer;transition:all .15s;white-space:nowrap;
}
.ku-type-chip:hover{border-color:var(--orange);color:var(--orange);}
.ku-type-chip.active{
  background:var(--orange);border-color:var(--orange);
  color:#fff;font-weight:600;
}
.ku-type-count{
  background:rgba(255,255,255,0.3);border-radius:10px;
  padding:1px 6px;font-size:0.72rem;font-weight:700;
}
.ku-type-chip:not(.active) .ku-type-count{
  background:var(--border);color:var(--text-light);
}
.ku-filter-sub{
  display:flex;align-items:center;gap:10px;
}

/* ── 非ローカルカード（全国・冷凍・生協）背景を微妙に差別化 ── */
.ku-card--nonlocal{background:#FAFBFF;}

/* ══════════════════════════════════════════
   対応早見表
══════════════════════════════════════════ */
.ku-quick-table-section{
  background:#fff;border:1px solid var(--border);border-radius:12px;
  padding:20px;margin-top:16px;
}
.ku-quick-table{
  width:100%;border-collapse:collapse;font-size:0.8rem;white-space:nowrap;
}
.ku-quick-table th,.ku-quick-table td{
  border:1px solid var(--border);padding:7px 10px;text-align:left;
}
.ku-quick-table th{
  background:var(--cream);font-weight:600;color:var(--text);font-size:0.75rem;
}
.ku-quick-table tr:nth-child(even) td{background:#FAFAFA;}
.ku-quick-table td:first-child{white-space:normal;min-width:140px;}
.tbl-center{text-align:center !important;}

/* ══════════════════════════════════════════
   区ページ レスポンシブ追加
══════════════════════════════════════════ */
@media(max-width:600px){
  .ku-type-chips{gap:4px;}
  .ku-type-chip{padding:5px 9px;font-size:0.75rem;}
  .ku-filter-sub{flex-wrap:wrap;}
}
