:root{
  --bg:#f7f6f3;
  --paper:#ffffff;
  --ink:#151515;
  --muted:#6c6a66;
  --line:#d9d3c8;
  --navy:#0d2b4f;
  --navy-2:#061a31;
  --accent:#c5a56a;
  --soft:#ede8df;
  --shadow:0 18px 60px rgba(13,43,79,.10);
  --radius:24px;
  --serif: "Times New Roman", "Yu Mincho", "Hiragino Mincho ProN", serif;
  --sans: -apple-system, BlinkMacSystemFont, "Helvetica Neue", "Yu Gothic", "YuGothic", "Noto Sans JP", sans-serif;
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  color:var(--ink);
  background:
    linear-gradient(90deg, rgba(13,43,79,.08) 0 1px, transparent 1px) calc(50% - 232px) 0 / 1px 100% no-repeat,
    var(--bg);
  font-family:var(--sans);
  line-height:1.9;
  letter-spacing:.04em;
  overflow-x:hidden;
}

a{color:inherit;text-decoration:none}
img,svg{max-width:100%;display:block}
button,input,textarea,select{font:inherit}
::selection{background:rgba(197,165,106,.35)}

.skip-link{
  position:absolute;
  top:-100px;
  left:1rem;
  padding:.75rem 1rem;
  background:#fff;
  color:#000;
  z-index:100;
}
.skip-link:focus{top:1rem}

.site-header{
  position:fixed;
  top:0;
  left:0;
  width:100%;
  height:74px;
  display:flex;
  align-items:center;
  justify-content:space-between;
  padding:0 clamp(18px,4vw,54px);
  z-index:50;
  backdrop-filter:blur(14px);
  background:rgba(247,246,243,.76);
  border-bottom:1px solid rgba(13,43,79,.08);
}

.brand{
  display:flex;
  align-items:center;
  gap:11px;
  line-height:1.1;
}

.brand__mark{
  display:grid;
  place-items:center;
  width:38px;
  height:38px;
  border:1px solid var(--navy);
  background:var(--navy);
  color:#fff;
  font-family:var(--serif);
  font-size:1.4rem;
}

.brand__text{
  font-size:.72rem;
  text-transform:uppercase;
  letter-spacing:.14em;
  color:var(--navy);
  font-weight:700;
}

.header-nav{
  display:flex;
  align-items:center;
  gap:clamp(14px,3vw,30px);
  font-size:.72rem;
  text-transform:uppercase;
  letter-spacing:.14em;
  color:var(--navy);
}

.nav-cta{
  border:1px solid var(--navy);
  padding:.55rem .8rem;
  border-radius:999px;
}

.section{
  position:relative;
  padding:clamp(76px,10vw,132px) 0;
}

.section__inner,
.hero__inner{
  width:min(100% - 34px, 1050px);
  margin-inline:auto;
  position:relative;
}

.section--hero{
  min-height:100vh;
  padding-top:120px;
  display:flex;
  align-items:center;
  overflow:hidden;
}

.section-number{
  display:flex;
  flex-direction:column;
  align-items:flex-end;
  gap:2px;
  color:var(--navy);
  font-family:var(--serif);
  line-height:1;
  margin-bottom:36px;
}

.section-number span{
  font-size:clamp(2rem,8vw,4.6rem);
  letter-spacing:.08em;
}

.section-number small{
  font-family:var(--sans);
  font-size:.68rem;
  letter-spacing:.18em;
}

.section-number--hero{
  position:absolute;
  top:-52px;
  right:0;
  margin:0;
}

.eyebrow{
  margin:0 0 16px;
  color:var(--navy);
  font-size:.74rem;
  letter-spacing:.22em;
  text-transform:uppercase;
  font-weight:700;
}

.hero__bg-word{
  position:absolute;
  top:18%;
  left:50%;
  transform:translateX(-50%);
  font-family:var(--serif);
  font-size:clamp(4rem,18vw,13rem);
  color:rgba(13,43,79,.045);
  white-space:nowrap;
  letter-spacing:.08em;
  pointer-events:none;
  animation:slowSlide 18s linear infinite alternate;
}

