/* =====================================================
   AI副業ラボ - 共通記事スタイルシート
   全記事ページで <link rel="stylesheet" href="article.css"> として読み込む
   ===================================================== */

/* ── RESET & BASE ── */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:'Noto Sans JP',sans-serif;background:#F8FAFC;color:#1E293B;line-height:1.75;font-size:15px;-webkit-font-smoothing:antialiased}
a{color:inherit;text-decoration:none}
img{display:block;max-width:100%}

/* ── CSS変数 ── */
:root{
  --ind:#6366F1;
  --ind-d:#4F46E5;
  --ind-l:#EEF2FF;
  --grn:#10B981;
  --grn-d:#059669;
  --grn-l:#ECFDF5;
  --amb:#F59E0B;
  --text:#1E293B;
  --t2:#475569;
  --t3:#94A3B8;
  --bg:#F8FAFC;
  --bg2:#F1F5F9;
  --card:#FFF;
  --bdr:#E2E8F0;
  --bdr2:#CBD5E1;
  --sh1:0 1px 3px rgba(15,23,42,.05),0 4px 16px rgba(15,23,42,.04);
  --sh2:0 4px 12px rgba(15,23,42,.08),0 12px 32px rgba(15,23,42,.06);
  --r:14px;
  --r2:8px;
  --mono:'JetBrains Mono',monospace;
}

