/*
Theme Name: Israel Trend News
Theme URI: https://israeltrend.net/
Description: イスラエルトレンドニュース自動生成テーマ
Version: 1.0.0
Author: Eatransform
Text Domain: israeltrend
*/

/* ===== VARIABLES ===== */
:root {
    --blue:     #1a4a8a;
    --blue-mid: #2563aa;
    --blue-dim: rgba(26,74,138,.08);
    --gold:     #c8922a;
    --black:    #0d0d0d;
    --dark:     #1a1e2e;
    --text:     #1a1a2e;
    --sub:      #5a6070;
    --line:     #e0e4ed;
    --bg:       #f2f4f8;
    --card:     #ffffff;
    --max:      1080px;
    --r:        6px;
    --font:     'Noto Sans JP','Hiragino Sans','Yu Gothic UI',sans-serif;
}

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

/* ===== HEADER ===== */
.site-header {
    background:#fff;
    border-bottom:3px solid var(--blue);
    position:sticky; top:0; z-index:100;
    box-shadow:0 2px 12px rgba(0,0,0,.08);
}
.header-top {
    background:var(--dark);
    padding:4px 0;
    font-size:.68rem;
    color:rgba(255,255,255,.5);
    letter-spacing:.04em;
}
.header-top-inner {
    max-width:var(--max);
    margin:0 auto;
    padding:0 20px;
    display:flex;
    align-items:center;
    justify-content:space-between;
}
.header-date { color:rgba(255,255,255,.4); }
.header-tag { color:var(--gold); font-weight:700; letter-spacing:.06em; }

.header-main {
    max-width:var(--max);
    margin:0 auto;
    padding:10px 20px;
    display:flex;
    align-items:center;
    justify-content:space-between;
    gap:20px;
}
.logo { display:flex; align-items:center; gap:12px; }
.logo-flag {
    font-size:1.6rem;
    line-height:1;
}
.logo-text-wrap {}
.logo-name {
    font-size:1.05rem;
    font-weight:800;
    color:var(--dark);
    letter-spacing:-.01em;
    line-height:1.2;
}
.logo-sub {
    font-size:.58rem;
    color:var(--sub);
    letter-spacing:.08em;
    display:block;
}
.site-nav { display:flex; align-items:center; gap:2px; }
.site-nav a {
    color:var(--sub);
    font-size:.75rem;
    font-weight:600;
    padding:6px 10px;
    border-radius:4px;
    transition:all .15s;
    white-space:nowrap;
}
.site-nav a:hover { color:var(--blue); background:var(--blue-dim); }
.search-btn { background:none; border:none; cursor:pointer; color:var(--sub); padding:6px; display:flex; align-items:center; }
.search-btn:hover { color:var(--blue); }
.hamburger { display:none; background:none; border:none; cursor:pointer; padding:6px; flex-direction:column; gap:5px; }
.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:block; color:var(--sub); font-size:.85rem; font-weight:600; padding:13px 20px; border-bottom:1px solid var(--line); }
.mobile-nav a:hover { color:var(--blue); background:var(--blue-dim); }

/* breaking news ticker */
.ticker-bar {
    background:var(--blue);
    color:#fff;
    padding:6px 0;
    overflow:hidden;
    font-size:.72rem;
}
.ticker-inner { max-width:var(--max); margin:0 auto; padding:0 20px; display:flex; align-items:center; gap:12px; }
.ticker-label {
    background:var(--gold);
    color:#fff;
    font-size:.62rem;
    font-weight:700;
    padding:2px 8px;
    border-radius:3px;
    white-space:nowrap;
    letter-spacing:.06em;
    flex-shrink:0;
}
.ticker-text { white-space:nowrap; overflow:hidden; text-overflow:ellipsis; opacity:.9; }

@media(max-width:768px){
    .site-nav { display:none; }
    .hamburger { display:flex; }
}

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

/* ===== SECTIONS ===== */
.sec { margin-bottom:28px; }
.sec-head {
    display:flex;
    align-items:center;
    justify-content:space-between;
    margin-bottom:14px;
    padding-bottom:8px;
    border-bottom:2px solid var(--blue);
}
.sec-title {
    font-size:.78rem;
    font-weight:800;
    letter-spacing:.12em;
    color:var(--blue);
    display:flex;
    align-items:center;
    gap:8px;
}
.sec-title::before { content:''; width:4px; height:14px; background:var(--gold); border-radius:2px; flex-shrink:0; }
.sec .more { font-size:.68rem; color:var(--sub); letter-spacing:.04em; }
.sec .more:hover { color:var(--blue); }

