html { font-size: 16px !important; }

:root {
  --ink: #0f0f0f;
  --paper: #faf8f5;
  --orange: #e8572a;
  --orange-glow: rgba(232,87,42,0.12);
  --cool: #2e6fe6;
  --cool-glow: rgba(46,111,230,0.10);
  --warm: #e8572a;
  --warm-glow: rgba(232,87,42,0.12);
  --gray-600: #555;
  --gray-400: #999;
  --gray-200: #e0ddd8;
  --gray-100: #f0eeea;
  --radius: 20px;
  --mono: 'IBM Plex Mono', monospace;
}
*{margin:0;padding:0;box-sizing:border-box;}
html{scroll-behavior:smooth;}
body{
  font-family:'Noto Sans JP',sans-serif;
  background:var(--paper);
  color:var(--ink);
  line-height:1.85;
  overflow-x:hidden;
}
h1,h2,h3,h4{font-family:'Zen Maru Gothic',sans-serif;line-height:1.35;}
.container{max-width:840px;margin:0 auto;padding:0 24px;}

/* ── NAV ── */
nav{
  position:fixed;top:0;left:0;right:0;z-index:100;
  background:rgba(250,248,245,0.8);
  backdrop-filter:blur(20px);
  border-bottom:1px solid rgba(0,0,0,0.04);
}
.nav-inner{
  max-width:840px;margin:0 auto;padding:14px 24px;
  display:flex;align-items:center;justify-content:space-between;
}
.nav-logo{
  font-family:var(--mono);font-weight:600;font-size:1.2rem;
  color:var(--ink);text-decoration:none;letter-spacing:0.05em;
}
.nav-logo span{color:var(--orange);}
.nav-cta{
  background:var(--ink);color:var(--paper);
  padding:12px 28px;border-radius:100px;
  text-decoration:none;font-weight:700;font-size:1rem;
  letter-spacing:0.02em;transition:all 0.3s;
}
.nav-cta:hover{background:var(--orange);}

/* ── HERO ── */
.hero{
  padding:120px 0 40px;
  text-align:center;
}
.hero-lead{
  font-family:var(--mono);font-size:0.75rem;
  color:var(--orange);letter-spacing:0.12em;
  text-transform:uppercase;margin-bottom:16px;
  animation:fadeUp .5s ease-out;
}
.hero h1{
  font-size:clamp(1.5rem,4.5vw,2.3rem);
  font-weight:900;margin-bottom:16px;
  animation:fadeUp .5s ease-out .08s both;
}
.hero h1 .warm{color:var(--warm);}
.hero h1 .cool{color:var(--cool);}
.hero-sub{
  color:var(--gray-600);font-size:0.95rem;
  margin-bottom:8px;line-height:1.8;
  animation:fadeUp .5s ease-out .16s both;
}
.hero-arrow{
  font-size:1.5rem;
  animation:bounce 2s infinite 1.5s;
  display:inline-block;margin-top:8px;
}
.hero-free-badge{
  display:inline-block;
  background:var(--orange);color:var(--paper);
  padding:14px 32px;border-radius:100px;
  text-decoration:none;font-weight:700;font-size:0.95rem;
  letter-spacing:0.02em;
  margin-top:20px;
  transition:all 0.3s;
  animation:fadeUp .5s ease-out .24s both;
  box-shadow:0 4px 20px rgba(232,87,42,0.25);
}
.hero-free-badge:hover{transform:translateY(-2px);box-shadow:0 8px 28px rgba(232,87,42,0.4);}
@keyframes bounce{
  0%,100%{transform:translateY(0);}
  50%{transform:translateY(8px);}
}

/* ── TWO AXES VISUAL ── */
.axes{padding:20px 0 60px;}
.axes-cards{
  display:grid;grid-template-columns:1fr 1fr;gap:16px;
  max-width:600px;margin:0 auto;
  animation:fadeUp .6s ease-out .3s both;
}
@media(max-width:560px){.axes-cards{grid-template-columns:1fr;max-width:360px;}}
.axis-card{
  padding:28px 24px;border-radius:var(--radius);
  text-align:center;
  transition:transform 0.3s;
  cursor:default;
}
.axis-card:hover{transform:translateY(-4px);}
.axis-card.revenue{
  background:linear-gradient(135deg,var(--warm-glow),rgba(232,87,42,0.02));
  border:2px solid var(--warm);
}
.axis-card.cost{
  background:linear-gradient(135deg,var(--cool-glow),rgba(46,111,230,0.02));
  border:2px solid var(--cool);
}
.axis-icon{font-size:2rem;margin-bottom:8px;}
.axis-label{
  font-family:var(--mono);font-size:0.65rem;
  letter-spacing:0.1em;text-transform:uppercase;
  margin-bottom:8px;
}
.axis-card.revenue .axis-label{color:var(--warm);}
.axis-card.cost .axis-label{color:var(--cool);}
.axis-card h3{font-size:1.1rem;margin-bottom:6px;}
.axis-card p{font-size:0.8rem;color:var(--gray-600);line-height:1.6;}