/* ── ナビゲーション ── */
.nav{position:sticky;top:0;z-index:100;background:rgba(255,255,255,.92);backdrop-filter:blur(20px) saturate(180%);-webkit-backdrop-filter:blur(20px) saturate(180%);border-bottom:1px solid rgba(226,232,240,.7);height:64px}
.nav-in{max-width:1200px;margin:0 auto;padding:0 24px;height:64px;display:flex;align-items:center;gap:24px}
.logo{display:flex;align-items:center;gap:10px;flex-shrink:0}
.logo-m{width:34px;height:34px;border-radius:10px;background:linear-gradient(135deg,#6366F1,#8B5CF6);display:flex;align-items:center;justify-content:center;font-size:17px;box-shadow:0 3px 10px rgba(99,102,241,.3)}
.logo-t{font-size:16px;font-weight:700;color:var(--text)}
.nav-links{display:flex;gap:2px;flex:1}
.nav-links a{padding:7px 12px;border-radius:8px;font-size:13px;font-weight:500;color:var(--t2);transition:all .15s}
.nav-links a:hover{color:var(--ind);background:var(--ind-l)}
.nav-r{margin-left:auto;display:flex;gap:10px;flex-shrink:0;align-items:center}
.btn-cta{padding:8px 16px;background:var(--ind);color:#fff;border-radius:8px;font-size:13px;font-weight:700;box-shadow:0 2px 8px rgba(99,102,241,.3);transition:all .15s}
.btn-cta:hover{background:var(--ind-d);transform:translateY(-1px)}
.ham{display:none;flex-direction:column;gap:5px;padding:6px;margin-left:auto;background:none;border:none;cursor:pointer}
.ham span{display:block;width:22px;height:2px;background:var(--text);border-radius:2px}

/* ── ドロワーメニュー ── */
.drawer-ov{display:none;position:fixed;inset:0;background:rgba(15,23,42,.6);z-index:300;backdrop-filter:blur(4px)}
.drawer-ov.open{display:block}
.drawer{position:absolute;top:0;right:0;bottom:0;width:280px;background:#fff;padding:24px;overflow-y:auto;box-shadow:-8px 0 32px rgba(0,0,0,.15)}
.drawer-cl{text-align:right;margin-bottom:20px;font-size:22px;color:var(--t2);cursor:pointer}
.drawer a{display:block;padding:13px 0;border-bottom:1px solid var(--bdr);font-size:15px;font-weight:500;color:var(--text)}
.drawer a:hover{color:var(--ind)}

/* ── パンくずリスト ── */
.bc-strip{background:#fff;border-bottom:1px solid var(--bdr);padding:12px 0}
.bc{max-width:1200px;margin:0 auto;padding:0 24px;font-size:12px;color:var(--t3);display:flex;align-items:center;gap:6px;flex-wrap:wrap}
.bc a{color:var(--t3)}.bc a:hover{color:var(--ind)}

/* ── 記事ヒーロー ── */
.art-hero{background:#fff;border-bottom:1px solid var(--bdr);padding:36px 0}
.art-hero-in{max-width:1200px;margin:0 auto;padding:0 24px}
.art-cats{display:flex;gap:6px;margin-bottom:14px;flex-wrap:wrap}
.cat-badge{font-size:10px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;padding:3px 10px;border-radius:4px}
.cb-ai{background:var(--ind-l);color:#4338CA}
.cb-fuku{background:var(--grn-l);color:#065F46}
.cb-new{background:#FFF7ED;color:#C2410C}
.cb-cmp{background:#F5F3FF;color:#6D28D9}
.cb-auto{background:#EFF6FF;color:#1D4ED8}
.art-h1{font-size:clamp(20px,3vw,30px);font-weight:700;line-height:1.35;margin-bottom:18px;letter-spacing:-.02em}
.art-meta{display:flex;align-items:center;gap:14px;flex-wrap:wrap;margin-bottom:20px}
.art-date,.art-views{font-size:12.5px;color:var(--t3)}
.art-update{font-size:11px;background:var(--grn-l);color:var(--grn-d);padding:3px 9px;border-radius:4px;font-weight:700}
.star-row{display:flex;align-items:center;gap:10px;background:var(--bg2);border:1px solid var(--bdr);border-radius:10px;padding:12px 18px;margin-bottom:20px;max-width:320px}
.stars-vis{font-size:20px;letter-spacing:-2px;color:var(--amb)}
.star-score{font-family:var(--mono);font-size:22px;font-weight:600}
.star-label,.star-count{font-size:11px;color:var(--t3);line-height:1.4}
.art-summary{background:var(--ind-l);border:1.5px solid rgba(99,102,241,.2);border-radius:var(--r);padding:18px 22px}
.art-summary h3{font-size:13px;font-weight:700;color:var(--ind);margin-bottom:9px;text-transform:uppercase;letter-spacing:.06em}
.art-summary ul{padding-left:18px}
.art-summary li{font-size:14px;color:var(--text);margin-bottom:5px;line-height:1.7}

/* ── 記事レイアウト ── */
.art-layout{max-width:1200px;margin:0 auto;padding:36px 24px 64px;display:grid;grid-template-columns:1fr 280px;gap:40px;align-items:start}

/* ── 記事本文 ── */
.art-body h2{font-size:19px;font-weight:700;margin:38px 0 14px;padding-left:14px;border-left:4px solid var(--ind);line-height:1.4}
.art-body h3{font-size:15px;font-weight:700;margin:24px 0 9px}
.art-body p{font-size:14.5px;color:var(--t2);line-height:1.9;margin-bottom:13px}
.art-body ul,.art-body ol{padding-left:22px;margin-bottom:13px}
.art-body li{font-size:14.5px;color:var(--t2);line-height:1.85;margin-bottom:5px}
.art-body strong{color:var(--text);font-weight:700}
.art-body a{color:var(--ind)}
.art-body a:hover{text-decoration:underline}

/* ── コンテンツボックス ── */
.info-box{background:var(--ind-l);border-left:4px solid var(--ind);border-radius:0 10px 10px 0;padding:13px 17px;margin:16px 0}
.info-box p{color:var(--text);margin-bottom:0;font-size:13.5px}
.warn-box{background:#FFF7ED;border-left:4px solid var(--amb);border-radius:0 10px 10px 0;padding:13px 17px;margin:16px 0}
.warn-box p{color:#92400E;margin-bottom:0;font-size:13.5px}
.check-box{background:var(--grn-l);border-left:4px solid var(--grn);border-radius:0 10px 10px 0;padding:13px 17px;margin:16px 0}
.check-box p{color:#065F46;margin-bottom:0;font-size:13.5px}

/* ── テーブル ── */
.tbl-wrap{overflow-x:auto;margin:16px 0;border-radius:var(--r);border:1px solid var(--bdr);box-shadow:var(--sh1)}
table{width:100%;border-collapse:collapse;background:#fff;font-size:13.5px}
thead tr{background:var(--text);color:#fff}
thead th{padding:11px 14px;text-align:left;font-weight:700;font-size:12.5px;white-space:nowrap}
tbody tr{border-bottom:1px solid var(--bdr)}
tbody tr:hover{background:var(--bg2)}
tbody tr:last-child{border-bottom:none}
td{padding:11px 14px;color:var(--t2);vertical-align:top;line-height:1.65}
td:first-child{font-weight:700;color:var(--text)}
.rec{display:inline-block;font-size:9px;font-weight:700;background:var(--grn);color:#fff;padding:2px 6px;border-radius:3px;margin-left:5px;vertical-align:middle}
.price{font-family:var(--mono);font-weight:600;color:var(--grn-d)}

/* ── CTAブロック ── */
.cta-block{background:linear-gradient(135deg,#ECFDF5,#F0FDF4);border:1.5px solid rgba(16,185,129,.25);border-radius:var(--r);padding:20px;margin:22px 0;text-align:center}
.cta-block p{font-size:13.5px;color:var(--t2);margin-bottom:10px}
.btn-try{display:inline-flex;align-items:center;gap:8px;padding:12px 26px;background:var(--grn);color:#fff;border-radius:10px;font-size:14px;font-weight:700;box-shadow:0 4px 14px rgba(16,185,129,.3);transition:all .2s}
.btn-try:hover{background:var(--grn-d);transform:translateY(-2px);color:#fff}

/* ── メリット/デメリット ── */
.md-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin:16px 0}
.merit-box,.demerit-box{border-radius:var(--r);padding:15px 17px}
.merit-box{background:var(--grn-l);border:1px solid rgba(16,185,129,.2)}
.demerit-box{background:#FFF1F2;border:1px solid rgba(244,63,94,.15)}
.md-title{font-size:13px;font-weight:700;margin-bottom:8px}
.merit-box .md-title{color:var(--grn-d)}
.demerit-box .md-title{color:#BE123C}
.md-list{list-style:none;padding:0}
.md-list li{font-size:13px;line-height:1.75;padding-left:14px;position:relative;margin-bottom:4px;color:var(--t2)}
.merit-box .md-list li::before{content:'✓';position:absolute;left:0;color:var(--grn);font-weight:700}
.demerit-box .md-list li::before{content:'✕';position:absolute;left:0;color:#BE123C;font-weight:700}

/* ── 著者ボックス ── */
.author-box{background:#fff;border:1px solid var(--bdr);border-radius:var(--r);padding:18px 20px;display:flex;gap:14px;align-items:flex-start;margin:34px 0}
.author-avatar{width:52px;height:52px;border-radius:50%;background:linear-gradient(135deg,var(--ind),#8B5CF6);display:flex;align-items:center;justify-content:center;font-size:24px;flex-shrink:0}
.author-name{font-size:14px;font-weight:700;margin-bottom:3px}
.author-role{font-size:10px;color:var(--ind);font-weight:700;margin-bottom:6px;text-transform:uppercase;letter-spacing:.06em}
.author-bio{font-size:12.5px;color:var(--t2);line-height:1.75}

/* ── 関連記事 ── */
.related h3{font-size:16px;font-weight:700;margin-bottom:14px;display:flex;align-items:center;gap:7px}
.related h3::before{content:'';display:block;width:3px;height:16px;background:var(--ind);border-radius:2px}
.related-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:11px}
.rel-card{background:#fff;border:1px solid var(--bdr);border-radius:var(--r2);overflow:hidden;cursor:pointer;transition:all .18s;box-shadow:var(--sh1);text-decoration:none;display:block}
.rel-card:hover{box-shadow:var(--sh2);transform:translateY(-2px);border-color:rgba(99,102,241,.2)}
.rel-img{height:68px;display:flex;align-items:center;justify-content:center;font-size:24px}
.rel-body{padding:10px 11px}
.rel-tag{font-size:9px;font-weight:700;color:var(--ind);text-transform:uppercase;letter-spacing:.06em;margin-bottom:4px}
.rel-title{font-size:12px;font-weight:700;line-height:1.5;color:var(--text)}
.rel-card:hover .rel-title{color:var(--ind)}

/* ── 広告ボックス ── */
.ad-box{background:var(--bg2);border:1.5px dashed var(--bdr2);border-radius:8px;padding:9px;text-align:center;font-family:var(--mono);font-size:11px;color:var(--t3);margin:18px 0;min-height:52px;display:flex;align-items:center;justify-content:center;line-height:1.6}

/* ── サイドバー ── */
.sidebar{display:flex;flex-direction:column;gap:16px}
.sb-card{background:#fff;border:1px solid var(--bdr);border-radius:var(--r);padding:17px;position:sticky;top:80px;box-shadow:var(--sh1)}
.sb-card h3{font-size:13px;font-weight:700;margin-bottom:11px;display:flex;align-items:center;gap:6px}
.toc-list{list-style:none}
.toc-list li{border-bottom:1px solid var(--bdr)}
.toc-list li:last-child{border-bottom:none}
.toc-list a{display:flex;align-items:flex-start;gap:6px;padding:7px 0;font-size:12px;color:var(--t2);transition:color .15s}
.toc-list a:hover{color:var(--ind)}
.toc-list a::before{content:'§';color:var(--ind);font-size:10px;opacity:.6;flex-shrink:0;margin-top:3px}
.toc-list a.active{color:var(--ind);font-weight:700}
.sb-cta{background:linear-gradient(135deg,var(--ind),#7C3AED);border-radius:var(--r);padding:18px;color:#fff;text-align:center}
.sb-cta h4{font-size:13px;font-weight:700;margin-bottom:6px}
.sb-cta p{font-size:12px;opacity:.85;margin-bottom:12px;line-height:1.6}
.sb-cta a{display:block;padding:9px;background:#fff;color:var(--ind);border-radius:7px;font-size:12px;font-weight:700;transition:.15s}
.sb-cta a:hover{background:var(--grn-l);color:var(--grn-d)}
.sb-rating{background:var(--bg2);border-radius:10px;padding:13px;text-align:center}
.big-score{font-family:var(--mono);font-size:36px;font-weight:600;line-height:1}
.big-stars{font-size:17px;color:var(--amb);letter-spacing:-1px;margin:3px 0}
.score-label{font-size:11px;color:var(--t3)}
.score-bars{margin-top:11px}
.score-row{display:flex;align-items:center;gap:7px;margin-bottom:5px}
.score-row-label{font-size:10.5px;color:var(--t3);min-width:60px;text-align:right}
.score-bar-bg{flex:1;height:5px;background:var(--bdr2);border-radius:3px;overflow:hidden}
.score-bar-fill{height:100%;border-radius:3px;background:var(--amb)}
.score-row-val{font-size:10.5px;font-family:var(--mono);color:var(--t2);min-width:18px}

/* ── フッター ── */
.footer{background:#0F172A;color:#64748B;padding:40px 0 0}
.ft-in{max-width:1200px;margin:0 auto;padding:0 24px}
.ft-grid{display:grid;grid-template-columns:1.8fr 1fr 1fr 1fr;gap:40px;margin-bottom:36px}
.ft-brand .ftl{display:flex;align-items:center;gap:8px;margin-bottom:12px}
.ft-brand .ftl span{font-size:15px;font-weight:700;color:#fff}
.ft-brand p{font-size:12.5px;line-height:1.8;max-width:250px}
.ft-col h4{font-size:10px;font-weight:700;color:#94A3B8;text-transform:uppercase;letter-spacing:.1em;margin-bottom:14px}
.ft-col a{display:block;font-size:13px;color:#475569;margin-bottom:9px;transition:color .15s}
.ft-col a:hover{color:#fff}
.ft-bottom{border-top:1px solid #1E293B;padding:18px 0 22px;display:flex;justify-content:space-between;flex-wrap:wrap;gap:8px;font-size:12px}
.ft-bottom a{color:#475569}
.ft-bottom a:hover{color:#fff}
.ft-affi{background:#1E293B;padding:9px 0;text-align:center;font-size:11px;color:#475569}

/* ── レスポンシブ ── */
@media(max-width:960px){
  .art-layout{grid-template-columns:1fr}
  .sidebar{display:none}
  .related-grid{grid-template-columns:1fr 1fr}
  .ft-grid{grid-template-columns:1fr 1fr;gap:28px}
  .nav-links,.nav-r{display:none}
  .ham{display:flex}
  .md-grid{grid-template-columns:1fr}
}
@media(max-width:600px){
  .art-h1{font-size:19px}
  .ft-grid{grid-template-columns:1fr}
  .related-grid{grid-template-columns:1fr}
  .art-layout{padding:20px 16px 48px}
  .bc,.art-hero-in{padding:0 16px}
}
