*{box-sizing:border-box}
:root{--primary:#b71c1c;--accent:#d32f2f;--bg:#f0f2f5;--text:#222;--link:#0056b3}
body{font-family:'Noto Sans JP',sans-serif;background:var(--bg);color:var(--text);margin:0;line-height:1.8;font-size:16px;-webkit-font-smoothing:antialiased}
.container{width:100%;max-width:1000px;margin:0 auto;padding:20px 16px}
a{text-decoration:none;color:inherit;transition:opacity .2s,color .15s}
a:hover{opacity:.85}
::selection{background:#ff5252;color:#fff}
::-moz-selection{background:#ff5252;color:#fff}
header.site{background:var(--primary);color:#fff;padding:0 16px;height:56px;display:flex;align-items:center;justify-content:space-between;position:sticky;top:0;z-index:1000;box-shadow:0 2px 8px rgba(0,0,0,.2)}
header.site .logo{font-size:17px;font-weight:900}
header.site .logo a{color:#fff}
.crumbs{font-size:12px;color:#666;margin-bottom:14px;word-break:break-all}
.crumbs a{color:var(--link)}
h1.page{font-size:22px;font-weight:900;margin:0 0 6px}
.lead{font-size:14px;color:#444;margin:0 0 20px}
.hero{text-align:center;padding:28px 16px;background:linear-gradient(135deg,#2c3e50,#111);color:#fff;border-radius:12px;margin-bottom:24px}
.hero h1{font-size:21px;font-weight:900;margin:0 0 8px}
.hero p{font-size:13px;opacity:.9;margin:0 0 18px}
.stats{display:grid;grid-template-columns:1fr 1fr 1fr;gap:8px;max-width:560px;margin:0 auto}
.stat{background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.2);padding:10px 4px;border-radius:8px}
.stat b{font-size:22px;font-weight:900;display:block;line-height:1.1;color:#ff5252}
.stat span{font-size:10px;opacity:.9}
.card{background:#fff;border:1px solid #e8edf3;border-radius:16px;box-shadow:0 8px 26px rgba(20,30,50,.08);padding:20px 20px 18px;margin-bottom:20px}
.card.plain{background:#fff}
.sec{font-size:16.5px;font-weight:800;color:#16202e;margin:0 0 15px;display:flex;align-items:center;gap:9px;letter-spacing:.01em}
.sec::before{content:"";width:5px;height:21px;border-radius:3px;background:linear-gradient(180deg,#e53935,#ff7a3d);flex:none}
.card.collapsible>.sec{cursor:pointer;user-select:none}
.card.collapsible>.sec::after{content:"▲";margin-left:auto;font-size:12px;color:#9aa7b6;font-weight:700;transition:transform .15s}
.card.collapsible.closed>.sec{margin-bottom:0}
.card.collapsible.closed>.sec::after{content:"▼"}
.card.collapsible.closed>.cbody{display:none}
.list{list-style:none;padding:0;margin:0;overflow-x:auto;-webkit-overflow-scrolling:touch}
.row{display:flex;gap:14px;padding:11px 8px;border-bottom:1px dashed #ddd;font-size:14px;border-radius:6px;transition:background .12s;width:max-content;min-width:100%}
.row:last-child{border-bottom:none}
.row:hover{background:#fff5f5}
.row .when{font-weight:700;color:#777;flex:0 0 auto;white-space:nowrap;font-size:12px;margin-top:2px}
.row .what{flex:0 0 auto;white-space:nowrap}
.row .what a:hover{color:#d32f2f;text-decoration:underline;opacity:1}
.tag{font-size:10px;color:#fff;padding:2px 7px;border-radius:3px;margin-right:6px;display:inline-block;vertical-align:middle}
.tag-fire{background:#d32f2f}.tag-veh{background:#5e35b1}.tag-forest{background:#2e7d32}.tag-ship{background:#00838f}.tag-other{background:#fb8c00}
.dmg{font-size:11px;color:#c62828;margin-left:6px}
.grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:10px}
.chip{display:flex;justify-content:space-between;align-items:center;gap:8px;background:#f6f8fb;padding:10px 13px;border-radius:10px;border:1px solid #e8edf3;font-weight:600;font-size:14px;color:#1a2433;transition:background .12s,border-color .12s,box-shadow .12s,transform .08s}
.chip:hover{background:#fff;border-color:#ffb38f;box-shadow:0 4px 12px rgba(211,47,47,.1);transform:translateY(-1px)}
/* 地図・エリア選択 */
.rmap{display:grid;grid-template-columns:210px 1fr;gap:20px;align-items:start}
.rmap-img{text-align:center}
.rmap-img img{width:100%;max-width:210px;filter:drop-shadow(0 6px 14px rgba(20,30,50,.12))}
.rmap-hint{font-size:12px;color:#8a98a8;margin:0 0 10px}
.regbtns{display:grid;grid-template-columns:repeat(4,1fr);gap:8px;margin-bottom:16px}
.regbtn{background:#f6f8fb;border:1px solid #e8edf3;border-radius:11px;padding:11px 6px;font-weight:800;font-size:13.5px;color:#1a2433;cursor:pointer;text-align:center;line-height:1.25;transition:all .12s}
.regbtn:hover{border-color:#ffb38f;background:#fff}
.regbtn.on{background:linear-gradient(135deg,#b71c1c,#e8472f);color:#fff;border-color:transparent;box-shadow:0 6px 14px rgba(183,28,28,.25)}
.regbtn small{display:block;font-size:10px;font-weight:700;color:#9aa7b6;margin-top:3px}
.regbtn.on small{color:#ffd9cf}
.regpref[hidden]{display:none}
@media(max-width:680px){.rmap{grid-template-columns:1fr}.rmap-img img{max-width:160px}.regbtns{grid-template-columns:repeat(4,1fr);gap:6px}.regbtn{font-size:12px;padding:10px 4px}}
.chip .n{background:#eee;color:#555;font-size:11px;font-weight:700;padding:2px 7px;border-radius:10px}
.chip .n.hi{background:#ffebee;color:#c62828}
.chip.off{background:#f3f4f6;border-color:#eee;color:#bbb;cursor:default;pointer-events:none}
.chip.off .n{background:#eee;color:#bbb}
.chome-row{display:flex;flex-wrap:wrap;gap:8px;margin:0 0 16px}
.chome-row .c{background:#fff8f8;border:1px solid #ffcdd2;border-radius:18px;padding:5px 13px;font-size:14px;font-weight:700}
.chome-row .c b{color:var(--accent);font-weight:900}
/* 地域傾向: 時間帯ヒートマップ + 焼損程度バー */
.statsum .ssum{font-size:14px;line-height:1.7;margin:4px 0 10px}
.statsum .ssum b{color:var(--accent);font-weight:900}
.minihm{display:flex;gap:2px;margin:2px 0 2px}
.minihm .hh{flex:1;height:22px;border-radius:3px;background:var(--accent)}
.hmx{display:flex;justify-content:space-between;font-size:10px;color:#9aa7b6;margin-bottom:4px}
.rk2{display:flex;align-items:center;gap:8px;margin:4px 0;font-size:13px}
.rk2l{width:84px;flex:0 0 auto;color:#555;text-align:right}
.rk2b{flex:1;height:14px;background:#eef1f5;border-radius:7px;overflow:hidden}
.rk2b i{display:block;height:100%;background:linear-gradient(90deg,#ef6c00,#d32f2f)}
.rk2n{width:54px;flex:0 0 auto;text-align:right;font-weight:700;font-variant-numeric:tabular-nums}
/* エリア口コミ常設カード */
.cmcard{background:linear-gradient(180deg,#fffdf6,#fff)}
.cmlist{list-style:none;margin:4px 0 0;padding:0;display:flex;flex-direction:column;gap:10px}
.cmlist li{border-left:3px solid #ffcf87;background:#fffdf6;border-radius:0 8px 8px 0;padding:8px 12px}
.cmlist .cm-txt{display:block;font-weight:700;color:#7a4a00;font-size:14px;line-height:1.6}
.cmlist .cm-meta{display:block;font-size:11px;color:#9aa7b6;margin-top:3px}
.insight{background:linear-gradient(180deg,#fff8f4,#fff)}
.insight .ins-list{list-style:none;margin:4px 0 0;padding:0;display:flex;flex-direction:column;gap:11px}
.insight .ins-list li{display:flex;gap:11px;align-items:flex-start;font-size:14px;line-height:1.65}
.insight .ins-i{flex:0 0 auto;font-size:19px;line-height:1.4}
.insight .ins-list b{color:var(--accent);font-weight:900}
.coverage{font-size:12px;color:#888;margin:6px 0 18px}
.typebar{display:flex;flex-wrap:wrap;gap:8px;margin:0 0 18px}
.typebar .t{background:#fff;border:1px solid #eee;border-radius:20px;padding:5px 12px;font-size:13px}
.typebar .t b{color:var(--accent)}
table.hist{width:100%;border-collapse:collapse;font-size:14px}
table.hist th,table.hist td{text-align:left;padding:9px 8px;border-bottom:1px solid #eee}
table.hist th{font-size:12px;color:#666;background:#fafafa}
.adbox{margin:22px 0;text-align:center;min-height:1px;overflow:hidden}
.search{max-width:560px;margin:0 auto}
.search form{display:flex;gap:8px}
.search input{flex:1;padding:13px;border:none;border-radius:6px;font-size:16px}
.search button{background:var(--accent);color:#fff;border:none;padding:0 18px;border-radius:6px;font-weight:700;cursor:pointer}
.note{font-size:12px;color:#777;margin-top:8px}
.pulse{}
.pulse .pulse-live{font-size:12px;font-weight:500;color:#888}
.pulse .pulse-live b{color:#fb8c00;font-size:15px}
.pulse-btns{display:grid;grid-template-columns:1fr;gap:10px;margin:6px 0 14px}
@media(min-width:560px){.pulse-btns{grid-template-columns:1fr 1fr 1fr}}
.pulse-cta{display:flex;align-items:center;gap:6px;font-size:13px;font-weight:800;color:#e65100;margin:2px 0 9px}
.pulse-btns button{font-family:inherit;font-size:15px;font-weight:800;padding:15px 12px;border:none;background:linear-gradient(#ffa726,#fb8c00);color:#fff;border-radius:12px;cursor:pointer;transition:transform .08s,box-shadow .12s,filter .2s;line-height:1.4;text-align:center;box-shadow:0 4px 0 #b35400,0 5px 11px rgba(0,0,0,.18);-webkit-tap-highlight-color:transparent}
.pulse-btns button:hover{filter:brightness(1.05)}
.pulse-btns button:active{transform:translateY(3px);box-shadow:0 1px 0 #b35400,0 2px 5px rgba(0,0,0,.2)}
.pulse-btns button.done{background:linear-gradient(#43a047,#2e7d32);box-shadow:0 4px 0 #1b5e20,0 5px 11px rgba(0,0,0,.18)}
.pulse-cm{margin:0 0 12px;padding:11px;background:#fff8f0;border:1px solid #ffe0b2;border-radius:10px}
.pulse-cm[hidden]{display:none}
.pulse-cm-l{margin:0 0 6px;font-size:12px;font-weight:800;color:#e65100}
.pulse-cm textarea{width:100%;border:1px solid #ddd;border-radius:8px;padding:9px;font-family:inherit;font-size:14px;resize:vertical}
.pulse-cm button{margin-top:7px;font-family:inherit;font-weight:800;font-size:13px;color:#fff;background:#fb8c00;border:none;border-radius:8px;padding:9px 16px;cursor:pointer}
.pulse-cm button:disabled{opacity:.6}
.pulse-feed .pf-cm{color:#bf360c;font-size:12.5px}
/* 最新の火事カード（ファーストビュー・赤ヘッダー帯） */
.latest-card{border:1px solid #f0dada;border-radius:18px;box-shadow:0 14px 34px rgba(183,28,28,.13);padding:0;overflow:hidden;margin-top:-28px;position:relative;z-index:5}
.latest-head{background:linear-gradient(135deg,#b71c1c 0%,#e8472f 100%);color:#fff;padding:15px 20px;display:flex;align-items:center;justify-content:space-between;gap:10px}
.latest-head .lh-title{font-size:18px;font-weight:900;color:#fff;text-shadow:0 1px 4px rgba(0,0,0,.18)}
.latest-head .lh-live{display:inline-flex;align-items:center;gap:5px;background:rgba(255,255,255,.22);color:#fff;font-size:11px;font-weight:900;padding:4px 10px;border-radius:999px;letter-spacing:.06em}
.latest-head .lh-live .pulse-dot{background:#fff;width:7px;height:7px}
.latest-card .lh-sub{font-size:12.5px;color:#7a8597;margin:13px 20px 4px}
.latest-card .list{margin:0 12px}
.latest-card .lh-more{display:inline-block;margin:6px 20px 16px;font-weight:800;font-size:13px;color:#b71c1c}
@media(max-width:780px){.latest-card{margin-top:-20px}.latest-head{padding:13px 15px}.latest-head .lh-title{font-size:16px}.latest-card .list{margin:0 4px}}
/* 右下フローティング 口コミ投稿 */
.pulse-fab{position:fixed;right:16px;bottom:16px;z-index:1600;max-width:340px}
.pulse-backdrop{position:fixed;inset:0;background:rgba(22,18,16,.5);z-index:1590;opacity:0;transition:opacity .18s ease}
.pulse-backdrop[hidden]{display:none}
.pulse-backdrop.on{opacity:1}
.pulse-fab-toggle{display:block;margin-left:auto;background:linear-gradient(135deg,#ff7a18,#e8472f);color:#fff;border:2px solid #fff;border-radius:999px;font-family:inherit;font-weight:900;font-size:15px;padding:14px 20px;cursor:pointer;box-shadow:0 8px 20px rgba(232,71,47,.5);animation:fabbounce 2.2s ease-in-out infinite, fabglow 1.8s ease-out infinite}
.pulse-fab-toggle:hover{filter:brightness(1.06)}
@keyframes fabbounce{0%,100%{transform:translateY(0)}50%{transform:translateY(-7px)}}
@keyframes fabglow{0%{box-shadow:0 8px 20px rgba(232,71,47,.5),0 0 0 0 rgba(232,71,47,.55)}70%{box-shadow:0 8px 20px rgba(232,71,47,.5),0 0 0 18px rgba(232,71,47,0)}100%{box-shadow:0 8px 20px rgba(232,71,47,.5),0 0 0 0 rgba(232,71,47,0)}}
.pulse-fab-panel{margin-top:10px;background:#fff;border:1px solid #ffd9b0;border-radius:14px;box-shadow:0 10px 30px rgba(0,0,0,.25);padding:14px}
.pulse-fab-panel[hidden]{display:none}
.pulse-fab-panel .pf-head{display:flex;align-items:center;justify-content:space-between;font-weight:800;font-size:14px;margin-bottom:6px}
.pulse-fab-panel .pf-live{background:#d32f2f;color:#fff;font-size:9px;font-weight:900;padding:2px 6px;border-radius:3px;margin-left:4px}
.pulse-fab-panel .pf-x{background:none;border:none;font-size:18px;color:#999;cursor:pointer;line-height:1}
.pulse-fab-panel .pf-note{font-size:11px;color:#888;margin:0 0 10px}
.pulse-fab-panel .pf-cnt{font-size:12px;color:#777;margin:10px 0 0}
.pulse-fab-panel .pf-cnt b{color:#e53935;font-size:15px}
@media(max-width:480px){.pulse-fab{left:12px;right:12px;max-width:none}.pulse-fab-panel{max-height:70vh;overflow:auto}}
.row .rep{display:inline-block;background:#eef3ff;color:#33529e;border:1px solid #c5d4f5;border-radius:4px;font-size:11px;font-weight:700;padding:0 6px;margin-left:6px}
.row .rep-l{font-size:11px;color:#33529e;margin-left:4px}
.pulse-feed{list-style:none;padding:0;margin:0;border-top:1px dashed #eee}
.pulse-feed li{display:flex;gap:8px;align-items:baseline;padding:8px 2px;border-bottom:1px dashed #eee;font-size:13px;animation:pulsein .5s ease}
.pulse-feed li .pf-ago{color:#999;font-size:11px;width:64px;flex-shrink:0}
.pulse-feed li .pf-area{font-weight:700;color:#555}
.pulse-feed .empty{color:#aaa;font-size:12px;padding:10px 2px}
@keyframes pulsein{from{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:none}}
.sbox{}
.sb-wrap{position:relative}
.sb-wrap input{width:100%;padding:14px 16px;border:2px solid #eee;border-radius:10px;font-size:16px;font-family:inherit;outline:none}
.sb-wrap input:focus{border-color:#d32f2f}
.sb-list{list-style:none;margin:6px 0 0;padding:0;position:absolute;left:0;right:0;top:100%;z-index:600;background:#fff;border:1px solid #ddd;border-radius:10px;box-shadow:0 12px 30px rgba(0,0,0,.22);max-height:340px;overflow-y:auto}
.sb-list li{display:flex;justify-content:space-between;align-items:center;gap:10px;padding:11px 16px;cursor:pointer;font-size:14px;border-bottom:1px solid #f3f3f3;color:#222;font-weight:600}
.sb-list li span{color:#222}
.sb-list li:last-child{border-bottom:none}
.sb-list li:hover,.sb-list li.on{background:#fff5f5}
.sb-list li b{color:#d32f2f;font-size:12px;font-weight:700;flex-shrink:0}
.dept{}
.station{}
.station .st-area{font-size:14px;margin:0 0 10px}.station .st-area b{color:#c62828}
.station .st-body{display:flex;gap:14px;align-items:flex-start}
@media(max-width:560px){.station .st-body{flex-direction:column}}
.station .st-photo{width:200px;max-width:42%;border-radius:10px;flex-shrink:0}
@media(max-width:560px){.station .st-photo{width:100%;max-width:100%}}
.station .st-name{font-size:18px;font-weight:900;color:#b71c1c;margin:0 0 6px}
.station .st-meta{font-size:14px;color:#444;margin:3px 0}
.station .st-meta a{color:#c62828;font-weight:700}
.station .st-link{color:#c62828;font-weight:700;text-decoration:underline}
.dept .dept-station{font-size:14px;margin:0 0 8px;background:#e8f5e9;border-radius:8px;padding:9px 12px}
.dept .dept-station b{color:#1b5e20;font-size:15px}
.dept .dept-station a{color:#1b5e20;font-weight:700;margin-left:6px;text-decoration:underline}
.dept .dept-name{font-size:18px;font-weight:900;margin:4px 0 4px;color:#1b5e20}
.dept .dept-meta{font-size:13px;color:#444;margin:2px 0}
.dept .dept-meta a{color:#1b5e20;font-weight:700}
.dept-links{display:flex;flex-wrap:wrap;gap:10px;margin-top:10px}
.dept-links a{display:inline-block;background:#e8f5e9;border:1px solid #c8e6c9;color:#1b5e20;font-weight:700;font-size:13px;padding:8px 14px;border-radius:8px}
.dept-links a:hover{background:#d7eed9}
.nearby{}
.nearby-btn{font-family:inherit;font-size:15px;font-weight:700;padding:14px 18px;width:100%;border:none;background:#0056b3;color:#fff;border-radius:10px;cursor:pointer;transition:background .2s}
.nearby-btn:hover{background:#01408a}.nearby-btn:disabled{background:#9bb}
.nearby-result{margin-top:14px}
.nearby-hit{display:flex;justify-content:space-between;align-items:center;gap:10px;background:#eef5ff;border:1px solid #cfe0f5;border-radius:10px;padding:14px 16px;font-weight:700;color:#0056b3}
.nearby-hit span{background:#0056b3;color:#fff;font-size:13px;padding:3px 10px;border-radius:12px;white-space:nowrap}
.pulse-dot{display:inline-block;width:8px;height:8px;border-radius:50%;background:#e53935;margin-right:5px;animation:blink 1.4s infinite}
@keyframes blink{0%,100%{opacity:1}50%{opacity:.3}}
/* ===== 速報ティッカー ===== */
.ticker{background:#b71c1c;color:#fff;display:flex;align-items:stretch;gap:0;overflow:hidden;font-size:13px}
.ticker .tk-lbl{position:relative;z-index:2;background:#7f0000;font-weight:900;padding:7px 12px;flex-shrink:0;font-size:12px;letter-spacing:.05em;display:flex;align-items:center;box-shadow:3px 0 6px rgba(0,0,0,.45)}
.ticker .tk-wrap{flex:1;min-width:0;overflow:hidden;position:relative}
.ticker .tk-track{display:flex;gap:34px;white-space:nowrap;animation:tkscroll 40s linear infinite;padding:7px 0 7px 16px}
.ticker .tk-track a{color:#fff}
.ticker .tk-track b{color:#ffd54f;margin-right:6px}
@keyframes tkscroll{from{transform:translateX(0)}to{transform:translateX(-50%)}}
/* ===== ヒーロー ===== */
.hero2{position:relative;color:#fff;border-radius:0;overflow:visible;margin:0 0 24px}
.hero2 .bg,.hero2 .ov{overflow:hidden}
.hero2 .bg{position:absolute;inset:0;background:center/cover no-repeat;filter:saturate(1.05)}
.hero2 .ov{position:absolute;inset:0;background:linear-gradient(90deg,rgba(10,12,18,.92) 0%,rgba(10,12,18,.72) 45%,rgba(10,12,18,.25) 100%)}
.hero2 .inner{position:relative;max-width:1000px;margin:0 auto;padding:40px 16px 30px}
.hero2 .inner>div{max-width:680px}
@media(max-width:780px){.hero2 .inner{padding:26px 16px}}
.hero2 h1{font-size:34px;font-weight:900;line-height:1.25;margin:0 0 14px;text-shadow:0 2px 12px rgba(0,0,0,.6)}
.hero2 h1 .r{color:#ff3b30}
@media(max-width:780px){.hero2 h1{font-size:26px}}
.hero2 .lead{font-size:14px;color:#fff;opacity:1;margin:0 0 18px;line-height:1.8;text-shadow:0 1px 6px rgba(0,0,0,.85)}
.hero-search input{width:100%;padding:15px 16px;border:none;border-radius:10px;font-size:16px;font-family:inherit;box-shadow:0 6px 20px rgba(0,0,0,.3)}
.hero-cta{display:flex;gap:10px;margin-top:14px;flex-wrap:wrap}
.hero-cta a{flex:1;min-width:150px;display:flex;align-items:center;justify-content:center;gap:7px;padding:13px;border-radius:9px;font-weight:800;font-size:14px;cursor:pointer}
.hero-cta .c1{background:#d32f2f;color:#fff}.hero-cta .c2{background:#ef6c00;color:#fff}
.hero-panel{background:rgba(13,15,20,.82);border:1px solid rgba(255,255,255,.14);border-radius:14px;padding:16px}
.hero-panel .ph{display:flex;align-items:center;justify-content:space-between;font-weight:800;font-size:15px;margin-bottom:4px}
.hero-panel .lv{background:#d32f2f;font-size:9px;font-weight:900;padding:2px 6px;border-radius:3px}
.hero-panel .note{font-size:11px;color:#ccd;margin:0 0 12px}
.hero-pbcta{font-size:12px;font-weight:800;color:#ffd54f;margin:0 0 9px}
.hero-pb{display:flex;flex-direction:column;gap:10px}
.hero-pb button{display:flex;align-items:center;justify-content:space-between;gap:10px;font-family:inherit;font-size:14px;font-weight:800;text-align:left;padding:14px 14px;border:none;border-radius:11px;color:#fff;cursor:pointer;transition:transform .08s,box-shadow .12s,filter .2s;-webkit-tap-highlight-color:transparent}
.hero-pb .b1{background:#c62828;box-shadow:0 4px 0 #8e1c1c,0 5px 11px rgba(0,0,0,.3)}
.hero-pb .b2{background:#ef6c00;box-shadow:0 4px 0 #a84c00,0 5px 11px rgba(0,0,0,.3)}
.hero-pb .b3{background:#455a64;box-shadow:0 4px 0 #2a373d,0 5px 11px rgba(0,0,0,.3)}
.hero-pb button:hover{filter:brightness(1.08)}
.hero-pb button:active{transform:translateY(3px);box-shadow:0 1px 0 rgba(0,0,0,.4)}
.hero-pb .vt{flex-shrink:0;font-size:11px;font-weight:900;background:rgba(255,255,255,.22);border:1px solid rgba(255,255,255,.55);border-radius:999px;padding:3px 11px;letter-spacing:.06em}
.hero-pb button.done{background:#2e7d32!important;box-shadow:0 4px 0 #1b5e20,0 5px 11px rgba(0,0,0,.3)!important;justify-content:center}
.hero-cm{margin:10px 0 0;padding:10px;background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.2);border-radius:10px}
.hero-cm[hidden]{display:none}
.hero-cm-l{margin:0 0 6px;font-size:12px;font-weight:800;color:#ffd54f}
.hero-cm textarea{width:100%;border:none;border-radius:8px;padding:9px;font-family:inherit;font-size:14px;resize:vertical}
.hero-cm button{margin-top:7px;font-family:inherit;font-weight:800;font-size:13px;color:#fff;background:#d32f2f;border:none;border-radius:8px;padding:9px 16px;cursor:pointer}
.hero-cm button:disabled{opacity:.6}
/* ===== 統計バー ===== */
.statbar{margin:0 0 20px;display:grid;grid-template-columns:repeat(4,1fr);gap:12px}
@media(max-width:680px){.statbar{grid-template-columns:1fr 1fr}}
.statbar .st{background:#fff;border-radius:12px;box-shadow:0 4px 16px rgba(0,0,0,.08);padding:14px;display:flex;align-items:center;gap:11px}
.statbar .st .ic{font-size:24px}
.statbar .st b{font-size:22px;font-weight:900;display:block;line-height:1.1;color:#b71c1c}
.statbar .st span{font-size:11px;color:#666}
/* ===== 火災マップ画像 ===== */
.mapwrap{display:grid;grid-template-columns:1.1fr 1fr;gap:18px;align-items:center}
@media(max-width:680px){.mapwrap{grid-template-columns:1fr}}
.mapwrap img{width:100%;border-radius:10px}
.maplegend{display:flex;flex-wrap:wrap;gap:8px;margin-top:10px;font-size:12px;color:#555}
.maplegend i{display:inline-block;width:12px;height:12px;border-radius:3px;margin-right:4px;vertical-align:middle}
/* ===== 火災種別カード ===== */
.typecards{display:grid;grid-template-columns:repeat(4,1fr);gap:12px}
@media(max-width:680px){.typecards{grid-template-columns:1fr 1fr}}
.typecards .tc{background:#fafafa;border:1px solid #eee;border-radius:12px;padding:16px;text-align:center}
.typecards .tc .ic{font-size:30px}
.typecards .tc b{display:block;font-size:24px;font-weight:900;color:#b71c1c;margin-top:4px}
.typecards .tc span{font-size:12px;color:#666}
/* ===== ナビ ===== */
header.site{background:#15171c;color:#fff;padding:0;height:auto;display:block;position:sticky;top:0;z-index:1000;box-shadow:0 2px 10px rgba(0,0,0,.3)}
.navbar{max-width:1100px;margin:0 auto;display:flex;align-items:center;gap:18px;padding:10px 16px}
.navbar .brand{display:flex;align-items:center;gap:9px;flex-shrink:0}
.navbar .brand .bi{font-size:24px}
.ico{display:inline-block;vertical-align:middle;object-fit:contain}
.statbar .st .ico{width:30px;height:30px}
.typecards .tc .ico{width:40px;height:40px}
.navbar .brand .ico{width:26px;height:26px}
.sec .ico{width:22px;height:22px;margin-right:4px}
.navbar .brand b{font-size:19px;font-weight:900;letter-spacing:.02em;line-height:1.05}
.navbar .brand span{display:block;font-size:10px;color:#aab;font-weight:500}
.navbar .brand a{color:#fff}
.navmenu{display:flex;gap:6px;margin-left:auto;flex-wrap:wrap;justify-content:flex-end}
.navmenu a{color:#e8eaf0;font-size:14px;font-weight:700;padding:8px 12px;border-radius:7px}
.navmenu a:hover{background:rgba(255,255,255,.08)}
.navmenu a.cur{color:#fff;border-bottom:3px solid #d32f2f;border-radius:0}
.navmenu .live{background:#d32f2f;color:#fff;font-size:9px;font-weight:900;padding:1px 5px;border-radius:3px;margin-left:4px;vertical-align:middle}
.navicons{display:flex;gap:6px;flex-shrink:0;font-size:18px}
.navicons span{cursor:pointer;padding:6px;opacity:.85}
.navtoggle{display:none}
@media(max-width:820px){
  .navmenu{display:none;width:100%;order:3;flex-direction:column;margin:0}
  .navmenu.open{display:flex}
  .navmenu a{padding:11px 8px;border-radius:0;border-bottom:1px solid rgba(255,255,255,.07)}
  .navtoggle{display:inline-block;margin-left:auto;cursor:pointer;font-size:22px}
}
footer.site{background:#15171c;color:#9aa;padding:36px 20px 28px;font-size:12px;margin-top:40px;line-height:1.9}
footer.site a{color:#bcc}
.foot-grid{max-width:1000px;margin:0 auto;display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:24px}
@media(max-width:680px){.foot-grid{grid-template-columns:1fr 1fr}}
.foot-grid h4{color:#fff;font-size:13px;margin:0 0 10px}
.foot-grid .fb{display:flex;align-items:center;gap:8px;margin-bottom:8px}
.foot-grid .fb .bi{font-size:22px}
.foot-grid .fb b{color:#fff;font-size:16px}
.foot-grid ul{list-style:none;padding:0;margin:0}
.foot-grid li{margin-bottom:7px}
.foot-emg{background:#d32f2f;color:#fff;border-radius:8px;padding:10px 12px;font-weight:900;text-align:center;margin-bottom:10px}
.foot-emg b{font-size:22px}
.foot-bottom{max-width:1000px;margin:22px auto 0;padding-top:16px;border-top:1px solid #2a2d35;text-align:center;color:#778}

/* 火災記録フィルタ(エリアページ) */
.recfilter .sec{display:flex;align-items:center;flex-wrap:wrap;gap:8px}
.filter-toggle{margin-left:auto;font-family:inherit;font-size:13px;font-weight:800;color:var(--accent);background:#fff;border:1.5px solid #f0c4c4;border-radius:999px;padding:5px 14px;cursor:pointer;transition:background .12s,color .12s,border-color .12s}
.filter-toggle:hover{background:#fff5f5}
.filter-toggle.on{background:var(--accent);border-color:var(--accent);color:#fff}
.filters[hidden]{display:none}
.recfilter .filters{display:flex;flex-direction:column;gap:9px;margin:6px 0 12px}
.fgroup{display:flex;flex-wrap:wrap;gap:6px;align-items:center}
.flabel{font-size:12px;font-weight:800;color:#7a8597;flex:0 0 30px}
.fchip{font-family:inherit;font-size:13px;font-weight:700;color:#445;background:#fff;border:1.5px solid #e2e8f0;border-radius:999px;padding:5px 12px;cursor:pointer;display:inline-flex;align-items:center;gap:5px;transition:background .12s,border-color .12s,color .12s}
.fchip b{color:var(--accent);font-weight:900;font-size:12px}
.fchip:hover{border-color:#f0b8b8}
.fchip.on{background:var(--accent);border-color:var(--accent);color:#fff}
.fchip.on b{color:#fff}
.rec-count{font-size:12px;color:#7a8597;margin:0 0 8px}
.rec-count b{color:var(--accent);font-size:14px}
.rec-empty{font-size:14px;color:#888;padding:14px 4px}
.hist-wrap{overflow-x:auto;-webkit-overflow-scrolling:touch}
.td-when{white-space:nowrap}

/* 防災管理会社（消防設備点検実績） */
.card.bousai .sec{display:flex;align-items:center;flex-wrap:wrap;gap:8px}
.bz-n{font-size:12px;font-weight:700;color:#fff;background:var(--accent);border-radius:10px;padding:2px 10px}
.bz-colist{list-style:none;margin:10px 0 0;padding:0;display:flex;flex-direction:column;gap:2px}
.bz-colist li{display:flex;align-items:center;flex-wrap:wrap;gap:8px;padding:8px 4px;border-bottom:1px solid #f0f0f2}
.bz-co{font-weight:700;color:#1a2740;text-decoration:none}
.bz-co:hover{text-decoration:underline}
.bz-cnt{font-size:12px;color:#fff;background:#8a94a6;border-radius:9px;padding:1px 8px}
.bz-tel{font-size:12px;color:#7a8597;margin-left:auto}
.bz-blk{margin:14px 0 6px;font-size:13px;font-weight:700;color:#5a6577}
.bz-bllist{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:2px}
.bz-bllist li{display:flex;align-items:baseline;flex-wrap:wrap;gap:6px 10px;padding:6px 4px;border-bottom:1px dotted #eceef1;font-size:13px}
.bz-bn{font-weight:700;color:#2a3346}
.bz-ba{color:#7a8597;font-size:12px}
.bz-bw{color:#8a94a6;font-size:12px;margin-left:auto;white-space:nowrap}

/* 防災管理会社 地図・索引 */
.bzmap{height:360px;border-radius:8px;overflow:hidden;margin-top:6px;z-index:0}
.bz-area2{font-size:12px;color:#7a8597}
.bz-more{margin:12px 0 4px}
.bz-more a{font-weight:700;color:#1a2740;text-decoration:none}
.bz-more a:hover{text-decoration:underline}
