/* =============================================================
   ataraku.com サイト雛形 共有スタイル（Draft）
   ブランド: AtaRaku（あたらく合同会社）
   トーン: 編集的・信頼感・落ち着き（法人信頼性優先）
   ============================================================= */
:root {
  --ink: #1a1814;
  --muted: #6b6357;
  --line: #e3ddd2;
  --paper: #fbf9f4;
  --paper-2: #f4efe6;
  --accent: #c8553d;      /* テラコッタ */
  --accent-2: #d99a2b;    /* 補助 */
  --ok: #2f7d5b;
  --max: 1080px;
}
* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
  margin: 0;
  font-family: "Hiragino Kaku Gothic ProN", "Noto Sans JP", "Yu Gothic", Meiryo, sans-serif;
  color: var(--ink);
  background: var(--paper);
  line-height: 1.85;
  font-size: 16px;
}
.serif { font-family: "Fraunces", "Noto Serif JP", "Yu Mincho", serif; }
a { color: var(--accent); text-decoration: none; }
a:hover { text-decoration: underline; }
.wrap { max-width: var(--max); margin: 0 auto; padding: 0 24px; }
.muted { color: var(--muted); }

/* ---- ヘッダー ---- */
.site-header {
  position: sticky; top: 0; z-index: 50;
  background: rgba(251,249,244,0.92); backdrop-filter: blur(6px);
  border-bottom: 1px solid var(--line);
}
.site-header .wrap { display: flex; align-items: center; justify-content: space-between; height: 64px; }
.brand { font-family: "Fraunces","Noto Serif JP",serif; font-weight: 700; font-size: 22px; letter-spacing: 0.01em; color: var(--ink); }
.brand span { color: var(--accent); }
.nav a { color: var(--ink); font-size: 14px; margin-left: 22px; }
.nav a.cta {
  background: var(--accent); color: #fff; padding: 8px 16px; border-radius: 6px;
}
.nav a.cta:hover { text-decoration: none; opacity: 0.92; }
@media (max-width: 720px){
  .site-header .wrap { height: auto; flex-wrap: wrap; gap: 8px; padding: 10px 16px; }
  .nav a { margin-left: 14px; }
}

/* ---- ヒーロー ---- */
.hero { padding: 84px 0 64px; }
.hero h1 { font-family:"Fraunces","Noto Serif JP",serif; font-size: 40px; line-height: 1.3; margin: 0 0 18px; }
.hero p.lead { font-size: 18px; color: var(--muted); max-width: 640px; margin: 0 0 28px; }
.btn {
  display: inline-block; background: var(--accent); color: #fff;
  padding: 13px 28px; border-radius: 8px; font-weight: 600; font-size: 16px;
}
.btn:hover { text-decoration: none; opacity: 0.92; }
.btn.secondary { background: transparent; color: var(--ink); border: 1px solid var(--line); margin-left: 10px; }

/* ---- セクション ---- */
section { padding: 56px 0; }
section h2 { font-family:"Fraunces","Noto Serif JP",serif; font-size: 28px; margin: 0 0 8px; }
section .sec-lead { color: var(--muted); margin: 0 0 32px; }

/* ---- 製品カード ---- */
.cards { display: grid; grid-template-columns: repeat(2, 1fr); gap: 20px; }
@media (max-width: 720px){ .cards { grid-template-columns: 1fr; } }
.card {
  background: #fff; border: 1px solid var(--line); border-radius: 12px; padding: 26px 26px 22px;
  display: flex; flex-direction: column; gap: 8px;
}
.card .badge { align-self: flex-start; font-size: 12px; font-weight: 700; letter-spacing: 0.06em; padding: 3px 10px; border-radius: 999px; }
.badge.available { background: #e6f2ec; color: var(--ok); }
.badge.soon { background: var(--paper-2); color: var(--muted); }
.card h3 { font-family:"Fraunces","Noto Serif JP",serif; font-size: 20px; margin: 6px 0 2px; }
.card p { font-size: 14px; color: var(--muted); margin: 0 0 8px; }
.card .card-link { margin-top: auto; font-weight: 600; font-size: 14px; }

/* ---- 特徴グリッド ---- */
.features { display: grid; grid-template-columns: repeat(3, 1fr); gap: 22px; }
@media (max-width: 720px){ .features { grid-template-columns: 1fr; } }
.feature h3 { font-size: 16px; margin: 0 0 6px; }
.feature p { font-size: 14px; color: var(--muted); margin: 0; }

/* ---- 価格 ---- */
.pricing { display: grid; grid-template-columns: repeat(2, 1fr); gap: 22px; }
@media (max-width: 720px){ .pricing { grid-template-columns: 1fr; } }
.plan { background: #fff; border: 1px solid var(--line); border-radius: 12px; padding: 28px; text-align: center; }
.plan.featured { border-color: var(--accent); box-shadow: 0 6px 24px rgba(200,85,61,0.08); }
.plan h3 { font-family:"Fraunces","Noto Serif JP",serif; font-size: 20px; margin: 0 0 6px; }
.plan .price { font-size: 32px; font-weight: 700; margin: 8px 0; }
.plan .price small { font-size: 14px; font-weight: 400; color: var(--muted); }
.plan ul { text-align: left; font-size: 14px; padding-left: 1.1em; margin: 14px 0 20px calc(3.6em + 1cm); color: var(--muted); }
.plan ul li { margin: 4px 0; }

/* ---- 注記 / 画像プレースホルダ ---- */
.shot { background: var(--paper-2); border: 2px dashed var(--accent-2); border-radius: 10px; padding: 48px 20px; text-align: center; color: var(--muted); font-size: 14px; }
.ph { color: #b03a2e; font-weight: 700; } /* 公開前に差し替える箇所 */
.note { background: #fff; border-left: 4px solid var(--accent-2); border-radius: 0 8px 8px 0; padding: 16px 20px; font-size: 14px; color: var(--ink); }

/* ---- フッター ---- */
.site-footer { border-top: 1px solid var(--line); background: var(--paper-2); padding: 40px 0; font-size: 13px; color: var(--muted); margin-top: 40px; }
.site-footer .cols { display: flex; justify-content: space-between; gap: 24px; flex-wrap: wrap; }
.site-footer a { color: var(--muted); }
.site-footer .legal { margin-top: 18px; font-size: 12px; }

/* purchase buttons (pastel green) */
.btn.buy, a.cta.buy { background: #729167; }
.btn.buy:hover, a.cta.buy:hover { background: #61805a; opacity: 1; }

/* fixes: button text white / align plan buttons to bottom / price & legal-link black */
.btn .ph, a.cta .ph { color: #fff; }
.plan { display: flex; flex-direction: column; }
.plan .btn { margin-top: auto; align-self: center; }
.plan .price .ph { color: var(--ink); }
