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

/* 真似元: 星野リゾート 採用サイト hoshinoresorts.com/jp/recruit/
   観察結果:
   - 全体に温かいクリーム色背景 rgb(252,245,239) #fcf5ef
   - 上部に大きなイラストヒーロー: ぶらんこ・人々・絵を描く人・牛・スキーヤー + 雲 + 黄土色の地面
   - 左上に「星野リゾート RECRUITMENT」(縦組のロゴと横の小さい英字)
   - 右上に MENU ハンバーガー(円形)・黒い ENTRY ボタン
   - ロゴの下「Hoshino Resorts」筆記体風
   - 中段ぐにゃぐにゃした白い波線(HISTORY ページ参照)
   - ページ下部「年次ENTRY」3枚カード: 27卒(オレンジピンク)/キャリア採用(緑)/パートナー社員(水色)
   - フッター: クリーム白、「TOP へ戻る」が橙色の8角形バッジ(回転スター)
   - 主色: クリーム #fcf5ef / インク #080808 / オレンジ橙(アクセント) #f48a4e / ピンクオレンジカード #ed8163 / グリーン #5a8e60 / 水色 #7dbed1 / 地面マスタード #f5c64a
*/

:root{
  --p27-bg:#fcf5ef;
  --p27-paper:#fff;
  --p27-ink:#080808;
  --p27-ink-soft:#3a3a3a;
  --p27-mute:#888475;
  --p27-line:#e6dccf;
  --p27-accent:#f48a4e;
  --p27-orange:#ed8163;
  --p27-green:#5a8e60;
  --p27-blue:#7dbed1;
  --p27-mustard:#f5c64a;
  --p27-rose:#e7a39a;
  --p27-cream-2:#fbece0;
}
*{box-sizing:border-box}
html,body{margin:0;padding:0}
html{background:var(--p27-bg);color:var(--p27-ink);font-family:var(--p27-font-body);font-weight:400;font-size:14px;line-height:1.85;-webkit-font-smoothing:antialiased}
body.p27-no-scroll{overflow:hidden}
img{max-width:100%;display:block;height:auto}
a{color:inherit;text-decoration:none}

