@charset "UTF-8";
/* 中村真紀公式サイト — 非WordPress版 共通スタイル
   元サイト(WordPress+Elementor)のデザインを踏襲してクリーンに書き直し。
   白基調・縦書きの装飾見出し・やわらかなパステルのブロブが特徴。 */

:root{
  --accent:#c9a44e;          /* ゴールド系アクセント */
  --accent-deep:#b08a3a;
  --ink:#33302a;             /* 見出し */
  --text:#5a564e;            /* 本文 */
  --text-soft:#8c887e;
  --line:#ece7db;
  --note-btn:#d178d6;
  --bg:#ffffff;
  --maxw:900px;        /* 本文 */
  --maxw-wide:1140px;  /* PCの基準幅 */
  --serif:"Noto Serif JP",serif;
  --sans:"Noto Sans JP","Hiragino Kaku Gothic ProN",system-ui,sans-serif;
}

*{box-sizing:border-box}
html{-webkit-text-size-adjust:100%}
body{
  margin:0;font-family:var(--serif);color:var(--text);background:var(--bg);
  line-height:2.05;font-size:16px;font-weight:400;letter-spacing:.03em;
  -webkit-font-smoothing:antialiased;overflow-x:hidden;
}
img{max-width:100%;height:auto;display:block}
a{color:inherit;text-decoration:none}
p{margin:0 0 1.5em}

