/* 真似元: recruit.ito-noen.co.jp/
   観察: 和紙クリーム背景 (#f7f1e2 系) + 黄色みかんアクセント (#f6d23a) +
        散らされた手描き葉モチーフ + 写真は中央に小ぶりにフローティング配置 +
        セクション間が大きな余白 (上下400-600px) +
        英字見出しは小さく薄く、和文見出しを主軸に。
        ナビは上部固定、右に CORPORATE SITE ボタン。
*/
@import url('./fonts.css');

*,*::before,*::after{box-sizing:border-box}
html,body{margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  font-family:var(--p14-font-jp);
  font-weight:400;
  color:#2a2a2a;
  background:#f7f1e2;
  line-height:1.9;
  font-size:14px;
  letter-spacing:0.04em;
  -webkit-font-smoothing:antialiased;
}
img{max-width:100%;display:block;height:auto}
a{color:inherit;text-decoration:none}
button{font:inherit;cursor:pointer;border:0;background:transparent;color:inherit}

/* 和紙テクスチャ風背景 - 微細なノイズ */
body::before{
  content:'';position:fixed;inset:0;z-index:-1;pointer-events:none;
  background:
    radial-gradient(800px 600px at 12% 8%, rgba(246,210,58,.10), transparent 60%),
    radial-gradient(900px 700px at 92% 35%, rgba(238,184,40,.07), transparent 60%),
    radial-gradient(700px 500px at 8% 78%, rgba(246,210,58,.08), transparent 60%);
}

