/*
Theme Name: Keiba Trend News
Theme URI: https://eatransform.net/
Description: 競馬AIニュース速報 - 中央・地方競馬ニュース配信テーマ
Version: 2.0.0
Author: Eatransform
Text Domain: keiba-trend
*/

/* ===== VARIABLES ===== */
:root {
    --green:      #1a6b3a;
    --green-mid:  #155630;
    --green-light:#e8f5ee;
    --green-dim:  rgba(26,107,58,.06);
    --gold:       #c8922a;
    --gold-light: #fef3e2;
    --dark:       #0f1c10;
    --text:       #111827;
    --sub:        #6b7280;
    --muted:      #9ca3af;
    --line:       #e5e7eb;
    --line-dark:  #d1d5db;
    --bg:         #f8f9fb;
    --card:       #ffffff;
    --max:        1160px;
    --r:          4px;
    --font:       'Noto Sans JP','Hiragino Sans','Yu Gothic UI',sans-serif;
}

*,*::before,*::after { box-sizing:border-box; margin:0; padding:0 }
html { font-size:15px; -webkit-text-size-adjust:100% }
html,body { font-family:var(--font); background:var(--bg); color:var(--text); line-height:1.75; overflow-x:hidden; max-width:100%; }
a { color:inherit; text-decoration:none }
img { max-width:100%; height:auto; display:block }

