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

/* 真似元: 三井住友銀行 採用サイト smbc-freshers.com/
   観察結果(captures/16-smbc-freshers/):
   - 上部に深い緑のヘッダー帯(~#003828)、ロゴは黄色/ライムの折り紙マーク + "SMBC"(白セリフ)
   - ヘッダー直下に細いライムイエロー(#D6E021系)のアクセントライン
   - 右肩に「SMBCグループ」「2027卒マイページ」「2028卒マイページ」「海外大生の方はこちら」等の小さなテキストリンク
   - ヒーロー: 真っ白な背景に、傾けた巨大な明朝体テキスト2行(ぼかし観察: 「○○ ○○ ／ ○○ ○○ ○○○」)
   - サブページ: 上部に同じ緑ヘッダー、白背景、傾けた人物ポートレート板が中央に置かれ右下に影
   - そのすぐ下に小さなサムネ3枚のバナー帯(入社一覧 / 働く場所としてのSMBC / SMBC STUDIO)
   - ページ最下部: INTERVIEW セクション(8〜12枚のポートレートタイル)
   - フッター: 「SMBC 三井住友銀行」の緑のミニロゴと細い著作権テキスト
   - 全体: セリフ(Noto Serif JP)、余白広め、上品な金融サイト */

:root{
  --p16-green:#003828;
  --p16-green-dark:#002A1E;
  --p16-green-mid:#1A5942;
  --p16-lime:#D6E021;
  --p16-lime-soft:#E8EE6B;
  --p16-gold:#C9A958;
  --p16-ink:#1A1A1A;
  --p16-ink-soft:#3a3a3a;
  --p16-mute:#888;
  --p16-paper:#F5F4EE;
  --p16-line:#E5E3DC;
  --p16-bg:#fff;
}

*{box-sizing:border-box}
html,body{margin:0;padding:0}
html{background:var(--p16-bg);color:var(--p16-ink);font-family:var(--p16-font-serif);font-weight:400;font-size:14px;line-height:1.9;-webkit-font-smoothing:antialiased}
img{max-width:100%;display:block;height:auto}
a{color:inherit;text-decoration:none}

