/* =========================================================
   eyelash salon eyeliy｜アイリスト採用LP スタイルシート
   デザイン：eyeliy.com 踏襲（白＋クリーム／フラット／直線基調／
   中央見出し＋幅128px罫線／応募CTAはローズ #AE2D5B／ヘッダーはダークウッド）
   モバイルファースト／カスタムプロパティ
   ========================================================= */

/* ---------- デザイントークン（eyeliy.com 実測値） ---------- */
:root{
  --bg:#ffffff;            /* ベース白 */
  --cream:#fefaf1;         /* クリーム白（セクション差し色） */
  --cream2:#fdf5e4;        /* 濃いめクリーム（帯・枠） */
  --text:#2f201d;          /* 本文・見出し（こげ茶） */
  --sub:#7b7a78;           /* サブ・罫線グレー */
  --line:#e8e3da;          /* 細い境界線 */
  --cta:#ae2d5b;           /* 応募CTA（ローズ＝最重要導線） */
  --cta-h:#1b160f;         /* CTAホバー（茶黒） */
  --pink:#ffb0c3;          /* 差し色ピンク */
  --blue:#64bdeb;          /* 差し色ブルー */
  --jp:"Noto Sans JP",-apple-system,BlinkMacSystemFont,"Hiragino Kaku Gothic ProN",sans-serif;
  --en:"Outfit",var(--jp);
  --maxw:1120px;
}

*{box-sizing:border-box;}
html{scroll-behavior:smooth;}
body{
  margin:0;background:var(--bg);color:var(--text);
  font-family:var(--jp);font-weight:400;line-height:1.9;
  -webkit-font-smoothing:antialiased;font-size:15px;
}
img{max-width:100%;height:auto;display:block;}
a{color:inherit;}
ul{list-style:none;margin:0;padding:0;}
button{font-family:inherit;cursor:pointer;}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 20px;}

/* アイコン（currentColor 描画） */
.ic{width:1em;height:1em;flex:none;fill:none;stroke:currentColor;
    stroke-width:2;stroke-linecap:round;stroke-linejoin:round;vertical-align:-.15em;}

:focus-visible{outline:2px solid var(--cta);outline-offset:2px;}