.axes-connector{
  text-align:center;margin-top:24px;
  font-family:'Zen Maru Gothic',sans-serif;
  font-weight:700;font-size:0.95rem;
  color:var(--gray-400);
  animation:fadeUp .6s ease-out .5s both;
}
.axes-connector strong{color:var(--ink);}

/* ── CHAT WINDOW ── */
.chat-section{padding:60px 0 80px;}
.chat-section .section-header{text-align:center;margin-bottom:24px;}
.chat-section .section-header h2{font-size:1.4rem;margin-bottom:6px;}
.chat-section .section-header p{font-size:0.85rem;color:var(--gray-400);}

.chat-window{
  max-width:540px;margin:0 auto;
  background:#fff;border-radius:var(--radius);
  box-shadow:0 8px 48px rgba(0,0,0,0.07);
  overflow:hidden;
  border:1px solid var(--gray-200);
}
.chat-topbar{
  background:var(--ink);color:var(--paper);
  padding:14px 20px;
  font-family:var(--mono);font-size:0.75rem;
  display:flex;align-items:center;gap:8px;
  letter-spacing:0.05em;
}
.chat-topbar .dot{
  width:8px;height:8px;border-radius:50%;
  background:var(--cool);animation:blink 2s infinite;
}
@keyframes blink{0%,100%{opacity:1;}50%{opacity:0.3;}}
.chat-body{
  padding:20px;
  min-height:200px;
  display:flex;flex-direction:column;gap:12px;
  overflow-y:auto;max-height:420px;
}
.msg{
  max-width:85%;padding:12px 16px;
  border-radius:16px;font-size:0.88rem;
  line-height:1.6;
  animation:msgIn 0.35s ease-out both;
}
@keyframes msgIn{from{opacity:0;transform:translateY(8px);}to{opacity:1;transform:translateY(0);}}
.msg.bot{
  background:var(--gray-100);
  align-self:flex-start;
  border-bottom-left-radius:4px;
}
.msg.user{
  background:var(--ink);color:var(--paper);
  align-self:flex-end;
  border-bottom-right-radius:4px;
}
.msg.typing .dots{display:inline-flex;gap:4px;}
.msg.typing .dots span{
  width:6px;height:6px;border-radius:50%;
  background:var(--gray-400);
  animation:dotBounce 1.2s infinite;
}
.msg.typing .dots span:nth-child(2){animation-delay:0.2s;}
.msg.typing .dots span:nth-child(3){animation-delay:0.4s;}
@keyframes dotBounce{0%,100%{transform:translateY(0);}50%{transform:translateY(-5px);}}

.chat-options{
  padding:0 20px 20px;
  display:flex;flex-direction:column;gap:8px;
}
.chat-opt{
  background:var(--paper);
  border:2px solid var(--gray-200);
  border-radius:12px;
  padding:12px 16px;
  font-size:0.85rem;
  font-weight:500;
  cursor:pointer;
  transition:all 0.25s;
  text-align:left;
  font-family:'Noto Sans JP',sans-serif;
}
.chat-opt:hover{border-color:var(--orange);background:var(--orange-glow);color:var(--orange);}
.chat-opt:active{transform:scale(0.98);}
.chat-opt.selected{
  border-color:var(--orange);background:var(--orange);
  color:var(--paper);pointer-events:none;
}

/* ── RESULT CARD ── */
.result-card{
  margin:0 20px 20px;padding:24px;
  border-radius:16px;
  text-align:center;
  animation:msgIn 0.5s ease-out both;
}
.result-card.revenue-type{
  background:linear-gradient(135deg, var(--warm-glow) 0%, rgba(232,87,42,0.04) 100%);
  border:2px solid var(--warm);
}
.result-card.cost-type{
  background:linear-gradient(135deg, var(--cool-glow) 0%, rgba(46,111,230,0.04) 100%);
  border:2px solid var(--cool);
}
.result-card.balanced-type{
  background:linear-gradient(135deg, var(--warm-glow) 0%, var(--cool-glow) 100%);
  border:2px solid var(--ink);
}
.result-card .result-type{
  font-family:var(--mono);font-size:0.7rem;
  letter-spacing:0.1em;
  text-transform:uppercase;margin-bottom:8px;
}
.result-card h3{font-size:1.15rem;margin-bottom:8px;}
.result-card p{font-size:0.85rem;color:var(--gray-600);margin-bottom:16px;line-height:1.7;}
.result-card a{
  display:inline-block;
  background:var(--orange);color:var(--paper);
  padding:12px 28px;border-radius:100px;
  text-decoration:none;font-weight:700;font-size:0.85rem;
  transition:all 0.3s;
}
.result-card a:hover{transform:translateY(-2px);box-shadow:0 6px 20px rgba(232,87,42,0.3);}