/* ===== SKIP ===== */
.p27-skip{position:absolute;left:-9999px;top:0;background:var(--p27-ink);color:#fff;padding:8px 14px}
.p27-skip:focus{left:14px;top:14px;z-index:200}

/* ===== HEADER (sticky) ===== */
.p27-header{position:sticky;top:0;z-index:60;background:var(--p27-bg);padding:14px 28px;display:grid;grid-template-columns:auto 1fr auto;align-items:center;gap:18px}
.p27-header__brand{display:flex;align-items:baseline;gap:8px;text-decoration:none;color:var(--p27-ink)}
.p27-header__brand strong{font-family:var(--p27-font-body);font-weight:900;font-size:15px;letter-spacing:.04em}
.p27-header__brand small{font-family:var(--p27-font-display);font-weight:700;font-size:9.5px;letter-spacing:.18em;color:var(--p27-ink);position:relative;top:-2px}
.p27-header__util{display:flex;align-items:center;gap:14px}
.p27-entry-btn{background:var(--p27-ink);color:#fff;padding:11px 28px;font-family:var(--p27-font-display);font-weight:700;letter-spacing:.18em;font-size:11px;border-radius:2px;display:inline-block}
.p27-entry-btn:hover{background:#2a2a2a}
.p27-hb{display:inline-flex;align-items:center;gap:8px;width:auto;padding:8px 14px 8px 18px;background:#fff;color:var(--p27-ink);border:1px solid var(--p27-ink);border-radius:999px;font-family:var(--p27-font-display);font-weight:700;font-size:11px;letter-spacing:.2em;cursor:pointer}
.p27-hb__bars{display:inline-flex;flex-direction:column;gap:3px}
.p27-hb__bars span{display:block;width:18px;height:1.5px;background:var(--p27-ink)}

/* DRAWER */
.p27-drawer{position:fixed;inset:0;background:var(--p27-bg);transform:translateY(-100%);transition:transform .35s ease;z-index:50;padding:80px 36px 36px;overflow:auto}
.p27-drawer.is-open{transform:translateY(0)}
.p27-drawer ul{list-style:none;padding:0;margin:0;display:grid;gap:6px;max-width:720px}
.p27-drawer a{display:block;padding:14px 4px;border-bottom:1px solid var(--p27-line);font-weight:700;font-size:15px}
.p27-drawer a small{color:var(--p27-mute);font-weight:500;font-size:11px;margin-left:8px;letter-spacing:.16em;font-family:var(--p27-font-display)}

/* ===== HERO ===== */
.p27-hero{position:relative;background:var(--p27-bg);padding:28px 0 0;overflow:hidden;min-height:520px}
.p27-hero__inner{position:relative;display:grid;grid-template-columns:minmax(220px,28%) 1fr;align-items:start;gap:24px;padding:0 36px;max-width:1320px;margin:0 auto}
.p27-hero__lockup{padding-top:14px}
.p27-hero__lockup .p27-mark{font-family:var(--p27-font-body);font-weight:900;font-size:46px;line-height:1;letter-spacing:.02em;color:var(--p27-ink);display:block}
.p27-hero__lockup .p27-mark::after{content:"";display:inline-block;width:6px;height:6px;border-radius:50%;background:var(--p27-accent);transform:translate(-4px,-28px)}
.p27-hero__lockup .p27-mark-en{font-family:'Pacifico','Brush Script MT','Comic Sans MS',cursive;font-size:32px;color:var(--p27-ink);display:block;margin-top:8px;font-weight:500}
.p27-hero__illu{position:relative;height:520px}
.p27-hero__illu svg{width:100%;height:100%;display:block}
.p27-hero__ground{position:absolute;left:0;right:0;bottom:0;height:120px;background:var(--p27-mustard)}
.p27-hero__cloud{position:absolute;background:#fff;border-radius:60px;opacity:.95;will-change:transform}
.p27-hero__cloud--1{width:140px;height:46px;left:6%;bottom:130px;border-radius:60% 60% 50% 50%/60% 60% 50% 50%;box-shadow:30px -8px 0 -4px #fff,-30px -4px 0 -6px #fff}
.p27-hero__cloud--2{width:96px;height:36px;right:18%;top:36%;border-radius:60% 60% 50% 50%/60% 60% 50% 50%}
.p27-hero__cloud--3{width:120px;height:40px;left:42%;top:14%;border-radius:60% 60% 50% 50%/60% 60% 50% 50%}
.p27-hero__cloud--4{width:80px;height:30px;right:6%;bottom:170px;border-radius:60% 60% 50% 50%/60% 60% 50% 50%}

.p27-hero__menubadge{position:absolute;right:36px;top:0;display:flex;align-items:center;gap:8px}

/* ヒーロー下: 雲のなみなみ境界(クリーム→白) */
.p27-cloudwave{position:relative;background:var(--p27-mustard);height:80px}
.p27-cloudwave::after{content:"";position:absolute;left:0;right:0;bottom:0;height:60px;background:radial-gradient(ellipse 60px 28px at 5% 100%,var(--p27-bg) 50%,transparent 51%),radial-gradient(ellipse 80px 36px at 20% 100%,var(--p27-bg) 50%,transparent 51%),radial-gradient(ellipse 60px 26px at 35% 100%,var(--p27-bg) 50%,transparent 51%),radial-gradient(ellipse 90px 40px at 52% 100%,var(--p27-bg) 50%,transparent 51%),radial-gradient(ellipse 70px 28px at 70% 100%,var(--p27-bg) 50%,transparent 51%),radial-gradient(ellipse 80px 36px at 85% 100%,var(--p27-bg) 50%,transparent 51%),radial-gradient(ellipse 60px 26px at 98% 100%,var(--p27-bg) 50%,transparent 51%)}

/* ===== INDEX: CONTENTS section ===== */
.p27-section{padding:120px 28px;max-width:1180px;margin:0 auto;position:relative}
.p27-section__head{text-align:center;margin-bottom:64px}
.p27-section__head h2{font-family:var(--p27-font-display);font-weight:800;font-size:clamp(40px,5vw,72px);letter-spacing:.06em;margin:0;color:var(--p27-ink)}
.p27-section__head small{display:block;font-size:13px;letter-spacing:.24em;color:var(--p27-ink-soft);margin-top:14px}
.p27-section__head::after{content:"";display:block;width:1px;height:48px;background:var(--p27-ink);margin:32px auto 0}

.p27-contents{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:28px;padding-top:8px}
.p27-contents__item{background:#fff;border-radius:6px;overflow:hidden;display:block;position:relative;transition:transform .35s,box-shadow .35s;border:1px solid var(--p27-line)}
.p27-contents__item:hover{transform:translateY(-6px);box-shadow:0 22px 44px rgba(40,30,12,.10)}
.p27-contents__item img{aspect-ratio:5/4;object-fit:cover;width:100%}
.p27-contents__item__body{padding:20px 22px 24px}
.p27-contents__item__cat{font-family:var(--p27-font-display);font-size:10.5px;letter-spacing:.22em;color:var(--p27-accent);font-weight:700}
.p27-contents__item__title{font-weight:900;font-size:18px;margin:8px 0 6px;line-height:1.5}
.p27-contents__item__lead{font-size:12.5px;color:var(--p27-ink-soft);line-height:1.8;margin:0}

/* 数字バンド */
.p27-numbers{background:var(--p27-cream-2);padding:80px 28px;border-top:1px solid var(--p27-line);border-bottom:1px solid var(--p27-line)}
.p27-numbers__inner{max-width:1100px;margin:0 auto;display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:24px}
.p27-num{text-align:center;padding:12px}
.p27-num__v{font-family:var(--p27-font-display);font-weight:800;font-size:64px;line-height:1;color:var(--p27-ink)}
.p27-num__v sub{font-size:18px;font-weight:700;margin-left:4px;vertical-align:0}
.p27-num__label{font-weight:700;font-size:14px;margin:8px 0 4px}
.p27-num__note{font-size:11px;color:var(--p27-mute);margin:0}

/* MESSAGE 風 (illust strip) */
.p27-message{background:var(--p27-bg);padding:120px 28px;position:relative;overflow:hidden}
.p27-message__inner{max-width:880px;margin:0 auto;text-align:center;position:relative;z-index:2}
.p27-message__title{font-weight:900;font-size:clamp(20px,2.4vw,28px);letter-spacing:.04em;line-height:1.6;margin:0 0 28px}
.p27-message__body{text-align:left;font-size:14.5px;line-height:2;color:var(--p27-ink-soft);white-space:pre-wrap}
.p27-message__sign{margin-top:36px;text-align:right;font-weight:700}
.p27-message__sign b{font-size:18px;display:block;margin-top:4px}

/* ===== ENTRY 3-tile (orange/green/blue) ===== */
.p27-entry-tiles{display:grid;grid-template-columns:1fr 1fr 1fr;gap:0}
.p27-entry-tiles a{position:relative;padding:60px 32px 56px;color:#fff;display:flex;flex-direction:column;justify-content:center;align-items:center;text-align:center;min-height:240px;overflow:hidden;font-family:var(--p27-font-body)}
.p27-entry-tiles a strong{font-size:24px;font-weight:900;display:block;margin-bottom:6px;letter-spacing:.06em;line-height:1.4}
.p27-entry-tiles a strong em{font-style:normal;font-family:var(--p27-font-display);font-weight:800;font-size:42px;letter-spacing:0;display:inline-block;margin-right:6px}
.p27-entry-tiles a span{display:inline-block;border:1.5px solid #fff;padding:10px 36px;font-family:var(--p27-font-display);font-weight:700;letter-spacing:.24em;font-size:12px;margin-top:18px}
.p27-entry-tiles__1{background:var(--p27-orange);background-image:linear-gradient(180deg,#f29981 0%,#ed8163 100%)}
.p27-entry-tiles__1 strong+strong{margin-top:10px;font-size:18px}
.p27-entry-tiles__2{background:var(--p27-green);background-image:linear-gradient(180deg,#74a37a 0%,#5a8e60 100%)}
.p27-entry-tiles__3{background:var(--p27-blue);background-image:linear-gradient(180deg,#9ed1e0 0%,#7dbed1 100%)}

/* ===== FOOTER ===== */
.p27-foot{background:var(--p27-bg);padding:72px 28px 24px;position:relative;border-top:1px solid var(--p27-line)}
.p27-foot__top{position:absolute;right:36px;top:-32px;width:72px;height:72px;background:var(--p27-accent);color:#fff;display:flex;flex-direction:column;align-items:center;justify-content:center;font-family:var(--p27-font-display);font-weight:800;font-size:9px;letter-spacing:.14em;clip-path:polygon(50% 0,90% 22%,100% 50%,90% 78%,50% 100%,10% 78%,0 50%,10% 22%);text-align:center;line-height:1.3;animation:p27-spin 22s linear infinite}
.p27-foot__top small{font-size:8px;display:block;margin-top:2px}
@keyframes p27-spin{to{transform:rotate(360deg)}}
.p27-foot__brand{display:flex;align-items:baseline;gap:8px;margin-bottom:36px}
.p27-foot__brand strong{font-weight:900;font-size:18px}
.p27-foot__brand small{font-family:var(--p27-font-display);font-weight:700;font-size:11px;letter-spacing:.22em}
.p27-foot__cols{display:grid;grid-template-columns:repeat(3,1fr);gap:36px;padding-bottom:36px;border-bottom:1px solid var(--p27-line)}
.p27-foot__col h4{font-weight:900;font-size:13.5px;margin:0 0 14px;position:relative;padding-left:14px}
.p27-foot__col h4::before{content:"";position:absolute;left:0;top:8px;width:6px;height:6px;background:var(--p27-accent);border-radius:50%}
.p27-foot__col ul{list-style:none;padding:0;margin:0}
.p27-foot__col li{padding:4px 0;font-size:12.5px}
.p27-foot__col li small{color:var(--p27-mute);font-size:10.5px;margin-left:6px;letter-spacing:.16em;font-family:var(--p27-font-display)}
.p27-foot__legal{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:14px;padding-top:18px;font-size:11px;color:var(--p27-mute)}
.p27-foot__legal a{margin-right:14px}
.p27-foot__legal span{font-family:var(--p27-font-display);letter-spacing:.1em}

/* ===== SUB PAGES (共通) ===== */
.p27-page{padding:64px 28px 0;max-width:1180px;margin:0 auto;position:relative;min-height:520px}
.p27-page__crumb{font-size:11px;color:var(--p27-mute);letter-spacing:.04em;margin:0 0 24px}
.p27-page__crumb a{border-bottom:1px solid var(--p27-line);padding-bottom:2px}
.p27-page__hero{display:grid;grid-template-columns:1fr auto;align-items:center;gap:36px;margin-bottom:80px}
.p27-page__hero__title{font-family:var(--p27-font-display);font-weight:800;font-size:clamp(48px,6vw,86px);letter-spacing:.06em;margin:0;line-height:1}
.p27-page__hero__sub{font-weight:700;font-size:14px;margin:14px 0 0;letter-spacing:.04em}
.p27-page__hero__sub::before{content:"";display:inline-block;width:5px;height:5px;border-radius:50%;background:var(--p27-accent);margin:0 8px 3px 0;vertical-align:middle}
.p27-page__hero__photo{width:300px;height:200px;border-radius:120px;overflow:hidden;background:var(--p27-line)}
.p27-page__hero__photo img{width:100%;height:100%;object-fit:cover}
.p27-page__lead{font-size:15px;line-height:2.05;color:var(--p27-ink-soft);max-width:780px;margin:0 0 56px}
.p27-page__stamp{position:absolute;right:36px;top:280px;width:84px;height:84px;border:1px dashed var(--p27-accent);border-radius:50%;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;color:var(--p27-accent);font-family:var(--p27-font-display);font-weight:700;font-size:9px;letter-spacing:.14em;line-height:1.4;animation:p27-spin 30s linear infinite}

/* JOBS LIST */
.p27-jobs__grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:28px;padding:8px 0 80px}
.p27-jobcard{background:#fff;border:1px solid var(--p27-line);border-radius:6px;overflow:hidden;display:block;transition:transform .35s,box-shadow .35s}
.p27-jobcard:hover{transform:translateY(-6px);box-shadow:0 22px 44px rgba(40,30,12,.10)}
.p27-jobcard__plate{aspect-ratio:5/3;background:var(--p27-line);overflow:hidden}
.p27-jobcard__plate img{width:100%;height:100%;object-fit:cover}
.p27-jobcard__body{padding:22px 22px 26px}
.p27-jobcard__code{font-family:var(--p27-font-display);font-size:10.5px;letter-spacing:.22em;color:var(--p27-accent);font-weight:700;margin:0 0 6px}
.p27-jobcard__title{font-size:20px;font-weight:900;margin:0 0 4px;line-height:1.4}
.p27-jobcard__sub{font-size:13px;color:var(--p27-ink-soft);margin:0 0 16px}
.p27-jobcard__meta{display:flex;flex-direction:column;gap:6px;font-size:12.5px;color:var(--p27-ink-soft)}
.p27-jobcard__meta b{display:inline-block;width:50px;font-weight:700;color:var(--p27-ink);font-size:11px;letter-spacing:.06em;margin-right:8px}

/* JOB DETAIL */
.p27-job__hero{display:grid;grid-template-columns:1fr 380px;gap:48px;align-items:end;margin-bottom:64px}
.p27-job__hero__photo{aspect-ratio:5/4;overflow:hidden;border-radius:6px;background:var(--p27-line)}
.p27-job__hero__photo img{width:100%;height:100%;object-fit:cover}
.p27-job__hero__title{font-family:var(--p27-font-display);font-weight:800;font-size:clamp(40px,5vw,68px);letter-spacing:.04em;line-height:1;margin:0 0 14px}
.p27-job__hero__code{font-family:var(--p27-font-display);font-size:11px;letter-spacing:.24em;color:var(--p27-accent);font-weight:700;margin-bottom:8px}
.p27-job__hero__sub{font-size:15px;line-height:1.95;color:var(--p27-ink-soft);margin:0 0 24px}
.p27-job__hero__meta{display:grid;grid-template-columns:1fr 1fr;gap:16px 24px;border-top:1px solid var(--p27-line);padding-top:18px;margin:0}
.p27-job__hero__meta>div{display:flex;flex-direction:column;gap:4px}
.p27-job__hero__meta dt{font-size:10.5px;letter-spacing:.18em;color:var(--p27-mute);font-family:var(--p27-font-display);font-weight:700;margin:0}
.p27-job__hero__meta dd{font-size:14px;font-weight:700;margin:0}

.p27-job__sec{margin:0 0 56px;padding:0}
.p27-job__sec__bar{display:flex;align-items:center;gap:18px;margin-bottom:24px;padding-bottom:14px;border-bottom:1px solid var(--p27-line)}
.p27-job__sec__bar__tag{background:var(--p27-ink);color:#fff;padding:5px 12px;font-size:11px;letter-spacing:.06em;font-weight:700}
.p27-job__sec__bar__title{font-family:var(--p27-font-display);font-size:13px;letter-spacing:.24em;font-weight:800;color:var(--p27-accent)}
.p27-job__sec p{font-size:14.5px;line-height:2.05;color:var(--p27-ink-soft);margin:0}
.p27-job__sec ul{list-style:none;padding:0;margin:0;display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:14px}
.p27-job__sec li{background:#fff;padding:18px 20px;border-radius:4px;border-left:3px solid var(--p27-accent);font-size:14px;line-height:1.7}

/* A DAY schedule */
.p27-day{display:grid;gap:0;border-left:1px dashed var(--p27-line);padding-left:24px;margin-left:8px}
.p27-day__row{display:grid;grid-template-columns:120px 1fr;align-items:start;gap:18px;padding:18px 0;border-bottom:1px solid var(--p27-line);position:relative}
.p27-day__row::before{content:"";position:absolute;left:-30px;top:26px;width:11px;height:11px;border-radius:50%;background:var(--p27-accent);border:3px solid var(--p27-bg)}
.p27-day__time{font-family:var(--p27-font-display);font-weight:800;font-size:22px;color:var(--p27-ink);letter-spacing:.02em}
.p27-day__body h4{margin:0 0 4px;font-weight:900;font-size:15px}
.p27-day__body p{margin:0;font-size:13.5px;color:var(--p27-ink-soft);line-height:1.85}

/* REQUIREMENTS table */
.p27-reqtable{width:100%;border-collapse:collapse;margin:8px 0 64px;border-top:1px solid var(--p27-line)}
.p27-reqtable tr{border-bottom:1px solid var(--p27-line)}
.p27-reqtable th{background:transparent;color:var(--p27-ink);text-align:left;padding:20px 18px;font-weight:900;font-size:13.5px;width:200px;letter-spacing:.04em;vertical-align:top}
.p27-reqtable td{padding:20px 18px;font-size:14px;line-height:1.95;color:var(--p27-ink-soft);vertical-align:top}

/* HISTORY */
.p27-history{position:relative;padding:24px 0 80px}
.p27-history::before{content:"";position:absolute;left:120px;top:0;bottom:0;width:1px;background:var(--p27-line);background-image:linear-gradient(180deg,var(--p27-line) 50%,transparent 50%);background-size:1px 8px}
.p27-history__row{display:grid;grid-template-columns:120px 1fr;align-items:start;gap:36px;padding:22px 0;position:relative}
.p27-history__row::before{content:"";position:absolute;left:115px;top:32px;width:11px;height:11px;border-radius:50%;background:var(--p27-accent);border:3px solid var(--p27-bg)}
.p27-history__year{font-family:var(--p27-font-display);font-weight:800;font-size:24px;color:var(--p27-ink)}
.p27-history__event{font-size:14.5px;color:var(--p27-ink-soft);line-height:1.95;padding-left:24px}

/* FAQ */
.p27-faqlist{display:flex;flex-direction:column;gap:14px;margin:8px 0 80px}
.p27-faqitem{background:#fff;border:1px solid var(--p27-line);border-radius:6px;padding:0;overflow:hidden}
.p27-faqitem summary{cursor:pointer;list-style:none;padding:22px 56px 22px 56px;position:relative;font-weight:900;font-size:15px;line-height:1.6}
.p27-faqitem summary::-webkit-details-marker{display:none}
.p27-faqitem summary::before{content:"Q";position:absolute;left:20px;top:50%;transform:translateY(-50%);font-family:var(--p27-font-display);font-weight:800;color:var(--p27-accent);font-size:18px}
.p27-faqitem summary::after{content:"+";position:absolute;right:20px;top:50%;transform:translateY(-50%);font-size:22px;font-weight:300;color:var(--p27-mute);transition:transform .25s}
.p27-faqitem[open] summary::after{content:"−"}
.p27-faqitem>div{padding:0 56px 24px 56px;font-size:14px;line-height:1.95;color:var(--p27-ink-soft);position:relative}
.p27-faqitem>div::before{content:"A";position:absolute;left:20px;top:0;font-family:var(--p27-font-display);font-weight:800;color:var(--p27-ink);font-size:18px}

/* FORM */
.p27-form{display:grid;gap:22px;background:#fff;padding:42px;border-radius:6px;border:1px solid var(--p27-line);max-width:760px;margin:8px 0 80px}
.p27-form>div{display:grid;gap:8px}
.p27-form label{font-weight:700;font-size:13.5px;display:flex;align-items:center;gap:10px}
.p27-form label small{background:var(--p27-accent);color:#fff;padding:2px 8px;font-size:10px;font-weight:700;border-radius:2px;letter-spacing:.06em}
.p27-form input,.p27-form select,.p27-form textarea{font:inherit;padding:12px 14px;border:1px solid var(--p27-line);background:var(--p27-bg);border-radius:3px;width:100%;font-size:14px;color:var(--p27-ink)}
.p27-form input:focus,.p27-form select:focus,.p27-form textarea:focus{outline:2px solid var(--p27-accent);outline-offset:1px;border-color:var(--p27-accent)}
.p27-form button{background:var(--p27-ink);color:#fff;padding:16px 36px;font-family:var(--p27-font-display);font-weight:700;letter-spacing:.24em;font-size:12px;border:0;cursor:pointer;border-radius:2px;justify-self:start;margin-top:8px}
.p27-form button:hover{background:#333}
.p27-form__note{font-size:12px;color:var(--p27-mute);margin:8px 0 22px;line-height:1.85;max-width:760px}

/* VISION (about us 風 セクション) */
.p27-vision{max-width:880px;margin:0 auto 80px;text-align:center}
.p27-vision__label{font-family:var(--p27-font-display);font-weight:800;font-size:22px;letter-spacing:.32em;color:var(--p27-accent)}
.p27-vision__body{font-size:18px;font-weight:700;line-height:2.1;margin:14px 0 0}
.p27-vision__small{font-size:13.5px;color:var(--p27-ink-soft);line-height:2;margin:18px 0 0}

/* Stakeholder/カード列 */
.p27-stake{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:18px;max-width:920px;margin:0 auto 80px}
.p27-stake__c{aspect-ratio:1/1;border-radius:50%;display:flex;align-items:center;justify-content:center;text-align:center;font-weight:900;font-size:14px;color:#fff;padding:18px;line-height:1.5;letter-spacing:.04em}
.p27-stake__c:nth-child(1){background:#d35a3f}
.p27-stake__c:nth-child(2){background:#4a7a4f}
.p27-stake__c:nth-child(3){background:#74716c}
.p27-stake__c:nth-child(4){background:#3c6f7e}

/* REVEAL animation */
.p27-reveal{opacity:0;transform:translateY(20px);transition:opacity .9s cubic-bezier(.2,.7,.2,1) var(--p27-delay,0ms),transform .9s cubic-bezier(.2,.7,.2,1) var(--p27-delay,0ms)}
.p27-reveal.p27-in{opacity:1;transform:none}
.p27-hero.p27-loaded .p27-hero__illu{animation:p27-hero-in 1.2s cubic-bezier(.2,.7,.2,1) both}
@keyframes p27-hero-in{from{opacity:0;transform:translateY(20px)}to{opacity:1;transform:none}}

/* ===== RESPONSIVE ===== */
@media (max-width:880px){
  .p27-header{padding:10px 14px}
  .p27-hero__inner{grid-template-columns:1fr;padding:0 16px}
  .p27-hero__illu{height:300px}
  .p27-hero__lockup .p27-mark{font-size:30px}
  .p27-hero__menubadge{right:14px}
  .p27-section{padding:80px 16px}
  .p27-message,.p27-numbers{padding:64px 16px}
  .p27-entry-tiles{grid-template-columns:1fr}
  .p27-entry-tiles a{min-height:180px;padding:36px 24px}
  .p27-foot{padding:56px 14px 18px}
  .p27-foot__cols{grid-template-columns:1fr}
  .p27-page{padding:36px 14px 0}
  .p27-page__hero{grid-template-columns:1fr;gap:18px}
  .p27-page__hero__photo{width:100%;height:200px;border-radius:24px}
  .p27-page__stamp{display:none}
  .p27-job__hero{grid-template-columns:1fr}
  .p27-history::before,.p27-history__row::before{display:none}
  .p27-history__row{grid-template-columns:80px 1fr;gap:14px}
  .p27-history__event{padding-left:0}
  .p27-reqtable th{width:120px;padding:14px 10px;font-size:12.5px}
  .p27-reqtable td{padding:14px 10px}
  .p27-form{padding:24px 18px}
  .p27-day__row{grid-template-columns:80px 1fr;gap:12px}
  .p27-foot__top{right:14px;width:60px;height:60px;font-size:8px}
}