/* ====================== やわらかいグラデ背景（ヒーロー/フッター） ====================== */
/* 原サイト my-gradient-bg：4色パステルを background-position でゆっくり流す自動アニメ */
.gradient-bg{
  position:relative;
  background:linear-gradient(135deg,#fde8ef,#e8f0fd,#fde8f5,#e8f5fd);
  background-size:400% 400%;
  animation:gradientFlow 20s ease infinite;
}
.gradient-bg.green{
  background:linear-gradient(135deg,#e9f6ee,#e8f0fd,#f1faf3,#e8f5fd);
  background-size:400% 400%;
  animation:gradientFlow 20s ease infinite;
}
@keyframes gradientFlow{
  0%{background-position:0% 50%}25%{background-position:100% 50%}
  50%{background-position:100% 0%}75%{background-position:0% 100%}100%{background-position:0% 50%}
}
@media(prefers-reduced-motion:reduce){
  .gradient-bg,.orb,.orb::before,.orbbg::before,.orb-pink,.orb-pink::before{animation:none}
}

/* ====================== 波形ディバイダ ====================== */
.wave{display:block;width:100%;height:70px;line-height:0;margin:0}
.wave svg{display:block;width:100%;height:100%}
.wave-flip svg{transform:rotate(180deg)}

/* ====================== ヘッダー（固定ハンバーガー） ====================== */
.menu-toggle{
  position:fixed;top:22px;right:22px;z-index:120;width:52px;height:52px;border:none;border-radius:50%;
  background:rgba(255,255,255,.8);backdrop-filter:blur(6px);box-shadow:0 4px 18px rgba(80,60,20,.14);
  cursor:pointer;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:5px;transition:background .25s;
}
.menu-toggle:hover{background:#fff}
.menu-toggle span{display:block;width:22px;height:2px;background:var(--ink);transition:.3s}
body.nav-open .menu-toggle span:nth-child(1){transform:translateY(7px) rotate(45deg)}
body.nav-open .menu-toggle span:nth-child(2){opacity:0}
body.nav-open .menu-toggle span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

.nav-overlay{
  position:fixed;inset:0;z-index:110;
  background:radial-gradient(ellipse 600px 500px at 15% 20%, rgba(253,230,138,.4) 0%, transparent 70%),linear-gradient(135deg,#fdeef3,#eef3fd,#fdeff7,#eef6fd);
  backdrop-filter:blur(3px);opacity:0;visibility:hidden;transition:opacity .35s,visibility .35s;
  display:flex;align-items:center;justify-content:center;overflow-y:auto;padding:80px 24px;
}
body.nav-open .nav-overlay{opacity:1;visibility:visible}
.nav-overlay nav{text-align:center;max-width:520px;width:100%}
.nav-overlay .site-name{font-size:13px;letter-spacing:.32em;color:var(--text-soft);margin-bottom:34px}
.nav-overlay ul{list-style:none;margin:0;padding:0}
.nav-overlay li{margin:0;opacity:0;transform:translateY(12px)}
body.nav-open .nav-overlay li{animation:navin .5s forwards}
.nav-overlay a{display:inline-block;font-family:var(--serif);font-size:20px;color:var(--ink);padding:11px 0;letter-spacing:.1em;transition:color .25s}
.nav-overlay a:hover{color:var(--accent-deep)}
.nav-overlay a.ext::after{content:"↗";font-size:.7em;margin-left:6px;color:var(--text-soft)}
.nav-overlay .accent a{color:var(--accent-deep);font-weight:500}
@keyframes navin{to{opacity:1;transform:none}}

/* ====================== フローティング まきりんボタン ====================== */
.maki-float{position:fixed;left:29px;bottom:38px;z-index:90;width:195px;height:auto;transition:transform .3s;animation:floatin .6s .8s both;filter:drop-shadow(0 6px 16px rgba(80,60,20,.18))}
.maki-float:hover{transform:translateY(-5px) rotate(-2deg)}
@keyframes floatin{from{opacity:0;transform:translateY(30px)}to{opacity:1}}
@media(max-width:600px){.maki-float{width:130px;left:14px;bottom:14px}}

/* ====================== 縦書き装飾見出し ====================== */
.tate{
  writing-mode:vertical-rl;font-family:var(--serif);font-weight:400;
  letter-spacing:.068em;line-height:1.05;color:#000;          /* 原サイト：黒・字間5.4px相当 */
  user-select:none;pointer-events:none;white-space:nowrap;
}

/* ====================== ヒーロー ====================== */
.hero{position:relative;padding:124px 24px 36px;text-align:center}
.hero.full{min-height:100vh;min-height:100svh;display:flex;align-items:flex-start;justify-content:center;padding:13vh 24px 60px}
/* 2列の縦書きキャッチ（右列＝第一フレーズ、左列＝第二フレーズ）。各列は折り返さない */
.hero-tate{display:flex;flex-direction:row-reverse;justify-content:center;align-items:flex-start;gap:.25em;margin:0 auto;animation:fadeup 1.2s .2s both}
.hero-tate span{writing-mode:vertical-rl;font-family:var(--serif);font-weight:400;font-size:27px;letter-spacing:.2em;line-height:1.37;color:#000;white-space:nowrap}
@media(max-width:600px){.hero-tate span{font-size:21px}}
.hero .page-head{animation:fadeup 1s .1s both}
.hero h1{font-family:var(--serif);font-weight:600;color:var(--ink);font-size:clamp(27px,4.6vw,38px);letter-spacing:.12em;margin:.2em 0 .6em;line-height:1.5}
.hero .intro{max-width:620px;margin:0 auto;color:var(--text);font-size:15.5px;line-height:2.15;white-space:pre-line}
@keyframes fadeup{from{opacity:0;transform:translateY(18px)}to{opacity:1;transform:none}}

/* ====================== コンテンツ（白基調） ====================== */
main{display:block}
.section{position:relative;padding:74px 24px}
.section.tight{padding:54px 24px}
.wrap{max-width:var(--maxw);margin:0 auto;position:relative;z-index:2}
.wrap-wide{max-width:var(--maxw-wide);margin:0 auto;position:relative;z-index:2}

.eyebrow{display:block;text-align:center;color:var(--accent-deep);font-size:12px;letter-spacing:.34em;margin-bottom:10px}
h2.sec-title{font-family:var(--serif);font-weight:600;color:var(--ink);font-size:clamp(21px,3vw,27px);text-align:center;letter-spacing:.1em;line-height:1.6;margin:0 0 8px}
.sec-title + .sec-sub{text-align:center;color:var(--text-soft);font-size:14px;margin:-2px 0 30px}
.rule{width:42px;height:2px;background:var(--accent);margin:18px auto 34px;border:0}

/* 原サイトの大見出し（日々の探求・まきからのお知らせ＝59px中央 / ようこそ＝20px / 最新記事＝20px小） */
.title-lg{font-family:var(--serif);font-weight:400;color:#000;font-size:clamp(34px,5.4vw,59px);text-align:center;line-height:1.2;letter-spacing:.06em;margin:0 0 14px}
.title-sm{font-family:var(--serif);font-weight:500;color:#000;font-size:21px;text-align:center;letter-spacing:.06em;margin:0 0 10px}
.title-latest{font-family:var(--serif);font-weight:500;color:#000;font-size:18px;text-align:left;letter-spacing:.06em;margin:34px 0 6px}
.sec-intro{text-align:center;color:#555;font-size:15px;line-height:2;margin:0 auto 6px;max-width:760px}
.hr-line{border:0;border-top:1px solid var(--line);margin:14px 0 26px}
@media(max-width:600px){.title-lg{font-size:32px}}

/* 原サイト your-container3：ピンク系オーブの全幅モーフィングコンテナ（3つのフィールド本文） */
.orb-pink{position:relative;overflow:hidden;max-width:var(--maxw-wide);margin:0 auto;padding:84px 90px;animation:morphContainer2 22s ease-in-out infinite alternate}
.orb-pink > *{position:relative;z-index:1}
.orb-pink::before{content:"";position:absolute;inset:-6%;z-index:0;filter:blur(56px);
  background:
    radial-gradient(ellipse 560px 480px at 20% 30%, #cca6bf 0%, transparent 70%),
    radial-gradient(ellipse 460px 520px at 80% 70%, #cc4f93 0%, transparent 70%),
    radial-gradient(ellipse 380px 340px at 55% 45%, #f0b0b6 0%, transparent 70%);
  animation:orbMove2 24s ease-in-out infinite alternate}
@media(max-width:720px){.orb-pink{padding:54px 30px}}

.prose{font-size:15.5px;line-height:2.25;color:var(--text)}
.prose h3{font-family:var(--serif);font-weight:600;color:var(--ink);font-size:18px;letter-spacing:.06em;margin:2em 0 .6em}
.prose p{margin:0 0 1.6em}
.prose .dateline{text-align:right;color:var(--text-soft);font-size:14px}
.prose ul{padding-left:1.2em;margin:0 0 1.6em}
.prose li{margin:.3em 0}
.prose a.inline{color:var(--accent-deep);font-weight:500;border-bottom:1px solid rgba(201,164,78,.4)}
.prose a.inline:hover{border-color:var(--accent-deep)}

.arrow-link{display:inline-block;margin-top:.4em;color:var(--accent-deep);font-weight:500;letter-spacing:.05em}
.arrow-link::before{content:"→ "}
.arrow-link:hover{color:var(--ink)}

/* ====================== モーフィングする背景の丸（オーブ）— 原サイト踏襲 ====================== */
.blob-wrap{max-width:var(--maxw-wide);margin:0 auto;position:relative;z-index:2}
.orb{position:relative;overflow:hidden;width:700px;max-width:100%;margin:0;padding:96px 80px;background:transparent;text-align:center}
.orb.peach{margin-right:auto}             /* 左上 */
.orb.green{margin-left:auto;margin-top:-72px}  /* 右下・重なり */
.orb > *{position:relative;z-index:1}
.orb::before{content:"";position:absolute;inset:-16%;z-index:0;filter:blur(52px)}
.orb.peach{animation:morphContainer 16s ease-in-out infinite alternate}
.orb.peach::before{
  background:
    radial-gradient(ellipse 560px 460px at 10% 20%, #fde68a 0%, transparent 70%),
    radial-gradient(ellipse 460px 500px at 90% 80%, #fb923c 0%, transparent 70%),
    radial-gradient(ellipse 360px 320px at 50% 50%, #fcd34d 0%, transparent 70%);
  opacity:.58;animation:orbColor 16s ease-in-out infinite alternate;
}
.orb.green{animation:morphContainer2 20s ease-in-out infinite alternate}
.orb.green::before{
  background:
    radial-gradient(ellipse 560px 460px at 20% 30%, #a8d5b5 0%, transparent 70%),
    radial-gradient(ellipse 460px 500px at 80% 70%, #f4c48e 0%, transparent 70%),
    radial-gradient(ellipse 360px 320px at 55% 45%, #c9e8d6 0%, transparent 70%);
  animation:orbMove2 24s ease-in-out infinite alternate;
}
.orb h3{font-family:var(--serif);font-weight:400;color:#000;font-size:20px;line-height:1.8;margin:0 0 18px;letter-spacing:.04em}
.orb p{font-size:16px;line-height:2;color:#2c2820;margin:0 0 .8em;text-align:left}
.orb .arrow-link{color:#7e6433}
.orb .arrow-link:hover{color:#4f4022}
.blob-wrap{position:relative}
@media(max-width:1024px){.orb{width:100%;margin:0 0 26px!important;padding:64px 40px}}

@keyframes morphContainer{
  0%{border-radius:60% 40% 70% 30% / 50% 60% 40% 50%}
  25%{border-radius:40% 60% 30% 70% / 60% 40% 70% 30%}
  50%{border-radius:70% 30% 50% 50% / 40% 70% 30% 60%}
  75%{border-radius:30% 70% 60% 40% / 50% 30% 60% 40%}
  100%{border-radius:60% 40% 70% 30% / 50% 60% 40% 50%}
}
@keyframes morphContainer2{
  0%{border-radius:50% 50% 60% 40% / 60% 40% 50% 50%}
  25%{border-radius:65% 35% 45% 55% / 40% 65% 35% 60%}
  50%{border-radius:40% 60% 55% 45% / 55% 45% 65% 35%}
  75%{border-radius:55% 45% 35% 65% / 45% 55% 40% 60%}
  100%{border-radius:50% 50% 60% 40% / 60% 40% 50% 50%}
}
@keyframes orbColor{
  0%{filter:blur(52px) hue-rotate(0deg)}
  50%{filter:blur(52px) hue-rotate(30deg)}
  100%{filter:blur(52px) hue-rotate(-20deg)}
}
@keyframes orbMove2{
  0%{background-position:20% 30%,80% 70%,55% 45%;opacity:.5}
  33%{background-position:40% 60%,60% 40%,45% 65%;opacity:.62}
  66%{background-position:65% 20%,35% 80%,50% 35%;opacity:.54}
  100%{background-position:25% 75%,75% 25%,50% 50%;opacity:.58}
}

/* セクション全面のやわらかいオーブ背景（3つのフィールド等） */
.orbbg{position:relative;overflow:hidden}
.orbbg::before{content:"";position:absolute;inset:0;z-index:0;filter:blur(60px);opacity:.42;
  background:
    radial-gradient(ellipse 620px 500px at 18% 28%, #cca6bf 0%, transparent 70%),
    radial-gradient(ellipse 480px 540px at 82% 72%, #cc6699 0%, transparent 70%),
    radial-gradient(ellipse 380px 320px at 55% 48%, #f0b0b6 0%, transparent 70%);
  animation:orbMove2 26s ease-in-out infinite alternate}
.orbbg .wrap,.orbbg .wrap-wide{position:relative;z-index:2}

/* 縦書き見出しを横に添える装飾セクション */
.deco{position:relative;overflow:hidden}
.deco .tate-side{position:absolute;top:48px;font-size:79px;z-index:1}
.deco .tate-side.r{right:5%}
.deco .tate-side.l{left:5%}
@media(max-width:980px){.deco .tate-side{font-size:54px;opacity:.12}.deco .tate-side.r{right:2%}.deco .tate-side.l{left:2%}}

/* ====================== ライフストーリー：アニメーション波背景（原サイト踏襲） ====================== */
.story{position:relative;background:#fff;padding:128px 24px 84px}
.story .wave-anim{position:absolute;top:0;left:0;width:100%;height:360px;z-index:0;pointer-events:none;overflow:hidden}
.story .wave-anim svg{position:absolute;top:0;left:0;width:100%;height:100%}
.story .story-inner{position:relative;max-width:var(--maxw-wide);margin:0 auto;z-index:2}
.story .tate-title{position:absolute;top:-190px;left:max(6px,calc(50% - 532px));font-size:80px;color:#000;z-index:3}
.story .story-body{max-width:884px;margin:0 auto;padding-left:30px;font-size:15px;line-height:2.2}
@media(max-width:980px){.story .tate-title{left:0;top:-50px;font-size:60px}.story .story-body{margin:0 0 0 auto;padding-left:70px;max-width:700px}}

/* 3つのフィールド見出し（横書き・右寄せ・大） */
.fields-title{font-family:var(--serif);font-weight:400;color:#000;font-size:clamp(34px,5.4vw,59px);text-align:right;line-height:1.1;letter-spacing:.05em;margin:0 0 34px}
@media(max-width:600px){.fields-title{font-size:32px}}

.catch{text-align:center;font-size:clamp(18px,2.6vw,22px);color:var(--ink);font-weight:500;line-height:1.95;letter-spacing:.08em;margin:0 auto 1.6em;max-width:680px}

/* ====================== 2カラム カードグリッド ====================== */
.cards{display:grid;grid-template-columns:repeat(2,1fr);gap:34px;margin-top:8px}
.card{background:#fff;border:1px solid var(--line);border-radius:16px;padding:30px 28px;box-shadow:0 8px 30px rgba(120,100,50,.05)}
.card img.thumb{width:100%;max-width:200px;margin:0 auto 18px;border-radius:12px}
.card h3{font-family:var(--serif);font-weight:600;color:var(--ink);font-size:17.5px;letter-spacing:.04em;line-height:1.6;margin:0 0 14px;text-align:center}
.card .body{font-size:14.5px;line-height:2.05;color:var(--text)}
.card .body p{margin:0 0 1em}
@media(max-width:720px){.cards{grid-template-columns:1fr;gap:24px}}

/* ====================== タイムライン（ライフストーリー） ====================== */
.timeline{position:relative;max-width:var(--maxw-wide);margin:10px auto 0;padding:10px 0}
.timeline::before{content:"";position:absolute;left:50%;top:0;bottom:0;width:2px;background:linear-gradient(var(--accent),rgba(201,164,78,.2));transform:translateX(-50%)}
.tl-item{position:relative;width:50%;padding:0 50px 50px}
.tl-item:nth-child(odd){left:0;text-align:right}
.tl-item:nth-child(even){left:50%;text-align:left}
.tl-item .dot{position:absolute;top:6px;width:14px;height:14px;border-radius:50%;background:#fff;border:3px solid var(--accent)}
.tl-item:nth-child(odd) .dot{right:-7px}
.tl-item:nth-child(even) .dot{left:-7px}
.tl-chapter{color:var(--accent-deep);font-size:12.5px;letter-spacing:.18em;margin-bottom:4px}
.tl-card{display:block;width:100%;text-align:left;background:#fff;border:1px solid var(--line);border-radius:14px;padding:26px 30px;box-shadow:0 8px 28px rgba(120,100,50,.06)}
.tl-card h3{font-family:var(--serif);font-weight:600;color:var(--ink);font-size:17px;margin:0 0 12px;letter-spacing:.04em}
.tl-card p{font-size:14.5px;line-height:2.05;margin:0 0 1em;color:var(--text)}
.tl-card p:last-child{margin-bottom:0}
@media(max-width:720px){.timeline::before{left:18px}.tl-item{width:100%;left:0!important;text-align:left!important;padding:0 0 38px 44px}.tl-item .dot{left:11px!important;right:auto!important}}

/* ====================== Note記事リスト ====================== */
.note-list{width:100%;margin:0 auto}
.note-item{border-top:1px solid var(--line);padding:30px 4px;display:flex;flex-direction:column;align-items:flex-start}
.note-item:last-child{border-bottom:1px solid var(--line)}
.note-item h3{font-family:var(--serif);font-weight:600;color:var(--ink);font-size:18px;margin:0 0 12px;letter-spacing:.03em}
.note-item .excerpt{font-size:14.5px;line-height:2;color:var(--text-soft);margin:0 0 16px}
.note-btn{display:inline-block;background:var(--note-btn);color:#fff;font-size:13px;letter-spacing:.08em;padding:9px 22px;border-radius:30px;transition:opacity .25s;align-self:flex-end}
.note-btn:hover{opacity:.85}

/* まきからのお知らせ（投稿リスト） */
.article{border-top:1px solid var(--line);padding:26px 4px}
.article:last-child{border-bottom:1px solid var(--line)}
.article h4{font-family:var(--serif);font-weight:500;color:#000;font-size:18px;margin:0 0 10px;letter-spacing:.03em;line-height:1.7}
.article .ex{font-size:14px;line-height:1.95;color:var(--text-soft);margin:0 0 8px}
.article .more{font-size:13px;color:var(--accent-deep);letter-spacing:.04em}
.article .more:hover{color:var(--ink)}

/* ====================== お問い合わせフォーム ====================== */
.form-box{max-width:560px;margin:0 auto}
.field{margin-bottom:20px}
.field label{display:block;font-size:14px;color:var(--ink);margin-bottom:7px;letter-spacing:.05em}
.field label .req{color:#c0673f;font-size:12px;margin-left:6px}
.field input,.field textarea{width:100%;font-family:var(--sans);font-size:15px;color:var(--ink);padding:13px 15px;border:1px solid var(--line);border-radius:10px;background:#fdfcf9;transition:border-color .2s,box-shadow .2s}
.field input:focus,.field textarea:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px rgba(201,164,78,.15)}
.field textarea{resize:vertical;min-height:130px;line-height:1.9}
.btn-primary{display:inline-block;width:100%;border:none;cursor:pointer;background:var(--accent);color:#fff;font-family:var(--serif);font-size:16px;letter-spacing:.14em;padding:15px;border-radius:10px;transition:background .25s}
.btn-primary:hover{background:var(--accent-deep)}
.form-note{font-size:14px;color:var(--text-soft);text-align:center;margin-bottom:30px}
.alert{padding:15px 18px;border-radius:10px;margin-bottom:24px;font-size:14.5px;line-height:1.8}
.alert.ok{background:#eef7ef;border:1px solid #cfe6cf;color:#3c6b41}
.alert.err{background:#fbeeea;border:1px solid #f0cfc4;color:#a85138}

/* ====================== フッター ====================== */
.site-footer{position:relative;padding:96px 24px 36px;text-align:center;overflow:hidden}
.footer-wave{position:absolute;top:0;left:0;width:100%;line-height:0}
.footer-wave .wave{height:64px}
.footer-nav{display:flex;flex-wrap:wrap;justify-content:center;gap:12px 24px;max-width:var(--maxw-wide);margin:0 auto 26px}
.footer-nav a{white-space:nowrap}
.footer-nav a{font-size:14px;color:var(--ink);letter-spacing:.05em;transition:color .2s}
.footer-nav a:hover{color:var(--accent-deep)}
.copyright{font-size:12px;color:var(--text-soft);letter-spacing:.08em}

.center{text-align:center}
.mt0{margin-top:0}

/* ====================== スマホ最適化 ====================== */
@media(max-width:680px){
  body{font-size:15px;line-height:1.95}
  .section{padding:52px 20px}
  .section.tight{padding:40px 20px}
  .hero.full{padding:16vh 20px 60px}
  h2.sec-title{font-size:20px}
  .prose{font-size:14.5px}
  /* ２つの指針：丸は縦積み・余白控えめ */
  .orb{padding:54px 30px}
  .orb h3{font-size:18px;line-height:1.7}
  .orb p{font-size:14.5px}
  .deco .tate-side{font-size:44px}
  /* ライフストーリーteaser：見出しを横書きにして上に */
  .story{padding:90px 20px 60px}
  .story .tate-title{position:static;writing-mode:horizontal-tb;font-size:30px;letter-spacing:.08em;color:#000;margin:0 0 12px;display:block}
  .story .story-body{margin:0;padding-left:0;max-width:none}
  /* 3つのフィールド見出し */
  .fields-title{font-size:30px}
  /* タイムライン余白 */
  .tl-card{padding:22px 22px}
  .tl-item{padding:0 0 34px 40px}
  /* ヒーロー縦書き2列 */
  .hero-tate{gap:.2em}
  .hero-tate span{font-size:20px}
  /* フォーム・カード */
  .cards{gap:20px}
  .card{padding:26px 22px}
}
@media(max-width:400px){
  .hero-tate span{font-size:18px}
  .orb{padding:46px 24px}
}