/* ===== FEATURED CARD ===== */
.featured {
    background:var(--card);
    border-radius:var(--r);
    overflow:hidden;
    box-shadow:0 2px 8px rgba(0,0,0,.06);
    display:grid;
    grid-template-columns:1.1fr 1fr;
    transition:box-shadow .25s;
    margin-bottom:6px;
    border:1px solid var(--line);
}
.featured:hover { box-shadow:0 8px 30px rgba(0,0,0,.12); }
.feat-img { aspect-ratio:16/10; overflow:hidden; background:var(--bg); }
.feat-img img { width:100%; height:100%; object-fit:cover; transition:transform .4s; }
.featured:hover .feat-img img { transform:scale(1.04); }
.feat-body { padding:20px; display:flex; flex-direction:column; justify-content:center; }
.feat-cat {
    display:inline-flex;
    align-items:center;
    background:var(--blue);
    color:#fff;
    font-size:.62rem;
    font-weight:700;
    letter-spacing:.05em;
    padding:3px 9px;
    border-radius:3px;
    margin-bottom:10px;
    width:fit-content;
}
.feat-title { font-size:1.05rem; font-weight:800; line-height:1.45; margin-bottom:8px; }
.feat-title:hover { color:var(--blue); }
.feat-excerpt { font-size:.78rem; color:var(--sub); line-height:1.7; display:-webkit-box; -webkit-line-clamp:3; -webkit-box-orient:vertical; overflow:hidden; }
.feat-meta { font-size:.68rem; color:var(--sub); margin-top:12px; padding-top:10px; border-top:1px solid var(--line); }
@media(max-width:600px){
    .featured { grid-template-columns:1fr; }
    .feat-img { aspect-ratio:16/9; }
}

/* ===== CARD GRID ===== */
.card-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:14px; }
@media(max-width:700px){ .card-grid { grid-template-columns:repeat(2,1fr); } }
@media(max-width:480px){ .card-grid { grid-template-columns:1fr; } }

.card {
    background:var(--card);
    border-radius:var(--r);
    overflow:hidden;
    box-shadow:0 1px 4px rgba(0,0,0,.05);
    transition:box-shadow .2s;
    border:1px solid var(--line);
}
.card:hover { box-shadow:0 6px 20px rgba(0,0,0,.1); }
.card-img { aspect-ratio:16/9; overflow:hidden; background:var(--bg); }
.card-img img { width:100%; height:100%; object-fit:cover; transition:transform .35s; }
.card:hover .card-img img { transform:scale(1.05); }
.card-body { padding:12px; }
.cat-tag {
    display:inline-block;
    background:var(--blue-dim);
    color:var(--blue);
    font-size:.6rem;
    font-weight:700;
    padding:2px 7px;
    border-radius:3px;
    margin-bottom:6px;
    letter-spacing:.04em;
}
.card-ttl { font-size:.83rem; font-weight:700; line-height:1.5; display:-webkit-box; -webkit-line-clamp:2; -webkit-box-orient:vertical; overflow:hidden; }
.card-ttl:hover { color:var(--blue); }
.card-meta { font-size:.65rem; color:var(--sub); margin-top:8px; }

/* ===== NEWS LIST ===== */
.news-list { display:flex; flex-direction:column; gap:0; }
.news-item {
    display:flex;
    gap:12px;
    align-items:flex-start;
    padding:12px 0;
    border-bottom:1px solid var(--line);
}
.news-item:last-child { border-bottom:none; }
.ni-img { width:70px; height:52px; border-radius:4px; overflow:hidden; background:var(--bg); flex-shrink:0; }
.ni-thumb img { width:100%; height:100%; object-fit:cover; }
.ni-body { flex:1; min-width:0; }
.ni-cat-tag {
    display:inline-block;
    background:var(--blue-dim);
    color:var(--blue);
    font-size:.58rem;
    font-weight:700;
    padding:1px 6px;
    border-radius:3px;
    margin-right:6px;
    margin-bottom:3px;
}
.ni-ttl { font-size:.8rem; font-weight:700; line-height:1.45; display:-webkit-box; -webkit-line-clamp:2; -webkit-box-orient:vertical; overflow:hidden; }
.ni-ttl:hover { color:var(--blue); }
.ni-date { font-size:.62rem; color:var(--sub); margin-top:4px; }