.hero__title,
.section-title{
  margin:0;
  font-family:var(--serif);
  font-weight:400;
  line-height:1.18;
  letter-spacing:.08em;
}

.hero__title{
  font-size:clamp(3.05rem,10vw,8.2rem);
  max-width:850px;
}

.hero__title span{
  color:var(--navy);
}

.hero__lead{
  margin:28px 0 0;
  color:var(--navy);
  font-weight:700;
  font-size:clamp(1rem,2.1vw,1.42rem);
  line-height:1.9;
}

.hero__text,
.section-text{
  max-width:720px;
  margin:22px 0 0;
  color:#3b3a37;
  font-size:clamp(.95rem,1.4vw,1.05rem);
}

.hero__actions{
  display:flex;
  align-items:flex-start;
  flex-wrap:wrap;
  gap:14px 22px;
  margin-top:36px;
}

.hero__actions p{
  margin:0;
  color:var(--muted);
  font-size:.84rem;
}

.button{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-height:54px;
  padding:0 24px;
  border-radius:999px;
  border:1px solid transparent;
  font-weight:700;
  letter-spacing:.08em;
  line-height:1.4;
  transition:transform .25s ease, box-shadow .25s ease, background .25s ease;
  cursor:pointer;
}

.button:hover{
  transform:translateY(-2px);
  box-shadow:0 14px 32px rgba(13,43,79,.18);
}

.button--primary{
  background:var(--navy);
  color:#fff;
}

.button--light{
  background:#fff;
  color:var(--navy);
}

.hero-card{
  width:min(100%, 620px);
  margin-top:46px;
  border:1px solid rgba(13,43,79,.22);
  background:rgba(255,255,255,.72);
  backdrop-filter:blur(8px);
  box-shadow:var(--shadow);
  padding:20px;
  position:relative;
}

.hero-card::after,
.service-card::after,
.work-card::after{
  content:"";
  position:absolute;
  right:-1px;
  bottom:-1px;
  width:30px;
  height:30px;
  background:linear-gradient(135deg, transparent 0 48%, var(--navy) 50%);
}

.hero-card__label{
  color:var(--navy);
  font-family:var(--serif);
  letter-spacing:.14em;
  margin-bottom:14px;
}

.hero-card__grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:12px;
}

.hero-card__grid div{
  padding:12px;
  background:var(--soft);
}

.hero-card strong{
  display:block;
  color:var(--navy);
  font-family:var(--serif);
  font-size:1.4rem;
  line-height:1.2;
}

.hero-card span:not(.count){
  display:block;
  color:var(--muted);
  font-size:.76rem;
  line-height:1.5;
  margin-top:5px;
}

.mock-phone{
  position:absolute;
  right:0;
  bottom:-28px;
  width:min(34vw,330px);
  min-width:260px;
  padding:16px;
  border:1px solid rgba(13,43,79,.18);
  background:#fff;
  box-shadow:var(--shadow);
  border-radius:34px;
  transform:rotate(2deg);
}

.mock-phone__bar{
  width:72px;
  height:6px;
  border-radius:999px;
  background:var(--line);
  margin:0 auto 18px;
}

