/* ふたりのマネー会議 — calm teal + cream tone (app の静謐トーンに準拠) */

:root{
  --bg:          #f3f1ec;
  --bg-card:     #ffffff;
  --bg-soft:     #ebe7df;
  --ink:         #222828;
  --ink-soft:    #3c4242;
  --muted:       #5e6565;        /* caption 用に AA(>=4.5:1 on cream)を満たすよう darken */
  --dim:         #586060;

  --line:        rgba(34,40,40,.10);
  --line-strong: rgba(34,40,40,.18);

  --teal:        #2d6a6e;        /* deep teal(アクセント・吹き出し濃色) */
  --teal-deep:   #235458;
  --teal-text:   #1f5054;        /* cream 上のテキストアクセント(AA) */
  --sage:        #6fa3a0;        /* sage teal(吹き出し淡色) */
  --teal-soft:   rgba(45,106,110,.12);

  --sans:"Inter","Hiragino Sans","Noto Sans JP","Helvetica Neue",system-ui,sans-serif;
  --mono:"JetBrains Mono","SF Mono",Menlo,Consolas,monospace;
}

*{box-sizing:border-box}
html,body{margin:0;padding:0;background:var(--bg);color:var(--ink);font-family:var(--sans);font-size:16px;line-height:1.75;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}
body{min-height:100vh;overflow-x:hidden}

a{color:var(--teal-deep);text-decoration:underline;text-decoration-thickness:1px;text-underline-offset:3px;text-decoration-color:var(--teal-soft);transition:color .15s, text-decoration-color .15s}
a:hover{text-decoration-color:currentColor}
.muted{color:var(--muted)}
.dim{color:var(--dim)}

h1,h2,h3{font-family:var(--sans);font-weight:700;margin:0;color:var(--ink);letter-spacing:0}
h1{font-size:clamp(32px,5.2vw,52px);line-height:1.3;font-weight:700}
h1 .accent{color:var(--teal-text);font-style:normal;font-weight:700}
h2{font-size:clamp(22px,3.2vw,30px);line-height:1.42;margin:0 0 14px;font-weight:700}
h3{font-size:17px;line-height:1.48;margin:0 0 6px;font-weight:700}