/* ===== SIDEBAR ===== */
.side-card {
    background:var(--card);
    border-radius:var(--r);
    border:1px solid var(--line);
    overflow:hidden;
    margin-bottom:20px;
}
.side-hd {
    background:var(--dark);
    color:#fff;
    font-size:.7rem;
    font-weight:700;
    letter-spacing:.12em;
    padding:9px 14px;
}
.side-body { padding:12px; }
.hot-list { list-style:none; display:flex; flex-direction:column; gap:0; }
.hi { display:flex; gap:10px; align-items:flex-start; padding:10px 0; border-bottom:1px solid var(--line); }
.hi-item:last-child { border-bottom:none; }
.hi-n { font-size:1.1rem; font-weight:900; color:var(--line); width:20px; flex-shrink:0; line-height:1; }
.hi-n.r1 { color:var(--gold); }
.hi-n.r2 { color:var(--blue); }
.hi-w a { font-size:.78rem; font-weight:600; line-height:1.45; display:-webkit-box; -webkit-line-clamp:2; -webkit-box-orient:vertical; overflow:hidden; }
.hi-w a:hover { color:var(--blue); }

/* ===== BREADCRUMB ===== */
.bc { font-size:.7rem; color:var(--sub); padding:10px 0; max-width:var(--max); margin:0 auto; padding-left:20px; padding-right:20px; }
.bc a:hover { color:var(--blue); }
.bc span { margin:0 5px; opacity:.4; }