.mock-post{
  min-height:280px;
  background:
    linear-gradient(160deg, rgba(13,43,79,.95), rgba(13,43,79,.55)),
    radial-gradient(circle at 70% 20%, rgba(197,165,106,.9), transparent 32%),
    linear-gradient(135deg, #111, #666);
  color:#fff;
  padding:22px;
  display:flex;
  flex-direction:column;
  justify-content:flex-end;
  border-radius:24px;
  overflow:hidden;
  position:relative;
}

.mock-post::before{
  content:"";
  position:absolute;
  inset:16px;
  border:1px solid rgba(255,255,255,.35);
  border-radius:18px;
}

.mock-post__tag{
  display:inline-block;
  width:max-content;
  font-size:.62rem;
  letter-spacing:.18em;
  border:1px solid rgba(255,255,255,.55);
  padding:.3rem .55rem;
  margin-bottom:12px;
  z-index:1;
}

.mock-post strong{
  font-family:var(--serif);
  font-size:1.55rem;
  line-height:1.35;
  font-weight:400;
  z-index:1;
}

.mock-phone__cards{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:8px;
  margin-top:12px;
}

.mock-phone__cards span{
  display:grid;
  place-items:center;
  height:56px;
  border-radius:15px;
  background:var(--soft);
  color:var(--navy);
  font-size:.68rem;
  letter-spacing:.1em;
}

.scroll-cue{
  position:absolute;
  left:clamp(18px,4vw,54px);
  bottom:24px;
  writing-mode:vertical-rl;
  color:var(--navy);
  font-size:.66rem;
  letter-spacing:.22em;
}

.problem{
  background:#fff;
}

.check-panel{
  margin-top:38px;
  padding:clamp(24px,5vw,48px);
  background:var(--bg);
  border-left:3px solid var(--navy);
}

.check-panel h3{
  margin:0 0 18px;
  font-family:var(--serif);
  font-size:clamp(1.45rem,3vw,2.4rem);
  font-weight:400;
  color:var(--navy);
}

.check-list{
  list-style:none;
  margin:0;
  padding:0;
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:12px 22px;
}

.check-list li{
  position:relative;
  padding-left:22px;
}

.check-list li::before{
  content:"";
  position:absolute;
  left:0;
  top:.78em;
  width:8px;
  height:8px;
  background:var(--accent);
  transform:rotate(45deg);
}

.statement{
  overflow:hidden;
  background:var(--soft);
}

.marquee{
  position:absolute;
  top:28px;
  left:0;
  display:flex;
  gap:40px;
  white-space:nowrap;
  color:rgba(13,43,79,.08);
  font-family:var(--serif);
  font-size:clamp(3.5rem,10vw,9rem);
  letter-spacing:.08em;
  animation:marquee 32s linear infinite;
}

.statement-card{
  width:min(100%,760px);
  margin-left:auto;
  padding:clamp(30px,6vw,70px);
  background:#fff;
  box-shadow:var(--shadow);
  position:relative;
  z-index:1;
}

.statement-card h2{
  margin:0;
  font-family:var(--serif);
  font-weight:400;
  font-size:clamp(2rem,5vw,4.2rem);
  line-height:1.25;
}

.statement-card h2 span{
  color:var(--navy);
}

.statement-card p:last-child{
  margin:26px 0 0;
  color:#3b3a37;
}

.section-title{
  font-size:clamp(2.1rem,6vw,5.1rem);
}

.service-grid{
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:16px;
  margin-top:46px;
}

.service-card{
  position:relative;
  min-height:230px;
  padding:28px;
  border:1px solid rgba(13,43,79,.18);
  background:#fff;
  box-shadow:0 12px 40px rgba(13,43,79,.06);
}

.service-card span,
.target-card span,
.work-card span,
.flow-item span{
  display:inline-block;
  color:var(--accent);
  font-family:var(--serif);
  letter-spacing:.14em;
  margin-bottom:16px;
}

.service-card h3,
.target-card h3,
.reason-item h3,
.work-card h3,
.flow-item h3{
  margin:0 0 12px;
  color:var(--navy);
  font-family:var(--serif);
  font-weight:400;
  font-size:1.45rem;
  line-height:1.35;
}

.service-card p,
.target-card p,
.reason-item p,
.work-card p,
.flow-item p{
  margin:0;
  color:#494844;
  font-size:.92rem;
}

.target{
  background:#fff;
  overflow:hidden;
}

.target-slider{
  margin-top:42px;
  display:grid;
  grid-auto-flow:column;
  grid-auto-columns:minmax(270px,1fr);
  gap:16px;
  overflow-x:auto;
  padding-bottom:18px;
  scroll-snap-type:x mandatory;
}

.target-slider::-webkit-scrollbar{height:6px}
.target-slider::-webkit-scrollbar-thumb{background:var(--line);border-radius:999px}

.target-card{
  scroll-snap-align:start;
  min-height:310px;
  padding:30px;
  background:
    linear-gradient(180deg, rgba(13,43,79,.05), transparent 35%),
    var(--bg);
  border:1px solid rgba(13,43,79,.15);
}

.reason-list{
  display:grid;
  gap:18px;
  margin-top:44px;
}

.reason-item{
  display:grid;
  grid-template-columns:92px 1fr;
  gap:22px;
  padding:28px 0;
  border-top:1px solid var(--line);
}

.reason-item:last-child{
  border-bottom:1px solid var(--line);
}

.reason-item__num{
  color:var(--navy);
  font-family:var(--serif);
  font-size:2.3rem;
  line-height:1;
}

.works{
  background:#0b1728;
  color:#fff;
  overflow:hidden;
}

.works .section-title,
.works .eyebrow,
.works .section-number,
.works .work-card h3{
  color:#fff;
}

.works .section-text,
.works .work-card p{
  color:rgba(255,255,255,.78);
}

.metrics{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:1px;
  background:rgba(255,255,255,.18);
  margin-top:42px;
  border:1px solid rgba(255,255,255,.18);
}

.metric{
  background:#0b1728;
  padding:clamp(20px,4vw,36px);
}

.metric strong{
  display:block;
  color:#fff;
  font-family:var(--serif);
  font-size:clamp(1.7rem,4vw,3.2rem);
  line-height:1.1;
  font-weight:400;
}

.metric span{
  display:block;
  margin-top:12px;
  color:rgba(255,255,255,.7);
  font-size:.84rem;
}

.work-list{
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:16px;
  margin-top:34px;
}

.work-card{
  position:relative;
  padding:28px;
  background:rgba(255,255,255,.06);
  border:1px solid rgba(255,255,255,.18);
  min-height:210px;
}

.work-card::after{
  background:linear-gradient(135deg, transparent 0 48%, var(--accent) 50%);
}

.plan{
  background:#fff;
}

.plan-box{
  margin-top:42px;
  background:var(--bg);
  border:1px solid rgba(13,43,79,.16);
  padding:clamp(26px,6vw,58px);
  box-shadow:var(--shadow);
}

.plan-box__head{
  display:flex;
  align-items:flex-end;
  justify-content:space-between;
  gap:18px;
  border-bottom:1px solid var(--line);
  padding-bottom:20px;
  margin-bottom:24px;
}

.plan-box__head span{
  color:var(--accent);
  text-transform:uppercase;
  letter-spacing:.16em;
  font-size:.78rem;
}

.plan-box__head h3{
  margin:0;
  color:var(--navy);
  font-family:var(--serif);
  font-size:clamp(1.9rem,4vw,3.6rem);
  font-weight:400;
}

.two-col-list{
  list-style:none;
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:10px 20px;
  margin:28px 0;
  padding:0;
}

.two-col-list li{
  padding:12px 14px;
  background:#fff;
  border-left:2px solid var(--navy);
  color:#333;
  font-size:.9rem;
}

.price-note{
  padding:24px;
  background:#fff;
  border:1px solid var(--line);
}

.price-note span{
  display:block;
  color:var(--muted);
  font-size:.76rem;
  letter-spacing:.12em;
}

.price-note strong{
  display:block;
  color:var(--navy);
  font-family:var(--serif);
  font-size:clamp(2rem,5vw,4rem);
  font-weight:400;
  line-height:1.2;
}

.price-note p{
  margin:8px 0 0;
  color:var(--muted);
  font-size:.88rem;
}

.consultation{
  background:var(--soft);
}

.consult-box{
  margin-top:42px;
  display:grid;
  grid-template-columns:1fr auto;
  align-items:center;
  gap:26px;
  padding:clamp(24px,5vw,48px);
  background:#fff;
  border:1px solid var(--line);
}

.consult-box ul{
  margin:0;
  padding-left:1.2em;
  columns:2;
}

.flow-list{
  margin-top:42px;
  display:grid;
  gap:12px;
}

.flow-item{
  display:grid;
  grid-template-columns:160px 1fr;
  gap:22px;
  padding:26px 0;
  border-top:1px solid var(--line);
}

.flow-item:last-child{
  border-bottom:1px solid var(--line);
}

.faq{
  background:#fff;
}

.faq-list{
  margin-top:34px;
  border-top:1px solid var(--line);
}

.faq-item{
  border-bottom:1px solid var(--line);
  padding:0;
}

.faq-item summary{
  cursor:pointer;
  list-style:none;
  padding:22px 46px 22px 0;
  position:relative;
  color:var(--navy);
  font-weight:700;
}

.faq-item summary::-webkit-details-marker{display:none}
.faq-item summary::after{
  content:"+";
  position:absolute;
  right:10px;
  top:50%;
  transform:translateY(-50%);
  font-size:1.8rem;
  font-family:var(--serif);
  color:var(--accent);
}
.faq-item[open] summary::after{content:"−"}
.faq-item p{
  margin:0;
  padding:0 0 24px;
  color:#444;
}

.final-cta{
  background:linear-gradient(135deg, var(--navy), var(--navy-2));
  color:#fff;
}

.final-cta__box{
  text-align:center;
  width:min(100%, 760px);
  margin-inline:auto;
}

.final-cta .eyebrow{
  color:rgba(255,255,255,.74);
}

.final-cta h2{
  margin:0;
  font-family:var(--serif);
  font-weight:400;
  font-size:clamp(2.4rem,6vw,5.4rem);
  line-height:1.25;
}

.final-cta p{
  margin:24px auto 30px;
  max-width:640px;
  color:rgba(255,255,255,.82);
}

.contact{
  background:var(--bg);
}

.contact-form{
  margin-top:36px;
  display:grid;
  gap:18px;
  padding:clamp(24px,5vw,52px);
  background:#fff;
  border:1px solid rgba(13,43,79,.15);
  box-shadow:var(--shadow);
}

.contact-form label{
  display:grid;
  gap:7px;
}

.contact-form label span{
  color:var(--navy);
  font-weight:700;
  font-size:.9rem;
}

.contact-form em{
  font-style:normal;
  color:#fff;
  background:var(--navy);
  border-radius:999px;
  padding:.1rem .45rem;
  font-size:.68rem;
  margin-left:.3rem;
}

.contact-form input,
.contact-form textarea,
.contact-form select{
  width:100%;
  border:1px solid var(--line);
  background:#fafafa;
  border-radius:0;
  padding:14px 15px;
  color:var(--ink);
  outline:none;
  transition:border-color .2s ease, box-shadow .2s ease, background .2s ease;
}

.contact-form input:focus,
.contact-form textarea:focus,
.contact-form select:focus{
  border-color:var(--navy);
  box-shadow:0 0 0 4px rgba(13,43,79,.08);
  background:#fff;
}

.contact-form textarea{
  resize:vertical;
  min-height:150px;
}

.form-note,
.form-success{
  margin:0;
  color:var(--muted);
  font-size:.78rem;
}

.form-success{
  color:var(--navy);
  font-weight:700;
}

.site-footer{
  padding:42px 20px 90px;
  text-align:center;
  background:#fff;
  color:var(--navy);
}

.site-footer p{
  margin:0;
  font-family:var(--serif);
  font-size:1.6rem;
  letter-spacing:.12em;
}

.site-footer small{
  display:block;
  margin-top:8px;
  color:var(--muted);
  letter-spacing:.12em;
}

.sticky-cta{
  position:fixed;
  right:18px;
  bottom:18px;
  z-index:45;
  display:none;
  align-items:center;
  justify-content:center;
  min-height:48px;
  padding:0 18px;
  border-radius:999px;
  background:var(--navy);
  color:#fff;
  box-shadow:0 12px 34px rgba(13,43,79,.28);
  font-size:.84rem;
  font-weight:700;
  letter-spacing:.08em;
}

.reveal{
  opacity:0;
  transform:translateY(28px);
  transition:opacity .8s ease, transform .8s ease;
}

.reveal.is-visible{
  opacity:1;
  transform:translateY(0);
}

@keyframes slowSlide{
  from{transform:translateX(-48%)}
  to{transform:translateX(-54%)}
}

@keyframes marquee{
  from{transform:translateX(0)}
  to{transform:translateX(-50%)}
}

@media (max-width: 920px){
  body{
    background:var(--bg);
  }

  .header-nav a:not(.nav-cta){
    display:none;
  }

  .section--hero{
    min-height:auto;
    padding-top:108px;
    padding-bottom:86px;
  }

  .section-number--hero{
    top:-34px;
  }

  .mock-phone{
    position:relative;
    right:auto;
    bottom:auto;
    width:100%;
    min-width:0;
    margin-top:42px;
    transform:none;
  }

  .hero-card__grid,
  .service-grid,
  .metrics,
  .work-list{
    grid-template-columns:1fr;
  }

  .check-list,
  .two-col-list{
    grid-template-columns:1fr;
  }

  .consult-box{
    grid-template-columns:1fr;
  }

  .consult-box ul{
    columns:1;
  }

  .flow-item,
  .reason-item{
    grid-template-columns:1fr;
    gap:10px;
  }

  .plan-box__head{
    display:block;
  }

  .sticky-cta{
    display:flex;
  }
}

@media (max-width: 560px){
  .site-header{
    height:66px;
    padding-inline:14px;
  }

  .brand__mark{
    width:34px;
    height:34px;
  }

  .brand__text{
    font-size:.62rem;
  }

  .nav-cta{
    font-size:.62rem;
    padding:.5rem .62rem;
  }

  .section{
    padding:76px 0;
  }

  .hero__title{
    font-size:clamp(2.7rem,16vw,4.8rem);
  }

  .section-title{
    font-size:clamp(2rem,12vw,3.4rem);
  }

  .hero__text,
  .section-text{
    font-size:.92rem;
  }

  .button{
    width:100%;
    padding-inline:16px;
  }

  .hero-card{
    padding:16px;
  }

  .hero-card__grid div{
    padding:12px 10px;
  }

  .service-card,
  .target-card,
  .work-card{
    padding:24px;
  }

  .mock-post{
    min-height:240px;
  }

  .metrics{
    gap:0;
  }

  .metric{
    border-bottom:1px solid rgba(255,255,255,.15);
  }
}

@media (prefers-reduced-motion: reduce){
  *,
  *::before,
  *::after{
    animation-duration:.001ms !important;
    animation-iteration-count:1 !important;
    scroll-behavior:auto !important;
    transition-duration:.001ms !important;
  }

  .reveal{
    opacity:1;
    transform:none;
  }
}


/* WordPress contact status */
.form-alert {
  border: 1px solid rgba(9, 31, 63, 0.16);
  border-radius: 18px;
  margin: 0 0 24px;
  padding: 16px 18px;
  background: rgba(255,255,255,0.86);
  color: var(--ink);
  line-height: 1.8;
}

.form-alert--success {
  border-color: rgba(28, 110, 75, 0.3);
  background: rgba(235, 248, 241, 0.92);
}

.form-alert--error {
  border-color: rgba(158, 57, 57, 0.3);
  background: rgba(253, 241, 241, 0.92);
}

.admin-bar .site-header {
  top: 32px;
}

@media (max-width: 782px) {
  .admin-bar .site-header {
    top: 46px;
  }
}