/* ===== TOP BAR ===== */
.top-bar { background:var(--dark); padding:6px 0; font-size:.68rem; color:rgba(255,255,255,.45); }
.top-bar-inner { max-width:var(--max); margin:0 auto; padding:0 24px; display:flex; align-items:center; justify-content:space-between; gap:8px; flex-wrap:nowrap; overflow:hidden; }
.top-bar-left { display:flex; align-items:center; gap:12px; min-width:0; overflow:hidden; }
.top-bar-date { color:rgba(255,255,255,.35); white-space:nowrap; flex-shrink:0; }
.top-bar-tag { color:rgba(255,255,255,.6); font-weight:600; letter-spacing:.05em; font-size:.65rem; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.top-bar-badge { background:var(--gold); color:#fff; font-size:.6rem; font-weight:700; padding:2px 8px; border-radius:2px; letter-spacing:.04em; white-space:nowrap; flex-shrink:0; }

/* ===== HEADER ===== */
.site-header { background:#fff; border-bottom:1px solid var(--line); position:sticky; top:0; z-index:100; box-shadow:0 1px 6px rgba(0,0,0,.06); }
.header-main { max-width:var(--max); margin:0 auto; padding:14px 24px; display:flex; align-items:center; justify-content:space-between; gap:24px; }
.logo { display:flex; align-items:center; gap:12px; flex-shrink:0; min-width:0; }
.logo-mark { display:flex; align-items:center; justify-content:center; width:46px; height:46px; background:var(--green); border-radius:3px; flex-shrink:0; }
.logo-mark svg { width:26px; height:26px; }
.logo-text { min-width:0; }
h1.logo-name { font-size:1.2rem; font-weight:900; color:var(--dark); letter-spacing:-.02em; line-height:1.15; display:block; white-space:nowrap; margin:0; padding:0; }
.logo-name { font-size:1.2rem; font-weight:900; color:var(--dark); letter-spacing:-.02em; line-height:1.15; display:block; white-space:nowrap; }
.logo-tagline { font-size:.58rem; color:var(--sub); letter-spacing:.07em; display:block; margin-top:2px; text-transform:uppercase; white-space:nowrap; }
.site-nav { display:flex; align-items:center; gap:1px; flex:1; justify-content:center; }
.site-nav a { color:var(--text); font-size:.8rem; font-weight:600; padding:8px 12px; border-radius:3px; transition:all .15s; white-space:nowrap; }
.site-nav a:hover { color:var(--green); background:var(--green-dim); }
.header-actions { display:flex; align-items:center; gap:8px; }
.search-btn { background:none; border:1.5px solid var(--line); border-radius:3px; cursor:pointer; color:var(--sub); padding:7px 10px; display:flex; align-items:center; transition:all .15s; }
.search-btn:hover { border-color:var(--green); color:var(--green); }

/* ===== NAV STRIP ===== */
.nav-strip { border-top:3px solid var(--green); border-bottom:1px solid var(--line); background:#fff; }
.nav-strip-inner { max-width:var(--max); margin:0 auto; padding:0 24px; display:flex; align-items:center; overflow-x:auto; }
.nav-strip-inner a { font-size:.76rem; font-weight:700; color:var(--sub); padding:10px 14px; border-bottom:3px solid transparent; margin-bottom:-1px; transition:all .15s; white-space:nowrap; letter-spacing:.02em; }
.nav-strip-inner a:hover { color:var(--green); border-bottom-color:var(--green); }

/* ===== HAMBURGER ===== */
.hamburger { display:none; background:none; border:none; cursor:pointer; flex-direction:column; gap:5px; padding:6px; }
.hamburger span { display:block; width:22px; height:2px; background:var(--dark); border-radius:2px; }
.mobile-nav { display:none; background:#fff; border-top:1px solid var(--line); }
.mobile-nav.open { display:block; }
.mobile-nav a { display:flex; align-items:center; gap:10px; padding:13px 24px; font-size:.88rem; font-weight:600; color:var(--text); border-bottom:1px solid var(--line); text-decoration:none; }
.mobile-nav a:hover { background:var(--green-dim); color:var(--green); }
.mobile-nav a svg { opacity:.5; flex-shrink:0; }

/* ===== SEARCH OVERLAY ===== */
.search-overlay { position:fixed; inset:0; background:rgba(0,0,0,.65); z-index:200; display:flex; align-items:flex-start; justify-content:center; padding-top:80px; }
.search-overlay-inner { background:#fff; border-radius:6px; padding:24px; width:min(600px,90vw); display:flex; gap:10px; position:relative; }
.search-overlay-inner input { flex:1; border:1.5px solid var(--line); border-radius:4px; padding:12px 14px; font-size:.95rem; font-family:var(--font); outline:none; }
.search-overlay-inner input:focus { border-color:var(--green); }
.search-overlay-inner button[type=submit] { background:var(--green); color:#fff; border:none; border-radius:4px; padding:12px 20px; font-size:.88rem; font-weight:700; cursor:pointer; font-family:var(--font); }
.search-overlay-close { position:absolute; top:-14px; right:-14px; background:var(--dark); color:#fff; border:none; border-radius:50%; width:30px; height:30px; cursor:pointer; font-size:.8rem; display:flex; align-items:center; justify-content:center; }

/* ===== LAYOUT ===== */
.wrap { max-width:var(--max); margin:0 auto; padding:32px 24px; }
.grid { display:grid; grid-template-columns:1fr 300px; gap:36px; }

/* ===== SECTION HEADER ===== */
.sec { display:flex; align-items:center; gap:12px; margin:32px 0 18px; padding-bottom:10px; border-bottom:2px solid var(--dark); }
.sec h2 { font-size:.72rem; font-weight:900; letter-spacing:.14em; color:var(--dark); text-transform:uppercase; display:flex; align-items:center; gap:8px; }
.sec h2::before { content:''; display:block; width:4px; height:16px; background:var(--green); border-radius:2px; }
.sec-more { margin-left:auto; font-size:.72rem; color:var(--green); font-weight:600; }
.sec-more:hover { text-decoration:underline; }

/* ===== RACE RESULTS ===== */
.race-results-section { margin-bottom:8px; }
.race-block { background:var(--card); border:1px solid var(--line); border-radius:var(--r); overflow:hidden; margin-bottom:16px; }
.race-block-header { background:var(--green); color:#fff; padding:10px 16px; display:flex; align-items:center; justify-content:space-between; flex-wrap:wrap; gap:8px; }
.race-block-title { font-size:.85rem; font-weight:800; letter-spacing:.03em; display:flex; align-items:center; gap:10px; }
.race-place-badge { background:rgba(255,255,255,.2); padding:2px 10px; border-radius:2px; font-size:.7rem; font-weight:700; }
.race-meta { font-size:.7rem; color:rgba(255,255,255,.7); display:flex; gap:12px; flex-wrap:wrap; }
.race-updated { font-size:.65rem; color:rgba(255,255,255,.5); }
.race-table-wrap { overflow-x:auto; }
.race-table { width:100%; border-collapse:collapse; font-size:.8rem; table-layout:fixed; }
.race-table th { background:var(--green-light); color:var(--green); font-size:.65rem; font-weight:800; letter-spacing:.06em; padding:8px 10px; text-align:left; border-bottom:2px solid var(--green); white-space:nowrap; overflow:hidden; }
.race-table td { padding:8px 10px; border-bottom:1px solid var(--line); vertical-align:middle; overflow:hidden; text-overflow:ellipsis; white-space:nowrap; }
/* 列幅: 着順 馬番 馬名 騎手 タイム 人気 単勝 */
.race-table th:nth-child(1),.race-table td:nth-child(1){width:46px;text-align:center;}
.race-table th:nth-child(2),.race-table td:nth-child(2){width:42px;text-align:center;}
.race-table th:nth-child(3),.race-table td:nth-child(3){width:130px;}
.race-table th:nth-child(4),.race-table td:nth-child(4){width:90px;}
.race-table th:nth-child(5),.race-table td:nth-child(5){width:90px;}
.race-table th:nth-child(6),.race-table td:nth-child(6){width:44px;text-align:center;}
.race-table th:nth-child(7),.race-table td:nth-child(7){width:54px;text-align:right;}
.race-table tr:last-child td { border-bottom:none; }
.race-table tr:hover td { background:var(--green-dim); }
.rank-badge { display:inline-flex; align-items:center; justify-content:center; width:24px; height:24px; border-radius:3px; font-size:.72rem; font-weight:800; }
.rank-1 { background:var(--gold); color:#fff; }
.rank-2 { background:#999; color:#fff; }
.rank-3 { background:#a0724a; color:#fff; }
.rank-other { background:var(--line); color:var(--sub); }
.horse-name { font-weight:700; color:var(--dark); }
.popular-badge { display:inline-flex; align-items:center; justify-content:center; width:20px; height:20px; border-radius:50%; font-size:.65rem; font-weight:800; }
.pop-1 { background:#e53e3e; color:#fff; }
.pop-2 { background:#e57c3e; color:#fff; }
.pop-3 { background:#e5b03e; color:#fff; }
.pop-other { background:#bbb; color:#fff; }
.rank-other { background:#ddd; color:#555; }
.pop-2 { background:#ed8936; color:#fff; }
.pop-3 { background:#ecc94b; color:#333; }
.pop-other { background:var(--line); color:var(--sub); }
.odds-val { color:var(--green); font-weight:700; }
.race-ai-comment { padding:12px 16px; background:var(--green-dim); border-top:1px solid var(--green-light); font-size:.8rem; color:var(--text); line-height:1.7; display:flex; gap:8px; align-items:flex-start; }
.race-ai-icon { background:var(--green); color:#fff; font-size:.6rem; font-weight:800; padding:2px 6px; border-radius:2px; white-space:nowrap; flex-shrink:0; margin-top:2px; }
.race-empty { padding:32px 16px; text-align:center; color:var(--sub); font-size:.85rem; }
.race-empty-icon { font-size:2rem; margin-bottom:10px; }

/* ===== FEATURED ===== */
.featured { display:block; background:var(--card); border:1px solid var(--line); border-radius:var(--r); overflow:hidden; margin-bottom:4px; transition:box-shadow .2s; }
.featured:hover { box-shadow:0 6px 24px rgba(26,107,58,.12); }
.feat-img { width:100%; aspect-ratio:21/9; overflow:hidden; position:relative; }
.feat-img img { width:100%; height:100%; object-fit:cover; transition:transform .4s; }
.featured:hover .feat-img img { transform:scale(1.015); }
.feat-overlay { position:absolute; bottom:0; left:0; right:0; background:linear-gradient(to top,rgba(15,28,16,.88) 0%,rgba(15,28,16,.3) 60%,transparent 100%); padding:48px 28px 24px; }
.feat-cat-overlay { display:inline-block; background:var(--green); color:#fff; font-size:.62rem; font-weight:800; padding:3px 10px; border-radius:2px; letter-spacing:.05em; margin-bottom:10px; }
.feat-title-overlay { font-size:1.6rem; font-weight:900; color:#fff; line-height:1.4; text-shadow:0 1px 4px rgba(0,0,0,.4); letter-spacing:-.01em; }
.feat-body { padding:16px 24px 20px; border-top:1px solid var(--line); display:flex; align-items:flex-start; justify-content:space-between; gap:20px; }
.feat-excerpt { font-size:.88rem; color:var(--sub); line-height:1.8; flex:1; }
.feat-meta { font-size:.72rem; color:var(--muted); white-space:nowrap; padding-top:3px; }

/* ===== SKEW DIVIDER ===== */
.skew-divider { height:3px; background:linear-gradient(90deg,var(--green) 0%,#66cc88 60%,transparent 100%); margin:24px 0; clip-path:polygon(0 0,100% 0,97% 100%,0 100%); }

/* ===== CARD GRID ===== */
.card-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:20px; margin-bottom:4px; }
.card { background:var(--card); border-radius:var(--r); overflow:hidden; border:1px solid var(--line); transition:box-shadow .2s,transform .2s; display:flex; flex-direction:column; }
.card:hover { box-shadow:0 4px 20px rgba(26,107,58,.1); transform:translateY(-2px); }
.card-img { aspect-ratio:16/9; overflow:hidden; flex-shrink:0; }
.card-img img { width:100%; height:100%; object-fit:cover; transition:transform .3s; }
.card:hover .card-img img { transform:scale(1.04); }
.card-body { padding:14px 16px 16px; display:flex; flex-direction:column; flex:1; }
.cat-tag { display:inline-block; background:var(--green-light); color:var(--green); font-size:.6rem; font-weight:700; padding:2px 8px; border-radius:2px; margin-bottom:8px; border-left:2px solid var(--green); }
.card-ttl { font-size:.88rem; font-weight:700; line-height:1.5; margin-bottom:8px; flex:1; }
.card-ttl a:hover { color:var(--green); }
.card-excerpt { font-size:.75rem; color:var(--sub); line-height:1.7; margin-bottom:10px; display:-webkit-box; -webkit-line-clamp:2; -webkit-box-orient:vertical; overflow:hidden; }
.card-footer { display:flex; align-items:center; justify-content:space-between; margin-top:auto; padding-top:8px; border-top:1px solid var(--line); }
.card-date { font-size:.68rem; color:var(--muted); }
.card-read { font-size:.68rem; color:var(--green); font-weight:600; }

/* ===== NEWS LIST ===== */
.news-list { display:flex; flex-direction:column; }
.ni { display:flex; gap:16px; padding:16px 0; border-bottom:1px solid var(--line); align-items:flex-start; }
.ni:first-child { border-top:1px solid var(--line); }
.ni-img { flex-shrink:0; width:110px; height:72px; overflow:hidden; border-radius:var(--r); }
.ni-img img { width:100%; height:100%; object-fit:cover; transition:transform .3s; }
.ni:hover .ni-img img { transform:scale(1.04); }
.ni-body { flex:1; min-width:0; }
.ni-top { display:flex; align-items:center; gap:8px; margin-bottom:6px; }
.ni-cat { background:var(--green-light); color:var(--green); font-size:.6rem; font-weight:700; padding:1px 7px; border-radius:2px; border-left:2px solid var(--green); }
.ni-ttl { font-size:.9rem; font-weight:700; line-height:1.5; display:block; margin-bottom:6px; transition:color .15s; }
.ni-ttl:hover { color:var(--green); }
.ni-excerpt { font-size:.78rem; color:var(--sub); line-height:1.7; display:-webkit-box; -webkit-line-clamp:2; -webkit-box-orient:vertical; overflow:hidden; margin-bottom:5px; }
.ni-meta { font-size:.68rem; color:var(--muted); }

/* ===== PAGINATION ===== */
.pagination { display:flex; gap:4px; margin-top:32px; flex-wrap:wrap; }
.pagination a,.pagination span { display:inline-flex; align-items:center; justify-content:center; padding:8px 14px; border-radius:3px; font-size:.8rem; font-weight:600; border:1px solid var(--line); }
.pagination a:hover { border-color:var(--green); color:var(--green); background:var(--green-dim); }
.pagination .current { background:var(--green); color:#fff; border-color:var(--green); }

/* ===== SIDEBAR ===== */
.side-card { background:var(--card); border:1px solid var(--line); border-radius:var(--r); overflow:hidden; margin-bottom:24px; }
.side-hd { background:var(--dark); color:#fff; font-size:.65rem; font-weight:800; letter-spacing:.14em; padding:10px 16px; text-transform:uppercase; display:flex; align-items:center; gap:8px; }
.side-hd::before { content:''; display:block; width:3px; height:12px; background:var(--gold); border-radius:1px; flex-shrink:0; }
.hot-list { padding:4px 0; }
.hi { display:flex; align-items:flex-start; gap:10px; padding:10px 16px; }
.hi:not(:last-child) { border-bottom:1px solid var(--line); }
.hi-n { font-size:.65rem; font-weight:800; min-width:22px; width:22px; height:22px; display:flex; align-items:center; justify-content:center; border-radius:3px; flex-shrink:0; margin-top:1px; }
.hi-n.r1 { background:var(--gold); color:#fff; }
.hi-n.r2 { background:#bbb; color:#fff; }
.hi-n.r3 { background:#a0724a; color:#fff; }
.hi-n.rx { background:var(--line); color:var(--sub); }
.hi-w { font-size:.78rem; line-height:1.55; }
.hi-w a:hover { color:var(--green); }
.side-recent-item { display:flex; gap:10px; padding:10px 16px; border-bottom:1px solid var(--line); align-items:flex-start; }
.side-recent-item:last-child { border-bottom:none; }
.side-recent-img { flex-shrink:0; width:64px; height:46px; overflow:hidden; border-radius:var(--r); }
.side-recent-img img { width:100%; height:100%; object-fit:cover; }
.side-recent-body { flex:1; min-width:0; display:flex; align-items:flex-start; gap:6px; }
.side-recent-body .hi-n { width:22px; min-width:22px; height:22px; flex-shrink:0; display:inline-flex; align-items:center; justify-content:center; border-radius:3px; font-size:.65rem; font-weight:800; margin-top:1px; }
.side-recent-ttl { font-size:.76rem; font-weight:600; line-height:1.5; flex:1; display:block; }
.side-recent-ttl:hover { color:var(--green); }
.side-recent-date { font-size:.68rem; color:var(--sub); margin-top:2px; }

/* ===== SINGLE ===== */
.single-wrap { max-width:var(--max); margin:0 auto; padding:32px 24px; display:grid; grid-template-columns:1fr 300px; gap:36px; }
.art-wrap { background:#fff; border-radius:var(--r); border:1px solid var(--line); overflow:hidden; }
.art-header { padding:32px 36px 0; }
.art-cats { display:flex; gap:8px; flex-wrap:wrap; margin-bottom:16px; }
.art-cat { display:inline-block; font-size:.68rem; font-weight:700; letter-spacing:.06em; text-transform:uppercase; color:#fff; background:var(--green); padding:4px 12px; border-radius:3px; text-decoration:none; transition:opacity .2s; }
.art-cat:hover { opacity:.8; }
.art-h1 { font-size:1.75rem; font-weight:800; line-height:1.35; color:var(--dark); margin:0 0 18px; letter-spacing:-.01em; }
.art-meta { display:flex; flex-wrap:wrap; gap:16px; align-items:center; font-size:.78rem; color:#888; margin-bottom:20px; }
.art-meta-item { display:flex; align-items:center; gap:5px; }
.art-meta-item svg { opacity:.6; flex-shrink:0; }
.art-meta-cat { color:var(--green); font-weight:600; }
.art-divider { height:3px; background:linear-gradient(90deg, var(--green) 0%, #e8f5ee 60%, transparent 100%); margin-bottom:0; border-radius:2px; }
.art-thumb { line-height:0; }
.art-thumb img { width:100%; height:auto; display:block; }
.art-photo-credit { font-size:.72rem; color:#999; padding:6px 36px; background:#fafafa; border-bottom:1px solid var(--line); }
.art-body { padding:28px 36px 32px; font-size:.93rem; line-height:1.95; color:var(--text); }
.art-body h2 { font-size:1.1rem; font-weight:800; color:var(--dark); border-left:4px solid var(--green); padding-left:14px; margin:32px 0 14px; }
.art-body h3 { font-size:1rem; font-weight:700; color:var(--dark); margin:24px 0 10px; }
.art-body p { margin-bottom:18px; }
.art-body p:last-child { margin-bottom:0; }
.art-tags { display:flex; align-items:flex-start; gap:12px; padding:20px 36px 28px; border-top:1px solid var(--line); flex-wrap:wrap; }
.art-tags-label { display:inline-flex; align-items:center; gap:5px; font-size:.72rem; font-weight:700; letter-spacing:.07em; text-transform:uppercase; color:#aaa; white-space:nowrap; margin-top:3px; }
.art-tags-list { display:flex; flex-wrap:wrap; gap:8px; }
.art-tag { display:inline-block; font-size:.75rem; font-weight:600; color:var(--green); background:var(--green-light); border:1px solid #b8dfc5; padding:4px 12px; border-radius:20px; text-decoration:none; transition:background .2s, color .2s; }
.art-tag:hover { background:var(--green); color:#fff; border-color:var(--green); }

/* ===== ARCHIVE ===== */
.archive-wrap { max-width:var(--max); margin:0 auto; padding:32px 24px; display:grid; grid-template-columns:1fr 300px; gap:36px; }
.archive-title { font-size:1.2rem; font-weight:800; color:var(--dark); border-left:4px solid var(--green); padding-left:14px; margin-bottom:24px; }

/* ===== FOOTER ===== */
.site-footer { background:var(--dark); color:rgba(255,255,255,.5); margin-top:60px; }
.ft-top-inner { max-width:var(--max); margin:0 auto; padding:40px 24px; display:grid; grid-template-columns:2.5fr 1fr 1fr; gap:40px; border-bottom:1px solid rgba(255,255,255,.07); }
.ft-brand { display:flex; align-items:center; gap:10px; margin-bottom:14px; }
.ft-badge { background:var(--green); color:#fff; font-size:.75rem; font-weight:800; padding:5px 12px; border-radius:3px; }
.ft-name { color:#fff; font-size:1rem; font-weight:800; }
.ft-desc { font-size:.78rem; line-height:1.85; color:rgba(255,255,255,.38); }
.ft-col-ttl { color:rgba(255,255,255,.7); font-size:.7rem; font-weight:800; letter-spacing:.1em; text-transform:uppercase; margin-bottom:12px; }
.ft-links { list-style:none; display:flex; flex-direction:column; gap:8px; }
.ft-links a { font-size:.78rem; color:rgba(255,255,255,.38); transition:color .15s; }
.ft-links a:hover { color:#fff; }
.ft-bottom { max-width:var(--max); margin:0 auto; padding:16px 24px; display:flex; align-items:center; justify-content:space-between; font-size:.68rem; color:rgba(255,255,255,.22); }

/* ===== PAGE / 404 ===== */
.content-wrap { max-width:var(--max); margin:0 auto; padding:48px 24px; }
.page-content { background:var(--card); border-radius:var(--r); padding:40px; border:1px solid var(--line); }
.page-content h1 { font-size:1.5rem; font-weight:800; margin-bottom:16px; }
.page-content p { font-size:.9rem; line-height:1.9; margin-bottom:12px; }

/* ===== ADMIN ===== */
.rt-status-box { background:var(--bg); border-radius:4px; padding:16px; margin:16px 0; font-size:.82rem; line-height:1.8; border:1px solid var(--line); }
.rt-btn { background:var(--green); color:#fff; border:none; padding:8px 20px; border-radius:4px; cursor:pointer; font-size:.82rem; font-weight:700; margin-right:8px; }
.rt-btn:hover { opacity:.85; }
.rt-btn.danger { background:#c00; }

/* ===== BREADCRUMB ===== */
.breadcrumb { background:#fff; border-bottom:1px solid var(--line); }
.breadcrumb-inner { max-width:var(--max); margin:0 auto; padding:9px 24px; font-size:.72rem; color:var(--muted); display:flex; align-items:center; flex-wrap:wrap; gap:4px; }
.breadcrumb-inner a { color:var(--sub); }
.breadcrumb-inner a:hover { color:var(--green); }
.bc-sep { color:var(--line-dark); margin:0 2px; }

/* ===== RESPONSIVE ===== */
@media (max-width:960px) {
    .grid,.single-wrap,.archive-wrap { grid-template-columns:1fr; }
    .sidebar,.single-sidebar { display:block; }
    .card-grid { grid-template-columns:repeat(2,1fr); }
    .related-grid { grid-template-columns:repeat(2,1fr); }
    .ft-top-inner { grid-template-columns:1fr 1fr; gap:24px; }
    .hamburger { display:flex; }
    .site-nav { display:none; }
    .nav-strip { display:none; }
    .feat-title-overlay { font-size:1.2rem; }
    .race-table { font-size:.75rem; }
    .wrap { padding:20px 16px; }
}
@media (max-width:640px) {
    /* ヘッダー */
    .top-bar-inner { padding:0 12px; }
    .top-bar-tag { display:none; }
    .header-main { padding:10px 14px; }
    .logo-mark { width:34px; height:34px; }
    .logo-mark svg { width:19px; height:19px; }
    .logo-name { font-size:.92rem; }
    .logo-tagline { display:none; }
    .hamburger span { width:20px; }

    /* セクションヘッダー */
    .sec { flex-wrap:wrap; align-items:flex-start; gap:4px 8px; margin:20px 0 12px; }
    .sec h2 { font-size:.7rem; }
    .sec-more { margin-left:0; font-size:.7rem; width:100%; }

    /* レースタブ */
    .race-tabs { gap:0; }
    .race-tab { padding:8px 10px; font-size:.76rem; flex:1; text-align:center; }
    .race-tab-count { font-size:.6rem; padding:1px 4px; }

    /* 競馬場フィルター */
    .race-place-tabs { gap:4px; }
    .race-place-btn { padding:3px 8px; font-size:.66rem; }

    /* レースブロック */
    .race-block { margin-bottom:12px; }
    .race-block-header { flex-direction:column; align-items:flex-start; gap:2px; padding:8px 10px; }
    .race-block-title { font-size:.8rem; width:100%; }
    .race-meta { font-size:.65rem; width:100%; }
    .race-updated { font-size:.62rem; align-self:flex-end; }
    .race-place-badge { font-size:.65rem; padding:2px 6px; }

    /* レーステーブル */
    .race-table-wrap { overflow-x:auto; -webkit-overflow-scrolling:touch; width:100%; }
    .race-table { font-size:.7rem; white-space:nowrap; table-layout:auto; min-width:0; }
    .race-table th, .race-table td { padding:5px 7px; }

    /* フィーチャード記事 */
    .featured { display:block; }
    .feat-img { aspect-ratio:16/9; height:auto; }
    .feat-title-overlay { font-size:1rem; line-height:1.3; }
    .feat-body { flex-direction:column; gap:4px; padding:12px 14px; }
    .feat-excerpt { font-size:.8rem; }
    .feat-meta { white-space:normal; }

    /* カードグリッド */
    .card-grid { grid-template-columns:repeat(2,1fr); gap:10px; }
    .card-body { padding:10px 12px 12px; }
    .card-ttl { font-size:.82rem; }
    .card-excerpt { display:none; }

    /* ニュースリスト */
    .ni { gap:10px; padding:12px 0; }
    .ni-img { width:80px; height:54px; flex-shrink:0; }
    .ni-ttl { font-size:.84rem; }
    .ni-excerpt { display:none; }

    /* 記事ページ */
    .single-wrap { padding:14px 12px; }
    .art-header { padding:16px 14px 0; }
    .art-body { padding:14px; font-size:.88rem; line-height:1.85; }
    .art-body h2 { font-size:.97rem; }
    .art-body h3 { font-size:.9rem; }
    .art-body img { max-width:100%; height:auto; }
    .art-tags { padding:14px; }
}
@media (max-width:540px) {
    html, body { overflow-x:hidden; }
    .wrap { padding:12px; }
    .card-grid { grid-template-columns:1fr; }
    .single-title { font-size:1.2rem; }
    .ft-top-inner { grid-template-columns:1fr; }
    .feat-title-overlay { font-size:.95rem; }
    .feat-img { aspect-ratio:4/3; }
    .race-tab { font-size:.72rem; padding:7px 6px; }
    .ni-img { width:72px; height:50px; }
}

/* ===== SEARCH PAGE ===== */
.search-wrap { padding-bottom:40px; }
.search-hd { font-size:1.1rem; font-weight:800; color:var(--dark); margin-bottom:20px; padding-bottom:12px; border-bottom:2px solid var(--green); }
.search-hd span { color:var(--green); }
.search-form-wrap { margin-bottom:28px; }
.search-form-wrap form { display:flex; gap:8px; }
.search-form-wrap input { flex:1; border:1.5px solid var(--line); border-radius:4px; padding:10px 14px; font-size:.9rem; font-family:var(--font); outline:none; }
.search-form-wrap input:focus { border-color:var(--green); }
.search-form-wrap button { background:var(--green); color:#fff; border:none; border-radius:4px; padding:10px 20px; font-size:.88rem; font-weight:700; cursor:pointer; font-family:var(--font); }
.search-item { display:flex; gap:14px; padding:16px 0; border-bottom:1px solid var(--line); align-items:flex-start; }
.search-item:first-of-type { border-top:1px solid var(--line); }
.search-item-img { flex-shrink:0; width:100px; height:68px; overflow:hidden; border-radius:var(--r); background:var(--bg); display:flex; align-items:center; justify-content:center; font-size:1.5rem; }
.search-item-img img { width:100%; height:100%; object-fit:cover; }
.search-item-body { flex:1; min-width:0; }
.search-item-cat { display:inline-block; background:var(--green-light); color:var(--green); font-size:.6rem; font-weight:700; padding:2px 8px; border-radius:2px; margin-bottom:6px; }
.search-item-title { font-size:.9rem; font-weight:700; line-height:1.5; margin-bottom:4px; }
.search-item-title a:hover { color:var(--green); }
.search-item-date { font-size:.72rem; color:var(--muted); }
.search-none { padding:40px 24px; text-align:center; color:var(--sub); font-size:.9rem; background:var(--card); border-radius:var(--r); border:1px solid var(--line); }

/* ===== CONTACT FORM 7 ===== */
.wpcf7 { margin:24px 0; }
.wpcf7 input[type="text"],.wpcf7 input[type="email"],.wpcf7 textarea { width:100%; border:1.5px solid var(--line); border-radius:4px; padding:12px 14px; font-size:.9rem; font-family:var(--font); color:var(--text); background:#fff; transition:border-color .15s; box-sizing:border-box; }
.wpcf7 input[type="text"]:focus,.wpcf7 input[type="email"]:focus,.wpcf7 textarea:focus { outline:none; border-color:var(--green); box-shadow:0 0 0 3px rgba(26,107,58,.08); }
.wpcf7 textarea { min-height:160px; resize:vertical; }
.wpcf7 input[type="submit"] { background:var(--green); color:#fff; border:none; border-radius:4px; padding:13px 32px; font-size:.9rem; font-weight:700; font-family:var(--font); cursor:pointer; transition:opacity .15s; align-self:flex-start; }
.wpcf7 input[type="submit"]:hover { opacity:.85; }

/* ===== YOUTUBE ===== */
.yt-wrap { margin:24px 0; background:#000; border-radius:var(--r); overflow:hidden; }
.yt-label { background:var(--green); color:#fff; font-size:.72rem; font-weight:700; padding:6px 14px; letter-spacing:.06em; }
.yt-wrap iframe { width:100%; aspect-ratio:16/9; display:block; border:none; }
