/* Styles extracted from the top page to unify design across the site */
:root{
      --ink:#10243f;
      --ink-soft:#2d405c;
      --muted:#687588;
      --line:rgba(16,36,63,.14);
      --line-soft:rgba(16,36,63,.08);
      --paper:#ffffff;
      --warm:#f7f4ed;
      --warm-2:#fbfaf6;
      --beige:#c7aa78;
      --shadow:0 28px 80px rgba(16,36,63,.08);
      --radius:999px;
      --serif:"Yu Mincho","Hiragino Mincho ProN","Noto Serif JP",serif;
      --sans:-apple-system,BlinkMacSystemFont,"Hiragino Sans","Yu Gothic",Meiryo,sans-serif;
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
      margin:0;
      color:var(--ink);
      background:var(--paper);
      font-family:var(--sans);
      line-height:1.95;
      letter-spacing:.04em;
      -webkit-font-smoothing:antialiased;
      text-rendering:optimizeLegibility;
}
a{color:inherit;text-decoration:none}
img,svg{display:block;max-width:100%}
::selection{background:rgba(199,170,120,.25)}

.site{
      overflow:hidden;
      background:
        radial-gradient(circle at 82% 6%, rgba(199,170,120,.10), transparent 26rem),
        linear-gradient(180deg,#fff 0%,#fff 72%,#fbfaf6 100%);
}

.container{
      width:min(1120px,calc(100% - 40px));
      margin-inline:auto;
}

.header{
      position:sticky;
      top:0;
      z-index:20;
      background:rgba(255,255,255,.84);
      backdrop-filter:blur(18px);
      border-bottom:1px solid var(--line-soft);
}
.header-inner{
      width:min(1120px,calc(100% - 40px));
      margin-inline:auto;
      min-height:78px;
      display:flex;
      align-items:center;
      justify-content:space-between;
      gap:28px;
}
.brand{
      display:flex;
      flex-direction:column;
      line-height:1.25;
      letter-spacing:.12em;
      white-space:nowrap;
}
.brand-main{
      font-family:var(--serif);
      font-size:15px;
      font-weight:600;
}
.brand-sub{
      margin-top:5px;
      color:var(--muted);
      font-size:11px;
      letter-spacing:.08em;
}
.nav{
      display:flex;
      align-items:center;
      gap:28px;
      font-size:13px;
      color:var(--ink-soft);
}
.nav a{transition:opacity .2s ease, transform .2s ease}
.nav a:hover{opacity:.66;transform:translateY(-1px)}
.nav-cta{
      display:inline-flex;
      align-items:center;
      justify-content:center;
      min-height:40px;
      padding:0 19px;
      color:#fff!important;
      background:var(--ink);
      border-radius:var(--radius);
      box-shadow:0 12px 30px rgba(16,36,63,.16);
}

/* Hamburger menu toggle button */
.nav-toggle{
      display:none;
      cursor:pointer;
      background:none;
      border:none;
      padding:8px;
}
.nav-toggle:focus{
      outline:none;
}
.nav-toggle .bar{
      display:block;
      width:20px;
      height:2px;
      background:var(--ink);
      margin:4px 0;
      transition:transform .3s ease;
}

/* Mobile navigation styles */
@media (max-width: 920px){
      .nav{
            display:none;
            position:absolute;
            right:20px;
            top:70px;
            flex-direction:column;
            align-items:flex-start;
            gap:18px;
            background:rgba(255,255,255,.96);
            padding:20px 24px;
            border-radius:12px;
            box-shadow:0 12px 30px rgba(16,36,63,.16);
            z-index:30;
      }
      .nav.open{
            display:flex;
      }
      .nav-toggle{
            display:block;
      }
      /* Hide CTA inside collapsed menu; show last */
      .nav a.nav-cta{
            margin-top:12px;
      }
}

.hero{
      position:relative;
      padding:94px 0 116px;
}
.hero-grid{
      display:grid;
      grid-template-columns:minmax(0,1.02fr) minmax(360px,.98fr);
      gap:72px;
      align-items:center;
}
.eyebrow{
      display:inline-flex;
      align-items:center;
      gap:14px;
      color:var(--muted);
      font-size:12px;
      letter-spacing:.16em;
      text-transform:uppercase;
}
.eyebrow::before{
      content:"";
      width:42px;
      height:1px;
      background:var(--beige);
}
h1,h2,h3,p{margin:0}
h1{
      margin-top:28px;
      font-family:var(--serif);
      font-size:clamp(35px,5vw,64px);
      line-height:1.52;
      font-weight:500;
      letter-spacing:.09em;
}
.lead{
      margin-top:28px;
      max-width:640px;
      color:var(--ink-soft);
      font-size:15.5px;
      line-height:2.25;
}
.support{
      margin-top:28px;
      max-width:580px;
      color:var(--muted);
      font-size:14px;
      line-height:2.15;
}
.actions{
      margin-top:42px;
      display:flex;
      flex-wrap:wrap;
      gap:16px;
}
.button{
      display:inline-flex;
      align-items:center;
      justify-content:center;
      gap:14px;
      min-height:48px;
      padding:0 23px;
      border-radius:var(--radius);
      border:1px solid var(--line);
      font-size:13px;
      letter-spacing:.08em;
      transition:transform .2s ease, box-shadow .2s ease, opacity .2s ease;
}
.button::after{content:"›";font-size:20px;line-height:1;transform:translateY(-1px)}
.button:hover{transform:translateY(-2px);box-shadow:0 16px 36px rgba(16,36,63,.10)}
.button-primary{background:var(--ink);border-color:var(--ink);color:#fff;box-shadow:0 18px 42px rgba(16,36,63,.18)}
.button-ghost{background:rgba(255,255,255,.56);color:var(--ink)}

.visual{
      position:relative;
      min-height:520px;
}
.desk{
      position:absolute;
      inset:18px 0 0 0;
      border-radius:36px 0 0 36px;
      background:
        linear-gradient(135deg, rgba(255,255,255,.8), rgba(247,244,237,.72)),
        radial-gradient(circle at 28% 34%, rgba(199,170,120,.16), transparent 18rem),
        linear-gradient(160deg,#fff,#f7f4ed);
      box-shadow:var(--shadow);
      overflow:hidden;
}
.desk::before{
      content:"";
      position:absolute;
      inset:0;
      background:
        linear-gradient(rgba(16,36,63,.045) 1px, transparent 1px),
        linear-gradient(90deg, rgba(16,36,63,.035) 1px, transparent 1px);
      background-size:44px 44px;
      mask-image:linear-gradient(120deg,transparent 0%,#000 18%,#000 72%,transparent 100%);
      opacity:.5;
}
.paper{
      position:absolute;
      left:10%;
      bottom:13%;
      width:58%;
      height:43%;
      border:1px solid rgba(16,36,63,.11);
      background:rgba(255,255,255,.82);
      border-radius:3px;
      transform:rotate(-3deg);
      box-shadow:0 22px 60px rgba(16,36,63,.08);
}
.paper::before,.paper::after{
      content:"";
      position:absolute;
      left:9%;
      right:9%;
      height:1px;
      background:rgba(16,36,63,.10);
}
.paper::before{top:30%}
.paper::after{top:48%;box-shadow:0 36px 0 rgba(16,36,63,.10),0 72px 0 rgba(16,36,63,.08)}
.notebook{
      position:absolute;
      left:19%;
      bottom:22%;
      width:46%;
      height:24%;
      background:#f3efe5;
      border:1px solid rgba(16,36,63,.10);
      border-radius:5px;
      transform:rotate(4deg);
      box-shadow:0 18px 44px rgba(16,36,63,.10);
}
.notebook::before{
      content:"";
      position:absolute;
      left:0;
      top:0;
      bottom:0;
      width:18px;
      background:repeating-linear-gradient(180deg,rgba(16,36,63,.22) 0 2px,transparent 2px 11px);
      opacity:.6;
}
.laptop{
      position:absolute;
      right:-7%;
      bottom:16%;
      width:35%;
      height:38%;
      border-radius:10px;
      background:linear-gradient(145deg,#26364f,#0d1b2d);
      box-shadow:0 28px 70px rgba(16,36,63,.20);
      transform:rotate(1deg);
}
.laptop::after{
      content:"";
      position:absolute;
      left:-16%;
      right:4%;
      bottom:-18%;
      height:16%;
      background:#d9dce1;
      border-radius:0 0 14px 14px;
      transform:skewX(-16deg);
}
.cup{
      position:absolute;
      right:28%;
      top:28%;
      width:82px;
      height:64px;
      border-radius:0 0 34px 34px;
      background:linear-gradient(180deg,#ded6c8,#f3efe5);
      box-shadow:0 18px 42px rgba(16,36,63,.12);
}
.cup::before{
      content:"";
      position:absolute;
      inset:-10px 0 auto;
      height:20px;
      border-radius:50%;
      background:#f6f1e7;
      border:1px solid rgba(16,36,63,.08);
}
.branch{
      position:absolute;
      right:37%;
      top:6%;
      width:160px;
      height:210px;
      opacity:.84;
}
.branch svg{width:100%;height:100%}
.hero-curve{
      position:absolute;
      left:-5vw;
      right:-5vw;
      bottom:-1px;
      height:86px;
      border-top:1px solid var(--line-soft);
      border-radius:50% 50% 0 0 / 100% 100% 0 0;
      background:linear-gradient(180deg,rgba(255,255,255,0),#fff 68%);
      pointer-events:none;
}

.section{padding:98px 0;border-top:1px solid var(--line-soft)}
.section:first-of-type{border-top:0}
.narrow{max-width:820px;margin-inline:auto}
.section-title{
      font-family:var(--serif);
      font-size:clamp(25px,3.1vw,39px);
      line-height:1.75;
      font-weight:500;
      letter-spacing:.08em;
}
.section-text{
      margin-top:22px;
      color:var(--ink-soft);
      font-size:15px;
      line-height:2.25;
}
.soft-note{
      color:var(--muted);
      font-size:13.5px;
      line-height:2.1;
}

.editorial{
      position:relative;
      display:grid;
      grid-template-columns:.78fr 1fr;
      gap:72px;
      align-items:center;
}
.line-drawing{
      position:relative;
      min-height:260px;
}
.line-drawing::before{
      content:"";
      position:absolute;
      left:-18%;
      bottom:24px;
      width:82%;
      height:34%;
      background:var(--warm);
      border-radius:52% 48% 0 0;
      opacity:.9;
}
.line-drawing svg{
      position:absolute;
      left:14%;
      bottom:40px;
      width:170px;
      color:rgba(16,36,63,.58);
}

.flow{
      display:grid;
      grid-template-columns:.78fr 1.25fr;
      gap:68px;
      align-items:start;
}
.steps{
      position:relative;
      display:grid;
      grid-template-columns:repeat(3,1fr);
      gap:0;
      border-top:1px solid var(--line);
      border-bottom:1px solid var(--line);
}
.step{
      position:relative;
      padding:34px 28px 32px;
      min-height:190px;
}
.step + .step{border-left:1px solid var(--line-soft)}
.num{
      display:block;
      color:var(--beige);
      font-family:var(--serif);
      font-size:30px;
      font-style:italic;
      line-height:1;
      letter-spacing:.02em;
}
.step-title{
      margin-top:18px;
      font-family:var(--serif);
      font-size:18px;
      font-weight:500;
      letter-spacing:.08em;
}
.step p{margin-top:13px;color:var(--muted);font-size:13px;line-height:2}

.service{
      background:
        radial-gradient(circle at 96% 42%, rgba(199,170,120,.12), transparent 24rem),
        linear-gradient(180deg,#fbfaf6,#fff);
}
.service-layout{
      display:grid;
      grid-template-columns:1.08fr .72fr;
      gap:76px;
      align-items:start;
}
.underbar::after{
      content:"";
      display:block;
      width:46px;
      height:1px;
      margin-top:16px;
      background:var(--beige);
}
.slash-list{
      margin-top:34px;
      color:var(--ink-soft);
      font-size:14px;
      line-height:2.35;
}
.price{
      position:relative;
      padding:8px 0 0 42px;
      border-left:1px solid var(--line);
}
.price-title{
      font-family:var(--serif);
      font-size:30px;
      font-weight:500;
}
.price-block{margin-top:28px;padding-bottom:24px;border-bottom:1px solid var(--line)}
.price-block:last-of-type{border-bottom:0;padding-bottom:0}
.price-label{color:var(--muted);font-size:13px;letter-spacing:.08em}
.amount{
      margin-top:3px;
      font-family:var(--serif);
      font-size:clamp(42px,5vw,64px);
      line-height:1.2;
      letter-spacing:.04em;
}
.amount small{font-family:var(--sans);font-size:16px;letter-spacing:.04em}
.price-intro{margin-top:22px;color:var(--ink-soft);font-size:13.5px;line-height:2.05}
.price-name{margin-top:6px;font-family:var(--serif);font-size:20px;letter-spacing:.08em}
.price-note{margin-top:22px;color:var(--muted);font-size:12.5px;line-height:2.05}
.price-block .price-note{margin-top:12px}

.note-band{
      padding:74px 0;
      border-top:1px solid var(--line-soft);
      border-bottom:1px solid var(--line-soft);
      background:#fff;
}

/* === Additional spacing adjustments and responsive elements === */
/* Ensure hero paragraphs have breathing room */
.hero h1 + p,
.hero p + p {
  margin-top: 24px;
}
/* Provide spacing between consecutive paragraphs and lists within sections */
.section .container > p + p,
.section .container > ul,
.section .container > div + div {
  margin-top: 24px;
}
.section ul {
  margin-top: 16px;
  padding-left: 1.2em;
  line-height: 2;
}
.section ul li {
  margin-bottom: 6px;
}
/* Make steps layout flexible to accommodate four steps */
.steps {
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
}
.note-layout{
      display:grid;
      grid-template-columns:180px 1fr;
      gap:56px;
      align-items:center;
}
.round-visual{
      width:150px;
      aspect-ratio:1;
      border-radius:50%;
      background:
        radial-gradient(circle at 30% 22%, rgba(118,137,110,.22), transparent 28%),
        linear-gradient(145deg,#fff,#efe9dd);
      box-shadow:0 22px 54px rgba(16,36,63,.08);
      position:relative;
      overflow:hidden;
}
.round-visual::before{
      content:"";
      position:absolute;
      left:30px;
      right:24px;
      bottom:38px;
      height:16px;
      background:#d7c9b4;
      border-radius:20px;
      box-shadow:0 -18px 0 #f7f3eb,0 -36px 0 #fff;
}
.round-visual::after{
      content:"";
      position:absolute;
      right:32px;
      bottom:52px;
      width:42px;
      height:32px;
      border-radius:0 0 18px 18px;
      background:#f5efe4;
      border:1px solid rgba(16,36,63,.08);
}
.text-link{
      display:inline-flex;
      align-items:center;
      gap:10px;
      margin-top:16px;
      color:var(--ink);
      border-bottom:1px solid rgba(16,36,63,.32);
      font-size:14px;
      line-height:1.6;
}
.text-link::after{content:"→"}

.final{
      padding:90px 0 96px;
      background:
        linear-gradient(130deg,rgba(247,244,237,.88),rgba(255,255,255,.94) 44%,#fff),
        radial-gradient(circle at 8% 10%,rgba(199,170,120,.12),transparent 22rem);
}
.final-layout{
      display:grid;
      grid-template-columns:1fr auto;
      gap:50px;
      align-items:center;
}
.final-actions{display:flex;gap:16px;flex-wrap:wrap;justify-content:flex-end}

.footer{
      border-top:1px solid var(--line-soft);
      padding:34px 0;
      background:#fff;
}
.footer-inner{
      display:grid;
      grid-template-columns:auto 1fr;
      gap:34px;
      align-items:end;
}
.footer-links{
      display:flex;
      flex-wrap:wrap;
      justify-content:flex-end;
      gap:10px 18px;
      color:var(--muted);
      font-size:12px;
}
.footer-links a + a::before{
      content:"";
      display:inline-block;
      width:1px;
      height:12px;
      margin-right:18px;
      background:var(--line);
      vertical-align:-2px;
}

@media (max-width: 920px){
      .nav a:not(.nav-cta){display:none}
      .nav.open a{display:inline-flex}
      .hero{padding:64px 0 86px}
      .hero-grid,.editorial,.flow,.service-layout,.final-layout{grid-template-columns:1fr;gap:42px}
      .visual{min-height:380px;order:-1}
      .desk{border-radius:28px}
      .steps{grid-template-columns:1fr}
      .step + .step{border-left:0;border-top:1px solid var(--line-soft)}
      .price{padding-left:0;border-left:0;border-top:1px solid var(--line);padding-top:34px}
      .note-layout{grid-template-columns:1fr;gap:28px}
      .final-actions{justify-content:flex-start}
      .footer-inner{grid-template-columns:1fr;align-items:start}
      .footer-links{justify-content:flex-start}
}

@media (max-width: 620px){
      .container,.header-inner{width:min(100% - 28px,1120px)}
      .header-inner{min-height:68px}
      .brand-main{font-size:13px}
      .nav-cta{min-height:36px;padding:0 14px;font-size:12px}
      h1{font-size:33px;letter-spacing:.06em}
      .lead{font-size:14.5px;line-height:2.1}
      .actions,.final-actions{display:grid;grid-template-columns:1fr;width:100%}
      .button{width:100%}
      .section{padding:72px 0}
      .visual{min-height:310px}
      .branch{right:42%;width:120px;height:170px}
      .cup{right:25%;width:64px;height:50px}
      .laptop{width:36%;right:-10%}
      .amount{font-size:44px}
      .footer-links a + a::before{display:none}
}
