@import url('./fonts.css');

/* 真似元: 月桂冠 新卒採用サイト gekkeikan.co.jp/saiyo/
   - 緑+白基調、ロゴ緑、Entry ボタンが緑
   - ヒーローは大型分割写真 + 明朝大見出し + Special Movie 緑丸ボタン
   - セクション見出し中央揃え + 英訳サブ
   - フッターに笹ロゴ + SNS + 5列リンク + 20歳警告 */
:root{
  --p03-bg:#fff;
  --p03-ink:#1a1a1a;
  --p03-ink-soft:#555;
  --p03-mute:#888;
  --p03-line:#e5e5e5;
  --p03-paper:#f6f6f3;
  --p03-green:#4A8A4D;
  --p03-green-d:#3a6f3d;
  --p03-green-light:#E8F2E5;
}
*{box-sizing:border-box}
html,body{margin:0;padding:0}
html{background:var(--p03-bg);color:var(--p03-ink);font-family:var(--p03-font-body);font-weight:400;font-size:14px;line-height:1.85;-webkit-font-smoothing:antialiased}
img{max-width:100%;display:block;height:auto}
a{color:inherit;text-decoration:none}

/* NAV: 左ロゴ + 中央メニュー + 右 Entry 緑ボタン2つ */
.p03-nav{position:sticky;top:0;z-index:30;background:#fff;padding:0;display:grid;grid-template-columns:auto 1fr auto;align-items:stretch;border-bottom:1px solid var(--p03-line)}
.p03-nav__brand{padding:16px 24px;display:flex;align-items:center;gap:12px;text-decoration:none;color:var(--p03-ink)}
.p03-nav__sasa{width:22px;height:22px;background:var(--p03-green);clip-path:polygon(50% 0,100% 50%,50% 100%,0 50%);position:relative}
.p03-nav__sasa::after{content:"";position:absolute;left:50%;top:0;bottom:0;width:1px;background:#fff;transform:translateX(-50%)}
.p03-nav__brand strong{font-family:var(--p03-font-en);font-weight:700;font-size:16px;letter-spacing:.04em;color:var(--p03-green)}
.p03-nav__brand small{display:block;font-size:9.5px;color:var(--p03-mute);letter-spacing:.04em;margin-top:1px}
.p03-nav__brand__sub{font-size:10.5px;color:var(--p03-mute);margin-left:8px;letter-spacing:.04em}
.p03-nav__menu{display:flex;justify-content:center;align-items:center;gap:32px;font-size:13.5px}
.p03-nav__menu a{padding:24px 0;color:var(--p03-ink);text-align:center;display:flex;flex-direction:column;gap:2px;font-weight:500}
.p03-nav__menu a small{font-family:var(--p03-font-en);font-size:10px;color:var(--p03-mute);font-style:italic;font-weight:400}
.p03-nav__menu a[aria-current]{color:var(--p03-green);border-bottom:3px solid var(--p03-green);padding-bottom:21px}
.p03-nav__cta{display:flex;align-items:stretch}
.p03-nav__cta a{background:var(--p03-green);color:#fff;padding:18px 26px;font-family:var(--p03-font-body);font-size:13px;font-weight:700;line-height:1.4;display:flex;flex-direction:column;justify-content:center;align-items:center;border-left:1px solid #fff;text-align:center}
.p03-nav__cta a:hover{background:var(--p03-green-d)}
.p03-nav__cta a small{font-size:11px;font-weight:500}
@media (max-width:880px){.p03-nav__menu{display:none}}

/* HERO: 大型分割写真(三角クリップ)+ 明朝大見出し + Special Movie 緑丸ボタン */
.p03-hero{position:relative;height:60vh;min-height:480px;overflow:hidden;background:#fff}
.p03-hero__a{position:absolute;left:0;top:0;width:55%;height:100%;background:#ddd;clip-path:polygon(0 0,100% 0,80% 100%,0 100%)}
.p03-hero__b{position:absolute;right:0;top:0;width:50%;height:100%;background:#222;clip-path:polygon(20% 0,100% 0,100% 100%,0 100%)}
.p03-hero__a img,.p03-hero__b img{width:100%;height:100%;object-fit:cover}
.p03-hero__h{position:absolute;left:5%;right:5%;top:50%;transform:translateY(-50%);font-family:var(--p03-font-display);font-weight:500;font-size:clamp(28px,5vw,64px);color:#fff;letter-spacing:.06em;text-align:center;line-height:1.3;text-shadow:0 4px 24px rgba(0,0,0,.4);z-index:2;margin:0}
.p03-hero__movie{position:absolute;right:5%;bottom:18%;background:var(--p03-green);color:#fff;padding:14px 24px;border-radius:0;font-size:12px;font-weight:500;display:flex;align-items:center;gap:10px;z-index:3}
.p03-hero__movie::before{content:"▶";font-size:14px}
.p03-hero__movie small{font-family:var(--p03-font-en);font-size:14px;display:block}
.p03-hero__movie::after{content:"→";margin-left:6px}

/* SECTION: 中央揃え + 英訳サブ */
.p03-section{padding:80px 24px;max-width:1100px;margin:0 auto}
.p03-section__head{text-align:center;margin:0 0 48px}
.p03-section__head h2{font-family:var(--p03-font-display);font-weight:500;font-size:clamp(28px,3.5vw,40px);color:var(--p03-ink);margin:0 0 4px;letter-spacing:.08em}
.p03-section__head h2 small{font-family:var(--p03-font-en);font-size:13px;color:var(--p03-green);font-style:italic;font-weight:400;display:block;margin-top:2px;letter-spacing:.04em}

/* CARDS */
.p03-cards{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.p03-card{background:var(--p03-paper);border:1px solid var(--p03-line);text-decoration:none;color:var(--p03-ink);display:flex;flex-direction:column;transition:transform .25s ease,box-shadow .25s ease,border-color .25s ease}
.p03-card:hover{transform:translateY(-4px);box-shadow:0 16px 32px -16px rgba(74,138,77,.25);border-color:var(--p03-green)}
.p03-card__plate{aspect-ratio:16/10;overflow:hidden;background:#eee}
.p03-card__plate img{width:100%;height:100%;object-fit:cover;transition:transform .8s ease}
.p03-card:hover .p03-card__plate img{transform:scale(1.05)}
.p03-card__body{padding:24px 26px}
.p03-card__code{font-family:var(--p03-font-en);font-style:italic;font-size:11px;color:var(--p03-green);font-weight:500;margin:0 0 6px;letter-spacing:.04em}
.p03-card__title{font-family:var(--p03-font-display);font-weight:600;font-size:20px;color:var(--p03-ink);margin:0 0 8px;line-height:1.4;letter-spacing:.04em}
.p03-card__sub{font-size:13px;color:var(--p03-ink-soft);margin:0 0 12px;line-height:1.85}
.p03-card__more{font-size:12px;color:var(--p03-green);font-weight:500;display:inline-flex;align-items:center;gap:6px;padding-top:12px;border-top:1px solid var(--p03-line)}
.p03-card__more::after{content:"→"}
@media (max-width:880px){.p03-cards{grid-template-columns:1fr}}

/* CTA section */
.p03-cta-band{background:var(--p03-green);color:#fff;padding:64px 24px;text-align:center;margin-top:60px}
.p03-cta-band h2{font-family:var(--p03-font-display);font-weight:500;font-size:clamp(24px,3vw,36px);margin:0 0 14px;color:#fff;letter-spacing:.06em}
.p03-cta-band p{font-size:14px;color:rgba(255,255,255,.92);margin:0 0 28px;max-width:46ch;margin-left:auto;margin-right:auto}
.p03-cta-band__btns{display:flex;gap:14px;justify-content:center;flex-wrap:wrap}
.p03-cta-band__btns a{background:#fff;color:var(--p03-green);padding:14px 36px;font-weight:700;font-size:14px}
.p03-cta-band__btns a.ghost{background:transparent;color:#fff;border:1px solid #fff}
.p03-cta-band__btns a:hover{background:#fff;color:var(--p03-green);transform:translateY(-2px)}

/* FOOTER */
.p03-foot{background:#fff;padding:60px 24px 24px;border-top:1px solid var(--p03-line)}
.p03-foot__top{max-width:1100px;margin:0 auto;display:grid;grid-template-columns:auto 1fr;gap:48px;align-items:start;margin-bottom:48px}
.p03-foot__brand{display:flex;flex-direction:column;gap:14px}
.p03-foot__brand__logo{display:flex;align-items:center;gap:10px}
.p03-foot__brand__logo strong{font-family:var(--p03-font-en);font-weight:700;font-size:18px;color:var(--p03-green);letter-spacing:.04em}
.p03-foot__brand__logo small{font-size:10px;color:var(--p03-mute);display:block;margin-top:2px}
.p03-foot__brand__sns{display:flex;gap:12px}
.p03-foot__brand__sns a{width:32px;height:32px;display:grid;place-items:center;border:1px solid var(--p03-line);font-size:14px;color:var(--p03-ink-soft)}
.p03-foot__brand__sns a:hover{background:var(--p03-green);color:#fff;border-color:var(--p03-green)}
.p03-foot__cols{display:grid;grid-template-columns:repeat(5,1fr);gap:24px}
.p03-foot__col h4{font-family:var(--p03-font-display);font-weight:600;font-size:13px;color:var(--p03-ink);margin:0 0 10px;letter-spacing:.06em;border-bottom:1px solid var(--p03-line);padding-bottom:6px}
.p03-foot__col h4 small{font-family:var(--p03-font-en);font-size:9.5px;color:var(--p03-green);font-style:italic;display:block;font-weight:400;margin-top:1px}
.p03-foot__col ul{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:5px}
.p03-foot__col li{font-size:12px;color:var(--p03-ink-soft);display:flex;gap:6px}
.p03-foot__col li small{color:var(--p03-mute);font-family:var(--p03-font-en);min-width:18px}
.p03-foot__col a{color:var(--p03-ink);text-decoration:none}
.p03-foot__col a:hover{color:var(--p03-green)}
.p03-foot__warn{background:var(--p03-paper);padding:14px 24px;font-size:11px;color:var(--p03-ink-soft);line-height:1.85;max-width:1100px;margin:0 auto}
.p03-foot__bot{max-width:1100px;margin:18px auto 0;padding-top:18px;border-top:1px solid var(--p03-line);display:flex;justify-content:space-between;font-size:11px;color:var(--p03-mute);gap:14px;flex-wrap:wrap}
.p03-foot__bot__top{background:var(--p03-green);color:#fff;padding:4px 10px;font-family:var(--p03-font-en);font-size:9.5px;letter-spacing:.12em}
@media (max-width:880px){.p03-foot__top{grid-template-columns:1fr}.p03-foot__cols{grid-template-columns:1fr 1fr}}

/* 下層ページ共通 */
.p03-page{max-width:1100px;margin:0 auto;padding:60px 24px}
.p03-page__crumb{font-size:11.5px;color:var(--p03-mute);margin:0 0 18px}
.p03-page__h{text-align:center;margin:0 0 36px;padding-bottom:18px;border-bottom:1px solid var(--p03-line)}
.p03-page__h h1{font-family:var(--p03-font-display);font-weight:500;font-size:clamp(32px,4.5vw,52px);color:var(--p03-ink);margin:0 0 6px;letter-spacing:.08em}
.p03-page__h small{font-family:var(--p03-font-en);font-size:13px;color:var(--p03-green);font-style:italic}
.p03-page__lead{font-size:14.5px;line-height:1.85;color:var(--p03-ink-soft);margin:0 auto 36px;text-align:center;max-width:60ch}

.p03-jobs__grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}

.p03-job__hero{background:var(--p03-paper);padding:48px 0;margin-bottom:48px;border-bottom:3px solid var(--p03-green)}
.p03-job__hero__inner{max-width:1100px;margin:0 auto;padding:0 24px;display:grid;grid-template-columns:1fr 1fr;gap:36px;align-items:center}
.p03-job__hero__plate{aspect-ratio:4/3;overflow:hidden}
.p03-job__hero__plate img{width:100%;height:100%;object-fit:cover}
.p03-job__hero__code{font-family:var(--p03-font-en);font-style:italic;font-size:13px;color:var(--p03-green);font-weight:500;margin:0 0 14px}
.p03-job__hero__title{font-family:var(--p03-font-display);font-weight:600;font-size:clamp(26px,3.4vw,40px);line-height:1.35;color:var(--p03-ink);margin:0 0 14px;letter-spacing:.04em}
.p03-job__hero__sub{font-size:14.5px;line-height:1.85;color:var(--p03-ink-soft);margin:0 0 22px}
.p03-job__hero__meta{display:grid;grid-template-columns:auto 1fr;gap:8px 24px;font-size:13.5px;padding-top:18px;border-top:1px solid var(--p03-line)}
.p03-job__hero__meta dt{font-family:var(--p03-font-en);font-size:11px;color:var(--p03-green);font-style:italic;letter-spacing:.04em}
.p03-job__hero__meta dd{margin:0;color:var(--p03-ink);font-weight:500}
@media (max-width:880px){.p03-job__hero__inner{grid-template-columns:1fr}}

.p03-job__sec{max-width:1100px;margin:0 auto;padding:0 24px 48px}
.p03-job__sec__head{font-family:var(--p03-font-display);font-weight:600;font-size:22px;color:var(--p03-ink);margin:0 0 18px;padding-bottom:10px;border-bottom:1px solid var(--p03-green);letter-spacing:.04em;display:flex;align-items:baseline;gap:12px}
.p03-job__sec__head small{font-family:var(--p03-font-en);font-size:13px;color:var(--p03-green);font-style:italic;font-weight:400}

.p03-day{display:grid;grid-template-columns:120px 1fr;gap:0;border-top:1px solid var(--p03-line)}
.p03-day__time{padding:18px 14px;border-bottom:1px solid var(--p03-line);font-family:var(--p03-font-display);font-weight:600;font-size:18px;color:var(--p03-green)}
.p03-day__body{padding:18px 24px;border-bottom:1px solid var(--p03-line);border-left:1px solid var(--p03-line)}
.p03-day__body h4{font-weight:600;font-size:15px;margin:0 0 4px}
.p03-day__body p{font-size:13px;color:var(--p03-ink-soft);margin:0;line-height:1.85}
.p03-day__row{display:contents}

.p03-reqtable{width:100%;border-collapse:collapse;font-size:14px}
.p03-reqtable tr{border-bottom:1px solid var(--p03-line)}
.p03-reqtable th{font-family:var(--p03-font-display);font-weight:600;font-size:13px;color:var(--p03-green);text-align:left;padding:16px 20px 16px 0;width:200px;vertical-align:top;background:var(--p03-green-light)}
.p03-reqtable td{padding:16px 20px;color:var(--p03-ink);line-height:1.85}

.p03-faqlist{border-top:1px solid var(--p03-green)}
.p03-faqitem{border-bottom:1px solid var(--p03-line);background:#fff}
.p03-faqitem summary{font-family:var(--p03-font-display);font-weight:600;font-size:15px;color:var(--p03-ink);cursor:pointer;list-style:none;padding:18px 20px;display:flex;gap:14px}
.p03-faqitem summary::before{content:"Q.";color:var(--p03-green);font-family:var(--p03-font-en);font-weight:700}
.p03-faqitem summary::after{content:"+";margin-left:auto;color:var(--p03-mute)}
.p03-faqitem[open] summary::after{content:"−"}
.p03-faqitem div{padding:0 20px 18px 56px;font-size:14px;color:var(--p03-ink-soft);line-height:1.85}

.p03-form{display:grid;gap:18px;max-width:680px;margin:0 auto}
.p03-form label{display:block;font-weight:600;font-size:13px;color:var(--p03-ink);margin:0 0 6px;font-family:var(--p03-font-display)}
.p03-form label small{font-weight:400;color:#c00;margin-left:6px}
.p03-form input,.p03-form select,.p03-form textarea{width:100%;font:inherit;padding:12px 14px;border:1px solid var(--p03-line);background:#fff;color:var(--p03-ink);border-radius:0}
.p03-form input:focus,.p03-form select:focus,.p03-form textarea:focus{outline:none;border-color:var(--p03-green);box-shadow:0 0 0 2px var(--p03-green-light)}
.p03-form button{background:var(--p03-green);color:#fff;padding:14px 36px;font-weight:700;font-size:14px;border:0;cursor:pointer;justify-self:start;margin-top:6px}
.p03-form button:hover{background:var(--p03-green-d)}
.p03-form__note{font-size:12px;color:var(--p03-ink-soft);background:var(--p03-paper);padding:14px 18px;border-left:3px solid var(--p03-green);margin-bottom:18px}

.p03-history{border-top:1px solid var(--p03-line)}
.p03-history__row{display:grid;grid-template-columns:120px 1fr;gap:24px;padding:18px 0;border-bottom:1px solid var(--p03-line)}
.p03-history__year{font-family:var(--p03-font-display);font-weight:600;font-size:18px;color:var(--p03-green);letter-spacing:.04em}
.p03-history__event{font-size:14px;color:var(--p03-ink);line-height:1.7}
.p03-message{background:var(--p03-paper);padding:48px 36px;margin-top:60px;border-left:6px solid var(--p03-green)}
.p03-message__title{font-family:var(--p03-font-display);font-weight:600;font-size:clamp(22px,2.8vw,32px);line-height:1.5;color:var(--p03-ink);margin:0 0 22px;letter-spacing:.04em}
.p03-message__body{font-size:14.5px;line-height:2;color:var(--p03-ink);max-width:64ch;white-space:pre-line}
.p03-message__sign{margin-top:24px;padding-top:14px;border-top:1px solid var(--p03-line);font-family:var(--p03-font-display);font-weight:600;font-size:14px;color:var(--p03-green)}

/* 動的要素 */
html.p03-motion-ready .p03-hero__h{opacity:0;transform:translateY(30px);transition:opacity 1.2s ease .3s,transform 1.2s ease .3s}
html.p03-motion-ready body.loaded .p03-hero__h{opacity:1;transform:translateY(0) translateY(-50%)}
html.p03-motion-ready .p03-hero__movie{opacity:0;transition:opacity 1s ease .8s,transform .25s ease}
html.p03-motion-ready body.loaded .p03-hero__movie{opacity:1}
html.p03-motion-ready .p03-hero__movie:hover{transform:translateY(-2px)}
html.p03-motion-ready .p03-reveal{opacity:0;transform:translateY(20px);transition:opacity .8s ease,transform .8s ease}
html.p03-motion-ready .p03-reveal.p03-in{opacity:1;transform:none}

.p03-skip{position:absolute;left:-9999px;top:0;background:var(--p03-green);color:#fff;padding:8px 14px}
.p03-skip:focus{left:14px;top:14px;z-index:100}
