/*
Theme Name: Interview Writer — Natsumi Kozono
Theme URI:
Description: 小薗夏海インタビューライターHP — Cocoon Child Theme
Author: Natsumi Kozono
Template: cocoon-master
Version: 1.0.0
Text Domain: nats-writer
*/

/* =========================================================
   小薗 夏海 — Interview Writer HP
   Editorial / warm cream / Mincho × Gothic
   ========================================================= */

:root{
  --cream:      #F7F3EC;
  --cream-deep: #EFE8DC;
  --paper:      #FCFAF5;
  --ink:        #2D2823;
  --ink-soft:   #5C5347;
  --brown:      #6B5B4A;
  --camel:      #C9A47A;
  --camel-deep: #8C6A33;
  --camel-line: #C9A47A;
  --line:       rgba(45,40,35,.13);
  --line-soft:  rgba(45,40,35,.07);

  --f-mincho: "Shippori Mincho", "Hiragino Mincho ProN", serif;
  --f-gothic: "Zen Kaku Gothic New", "Hiragino Kaku Gothic ProN", sans-serif;
  --f-latin:  "Cormorant Garamond", serif;

  --maxw: 1120px;
  --pad: clamp(22px, 5vw, 80px);
}

*{ box-sizing:border-box; }
html{ scroll-behavior:smooth; -webkit-text-size-adjust:100%; }
body{
  margin:0;
  background:var(--cream);
  color:var(--ink);
  font-family:var(--f-gothic);
  font-weight:400;
  line-height:1.95;
  letter-spacing:.02em;
  font-feature-settings:"palt" 1;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
img{ max-width:100%; display:block; }
a{ color:inherit; text-decoration:none; }

/* ---------- shared ---------- */
.wrap{ max-width:var(--maxw); margin:0 auto; padding-inline:var(--pad); }
section{ position:relative; }

.eyebrow{
  display:flex; align-items:center; gap:16px;
  font-family:var(--f-latin);
  font-style:italic;
  font-size:23px;
  letter-spacing:.06em;
  color:var(--camel-deep);
  margin:0 0 30px;
}
.eyebrow .num{
  font-style:normal;
  font-family:var(--f-mincho);
  font-size:15px;
  letter-spacing:.18em;
  color:var(--camel-deep);
  padding-top:2px;
}
.eyebrow .jp{
  font-family:var(--f-gothic);
  font-style:normal;
  font-size:14px;
  letter-spacing:.3em;
  color:var(--ink-soft);
}
.eyebrow .rule{ flex:0 0 46px; height:1px; background:var(--camel); opacity:.7; }

.h2{
  font-family:var(--f-mincho);
  font-weight:600;
  font-size:clamp(26px, 3.4vw, 40px);
  line-height:1.5;
  letter-spacing:.04em;
  margin:0;
}

.lead{
  font-size:clamp(14.5px,1.05vw,16px);
  line-height:2.15;
  color:var(--ink-soft);
  letter-spacing:.03em;
}

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

/* ---------- nav ---------- */
.nats-nav{
  position:fixed; top:0; left:0; right:0; z-index:9999;
  display:flex; align-items:center; justify-content:space-between;
  padding:18px var(--pad);
  transition:background .5s ease, box-shadow .5s ease, padding .4s ease;
}
.nats-nav.scrolled{
  background:rgba(247,243,236,.86);
  backdrop-filter:blur(14px);
  box-shadow:0 1px 0 var(--line-soft);
  padding-top:13px; padding-bottom:13px;
}
.nats-nav .brand{ font-family:var(--f-latin); font-style:italic; font-size:23px; letter-spacing:.02em; color:var(--ink); display:flex; align-items:baseline; gap:10px; }
.nats-nav .brand small{ font-family:var(--f-gothic); font-style:normal; font-size:10.5px; letter-spacing:.34em; color:var(--camel-deep); }
.nats-nav .links{ display:flex; align-items:center; gap:30px; }
.nats-nav .links a{ font-size:12.5px; letter-spacing:.18em; color:var(--ink-soft); transition:color .3s; }
.nats-nav .links a:hover{ color:var(--camel-deep); }
.nats-nav .cta{
  font-family:var(--f-gothic);
  font-size:12px; letter-spacing:.2em;
  border:1px solid var(--ink); color:var(--ink);
  padding:11px 22px; border-radius:999px;
  transition:background .35s, color .35s, border-color .35s;
}
.nats-nav .cta:hover{ background:var(--ink); color:var(--cream); }
@media (max-width:880px){
  .nats-nav .links a:not(.cta){ display:none; }
}

/* ---------- hero ---------- */
.hero{ padding:152px 0 96px; position:relative; overflow:hidden; }
.hero-grid{ display:grid; grid-template-columns:1.22fr .78fr; gap:clamp(30px,5vw,66px); align-items:center; }
.hero-eyebrow{
  font-family:var(--f-latin); font-style:italic; font-size:19px; letter-spacing:.08em;
  color:var(--camel-deep); display:flex; align-items:center; gap:14px; margin-bottom:34px;
}
.hero-eyebrow .rule{ width:46px; height:1px; background:var(--camel); }
.hero-eyebrow .jp{ font-family:var(--f-gothic); font-style:normal; font-size:12px; letter-spacing:.3em; color:var(--ink-soft); }
.hero h1{
  font-family:var(--f-mincho);
  font-weight:600;
  font-size:clamp(27px, 3.5vw, 45px);
  line-height:1.66;
  letter-spacing:.035em;
  margin:0 0 38px;
}
.hero h1 .accent{ color:var(--camel-deep); }
.hero h1 .qm{ color:var(--camel-deep); font-weight:500; }
.hero p.intro{ max-width:30em; font-size:15.5px; line-height:2.25; color:var(--ink-soft); letter-spacing:.03em; margin:0 0 42px; }
.hero .actions{ display:flex; align-items:center; gap:26px; flex-wrap:wrap; }
.btn{
  display:inline-flex; align-items:center; gap:12px;
  font-family:var(--f-gothic); font-size:13.5px; letter-spacing:.16em;
  background:var(--ink); color:var(--cream);
  padding:17px 34px; border-radius:999px;
  transition:transform .4s cubic-bezier(.2,.7,.2,1), background .4s;
}
.btn:hover{ background:var(--camel-deep); transform:translateY(-2px); }
.btn .arr{ transition:transform .4s; }
.btn:hover .arr{ transform:translateX(4px); }
.link-quiet{ font-size:13px; letter-spacing:.14em; color:var(--ink-soft); border-bottom:1px solid var(--line); padding-bottom:3px; transition:color .3s, border-color .3s; }
.link-quiet:hover{ color:var(--camel-deep); border-color:var(--camel); }

.hero-media{ position:relative; }
.hero-media .hero-img{ width:100%; height:540px; object-fit:cover; object-position:center top; display:block; box-shadow:0 30px 70px -40px rgba(45,40,35,.5); }
.hero-media .vlabel{
  position:absolute; top:0; right:-30px;
  writing-mode:vertical-rl;
  font-family:var(--f-mincho); font-size:12px; letter-spacing:.5em;
  color:var(--camel-deep); height:auto;
}
.hero-media .cap{
  position:absolute; left:-18px; bottom:26px;
  background:var(--paper); padding:13px 20px;
  font-family:var(--f-latin); font-style:italic; font-size:16px; color:var(--ink);
  box-shadow:0 16px 40px -28px rgba(45,40,35,.6);
}
.hero-media .cap small{ display:block; font-family:var(--f-gothic); font-style:normal; font-size:10px; letter-spacing:.26em; color:var(--camel-deep); margin-top:2px; }

@media (max-width:860px){
  .hero{ padding-top:128px; }
  .hero-grid{ grid-template-columns:1fr; gap:44px; }
  .hero-media .hero-img{ height:380px; }
  .hero-media .vlabel{ right:-18px; }
}

/* ---------- worries ---------- */
.worries{ padding:clamp(70px,9vw,128px) 0; }
.worries-head{ max-width:38em; margin-bottom:54px; }
.worries-list{ display:grid; gap:0; border-top:1px solid var(--line); max-width:760px; }
.worry{
  display:flex; align-items:baseline; gap:24px;
  padding:26px 6px; border-bottom:1px solid var(--line);
}
.worry .q{ font-family:var(--f-mincho); font-size:30px; line-height:1; color:var(--camel); flex:0 0 auto; }
.worry p{ margin:0; font-family:var(--f-mincho); font-size:clamp(16px,1.6vw,20px); letter-spacing:.04em; color:var(--ink); }
.worries .turn{
  margin:48px 0 0; font-family:var(--f-mincho); font-size:clamp(18px,2vw,24px);
  letter-spacing:.06em; color:var(--ink);
}
.worries .resolve{ max-width:40em; margin-top:24px; }

/* ---------- philosophy ---------- */
.philo{ background:var(--cream-deep); padding:clamp(80px,11vw,150px) 0; }
.philo-grid{ display:grid; grid-template-columns:.9fr 1.1fr; gap:clamp(34px,5vw,80px); align-items:center; }
.philo-media .philo-img{ width:100%; height:520px; object-fit:cover; object-position:center top; display:block; box-shadow:0 30px 70px -42px rgba(45,40,35,.5); }
.philo blockquote{
  margin:0 0 36px; font-family:var(--f-mincho); font-weight:600;
  font-size:clamp(22px,2.7vw,34px); line-height:1.85; letter-spacing:.05em; color:var(--ink);
}
.philo blockquote .hi{ color:var(--camel-deep); }
.philo .body{ max-width:34em; }
.philo .body p{ margin:0 0 20px; color:var(--ink-soft); line-height:2.2; }
@media (max-width:860px){ .philo-grid{ grid-template-columns:1fr; } .philo-media{ order:-1; } .philo-media .philo-img{ height:340px; } }

/* ---------- services ---------- */
.services{ padding:clamp(80px,11vw,150px) 0; }
.services .h2{ margin-bottom:54px; }
.svc-list{ border-top:1px solid var(--line); }
.svc{
  display:grid; grid-template-columns:90px 1fr auto; align-items:center; gap:24px;
  padding:30px 6px; border-bottom:1px solid var(--line);
  transition:background .4s, padding-left .4s;
}
.svc:hover{ background:var(--paper); padding-left:18px; }
.svc .idx{ font-family:var(--f-latin); font-style:italic; font-size:30px; color:var(--camel); }
.svc .name{ font-family:var(--f-mincho); font-size:clamp(17px,1.8vw,23px); letter-spacing:.04em; color:var(--ink); }
.svc .tag{ font-family:var(--f-gothic); font-size:11px; letter-spacing:.22em; color:var(--ink-soft); }
@media (max-width:680px){ .svc{ grid-template-columns:54px 1fr; } .svc .tag{ display:none; } .svc .idx{ font-size:23px; } }

/* ---------- pricing ---------- */
.pricing{ background:var(--cream-deep); padding:clamp(80px,11vw,150px) 0; }
.pricing .head{ text-align:center; margin-bottom:60px; }
.pricing .head .eyebrow{ justify-content:center; }
.price-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:22px; align-items:stretch; }
.plan{
  background:var(--paper); border:1px solid var(--line);
  padding:40px 32px 36px; display:flex; flex-direction:column;
  position:relative; transition:transform .5s cubic-bezier(.2,.7,.2,1), box-shadow .5s;
}
.plan:hover{ transform:translateY(-6px); box-shadow:0 34px 60px -42px rgba(45,40,35,.45); }
.plan.feature{ border-color:var(--camel); background:#FFFDF8; }
.plan .ribbon{
  position:absolute; top:-12px; left:32px;
  background:var(--camel-deep); color:var(--cream);
  font-size:10.5px; letter-spacing:.24em; padding:6px 16px; border-radius:999px;
}
.plan .pname{ font-family:var(--f-mincho); font-size:19px; letter-spacing:.04em; margin:0 0 18px; color:var(--ink); }
.plan .pprice{ font-family:var(--f-mincho); font-weight:600; display:flex; align-items:baseline; gap:4px; margin-bottom:6px; }
.plan .pprice .yen{ font-size:18px; }
.plan .pprice .num{ font-size:42px; letter-spacing:.01em; color:var(--ink); line-height:1; }
.plan .pprice .per{ font-family:var(--f-gothic); font-size:12px; letter-spacing:.1em; color:var(--ink-soft); }
.plan .ptax{ font-size:11.5px; letter-spacing:.1em; color:var(--ink-soft); margin-bottom:26px; }
.plan ul{ list-style:none; margin:0 0 22px; padding:0; border-top:1px solid var(--line-soft); }
.plan li{ font-size:13.5px; line-height:1.7; color:var(--ink-soft); padding:11px 0 11px 22px; border-bottom:1px solid var(--line-soft); position:relative; letter-spacing:.02em; }
.plan li::before{ content:""; position:absolute; left:2px; top:18px; width:7px; height:7px; border-radius:50%; background:var(--camel); }
.plan .note{ font-size:11px; line-height:1.7; color:var(--brown); margin-top:auto; }
.pricing .foot-notes{ text-align:center; margin-top:40px; font-size:12px; letter-spacing:.08em; color:var(--ink-soft); }
.pricing .foot-notes span{ margin:0 14px; }
@media (max-width:860px){ .price-grid{ grid-template-columns:1fr; max-width:460px; margin:0 auto; } }

/* ---------- for-you ---------- */
.foryou{ padding:clamp(80px,11vw,150px) 0; }
.foryou-grid{ display:grid; grid-template-columns:.8fr 1.2fr; gap:clamp(30px,5vw,72px); align-items:start; }
.check-list{ display:grid; grid-template-columns:1fr 1fr; gap:0; border-top:1px solid var(--line); }
.check{ display:flex; align-items:flex-start; gap:14px; padding:24px 4px; border-bottom:1px solid var(--line); font-size:14.5px; line-height:1.7; color:var(--ink); letter-spacing:.02em; }
.check .mk{ flex:0 0 auto; width:22px; height:22px; border-radius:50%; border:1px solid var(--camel); display:grid; place-items:center; margin-top:2px; }
.check .mk svg{ width:11px; height:11px; }
@media (max-width:720px){ .foryou-grid{ grid-template-columns:1fr; } .check-list{ grid-template-columns:1fr; } }

/* ---------- steps ---------- */
.steps{ background:var(--ink); color:var(--cream); padding:clamp(80px,11vw,150px) 0; }
.steps .eyebrow{ color:var(--camel); }
.steps .eyebrow .jp{ color:rgba(247,243,236,.6); }
.steps .h2{ color:var(--cream); margin-bottom:60px; }
.step-row{ display:grid; grid-template-columns:160px 1fr; gap:clamp(20px,4vw,60px); padding:38px 0; border-top:1px solid rgba(247,243,236,.16); }
.step-row:last-child{ border-bottom:1px solid rgba(247,243,236,.16); }
.step-row .lab{ display:flex; flex-direction:column; gap:6px; }
.step-row .lab .st{ font-family:var(--f-latin); font-style:italic; font-size:14px; letter-spacing:.2em; color:var(--camel); }
.step-row .lab .no{ font-family:var(--f-mincho); font-size:46px; line-height:1; color:var(--cream); }
.step-row .ttl{ font-family:var(--f-mincho); font-size:clamp(19px,2vw,26px); letter-spacing:.04em; margin:0 0 16px; color:var(--cream); }
.step-row .desc{ max-width:46em; font-size:14px; line-height:2.1; color:rgba(247,243,236,.7); letter-spacing:.02em; }
.step-row .desc .meta{ display:block; margin-top:10px; font-size:12px; color:var(--camel); letter-spacing:.06em; }
@media (max-width:680px){ .step-row{ grid-template-columns:1fr; gap:14px; } .step-row .lab{ flex-direction:row; align-items:baseline; gap:16px; } .step-row .lab .no{ font-size:34px; } }

/* ---------- profile ---------- */
.profile{ padding:clamp(80px,11vw,150px) 0; }
.profile-grid{ display:grid; grid-template-columns:.85fr 1.15fr; gap:clamp(36px,5vw,80px); align-items:start; }
.profile-media{ position:relative; }
.profile-media .profile-img{ width:100%; height:560px; object-fit:cover; object-position:center top; display:block; box-shadow:0 30px 70px -42px rgba(45,40,35,.5); }
.profile-media .vname{ position:absolute; left:-26px; top:24px; writing-mode:vertical-rl; font-family:var(--f-mincho); font-size:13px; letter-spacing:.4em; color:var(--camel-deep); }
.profile .pname{ font-family:var(--f-mincho); font-weight:600; font-size:clamp(26px,3vw,38px); letter-spacing:.06em; margin:0 0 4px; }
.profile .platin{ font-family:var(--f-latin); font-style:italic; font-size:21px; color:var(--camel-deep); margin:0 0 10px; }
.profile .prole{ font-size:12.5px; letter-spacing:.2em; color:var(--ink-soft); margin:0 0 32px; padding-bottom:24px; border-bottom:1px solid var(--line); }
.profile .pbody p{ margin:0 0 22px; color:var(--ink-soft); line-height:2.2; font-size:14.5px; letter-spacing:.03em; }
.profile .pbody p:last-child{ margin-bottom:0; }
@media (max-width:860px){ .profile-grid{ grid-template-columns:1fr; } .profile-media .profile-img{ height:420px; } .profile-media .vname{ left:-16px; } }

/* ---------- closing ---------- */
.closing{ background:var(--cream-deep); padding:clamp(90px,12vw,170px) 0; text-align:center; }
.closing .mark{ font-family:var(--f-latin); font-style:italic; font-size:20px; color:var(--camel-deep); letter-spacing:.1em; margin-bottom:30px; }
.closing h2{
  font-family:var(--f-mincho); font-weight:600;
  font-size:clamp(24px,3.4vw,42px); line-height:1.9; letter-spacing:.05em;
  margin:0 auto; max-width:22em; color:var(--ink);
}
.closing h2 .hi{ color:var(--camel-deep); }
.closing .sub{ max-width:30em; margin:34px auto 0; color:var(--ink-soft); line-height:2.2; }

/* ---------- contact ---------- */
.contact{ padding:clamp(80px,11vw,140px) 0; }
.contact-grid{ display:grid; grid-template-columns:1fr 1fr; gap:clamp(34px,6vw,90px); align-items:center; }
.contact h3{ font-family:var(--f-mincho); font-weight:600; font-size:clamp(24px,2.8vw,34px); line-height:1.6; letter-spacing:.05em; margin:0 0 24px; }
.contact .form-btn{ margin-top:14px; }
.contact-info{ border-top:1px solid var(--line); }
.cinfo{ display:grid; grid-template-columns:120px 1fr; gap:18px; align-items:center; padding:20px 4px; border-bottom:1px solid var(--line); }
.cinfo .k{ font-family:var(--f-gothic); font-size:11px; letter-spacing:.24em; color:var(--camel-deep); }
.cinfo .v{ font-size:14.5px; letter-spacing:.04em; color:var(--ink); word-break:break-all; }
.cinfo a.v{ transition:color .3s; }
.cinfo a.v:hover{ color:var(--camel-deep); }
.socials{ display:flex; gap:13px; }
.socials a{ width:50px; height:50px; border-radius:50%; border:1px solid var(--line); display:grid; place-items:center; color:var(--ink); transition:background .3s, color .3s, border-color .3s, transform .35s cubic-bezier(.2,.7,.2,1); }
.socials a:hover{ background:var(--ink); color:var(--cream); border-color:var(--ink); transform:translateY(-3px); }
.socials a svg{ width:19px; height:19px; display:block; }
.socials a .nt{ font-family:var(--f-gothic); font-weight:700; font-size:13px; letter-spacing:-.01em; }
@media (max-width:760px){ .contact-grid{ grid-template-columns:1fr; gap:46px; } .cinfo{ grid-template-columns:92px 1fr; } }

/* ---------- footer ---------- */
.nats-foot{ border-top:1px solid var(--line); padding:46px 0; }
.nats-foot .foot-in{ display:flex; align-items:center; justify-content:space-between; gap:20px; flex-wrap:wrap; }
.nats-foot .brand{ font-family:var(--f-latin); font-style:italic; font-size:20px; }
.nats-foot .brand small{ font-family:var(--f-gothic); font-style:normal; font-size:10px; letter-spacing:.3em; color:var(--camel-deep); margin-left:10px; }
.nats-foot .cr{ font-size:11px; letter-spacing:.14em; color:var(--ink-soft); }

/* =========================================================
   Cocoon デフォルト要素の上書き（LP専用）
   ========================================================= */
body.nats-landing #header,
body.nats-landing #footer,
body.nats-landing #breadcrumb,
body.nats-landing .sidebar,
body.nats-landing #sidebar,
body.nats-landing .entry-title,
body.nats-landing .sns-share,
body.nats-landing .related-entries,
body.nats-landing .comments-area,
body.nats-landing .pagination,
body.nats-landing #scroll-page-top{ display:none !important; }

body.nats-landing #contents,
body.nats-landing #main,
body.nats-landing .entry-content,
body.nats-landing #wrapper{ all:unset; display:block; }

body.nats-landing{ background:var(--cream); }

/* =========================================================
   スマホ対応 — 480px以下
   ========================================================= */
@media (max-width:480px){
  :root{ --pad: 20px; }

  .nats-nav{ padding:14px var(--pad); }
  .nats-nav .brand{ font-size:18px; }
  .nats-nav .brand small{ font-size:9px; letter-spacing:.22em; }
  .nats-nav .links a:not(.cta){ display:none; }
  .nats-nav .cta{ font-size:11px; padding:9px 16px; }

  .hero{ padding-top:100px; padding-bottom:60px; }
  .hero-grid{ gap:32px; }
  .hero h1{ font-size:clamp(24px,7.5vw,32px); line-height:1.7; margin-bottom:24px; }
  .hero p.intro{ font-size:14px; line-height:2; margin-bottom:28px; }
  .hero-eyebrow{ font-size:15px; margin-bottom:22px; gap:10px; }
  .hero-eyebrow .jp{ font-size:10px; }
  .hero-media .hero-img{ height:280px; }
  .hero-media .vlabel{ display:none; }
  .hero-media .cap{ left:0; bottom:16px; padding:10px 14px; font-size:13px; }
  .hero .actions{ gap:16px; }
  .btn{ font-size:12.5px; padding:14px 26px; }

  .worries{ padding:60px 0; }
  .worries-head{ margin-bottom:36px; }
  .worry p{ font-size:15px; }
  .worries .turn{ font-size:17px; }

  .philo{ padding:60px 0; }
  .philo blockquote{ font-size:clamp(19px,5.8vw,26px); line-height:1.9; word-break:keep-all; overflow-wrap:break-word; }
  .philo-media .philo-img{ height:260px; }

  .services{ padding:60px 0; }
  .svc{ padding:22px 4px; gap:14px; }
  .svc .name{ font-size:15px; }

  .pricing{ padding:60px 0; }
  .price-grid{ gap:16px; }
  .plan{ padding:32px 22px 28px; }
  .plan .pprice .num{ font-size:36px; }

  .foryou{ padding:60px 0; }
  .check-list{ grid-template-columns:1fr; }
  .check{ font-size:13.5px; padding:18px 4px; }

  .steps{ padding:60px 0; }
  .step-row{ padding:28px 0; gap:12px; }
  .step-row .ttl{ font-size:17px; margin-bottom:10px; }
  .step-row .desc{ font-size:13px; line-height:2; }

  .profile{ padding:60px 0; }
  .profile-media .profile-img{ height:340px; }
  .profile-media .vname{ left:-12px; font-size:11px; letter-spacing:.3em; }
  .profile .pname{ font-size:clamp(22px,6vw,30px); }
  .profile .pbody p{ font-size:13.5px; line-height:2.1; }

  .closing{ padding:70px 0; }
  .closing h2{ font-size:clamp(20px,5.5vw,28px); line-height:1.85; }

  .contact{ padding:60px 0; }
  .contact h3{ font-size:clamp(20px,5.5vw,26px); }
  .cinfo{ grid-template-columns:80px 1fr; gap:12px; }
  .socials{ gap:10px; flex-wrap:wrap; }
  .socials a{ width:44px; height:44px; }

  .nats-foot{ padding:32px 0; }
  .nats-foot .foot-in{ flex-direction:column; align-items:flex-start; gap:10px; }
}

/* =========================================================
   タブレット補完 — 481px〜680px
   ========================================================= */
@media (min-width:481px) and (max-width:680px){
  .hero-media .hero-img{ height:320px; }
  .philo blockquote{ font-size:clamp(20px,4.5vw,28px); word-break:keep-all; }
  .profile-media .profile-img{ height:380px; }
  .check-list{ grid-template-columns:1fr; }
}