/* ---------- ヘッダー（ダークウッド） ---------- */
.site-header{
  position:sticky;top:0;z-index:50;
  background:linear-gradient(180deg,#3b2b22,#2b1e17);backdrop-filter:saturate(160%) blur(8px);
  border-bottom:1px solid rgba(255,247,230,.12);
}
.header-inner{
  max-width:1180px;margin:0 auto;height:62px;
  display:flex;align-items:center;gap:16px;padding:0 20px;
}
.brand{display:flex;align-items:center;gap:9px;text-decoration:none;color:#fff7e6;}
.brand img{height:22px;width:auto;}
.brand .brand-tx{font-family:var(--en);font-weight:600;font-size:18px;letter-spacing:.06em;}
.header-nav{display:none;margin-left:auto;gap:22px;}
.header-nav a{font-size:13px;color:#f3ebdf;text-decoration:none;letter-spacing:.04em;transition:color .2s;}
.header-nav a:hover{color:var(--pink);}
.header-cta{
  display:none;font-size:13px;letter-spacing:.04em;
  padding:9px 20px;background:var(--cta);color:#fff;text-decoration:none;
  border-radius:2px;transition:background .2s;
}
.header-cta:hover{background:var(--cta-h);}
.menu-toggle{
  margin-left:auto;width:42px;height:42px;background:none;border:none;padding:0;
  display:flex;flex-direction:column;justify-content:center;align-items:center;gap:5px;
}
.menu-toggle span{display:block;width:22px;height:2px;background:#fff7e6;transition:transform .3s,opacity .3s;}
.menu-toggle[aria-expanded="true"] span:nth-child(1){transform:translateY(7px) rotate(45deg);}
.menu-toggle[aria-expanded="true"] span:nth-child(2){opacity:0;}
.menu-toggle[aria-expanded="true"] span:nth-child(3){transform:translateY(-7px) rotate(-45deg);}

/* モバイルメニュー（右サイドパネル） */
.nav-overlay{position:fixed;inset:0;z-index:60;background:rgba(31,22,15,.45);opacity:0;transition:opacity .3s;}
.nav-overlay.is-open{opacity:1;}
.mobile-nav{
  position:fixed;top:0;right:0;z-index:70;width:74%;max-width:320px;height:100%;
  background:var(--bg);box-shadow:-10px 0 40px rgba(0,0,0,.12);
  padding:78px 28px 28px;display:flex;flex-direction:column;gap:2px;
  transform:translateX(100%);transition:transform .32s cubic-bezier(.22,.61,.36,1);
}
.mobile-nav.is-open{transform:translateX(0);}
.mobile-nav a{font-size:15px;color:var(--text);text-decoration:none;padding:13px 4px;border-bottom:1px solid var(--line);}
.mobile-nav .mobile-cta{margin-top:18px;text-align:center;background:var(--cta);color:#fff;border-radius:2px;border-bottom:none;font-weight:500;}

/* ---------- ヒーロー ---------- */
.hero{background:var(--cream);}
.hero-grid{display:grid;grid-template-columns:1fr;}
.hero-media{aspect-ratio:4/3;overflow:hidden;background:var(--cream2);}
.hero-media img{width:100%;height:100%;object-fit:cover;}
.hero-body{padding:38px 22px 50px;}
.hero-en{font-family:var(--en);font-size:12px;letter-spacing:.3em;color:var(--cta);font-weight:600;margin:0 0 14px;}
.hero-title{font-size:30px;line-height:1.5;font-weight:700;letter-spacing:.02em;margin:0 0 14px;}
.hero-sub{font-size:15px;color:var(--text);margin:0 0 8px;}
.hero-meta{font-size:13px;color:var(--sub);margin:0 0 22px;letter-spacing:.03em;}
.badges{display:flex;flex-wrap:wrap;gap:8px;margin:0 0 26px;}
.badge{font-size:12px;padding:5px 13px;border-radius:999px;background:#fff;border:1px solid var(--line);color:var(--text);}
.badge--pink{background:var(--pink);border-color:var(--pink);color:#6b2438;}
.badge--blue{background:var(--blue);border-color:var(--blue);color:#0c4763;}
.hero-cta{display:flex;flex-direction:column;gap:11px;}
@media(min-width:560px){.hero-cta{flex-direction:row;}.hero-cta .btn{flex:1;}}
@media(min-width:880px){
  .hero-grid{grid-template-columns:1.05fr 1fr;align-items:stretch;}
  .hero-media{aspect-ratio:auto;min-height:560px;order:2;}
  .hero-body{order:1;display:flex;flex-direction:column;justify-content:center;padding:72px 60px;}
  .hero-title{font-size:40px;}
}

/* ---------- ボタン ---------- */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:9px;
  font-size:15px;font-weight:500;letter-spacing:.03em;text-decoration:none;
  padding:15px 26px;border:1px solid transparent;border-radius:2px;
  transition:background .2s,color .2s,transform .12s;
}
.btn:active{transform:translateY(1px);}
.btn--cta{background:var(--cta);color:#fff;}
.btn--cta:hover{background:var(--cta-h);}
.btn--outline{background:#fff;color:var(--text);border-color:var(--sub);}
.btn--outline:hover{background:var(--cream2);}
.btn--block{width:100%;}

/* ---------- セクション共通 ---------- */
.sec{padding:62px 0;border-bottom:1px solid var(--line);}
.sec--cream{background:var(--cream);}
.sec-head{text-align:center;margin:0 0 42px;}
.sec-head .en{display:block;font-family:var(--en);font-size:12px;font-weight:600;letter-spacing:.28em;color:var(--cta);text-transform:uppercase;margin-bottom:11px;}
.sec-head .jp{display:inline-block;font-size:23px;font-weight:700;letter-spacing:.05em;padding-bottom:18px;position:relative;}
.sec-head .jp::after{content:"";position:absolute;left:50%;bottom:0;transform:translateX(-50%);width:128px;height:1px;background:var(--sub);}
.sec-lead{text-align:center;color:var(--text);max-width:680px;margin:0 auto;font-size:15px;}
@media(min-width:880px){.sec{padding:88px 0;}.sec-head .jp{font-size:28px;}}

/* ---------- 魅力（FEATURES 01–05） ---------- */
.feat{display:flex;flex-direction:column;gap:30px;max-width:880px;margin:0 auto;}
.feat-item{display:grid;grid-template-columns:1fr;gap:14px;padding-bottom:30px;border-bottom:1px solid var(--line);}
.feat-item:last-child{border-bottom:none;padding-bottom:0;}
.feat-no{font-family:var(--en);font-size:13px;font-weight:600;letter-spacing:.2em;color:var(--cta);}
.feat-title{font-size:19px;font-weight:700;line-height:1.5;margin:2px 0 6px;letter-spacing:.02em;}
.feat-body{font-size:14.5px;color:var(--text);margin:0;line-height:1.95;}
.feat-img{aspect-ratio:4/3;overflow:hidden;background:var(--cream2);border-radius:2px;}
.feat-img img{width:100%;height:100%;object-fit:cover;}
@media(min-width:720px){
  .feat-item{grid-template-columns:1fr;}
  .feat-item.has-img{grid-template-columns:1.4fr 1fr;align-items:center;gap:36px;}
  .feat-item.has-img:nth-child(even) .feat-img{order:-1;}
}

/* ---------- 募集にあたって（メッセージ） ---------- */
.message{max-width:760px;margin:0 auto;}
.message p{font-size:15px;line-height:2.05;margin:0 0 16px;}
.message .accent{color:var(--cta);font-weight:700;}
.message-sign{text-align:right;color:var(--sub);font-size:13px;margin-top:8px;}

/* ---------- 募集要項（2区分カード） ---------- */
.jobs{display:grid;grid-template-columns:1fr;gap:18px;max-width:920px;margin:0 auto;}
@media(min-width:760px){.jobs{grid-template-columns:1fr 1fr;}}
.job{background:#fff;border:1px solid var(--line);border-radius:2px;padding:0;overflow:hidden;}
.job-head{background:var(--cream2);padding:16px 22px;display:flex;align-items:center;gap:10px;border-bottom:1px solid var(--line);}
.job-head .tag{font-family:var(--en);font-size:11px;font-weight:600;letter-spacing:.14em;background:var(--cta);color:#fff;padding:3px 9px;border-radius:2px;}
.job-head h3{font-size:17px;font-weight:700;margin:0;letter-spacing:.03em;}
.job-body{padding:6px 22px 20px;}
.spec{margin:0;}
.spec-row{display:grid;grid-template-columns:84px 1fr;gap:12px;padding:11px 0;border-bottom:1px solid var(--line);font-size:13.5px;}
.spec-row:last-child{border-bottom:none;}
.spec-row dt{color:var(--sub);font-weight:500;margin:0;}
.spec-row dd{margin:0;}
.job-note{max-width:920px;margin:18px auto 0;font-size:12.5px;color:var(--sub);line-height:1.8;text-align:center;}
.jobs-cta{display:flex;flex-direction:column;gap:11px;max-width:520px;margin:30px auto 0;}
@media(min-width:560px){.jobs-cta{flex-direction:row;}.jobs-cta .btn{flex:1;}}

/* ---------- ギャラリー ---------- */
.gallery{display:grid;grid-template-columns:1fr 1fr;gap:10px;}
@media(min-width:680px){.gallery{grid-template-columns:repeat(3,1fr);}}
.gallery li{aspect-ratio:1/1;overflow:hidden;border-radius:2px;background:var(--cream2);}
.gallery img{width:100%;height:100%;object-fit:cover;transition:transform .5s;}
.gallery li:hover img{transform:scale(1.05);}

/* ---------- メニュー・料金 ---------- */
.menu-table{max-width:780px;margin:0 auto;border-top:1px solid var(--sub);}
.menu-row{display:grid;grid-template-columns:1fr auto;gap:16px;padding:13px 4px;border-bottom:1px solid var(--line);align-items:baseline;}
.menu-row .name{font-size:14px;}
.menu-row .name .cat{display:block;font-size:11px;color:var(--cta);letter-spacing:.06em;margin-bottom:2px;}
.menu-row .price{font-size:13.5px;color:var(--text);white-space:nowrap;font-family:var(--en);font-weight:500;}
.menu-note{max-width:780px;margin:14px auto 0;font-size:12px;color:var(--sub);text-align:center;}

/* ---------- 店舗情報 ---------- */
.access-grid{display:grid;grid-template-columns:1fr;gap:28px;max-width:980px;margin:0 auto;}
@media(min-width:820px){.access-grid{grid-template-columns:1fr 1fr;align-items:start;}}
.access .spec-row{grid-template-columns:96px 1fr;}
.access a{color:var(--cta);text-decoration:none;}
.access a:hover{text-decoration:underline;}
.map-wrap{border:1px solid var(--line);border-radius:2px;overflow:hidden;aspect-ratio:4/3;background:var(--cream2);}
.map-wrap iframe{width:100%;height:100%;border:0;display:block;}

/* ---------- FAQ ---------- */
.faq{max-width:780px;margin:0 auto;border-top:1px solid var(--line);}
.faq-item{border-bottom:1px solid var(--line);}
.faq-q{width:100%;display:flex;align-items:center;justify-content:space-between;gap:14px;background:none;border:none;text-align:left;font-size:14.5px;font-weight:500;color:var(--text);padding:18px 2px;}
.faq-q .q{display:flex;gap:10px;}
.faq-q .q::before{content:"Q";font-family:var(--en);color:var(--cta);font-weight:600;}
.faq-chev{font-size:18px;color:var(--sub);flex:none;transition:transform .3s;}
.faq-q[aria-expanded="true"] .faq-chev{transform:rotate(180deg);}
.faq-a{overflow:hidden;max-height:0;transition:max-height .3s ease;}
.faq-a p{margin:0;font-size:13.5px;color:var(--text);line-height:1.95;padding:0 2px 18px 26px;}
.faq-item.is-open .faq-a{max-height:480px;}

/* ---------- フォーム ---------- */
.form{max-width:620px;margin:0 auto;}
.field{margin-bottom:17px;}
.field-row{display:flex;gap:12px;}
.field-row .field{flex:1;}
.field label,.field .lab{display:block;font-size:12.5px;color:var(--sub);font-weight:500;margin-bottom:7px;}
.req{display:inline-block;font-size:10px;color:#fff;background:var(--cta);padding:1px 7px;border-radius:999px;margin-left:5px;vertical-align:1px;}
.field input,.field select,.field textarea{
  width:100%;font-family:inherit;font-size:15px;color:var(--text);background:#fff;
  border:1px solid var(--sub);border-radius:2px;padding:12px 13px;transition:border-color .2s,box-shadow .2s;
}
.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--cta);box-shadow:0 0 0 3px rgba(174,45,91,.12);}
.field textarea{resize:vertical;min-height:110px;}
.field.has-error input,.field.has-error select,.field.has-error textarea,.field.has-error .seg{border-color:#d4503b;box-shadow:0 0 0 3px rgba(212,80,59,.12);}
.field-error{display:block;font-size:11.5px;color:#d4503b;margin-top:5px;}
.seg{display:flex;gap:10px;}
.seg-opt{flex:1;display:flex;align-items:center;justify-content:center;font-size:13.5px;padding:11px 8px;border:1px solid var(--sub);border-radius:2px;background:#fff;cursor:pointer;transition:.2s;}
.seg-opt input{position:absolute;opacity:0;width:0;height:0;}
.seg-opt:has(input:checked){background:var(--cta);color:#fff;border-color:var(--cta);}
.hp-field{position:absolute !important;left:-9999px;width:1px;height:1px;overflow:hidden;}
.form-privacy{font-size:11.5px;color:var(--sub);margin:0 0 14px;}
.form-privacy a{color:var(--cta);}
.form-status{margin:14px 0 0;font-size:13.5px;padding:13px 15px;border-radius:2px;line-height:1.7;}
.form-status.is-success{background:#eef7f0;color:#1f7a45;}
.form-status.is-error{background:#fbe9e7;color:#c0392b;}
.alt-cta{display:flex;justify-content:center;margin-top:22px;}
.alt-cta .btn{min-width:260px;}

/* ---------- フッター ---------- */
.site-footer{background:var(--cream);text-align:center;padding:46px 20px 52px;border-top:1px solid var(--line);}
.footer-logo{height:26px;width:auto;margin:0 auto 14px;}
.footer-name{font-size:14px;font-weight:700;margin:0 0 6px;letter-spacing:.04em;}
.footer-addr{font-size:12px;color:var(--sub);margin:0 0 4px;}
.footer-tel{font-size:12px;margin:0 0 18px;}
.footer-tel a{color:var(--sub);text-decoration:none;}
.footer-nav{display:flex;flex-wrap:wrap;justify-content:center;gap:8px 18px;margin-bottom:16px;}
.footer-nav a{font-size:12px;color:var(--cta);text-decoration:none;}
.footer-nav a:hover{text-decoration:underline;}
.footer-copy{font-size:11px;color:var(--sub);margin:0;font-family:var(--en);letter-spacing:.06em;}

/* ---------- reveal / br-sp ---------- */
.reveal{opacity:0;transform:translateY(18px);transition:opacity .6s ease,transform .6s ease;}
.reveal.is-visible{opacity:1;transform:none;}
.br-sp{display:inline;}
@media(min-width:760px){
  .menu-toggle{display:none;}.header-nav{display:flex;}.header-cta{display:inline-block;}
  .br-sp{display:none;}
}
@media(prefers-reduced-motion:reduce){
  html{scroll-behavior:auto;}
  *,*::before,*::after{animation-duration:.001ms !important;transition-duration:.001ms !important;}
  .reveal{opacity:1;transform:none;}
}

/* ---------- プライバシーポリシー本文 ---------- */
.policy{max-width:780px;margin:0 auto;}
.policy-intro{font-size:14px;color:var(--text);line-height:1.95;margin:0 0 30px;}
.policy-block{margin-bottom:30px;}
.policy-head{font-size:15px;font-weight:700;margin:0 0 12px;padding-bottom:7px;border-bottom:2px solid var(--cta);display:inline-block;}
.policy-block p{font-size:14px;color:var(--text);line-height:1.95;margin:0 0 12px;}
.policy-block p:last-child{margin-bottom:0;}
.policy-list{margin:0 0 12px;}
.policy-list li{font-size:14px;color:var(--text);line-height:1.9;padding-left:18px;position:relative;margin-bottom:6px;}
.policy-list li::before{content:"";position:absolute;left:2px;top:.85em;width:6px;height:6px;border-radius:50%;background:var(--cta);}
.policy-list li:last-child{margin-bottom:0;}
.policy-contact a{color:var(--cta);text-decoration:none;font-weight:500;}
.policy-contact a:hover{text-decoration:underline;}
.policy-meta{font-size:12.5px;color:var(--sub);line-height:1.8;margin:8px 0 0;text-align:right;}
.policy-back{display:flex;justify-content:center;margin-top:36px;}
