/*
Theme Name: SENTAKU-YUICHI
Author: 中村祐一
Description: 洗濯家・中村祐一 公式サイト用テーマ。Thoughts（記事）と News（お知らせ）を、管理画面からカスタム投稿として追加・管理できます。デザインは静的モックアップをそのまま移植。
Version: 2.4.0
Requires at least: 6.0
Requires PHP: 7.4
Text Domain: sentaku-yuichi
*/

  :root{
    --paper:#FCFCFB;
    --paper-2:#F2F1ED;
    --ink:#16181D;
    --ink-soft:#3D424C;
    --mute:#888B91;
    --indigo:#4662AC;
    --indigo-deep:#33478A;
    --line:#E4E2DC;
    --maxw:1080px;
  }
  *{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.95;
    font-weight:300;
    -webkit-font-smoothing:antialiased;
  }
  .wrap{max-width:var(--maxw);margin:0 auto;padding:0 32px}

  header{
    position:sticky;top:0;z-index:50;
    background:rgba(252,252,251,.9);
    backdrop-filter:saturate(150%) blur(12px);
    border-bottom:1px solid var(--line);
  }
  .nav{display:flex;flex-direction:column;align-items:center;gap:14px;height:auto;padding:22px 0}
  .brand img{height:38px;display:block}
  .brand-tag{display:flex;flex-direction:column;align-items:center;text-align:center;gap:6px}
  .tagline{font-size:10.5px;letter-spacing:.3em;color:var(--indigo);font-weight:400;padding-left:2px}
  .menu{display:flex;gap:34px;align-items:center;justify-content:center}
  .menu a{font-size:13px;color:var(--indigo);text-decoration:none;letter-spacing:.1em;transition:color .2s}
  .menu a:hover{color:var(--indigo-deep)}
  .menu .cta{
    border:1px solid var(--ink);color:var(--ink);padding:9px 20px;font-size:12px;
    letter-spacing:.14em;transition:all .2s;border-radius:0;
  }
  .menu .cta:hover{background:var(--ink);color:#fff}

  /* hero — generous whitespace, thin type, wide tracking */
  .hero{position:relative;padding:150px 0 130px;overflow:hidden}
  .hero .wrap{position:relative;z-index:2}
  .eyebrow{
    font-size:11px;letter-spacing:.42em;color:var(--indigo);font-weight:500;
    margin-bottom:48px;text-transform:uppercase;
  }
  .hero h1{
    font-family:"Zen Kaku Gothic New",sans-serif;
    font-weight:400;
    font-size:clamp(27px,4.3vw,46px);
    line-height:1.72;
    letter-spacing:.05em;
    color:var(--ink);
    margin-bottom:46px;
  }
  .hero h1 .b{color:var(--ink);font-weight:500}
  .hero h1 .hl1,.hero h1 .hl2{display:block}
  .hero h1 .hl-b{font-weight:700;white-space:nowrap}
  /* 写真背景ヒーロー（画像を切らずに全体表示） */
  .hero-photo{padding:0;position:relative;overflow:hidden}
  .hero-photo .hero-img{display:block;width:100%;height:auto}
  .hero-photo .wrap{position:absolute;left:0;right:0;bottom:11%;z-index:2;padding-top:0;padding-bottom:0}
  .hero-photo h1{margin:0;color:var(--ink);line-height:1.85;letter-spacing:.05em;text-align:right;text-shadow:0 1px 12px rgba(255,255,255,.75),0 1px 3px rgba(255,255,255,.95)}
  .hero-photo h1 .hl1,.hero-photo h1 .hl2{display:block;background:none;padding:0}
  .hero-photo h1 .ink-em{color:var(--indigo);font-weight:500}
  .hero-photo h1 .hl-b{color:var(--ink);font-weight:700}
  .hero .lead{
    font-size:15px;color:var(--ink-soft);max-width:540px;line-height:2.2;margin-bottom:52px;font-weight:300;
  }
  .hero .actions{display:flex;gap:0;flex-wrap:wrap}
  .btn{
    display:inline-flex;align-items:center;gap:10px;font-size:13px;text-decoration:none;
    padding:15px 34px;letter-spacing:.1em;transition:all .2s;border-radius:0;
  }
  .btn-primary{background:var(--ink);color:#fff}
  .btn-primary:hover{background:var(--indigo-deep)}
  .btn-ghost{color:var(--ink);border:1px solid var(--line);border-left:none}
  .btn-ghost:hover{border-color:var(--indigo);color:var(--indigo)}
  .inkline{position:absolute;right:-40px;top:50%;transform:translateY(-50%);z-index:1;pointer-events:none}
  @media(max-width:820px){.inkline{display:none}}

  section{padding:96px 0}
  .sec-head{display:flex;flex-direction:column;align-items:center;text-align:center;gap:12px;margin-bottom:54px}
  .sec-head .num{font-size:11px;letter-spacing:.3em;color:var(--indigo);font-weight:500}
  .sec-head .eng{font-family:"Zen Kaku Gothic New",sans-serif;font-weight:500;
    font-size:34px;letter-spacing:.14em;color:var(--indigo);line-height:1}
  .sec-head .sub{font-size:13px;letter-spacing:.1em;color:var(--indigo);font-weight:400}
  .journal-more{text-align:center;margin-top:38px}
  .journal-more a{font-size:12px;color:var(--indigo);text-decoration:none;letter-spacing:.08em;transition:opacity .2s}
  .journal-more a:hover{opacity:.6}
  #journal .sec-head .eng{font-size:26px;color:#6E7177;font-weight:400}
  #journal .sec-head .sub{color:#6E7177}

  .vision{border-top:1px solid var(--line);padding-top:44px}
  .vision p{font-size:16px;line-height:1.9;color:var(--ink-soft);max-width:680px;margin:0 auto;text-align:center;font-weight:400;letter-spacing:.02em}

  .contact-sec{padding:90px 0}
  .contact{display:flex;justify-content:space-between;align-items:center;gap:40px;flex-wrap:wrap;
    border-top:1px solid var(--ink);border-bottom:1px solid var(--ink);padding:54px 0}
  .contact .k{font-size:11px;letter-spacing:.36em;color:var(--indigo);font-weight:500;margin-bottom:18px}
  .contact h2{font-family:"Zen Kaku Gothic New",sans-serif;font-weight:500;font-size:22px;letter-spacing:.06em;margin-bottom:16px}
  .contact p{font-size:14px;color:var(--ink-soft);max-width:480px;line-height:2;font-weight:300}
  .contact-btn{display:inline-flex;align-items:center;background:var(--ink);color:#fff;text-decoration:none;
    padding:17px 38px;font-size:13.5px;letter-spacing:.1em;white-space:nowrap;transition:background .2s}
  .contact-btn:hover{background:var(--indigo-deep)}
  @media(max-width:680px){.contact{flex-direction:column;align-items:flex-start}}
  .sec-head h2{font-family:"Zen Kaku Gothic New",sans-serif;font-weight:500;font-size:20px;letter-spacing:.14em}
  .sec-head .more{margin:4px 0 0;font-size:12px;color:var(--indigo);text-decoration:none;letter-spacing:.08em}
  .sec-head .more:hover{color:var(--indigo-deep)}

  .articles{border-top:1px solid var(--ink)}
  .art{
    display:grid;grid-template-columns:120px 1fr auto;gap:32px;align-items:center;
    padding:30px 4px;border-bottom:1px solid var(--line);text-decoration:none;color:inherit;
    transition:padding-left .25s,background .2s;
  }
  .art:hover{background:var(--paper-2);padding-left:14px}
  .art .thumb{width:120px;height:78px;background:#DDE3F0;overflow:hidden;position:relative}
  .art .thumb span{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;color:#9AA8C8;font-size:10px;letter-spacing:.14em}
  .art .tag{font-size:10px;letter-spacing:.2em;color:var(--indigo);font-weight:500;margin-bottom:9px;text-transform:uppercase}
  .card-meta{display:flex;align-items:center;gap:9px;margin-bottom:9px}
  .card-meta .tag{margin-bottom:0}
  .new-badge{display:inline-block;font-family:"Zen Kaku Gothic New",sans-serif;font-size:9px;font-weight:700;letter-spacing:.14em;color:#fff;background:var(--indigo);padding:2px 7px;line-height:1.5}
  .art h3{font-family:"Zen Kaku Gothic New",sans-serif;font-weight:400;font-size:17px;line-height:1.65;color:var(--ink);letter-spacing:.02em}
  .art .date{font-size:12px;color:var(--mute);white-space:nowrap;letter-spacing:.08em}
  @media(max-width:680px){
    .art{grid-template-columns:90px 1fr;gap:18px}
    .art .date{display:none}
    .art .thumb{width:90px;height:62px}
  }

  .book{background:#26315A;color:#fff;padding:70px 64px;display:grid;grid-template-columns:1fr auto;gap:50px;align-items:center}
  .book .k{font-size:11px;letter-spacing:.36em;color:#8FA3D6;font-weight:500;margin-bottom:22px;text-transform:uppercase}
  .book h2{font-family:"Zen Kaku Gothic New",sans-serif;font-weight:500;font-size:24px;line-height:1.65;margin-bottom:22px;letter-spacing:.04em;color:#fff}
  .book p{font-size:14px;color:#C7CBD4;max-width:520px;line-height:2.15;font-weight:300}
  .book .reg{display:flex;flex-direction:column;gap:0;min-width:210px}
  .book .reg a{text-align:center;text-decoration:none;padding:15px 22px;font-size:13px;transition:all .2s;letter-spacing:.1em;border-radius:0}
  .reg .line{background:var(--indigo);color:#fff}
  .reg .line:hover{background:#fff;color:var(--ink)}
  .reg .mail{border:1px solid #3A3F49;border-top:none;color:#fff}
  .reg .mail:hover{background:#22252C}
  @media(max-width:820px){.book{grid-template-columns:1fr;padding:44px 34px}}

  .about{display:grid;grid-template-columns:150px 1fr;gap:44px;align-items:center}
  .about .face{width:150px;height:150px;border-radius:0;background:#DDE3F0;position:relative;overflow:hidden}
  .about .face span{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;color:#9AA8C8;font-size:11px;letter-spacing:.1em}
  .about .face img{width:100%;height:100%;object-fit:cover;display:block}
  .about h2{font-family:"Zen Kaku Gothic New",sans-serif;font-weight:500;font-size:19px;margin-bottom:18px;letter-spacing:.06em}
  .about p{font-size:14px;color:var(--ink-soft);line-height:2.15;max-width:620px;font-weight:300}
  .about .media{font-size:11px;color:var(--mute);margin-top:18px;letter-spacing:.12em;text-transform:uppercase}
  @media(max-width:680px){.about{grid-template-columns:1fr;text-align:center}.about .face{margin:0 auto}.about p{text-align:left}}

  footer{border-top:1px solid var(--ink);padding:64px 0 70px;margin-top:40px}
  .foot{display:flex;justify-content:space-between;flex-wrap:wrap;gap:40px}
  .foot .brand img{height:34px;display:block;margin-bottom:8px}
  .foot .cols{display:flex;gap:64px;flex-wrap:wrap}
  .foot .col a{display:block;font-size:13px;color:var(--ink-soft);text-decoration:none;margin-bottom:13px;letter-spacing:.06em}
  .foot .col a:hover{color:var(--indigo)}
  .foot .col .h{font-size:10px;letter-spacing:.24em;color:var(--mute);margin-bottom:18px}
  .copy{font-size:11px;color:var(--mute);margin-top:48px;letter-spacing:.1em}

  /* key concept — Variant A: colored text emphasis */
  .ink-em{position:relative;white-space:nowrap;color:var(--indigo);font-weight:700;letter-spacing:.04em}
  .ink-em .line-svg{display:none}

  /* contact form */
  .cform{display:grid;grid-template-columns:1fr 1fr;gap:18px 22px;margin-top:8px;max-width:640px;margin-left:auto;margin-right:auto}
  .cform .full{grid-column:1 / -1}
  .cform label{display:block;font-size:11px;letter-spacing:.16em;color:var(--mute);margin-bottom:8px}
  .cform input,.cform select,.cform textarea{
    width:100%;background:var(--paper);border:1px solid var(--line);border-radius:0;
    padding:13px 14px;font-family:inherit;font-size:14px;color:var(--ink);font-weight:300;transition:border-color .2s}
  .cform input:focus,.cform select:focus,.cform textarea:focus{outline:none;border-color:var(--indigo)}
  .cform textarea{resize:vertical;min-height:120px;line-height:1.8}
  .cform .submit{grid-column:1 / -1;justify-self:end;background:var(--ink);color:#fff;border:none;
    padding:16px 44px;font-size:13.5px;letter-spacing:.1em;cursor:pointer;transition:background .2s}
  .cform .submit:hover{background:var(--indigo-deep)}
  @media(max-width:680px){.cform{grid-template-columns:1fr}}
  .ripple-set circle{transform-origin:360px 300px;animation:rippleExpand 7s ease-out infinite}
  .ripple-set circle:nth-child(1){animation-delay:0s}
  .ripple-set circle:nth-child(2){animation-delay:.5s}
  .ripple-set circle:nth-child(3){animation-delay:1s}
  .ripple-set circle:nth-child(4){animation-delay:1.5s}
  .ripple-set circle:nth-child(5){animation-delay:2s}
  @keyframes rippleExpand{0%{transform:scale(.6);opacity:0}30%{opacity:1}100%{transform:scale(1.15);opacity:0}}
  @media(prefers-reduced-motion:reduce){.ripple-set circle{animation:none}}
  .art-news{grid-template-columns:1fr auto}
  .news .art{padding:24px 4px}
  .cform .req{display:inline-block;background:var(--indigo);color:#fff;font-size:9px;letter-spacing:.12em;padding:2px 7px;margin-left:6px;vertical-align:middle}
  .cform input.short{max-width:280px}

  /* About — wide photo with text overlay */
  .about-hero{position:relative;width:100%;aspect-ratio:16/8;overflow:hidden;border-radius:0}
  .about-bg{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:34% 20%}
  .about-overlay{position:absolute;inset:0;display:flex;flex-direction:column;justify-content:flex-end;align-items:flex-end;text-align:right;
    padding:48px 64px 48px 52px;background:linear-gradient(90deg, rgba(23,56,96,0) 0%, rgba(23,56,96,.14) 28%, rgba(23,56,96,.55) 58%, rgba(23,56,96,.82) 100%)}
  .about-overlay h2{font-family:"Zen Kaku Gothic New",sans-serif;font-weight:500;font-size:26px;
    letter-spacing:.06em;color:#fff;margin-bottom:18px;display:flex;align-items:baseline;gap:18px;justify-content:flex-end;text-shadow:0 1px 4px rgba(0,0,0,.85),0 2px 20px rgba(0,0,0,.7)}
  .about-overlay h2 span{font-size:13px;letter-spacing:.2em;color:#EAF0FA;font-weight:400;text-shadow:0 1px 4px rgba(0,0,0,.85),0 2px 16px rgba(0,0,0,.6)}
  .about-overlay p{font-size:14px;line-height:2.1;color:#fff;max-width:460px;font-weight:400;
    text-shadow:0 1px 3px rgba(0,0,0,.85),0 2px 18px rgba(0,0,0,.7);margin-left:auto;text-align:justify;text-justify:inter-character}
  .about-media{font-size:11px;color:#B9C0CC;margin-top:18px;letter-spacing:.1em}
  @media(max-width:680px){
    .about-hero{aspect-ratio:auto;border-radius:0;display:block}
    .about-bg{position:static;inset:auto;width:100%;height:auto;display:block;object-position:center}
    .about-overlay{position:static;inset:auto;padding:22px 2px 0;background:none;align-items:flex-start;text-align:left;display:block}
    .about-overlay h2{font-size:21px;color:var(--ink);text-shadow:none;flex-direction:column;gap:4px;align-items:flex-start;justify-content:flex-start;margin-bottom:14px}
    .about-overlay h2 span{color:var(--indigo-deep);text-shadow:none}
    .about-overlay p{margin-left:0;color:var(--ink-soft);text-shadow:none;font-size:13.5px;line-height:2.05;max-width:none;text-align:left;text-justify:auto}
  }
  .sns-icons{display:flex;gap:18px;margin-top:2px}
  .sns-icons a{color:var(--ink-soft);display:inline-flex;transition:color .2s,transform .2s}
  .sns-icons a:hover{color:var(--indigo);transform:translateY(-2px)}


/* ===== detail pages (Thoughts / News) ===== */
.d-wrap{max-width:740px;margin:0 auto;padding:0 32px}
.crumbs{font-size:11px;letter-spacing:.14em;color:var(--mute);margin:60px 0 30px}
.crumbs a{color:var(--mute);text-decoration:none}
.crumbs a:hover{color:var(--indigo)}
.crumbs span{margin:0 9px;color:var(--line)}
.d-head{margin-bottom:40px}
.d-meta{display:flex;align-items:center;gap:16px;margin-bottom:22px}
.d-meta .tag{font-size:10px;letter-spacing:.2em;color:#fff;background:var(--indigo);font-weight:500;text-transform:uppercase;padding:4px 11px}
.d-meta .date{font-size:12px;letter-spacing:.08em;color:var(--mute)}
.d-meta .d-ep{font-size:12px;letter-spacing:.3em;color:var(--indigo-deep);font-weight:500}
.d-meta .d-cat{font-size:11px;letter-spacing:.14em;color:var(--mute)}
.d-title{font-family:"Zen Kaku Gothic New",sans-serif;font-weight:500;font-size:clamp(23px,3.3vw,33px);line-height:1.6;letter-spacing:.03em;color:var(--ink)}
.d-cover{width:100%;aspect-ratio:16/9;background:#DDE3F0;position:relative;overflow:hidden;margin:40px 0 8px}
.d-cover img{width:100%;height:100%;object-fit:cover;display:block}
.d-body{margin-top:46px}
.d-body p{font-size:16px;line-height:2.2;color:var(--ink-soft);font-weight:400;letter-spacing:.02em;margin-bottom:30px}
.d-body h2{font-family:"Zen Kaku Gothic New",sans-serif;font-weight:500;font-size:20px;letter-spacing:.04em;color:var(--ink);line-height:1.6;margin:54px 0 24px}
.d-body h3{font-family:"Zen Kaku Gothic New",sans-serif;font-weight:500;font-size:17px;color:var(--ink);margin:40px 0 18px}
.d-body a{color:var(--indigo);text-underline-offset:3px}
.d-body ul,.d-body ol{margin:0 0 30px 1.4em}
.d-body li{font-size:16px;line-height:2.2;color:var(--ink-soft);font-weight:400;margin-bottom:8px}
.d-body img{max-width:100%;height:auto;display:block;margin:30px auto}
.d-body blockquote,.pullquote{margin:50px 0;padding:6px 0 6px 28px;border-left:2px solid var(--indigo);font-family:"Zen Kaku Gothic New",sans-serif;font-weight:500;font-size:19px;line-height:1.95;color:var(--ink);letter-spacing:.03em}
.d-body blockquote p{font-size:19px;color:var(--ink);font-weight:500;margin:0}
.d-share{display:flex;align-items:center;gap:18px;margin:56px 0 0;padding-top:30px;border-top:1px solid var(--line)}
.d-share .lab{font-size:10px;letter-spacing:.2em;color:var(--mute);text-transform:uppercase}
.d-info{border-top:1px solid var(--ink);margin:38px 0}
.d-info .row{display:grid;grid-template-columns:128px 1fr;border-bottom:1px solid var(--line)}
.d-info dt{font-size:12px;letter-spacing:.14em;color:var(--mute);padding:17px 0}
.d-info dd{font-size:14px;line-height:1.9;color:var(--ink-soft);padding:17px 0;font-weight:300}
.d-cta{margin:42px 0 0}
.d-cta a{display:inline-flex;align-items:center;gap:10px;background:var(--ink);color:#fff;text-decoration:none;padding:16px 40px;font-size:13.5px;letter-spacing:.1em;transition:background .2s}
.d-cta a:hover{background:var(--indigo-deep)}
.d-note{font-size:12px;color:var(--mute);margin-top:14px;letter-spacing:.04em;line-height:1.8}
.d-note a{color:var(--indigo);text-decoration:none}
.d-footnav{display:grid;grid-template-columns:1fr 1fr;gap:1px;background:var(--line);border-top:1px solid var(--ink);margin-top:60px}
.d-footnav a{background:var(--paper);padding:30px 26px;text-decoration:none;transition:background .2s}
.d-footnav a:hover{background:var(--paper-2)}
.d-footnav .dir{font-size:10px;letter-spacing:.2em;color:var(--indigo);text-transform:uppercase;margin-bottom:12px;display:block}
.d-footnav .ttl{font-family:"Zen Kaku Gothic New",sans-serif;font-weight:400;font-size:15px;line-height:1.6;color:var(--ink)}
.d-footnav .next{text-align:right}
.back-all{text-align:center;margin:60px 0 0}
.back-all a{font-size:13px;letter-spacing:.1em;color:var(--indigo);text-decoration:none;border:1px solid var(--line);padding:13px 30px;transition:all .2s;display:inline-block}
.back-all a:hover{border-color:var(--indigo);background:var(--paper-2)}
/* 読み進めナビ（＜前のページ ／ 次のページ＞） */
.page-nav{display:flex;justify-content:space-between;align-items:flex-start;gap:24px;margin-top:48px;border-top:1px solid var(--line);padding-top:26px}
.page-nav a{display:flex;flex-direction:column;gap:8px;max-width:47%;text-decoration:none;transition:opacity .2s}
.page-nav a:hover{opacity:.6}
.page-nav .pn-prev{text-align:left;align-items:flex-start}
.page-nav .pn-next{text-align:right;align-items:flex-end;margin-left:auto}
.page-nav .pn-lab{font-family:"Zen Kaku Gothic New",sans-serif;font-size:12px;letter-spacing:.08em;color:var(--indigo-deep);font-weight:500}
.page-nav .pn-ttl{font-size:14px;line-height:1.55;letter-spacing:.02em;color:var(--ink-soft);font-weight:400}
.page-nav > span{display:inline-block}
@media(max-width:680px){
  .page-nav{flex-direction:column;gap:22px}
  .page-nav a{max-width:100%}
  .page-nav .pn-next{text-align:left;align-items:flex-start;margin-left:0}
}
.essay-cta{max-width:560px;margin:52px auto 0;text-align:center}
.essay-cta .ec-lead{font-size:13px;line-height:1.9;color:var(--mute);font-weight:400;letter-spacing:.04em;margin:0 0 13px}
.essay-cta .ec-strong{color:var(--ink-soft);font-weight:500}
.essay-cta .ec-btn{display:inline-flex;align-items:center;gap:7px;color:var(--indigo-deep);font-size:14px;font-weight:500;letter-spacing:.06em;text-decoration:none;transition:opacity .2s}
.essay-cta .ec-btn:hover{opacity:.55}
.essay-cta .ec-btn svg{width:17px;height:17px;fill:#06C755}
/* TOPの入口（蝶番：書き出しだけで惹く・最小構成） */
.read-start{display:block;max-width:600px;margin:0 auto;text-decoration:none;text-align:left}
.read-start .rs-head{display:block;margin-bottom:28px}
.read-start .rs-no{display:block;font-size:12px;letter-spacing:.3em;color:var(--indigo-deep);font-weight:500;margin-bottom:12px}
.read-start .rs-title{font-family:"Zen Kaku Gothic New",sans-serif;font-weight:500;font-size:21px;line-height:1.55;letter-spacing:.04em;color:var(--ink);margin:0}
@media(max-width:680px){.read-start .rs-title{font-size:19px}}
.read-start .rs-excerpt{font-family:"Zen Kaku Gothic New",sans-serif;font-weight:400;font-size:16px;line-height:2.15;color:var(--ink);letter-spacing:.02em}
.read-start .rs-go{font-size:14px;font-weight:500;letter-spacing:.1em;color:var(--indigo-deep);white-space:nowrap;margin-left:.6em;transition:opacity .2s}
.read-start:hover .rs-go{opacity:.5}
@media(max-width:680px){.read-start .rs-excerpt{font-size:15px;line-height:2.05}}
@media(max-width:680px){.d-footnav{grid-template-columns:1fr}}
@media(max-width:560px){.d-info .row{grid-template-columns:92px 1fr}}
/* featured-image thumbnails in list views */
.art .thumb img{width:100%;height:100%;object-fit:cover;display:block}
/* WordPress custom-logo (so a logo can be swapped from the admin) */
.brand .custom-logo-link{display:block}
.brand .custom-logo,.brand .custom-logo-link img{height:40px;width:auto;display:block}
.archive-head{padding-top:54px}
#book{margin-top:96px}

/* contact form messages */
.cform-msg{max-width:640px;margin:0 auto 24px;padding:14px 18px;font-size:13px;letter-spacing:.02em;text-align:center;line-height:1.7}
.cform-msg.ok{background:#EAF0FA;color:#33478A;border:1px solid #B9C8E8}
.cform-msg.err{background:#FBEEEE;color:#9A3B3B;border:1px solid #E6C5C5}

/* --- mobile fixes --- */
.tagline br{display:none}
.cform input.short{max-width:100%}
.menu-toggle{display:none}
@media(max-width:680px){
  .tagline br{display:none}
  .tagline .tl-c{display:inline}
  .tagline{font-size:11px;letter-spacing:.16em}
  .ink-em{white-space:normal}
  .brand-tag{gap:7px}
  header .nav{flex-direction:column;align-items:center;gap:13px;height:auto;padding:16px 0}
  .menu-toggle{display:none}
  .menu{display:flex;position:static;flex-direction:row;flex-wrap:wrap;justify-content:center;gap:7px 20px;background:none;backdrop-filter:none;border:none;box-shadow:none;padding:0}
  .menu a{font-size:12.5px;letter-spacing:.06em;padding:3px 2px;border:none}
  .menu a:last-child{border-bottom:none}
}

/* About — role line under the name */
.about-overlay .about-role{font-size:13px;letter-spacing:.12em;color:#EAF0FA;font-weight:700;max-width:460px;margin:-8px 0 18px auto;text-align:right;text-shadow:0 1px 4px rgba(0,0,0,.85),0 2px 16px rgba(0,0,0,.6)}

/* Credentials — top-rule labels, small caption over a larger value */
#about{padding-top:96px}
.about-row{display:flex;gap:46px;align-items:center}
.about-photo{flex:0 0 36%;max-width:330px}
.about-photo img{width:100%;height:auto;display:block;border-radius:2px}
.about-text{flex:1;padding-top:4px}
.about-text h2{font-family:"Zen Kaku Gothic New",sans-serif;font-weight:500;font-size:26px;color:var(--ink);display:flex;align-items:baseline;gap:13px;margin:0 0 9px;line-height:1.3}
.about-text h2 span{font-size:13px;letter-spacing:.2em;color:var(--indigo-deep);font-weight:400}
.about-text .about-role{font-size:13px;letter-spacing:.08em;color:var(--indigo-deep);font-weight:500;margin:0 0 20px}
.about-text p{font-size:17px;line-height:2.45;color:var(--ink-soft);font-weight:400;margin:0 0 20px}
.about-text p:last-child{margin-bottom:0}
.creds{display:grid;grid-template-columns:repeat(4,1fr);gap:0 26px;max-width:720px;margin:44px auto 0}
.cred{text-align:center;padding-top:13px;border-top:1.5px solid var(--indigo)}
.cred .t{display:block;font-family:"Zen Kaku Gothic New",sans-serif;font-weight:500;font-size:12.5px;letter-spacing:.03em;color:var(--indigo);line-height:1.35}
.cred .b{display:block;font-family:"Zen Kaku Gothic New",sans-serif;font-weight:500;font-size:16px;letter-spacing:.04em;color:var(--indigo-deep);line-height:1.3;margin-top:3px}

/* tighten first view + overall rhythm on phones */
@media(max-width:680px){
  section{padding:58px 0}
  .hero{padding:42px 0 34px}
  .hero-photo{padding:0}
  .hero-photo .wrap{bottom:13%;padding-bottom:0}
  .hero-photo h1{line-height:1.95}
  .hero .wrap{padding:0 22px}
  .hero h1{font-size:clamp(11px,3.7vw,15px);line-height:1.95;margin-bottom:0}
  .about-overlay .about-role{color:var(--ink-soft);text-shadow:none;text-align:left;margin:1px 0 18px;font-size:13.5px;letter-spacing:.08em}
  .about-overlay p + p{margin-top:15px}
  .about-row{flex-direction:column;gap:20px}
  #about{padding-top:52px}
  .about-photo{flex:none;max-width:280px;width:100%;margin:0 auto}
  .about-text{padding-top:0}
  .about-text h2{font-size:21px;flex-direction:column;align-items:flex-start;gap:5px;margin-bottom:12px}
  .about-text .about-role{margin:0 0 16px;font-size:13px}
  .about-text p{font-size:13.5px;line-height:2.05}
  .creds{grid-template-columns:1fr 1fr;gap:26px 16px;max-width:330px;margin:32px auto 0}
  .cred{padding-top:12px}
  .cred .t{font-size:12px;letter-spacing:.02em;line-height:1.4;white-space:nowrap}
  .cred .b{font-size:16px;letter-spacing:.02em;line-height:1.3;margin-top:3px;white-space:nowrap}
  .vision p{font-size:15px;letter-spacing:0;line-height:1.95}
}

.vision-lead{font-family:"Zen Kaku Gothic New",sans-serif;font-weight:500;font-size:clamp(16px,1.9vw,19px);line-height:1.8;letter-spacing:.04em;color:var(--ink);text-align:center;max-width:760px;margin:-18px auto 42px}
.vision-lead .nb{white-space:nowrap}

/* Vision 締めの一行：拡大＋スクロールイン演出 */
.vision .v-fin{display:inline-block;font-size:1.4em;font-weight:500;color:var(--indigo-deep);letter-spacing:.06em;white-space:nowrap;transform-origin:center}
.sy-js .vision .v-fin{opacity:0;transform:translateY(10px)}
.sy-js .vision .v-fin.in{opacity:1;transform:translateY(0);transition:opacity .9s ease,transform .9s cubic-bezier(.22,.61,.36,1)}
@media (prefers-reduced-motion: reduce){.sy-js .vision .v-fin{opacity:1;transform:none;transition:none}}

/* Contact — services offered */
.services-cap{text-align:center;font-size:11px;letter-spacing:.28em;color:var(--mute);margin:0 0 16px}
.services{display:flex;flex-wrap:wrap;justify-content:center;align-items:center;gap:8px 0;list-style:none;max-width:680px;margin:0 auto 40px;padding:0}
.services li{font-family:"Zen Kaku Gothic New",sans-serif;font-weight:500;font-size:13px;letter-spacing:.05em;color:var(--indigo-deep);padding:0 17px;position:relative;line-height:1.6}
.services li:not(:first-child)::before{content:"";position:absolute;left:0;top:50%;transform:translateY(-50%);width:1px;height:12px;background:var(--line)}
@media(max-width:680px){
  .services{flex-direction:column;gap:11px;margin-bottom:34px}
  .services li{padding:0;font-size:13.5px}
  .services li:not(:first-child)::before{display:none}
}
