/*
Theme Name: World Slap
Theme URI: https://worldslap.com/
Author: World Slap
Description: 世界に一発、世界を一周。バズ動画まとめサイト World Slap 専用のモダンテーマ（Design B / ライト・POP）。サムネ主役のカードグリッド、カテゴリ色分け、完全レスポンシブ。
Version: 1.0.0
Requires at least: 6.0
Tested up to: 7.0
Requires PHP: 7.4
License: GNU General Public License v2 or later
License URI: http://www.gnu.org/licenses/gpl-2.0.html
Text Domain: worldslap
*/

:root{
  --bg:#f7f5ef; --paper:#fff; --ink:#16130f; --ink-dim:#6b6358;
  --yellow:#ffd400; --pink:#ff3b6b; --blue:#2b59ff;
  --radius:18px; --shadow:6px 6px 0 var(--ink); --shadow-sm:4px 4px 0 var(--ink);
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{background:var(--bg);color:var(--ink);font-family:"Noto Sans JP",system-ui,-apple-system,"Segoe UI",sans-serif;line-height:1.7;-webkit-font-smoothing:antialiased;overflow-x:hidden}
a{color:inherit;text-decoration:none}
img{display:block;max-width:100%;height:auto}
.wrap{max-width:1240px;margin:0 auto;padding:0 20px}
.skip-link{position:absolute;left:-9999px}

/* ===== Header ===== */
.site-header{position:sticky;top:0;z-index:50;background:var(--paper);border-bottom:3px solid var(--ink)}
.header-inner{max-width:1240px;margin:0 auto;padding:13px 20px;display:flex;align-items:center;gap:18px}
.logo{display:flex;align-items:center;gap:11px;flex-shrink:0}
.logo-mark{width:44px;height:44px;border-radius:12px;background:var(--yellow);border:3px solid var(--ink);display:grid;place-items:center;font-family:"Anton";font-size:26px;color:var(--ink);transform:rotate(-5deg);box-shadow:var(--shadow-sm)}
.logo-text{font-family:"Anton";font-size:26px;letter-spacing:.5px;line-height:1}
.logo-text span{color:var(--pink)}
.logo-sub{font-size:10.5px;color:var(--ink-dim);font-weight:700;margin-top:3px}
.header-spacer{flex:1}
.search-box{display:flex;align-items:center;gap:8px;background:var(--bg);border:2.5px solid var(--ink);border-radius:999px;padding:8px 16px;width:220px}
.search-box input{background:none;border:none;color:var(--ink);outline:none;width:100%;font-size:14px;font-family:inherit;font-weight:600}
.search-box input::placeholder{color:var(--ink-dim)}
.search-box button{background:none;border:none;cursor:pointer;color:var(--ink);display:grid;place-items:center}
.x-link{display:grid;place-items:center;width:42px;height:42px;border-radius:11px;background:var(--ink);color:var(--paper);border:2.5px solid var(--ink);transition:.15s;flex-shrink:0}
.x-link:hover{background:var(--pink);transform:translate(-2px,-2px);box-shadow:var(--shadow-sm)}
.nav-toggle{display:none;background:var(--yellow);border:2.5px solid var(--ink);border-radius:10px;width:42px;height:42px;cursor:pointer;font-size:20px}

/* ===== Category nav ===== */
.cat-nav{background:var(--yellow);border-bottom:3px solid var(--ink)}
.cat-nav-inner{max-width:1240px;margin:0 auto;padding:11px 20px;display:flex;gap:10px;overflow-x:auto;scrollbar-width:none}
.cat-nav-inner::-webkit-scrollbar{display:none}
.chip{flex-shrink:0;padding:7px 16px;border-radius:999px;background:var(--paper);border:2.5px solid var(--ink);font-size:13.5px;font-weight:800;cursor:pointer;transition:.13s;white-space:nowrap;color:var(--ink)}
.chip:hover{transform:translate(-2px,-2px);box-shadow:var(--shadow-sm)}
.chip.active{background:var(--ink);color:var(--yellow)}

/* ===== Hero ===== */
.hero{max-width:1240px;margin:30px auto 4px;padding:0 20px}
.hero-card{position:relative;border:3px solid var(--ink);border-radius:var(--radius);overflow:hidden;min-height:400px;display:flex;align-items:flex-end;box-shadow:var(--shadow);background:var(--paper)}
.hero-card img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.hero-overlay{position:absolute;inset:0;background:linear-gradient(180deg,rgba(0,0,0,0) 30%,rgba(0,0,0,.82) 100%)}
.hero-content{position:relative;padding:32px;max-width:780px;color:#fff}
.badge-pick{display:inline-flex;align-items:center;gap:6px;background:var(--yellow);color:var(--ink);font-weight:900;font-size:12.5px;padding:6px 14px;border-radius:999px;border:2.5px solid var(--ink);margin-bottom:14px}
.hero-title{font-size:clamp(23px,3.3vw,36px);font-weight:900;line-height:1.3;letter-spacing:-.5px;text-shadow:0 2px 14px rgba(0,0,0,.5)}
.hero-meta{display:flex;align-items:center;gap:10px;margin-top:14px;font-size:13px;font-weight:700}
.hero-cat{padding:3px 11px;border-radius:999px;border:2px solid #fff;color:#fff}

/* ===== Section head ===== */
.section-head{display:flex;align-items:center;gap:13px;margin:40px 0 20px}
.section-head h1,.section-head h2{font-family:"Anton";font-size:30px;letter-spacing:.5px;font-weight:400}
.section-head h1 mark,.section-head h2 mark{background:var(--yellow);padding:0 8px;border-radius:6px;color:var(--ink)}
.section-count{background:var(--ink);color:var(--yellow);font-size:13px;font-weight:800;padding:4px 12px;border-radius:999px}

/* ===== 2カラムレイアウト ===== */
.layout{display:flex;gap:30px;align-items:flex-start;margin-top:30px}
.main-col{flex:1;min-width:0}
.sidebar{width:300px;flex-shrink:0;position:sticky;top:150px;display:flex;flex-direction:column;gap:22px}
.side-box{background:var(--paper);border:3px solid var(--ink);border-radius:var(--radius);padding:14px 15px;box-shadow:var(--shadow-sm)}
.side-title{font-family:"Anton";font-size:18px;letter-spacing:.5px;margin-bottom:12px}
.side-box.ad-widget{padding:10px;text-align:center}
.side-list{list-style:none;margin:0;padding:0}
.side-list li{margin:0 0 12px}
.side-list a{display:flex;gap:10px;align-items:center}
.side-thumb{width:74px;height:48px;flex-shrink:0;border:2px solid var(--ink);border-radius:8px;overflow:hidden;background:var(--bg)}
.side-thumb img{width:100%;height:100%;object-fit:cover}
.side-ttl{font-size:12.5px;font-weight:700;line-height:1.45;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.side-cats{list-style:none;margin:0;padding:0}
.side-cats li{margin:0 0 8px}
.side-cats a{display:flex;justify-content:space-between;align-items:center;background:var(--bg);border:2px solid var(--ink);border-left-width:7px;border-radius:8px;padding:8px 12px;font-weight:800;font-size:13.5px;transition:.13s}
.side-cats a:hover{transform:translate(-2px,-2px);box-shadow:var(--shadow-sm)}
.side-cats a span{background:var(--ink);color:var(--yellow);font-size:11px;padding:1px 8px;border-radius:999px}

/* ===== Grid + cards ===== */
.grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:22px;padding-bottom:30px}
.card{background:var(--paper);border:3px solid var(--ink);border-radius:var(--radius);overflow:hidden;transition:.16s;display:flex;flex-direction:column}
.card:hover{transform:translate(-4px,-4px);box-shadow:var(--shadow)}
.thumb{position:relative;aspect-ratio:16/10;overflow:hidden;background:var(--bg);border-bottom:3px solid var(--ink)}
.thumb img{width:100%;height:100%;object-fit:cover;transition:transform .45s ease}
.card:hover .thumb img{transform:scale(1.06)}
.thumb-empty{width:100%;height:100%;display:grid;place-items:center;font-family:"Anton";font-size:34px;color:#cbc6ba;background:repeating-linear-gradient(45deg,#efece4,#efece4 10px,#f7f5ef 10px,#f7f5ef 20px)}
.play{position:absolute;inset:0;display:grid;place-items:center;opacity:0;transition:.2s;background:rgba(0,0,0,.18)}
.card:hover .play{opacity:1}
.play div{width:60px;height:60px;border-radius:50%;background:var(--pink);border:3px solid #fff;display:grid;place-items:center}
.cat-tag{position:absolute;top:11px;left:11px;font-size:11.5px;font-weight:900;padding:4px 11px;border-radius:999px;color:#fff;border:2.5px solid var(--ink)}
.card-body{padding:14px 15px 16px;display:flex;flex-direction:column;gap:9px;flex:1}
.card-title{font-size:15px;font-weight:800;line-height:1.5;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden;color:var(--ink)}
.card-meta{display:flex;align-items:center;gap:8px;margin-top:auto;color:var(--ink-dim);font-size:12px;font-weight:700}
.dot{width:4px;height:4px;border-radius:50%;background:var(--pink)}

/* ===== Pagination ===== */
.pagination{display:flex;justify-content:center;gap:8px;flex-wrap:wrap;padding:10px 0 70px}
.pagination .page-numbers{display:grid;place-items:center;min-width:44px;height:44px;padding:0 12px;border:2.5px solid var(--ink);border-radius:999px;background:var(--paper);font-weight:800;transition:.13s}
.pagination .page-numbers:hover{transform:translate(-2px,-2px);box-shadow:var(--shadow-sm)}
.pagination .page-numbers.current{background:var(--ink);color:var(--yellow)}

/* ===== Single post ===== */
.single-wrap{max-width:820px;margin:34px auto;padding:0 20px}
.single-cat{display:inline-block;color:#fff;font-weight:900;font-size:12.5px;padding:5px 14px;border-radius:999px;border:2.5px solid var(--ink);margin-bottom:16px}
.single-title{font-size:clamp(22px,3.4vw,32px);font-weight:900;line-height:1.45;margin-bottom:14px}
.single-meta{display:flex;gap:12px;align-items:center;color:var(--ink-dim);font-size:13px;font-weight:700;margin-bottom:24px;border-bottom:3px solid var(--ink);padding-bottom:16px}
.single-content{font-size:16.5px}
.single-content p{margin:0 0 1.3em}
.single-content h2{font-family:"Anton";font-size:24px;margin:1.4em 0 .6em;border-left:8px solid var(--yellow);padding-left:12px}
.single-content h3{font-size:20px;font-weight:900;margin:1.2em 0 .5em}
.single-content img{border-radius:12px;margin:1em 0}
.single-content a{color:var(--blue);text-decoration:underline;font-weight:700}
.single-content iframe{max-width:100%}
.wp-block-embed__wrapper,.single-content figure.wp-block-embed{margin:1.4em 0}
.wp-block-embed.is-type-video .wp-block-embed__wrapper{position:relative;padding-top:56.25%}
.wp-block-embed.is-type-video iframe{position:absolute;inset:0;width:100%;height:100%;border-radius:12px}
.single-tags{display:flex;flex-wrap:wrap;gap:8px;margin:28px 0}
.single-tags a{font-size:13px;font-weight:700;padding:5px 12px;border:2px solid var(--ink);border-radius:999px}
.related-head{font-family:"Anton";font-size:24px;margin:40px 0 18px}

/* ===== Footer ===== */
.site-footer{border-top:3px solid var(--ink);background:var(--ink);color:var(--bg);margin-top:30px}
.footer-inner{max-width:1240px;margin:0 auto;padding:42px 20px;display:flex;flex-wrap:wrap;gap:30px;justify-content:space-between}
.footer-inner .logo-text{color:var(--paper)}
.footer-inner p{color:#b9b1a5;font-size:13px;max-width:340px;margin-top:12px;font-weight:500}
.footer-cats{display:flex;flex-wrap:wrap;gap:8px;max-width:560px;align-content:flex-start}
.footer-cats a{font-size:13px;font-weight:700;padding:5px 13px;border:2px solid #4a443c;border-radius:999px;transition:.15s}
.footer-cats a:hover{background:var(--yellow);color:var(--ink);border-color:var(--yellow)}
.copy{width:100%;border-top:1px solid #4a443c;margin-top:6px;padding-top:20px;color:#8a8278;font-size:12px}

/* ===== Mobile ===== */
@media(max-width:980px){
  .layout{flex-direction:column}
  .sidebar{width:100%;position:static}
  .sidebar .side-box{max-width:600px;margin:0 auto}
}
@media(max-width:820px){
  .search-box{display:none}
  .nav-toggle{display:grid;place-items:center}
}
@media(max-width:680px){
  .logo-sub{display:none}
  .hero-card{min-height:300px}
  .hero-content{padding:22px 18px 20px}
  .grid{grid-template-columns:repeat(auto-fill,minmax(155px,1fr));gap:14px}
  .card-title{font-size:13px}
  .section-head h1,.section-head h2{font-size:23px}
  .single-content{font-size:16px}
}
.fade-in{animation:fade .45s ease both}
@keyframes fade{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:none}}

/* ===== 広告枠 ===== */
.ad-slot,.ad-in-feed-slot{max-width:820px;margin:26px auto;text-align:center}
.ad-in-feed-slot{max-width:1240px;padding:0 20px}
.ad-widget{margin:0 auto;display:flex;justify-content:center}
.ad-slot:not(:empty)::before{content:"スポンサーリンク";display:block;font-size:11px;color:var(--ink-dim);margin-bottom:6px;letter-spacing:.5px}

/* ===== コメント ===== */
.comments-area{max-width:820px;margin:40px auto 10px;padding:0 20px}
.comments-title{font-family:"Anton";font-size:22px;margin-bottom:18px;letter-spacing:.5px}
.comment-list{list-style:none;margin:0 0 24px;padding:0}
.comment-list li{margin:0 0 14px}
.comment-body,.comment-list .comment-body{background:var(--paper);border:2.5px solid var(--ink);border-radius:14px;padding:14px 16px}
.comment-list .children{list-style:none;margin:12px 0 0 24px;padding:0}
.comment-author{font-weight:800;font-size:14px;display:flex;align-items:center;gap:8px}
.comment-author .avatar{border-radius:50%;border:2px solid var(--ink)}
.comment-metadata{font-size:11px;color:var(--ink-dim);margin:2px 0 8px}
.comment-content{font-size:15px;line-height:1.7}
.comment-content p{margin:0 0 .6em}
.comment-respond{background:var(--bg);border:3px solid var(--ink);border-radius:16px;padding:18px 18px 8px;box-shadow:var(--shadow-sm)}
.comment-reply-title{font-family:"Anton";font-size:20px;margin-bottom:6px}
.comment-notes{font-size:12px;color:var(--ink-dim)}
.comment-form input[type=text],.comment-form input[type=email],.comment-form input[type=url],.comment-form textarea{
  width:100%;border:2.5px solid var(--ink);border-radius:10px;padding:10px 12px;font-family:inherit;font-size:15px;margin-top:4px;background:var(--paper)}
.comment-form p{margin:0 0 12px}
.comment-form label{font-weight:700;font-size:13px}
.comment-submit,.comment-form input[type=submit]{
  background:var(--ink);color:var(--yellow);border:2.5px solid var(--ink);border-radius:999px;
  font-weight:800;padding:10px 26px;font-size:15px;cursor:pointer;transition:.13s}
.comment-submit:hover,.comment-form input[type=submit]:hover{transform:translate(-2px,-2px);box-shadow:var(--shadow-sm)}
.comment-reply-link{font-size:12px;font-weight:700;color:var(--blue)}
.no-comments{color:var(--ink-dim);font-weight:700}