/* ── ROAST ── */
.roast{padding:80px 0;overflow:hidden;}
.roast-inner{
  max-width:560px;margin:0 auto;
}
.roast-lead{
  font-size:0.95rem;
  line-height:1.9;
  color:var(--gray-600);
  margin-bottom:20px;
}
.roast-punchline{
  font-family:'Zen Maru Gothic',sans-serif;
  font-size:1.6rem;font-weight:700;
  line-height:1.4;
  margin-bottom:32px;
  color:var(--ink);
}
.roast-answer{
  padding-left:20px;
  border-left:3px solid var(--orange);
  margin-bottom:24px;
}
.roast-answer p{
  font-size:1rem;
  line-height:1.9;
  margin-bottom:12px;
  color:var(--ink);
}
.roast-answer p:last-child{margin-bottom:0;}
.roast .highlight{
  background:linear-gradient(transparent 60%,var(--orange-glow) 60%);
  font-weight:700;
}
.roast-sub{
  font-size:0.82rem;color:var(--gray-400);
  margin-top:32px;
  letter-spacing:0.02em;
}

/* ── WHY ── */
.why{padding:80px 0;overflow:hidden;}
.why-inner{
  display:grid;grid-template-columns:1fr 1fr;gap:40px;
  align-items:center;
}
@media(max-width:640px){.why-inner{grid-template-columns:1fr;gap:32px;}}
.why-text h2{font-size:1.6rem;margin-bottom:16px;}
.why-text p{font-size:0.92rem;color:var(--gray-600);margin-bottom:16px;}
.why-text .why-punchline{
  font-family:'Zen Maru Gothic',sans-serif;
  font-weight:900;font-size:1.1rem;
  color:var(--ink);
  padding:16px 20px;
  background:var(--orange-glow);
  border-left:4px solid var(--orange);
  border-radius:0 12px 12px 0;
  margin-top:20px;
  line-height:1.6;
}

