@charset "utf-8";
/* CSS Document */

/* ============ Reset & Base ============ */
    *, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
    html { scroll-behavior: smooth; }
    body {
      font-family: "Noto Sans JP", sans-serif;
      color: #1C1917;
      line-height: 1.8;
      background: #F6F3EC;
      font-size: 15px;
      -webkit-font-smoothing: antialiased;
    }
    img { max-width: 100%; display: block; }
    a { color: inherit; text-decoration: none; }
    .mincho { font-family: "Shippori Mincho", serif; font-weight: 500; }

    /* ============ Layout ============ */
    .container { max-width: 1080px; margin: 0 auto; padding: 0 24px; }
    .container-sm { max-width: 760px; margin: 0 auto; padding: 0 24px; }

    section { padding: 100px 0; }
    @media (max-width: 720px) { section { padding: 64px 0; } }

    .section-eyebrow {
      font-size: 11px;
      letter-spacing: 0.3em;
      color: #2D5F5D;
      text-align: center;
      margin-bottom: 12px;
    }
    h2.section-title {
      font-size: 30px;
      text-align: center;
      margin-bottom: 56px;
      letter-spacing: 0.04em;
      line-height: 1.5;
    }
    @media (max-width: 720px) { h2.section-title { font-size: 22px; margin-bottom: 40px; } }

    /* ============ Header ============ */
    .header {
      position: sticky; top: 0; z-index: 100;
      background: rgba(246, 243, 236, 0.85);
      backdrop-filter: blur(10px);
      -webkit-backdrop-filter: blur(10px);
      border-bottom: 1px solid rgba(28, 25, 23, 0.06);
    }
    .header-inner {
      display: flex; align-items: center; justify-content: space-between;
      padding: 16px 24px; max-width: 1080px; margin: 0 auto;
    }
    .logo { font-family: "Shippori Mincho", serif; font-size: 20px; font-weight: 500; letter-spacing: 0.1em; }
    .logo .accent { color: #2D5F5D; }
    .nav { display: flex; gap: 28px; align-items: center; }
    .nav a { font-size: 13px; color: #57534E; transition: color 0.15s; }
    .nav a:hover { color: #1C1917; }
    .nav .cta-mini {
      background: #1C1917; color: white; padding: 8px 18px; border-radius: 6px; font-size: 13px;
    }
    .nav .cta-mini:hover { color: white; opacity: 0.9; }
    @media (max-width: 720px) { .nav a:not(.cta-mini) { display: none; } }

    /* ============ Hero ============ */
    .hero {
      padding: 96px 0 80px;
      background: radial-gradient(800px 400px at 50% 0%, #EAF1EF 0%, transparent 70%);
      text-align: center;
    }
    .hero .badge {
      display: inline-block; padding: 5px 14px; border: 1px solid #2D5F5D;
      border-radius: 100px; color: #2D5F5D; font-size: 11px;
      letter-spacing: 0.15em; margin-bottom: 24px;
    }
    .hero h1 {
      font-family: "Shippori Mincho", serif; font-weight: 500;
      font-size: 46px; line-height: 1.45; letter-spacing: 0.04em;
      margin-bottom: 24px;
    }
    .hero h1 .em { color: #2D5F5D; }
    .hero .lead {
      font-size: 16px; color: #44403C; line-height: 2;
      max-width: 640px; margin: 0 auto 40px;
    }
    .hero .cta-row { display: flex; gap: 12px; justify-content: center; flex-wrap: wrap; }
    .btn-primary {
      background: #1C1917; color: white;
      padding: 14px 32px; border-radius: 8px; font-size: 14px; font-weight: 500;
      letter-spacing: 0.1em; transition: opacity 0.15s, transform 0.1s;
      display: inline-flex; align-items: center; gap: 8px;
    }
    .btn-primary:hover { color: white; opacity: 0.9; }
    .btn-primary:active { transform: scale(0.99); }
    .btn-secondary {
      background: white; color: #1C1917;
      padding: 14px 32px; border-radius: 8px; font-size: 14px; font-weight: 500;
      letter-spacing: 0.1em; border: 1px solid #D6D3D1;
      transition: border-color 0.15s;
    }
    .btn-secondary:hover { border-color: #1C1917; }
    .hero-note { font-size: 12px; color: #78716C; margin-top: 18px; letter-spacing: 0.05em; }

    /* Hero price banner */
    .hero-price {
      display: inline-flex; flex-direction: column; align-items: center;
      margin: 28px 0 40px;
      padding: 16px 44px;
      background: #2D5F5D; color: white;
      border-radius: 14px;
      box-shadow: 0 12px 32px -10px rgba(45, 95, 93, 0.45);
    }
    .hero-price-label {
      font-size: 11px; letter-spacing: 0.25em;
      margin-bottom: 4px; opacity: 0.85; font-weight: 500;
    }
    .hero-price-value {
      display: flex; align-items: baseline; gap: 4px;
    }
    .hero-price-num {
      font-family: "Shippori Mincho", serif;
      font-size: 52px; font-weight: 700;
      letter-spacing: 0.02em; line-height: 1.1;
    }
    .hero-price-yen { font-size: 20px; font-weight: 500; }
    .hero-price-tax {
      font-size: 10px; letter-spacing: 0.15em;
      margin-left: 6px; opacity: 0.7; font-weight: 500;
    }
    @media (max-width: 720px) {
      .hero-price { padding: 14px 32px; }
      .hero-price-num { font-size: 42px; }
    }
    @media (max-width: 720px) {
      .hero { padding: 56px 0 64px; }
      .hero h1 { font-size: 30px; }
    }

    /* ============ Hero illustration: スマホ風アニメーション ============ */
    .hero-visual {
      max-width: 280px; margin: 56px auto 0;
      background: #1C1917; padding: 12px; border-radius: 32px;
      box-shadow: 0 30px 60px -20px rgba(28, 25, 23, 0.25);
    }
    .hero-screen {
      position: relative;
      background: white; border-radius: 22px;
      aspect-ratio: 9 / 16; overflow: hidden;
    }
    /* 各画面（質問 / Google誘導）を重ねて切り替える */
    .demo-slide {
      position: absolute; inset: 0;
      padding: 28px 22px; text-align: center;
      display: flex; flex-direction: column; justify-content: space-between;
    }
    .demo-slide-1 { animation: slide1 9s infinite; }
    .demo-slide-2 { animation: slide2 9s infinite; }

    /* 0-5秒:画面1表示 → 5-5.5秒:切替 → 5.5-8.5秒:画面2 → 8.5-9秒:戻る */
    @keyframes slide1 {
      0%, 52% { opacity: 1; transform: translateX(0); }
      57%, 95% { opacity: 0; transform: translateX(-12%); }
      100% { opacity: 1; transform: translateX(0); }
    }
    @keyframes slide2 {
      0%, 52% { opacity: 0; transform: translateX(12%); }
      57%, 95% { opacity: 1; transform: translateX(0); }
      100% { opacity: 0; transform: translateX(12%); }
    }

    .hero-screen .mini-heading {
      font-family: "Shippori Mincho", serif; font-size: 17px;
      line-height: 1.5; margin-bottom: 16px;
    }
    .hero-screen .mini-q {
      font-size: 11px; color: #44403C; line-height: 1.7; margin-bottom: 16px;
    }
    .hero-screen .mini-options { display: flex; flex-direction: column; gap: 6px; }
    .hero-screen .mini-opt {
      padding: 10px; border: 1px solid #E7E5E4; border-radius: 6px;
      font-size: 11px; text-align: left; display: flex; align-items: center; gap: 8px;
      background: white; color: #1C1917;
      transition: none;
    }
    .hero-screen .mini-opt .dot {
      width: 10px; height: 10px; border-radius: 50%;
      border: 2px solid #D6D3D1; flex-shrink: 0;
    }
    /* 「非常に満足」が選択されるアニメーション */
    .mini-opt.opt-target { animation: optSelect 9s infinite; }
    .mini-opt.opt-target .dot { animation: dotSelect 9s infinite; }
    @keyframes optSelect {
      0%, 16% { background: white; color: #1C1917; border-color: #E7E5E4; }
      20%, 100% { background: #2D5F5D; color: white; border-color: transparent; }
    }
    @keyframes dotSelect {
      0%, 16% { border-color: #D6D3D1; background: transparent; }
      20%, 100% { border-color: white; background: white; }
    }

    .hero-screen .mini-btn {
      background: #1C1917; color: white; font-size: 11px; padding: 10px;
      border-radius: 6px; margin-top: 14px;
    }
    /* 「次へ」ボタンが押される動き */
    .mini-btn.btn-anim { animation: btnTap 9s infinite; }
    @keyframes btnTap {
      0%, 38% { transform: scale(1); background: #1C1917; }
      42% { transform: scale(0.94); background: #2D5F5D; }
      46%, 100% { transform: scale(1); background: #1C1917; }
    }

    /* 指カーソル */
    .demo-finger {
      position: absolute; width: 26px; height: 26px;
      z-index: 10; pointer-events: none;
      left: 50%; top: 50%;
      animation: fingerMove 9s infinite;
    }
    .demo-finger svg { width: 100%; height: 100%; filter: drop-shadow(0 2px 3px rgba(0,0,0,0.25)); }
    /* 指の移動: 選択肢へ → タップ → 次へボタンへ → タップ → 退場 */
    @keyframes fingerMove {
      0%      { left: 78%; top: 88%; opacity: 0; transform: scale(1); }
      6%      { left: 78%; top: 88%; opacity: 1; transform: scale(1); }
      14%     { left: 42%; top: 40%; opacity: 1; transform: scale(1); }
      17%     { left: 42%; top: 40%; opacity: 1; transform: scale(0.82); }
      20%     { left: 42%; top: 40%; opacity: 1; transform: scale(1); }
      34%     { left: 50%; top: 86%; opacity: 1; transform: scale(1); }
      40%     { left: 50%; top: 86%; opacity: 1; transform: scale(0.82); }
      44%     { left: 50%; top: 86%; opacity: 1; transform: scale(1); }
      50%     { left: 70%; top: 96%; opacity: 0; transform: scale(1); }
      100%    { left: 70%; top: 96%; opacity: 0; transform: scale(1); }
    }

    /* Google誘導画面 */
    .demo-google-icon {
      width: 44px; height: 44px; border-radius: 50%;
      background: #E8EEEC; display: flex; align-items: center; justify-content: center;
      margin: 0 auto 14px;
    }
    .demo-google-title {
      font-family: "Shippori Mincho", serif; font-size: 15px;
      margin-bottom: 8px;
    }
    .demo-google-text {
      font-size: 10px; color: #44403C; line-height: 1.7; margin-bottom: 16px;
    }
    .demo-google-btn {
      border: 1px solid #dadce0; border-radius: 6px;
      font-size: 10px; padding: 10px; color: #3c4043;
      display: flex; align-items: center; justify-content: center; gap: 6px;
    }
    .demo-stars {
      display: flex; justify-content: center; gap: 3px; margin: 4px 0 14px;
    }
    .demo-stars svg { width: 16px; height: 16px; }

    @media (prefers-reduced-motion: reduce) {
      .demo-slide-1, .demo-slide-2, .mini-opt.opt-target,
      .mini-opt.opt-target .dot, .mini-btn.btn-anim, .demo-finger {
        animation: none;
      }
      .demo-slide-2 { display: none; }
      .mini-opt.opt-target { background: #2D5F5D; color: white; border-color: transparent; }
      .mini-opt.opt-target .dot { border-color: white; background: white; }
      .demo-finger { opacity: 0; }
    }


    /* ============ Problem Section ============ */
    .problem { background: white; }
    .problem-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 32px; }
    @media (max-width: 720px) { .problem-grid { grid-template-columns: 1fr; gap: 20px; } }
    .problem-card {
      padding: 32px 28px; background: #F6F3EC; border-radius: 12px;
    }
    .problem-card .num {
      font-family: "Shippori Mincho", serif; font-size: 28px; color: #2D5F5D; margin-bottom: 12px;
    }
    .problem-card h3 {
      font-size: 16px; font-weight: 700; margin-bottom: 10px; line-height: 1.6;
    }
    .problem-card p { font-size: 13px; color: #57534E; line-height: 1.85; }

    /* ============ Solution Section ============ */
    .solution { background: #F6F3EC; }
    .solution-flow {
      display: grid; grid-template-columns: 1fr auto 1fr auto 1fr; gap: 20px;
      align-items: stretch; max-width: 920px; margin: 0 auto;
    }
    @media (max-width: 720px) { .solution-flow { grid-template-columns: 1fr; } }
    .flow-step {
      background: white; border-radius: 12px; padding: 32px 24px; text-align: center;
      border: 1px solid #E7E5E4;
    }
    .flow-step .step-num {
      display: inline-flex; align-items: center; justify-content: center;
      width: 32px; height: 32px; border-radius: 50%; background: #2D5F5D;
      color: white; font-family: "Shippori Mincho", serif; font-size: 14px;
      margin-bottom: 16px;
    }
    .flow-step h4 { font-size: 15px; font-weight: 700; margin-bottom: 10px; }
    .flow-step p { font-size: 12px; color: #57534E; line-height: 1.7; }
    .flow-arrow {
      align-self: center; color: #2D5F5D; font-size: 20px;
    }
    @media (max-width: 720px) {
      .flow-arrow { transform: rotate(90deg); margin: 0 auto; }
    }

    /* ============ Features ============ */
    .features { background: white; }
    .features-grid {
      display: grid; grid-template-columns: repeat(2, 1fr); gap: 32px;
    }
    @media (max-width: 720px) { .features-grid { grid-template-columns: 1fr; gap: 20px; } }
    .feature-card {
      padding: 28px;
    }
    .feature-card .icon {
      width: 44px; height: 44px; background: #EAF1EF; border-radius: 10px;
      display: flex; align-items: center; justify-content: center;
      margin-bottom: 20px;
    }
    .feature-card .icon svg { width: 20px; height: 20px; stroke: #2D5F5D; }
    .feature-card h4 { font-size: 16px; font-weight: 700; margin-bottom: 10px; }
    .feature-card p { font-size: 13px; color: #57534E; line-height: 1.85; }

    /* ============ Comparison Table ============ */
    .compare { background: #F6F3EC; }
    .compare-table {
      max-width: 760px; margin: 0 auto; background: white;
      border-radius: 12px; overflow: hidden;
      border: 1px solid #E7E5E4;
    }
    .compare-row {
      display: grid; grid-template-columns: 1.4fr 1fr 1fr;
      border-bottom: 1px solid #E7E5E4; font-size: 13px;
    }
    .compare-row:last-child { border-bottom: none; }
    .compare-row.head {
      background: #1C1917; color: white; font-size: 12px;
      letter-spacing: 0.1em; font-weight: 500;
    }
    .compare-row.head .ours { background: #2D5F5D; }
    .compare-cell { padding: 16px 20px; display: flex; align-items: center; }
    .compare-cell.label { color: #44403C; font-weight: 500; background: #FAF8F2; }
    .compare-cell.ours { background: #F0F6F4; font-weight: 500; }
    .compare-cell.center { justify-content: center; text-align: center; }
    .compare-check { color: #2D5F5D; font-weight: 700; }
    .compare-cross { color: #B4272B; }

    /* ============ Pricing ============ */
    .pricing { background: white; }
    .pricing-grid {
      max-width: 380px; margin: 0 auto;
    }
    .price-card {
      background: white; border: 1px solid #E7E5E4; border-radius: 12px;
      padding: 36px 32px; display: flex; flex-direction: column;
    }
    .price-card.featured {
      border: 2px solid #2D5F5D; position: relative;
    }
    .price-card .recommend-badge {
      position: absolute; top: -12px; left: 50%; transform: translateX(-50%);
      background: #2D5F5D; color: white; font-size: 11px;
      padding: 4px 16px; border-radius: 100px; letter-spacing: 0.1em; font-weight: 500;
    }
    .price-card .plan-name {
      font-family: "Shippori Mincho", serif; font-size: 22px;
      margin-bottom: 6px;
    }
    .price-card .plan-target {
      font-size: 12px; color: #78716C; margin-bottom: 24px; letter-spacing: 0.03em;
    }
    .price-card .price {
      display: flex; align-items: baseline; gap: 4px; margin-bottom: 6px;
    }
    .price-card .price .num {
      font-size: 38px; font-weight: 700; line-height: 1; letter-spacing: -0.02em;
    }
    .price-card .price .yen { font-size: 18px; }
    .price-card .price-suffix { font-size: 12px; color: #78716C; margin-bottom: 28px; }
    .price-card .price-tax { font-size: 11px; color: #A8A29E; }
    .price-card .price-custom {
      font-family: "Shippori Mincho", serif;
      font-size: 24px; font-weight: 500;
      letter-spacing: 0.04em; line-height: 1.3;
      margin-bottom: 6px;
    }
    .price-card ul {
      list-style: none; margin-bottom: 28px; flex-grow: 1;
    }
    .price-card ul li {
      font-size: 13px; padding: 8px 0 8px 24px; position: relative;
      color: #44403C;
    }
    .price-card ul li::before {
      content: ""; position: absolute; left: 0; top: 14px;
      width: 12px; height: 7px; border-left: 2px solid #2D5F5D; border-bottom: 2px solid #2D5F5D;
      transform: rotate(-45deg);
    }
    .price-card .plan-cta {
      display: block; text-align: center; padding: 12px;
      background: white; color: #1C1917; border: 1px solid #1C1917;
      border-radius: 8px; font-size: 14px; font-weight: 500;
      transition: all 0.15s; letter-spacing: 0.05em;
    }
    .price-card.featured .plan-cta { background: #1C1917; color: white; }
    .price-card .plan-cta:hover { opacity: 0.85; }

    .pricing-note {
      max-width: 760px; margin: 32px auto 0;
      text-align: center; font-size: 12px; color: #78716C; line-height: 1.9;
    }

    /* ============ FAQ ============ */
    .faq { background: #F6F3EC; }
    .faq-list { max-width: 760px; margin: 0 auto; }
    .faq-item {
      background: white; border-radius: 10px; margin-bottom: 12px;
      overflow: hidden; border: 1px solid #E7E5E4;
    }
    .faq-q {
      padding: 20px 24px; cursor: pointer; display: flex;
      align-items: flex-start; gap: 14px; font-weight: 500; font-size: 14px;
      list-style: none;
    }
    .faq-q::-webkit-details-marker { display: none; }
    .faq-q::before {
      content: "Q"; flex-shrink: 0;
      font-family: "Shippori Mincho", serif; color: #2D5F5D;
      font-size: 16px; font-weight: 500;
    }
    .faq-q::after {
      content: ""; flex-shrink: 0; margin-left: auto;
      width: 8px; height: 8px;
      border-right: 2px solid #78716C; border-bottom: 2px solid #78716C;
      transform: rotate(45deg) translateY(-2px);
      transition: transform 0.2s;
    }
    details[open] .faq-q::after { transform: rotate(-135deg) translateY(2px); }
    .faq-a {
      padding: 0 24px 22px 56px; font-size: 13px; color: #57534E; line-height: 1.9;
    }

    /* ============ Final CTA ============ */
    .final-cta {
      background: #1C1917; color: white; text-align: center;
    }
    .final-cta h2 {
      font-family: "Shippori Mincho", serif; font-size: 32px;
      letter-spacing: 0.04em; line-height: 1.5; margin-bottom: 20px;
    }
    @media (max-width: 720px) { .final-cta h2 { font-size: 22px; } }
    .final-cta p {
      color: #D6D3D1; font-size: 14px; margin-bottom: 36px; line-height: 1.9;
    }
    .final-cta .btn-primary {
      background: white; color: #1C1917;
    }
    .final-cta .btn-primary:hover { color: #1C1917; }

    /* ============ Footer ============ */
    .footer {
      background: #1C1917; color: #A8A29E; padding: 48px 0 32px;
      border-top: 1px solid rgba(255, 255, 255, 0.08);
    }
    .footer-inner {
      max-width: 1080px; margin: 0 auto; padding: 0 24px;
      display: flex; justify-content: space-between; align-items: center; flex-wrap: wrap; gap: 20px;
    }
    .footer .logo { color: white; }
    .footer-links { display: flex; gap: 24px; font-size: 12px; }
    .footer-links a:hover { color: white; }
    .footer-copy { font-size: 11px; color: #78716C; margin-top: 16px; text-align: center; width: 100%; }