/*
Theme Name: 男ラボ（OTOKO LABO）
Theme URI: https://otoko-labo.com
Author: REVAGLA
Description: メンズヘルス特化メディア「男ラボ」の専用テーマ。黒×金の高級ミニマル。エビデンスベースの記事量産に最適化。
Version: 1.0.1
Requires at least: 6.0
Tested up to: 6.5
Requires PHP: 7.4
License: GNU General Public License v2 or later
Text Domain: otokolabo
*/

:root{ --ink:#141414; --sub:#5a5651; --line:#e7e2d8; --gold:#c9a45c; --paper:#faf8f4; }
*{box-sizing:border-box;}
body{margin:0;background:var(--paper);color:var(--ink);
  font-family:'Hiragino Kaku Gothic ProN','Yu Gothic',-apple-system,'Segoe UI',sans-serif;
  line-height:1.85;-webkit-font-smoothing:antialiased;}
a{color:inherit;text-decoration:none;}
img{display:block;max-width:100%;height:auto;}

/* ===== header ===== */
.site-header{background:#111;border-bottom:2px solid var(--gold);position:sticky;top:0;z-index:50;}
.site-header .in{max-width:1140px;margin:0 auto;padding:14px 24px;display:flex;align-items:center;gap:18px;}
.logo{display:flex;align-items:center;gap:11px;text-decoration:none;}
.logo img{width:42px;height:42px;border-radius:9px;box-shadow:0 0 0 1px rgba(201,164,92,.3);}
.logo .wm{font-weight:800;letter-spacing:.16em;font-size:20px;color:#fff;line-height:1.1;}
.logo b{color:var(--gold);}
.logo small{display:block;font-size:9px;letter-spacing:.35em;color:#9a927f;font-weight:400;margin-top:2px;}
.gnav{margin-left:auto;display:flex;gap:24px;font-size:13px;color:#d8d2c4;list-style:none;margin:0;padding:0;}
.gnav a:hover{color:var(--gold);}
.gnav .current-menu-item a{color:var(--gold);}
.tagbar{background:#181818;color:#cfc8b8;text-align:center;font-size:13px;letter-spacing:.08em;padding:9px 16px;}
.tagbar b{color:var(--gold);}

/* ===== layout ===== */
.wrap{max-width:1140px;margin:0 auto;padding:0 24px;}
.container{max-width:1140px;margin:0 auto;padding:34px 24px 60px;display:flex;gap:46px;align-items:flex-start;}
.container main{flex:1;min-width:0;}
.sidebar{width:308px;flex:0 0 308px;}
.sidebar .inner{position:sticky;top:92px;}
@media(max-width:920px){ .container{flex-direction:column;gap:14px;} .sidebar{width:100%;flex:none;} .sidebar .inner{position:static;} }

/* ===== home hero ===== */
.hero{display:grid;grid-template-columns:1.7fr 1fr;gap:20px;margin:32px 0;}
@media(max-width:820px){.hero{grid-template-columns:1fr;}}
.feat{position:relative;border-radius:16px;overflow:hidden;min-height:390px;display:flex;align-items:flex-end;}
.feat img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;}
.feat .ov{position:relative;width:100%;padding:30px;background:linear-gradient(0deg,rgba(8,8,8,.92),rgba(8,8,8,.15) 70%,transparent);color:#fff;}
.chip{display:inline-block;background:var(--gold);color:#141414;font-size:11px;font-weight:800;letter-spacing:.08em;padding:4px 11px;border-radius:3px;margin-bottom:12px;}
.feat h2{font-size:26px;line-height:1.45;margin:0 0 8px;font-weight:800;}
.feat p{font-size:13.5px;color:#cfc8b8;margin:0;}
.subs{display:flex;flex-direction:column;gap:20px;}
.sub{display:grid;grid-template-columns:120px 1fr;gap:14px;align-items:center;}
.sub .th{aspect-ratio:1/1;border-radius:12px;overflow:hidden;}
.sub .th img{width:100%;height:100%;object-fit:cover;}
.sub .c{font-size:10px;color:var(--gold);font-weight:800;letter-spacing:.06em;}
.sub h3{font-size:15px;line-height:1.5;margin:3px 0 5px;font-weight:700;}
.sub .d{font-size:11px;color:var(--sub);}

/* ===== section head ===== */
.sec{margin:54px 0 0;}
.sec-h{display:flex;align-items:baseline;gap:12px;border-bottom:2px solid #141414;padding-bottom:8px;margin-bottom:22px;}
.sec-h .jp{font-size:22px;font-weight:800;}
.sec-h .en{font-size:11px;color:var(--gold);letter-spacing:.2em;}
.sec-h .more{margin-left:auto;font-size:12px;color:var(--sub);}

/* ===== card grid ===== */
.grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;}
.grid.cols2{grid-template-columns:1fr 1fr;}
@media(max-width:820px){.grid{grid-template-columns:1fr 1fr;}}
@media(max-width:520px){.grid{grid-template-columns:1fr;}}
.card{background:#fff;border:1px solid var(--line);border-radius:14px;overflow:hidden;transition:.2s;}
.card:hover{box-shadow:0 12px 30px rgba(0,0,0,.09);transform:translateY(-2px);}
.card .th{aspect-ratio:16/9;overflow:hidden;background:#f0ece2;}
.card .th img{width:100%;height:100%;object-fit:cover;}
.card .b{padding:14px 16px 16px;}
.card .c{font-size:10px;color:var(--gold);font-weight:800;letter-spacing:.06em;}
.card h3{font-size:15.5px;line-height:1.55;margin:5px 0 8px;font-weight:700;}
.card .ex{font-size:12px;color:var(--sub);margin:0 0 8px;line-height:1.6;}
.card .d{font-size:11px;color:#9a948a;}

/* ===== CTA banner ===== */
.cta-band{margin:56px 0;background:#111;border-radius:18px;overflow:hidden;display:grid;grid-template-columns:300px 1fr;align-items:center;}
@media(max-width:720px){.cta-band{grid-template-columns:1fr;}}
.cta-band .im{aspect-ratio:1/1;}
.cta-band .im img{width:100%;height:100%;object-fit:cover;}
.cta-band .tx{padding:34px 40px;color:#fff;}
.cta-band .tx .t{color:var(--gold);font-size:12px;letter-spacing:.14em;font-weight:800;}
.cta-band .tx h2{font-size:27px;margin:8px 0 10px;font-weight:800;}
.cta-band .tx p{font-size:14px;color:#c9c3b5;margin:0 0 18px;}
.btn{display:inline-block;background:var(--gold);color:#141414;font-weight:800;padding:13px 30px;border-radius:10px;font-size:14px;letter-spacing:.03em;}

/* ===== category hero ===== */
.chero{background:#141414;color:#fff;}
.chero .in{max-width:1140px;margin:0 auto;padding:40px 24px;}
.chero .cr{font-size:12px;color:#9a927f;letter-spacing:.04em;}
.chero h1{font-size:32px;margin:10px 0 8px;font-weight:800;}
.chero h1 .en{display:block;font-size:12px;color:var(--gold);letter-spacing:.28em;font-weight:400;margin-bottom:6px;}
.chero p{font-size:14px;color:#c9c3b5;margin:0;max-width:640px;}
.chero .cnt{font-size:12px;color:#9a927f;margin-top:12px;}

/* pagination */
.pager{display:flex;gap:8px;justify-content:center;margin:36px 0 0;flex-wrap:wrap;}
.pager a,.pager span{min-width:38px;height:38px;border:1px solid var(--line);border-radius:9px;display:flex;align-items:center;justify-content:center;font-size:14px;background:#fff;color:#4a463f;padding:0 10px;}
.pager .current{background:#141414;color:var(--gold);border-color:#141414;font-weight:800;}

/* ===== single article ===== */
.article .crumb{font-size:12px;color:var(--sub);margin:26px 0 14px;letter-spacing:.04em;}
.article .cat{display:inline-block;background:#141414;color:var(--gold);font-size:11px;letter-spacing:.12em;padding:5px 12px;border-radius:3px;}
.article h1{font-size:30px;line-height:1.55;font-weight:800;margin:16px 0 14px;}
.article .meta{display:flex;gap:16px;color:var(--sub);font-size:13px;border-bottom:1px solid var(--line);padding-bottom:18px;margin-bottom:6px;flex-wrap:wrap;}
.article .eye{width:100%;border-radius:14px;margin:22px 0 8px;box-shadow:0 12px 40px rgba(0,0,0,.13);}
.entry{font-size:16px;}
.entry p{margin:14px 0;}
.entry h2{font-size:23px;font-weight:800;margin:50px 0 8px;padding-top:14px;position:relative;line-height:1.5;scroll-margin-top:90px;}
.entry h2::before{content:"";position:absolute;top:0;left:0;width:44px;height:3px;background:var(--gold);}
.entry h3{font-size:17px;font-weight:700;margin:26px 0 6px;color:#2a2724;}
.entry img{border-radius:12px;margin:22px 0 6px;box-shadow:0 8px 26px rgba(0,0,0,.10);}
.entry table{width:100%;border-collapse:collapse;margin:22px 0;font-size:14.5px;background:#fff;border:1px solid var(--line);border-radius:10px;overflow:hidden;}
.entry th{background:#141414;color:#fff;text-align:left;padding:12px 14px;font-weight:600;font-size:13.5px;}
.entry td{padding:12px 14px;border-top:1px solid var(--line);vertical-align:top;}
.entry tr:nth-child(even) td{background:#faf8f3;}
.entry blockquote{border:none;background:#f6f2e9;border-radius:10px;padding:14px 18px;margin:22px 0;font-size:14.5px;color:#4a463f;}
.entry blockquote a{color:var(--gold);}
.lead{background:#fff;border-left:3px solid var(--gold);padding:20px 22px;margin:24px 0;color:#2c2a27;font-size:15px;border-radius:0 8px 8px 0;box-shadow:0 6px 24px rgba(0,0,0,.04);}
.note{background:#f6f2e9;border-radius:10px;padding:16px 18px;margin:22px 0;font-size:14.5px;color:#4a463f;}
.note b{color:var(--gold);}
.cite{color:#8a857c;font-size:13px;}
.fc{color:#b23;font-size:10px;background:#fdecec;border-radius:4px;padding:1px 5px;margin-left:3px;vertical-align:1px;}
.refs{border-top:1px solid var(--line);margin-top:38px;padding-top:6px;}
.refs ol{font-size:13.5px;color:#4a463f;line-height:1.8;padding-left:20px;}
.disc{font-size:12px;color:#8a857c;margin-top:26px;border-top:1px solid var(--line);padding-top:16px;}

/* ===== REVAGLA product box ===== */
.revbox{border:1px solid #e6e1d5;border-radius:16px;overflow:hidden;margin:32px 0;background:#fff;box-shadow:0 10px 34px rgba(0,0,0,.07);}
.revbox .top{background:#111;color:var(--gold);padding:10px 20px;font-size:12px;letter-spacing:.12em;}
.revbox .body{display:flex;flex-wrap:wrap;gap:22px;padding:24px;align-items:flex-start;}
.revbox .pimg{flex:0 0 170px;}
.revbox .pimg img{width:100%;border-radius:10px;box-shadow:0 8px 24px rgba(0,0,0,.18);margin:0;}
.revbox .info{flex:1;min-width:230px;}
.revbox h3{margin:0 0 6px;font-size:21px;}
.revbox .gold{color:var(--gold);font-size:13px;}
.revbox table{margin:12px 0;border:none;}
.revbox td{border-top:1px solid #eee;padding:7px 0;}

/* ===== sidebar widgets ===== */
.w{background:#fff;border:1px solid var(--line);border-radius:14px;padding:18px;margin-bottom:20px;}
.w-h{font-size:13px;font-weight:800;letter-spacing:.06em;margin:0 0 12px;padding-bottom:9px;border-bottom:2px solid var(--gold);}
.toc a{display:block;font-size:13.5px;color:#4a463f;padding:6px 0 6px 14px;border-left:2px solid var(--line);}
.toc a:hover{color:var(--gold);border-color:var(--gold);}
.w.cta-box{background:#111;border:none;color:#fff;text-align:center;}
.w.cta-box img{width:112px;border-radius:8px;margin:2px auto 10px;}
.w.cta-box .t{font-size:12px;color:var(--gold);letter-spacing:.1em;}
.w.cta-box .n{font-size:19px;font-weight:800;margin:2px 0 6px;}
.w.cta-box p{font-size:12px;color:#c9c3b5;margin:0 0 12px;line-height:1.7;}
.w.cta-box .btn{width:100%;font-size:13px;padding:11px 0;}
.rank{counter-reset:r;}
.rank a{display:flex;gap:11px;align-items:flex-start;font-size:13.5px;line-height:1.6;padding:9px 0;border-top:1px solid #f0ebe0;}
.rank a:first-child{border-top:none;}
.rank a::before{counter-increment:r;content:counter(r);flex:0 0 22px;height:22px;background:var(--gold);color:#141414;font-weight:800;font-size:12px;border-radius:50%;display:flex;align-items:center;justify-content:center;margin-top:1px;}
.rank .th{flex:0 0 56px;height:42px;border-radius:7px;overflow:hidden;}
.rank .th img{width:100%;height:100%;object-fit:cover;}
.cats a{display:inline-block;font-size:12.5px;background:#f6f2e9;border-radius:20px;padding:5px 12px;margin:0 6px 8px 0;color:#4a463f;}

/* ===== footer ===== */
.site-footer{background:#111;color:#b8b2a4;margin-top:40px;}
.site-footer .in{max-width:1140px;margin:0 auto;padding:34px 24px;display:flex;flex-wrap:wrap;gap:30px;align-items:center;}
.site-footer .fnav{display:flex;gap:26px;font-size:13px;margin-left:auto;flex-wrap:wrap;list-style:none;margin:0 0 0 auto;padding:0;}
.site-footer .cc{width:100%;border-top:1px solid #2a2a2a;padding-top:16px;font-size:11px;color:#7a7466;}
