/* フタリノマネー - original stylesheet */
:root{
  --bg:#fbf7f2;
  --ink:#2a2a2a;
  --sub:#6b6b6b;
  --brand:#2b7a78;     /* teal - intentionally different from reference site */
  --brand-dk:#205754;
  --accent:#f0a500;
  --card:#ffffff;
  --line:#e9e2d6;
  --shadow:0 2px 10px rgba(40,30,10,.06);
  --radius:12px;
  --maxw:1120px;
}
*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{
  font-family:-apple-system,BlinkMacSystemFont,"Hiragino Sans","Noto Sans JP","Yu Gothic",sans-serif;
  color:var(--ink);
  background:var(--bg);
  line-height:1.75;
  font-size:16px;
}
a{color:var(--brand-dk);text-decoration:none}
a:hover{text-decoration:underline}
img{max-width:100%;display:block}

/* header */
.site-header{
  background:#fff;
  border-bottom:1px solid var(--line);
  position:sticky;top:0;z-index:50;
}
.header-inner{
  max-width:var(--maxw);margin:0 auto;padding:14px 20px;
  display:flex;align-items:center;justify-content:space-between;gap:20px;
}
.logo{font-weight:800;font-size:22px;color:var(--brand-dk);letter-spacing:.02em}
.logo span{color:var(--accent)}
.logo small{display:block;font-size:11px;color:var(--sub);font-weight:500;margin-top:2px}
.nav{display:flex;gap:18px;flex-wrap:wrap}
.nav a{color:var(--ink);font-size:14px;font-weight:600}
.nav a:hover{color:var(--brand)}
.search{border:1px solid var(--line);border-radius:999px;padding:6px 14px;font-size:13px;background:#fbf7f2}

/* hero */
.hero{
  background:linear-gradient(135deg,#2b7a78 0%,#3aafa9 100%);
  color:#fff;padding:56px 20px;text-align:center;
}
.hero h1{margin:0 0 10px;font-size:30px;letter-spacing:.02em}
.hero p{margin:0;opacity:.92;font-size:15px}

/* layout */
.container{max-width:var(--maxw);margin:0 auto;padding:32px 20px}
.layout{display:grid;grid-template-columns:1fr 300px;gap:32px}
@media(max-width:860px){.layout{grid-template-columns:1fr}}

/* section */
.section-title{
  font-size:20px;margin:0 0 16px;padding-left:12px;
  border-left:4px solid var(--accent);
}

/* category chips */
.cats{display:flex;gap:10px;flex-wrap:wrap;margin:0 0 28px}
.cat{
  background:#fff;border:1px solid var(--line);border-radius:999px;
  padding:8px 16px;font-size:13px;font-weight:600;color:var(--brand-dk);
}
.cat:hover{background:var(--brand);color:#fff;text-decoration:none}

/* cards */
.card-list{display:grid;grid-template-columns:repeat(2,1fr);gap:18px}
@media(max-width:600px){.card-list{grid-template-columns:1fr}}
.card{
  background:var(--card);border-radius:var(--radius);box-shadow:var(--shadow);
  overflow:hidden;border:1px solid var(--line);transition:transform .15s;
}
.card:hover{transform:translateY(-2px)}
.card .thumb{
  height:150px;
  background:linear-gradient(135deg,#f0a500,#f7c35c);
  display:flex;align-items:center;justify-content:center;
  color:#fff;font-size:40px;font-weight:800;
}
.card .thumb.c2{background:linear-gradient(135deg,#2b7a78,#3aafa9)}
.card .thumb.c3{background:linear-gradient(135deg,#c4452e,#e87a5d)}
.card .thumb.c4{background:linear-gradient(135deg,#5f4b8b,#9b7ed4)}
.card .thumb.c5{background:linear-gradient(135deg,#386641,#6a994e)}
.card .thumb.c6{background:linear-gradient(135deg,#1f4e79,#4a90c2)}
.card-body{padding:16px}
.card .tag{
  display:inline-block;font-size:11px;font-weight:700;color:var(--brand);
  background:#e6f4f3;padding:3px 8px;border-radius:4px;margin-bottom:8px;
}
.card h3{margin:0 0 8px;font-size:16px;line-height:1.5}
.card h3 a{color:var(--ink)}
.card .meta{font-size:12px;color:var(--sub)}

/* sidebar */
.sidebar .widget{
  background:#fff;border:1px solid var(--line);border-radius:var(--radius);
  padding:18px;margin-bottom:20px;box-shadow:var(--shadow);
}
.sidebar h4{margin:0 0 12px;font-size:15px;border-bottom:2px solid var(--accent);padding-bottom:6px}
.sidebar ul{list-style:none;padding:0;margin:0}
.sidebar li{padding:8px 0;border-bottom:1px dashed var(--line);font-size:14px}
.sidebar li:last-child{border-bottom:none}

/* article page */
.article{
  background:#fff;padding:32px 36px;border-radius:var(--radius);
  border:1px solid var(--line);box-shadow:var(--shadow);
}
@media(max-width:600px){.article{padding:22px 18px}}
.breadcrumb{font-size:12px;color:var(--sub);margin-bottom:14px}
.breadcrumb a{color:var(--sub)}
.article h1{font-size:26px;line-height:1.5;margin:0 0 10px}
.article .meta{color:var(--sub);font-size:13px;margin-bottom:24px;padding-bottom:16px;border-bottom:1px solid var(--line)}
.article h2{
  font-size:22px;margin:36px 0 14px;padding:10px 16px;
  background:#e6f4f3;border-left:5px solid var(--brand);border-radius:4px;
}
.article h3{font-size:17px;margin:26px 0 10px;color:var(--brand-dk);border-bottom:2px dotted var(--line);padding-bottom:4px}
.article p{margin:0 0 16px}
.article ul,.article ol{margin:0 0 18px;padding-left:22px}
.article li{margin-bottom:6px}
.article table{width:100%;border-collapse:collapse;margin:16px 0;font-size:14px}
.article th,.article td{border:1px solid var(--line);padding:10px;text-align:left}
.article th{background:#e6f4f3;color:var(--brand-dk)}
.callout{
  background:#fff8e6;border:1px solid #f4d98a;border-radius:8px;
  padding:14px 18px;margin:18px 0;font-size:14px;
}
.callout.warn{background:#fdeeee;border-color:#f3b4b4}
.toc{
  background:#fbf7f2;border:1px solid var(--line);border-radius:8px;
  padding:16px 22px;margin:20px 0 28px;
}
.toc h4{margin:0 0 8px;font-size:14px}
.toc ol{margin:0;padding-left:20px}
.toc a{color:var(--ink)}

/* footer */
.site-footer{
  background:#1f3a39;color:#d9e7e6;margin-top:60px;padding:34px 20px;
  text-align:center;font-size:13px;
}
.site-footer a{color:#fff}
.site-footer .links{margin-bottom:10px}
.site-footer .links a{margin:0 10px}

/* ========== Affiliate/SNS additions ========== */

/* PR disclosure label */
.pr-label{
  display:inline-block;font-size:11px;color:var(--sub);
  border:1px solid var(--line);padding:2px 8px;border-radius:4px;
  margin-bottom:10px;background:#fff;
}

/* Lead magnet / LINE capture */
.lead-magnet{
  background:linear-gradient(135deg,#06c755 0%,#04a548 100%);
  color:#fff;border-radius:var(--radius);padding:26px 24px;
  margin:30px 0;text-align:center;box-shadow:var(--shadow);
}
.lead-magnet h3{margin:0 0 8px;font-size:20px}
.lead-magnet p{margin:0 0 16px;font-size:14px;opacity:.95}
.lead-magnet .btn{
  display:inline-block;background:#fff;color:#04a548;
  font-weight:800;padding:12px 28px;border-radius:999px;
  font-size:15px;text-decoration:none;
}
.lead-magnet .btn:hover{background:#f4f4f4;text-decoration:none}

/* Affiliate CTA box */
.aff-cta{
  background:#fff8e6;border:2px solid var(--accent);border-radius:var(--radius);
  padding:22px;margin:28px 0;box-shadow:var(--shadow);position:relative;
}
.aff-cta .pr-label{position:absolute;top:10px;right:12px;background:#fff}
.aff-cta h4{
  margin:0 0 8px;font-size:18px;color:#c4452e;
  padding-right:60px;
}
.aff-cta .aff-lead{font-size:13px;color:var(--sub);margin:0 0 14px}
.aff-cta .aff-features{
  list-style:none;padding:0;margin:0 0 16px;
  display:grid;grid-template-columns:1fr 1fr;gap:6px;font-size:13px;
}
.aff-cta .aff-features li::before{content:"✅ ";}
@media(max-width:520px){.aff-cta .aff-features{grid-template-columns:1fr}}
.aff-btn{
  display:block;text-align:center;background:linear-gradient(180deg,#ff8c42,#f0701c);
  color:#fff !important;font-weight:800;font-size:16px;
  padding:16px 20px;border-radius:10px;text-decoration:none;
  box-shadow:0 4px 0 #c45614;transition:transform .1s;
}
.aff-btn:hover{transform:translateY(1px);box-shadow:0 3px 0 #c45614;text-decoration:none}
.aff-btn small{display:block;font-size:11px;opacity:.9;font-weight:500;margin-top:2px}

/* Share buttons */
.share-buttons{
  display:flex;gap:8px;flex-wrap:wrap;margin:20px 0;
  padding:14px;background:#fbf7f2;border-radius:8px;
  align-items:center;
}
.share-buttons .share-label{
  font-size:12px;font-weight:700;color:var(--sub);margin-right:4px;
}
.share-buttons a{
  display:inline-flex;align-items:center;gap:6px;
  padding:8px 14px;border-radius:6px;color:#fff !important;
  font-size:13px;font-weight:700;text-decoration:none;
}
.share-buttons a:hover{opacity:.85;text-decoration:none}
.sb-x{background:#000}
.sb-line{background:#06c755}
.sb-fb{background:#1877f2}
.sb-hb{background:#00a4de}
.sb-copy{background:#6b6b6b}

/* Author box */
.author-box{
  display:flex;gap:16px;align-items:flex-start;
  background:#fbf7f2;border:1px solid var(--line);border-radius:var(--radius);
  padding:18px;margin:30px 0;
}
.author-box .avatar{
  width:64px;height:64px;border-radius:50%;flex-shrink:0;
  background:linear-gradient(135deg,#2b7a78,#3aafa9);
  display:flex;align-items:center;justify-content:center;
  color:#fff;font-size:24px;font-weight:800;
}
.author-box .author-info h5{margin:0 0 4px;font-size:15px}
.author-box .author-info p{margin:0;font-size:12px;color:var(--sub);line-height:1.6}
.author-box .author-sns{margin-top:6px;display:flex;gap:10px;font-size:12px}

/* Ranking card */
.ranking-card{
  background:#fff;border:2px solid var(--line);border-radius:var(--radius);
  padding:22px 22px 22px 72px;margin:18px 0;position:relative;
  box-shadow:var(--shadow);
}
.ranking-card::before{
  content:attr(data-rank);position:absolute;left:-2px;top:-2px;
  width:56px;height:56px;
  background:linear-gradient(135deg,#f0a500,#f7c35c);
  color:#fff;font-size:24px;font-weight:900;
  display:flex;align-items:center;justify-content:center;
  border-radius:var(--radius) 0 var(--radius) 0;
}
.ranking-card[data-rank="1位"]::before{background:linear-gradient(135deg,#d4af37,#f0d47c)}
.ranking-card[data-rank="2位"]::before{background:linear-gradient(135deg,#a8a8a8,#d4d4d4)}
.ranking-card[data-rank="3位"]::before{background:linear-gradient(135deg,#cd7f32,#e6a363)}
.ranking-card h3{margin:0 0 6px;font-size:19px;color:var(--brand-dk)}
.ranking-card .rc-tag{font-size:12px;color:var(--sub);margin-bottom:10px}
.ranking-card .rc-desc{font-size:14px;margin:0 0 14px}
.ranking-card table{width:100%;font-size:13px;margin:10px 0}

/* Floating CTA (mobile) */
.float-cta{
  position:fixed;left:0;right:0;bottom:0;z-index:100;
  background:#fff;border-top:1px solid var(--line);
  padding:10px 14px;display:none;
  box-shadow:0 -4px 16px rgba(0,0,0,.08);
}
.float-cta a{
  display:block;text-align:center;
  background:linear-gradient(180deg,#ff8c42,#f0701c);
  color:#fff;font-weight:800;padding:14px;border-radius:8px;
  text-decoration:none;font-size:15px;
}
@media(max-width:860px){
  .float-cta{display:block}
  body{padding-bottom:72px}
}

/* Hero CTA buttons */
.hero-cta{
  margin-top:20px;display:flex;gap:12px;justify-content:center;flex-wrap:wrap;
}
.hero-cta a{
  display:inline-block;padding:14px 28px;border-radius:999px;
  font-weight:800;font-size:15px;text-decoration:none;
}
.hero-cta .primary{background:#fff;color:var(--brand-dk)}
.hero-cta .secondary{background:rgba(255,255,255,.15);color:#fff;border:2px solid #fff}
.hero-cta a:hover{transform:translateY(-1px);text-decoration:none}

/* Comparison table highlight */
.compare-table{font-size:14px}
.compare-table .best{background:#fff8e6;font-weight:700}

/* ========== Mobile header fix ========== */
@media(max-width:860px){
  .site-header .header-inner{
    display:flex !important;
    flex-direction:column !important;
    align-items:stretch !important;
    flex-wrap:nowrap !important;
    padding:10px 14px !important;
    gap:8px !important;
  }
  .site-header .logo{
    font-size:18px !important;
    white-space:nowrap !important;
    overflow:hidden !important;
    text-overflow:ellipsis !important;
    text-align:left !important;
  }
  .site-header .logo small{
    display:inline-block !important;
    font-size:10px !important;
    margin-left:8px !important;
    margin-top:0 !important;
  }
  .site-header .search{display:none !important}
  .site-header .nav{
    display:flex !important;
    width:100% !important;
    overflow-x:auto !important;
    flex-wrap:nowrap !important;
    gap:16px !important;
    padding:2px 0 4px !important;
    -webkit-overflow-scrolling:touch !important;
    scrollbar-width:none !important;
    justify-content:flex-start !important;
  }
  .site-header .nav::-webkit-scrollbar{display:none !important}
  .site-header .nav a{
    font-size:13px !important;
    white-space:nowrap !important;
    flex-shrink:0 !important;
  }
  .hero{padding:40px 16px}
  .hero h1{font-size:22px}
  .hero p{font-size:13px}
  .hero-cta a{padding:11px 20px;font-size:14px}
}