.why-visual{position:relative;}
.goal-card{
  background:#fff;border-radius:var(--radius);
  padding:28px;box-shadow:0 8px 40px rgba(0,0,0,0.06);
  border:1px solid var(--gray-200);
  position:relative;
}
.goal-card .goal-label{
  font-family:var(--mono);font-size:0.65rem;
  letter-spacing:0.1em;text-transform:uppercase;
  color:var(--cool);margin-bottom:16px;display:block;
}
.goal-item{
  display:flex;gap:12px;align-items:flex-start;
  padding:12px 0;
  border-bottom:1px solid var(--gray-100);
}
.goal-item:last-child{border-bottom:none;}
.goal-check{
  flex-shrink:0;width:28px;height:28px;
  border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  font-size:0.85rem;font-weight:700;
}
.goal-check.done{background:var(--cool);color:#fff;}
.goal-check.next{background:var(--orange-glow);color:var(--orange);border:2px dashed var(--orange);}
.goal-item-text{font-size:0.88rem;}
.goal-item-text strong{display:block;font-size:0.8rem;color:var(--ink);}
.goal-item-text span{font-size:0.78rem;color:var(--gray-400);}
.goal-card-bg{
  position:absolute;
  top:20px;left:20px;right:-8px;bottom:-8px;
  background:var(--ink);border-radius:var(--radius);
  z-index:-1;opacity:0.04;
}

/* ── STORIES ── */
.stories{padding:80px 0;}
.stories-header{margin-bottom:48px;}
.stories-header h2{font-size:1.6rem;margin-bottom:8px;}
.stories-header p{color:var(--gray-400);font-size:0.9rem;}

.story{
  display:grid;grid-template-columns:1fr 40px 1fr;gap:0;
  align-items:stretch;
  margin-bottom:24px;
  opacity:0;transform:translateY(20px);
  transition:opacity 0.5s,transform 0.5s;
}
.story.visible{opacity:1;transform:translateY(0);}
@media(max-width:600px){
  .story{grid-template-columns:1fr;gap:0;}
  .story-arrow{transform:rotate(90deg) !important;margin:4px auto;}
}

.story-before,.story-after{
  padding:24px;border-radius:var(--radius);
  font-size:0.88rem;line-height:1.7;
  display:flex;flex-direction:column;justify-content:center;
}
.story-before{
  background:#fff;border:1px solid var(--gray-200);
  color:var(--gray-600);
}
.story-after{
  background:linear-gradient(135deg, #eef4fd, #e8f0fc);
  border:1px solid #c0d4f0;
  color:var(--ink);
}
.story-before .story-label,.story-after .story-label{
  font-family:var(--mono);font-size:0.65rem;
  letter-spacing:0.1em;text-transform:uppercase;
  margin-bottom:10px;display:block;
}
.story-before .story-label{color:var(--gray-400);}
.story-after .story-label{color:var(--cool);font-weight:600;}
.story-tag{
  display:inline-block;
  font-family:var(--mono);font-size:0.6rem;
  padding:2px 8px;border-radius:100px;
  margin-bottom:8px;letter-spacing:0.05em;
}
.story-tag.rev{background:var(--warm-glow);color:var(--warm);}
.story-tag.cost{background:var(--cool-glow);color:var(--cool);}
.story-before .story-who{
  font-weight:700;font-size:0.8rem;color:var(--ink);
  margin-bottom:8px;display:block;
  font-family:'Zen Maru Gothic',sans-serif;
}
.story-after .story-who{
  font-weight:700;font-size:0.8rem;color:var(--orange);
  margin-bottom:8px;display:block;
  font-family:'Zen Maru Gothic',sans-serif;
}
.story-arrow{
  display:flex;align-items:center;justify-content:center;
  font-size:1.2rem;color:var(--orange);
  font-weight:700;
}

/* ── WHAT WE DO ── */
.what{padding:80px 0;}
.what h2{font-size:1.6rem;margin-bottom:8px;}
.what .subtitle{color:var(--gray-400);font-size:0.9rem;margin-bottom:40px;}
.what-cards{display:flex;flex-direction:column;gap:16px;}
.what-card{
  display:grid;grid-template-columns:56px 1fr;gap:20px;
  align-items:start;
  background:#fff;border-radius:var(--radius);
  padding:28px;
  border:1px solid var(--gray-200);
  transition:opacity 0.35s,margin-left 0.35s;
  opacity:0;margin-left:-16px;
}
.what-card.visible{opacity:1;margin-left:0;}
.what-card:hover{box-shadow:0 8px 32px rgba(0,0,0,0.06);border-color:var(--orange);}
.what-num{
  font-family:var(--mono);font-size:1.8rem;font-weight:600;
  color:var(--orange);
  line-height:1.5;padding:4px 0;
}
.what-card h3{font-size:1.05rem;font-weight:700;margin-bottom:6px;}
.what-card p{font-size:0.85rem;color:var(--ink);}
.what-card .tag{
  display:inline-block;margin-top:10px;
  font-family:var(--mono);font-size:0.85rem;
  padding:3px 10px;border-radius:100px;
}
.tag-rev{color:var(--warm);background:var(--warm-glow);}
.tag-cost{color:var(--cool);background:var(--cool-glow);}
.tag-both{color:var(--ink);background:var(--gray-100);}

/* ── PRICING ROI (LP3 override: cool) ── */
.pricing-roi{
  text-align:center;margin-top:20px;
  font-family:'Zen Maru Gothic',sans-serif;
  font-weight:700;font-size:0.9rem;
  color:var(--cool);
  padding:12px 20px;
  background:var(--cool-glow);
  border-radius:100px;
  display:inline-block;
  width:100%;
}

/* ── MID CTA (LP3 override: cool-glow gradient) ── */
.mid-cta-box{
  background:linear-gradient(135deg, var(--orange-glow), var(--cool-glow));
}

/* ── FOOTER ── */
footer{padding:32px 0;text-align:center;font-size:0.75rem;color:var(--gray-400);}
.footer-lp__copyright{margin:0;}
.footer-lp__company-link{margin:8px 0 0;}
.footer-lp__company-link a{color:var(--gray-400);text-decoration:underline;}
.footer-lp__company-link a:hover{color:var(--gray-300);}

/* ── ANIMATIONS ── */
@keyframes fadeUp{
  from{opacity:0;transform:translateY(20px);}
  to{opacity:1;transform:translateY(0);}
}
.js-enabled .sf{opacity:0;transform:translateY(20px);transition:opacity 0.55s,transform 0.55s;}
.js-enabled .sf.visible{opacity:1;transform:translateY(0);}

@media(max-width:640px){
  .hero{padding:100px 0 30px;}
  .what-card{grid-template-columns:1fr;gap:8px;}
  .what-num{font-size:1.2rem;}
}
