/*
Theme Name: Incellderm Planner
Theme URI: https://incellderm-jp.com/
Author: Incellderm Japan Authorized Reseller
Description: B案ハイブリッド構成用カスタムテーマ。インセルダム日本公式プランナー専用。article.css 準拠。
Version: 1.0.0
License: GNU General Public License v2 or later
License URI: http://www.gnu.org/licenses/gpl-2.0.html
Text Domain: incellderm-planner
*/

/* ============================================
   Incellderm Planner - WordPress Theme
   既存 article.css とほぼ同等の軽量スタイル
   ============================================ */

:root{
  --green:#38584B;
  --green-d:#2A4338;
  --base:#FFFFFF;
  --base-warm:#FAFAFA;
  --text:#2C2C2C;
  --text-l:#6B6B6B;
  --line:#E5DFD3;
  --serif-en:'Cormorant Garamond', serif;
  --serif-ja:'Shippori Mincho', serif;
  --sans-ja:'Noto Sans JP', sans-serif;
}
*{box-sizing:border-box;margin:0;padding:0}
body{font-family:var(--sans-ja);color:var(--text);line-height:1.95;background:var(--base);-webkit-font-smoothing:antialiased}
img{max-width:100%;display:block;height:auto}
a{color:var(--green);text-decoration:underline;transition:opacity .2s}
a:hover{opacity:.7}

/* === Site Header === */
.site-header{
  background:#fff;border-bottom:1px solid var(--line);
  padding:18px 24px;position:sticky;top:0;z-index:50;
}
.site-header-inner{
  max-width:1200px;margin:0 auto;
  display:flex;justify-content:space-between;align-items:center;
  flex-wrap:wrap;gap:16px;
}
.site-logo{
  font-family:var(--serif-en);font-size:18px;color:var(--green);
  letter-spacing:.1em;text-decoration:none;font-weight:500;
}
.site-logo small{
  display:block;font-size:9px;letter-spacing:.2em;font-family:var(--sans-ja);
  color:var(--text-l);margin-top:2px;font-weight:300;
}
.site-nav{display:flex;gap:18px;align-items:center;flex-wrap:wrap}
.site-nav a{
  font-size:13px;color:var(--text);text-decoration:none;
  letter-spacing:.05em;font-weight:500;
}
.site-nav a:hover{color:var(--green)}
.site-cta{
  background:var(--green);color:#fff;
  padding:9px 18px;font-size:12px;letter-spacing:.1em;
  border-radius:2px;text-decoration:none;font-weight:500;
  transition:background .25s;
}
.site-cta:hover{background:var(--green-d);opacity:1}

/* === Article Wrapper === */
.article-wrap{max-width:760px;margin:40px auto;padding:0 24px}
.breadcrumb{font-size:12px;color:var(--text-l);margin-bottom:16px;letter-spacing:.05em}
.breadcrumb a{color:var(--text-l);text-decoration:none}
.breadcrumb a:hover{color:var(--green)}
.breadcrumb span{margin:0 8px;color:var(--line)}

/* === Article Body === */
article h1{
  font-family:var(--serif-ja);font-size:30px;line-height:1.5;
  color:var(--green);margin-bottom:14px;font-weight:500;
}
.article-meta{font-size:12px;color:var(--text-l);margin-bottom:32px;letter-spacing:.05em}
article h2{
  font-family:var(--serif-ja);font-size:22px;color:var(--green);
  margin-top:48px;margin-bottom:16px;padding-left:14px;
  border-left:3px solid var(--green);font-weight:500;
}
article h3{
  font-family:var(--serif-ja);font-size:17px;color:var(--green);
  margin-top:32px;margin-bottom:12px;font-weight:500;
}
article p{font-size:14.5px;line-height:1.95;margin-bottom:18px;color:var(--text)}
article ul, article ol{margin:18px 0 18px 22px}
article li{font-size:14.5px;line-height:1.95;margin-bottom:10px;color:var(--text)}
article strong{color:var(--green);font-weight:500}
article img{margin:24px auto;border-radius:4px}

/* === CTA Block === */
.cta-block{
  background:#F4F1EA;padding:28px 24px;border-radius:4px;
  text-align:center;margin:32px 0;
}
.cta-block p{margin-bottom:14px;font-size:14px;color:var(--text-l)}
.cta-btn{
  display:inline-block;background:var(--green);color:#fff;
  padding:14px 32px;font-size:13px;letter-spacing:.15em;
  border-radius:2px;text-decoration:none;font-weight:500;
  transition:background .25s;
}
.cta-btn:hover{background:var(--green-d);opacity:1;color:#fff}

/* === Related Articles === */
.related{
  margin-top:48px;padding-top:32px;border-top:1px solid var(--line);
}
.related h4{
  font-family:var(--serif-ja);font-size:16px;color:var(--green);
  margin-bottom:14px;font-weight:500;
}
.related ul{margin:0;list-style:none}
.related li{margin-bottom:8px}
.related a{font-size:13.5px;color:var(--green);text-decoration:underline}

/* === Disclaimer === */
.disclaimer{
  margin-top:32px;font-size:11px;color:var(--text-l);
  padding-top:16px;border-top:1px dashed var(--line);
}

/* === Archive / Index === */
.archive-grid{
  display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));
  gap:24px;margin-top:32px;
}
.archive-card{
  background:#fff;border:1px solid var(--line);padding:22px;
  border-radius:4px;transition:all .25s;
}
.archive-card:hover{
  border-color:var(--green);
  box-shadow:0 6px 20px rgba(56,88,75,.08);
  transform:translateY(-2px);
}
.archive-card a{text-decoration:none;color:var(--text)}
.archive-card .cat{
  display:inline-block;font-size:11px;letter-spacing:.1em;
  color:var(--green);background:#F4F1EA;padding:3px 10px;
  border-radius:2px;margin-bottom:10px;
}
.archive-card h3{
  font-family:var(--serif-ja);font-size:16px;
  line-height:1.6;margin-bottom:8px;color:var(--text);
}
.archive-card p{font-size:13px;color:var(--text-l);line-height:1.7;margin-bottom:8px}
.archive-card .date{font-size:11px;color:var(--text-l);letter-spacing:.05em}

/* === Pagination === */
.pagination{
  display:flex;justify-content:center;gap:8px;margin:48px 0;
  flex-wrap:wrap;
}
.pagination a, .pagination span{
  padding:8px 14px;border:1px solid var(--line);
  text-decoration:none;color:var(--text);font-size:13px;
  border-radius:2px;
}
.pagination a:hover{background:var(--green);color:#fff;border-color:var(--green)}
.pagination .current{background:var(--green);color:#fff;border-color:var(--green)}

/* === Footer === */
.site-footer{
  background:var(--base-warm);padding:40px 24px;text-align:center;
  font-size:12px;color:var(--text-l);margin-top:80px;
  border-top:1px solid var(--line);
}
.site-footer a{
  color:var(--text-l);text-decoration:none;margin:0 12px;
}
.site-footer a:hover{color:var(--green)}

/* === Responsive === */
@media (max-width: 768px){
  article h1{font-size:22px}
  article h2{font-size:18px}
  article h3{font-size:15px}
  article p, article li{font-size:14px}
  .site-header-inner{flex-direction:column;align-items:flex-start}
}

/* === Latest Posts Widget (HP top) === */
.latest-posts{
  display:grid;grid-template-columns:repeat(3,1fr);gap:24px;
  margin:32px 0;
}
@media(max-width:768px){.latest-posts{grid-template-columns:1fr}}

/* === Comment area (disable by default) === */
.comments-area{display:none}