/* ===== PAGINATION ===== */
.pagination { display:flex; gap:6px; justify-content:center; margin:28px 0; flex-wrap:wrap; }
.pagination a, .pagination .current {
    display:inline-flex; align-items:center; justify-content:center;
    width:36px; height:36px; border-radius:4px; font-size:.8rem;
    border:1px solid var(--line); color:var(--sub);
}
.pagination .current { background:var(--blue); border-color:var(--blue); color:#fff; font-weight:700; }
.pagination a:hover { background:var(--blue-dim); border-color:var(--blue); color:var(--blue); }

/* ===== ARTICLE ===== */
.art-wrap { max-width:var(--max); margin:0 auto; padding:0 20px 40px; display:grid; grid-template-columns:1fr 300px; gap:28px; }
@media(max-width:800px){ .art-wrap { grid-template-columns:1fr; } }
.art-header { margin-bottom:20px; }
.art-cat { display:inline-flex; background:var(--blue); color:#fff; font-size:.65rem; font-weight:700; padding:3px 10px; border-radius:3px; margin-right:6px; letter-spacing:.04em; }
.art-ttl { font-size:1.5rem; font-weight:900; line-height:1.4; margin:10px 0; }
.art-meta { display:flex; align-items:center; gap:12px; font-size:.72rem; color:var(--sub); padding:10px 0; border-bottom:1px solid var(--line); margin-bottom:20px; }
.art-meta-cat { color:var(--blue); font-weight:700; }
.art-eyecatch { border-radius:var(--r); overflow:hidden; margin-bottom:24px; }
.art-eyecatch img { width:100%; aspect-ratio:16/8; object-fit:cover; }
.article-body { font-size:.95rem; line-height:1.95; }
.article-body h2 { font-size:1.05rem; font-weight:800; color:var(--dark); margin:28px 0 10px; padding:10px 14px; background:var(--blue-dim); border-left:3px solid var(--blue); border-radius:0 4px 4px 0; }
.article-body p { margin-bottom:14px; }
.yt-wrap { margin:20px 0; border-radius:var(--r); overflow:hidden; }
.yt-label { font-size:.72rem; font-weight:700; color:var(--sub); margin-bottom:8px; letter-spacing:.06em; }
.yt-wrap iframe { width:100%; aspect-ratio:16/9; border:none; display:block; }
.photo-credit { font-size:.65rem; color:var(--sub); text-align:right; margin-top:6px; }
.photo-credit a { color:var(--blue); }

/* ===== ADMIN ===== */
.it-admin-wrap { max-width:800px; }
.it-btn { display:inline-flex; align-items:center; gap:6px; padding:9px 18px; border-radius:6px; font-size:.82rem; font-weight:600; cursor:pointer; border:none; color:#fff; background:var(--blue); margin:4px 4px 4px 0; transition:background .15s; }
.it-btn:hover { background:var(--blue-mid); }
.trend-list { display:flex; flex-wrap:wrap; gap:6px; margin-top:8px; }
.trend-chip { background:var(--blue-dim); color:var(--blue); font-size:.72rem; padding:3px 10px; border-radius:20px; }
.trend-chip.used { background:#f0f0f0; color:#aaa; }
.log-box { background:#0d1117; color:#7ee787; font-family:monospace; font-size:.78rem; padding:14px; border-radius:6px; max-height:220px; overflow-y:auto; margin-top:10px; white-space:pre-wrap; word-break:break-all; }

/* ===== FOOTER ===== */
.site-footer { background:var(--dark); color:rgba(255,255,255,.7); padding:40px 0 0; margin-top:40px; }
.ft-inner { max-width:var(--max); margin:0 auto; padding:0 20px; display:grid; grid-template-columns:1.5fr 1fr 1fr; gap:32px; }
@media(max-width:700px){ .ft-inner { grid-template-columns:1fr; } }
.ft-brand { display:flex; align-items:center; gap:10px; margin-bottom:12px; }
.ft-flag { font-size:1.4rem; }
.ft-name { font-size:.95rem; font-weight:800; color:#fff; letter-spacing:-.01em; }
.ft-desc { font-size:.75rem; color:rgba(255,255,255,.4); line-height:1.7; }
.ft-col-ttl { font-size:.68rem; font-weight:700; letter-spacing:.12em; color:rgba(255,255,255,.35); margin-bottom:12px; text-transform:uppercase; }
.ft-links { list-style:none; display:flex; flex-direction:column; gap:8px; }
.ft-links li a { font-size:.78rem; color:rgba(255,255,255,.5); transition:color .15s; }
.ft-links li a:hover { color:#fff; }
.ft-bottom { border-top:1px solid rgba(255,255,255,.07); padding:16px 20px; max-width:var(--max); margin:32px auto 0; display:flex; align-items:center; justify-content:space-between; font-size:.65rem; color:rgba(255,255,255,.2); }

/* ===== SEARCH ===== */
.search-wrap { max-width:700px; margin:0 auto; padding:40px 20px; }
.search-form { display:flex; gap:8px; margin-bottom:28px; }
.search-form input { flex:1; padding:10px 14px; border:1px solid var(--line); border-radius:var(--r); font-size:.9rem; font-family:var(--font); }
.search-form button { background:var(--blue); color:#fff; border:none; border-radius:var(--r); padding:10px 18px; cursor:pointer; font-weight:700; }

/* ===== PLACEHOLDER ===== */
.no-thumb {
    width:100%; height:100%;
    background:linear-gradient(135deg, #1a2a4a 0%, #2a4a8a 100%);
    display:flex; align-items:center; justify-content:center;
    color:rgba(255,255,255,.3);
    font-size:1.4rem;
    font-weight:900;
    letter-spacing:.05em;
}

/* ===== SIDEBAR COMPONENTS ===== */
.sidebar { }
.side-card {
    background:var(--card);
    border-radius:var(--r);
    border:1px solid var(--line);
    overflow:hidden;
    margin-bottom:20px;
}
.side-hd {
    background:var(--dark);
    color:#fff;
    font-size:.7rem;
    font-weight:700;
    letter-spacing:.12em;
    padding:9px 14px;
}
.side-recent-item {
    display:flex;
    gap:10px;
    align-items:flex-start;
    padding:10px 12px;
    border-bottom:1px solid var(--line);
}
.side-recent-item:last-child { border-bottom:none; }
.side-recent-img {
    width:60px;
    height:44px;
    border-radius:4px;
    overflow:hidden;
    flex-shrink:0;
    display:block;
    background:var(--bg);
}
.side-recent-img img { width:100%; height:100%; object-fit:cover; }
.side-recent-body { flex:1; min-width:0; }
.side-recent-ttl {
    font-size:.75rem;
    font-weight:600;
    line-height:1.4;
    display:-webkit-box;
    -webkit-line-clamp:2;
    -webkit-box-orient:vertical;
    overflow:hidden;
}
.side-recent-ttl:hover { color:var(--blue); }

.hot-list { padding:6px 0; }
.hi {
    display:flex;
    gap:8px;
    align-items:flex-start;
    padding:8px 12px;
    border-bottom:1px solid var(--line);
}
.hi:last-child { border-bottom:none; }
.hi-n { font-size:.9rem; font-weight:900; color:var(--line); width:18px; flex-shrink:0; line-height:1.4; }
.hi-n.r1 { color:var(--gold); }
.hi-n.r2 { color:var(--blue); }
.hi-n.r3 { color:var(--sub); }
.hi-w { flex:1; min-width:0; }
.hi-w a {
    font-size:.75rem;
    font-weight:600;
    line-height:1.45;
    display:-webkit-box;
    -webkit-line-clamp:2;
    -webkit-box-orient:vertical;
    overflow:hidden;
}
.hi-w a:hover { color:var(--blue); }

/* sec heading fix */
.sec h2 {
    font-size:.78rem;
    font-weight:800;
    letter-spacing:.12em;
    color:var(--blue);
    display:flex;
    align-items:center;
    gap:8px;
    padding-bottom:8px;
    border-bottom:2px solid var(--blue);
    margin-bottom:14px;
}
.sec h2::before { content:''; width:4px; height:14px; background:var(--gold); border-radius:2px; flex-shrink:0; }

/* grid layout */
.grid { display:grid; grid-template-columns:1fr 300px; gap:24px; }
@media(max-width:800px){ .grid { grid-template-columns:1fr; } }

/* ni (news item) */
.ni {
    display:flex;
    gap:12px;
    align-items:flex-start;
    padding:12px 0;
    border-bottom:1px solid var(--line);
}
.ni:last-child { border-bottom:none; }
.ni-img {
    width:80px;
    height:58px;
    border-radius:4px;
    overflow:hidden;
    background:var(--bg);
    flex-shrink:0;
}
.ni-img img { width:100%; height:100%; object-fit:cover; }
.ni-body { flex:1; min-width:0; }
.ni-ttl {
    font-size:.82rem;
    font-weight:700;
    line-height:1.45;
    display:-webkit-box;
    -webkit-line-clamp:2;
    -webkit-box-orient:vertical;
    overflow:hidden;
}
.ni-ttl:hover { color:var(--blue); }
.ni-meta { font-size:.65rem; color:var(--sub); margin-top:4px; }

/* feat-title fix */
.feat-title { font-size:1.05rem; font-weight:800; line-height:1.45; margin-bottom:8px; }
.feat-title:hover { color:var(--blue); }

/* ===== SEARCH OVERLAY ===== */
.search-overlay {
    display:none;
    position:fixed; inset:0; z-index:200;
    background:rgba(13,13,46,.85);
    align-items:flex-start;
    justify-content:center;
    padding-top:80px;
}
.search-overlay.open { display:flex; }
.search-overlay-inner {
    width:100%;
    max-width:600px;
    padding:0 20px;
    position:relative;
}
.search-overlay-inner form {
    display:flex;
    gap:0;
    border-radius:var(--r);
    overflow:hidden;
    box-shadow:0 8px 40px rgba(0,0,0,.4);
}
.search-overlay-inner input {
    flex:1;
    padding:14px 18px;
    font-size:1rem;
    border:none;
    font-family:var(--font);
    outline:none;
}
.search-overlay-inner button[type="submit"] {
    background:var(--blue);
    color:#fff;
    border:none;
    padding:14px 22px;
    font-size:.9rem;
    font-weight:700;
    cursor:pointer;
    font-family:var(--font);
}
.search-overlay-close {
    position:absolute;
    top:-50px; right:20px;
    background:none;
    border:none;
    color:#fff;
    font-size:1.4rem;
    cursor:pointer;
    opacity:.7;
}
.search-overlay-close:hover { opacity:1; }

/* ===== LOGO BADGE ===== */
.logo-badge {
    width:36px; height:36px;
    border-radius:6px;
    background:var(--blue);
    color:#fff;
    font-size:.75rem;
    font-weight:900;
    display:flex;
    align-items:center;
    justify-content:center;
    letter-spacing:.02em;
    flex-shrink:0;
}
.ft-badge-il {
    width:28px; height:28px;
    border-radius:4px;
    background:var(--blue);
    color:#fff;
    font-size:.65rem;
    font-weight:900;
    display:flex;
    align-items:center;
    justify-content:center;
}