/* ===== HEADER (緑バー + ライムライン) ===== */
.p16-skip{position:absolute;left:-9999px;top:0;background:var(--p16-green);color:#fff;padding:8px 14px}
.p16-skip:focus{left:14px;top:14px;z-index:100}

.p16-header{position:sticky;top:0;z-index:30;background:var(--p16-green);color:#fff;padding:18px 32px;display:grid;grid-template-columns:auto 1fr auto;align-items:center;gap:24px;border-bottom:3px solid var(--p16-lime)}
.p16-header__brand{display:flex;align-items:center;gap:14px;color:#fff}
.p16-header__logo{width:24px;height:32px;display:inline-block;position:relative}
.p16-header__logo::before{content:"";position:absolute;left:0;top:0;width:10px;height:32px;background:var(--p16-lime);clip-path:polygon(0 0,100% 6px,100% 100%,0 calc(100% - 6px))}
.p16-header__logo::after{content:"";position:absolute;left:14px;top:0;width:10px;height:32px;background:var(--p16-gold);clip-path:polygon(0 6px,100% 0,100% calc(100% - 6px),0 100%)}
.p16-header__brand strong{font-family:var(--p16-font-serif);font-weight:600;font-size:22px;letter-spacing:.12em;color:#fff}
.p16-header__util{display:flex;align-items:center;gap:18px;font-family:var(--p16-font-serif);font-size:12px;color:#e8eee0}
.p16-header__util a{color:#e8eee0;letter-spacing:.04em}
.p16-header__util a:hover{color:var(--p16-lime)}
.p16-header__util .p16-grp{font-size:11px;letter-spacing:.14em;opacity:.85}

/* ===== INDEX ヒーロー(真っ白な広い余白 + 巨大セリフ + ぼかし) ===== */
.p16-hero{background:#fff;position:relative;padding:140px 64px 100px;min-height:78vh;overflow:hidden}
.p16-hero__main{position:relative;max-width:1100px;margin:0 auto}
.p16-hero__copy{font-family:var(--p16-font-serif);font-weight:700;font-size:clamp(48px,8.4vw,118px);line-height:1.15;letter-spacing:.04em;color:var(--p16-ink);margin:0}
.p16-hero__copy span{display:block}
.p16-hero__copy .p16-hero__top{transform:translateX(-2%) skewX(-4deg);transform-origin:left center}
.p16-hero__copy .p16-hero__bot{margin-top:18px;transform:translateX(18%) skewX(-4deg);transform-origin:left center;color:var(--p16-green-mid)}
.p16-hero__sub{font-family:var(--p16-font-serif);font-size:16px;line-height:2;color:var(--p16-ink-soft);max-width:560px;margin-top:48px;letter-spacing:.04em}
.p16-hero__eyebrow{font-family:var(--p16-font-sans);font-size:11px;letter-spacing:.32em;color:var(--p16-green-mid);margin-bottom:18px;display:block;font-weight:600}

/* スクロールサイン */
.p16-hero__scroll{position:absolute;right:48px;bottom:48px;color:var(--p16-green);font-family:var(--p16-font-sans);font-size:10px;letter-spacing:.32em;writing-mode:vertical-rl}
.p16-hero__scroll::after{content:"";display:block;width:1px;height:64px;background:var(--p16-green);margin:14px auto 0}

/* ===== バナー帯(小サムネ3枚) ===== */
.p16-banners{background:#fff;border-top:1px solid var(--p16-line);padding:28px 32px;display:flex;flex-wrap:wrap;justify-content:center;align-items:stretch;gap:14px}
.p16-banner{display:flex;align-items:center;gap:12px;background:var(--p16-green);color:#fff;padding:12px 22px;min-width:240px;max-width:300px;border-radius:2px;font-family:var(--p16-font-serif);font-size:13px;line-height:1.4}
.p16-banner small{display:block;font-family:var(--p16-font-sans);font-size:9.5px;letter-spacing:.24em;color:var(--p16-lime);font-weight:600;margin-bottom:4px}
.p16-banner b{font-weight:600;letter-spacing:.04em}
.p16-banner__arrow{margin-left:auto;color:var(--p16-lime);font-size:14px}
.p16-banner--gold{background:var(--p16-green-mid)}
.p16-banner--studio{background:var(--p16-green-dark)}

/* ===== INTERVIEW グリッド(下部のポートレートタイル群) ===== */
.p16-interview{background:#fff;padding:96px 32px 64px}
.p16-interview__inner{max-width:1100px;margin:0 auto}
.p16-interview__head{font-family:var(--p16-font-sans);font-size:12px;letter-spacing:.4em;color:var(--p16-green);font-weight:600;margin:0 0 36px;display:flex;align-items:baseline;gap:18px}
.p16-interview__head::after{content:"";flex:1;height:1px;background:var(--p16-line)}
.p16-interview__grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}
.p16-itile{position:relative;display:block;background:var(--p16-paper);aspect-ratio:3/4;overflow:hidden;color:#fff}
.p16-itile img{width:100%;height:100%;object-fit:cover;transition:transform .5s ease}
.p16-itile:hover img{transform:scale(1.05)}
.p16-itile__num{position:absolute;left:10px;top:10px;background:var(--p16-lime);color:var(--p16-green);font-family:var(--p16-font-sans);font-size:10px;font-weight:700;letter-spacing:.16em;padding:4px 9px}
.p16-itile__name{position:absolute;left:0;bottom:0;right:0;padding:12px 14px;background:linear-gradient(transparent,rgba(0,40,30,.85));color:#fff;font-family:var(--p16-font-serif);font-weight:600;font-size:13.5px;line-height:1.45;letter-spacing:.04em}
.p16-itile__name small{display:block;font-family:var(--p16-font-sans);font-size:10px;letter-spacing:.18em;font-weight:500;color:var(--p16-lime);margin-bottom:4px}

/* ===== FOOTER ===== */
.p16-cta-bottom{background:#fff;text-align:center;padding:60px 32px 80px}
.p16-cta-bottom a{display:inline-block;background:var(--p16-green);color:#fff;border:2px solid var(--p16-green);padding:18px 56px;border-radius:30px;font-family:var(--p16-font-serif);font-weight:600;font-size:14px;letter-spacing:.18em;margin:0 6px}
.p16-cta-bottom a + a{background:#fff;color:var(--p16-green)}

.p16-foot{background:#fff;border-top:1px solid var(--p16-line);padding:40px 32px 48px;text-align:center;color:var(--p16-mute);font-size:11px;letter-spacing:.06em}
.p16-foot__logo{display:inline-flex;align-items:center;gap:10px;color:var(--p16-green);font-family:var(--p16-font-serif);font-weight:600;font-size:18px;letter-spacing:.1em;margin-bottom:18px}
.p16-foot__logo::before{content:"";display:inline-block;width:20px;height:24px;background:linear-gradient(180deg,var(--p16-lime) 0 50%,var(--p16-gold) 50% 100%);clip-path:polygon(0 0,100% 10%,100% 90%,0 100%)}
.p16-foot__note{max-width:880px;margin:0 auto;line-height:1.8;color:var(--p16-mute)}
.p16-foot__note small{display:block;margin-top:8px;font-size:10px;opacity:.75}

/* ===========================================================
   下層ページ共通
   ----------------------------------------------------------- */
.p16-page{background:#fff;min-height:60vh;padding:0}
.p16-page__hero{background:#fff;padding:80px 64px 48px;text-align:left;max-width:1100px;margin:0 auto;position:relative}
.p16-page__eyebrow{font-family:var(--p16-font-sans);font-size:11px;letter-spacing:.36em;color:var(--p16-green);font-weight:600;margin:0 0 18px}
.p16-page__title{font-family:var(--p16-font-serif);font-weight:700;font-size:clamp(38px,5.4vw,72px);letter-spacing:.06em;line-height:1.2;color:var(--p16-ink);margin:0 0 24px}
.p16-page__title span{display:block;font-size:.45em;color:var(--p16-green-mid);font-weight:500;letter-spacing:.18em;margin-top:14px}
.p16-page__crumb{font-family:var(--p16-font-sans);font-size:11px;color:var(--p16-mute);max-width:1100px;margin:0 auto;padding:14px 64px 0;letter-spacing:.08em}
.p16-page__crumb a{color:var(--p16-mute)}
.p16-page__crumb a:hover{color:var(--p16-green)}
.p16-page__inner{max-width:1100px;margin:0 auto;padding:0 64px 80px}
.p16-page__lead{font-family:var(--p16-font-serif);font-size:16px;line-height:2.05;color:var(--p16-ink-soft);margin:0 0 56px;max-width:64ch}

/* JOBS index — タイル(SMBCの「働く場所としてのSMBC」風) */
.p16-jobs__grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;max-width:1100px;margin:0 auto;padding:0 64px 80px}
.p16-jobcard{display:flex;flex-direction:column;background:#fff;border:1px solid var(--p16-line);transition:transform .25s ease,box-shadow .25s ease;color:var(--p16-ink)}
.p16-jobcard:hover{transform:translateY(-3px);box-shadow:0 12px 32px rgba(0,56,40,.12)}
.p16-jobcard__plate{aspect-ratio:4/3;overflow:hidden;background:var(--p16-paper);position:relative}
.p16-jobcard__plate img{width:100%;height:100%;object-fit:cover}
.p16-jobcard__plate::before{content:"";position:absolute;left:0;bottom:0;width:88px;height:6px;background:var(--p16-lime);z-index:1}
.p16-jobcard__body{padding:24px 24px 28px}
.p16-jobcard__code{font-family:var(--p16-font-sans);font-size:10.5px;font-weight:600;color:var(--p16-green);letter-spacing:.22em;margin:0 0 10px}
.p16-jobcard__title{font-family:var(--p16-font-serif);font-weight:700;font-size:20px;color:var(--p16-ink);margin:0 0 8px;line-height:1.5;letter-spacing:.04em}
.p16-jobcard__sub{font-family:var(--p16-font-serif);font-size:13px;color:var(--p16-ink-soft);margin:0 0 16px;line-height:1.85}
.p16-jobcard__meta{display:flex;flex-wrap:wrap;gap:14px;font-family:var(--p16-font-sans);font-size:11px;color:var(--p16-ink-soft);padding-top:14px;border-top:1px solid var(--p16-line);letter-spacing:.04em}
.p16-jobcard__meta b{color:var(--p16-green);font-weight:600;margin-right:6px;font-size:10px;letter-spacing:.14em;text-transform:uppercase}

/* JOB 詳細 — 傾き写真ヒーロー(SMBC interview ページの構図) */
.p16-job__hero{background:#fff;padding:64px 32px 48px;position:relative;overflow:hidden}
.p16-job__hero__inner{position:relative;max-width:1100px;margin:0 auto;display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:center}
.p16-job__hero__plate{position:relative;transform:rotate(-3deg);box-shadow:18px 22px 0 var(--p16-paper),24px 28px 36px rgba(0,40,30,.18);background:#fff;padding:14px}
.p16-job__hero__plate img{width:100%;aspect-ratio:4/5;object-fit:cover}
.p16-job__hero__plate::before{content:"";position:absolute;right:-10px;top:-10px;width:80px;height:80px;background:var(--p16-lime);z-index:-1}
.p16-job__hero__text .p16-page__eyebrow{margin-bottom:24px}
.p16-job__hero__num{font-family:var(--p16-font-sans);font-size:13px;font-weight:700;letter-spacing:.32em;color:var(--p16-green);margin:0 0 14px}
.p16-job__hero__title{font-family:var(--p16-font-serif);font-weight:700;font-size:clamp(28px,3.6vw,42px);line-height:1.4;letter-spacing:.06em;color:var(--p16-ink);margin:0 0 18px}
.p16-job__hero__sub{font-family:var(--p16-font-serif);font-size:15px;line-height:2;color:var(--p16-ink-soft);margin:0 0 28px}
.p16-job__hero__meta{display:grid;grid-template-columns:1fr 1fr;gap:14px 24px;font-size:12.5px;border-top:1px solid var(--p16-line);padding-top:18px}
.p16-job__hero__meta dt{font-family:var(--p16-font-sans);font-size:10px;letter-spacing:.18em;color:var(--p16-green);font-weight:600;margin:0 0 4px;text-transform:uppercase}
.p16-job__hero__meta dd{margin:0 0 4px;color:var(--p16-ink);font-family:var(--p16-font-serif);font-weight:600;font-size:14px}

/* JOB セクション */
.p16-job__sec{max-width:1100px;margin:0 auto;padding:48px 64px 0;position:relative}
.p16-job__sec__bar{display:flex;align-items:baseline;gap:18px;margin:0 0 28px;border-bottom:1px solid var(--p16-line);padding-bottom:16px}
.p16-job__sec__bar__tag{font-family:var(--p16-font-sans);font-size:11px;letter-spacing:.24em;color:var(--p16-green);font-weight:700;text-transform:uppercase}
.p16-job__sec__bar__title{font-family:var(--p16-font-serif);font-weight:700;font-size:clamp(20px,2.4vw,28px);color:var(--p16-ink);letter-spacing:.06em;margin:0}
.p16-job__sec p{font-family:var(--p16-font-serif);font-size:15px;line-height:2.05;color:var(--p16-ink);margin:0 0 14px}
.p16-job__sec ul{padding-left:1.2em;margin:0;font-family:var(--p16-font-serif);font-size:15px;line-height:2;color:var(--p16-ink)}
.p16-job__sec ul li{margin:0 0 8px;list-style:none;position:relative;padding-left:18px}
.p16-job__sec ul li::before{content:"";position:absolute;left:0;top:.85em;width:8px;height:8px;background:var(--p16-lime);clip-path:polygon(0 0,100% 50%,0 100%)}

/* 1日の流れ(縦タイムライン) */
.p16-day{display:flex;flex-direction:column;gap:0;border-left:2px solid var(--p16-green);padding:8px 0 8px 0;margin-top:8px}
.p16-day__row{display:grid;grid-template-columns:130px 1fr;gap:0;border-bottom:1px dashed var(--p16-line);padding:18px 0;position:relative}
.p16-day__row::before{content:"";position:absolute;left:-7px;top:30px;width:12px;height:12px;background:var(--p16-lime);border:2px solid var(--p16-green);border-radius:50%}
.p16-day__time{font-family:var(--p16-font-sans);font-weight:700;font-size:18px;color:var(--p16-green);letter-spacing:.04em;padding:0 0 0 24px}
.p16-day__body{padding:0 8px}
.p16-day__body h4{font-family:var(--p16-font-serif);font-weight:700;font-size:16px;margin:0 0 6px;color:var(--p16-ink);letter-spacing:.04em}
.p16-day__body p{font-family:var(--p16-font-serif);font-size:13.5px;color:var(--p16-ink-soft);margin:0;line-height:1.9}

/* requirements table */
.p16-reqtable{width:100%;border-collapse:collapse;font-size:14.5px;border-top:2px solid var(--p16-green);font-family:var(--p16-font-serif)}
.p16-reqtable tr{border-bottom:1px solid var(--p16-line)}
.p16-reqtable th{font-weight:700;font-size:13px;color:var(--p16-green);text-align:left;padding:22px 24px 22px 0;width:200px;vertical-align:top;letter-spacing:.06em}
.p16-reqtable td{padding:22px 0;color:var(--p16-ink);line-height:2}

/* faq */
.p16-faqlist{border-top:2px solid var(--p16-green);max-width:880px;margin:0 auto}
.p16-faqitem{border-bottom:1px solid var(--p16-line);background:#fff}
.p16-faqitem summary{font-family:var(--p16-font-serif);font-weight:600;font-size:16px;color:var(--p16-ink);cursor:pointer;list-style:none;padding:22px 0;display:flex;gap:18px;align-items:flex-start;letter-spacing:.04em}
.p16-faqitem summary::-webkit-details-marker{display:none}
.p16-faqitem summary::before{content:"Q.";font-family:var(--p16-font-serif);font-weight:700;color:var(--p16-green);font-size:22px;line-height:1;flex-shrink:0}
.p16-faqitem summary::after{content:"＋";margin-left:auto;color:var(--p16-green);font-size:18px;font-weight:300}
.p16-faqitem[open] summary::after{content:"−"}
.p16-faqitem div{padding:0 0 22px 44px;font-family:var(--p16-font-serif);font-size:14.5px;color:var(--p16-ink-soft);line-height:2;display:flex;gap:18px}
.p16-faqitem div::before{content:"A.";font-family:var(--p16-font-serif);font-weight:700;color:var(--p16-gold);font-size:22px;line-height:1;flex-shrink:0;margin-left:-30px}

/* apply form */
.p16-form{display:grid;gap:24px;max-width:680px;margin:0 auto;font-family:var(--p16-font-serif)}
.p16-form__note{font-family:var(--p16-font-serif);font-size:13px;color:var(--p16-ink-soft);background:var(--p16-paper);padding:18px 24px;border-left:3px solid var(--p16-green);max-width:680px;margin:0 auto 28px;line-height:1.95}
.p16-form label{display:block;font-family:var(--p16-font-serif);font-weight:600;font-size:13px;color:var(--p16-ink);margin:0 0 10px;letter-spacing:.06em}
.p16-form label small{font-weight:500;color:#c33;margin-left:8px;font-size:10.5px}
.p16-form input,.p16-form select,.p16-form textarea{width:100%;font:inherit;font-family:var(--p16-font-serif);padding:15px 18px;border:1px solid var(--p16-line);background:#fff;color:var(--p16-ink);border-radius:0;font-size:14.5px}
.p16-form input:focus,.p16-form select:focus,.p16-form textarea:focus{outline:none;border-color:var(--p16-green);box-shadow:0 0 0 3px rgba(0,56,40,.10)}
.p16-form button{background:var(--p16-green);color:#fff;padding:18px 56px;font-family:var(--p16-font-serif);font-weight:600;font-size:14px;letter-spacing:.2em;border:0;cursor:pointer;justify-self:center;margin-top:8px;border-radius:30px}
.p16-form button:hover{background:var(--p16-green-dark)}

/* history */
.p16-history{border-top:2px solid var(--p16-green);max-width:880px;margin:0 auto;font-family:var(--p16-font-serif)}
.p16-history__row{display:grid;grid-template-columns:140px 1fr;gap:24px;padding:24px 0;border-bottom:1px solid var(--p16-line);align-items:baseline}
.p16-history__year{font-family:var(--p16-font-sans);font-weight:700;font-size:20px;color:var(--p16-green);letter-spacing:.06em}
.p16-history__event{font-size:14.5px;color:var(--p16-ink);line-height:2}

/* message — トップメッセージ(白背景 + 緑帯 + セリフ大見出し) */
.p16-message{position:relative;background:#fff;padding:80px 64px;margin:0 auto;max-width:1100px;overflow:hidden}
.p16-message__bg{position:absolute;right:0;top:8%;width:38%;height:78%;background:var(--p16-paper);z-index:0}
.p16-message__bg2{position:absolute;left:0;bottom:6%;width:120px;height:6px;background:var(--p16-lime);z-index:0}
.p16-message__title{position:relative;font-family:var(--p16-font-serif);font-weight:700;font-size:clamp(32px,4.6vw,56px);letter-spacing:.06em;line-height:1.4;color:var(--p16-ink);margin:0 0 36px;z-index:1}
.p16-message__inner{position:relative;z-index:2;background:#fff;padding:36px 44px;border:1px solid var(--p16-line);max-width:880px}
.p16-message__lead{font-family:var(--p16-font-serif);font-weight:700;font-size:clamp(20px,2.4vw,28px);line-height:1.7;color:var(--p16-green);margin:0 0 28px;padding-bottom:28px;border-bottom:1px solid var(--p16-line);letter-spacing:.06em}
.p16-message__body{font-family:var(--p16-font-serif);font-size:15px;line-height:2.1;color:var(--p16-ink-soft);max-width:64ch;white-space:pre-line}
.p16-message__sign{margin-top:28px;font-family:var(--p16-font-serif);font-weight:600;font-size:13.5px;color:var(--p16-green);text-align:right;letter-spacing:.06em}
.p16-message__sign b{color:var(--p16-ink);font-size:16px;display:block;margin-top:4px}

/* ===== Responsive ===== */
@media (max-width:880px){
  .p16-header{grid-template-columns:auto 1fr;gap:12px;padding:14px 16px}
  .p16-header__util{display:none}
  .p16-hero{padding:80px 24px 60px}
  .p16-hero__copy{font-size:clamp(40px,12vw,72px)}
  .p16-hero__copy .p16-hero__bot{transform:translateX(8%) skewX(-4deg)}
  .p16-hero__scroll{display:none}
  .p16-banners{padding:20px 16px;gap:10px}
  .p16-banner{min-width:0;width:100%;max-width:none}
  .p16-interview{padding:60px 16px}
  .p16-interview__grid{grid-template-columns:repeat(2,1fr);gap:10px}
  .p16-page__hero,.p16-page__inner,.p16-page__crumb{padding-left:20px;padding-right:20px}
  .p16-jobs__grid{grid-template-columns:1fr;padding:0 20px 60px}
  .p16-job__hero__inner{grid-template-columns:1fr;gap:32px}
  .p16-job__hero__plate{margin:0 16px}
  .p16-job__sec{padding:40px 20px 0}
  .p16-day__row{grid-template-columns:90px 1fr}
  .p16-history__row{grid-template-columns:90px 1fr}
  .p16-message{padding:48px 20px}
  .p16-message__inner{padding:24px}
  .p16-cta-bottom a{display:block;margin:8px auto;max-width:280px}
}

/* ===== Motion ===== */
html.p16-motion-ready .p16-reveal{opacity:0;transform:translateY(20px);transition:opacity .9s ease var(--p16-delay,0ms),transform .9s ease var(--p16-delay,0ms)}
html.p16-motion-ready .p16-reveal.p16-in{opacity:1;transform:none}
@media (prefers-reduced-motion:reduce){html.p16-motion-ready .p16-reveal{opacity:1;transform:none;transition:none}}