/* topbar */
.topbar{
  position:sticky;top:0;z-index:50;
  display:flex;align-items:center;gap:14px;
  padding:14px 24px;
  background:rgba(243,241,236,.94);backdrop-filter:blur(12px);
  border-bottom:1px solid var(--line);
  font-size:14px;
}
.brand{display:inline-flex;align-items:center;gap:10px;font-family:var(--sans);font-size:18px;font-weight:800;color:var(--ink);text-decoration:none;letter-spacing:0}
.brand img{width:26px;height:26px;border-radius:6px;display:block}
.topbar .spacer{flex:1}
.topbar .topbar-cta{display:inline-block;padding:9px 18px;background:var(--teal);color:#fff;font-weight:700;font-size:13px;text-decoration:none;border-radius:8px;transition:transform .15s,background .15s,box-shadow .15s;box-shadow:0 2px 8px -2px rgba(45,106,110,.5)}
.topbar .topbar-cta:hover{transform:translateY(-1px);background:var(--teal-deep);color:#fff}

/* layout */
main{max-width:920px;margin:0 auto;padding:48px 28px 96px}
section{padding:48px 0;border-bottom:1px solid var(--line)}
section:last-of-type{border-bottom:none}
section:first-of-type{padding-top:24px}
@media (max-width:640px){
  main{padding:32px 18px 64px}
  section{padding:36px 0}
}

/* section marker */
.section-marker{
  font-family:var(--mono);font-size:11px;letter-spacing:.18em;text-transform:uppercase;
  color:var(--teal-text);margin-bottom:14px;
  display:flex;align-items:center;gap:10px;
}
.section-marker::before{content:"";display:inline-block;width:24px;height:1px;background:var(--teal)}

/* hero */
.hero{padding-top:40px}
.hero .lede{font-family:var(--sans);font-weight:400;font-size:clamp(16px,2.1vw,19px);line-height:1.78;color:var(--ink-soft);max-width:54ch;margin:20px 0 26px}
.hero .lede strong{color:var(--ink);font-weight:700}
.hero-bullets{list-style:none;padding:0;margin:0 0 32px;display:grid;gap:10px;max-width:56ch}
.hero-bullets li{font-size:15px;color:var(--ink-soft);line-height:1.7}
.hero-bullets li strong{color:var(--ink);font-weight:700}
.hero-cta{display:flex;flex-wrap:wrap;gap:14px;align-items:center;margin:8px 0 8px}
.badge{height:50px;width:auto;display:inline-block;vertical-align:middle}
.coming-soon{display:inline-flex;align-items:center;gap:8px;font-family:var(--mono);font-size:12px;letter-spacing:.08em;color:var(--teal-text);background:var(--teal-soft);border:1px solid var(--line);padding:10px 16px;border-radius:8px}

/* stats row(評価値は出さない=非リリース・静謐) */
.stats-row{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;padding-top:20px}
@media (max-width:560px){.stats-row{grid-template-columns:repeat(2,1fr)}}
.stat{padding:20px 14px;text-align:center;background:var(--bg-card);border:1px solid var(--line);border-radius:12px;box-shadow:0 1px 0 rgba(0,0,0,.02)}
.stat .v{font-family:var(--sans);font-size:clamp(24px,4vw,32px);font-weight:800;color:var(--teal-text);line-height:1.15}
.stat .l{font-family:var(--mono);font-size:11px;color:var(--muted);margin-top:10px;text-transform:uppercase;letter-spacing:.1em}

/* prose */
section p{font-size:16px;line-height:1.85;color:var(--ink-soft);max-width:62ch;margin:0 0 14px}
section p:last-child{margin-bottom:0}
section p strong{color:var(--ink);font-weight:700}

/* feature rows(スクショ無し=テキスト主体) */
.feat{display:grid;gap:14px}
.feat-block{background:var(--bg-card);border:1px solid var(--line);border-left:4px solid var(--teal);border-radius:12px;padding:20px 22px}
.feat-block h3{color:var(--teal-text)}
.feat-block p{margin:6px 0 0;font-size:15.5px;color:var(--ink-soft)}
.feat-block ul{margin:8px 0 0;padding-left:20px;font-size:15px;color:var(--ink-soft)}
.feat-block li{margin-bottom:6px}

/* pricing */
.plans{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin-top:8px}
@media (max-width:560px){.plans{grid-template-columns:1fr}}
.plan{background:var(--bg-card);border:1px solid var(--line);border-radius:14px;padding:22px 24px}
.plan.highlight{border-color:var(--teal);box-shadow:0 6px 22px -12px rgba(45,106,110,.5)}
.plan .plan-name{font-family:var(--mono);font-size:12px;letter-spacing:.1em;text-transform:uppercase;color:var(--muted)}
.plan .plan-price{font-size:30px;font-weight:800;color:var(--ink);margin:8px 0 2px}
.plan .plan-price .u{font-size:14px;color:var(--muted);font-weight:500;margin-left:4px}
.plan .plan-sub{font-size:13px;color:var(--teal-text);font-weight:600}
.plan .plan-note{font-size:13px;color:var(--muted);margin-top:8px}
.plans-note{margin-top:14px;font-size:13px;color:var(--dim)}

/* specs */
.specs{display:grid;grid-template-columns:repeat(2,1fr);gap:1px;background:var(--line);border:1px solid var(--line);border-radius:12px;overflow:hidden;margin-top:6px}
@media (max-width:560px){.specs{grid-template-columns:1fr}}
.spec{padding:16px 20px;background:var(--bg-card);display:flex;justify-content:space-between;align-items:baseline;gap:16px}
.spec dt{font-family:var(--mono);font-size:11px;color:var(--muted);text-transform:uppercase;letter-spacing:.12em;flex-shrink:0}
.spec dd{margin:0;font-size:15px;color:var(--ink);text-align:right;font-weight:600}
.spec dd em{font-style:normal;color:var(--teal-text);font-weight:700}

/* download cta */
.cta-row{display:flex;flex-wrap:wrap;gap:14px;margin-top:8px;align-items:center}
.cta{display:inline-flex;align-items:center;gap:10px;padding:16px 30px;border-radius:10px;background:var(--teal);color:#fff;font-weight:800;font-size:15px;text-decoration:none;transition:transform .15s, box-shadow .15s, background .15s;box-shadow:0 6px 22px -8px rgba(45,106,110,.55)}
.cta:hover{transform:translateY(-1px);background:var(--teal-deep);color:#fff;box-shadow:0 10px 26px -8px rgba(45,106,110,.65)}

/* FAQ */
.faq details{padding:18px 22px;background:var(--bg-card);border:1px solid var(--line);border-radius:10px;margin-bottom:10px}
.faq summary{cursor:pointer;font-weight:700;font-size:16px;color:var(--ink);list-style:none;padding-right:32px;position:relative;line-height:1.5}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{content:"+";position:absolute;right:0;top:0;font-family:var(--mono);font-size:22px;color:var(--teal-deep);transition:transform .2s;line-height:1}
.faq details[open] summary::after{content:"\2212"}
.faq p{margin:12px 0 0;color:var(--ink-soft);font-size:14.5px;line-height:1.8;max-width:none}

/* note / disclaimer band */
.note{background:var(--teal-soft);border:1px solid var(--line);border-radius:12px;padding:18px 22px;font-size:14.5px;color:var(--ink-soft);line-height:1.8}
.note strong{color:var(--teal-text)}

/* legal pages */
.legal h1{font-size:clamp(28px,4vw,42px);line-height:1.3;margin-bottom:12px}
.legal .updated{color:var(--dim);font-family:var(--mono);font-size:12px;margin:0 0 32px;letter-spacing:.05em}
.legal h2{font-size:20px;margin-top:36px;margin-bottom:12px;font-weight:700}
.legal h3{font-size:16px;margin-top:22px;margin-bottom:6px;color:var(--teal-text);font-weight:700}
.legal p, .legal ul{color:var(--ink-soft);font-size:15.5px;line-height:1.85;max-width:64ch}
.legal ul{padding-left:22px}
.legal li{margin-bottom:8px}
.legal a{color:var(--teal-text)}
.legal .note{margin:18px 0;max-width:64ch}

/* footer */
footer{padding:36px 28px;border-top:1px solid var(--line);font-size:13px;color:var(--muted);text-align:center;background:var(--bg-soft)}
footer a{color:var(--ink-soft);margin:0 10px;text-decoration:none;border-bottom:1px solid transparent;padding-bottom:2px;transition:color .15s, border-color .15s}
footer a:hover{color:var(--teal-deep);border-bottom-color:var(--teal-soft)}
footer .copy{margin-top:14px;font-family:var(--mono);font-size:11px;color:var(--dim);letter-spacing:.08em}

/* reduced motion */
@media (prefers-reduced-motion: reduce){
  *,*::before,*::after{animation:none !important;transition:none !important}
}