/* スキップリンク */
.p14-skip{position:absolute;left:-9999px;top:8px}
.p14-skip:focus{left:8px;z-index:9999;background:#fff;padding:8px 12px;border:1px solid #2a2a2a}

/* ========== HEADER ========== */
.p14-header{
  position:fixed;top:0;left:0;right:0;z-index:100;
  display:flex;align-items:center;justify-content:space-between;
  padding:18px 36px;
  background:rgba(247,241,226,.92);
  backdrop-filter:blur(8px);
}
.p14-header__brand{
  display:flex;align-items:center;gap:14px;
}
.p14-header__brand__mark{
  width:36px;height:36px;border-radius:50%;
  background:radial-gradient(circle at 35% 35%,#f6d23a,#e8a800);
  position:relative;flex-shrink:0;
  box-shadow:inset -2px -2px 4px rgba(0,0,0,.1);
}
.p14-header__brand__mark::before{
  content:'';position:absolute;top:-4px;left:50%;width:8px;height:10px;
  background:#5a8a3a;border-radius:50% 50% 50% 50% / 60% 60% 40% 40%;
  transform:translateX(-50%) rotate(-15deg);
}
.p14-header__brand__name{
  display:flex;flex-direction:column;line-height:1.2;
}
.p14-header__brand__name__jp{
  font-family:var(--p14-font-jp-serif);font-weight:500;font-size:14px;letter-spacing:0.15em;
}
.p14-header__brand__name__en{
  font-family:var(--p14-font-en);font-size:9px;letter-spacing:0.25em;color:#7a7a6a;margin-top:2px;
}
.p14-header__nav{
  display:flex;gap:36px;align-items:center;
}
.p14-header__nav__list{
  display:grid;grid-template-columns:auto auto;gap:6px 24px;list-style:none;padding:0;margin:0;
  font-size:11px;letter-spacing:0.12em;
}
.p14-header__nav__list a{position:relative;padding-left:14px}
.p14-header__nav__list a::before{
  content:'';position:absolute;left:0;top:50%;width:6px;height:1px;background:#2a2a2a;
}
.p14-header__corp{
  display:inline-flex;align-items:center;gap:8px;
  padding:10px 16px;border:1px solid #2a2a2a;
  font-family:var(--p14-font-en);font-size:11px;letter-spacing:0.18em;
  position:relative;
}
.p14-header__corp::before{
  content:'';position:absolute;top:-3px;left:50%;transform:translateX(-50%);
  width:14px;height:4px;background:#f6d23a;border-radius:50%;
}
.p14-header__corp:hover{background:#2a2a2a;color:#f7f1e2}

@media (max-width:960px){
  .p14-header{padding:12px 16px}
  .p14-header__nav{display:none}
}

/* ========== HERO (TOP) ========== */
.p14-hero{
  min-height:100vh;
  position:relative;
  padding:160px 0 80px;
  overflow:hidden;
}
.p14-hero__copy{
  position:absolute;top:160px;left:50%;transform:translateX(-50%);
  font-family:var(--p14-font-jp-serif);
  writing-mode:vertical-rl;
  font-size:13px;letter-spacing:0.6em;color:#3a3a2a;
  font-weight:400;
  margin:0;
}
.p14-hero__sub{
  position:absolute;top:170px;left:calc(50% + 80px);
  font-family:var(--p14-font-en-disp);font-style:italic;
  font-size:18px;color:#b89a3a;letter-spacing:0.05em;
  transform:rotate(-2deg);
}
.p14-hero__leaves{
  position:absolute;top:120px;left:0;right:0;height:600px;
  pointer-events:none;
}
.p14-hero__leaf{
  position:absolute;font-size:26px;color:#5a8a3a;opacity:.6;
  transition:transform .6s ease;
}
.p14-hero__leaf--1{top:60px;left:12%;transform:rotate(-20deg)}
.p14-hero__leaf--2{top:200px;right:18%;transform:rotate(30deg);color:#f6d23a;font-size:18px}
.p14-hero__leaf--3{top:340px;left:24%;transform:rotate(15deg);font-size:22px}
.p14-hero__leaf--4{top:460px;right:14%;transform:rotate(-25deg)}
.p14-hero__leaf--5{top:540px;left:42%;transform:rotate(40deg);color:#e8a800;font-size:16px}

.p14-hero__plate{
  margin:380px auto 0;max-width:1100px;padding:0 40px;
  display:grid;grid-template-columns:1fr 1fr 1fr;gap:60px;
  position:relative;
}
.p14-hero__photo{
  border-radius:6px;overflow:hidden;
  box-shadow:0 20px 50px -25px rgba(0,0,0,.25);
  opacity:0;transform:translateY(30px);transition:opacity .9s ease, transform .9s ease;
}
.p14-loaded .p14-hero__photo,
.p14-hero__photo.p14-loaded{opacity:1;transform:translateY(0)}
.p14-hero__photo:nth-child(1){grid-column:1;margin-top:0;aspect-ratio:4/3;transition-delay:.1s}
.p14-hero__photo:nth-child(2){grid-column:2;margin-top:80px;aspect-ratio:3/4;transition-delay:.3s}
.p14-hero__photo:nth-child(3){grid-column:3;margin-top:140px;aspect-ratio:4/3;transition-delay:.5s}
.p14-hero__photo img{width:100%;height:100%;object-fit:cover}

.p14-hero__caption{
  margin:160px auto 0;max-width:760px;padding:0 40px;
  display:grid;grid-template-columns:auto 1fr;gap:40px;
  align-items:start;
}
.p14-hero__caption__num{
  font-family:var(--p14-font-en);font-size:11px;letter-spacing:0.3em;color:#7a7a6a;
  border-top:1px solid #2a2a2a;padding-top:4px;min-width:80px;
}
.p14-hero__caption__body p{margin:0;font-size:13px;line-height:2.1;color:#3a3a2a}
.p14-hero__caption__body h1{
  font-family:var(--p14-font-jp-serif);font-size:22px;font-weight:500;letter-spacing:0.15em;
  margin:0 0 24px;line-height:1.8;
}
.p14-hero__scroll{
  position:absolute;bottom:60px;left:50%;transform:translateX(-50%);
  font-family:var(--p14-font-en);font-size:10px;letter-spacing:0.3em;color:#7a7a6a;
  writing-mode:vertical-rl;
}
.p14-hero__scroll::after{
  content:'';position:absolute;left:50%;bottom:-50px;width:1px;height:40px;background:#7a7a6a;
}

@media (max-width:760px){
  .p14-hero__plate{grid-template-columns:1fr;gap:30px;padding:0 24px}
  .p14-hero__photo:nth-child(2),
  .p14-hero__photo:nth-child(3){margin-top:0}
  .p14-hero__caption{grid-template-columns:1fr;padding:0 24px;margin-top:80px}
  .p14-hero__copy{font-size:11px}
}

/* ========== セクション共通 ========== */
.p14-section{
  max-width:1200px;margin:200px auto;padding:0 40px;
  position:relative;
}
.p14-section__label{
  font-family:var(--p14-font-en);font-size:11px;letter-spacing:0.3em;color:#7a7a6a;
  padding-left:50px;position:relative;margin:0 0 24px;
}
.p14-section__label::before{
  content:'';position:absolute;left:0;top:50%;width:36px;height:1px;background:#2a2a2a;
}
.p14-section__title{
  font-family:var(--p14-font-jp-serif);font-weight:500;font-size:24px;letter-spacing:0.15em;
  margin:0 0 80px;line-height:1.7;
}
@media (max-width:760px){
  .p14-section{margin:120px auto;padding:0 24px}
  .p14-section__title{font-size:20px;margin-bottom:50px}
}

/* ABOUT (3円/3コンセプト) */
.p14-about{
  display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:center;
}
.p14-about__text p{font-size:13px;line-height:2.2;color:#3a3a2a;margin:0 0 18px}
.p14-about__circles{
  position:relative;height:380px;
}
.p14-circle{
  position:absolute;width:160px;height:160px;border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  font-family:var(--p14-font-jp-serif);font-weight:500;font-size:14px;letter-spacing:0.2em;
  color:#3a3a2a;text-align:center;
  box-shadow:inset -6px -6px 18px rgba(0,0,0,.08);
}
.p14-circle--1{top:0;left:30%;background:radial-gradient(circle at 30% 30%,#fff6c4,#f6d23a)}
.p14-circle--2{top:140px;left:5%;background:radial-gradient(circle at 30% 30%,#fff6c4,#e8a800)}
.p14-circle--3{top:140px;left:55%;background:radial-gradient(circle at 30% 30%,#f0e9c0,#b8a838)}
@media (max-width:760px){
  .p14-about{grid-template-columns:1fr;gap:50px}
  .p14-about__circles{height:300px}
  .p14-circle{width:130px;height:130px;font-size:12px}
}

/* MESSAGE on TOP (代表) */
.p14-topmsg{
  display:grid;grid-template-columns:280px 1fr;gap:60px;align-items:start;
}
.p14-topmsg__photo{
  aspect-ratio:3/4;overflow:hidden;background:#e8dfc8;
}
.p14-topmsg__photo img{width:100%;height:100%;object-fit:cover}
.p14-topmsg__body p{font-size:13px;line-height:2.2;margin:0 0 20px;color:#3a3a2a}
.p14-topmsg__body__sign{
  font-family:var(--p14-font-jp-serif);font-size:14px;margin-top:30px;letter-spacing:0.1em;
}
.p14-topmsg__body__sign b{display:block;font-size:16px;margin-top:4px;font-weight:500}
.p14-topmsg__more{
  display:inline-flex;align-items:center;gap:24px;
  margin-top:30px;padding:14px 28px;border:1px solid #2a2a2a;
  font-family:var(--p14-font-en);font-size:11px;letter-spacing:0.2em;
}
.p14-topmsg__more::after{content:'→'}
@media (max-width:760px){
  .p14-topmsg{grid-template-columns:1fr}
}

/* GALLERY (TOP の散らし写真) */
.p14-gallery{
  display:grid;grid-template-columns:repeat(3,1fr);gap:24px;
  max-width:900px;margin:120px auto 0;padding:0 40px;
}
.p14-gallery__item{
  aspect-ratio:1/1;overflow:hidden;border-radius:4px;
}
.p14-gallery__item:nth-child(1){transform:translateY(40px)}
.p14-gallery__item:nth-child(3){transform:translateY(80px)}
.p14-gallery__item img{width:100%;height:100%;object-fit:cover;transition:transform .8s ease}
.p14-gallery__item:hover img{transform:scale(1.04)}

/* MISSION (縦書きキャッチ) */
.p14-mission{
  text-align:center;padding:140px 40px;
}
.p14-mission__copy{
  font-family:var(--p14-font-jp-serif);
  writing-mode:vertical-rl;
  font-size:24px;letter-spacing:0.6em;line-height:2.4;
  margin:0 auto;color:#3a3a2a;
  font-weight:500;
}

/* JOB-LIST on TOP (募集職種) */
.p14-toplist{
  margin:200px auto;max-width:1100px;padding:0 40px;
}
.p14-toplist__head{
  display:flex;align-items:flex-end;justify-content:space-between;margin-bottom:60px;
  border-bottom:1px solid #2a2a2a;padding-bottom:24px;
}
.p14-toplist__head h2{
  font-family:var(--p14-font-en);font-weight:400;font-size:32px;letter-spacing:0.1em;margin:0;
}
.p14-toplist__head__jp{
  font-family:var(--p14-font-jp-serif);font-size:14px;letter-spacing:0.15em;color:#7a7a6a;
}
.p14-toplist__item{
  display:grid;grid-template-columns:80px 1fr auto;gap:40px;align-items:center;
  padding:30px 0;border-bottom:1px solid rgba(42,42,42,.15);
  transition:padding-left .3s ease;
}
.p14-toplist__item:hover{padding-left:20px;background:rgba(246,210,58,.06)}
.p14-toplist__item__num{
  font-family:var(--p14-font-en);font-size:14px;color:#b89a3a;letter-spacing:0.2em;
}
.p14-toplist__item__title{
  font-family:var(--p14-font-jp-serif);font-size:18px;font-weight:500;letter-spacing:0.1em;margin:0 0 4px;
}
.p14-toplist__item__sub{font-size:12px;color:#7a7a6a;margin:0}
.p14-toplist__item__arrow{
  width:40px;height:40px;border-radius:50%;border:1px solid #2a2a2a;
  display:flex;align-items:center;justify-content:center;font-size:14px;
  background:#f6d23a;
}

/* ========== 下層ページ共通 ========== */
.p14-page{padding:140px 0 80px}
.p14-page__hero{
  text-align:center;padding:60px 20px 80px;position:relative;
}
.p14-page__hero__label{
  font-family:var(--p14-font-en);font-size:11px;letter-spacing:0.3em;color:#7a7a6a;
  padding-left:50px;position:relative;display:inline-block;
}
.p14-page__hero__label::before{
  content:'';position:absolute;left:0;top:50%;width:36px;height:1px;background:#2a2a2a;
}
.p14-page__hero__title{
  font-family:var(--p14-font-jp-serif);font-weight:500;font-size:26px;letter-spacing:0.2em;
  margin:20px 0 0;
}
.p14-page__hero__en{
  display:block;font-family:var(--p14-font-en);font-size:14px;letter-spacing:0.3em;
  color:#b89a3a;margin-top:10px;font-style:italic;
}
.p14-page__hero__photo{
  margin:40px auto 0;max-width:900px;aspect-ratio:21/9;overflow:hidden;
}
.p14-page__hero__photo img{width:100%;height:100%;object-fit:cover}
.p14-page__crumb{
  max-width:1100px;margin:0 auto 60px;padding:0 40px;
  font-size:11px;color:#7a7a6a;letter-spacing:0.1em;
}
.p14-page__crumb a{border-bottom:1px solid currentColor}
.p14-page__inner{max-width:840px;margin:0 auto;padding:0 40px}
.p14-page__lead{font-size:14px;line-height:2.2;margin:0 0 60px;color:#3a3a2a}

/* JOBS LIST */
.p14-jobs__grid{
  max-width:1100px;margin:60px auto;padding:0 40px;
  display:grid;grid-template-columns:repeat(3,1fr);gap:30px;
}
.p14-jobcard{
  display:block;padding:30px 24px;
  border:1px solid #2a2a2a;background:rgba(255,255,255,.4);
  position:relative;transition:background .3s ease, transform .3s ease;
}
.p14-jobcard:hover{background:#fff;transform:translateY(-3px)}
.p14-jobcard::before{
  content:'';position:absolute;top:-6px;left:24px;width:24px;height:24px;
  background:radial-gradient(circle at 35% 35%,#f6d23a,#e8a800);border-radius:50%;
}
.p14-jobcard__code{
  font-family:var(--p14-font-en);font-size:10px;color:#b89a3a;letter-spacing:0.2em;
  margin:8px 0 4px;
}
.p14-jobcard__title{
  font-family:var(--p14-font-jp-serif);font-size:16px;font-weight:500;letter-spacing:0.12em;
  margin:0 0 8px;
}
.p14-jobcard__sub{font-size:12px;color:#7a7a6a;margin:0 0 18px;line-height:1.7}
.p14-jobcard__meta{
  display:flex;flex-direction:column;gap:4px;font-size:11px;color:#3a3a2a;
  padding-top:14px;border-top:1px solid rgba(42,42,42,.15);
}
.p14-jobcard__meta b{display:inline-block;width:56px;color:#7a7a6a;font-weight:400}
.p14-jobcard__arrow{
  position:absolute;right:18px;bottom:18px;font-family:var(--p14-font-en);font-size:11px;
}
.p14-jobcard__arrow::after{content:' →'}
@media (max-width:760px){
  .p14-jobs__grid{grid-template-columns:1fr;gap:20px}
}

/* JOB DETAIL */
.p14-job__hero{
  max-width:1100px;margin:0 auto 60px;padding:0 40px;
  text-align:center;
}
.p14-job__hero__photo{
  aspect-ratio:21/9;overflow:hidden;margin:0 0 40px;
}
.p14-job__hero__photo img{width:100%;height:100%;object-fit:cover}
.p14-job__hero__code{
  font-family:var(--p14-font-en);font-size:11px;color:#b89a3a;letter-spacing:0.3em;
}
.p14-job__hero__title{
  font-family:var(--p14-font-jp-serif);font-size:28px;font-weight:500;letter-spacing:0.2em;
  margin:16px 0 20px;
}
.p14-job__hero__sub{
  font-size:14px;line-height:2;color:#3a3a2a;max-width:680px;margin:0 auto 40px;
}
.p14-job__hero__meta{
  display:flex;flex-wrap:wrap;justify-content:center;gap:30px;
  border-top:1px solid #2a2a2a;border-bottom:1px solid #2a2a2a;
  padding:20px 0;max-width:780px;margin:0 auto;
}
.p14-job__hero__meta div{display:flex;flex-direction:column;align-items:center;gap:6px;font-size:12px}
.p14-job__hero__meta dt{font-family:var(--p14-font-en);font-size:9px;letter-spacing:0.25em;color:#7a7a6a}
.p14-job__hero__meta dd{margin:0;font-family:var(--p14-font-jp-serif);font-size:13px}

.p14-job__sec{
  max-width:780px;margin:60px auto;padding:0 40px;
}
.p14-job__sec__bar{
  display:flex;align-items:baseline;gap:24px;border-bottom:1px solid #2a2a2a;
  padding-bottom:14px;margin-bottom:30px;
}
.p14-job__sec__bar__tag{
  font-family:var(--p14-font-jp-serif);font-size:14px;letter-spacing:0.15em;font-weight:500;
  position:relative;padding-left:18px;
}
.p14-job__sec__bar__tag::before{
  content:'';position:absolute;left:0;top:50%;transform:translateY(-50%);
  width:10px;height:10px;border-radius:50%;background:#f6d23a;
}
.p14-job__sec__bar__title{
  font-family:var(--p14-font-en);font-size:10px;letter-spacing:0.3em;color:#7a7a6a;margin-left:auto;
}
.p14-job__sec p{font-size:13px;line-height:2.1;margin:0 0 12px;color:#3a3a2a}
.p14-job__sec ul{padding:0;margin:0;list-style:none}
.p14-job__sec ul li{
  padding:14px 0 14px 24px;border-bottom:1px solid rgba(42,42,42,.12);
  font-size:13px;line-height:1.8;position:relative;
}
.p14-job__sec ul li::before{
  content:'';position:absolute;left:0;top:22px;width:10px;height:10px;border-radius:50%;
  background:#f6d23a;
}

/* 1日の流れ */
.p14-day{display:grid;gap:0}
.p14-day__row{
  display:grid;grid-template-columns:90px 1fr;gap:30px;
  padding:20px 0;border-bottom:1px dashed rgba(42,42,42,.2);position:relative;
}
.p14-day__time{
  font-family:var(--p14-font-en);font-size:14px;color:#b89a3a;letter-spacing:0.15em;
  padding-left:24px;position:relative;padding-top:2px;
}
.p14-day__time::before{
  content:'';position:absolute;left:0;top:8px;width:12px;height:12px;border-radius:50%;
  background:#f6d23a;border:2px solid #f7f1e2;box-shadow:0 0 0 1px #f6d23a;
}
.p14-day__body h4{
  font-family:var(--p14-font-jp-serif);font-size:14px;font-weight:500;margin:0 0 6px;letter-spacing:0.1em;
}
.p14-day__body p{margin:0;font-size:12px;color:#5a5a4a;line-height:1.8}

/* 要項テーブル */
.p14-reqtable{
  width:100%;border-collapse:collapse;font-size:13px;
}
.p14-reqtable tr{border-bottom:1px solid rgba(42,42,42,.15)}
.p14-reqtable tr:first-child{border-top:1px solid #2a2a2a}
.p14-reqtable tr:last-child{border-bottom:1px solid #2a2a2a}
.p14-reqtable th{
  text-align:left;padding:22px 0;width:160px;vertical-align:top;
  font-family:var(--p14-font-jp-serif);font-weight:500;letter-spacing:0.1em;
  position:relative;padding-left:18px;
}
.p14-reqtable th::before{
  content:'';position:absolute;left:0;top:30px;width:8px;height:8px;border-radius:50%;background:#f6d23a;
}
.p14-reqtable td{padding:22px 0 22px 24px;line-height:2;color:#3a3a2a}

/* FAQ */
.p14-faqlist{display:flex;flex-direction:column;gap:0;border-top:1px solid #2a2a2a}
.p14-faqitem{
  border-bottom:1px solid rgba(42,42,42,.15);
  padding:0;
}
.p14-faqitem summary{
  list-style:none;cursor:pointer;
  padding:24px 60px 24px 40px;position:relative;
  font-family:var(--p14-font-jp-serif);font-size:14px;letter-spacing:0.05em;line-height:1.8;
}
.p14-faqitem summary::-webkit-details-marker{display:none}
.p14-faqitem summary::before{
  content:'Q';position:absolute;left:0;top:22px;
  font-family:var(--p14-font-en);font-size:18px;color:#e8a800;font-style:italic;
}
.p14-faqitem summary::after{
  content:'+';position:absolute;right:20px;top:50%;transform:translateY(-50%);
  font-size:20px;color:#7a7a6a;transition:transform .3s;
}
.p14-faqitem[open] summary::after{content:'−'}
.p14-faqitem > div{
  padding:0 40px 28px 40px;font-size:13px;line-height:2;color:#3a3a2a;
  position:relative;
}
.p14-faqitem > div::before{
  content:'A';position:absolute;left:0;top:0;
  font-family:var(--p14-font-en);font-size:18px;color:#b89a3a;font-style:italic;
}

/* FORM */
.p14-form{display:flex;flex-direction:column;gap:24px;margin-top:30px}
.p14-form > div{display:flex;flex-direction:column;gap:8px}
.p14-form label{
  font-family:var(--p14-font-jp-serif);font-size:12px;letter-spacing:0.12em;color:#3a3a2a;
}
.p14-form label small{
  display:inline-block;margin-left:8px;padding:2px 8px;font-size:9px;
  background:#e8a800;color:#fff;letter-spacing:0.1em;border-radius:2px;
}
.p14-form input,.p14-form select,.p14-form textarea{
  font-family:var(--p14-font-jp);font-size:13px;
  padding:14px 16px;border:1px solid rgba(42,42,42,.3);background:rgba(255,255,255,.6);
  border-radius:2px;color:#2a2a2a;width:100%;
}
.p14-form input:focus,.p14-form select:focus,.p14-form textarea:focus{
  outline:none;border-color:#e8a800;background:#fff;
}
.p14-form button{
  margin:20px auto 0;padding:18px 60px;background:#2a2a2a;color:#f7f1e2;
  font-family:var(--p14-font-en);font-size:12px;letter-spacing:0.3em;
  display:inline-flex;align-items:center;gap:14px;
}
.p14-form button::after{content:'→'}
.p14-form button:hover{background:#e8a800}
.p14-form__note{
  font-size:11px;color:#7a7a6a;line-height:1.9;padding:14px 18px;
  background:rgba(246,210,58,.15);margin-bottom:30px;
}

/* HISTORY */
.p14-history{margin:30px 0;border-top:1px solid #2a2a2a}
.p14-history__row{
  display:grid;grid-template-columns:120px 1fr;gap:30px;
  padding:22px 0;border-bottom:1px solid rgba(42,42,42,.15);
}
.p14-history__year{
  font-family:var(--p14-font-en);font-size:16px;color:#b89a3a;letter-spacing:0.1em;padding-top:2px;
}
.p14-history__event{font-size:13px;line-height:1.9;color:#3a3a2a}

/* MESSAGE (代表ページ) */
.p14-message{
  max-width:880px;margin:80px auto;padding:80px 60px;position:relative;
  background:rgba(255,255,255,.5);
}
.p14-message::before{
  content:'';position:absolute;top:-30px;left:-30px;width:80px;height:80px;
  background:radial-gradient(circle at 30% 30%,#f6d23a,#e8a800);border-radius:50%;
  z-index:0;
}
.p14-message::after{
  content:'';position:absolute;bottom:-20px;right:40px;width:50px;height:50px;
  background:radial-gradient(circle at 30% 30%,#fff6c4,#f6d23a);border-radius:50%;
  z-index:0;
}
.p14-message__title{
  font-family:var(--p14-font-en);font-size:11px;letter-spacing:0.3em;color:#7a7a6a;
  position:relative;z-index:1;margin:0 0 30px;
}
.p14-message__lead{
  font-family:var(--p14-font-jp-serif);font-size:20px;line-height:1.9;letter-spacing:0.1em;
  margin:0 0 30px;position:relative;z-index:1;font-weight:500;
}
.p14-message__body{
  font-size:13px;line-height:2.2;color:#3a3a2a;white-space:pre-wrap;position:relative;z-index:1;
}
.p14-message__sign{
  margin:40px 0 0;font-family:var(--p14-font-jp-serif);font-size:13px;letter-spacing:0.1em;
  text-align:right;position:relative;z-index:1;
}
.p14-message__sign b{display:block;font-size:16px;margin-top:4px;font-weight:500}
@media (max-width:760px){
  .p14-message{padding:50px 24px;margin:60px 16px}
}

/* CTA strip */
.p14-cta-strip{
  max-width:1100px;margin:120px auto;padding:0 40px;
  display:grid;grid-template-columns:1fr 1fr;gap:0;border-top:1px solid #2a2a2a;
}
.p14-cta-strip a{
  display:flex;align-items:center;justify-content:space-between;
  padding:40px 30px;border-bottom:1px solid #2a2a2a;
  font-family:var(--p14-font-jp-serif);font-size:15px;letter-spacing:0.15em;
  position:relative;transition:background .3s ease;
}
.p14-cta-strip a:first-child{border-right:1px solid #2a2a2a}
.p14-cta-strip a:hover{background:rgba(246,210,58,.15)}
.p14-cta-strip a small{
  display:block;font-family:var(--p14-font-en);font-size:10px;letter-spacing:0.3em;color:#b89a3a;margin-bottom:6px;
}
.p14-cta-strip a::after{
  content:'→';font-family:var(--p14-font-en);font-size:14px;color:#7a7a6a;
}
@media (max-width:760px){
  .p14-cta-strip{grid-template-columns:1fr}
  .p14-cta-strip a:first-child{border-right:0}
}

/* ========== FOOTER ========== */
.p14-foot{
  background:rgba(247,241,226,.6);
  padding:80px 40px 30px;margin-top:120px;
  border-top:1px solid rgba(42,42,42,.15);
}
.p14-foot__inner{
  max-width:1200px;margin:0 auto;
  display:grid;grid-template-columns:1fr 1fr 1fr;gap:60px;
}
.p14-foot__brand{display:flex;flex-direction:column;gap:8px}
.p14-foot__brand__mark{
  display:flex;align-items:center;gap:12px;
}
.p14-foot__brand__mark__circle{
  width:36px;height:36px;border-radius:50%;
  background:radial-gradient(circle at 35% 35%,#f6d23a,#e8a800);
  position:relative;flex-shrink:0;
}
.p14-foot__brand__mark__circle::before{
  content:'';position:absolute;top:-4px;left:50%;width:8px;height:10px;
  background:#5a8a3a;border-radius:50% 50% 50% 50% / 60% 60% 40% 40%;
  transform:translateX(-50%) rotate(-15deg);
}
.p14-foot__brand__name__jp{
  font-family:var(--p14-font-jp-serif);font-size:13px;letter-spacing:0.15em;font-weight:500;
}
.p14-foot__brand__name__en{
  font-family:var(--p14-font-en);font-size:9px;letter-spacing:0.3em;color:#7a7a6a;margin-top:2px;
}
.p14-foot__corp{
  display:inline-flex;align-items:center;gap:8px;
  padding:10px 16px;border:1px solid #2a2a2a;width:fit-content;
  font-family:var(--p14-font-en);font-size:10px;letter-spacing:0.2em;margin-top:14px;
}
.p14-foot__sns{display:flex;gap:12px;margin-top:16px}
.p14-foot__sns a{
  width:30px;height:30px;border-radius:50%;background:#2a2a2a;color:#f7f1e2;
  display:flex;align-items:center;justify-content:center;font-size:11px;
}
.p14-foot__cols{display:grid;grid-template-columns:1fr 1fr;gap:30px}
.p14-foot__col{font-size:11px;letter-spacing:0.1em}
.p14-foot__col ul{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:10px}
.p14-foot__col ul a{position:relative;padding-left:14px}
.p14-foot__col ul a::before{
  content:'—';position:absolute;left:0;color:#b89a3a;
}
.p14-foot__bottom{
  max-width:1200px;margin:60px auto 0;padding-top:24px;
  border-top:1px solid rgba(42,42,42,.15);
  font-size:10px;color:#7a7a6a;letter-spacing:0.1em;
  display:flex;justify-content:space-between;flex-wrap:wrap;gap:10px;
}
@media (max-width:760px){
  .p14-foot__inner{grid-template-columns:1fr;gap:40px}
}

/* ========== モーション ========== */
.p14-reveal{opacity:0;transform:translateY(20px);transition:opacity .8s ease, transform .8s ease;transition-delay:var(--p14-delay,0)}
.p14-in{opacity:1;transform:translateY(0)}
