/*
Theme Name: らしくワーク / はらぺこlabo
Theme URI: https://tootoogroup.com
Description: 就労継続支援B型「らしくワーク」とおそうざいや「はらぺこlabo」の公式 WordPress テーマ
Author: らしくワーク
Version: 2.0.0
Text Domain: rashiku-work
*/

/* ============================================
   CSS Variables（共通）
============================================ */
:root {
  /* index.html / front-page 系 */
  --color-primary:       #E8845A;
  --color-primary-dark:  #C96A3E;
  --color-primary-light: #F5B08A;
  --color-accent:        #7BAD7E;
  --color-accent-light:  #A8CCA9;
  --color-bg:            #FDFAF6;
  --color-bg-warm:       #FBF4EC;
  --color-bg-section:    #F7F0E8;
  --color-text:          #3D2B1F;
  --color-text-sub:      #7A6355;
  --color-text-light:    #A89080;
  --color-white:         #FFFFFF;
  --color-border:        #E8DDD5;
  --font-base:   'Noto Sans JP', 'Hiragino Kaku Gothic ProN', sans-serif;
  --font-serif:  'Noto Serif JP', 'Hiragino Mincho ProN', serif;
  --shadow-sm:   0 2px 8px rgba(61,43,31,.08);
  --shadow-md:   0 4px 20px rgba(61,43,31,.12);
  --shadow-lg:   0 8px 40px rgba(61,43,31,.15);
  --shadow-card: 0 2px 12px rgba(61,43,31,.1);
  --radius-sm:   4px;
  --radius-md:   8px;
  --radius-lg:   16px;
  --radius-xl:   24px;
  --radius-full: 9999px;
  --transition-base: 0.3s ease;
  --max-width:   1100px;
  --header-height: 70px;

  /* recruit / page 系（r-hero・omoi・dekiru など） */
  --primary:        #E8845A;
  --primary-dark:   #C96A3E;
  --primary-light:  #F5B08A;
  --accent:         #7BAD7E;
  --bg:             #FDFAF6;
  --bg-warm:        #FBF4EC;
  --bg-section:     #F7F0E8;
  --text:           #3D2B1F;
  --text-sub:       #7A6355;
  --text-light:     #A89080;
  --white:          #FFFFFF;
  --border:         #E8DDD5;
  --serif:  'Noto Serif JP', serif;
  --sans:   'Noto Sans JP', sans-serif;
  --r-sm:   6px;
  --r-md:   12px;
  --r-lg:   20px;
  --r-xl:   28px;
  --r-full: 9999px;
  --ease:   0.38s cubic-bezier(.4,0,.2,1);
  --max:    1040px;
  --hh:     var(--header-height);
}

/* ============================================
   Reset & Base
============================================ */
*,*::before,*::after { box-sizing:border-box; margin:0; padding:0; }
html { font-size:16px; scroll-behavior:smooth; -webkit-text-size-adjust:100%; }
body { font-family:var(--font-base); font-size:1rem; line-height:1.8; color:var(--color-text); background:var(--color-bg); -webkit-font-smoothing:antialiased; overflow-x:hidden; }
img { max-width:100%; height:auto; display:block; }
a { color:inherit; text-decoration:none; transition:var(--transition-base); }
ul,ol { list-style:none; }
button { cursor:pointer; border:none; background:none; font-family:inherit; }
h1,h2,h3,h4,h5,h6 { font-family:var(--font-serif); line-height:1.4; }

/* ============================================
   Layout
============================================ */
.container { max-width:var(--max-width); margin:0 auto; padding:0 1.5rem; }
.section { padding:5rem 0; }
.section-header { text-align:center; margin-bottom:3rem; }
.section-label { display:inline-block; font-size:.75rem; font-weight:700; letter-spacing:.15em; text-transform:uppercase; color:var(--color-primary); background:rgba(232,132,90,.1); padding:4px 14px; border-radius:var(--radius-full); margin-bottom:1rem; }
.section-title { font-size:clamp(1.5rem,3vw,2rem); font-weight:700; margin-bottom:1rem; line-height:1.4; }
.section-desc { font-size:1.0625rem; color:var(--color-text-sub); line-height:1.9; }
.grid { display:grid; gap:1.5rem; }
.grid-2 { grid-template-columns:repeat(2,1fr); }
.grid-3 { grid-template-columns:repeat(3,1fr); }
.grid-4 { grid-template-columns:repeat(4,1fr); }
.text-center { text-align:center; }
.mt-xl { margin-top:3rem; }

/* ============================================
   Buttons
============================================ */
.btn { display:inline-flex; align-items:center; justify-content:center; gap:8px; padding:14px 32px; border-radius:var(--radius-full); font-size:1rem; font-weight:700; letter-spacing:.05em; transition:var(--transition-base); cursor:pointer; border:2px solid transparent; white-space:nowrap; font-family:var(--font-base); }
.btn--primary { background:var(--color-primary); color:#fff; border-color:var(--color-primary); box-shadow:0 4px 14px rgba(232,132,90,.4); }
.btn--primary:hover { background:var(--color-primary-dark); border-color:var(--color-primary-dark); transform:translateY(-2px); }
.btn--outline { background:transparent; color:var(--color-primary); border-color:var(--color-primary); }
.btn--outline:hover { background:var(--color-primary); color:#fff; transform:translateY(-2px); }
.btn--outline-white { background:transparent; color:#fff; border-color:rgba(255,255,255,.5); }
.btn--outline-white:hover { background:rgba(255,255,255,.1); border-color:#fff; transform:translateY(-2px); }
.btn--white { background:#fff; color:var(--color-primary); border-color:#fff; box-shadow:var(--shadow-md); }
.btn--white:hover { background:var(--color-bg-warm); transform:translateY(-2px); }
.btn--accent { background:var(--color-accent); color:#fff; border-color:var(--color-accent); }
.btn--accent:hover { background:#5a8e5d; transform:translateY(-2px); }
.btn--lg { padding:18px 44px; font-size:1.0625rem; }
.btn--sm { padding:10px 22px; font-size:.875rem; }
.btn-group { display:flex; flex-wrap:wrap; gap:1rem; align-items:center; }
.btn-group-center { display:flex; flex-wrap:wrap; gap:1rem; justify-content:center; }

/* ============================================
   Header
============================================ */
.site-header { position:fixed; top:0; left:0; right:0; z-index:1000; height:var(--header-height); background:rgba(253,250,246,.95); backdrop-filter:blur(10px); -webkit-backdrop-filter:blur(10px); border-bottom:1px solid var(--color-border); transition:var(--transition-base); }
.site-header.scrolled { box-shadow:var(--shadow-md); }
.site-header__inner { display:flex; align-items:center; justify-content:space-between; height:100%; max-width:var(--max-width); margin:0 auto; padding:0 1.5rem; }
.site-logo { display:flex; flex-direction:column; line-height:1.2; }
.site-logo__main { font-family:var(--font-serif); font-size:1.125rem; font-weight:700; color:var(--color-text); }
.site-logo__sub { font-size:10px; color:var(--color-text-sub); letter-spacing:.05em; }
.site-nav .menu { display:flex; align-items:center; gap:2rem; }
.site-nav .menu-item a { font-size:.875rem; font-weight:500; color:var(--color-text); padding:4px 0; position:relative; }
.site-nav .menu-item a::after { content:''; position:absolute; bottom:-2px; left:0; right:0; height:2px; background:var(--color-primary); transform:scaleX(0); transition:var(--transition-base); }
.site-nav .menu-item a:hover::after { transform:scaleX(1); }
.site-nav .menu-item a:hover { color:var(--color-primary); }
.header-cta { display:flex; gap:.5rem; margin-left:2rem; }
.hamburger { display:none; flex-direction:column; gap:5px; padding:8px; cursor:pointer; }
.hamburger span { display:block; width:24px; height:2px; background:var(--color-text); border-radius:2px; transition:var(--transition-base); }
.hamburger.active span:nth-child(1) { transform:translateY(7px) rotate(45deg); }
.hamburger.active span:nth-child(2) { opacity:0; }
.hamburger.active span:nth-child(3) { transform:translateY(-7px) rotate(-45deg); }
.mobile-menu { display:none; position:fixed; top:var(--header-height); left:0; right:0; background:#fff; padding:1.5rem; border-bottom:1px solid var(--color-border); box-shadow:var(--shadow-lg); z-index:999; }
.mobile-menu.open { display:block; }
.mobile-menu .menu { display:flex; flex-direction:column; gap:1rem; margin-bottom:1.5rem; }
.mobile-menu .menu-item a { display:block; font-size:1.125rem; font-weight:500; padding:.5rem 0; border-bottom:1px solid var(--color-border); color:var(--color-text); }
.mobile-menu .btn-group { flex-direction:column; }
.mobile-menu .btn { width:100%; }

/* ============================================
   Page Nav（ページ内アンカー）
============================================ */
.page-nav { display:flex; gap:8px; padding:12px 0; overflow-x:auto; scrollbar-width:none; }
.page-nav::-webkit-scrollbar { display:none; }
.page-nav a { padding:8px 18px; background:#fff; border:1px solid var(--color-border); border-radius:var(--radius-full); font-size:.8125rem; font-weight:600; white-space:nowrap; color:var(--color-text-sub); transition:var(--transition-base); }
.page-nav a:hover,.page-nav a.active { background:var(--color-primary); color:#fff; border-color:var(--color-primary); }
.page-nav-wrap { position:sticky; top:var(--header-height); z-index:100; background:rgba(253,250,246,.95); backdrop-filter:blur(10px); border-bottom:1px solid var(--color-border); }

/* ============================================
   Hero（フロントページ）
============================================ */
.hero { position:relative; min-height:100vh; display:flex; align-items:center; overflow:hidden; padding-top:var(--header-height); }
.hero__bg { position:absolute; inset:0; background:linear-gradient(135deg,#2C1810 0%,#4A2E20 50%,#3D2010 100%); z-index:0; }
.hero__bg-image { position:absolute; inset:0; background-size:cover; background-position:center; opacity:.45; z-index:1; }
.hero__overlay { position:absolute; inset:0; background:linear-gradient(to right,rgba(44,24,16,.85) 0%,rgba(44,24,16,.5) 50%,rgba(44,24,16,.2) 100%); z-index:2; }
.hero__content { position:relative; z-index:3; max-width:var(--max-width); margin:0 auto; padding:6rem 1.5rem; width:100%; }
.hero__eyebrow { display:inline-flex; align-items:center; gap:8px; font-size:.75rem; font-weight:700; letter-spacing:.15em; color:var(--color-primary-light); background:rgba(232,132,90,.15); border:1px solid rgba(232,132,90,.3); padding:6px 16px; border-radius:var(--radius-full); margin-bottom:1.5rem; }
.hero__title { font-family:var(--font-serif); font-size:clamp(2.5rem,8vw,5rem); font-weight:900; color:#fff; line-height:1.2; margin-bottom:1.5rem; }
.hero__title span { color:var(--color-primary-light); display:block; }
.hero__subtitle { font-size:1.125rem; color:rgba(255,255,255,.85); line-height:2; margin-bottom:2.5rem; max-width:520px; }
.hero__note { display:inline-block; font-size:.75rem; color:rgba(255,255,255,.55); border:1px solid rgba(255,255,255,.2); padding:4px 14px; border-radius:var(--radius-full); margin-top:1rem; }
.hero__scroll { position:absolute; bottom:1.5rem; left:50%; transform:translateX(-50%); z-index:3; display:flex; flex-direction:column; align-items:center; gap:8px; color:rgba(255,255,255,.6); font-size:.75rem; letter-spacing:.1em; }
.hero__scroll-bar { width:1px; height:50px; background:linear-gradient(to bottom,rgba(255,255,255,.6),transparent); animation:scrollBar 1.5s ease-in-out infinite; }
@keyframes scrollBar { 0%{transform:scaleY(0);transform-origin:top} 50%{transform:scaleY(1);transform-origin:top} 51%{transform:scaleY(1);transform-origin:bottom} 100%{transform:scaleY(0);transform-origin:bottom} }

/* ============================================
   Empathy
============================================ */
.empathy { background:var(--color-bg-warm); }
.empathy__bubble { background:#fff; border-radius:var(--radius-xl); padding:2.5rem 4rem; max-width:680px; margin:0 auto 2.5rem; box-shadow:var(--shadow-card); position:relative; text-align:center; }
.empathy__bubble::after { content:''; position:absolute; bottom:-16px; left:50%; transform:translateX(-50%); border-left:16px solid transparent; border-right:16px solid transparent; border-top:16px solid #fff; }
.empathy__quote { font-family:var(--font-serif); font-size:1.5rem; font-weight:700; color:var(--color-text); line-height:1.6; }
.empathy__response { text-align:center; }
.empathy__response-text { font-size:1.0625rem; color:var(--color-text-sub); line-height:1.9; max-width:600px; margin:2.5rem auto 0; }
.empathy__response-text strong { color:var(--color-text); font-weight:700; }
/* 新テキスト用クラス */
.empathy__answer { text-align:center; font-size:1.0625rem; color:var(--color-text-sub); line-height:1.9; max-width:600px; margin:2.5rem auto 0; }
.empathy__answer strong { color:var(--color-text); font-weight:700; }
.empathy__quote .highlight { color:var(--color-primary); }

/* ============================================
   Product Value
============================================ */
.product-value__feature { display:flex; flex-direction:column; border-radius:var(--radius-xl); overflow:hidden; background:var(--color-bg-warm); transition:var(--transition-base); box-shadow:var(--shadow-card); }
.product-value__feature:hover { transform:translateY(-4px); box-shadow:var(--shadow-md); }
.product-value__feature:hover .product-value__feature-img { transform:scale(1.04); }
.product-value__feature-img-wrap { overflow:hidden; aspect-ratio:4/3; }
.product-value__feature-img { width:100%; height:100%; object-fit:cover; display:block; transition:transform .45s ease; }
.product-value__feature-body { padding:1.75rem 1.5rem; text-align:left; }
.product-value__feature-title { font-size:1.125rem; font-weight:700; margin-bottom:.6rem; line-height:1.5; }
.product-value__feature-text { font-size:.875rem; color:var(--color-text-sub); line-height:1.8; }

/* ============================================
   Chef Supervisor Banner
============================================ */
.chef-banner { margin-top:3rem; padding:2rem 2.5rem; background:linear-gradient(135deg,#3D2B1F 0%,#5A3E30 100%); border-radius:var(--radius-xl); display:flex; align-items:center; gap:2rem; }
.chef-banner__icon { flex-shrink:0; width:64px; height:64px; border-radius:50%; background:rgba(255,255,255,.12); display:flex; align-items:center; justify-content:center; color:var(--color-primary-light); font-size:1.75rem; }
.chef-banner__label { display:inline-block; font-size:.7rem; font-weight:700; letter-spacing:.12em; text-transform:uppercase; color:var(--color-primary-light); background:rgba(232,132,90,.2); padding:3px 10px; border-radius:var(--radius-full); margin-bottom:.5rem; }
.chef-banner__title { font-size:1.0625rem; font-weight:700; color:#fff; line-height:1.6; margin-bottom:.4rem; }
.chef-banner__text { font-size:.875rem; color:rgba(255,255,255,.7); line-height:1.8; }

/* ============================================
   Usage Style
============================================ */
.usage-style { background:var(--color-bg-section); }
.usage-card { background:#fff; border-radius:var(--radius-xl); overflow:hidden; box-shadow:var(--shadow-card); transition:var(--transition-base); }
.usage-card:hover { transform:translateY(-4px); box-shadow:var(--shadow-md); }
.usage-card:hover .usage-card__img { transform:scale(1.04); }
.usage-card__img-wrap { overflow:hidden; aspect-ratio:4/3; position:relative; }
.usage-card__img { width:100%; height:100%; object-fit:cover; display:block; transition:transform .45s ease; }
.usage-card__badge,.usage-card__label-badge { position:absolute; top:12px; left:12px; background:var(--color-primary); color:#fff; font-size:.7rem; font-weight:700; letter-spacing:.1em; padding:4px 12px; border-radius:var(--radius-full); }
.usage-card__body { padding:1.5rem; }
.usage-card__title { font-size:1.125rem; font-weight:700; margin-bottom:.5rem; line-height:1.5; }
.usage-card__text { font-size:.875rem; color:var(--color-text-sub); line-height:1.8; }

/* ============================================
   Bridge Section
============================================ */
.bridge-section { background:linear-gradient(135deg,#2C1810 0%,#4A2E20 100%); padding:6rem 0; text-align:center; position:relative; overflow:hidden; }
.bridge-section::before { content:''; position:absolute; top:-50px; right:-50px; width:300px; height:300px; border-radius:50%; background:rgba(232,132,90,.08); }
.bridge-section::after { content:''; position:absolute; bottom:-80px; left:-80px; width:400px; height:400px; border-radius:50%; background:rgba(232,132,90,.06); }
.bridge-section .container { position:relative; z-index:1; }
.bridge-section__eyebrow { font-size:.75rem; letter-spacing:.2em; color:var(--color-primary-light); font-weight:700; margin-bottom:1.5rem; display:block; }
.bridge-section__title { font-family:var(--font-serif); font-size:clamp(1.5rem,4vw,2.5rem); font-weight:900; color:#fff; line-height:1.5; margin-bottom:1.5rem; }
.bridge-section__body,.bridge-section__text { font-size:1.0625rem; color:rgba(255,255,255,.8); line-height:2; max-width:600px; margin:0 auto 2.5rem; }

/* ============================================
   Story
============================================ */
.story { background:var(--color-bg-warm); }
.story__grid { display:grid; grid-template-columns:1fr 1fr; gap:4rem; align-items:center; }
.story__image-wrap { position:relative; border-radius:var(--radius-xl); overflow:hidden; box-shadow:var(--shadow-lg); }
.story__badge { position:absolute; bottom:1.5rem; left:1.5rem; background:var(--color-primary); color:#fff; padding:.5rem 1rem; border-radius:var(--radius-lg); font-size:.875rem; font-weight:700; box-shadow:var(--shadow-md); }
.story__content { display:flex; flex-direction:column; gap:1.5rem; }
.story__point { display:flex; gap:1rem; align-items:flex-start; }
.story__point-icon { width:40px; height:40px; border-radius:50%; background:var(--color-primary); color:#fff; display:flex; align-items:center; justify-content:center; font-size:18px; flex-shrink:0; }
.story__point-title { font-size:1rem; font-weight:700; margin-bottom:4px; }
.story__point-text { font-size:.875rem; color:var(--color-text-sub); line-height:1.8; }

/* ============================================
   Recruit CTA
============================================ */
.recruit-cta { background:linear-gradient(135deg,var(--color-accent) 0%,#5a8e5d 100%); padding:5rem 0; text-align:center; position:relative; overflow:hidden; }
.recruit-cta .container { position:relative; z-index:1; }
.recruit-cta__eyebrow { font-size:.75rem; letter-spacing:.2em; color:rgba(255,255,255,.8); margin-bottom:1rem; display:block; }
.recruit-cta__title { font-family:var(--font-serif); font-size:clamp(1.5rem,4vw,2.5rem); font-weight:700; color:#fff; line-height:1.5; margin-bottom:1.5rem; }
.recruit-cta__text { font-size:1rem; color:rgba(255,255,255,.9); line-height:2; max-width:560px; margin:0 auto 2.5rem; }

/* ============================================
   About Group
============================================ */
.about-group__inner { display:grid; grid-template-columns:1fr 1fr; gap:5rem; align-items:center; }
.about-group__title { font-family:var(--font-serif); font-size:clamp(2rem,3.5vw,2.875rem); font-weight:900; line-height:1.4; margin-bottom:1.5rem; color:var(--color-text); }
.about-group__lead { font-size:1rem; line-height:2; color:var(--color-text); margin-bottom:1.25rem; font-weight:500; }
.about-group__text { font-size:.9375rem; line-height:2; color:var(--color-text-sub); margin-bottom:1.25rem; }
.about-group__text--em { color:var(--color-text); font-weight:500; padding-left:1rem; border-left:3px solid var(--color-primary); }
.about-group__btn { display:inline-flex; align-items:center; gap:.6rem; margin-top:1rem; background:var(--color-primary); color:#fff; font-size:.9375rem; font-weight:700; padding:.875rem 2rem; border-radius:var(--radius-full); transition:var(--transition-base); box-shadow:0 4px 16px rgba(232,132,90,.28); }
.about-group__btn:hover { background:var(--color-primary-dark); transform:translateY(-2px); box-shadow:0 8px 24px rgba(232,132,90,.36); }
.about-group__visual { display:flex; flex-direction:column; gap:1.5rem; }
.about-group__quote-block { background:linear-gradient(135deg,#2C1810 0%,#4A2E20 100%); border-radius:var(--radius-xl); padding:3rem 2.5rem; position:relative; overflow:hidden; }
.about-group__quote-block::before { content:'"'; position:absolute; top:-1.5rem; left:1.5rem; font-family:var(--font-serif); font-size:8rem; line-height:1; color:rgba(255,255,255,.06); pointer-events:none; }
.about-group__quote-main { font-family:var(--font-serif); font-size:clamp(1.75rem,3vw,2.5rem); font-weight:900; color:#fff; line-height:1.4; margin-bottom:.75rem; }
.about-group__quote-sub { font-size:.875rem; color:rgba(255,255,255,.55); letter-spacing:.06em; margin-bottom:2rem; }
.about-group__logo-mark { width:48px; height:48px; background:rgba(232,132,90,.2); border-radius:50%; display:flex; align-items:center; justify-content:center; color:var(--color-primary); font-size:1.25rem; }
.about-group__tag-row { display:flex; flex-wrap:wrap; gap:.75rem; }
.about-group__tag { display:inline-block; padding:.4rem 1rem; border-radius:var(--radius-full); font-size:.8125rem; font-weight:600; background:#fff; color:var(--color-text-sub); border:1px solid var(--color-border); }

/* ============================================
   Products
============================================ */
.product-card { background:#fff; border-radius:var(--radius-xl); overflow:hidden; box-shadow:var(--shadow-card); transition:var(--transition-base); }
.product-card:hover { transform:translateY(-6px); box-shadow:var(--shadow-lg); }
.product-card__image-wrap { position:relative; overflow:hidden; }
.product-card__img { width:100%; aspect-ratio:4/3; object-fit:cover; display:block; transition:transform .4s ease; }
.product-card:hover .product-card__img { transform:scale(1.04); }
.product-card__badge { position:absolute; top:.5rem; left:.5rem; background:var(--color-primary); color:#fff; font-size:.75rem; font-weight:700; padding:4px 10px; border-radius:var(--radius-full); }
.product-card__body { padding:1.25rem; }
.product-card__name { font-size:1rem; font-weight:700; margin-bottom:6px; }
.product-card__desc { font-size:.75rem; color:var(--color-text-sub); line-height:1.7; }
.product-card__price { font-size:1.0625rem; font-weight:700; color:var(--color-primary); margin-top:.5rem; }

/* ============================================
   Blog
============================================ */
.blog-preview { background:var(--color-bg-section); }
.blog-card { background:#fff; border-radius:var(--radius-lg); overflow:hidden; box-shadow:var(--shadow-card); transition:var(--transition-base); display:flex; flex-direction:column; }
.blog-card:hover { transform:translateY(-4px); box-shadow:var(--shadow-md); }
.blog-card__link { display:flex; flex-direction:column; flex:1; color:inherit; }
.blog-card__image { overflow:hidden; }
.blog-card__image img { width:100%; aspect-ratio:16/9; object-fit:cover; transition:transform .4s ease; }
.blog-card:hover .blog-card__image img { transform:scale(1.04); }
.blog-card__body { padding:1.25rem; flex:1; display:flex; flex-direction:column; }
.blog-card__meta { display:flex; align-items:center; gap:.5rem; margin-bottom:8px; }
.blog-card__cat { display:inline-block; font-size:.75rem; font-weight:700; color:var(--color-accent); background:rgba(123,173,126,.1); padding:2px 8px; border-radius:var(--radius-full); }
.blog-card__date { font-size:.75rem; color:var(--color-text-light); }
.blog-card__title { font-size:1rem; font-weight:700; line-height:1.5; margin-bottom:8px; }
.blog-card__title:hover { color:var(--color-primary); }
.blog-card__excerpt { font-size:.75rem; color:var(--color-text-sub); line-height:1.7; display:-webkit-box; -webkit-line-clamp:2; -webkit-box-orient:vertical; overflow:hidden; }

/* ============================================
   Store Info
============================================ */
.store-info__grid { display:grid; grid-template-columns:1fr 1fr; gap:4rem; align-items:start; }
.store-table { width:100%; border-collapse:collapse; }
.store-table tr { border-bottom:1px solid var(--color-border); }
.store-table tr:first-child { border-top:1px solid var(--color-border); }
.store-table th,.store-table td { padding:1rem 0; text-align:left; vertical-align:top; font-size:.875rem; line-height:1.7; }
.store-table th { width:100px; color:var(--color-text-sub); font-weight:600; }

/* ============================================
   Last CTA
============================================ */
.last-cta { background:linear-gradient(135deg,#2C1810 0%,#3D2010 100%); padding:7rem 0; text-align:center; position:relative; overflow:hidden; }
.last-cta .container { position:relative; z-index:1; }
.last-cta__eyebrow { font-size:.75rem; letter-spacing:.2em; color:var(--color-primary-light); margin-bottom:1rem; display:block; }
.last-cta__title { font-family:var(--font-serif); font-size:clamp(1.75rem,5vw,3rem); font-weight:900; color:#fff; line-height:1.4; margin-bottom:1.5rem; }
.last-cta__title .accent { color:var(--color-primary-light); }
.last-cta__text { font-size:1.0625rem; color:rgba(255,255,255,.8); line-height:2; max-width:560px; margin:0 auto 2.5rem; }

/* ============================================
   Footer
============================================ */
.site-footer { background:var(--color-text); color:rgba(255,255,255,.8); }
.site-footer__main { padding:5rem 0 4rem; }
.site-footer__grid { display:grid; grid-template-columns:2fr 1fr 1fr 1fr; gap:4rem; }
.footer-brand__logo { font-family:var(--font-serif); font-size:1.5rem; font-weight:700; color:#fff; margin-bottom:.5rem; }
.footer-brand__sub { font-size:.75rem; color:rgba(255,255,255,.5); margin-bottom:1.5rem; }
.footer-brand__text { font-size:.875rem; line-height:1.8; color:rgba(255,255,255,.65); margin-bottom:1.5rem; }
.footer-contact { display:flex; flex-direction:column; gap:.625rem; margin-top:1.25rem; }
.footer-contact__item { display:flex; align-items:center; gap:.5rem; font-size:.875rem; color:rgba(255,255,255,.65); }
.footer-contact__item a { color:rgba(255,255,255,.65); }
.footer-contact__item a:hover { color:var(--color-primary-light); }
.footer-contact__item i { color:var(--color-primary-light); width:16px; text-align:center; }
.footer-sns { display:flex; gap:1rem; margin-top:1.25rem; }
.footer-sns a { width:36px; height:36px; border-radius:50%; background:rgba(255,255,255,.1); display:flex; align-items:center; justify-content:center; color:rgba(255,255,255,.7); font-size:.875rem; transition:var(--transition-base); }
.footer-sns a:hover { background:var(--color-primary); color:#fff; }
.footer-nav__title { font-size:.875rem; font-weight:700; color:#fff; margin-bottom:1rem; padding-bottom:8px; border-bottom:1px solid rgba(255,255,255,.1); }
.footer-nav__list { display:flex; flex-direction:column; gap:8px; }
.footer-nav__list a { font-size:.875rem; color:rgba(255,255,255,.65); }
.footer-nav__list a:hover { color:var(--color-primary-light); }
.site-footer__bottom { border-top:1px solid rgba(255,255,255,.1); padding:1.5rem 0; }
.site-footer__bottom-inner { display:flex; align-items:center; justify-content:space-between; flex-wrap:wrap; gap:1rem; }
.site-footer__copy { font-size:.75rem; color:rgba(255,255,255,.4); }
.footer-policy { display:flex; gap:2rem; }
.footer-policy a { font-size:.75rem; color:rgba(255,255,255,.4); }
.footer-policy a:hover { color:rgba(255,255,255,.8); }

/* ============================================
   Animation（共通）
============================================ */
.fade-in { opacity:0; transform:translateY(30px); transition:opacity .7s ease,transform .7s ease; }
.fade-in.visible { opacity:1; transform:translateY(0); }
.delay-1 { transition-delay:.1s; }
.delay-2 { transition-delay:.2s; }
.delay-3 { transition-delay:.3s; }
.delay-4 { transition-delay:.4s; }
.delay-5 { transition-delay:.5s; }
/* recruit.html 用 fi クラス（.fi = .fade-in 相当） */
.fi { opacity:0; transform:translateY(30px); transition:opacity .75s ease,transform .75s ease; }
.fi.show { opacity:1; transform:none; }
.fi.d1 { transition-delay:.1s; }
.fi.d2 { transition-delay:.2s; }
.fi.d3 { transition-delay:.3s; }
.fi.d4 { transition-delay:.4s; }
.fi.d5 { transition-delay:.5s; }

/* ============================================
   Recruit Page — r-hero（スプリットヒーロー）
============================================ */
.r-hero { min-height:100svh; display:grid; grid-template-columns:1fr 1fr; padding-top:var(--header-height); }
.r-hero__left { display:flex; flex-direction:column; justify-content:center; padding:5rem 3rem; background:var(--bg); position:relative; }
.r-hero__left::after { content:''; position:absolute; right:-1px; top:10%; bottom:10%; width:1px; background:var(--border); }
.r-hero__right { position:relative; overflow:hidden; }
.r-hero__right img { width:100%; height:100%; object-fit:cover; transition:transform 6s ease; }
.r-hero__right-overlay { position:absolute; inset:0; background:linear-gradient(to right,var(--bg) 0%,transparent 18%); pointer-events:none; }
.r-hero__label { display:inline-block; font-size:.6875rem; font-weight:700; letter-spacing:.18em; text-transform:uppercase; color:var(--primary); background:rgba(232,132,90,.1); padding:4px 14px; border-radius:var(--r-full); margin-bottom:1.75rem; }
.r-hero__title { font-size:clamp(2.25rem,4.5vw,3.5rem); font-weight:900; line-height:1.35; margin-bottom:1.5rem; color:var(--text); }
.r-hero__title span { display:block; color:var(--primary); font-size:.72em; margin-top:.3rem; }
.r-hero__sub { font-size:1rem; color:var(--text-sub); line-height:2; margin-bottom:2.5rem; max-width:400px; }
.r-hero__cta { display:inline-flex; align-items:center; gap:.6rem; background:var(--primary); color:#fff; font-size:1rem; font-weight:700; padding:.9375rem 2.25rem; border-radius:var(--r-full); transition:var(--ease); align-self:flex-start; box-shadow:0 6px 20px rgba(232,132,90,.28); }
.r-hero__cta:hover { background:var(--primary-dark); transform:translateY(-2px); box-shadow:0 10px 28px rgba(232,132,90,.38); }
.r-hero__scroll { position:absolute; bottom:2.5rem; left:50%; transform:translateX(-50%); display:flex; flex-direction:column; align-items:center; gap:.5rem; color:var(--text-light); font-size:.6875rem; letter-spacing:.12em; }
.r-hero__scroll-bar { width:1px; height:36px; background:linear-gradient(to bottom,var(--text-light),transparent); }

/* ============================================
   Recruit Page — Intro / Quote
============================================ */
.sec { padding:7rem 0; }
.sec--warm { background:var(--bg-warm); }
.sec--white { background:var(--white); }
.sec--section { background:var(--bg-section); }
.sec--dark { background:linear-gradient(135deg,#2C1810 0%,#3E2518 100%); }
.sec-label { display:inline-block; font-size:.6875rem; font-weight:700; letter-spacing:.15em; text-transform:uppercase; color:var(--primary); background:rgba(232,132,90,.1); padding:3px 12px; border-radius:var(--r-full); margin-bottom:.875rem; }
.sec-title { font-size:clamp(1.625rem,3vw,2.25rem); font-weight:700; margin-bottom:1rem; line-height:1.45; }
.sec-desc { font-size:1.0625rem; color:var(--text-sub); line-height:1.9; }
.intro-wrap { display:grid; grid-template-columns:1fr 1fr; gap:4.5rem; align-items:center; }
.intro-body p { font-size:1.0625rem; line-height:2.1; color:var(--text); margin-bottom:1.5rem; }
.intro-body p:last-child { margin-bottom:0; }
.intro-body p strong { color:var(--primary); font-weight:700; }
.intro-img { border-radius:var(--r-xl); overflow:hidden; box-shadow:var(--shadow-lg); position:relative; }
.intro-img img { width:100%; height:400px; object-fit:cover; display:block; transition:transform .6s ease; }
.intro-img:hover img { transform:scale(1.03); }
.intro-quote { margin-top:4rem; padding:2.75rem 3.5rem; background:linear-gradient(135deg,rgba(232,132,90,.07),rgba(232,132,90,.02)); border-left:4px solid var(--primary); border-radius:0 var(--r-lg) var(--r-lg) 0; position:relative; }
.intro-quote::before { content:'"'; position:absolute; top:-1rem; left:2.5rem; font-family:var(--serif); font-size:6rem; line-height:1; color:rgba(232,132,90,.15); }
.intro-quote p { font-family:var(--serif); font-size:1.3125rem; font-weight:700; line-height:1.85; color:var(--text); position:relative; z-index:1; }
.intro-quote small { display:block; margin-top:1rem; font-size:.875rem; color:var(--text-sub); }

/* ============================================
   Recruit Page — Numbers カード
============================================ */
.nums-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:1.5rem; }
.num-card { display:flex; flex-direction:column; border-radius:var(--r-xl); overflow:hidden; background:var(--bg-warm); box-shadow:var(--shadow-sm); transition:transform var(--ease),box-shadow var(--ease); }
.num-card:hover { transform:translateY(-5px); box-shadow:var(--shadow-md); }
.num-card:hover .num-card__img { transform:scale(1.05); }
.num-card__img-wrap { overflow:hidden; aspect-ratio:4/3; position:relative; }
.num-card__img { width:100%; height:100%; object-fit:cover; display:block; transition:transform .5s ease; }
.num-card__img-overlay { position:absolute; inset:0; background:linear-gradient(to top,rgba(61,43,31,.32) 0%,transparent 50%); pointer-events:none; }
.num-card__body { padding:1.75rem 1.625rem; display:flex; flex-direction:column; flex:1; }
.num-card__index { display:block; font-size:.6875rem; font-weight:700; letter-spacing:.16em; text-transform:uppercase; color:var(--text-light); margin-bottom:.875rem; }
.num-card__row { display:flex; align-items:baseline; gap:.3rem; line-height:1; margin-bottom:1rem; }
.num-card__num { font-family:var(--serif); font-size:clamp(2.75rem,4.5vw,3.75rem); font-weight:900; color:var(--text); line-height:1; }
.num-card__unit { font-family:var(--serif); font-size:1.125rem; font-weight:700; color:var(--primary); }
.num-card__label { font-size:.9375rem; font-weight:700; color:var(--text); line-height:1.65; margin-bottom:.5rem; }
.num-card__note { font-size:.8125rem; color:var(--text-sub); line-height:1.7; margin-top:auto; padding-top:.75rem; border-top:1px solid var(--border); }

/* ============================================
   Recruit Page — 想い（omoi）
============================================ */
.omoi-item { display:grid; grid-template-columns:5fr 4fr; gap:0; border-radius:var(--r-xl); overflow:hidden; box-shadow:var(--shadow-md); margin-bottom:2.5rem; background:var(--white); }
.omoi-item:last-child { margin-bottom:0; }
.omoi-item--rev { grid-template-columns:4fr 5fr; }
.omoi-item--rev .omoi-item__img { order:2; }
.omoi-item--rev .omoi-item__body { order:1; }
.omoi-item__img { position:relative; overflow:hidden; min-height:360px; }
.omoi-item__img img { width:100%; height:100%; object-fit:cover; display:block; transition:transform .65s ease; }
.omoi-item:hover .omoi-item__img img { transform:scale(1.05); }
.omoi-item__body { padding:3.25rem 3rem; display:flex; flex-direction:column; justify-content:center; background:var(--white); }
.omoi-item__num { font-family:var(--serif); font-size:4rem; font-weight:900; color:rgba(232,132,90,.12); line-height:1; margin-bottom:.25rem; }
.omoi-item__label { font-size:.6875rem; font-weight:700; letter-spacing:.12em; text-transform:uppercase; color:var(--primary); margin-bottom:.625rem; }
.omoi-item__title { font-size:1.3125rem; font-weight:700; line-height:1.55; margin-bottom:1.125rem; color:var(--text); }
.omoi-item__text { font-size:.9375rem; color:var(--text-sub); line-height:2.1; }
.omoi-item__text em { display:block; font-style:normal; font-weight:700; color:var(--text); margin:.875rem 0 .25rem; font-size:1rem; line-height:1.65; }

/* ============================================
   Recruit Page — やってみたい
============================================ */
.yaritai-inner { display:grid; grid-template-columns:1fr 1fr; gap:3.5rem; align-items:start; }
.yaritai-tags { display:flex; flex-wrap:wrap; gap:.75rem; margin:1.75rem 0 0; }
.yaritai-tag { display:inline-flex; align-items:center; gap:.5rem; background:var(--white); border:1.5px solid var(--border); color:var(--text); font-size:.9375rem; font-weight:500; padding:.625rem 1.25rem; border-radius:var(--r-full); box-shadow:var(--shadow-sm); transition:var(--ease); }
.yaritai-tag:hover { border-color:var(--primary); color:var(--primary); transform:translateY(-2px); box-shadow:var(--shadow-md); }
.yaritai-tag i { color:var(--primary); }
.yaritai-right { position:relative; }
.yaritai-img { border-radius:var(--r-xl); overflow:hidden; box-shadow:var(--shadow-lg); margin-bottom:1.75rem; }
.yaritai-img img { width:100%; height:280px; object-fit:cover; transition:transform .6s ease; }
.yaritai-img:hover img { transform:scale(1.04); }
.yaritai-msg { background:linear-gradient(135deg,rgba(232,132,90,.08),rgba(232,132,90,.03)); border-radius:0 var(--r-xl) var(--r-xl) 0; padding:1.875rem 2rem; border-left:4px solid var(--primary); }
.yaritai-msg__main { font-size:1.125rem; font-weight:700; color:var(--text); margin-bottom:.625rem; line-height:1.65; }
.yaritai-msg__sub { font-size:.9375rem; color:var(--text-sub); line-height:1.9; }

/* ============================================
   Recruit Page — できること（dekiru）
============================================ */
.dekiru-grid { display:grid; grid-template-columns:repeat(2,1fr); gap:1.5rem; margin-top:3rem; }
.dekiru-card { background:var(--white); border-radius:var(--r-xl); overflow:hidden; box-shadow:var(--shadow-sm); transition:var(--ease); display:flex; flex-direction:column; }
.dekiru-card:hover { transform:translateY(-5px); box-shadow:var(--shadow-md); }
.dekiru-card__img { position:relative; overflow:hidden; height:200px; background:var(--bg-section); }
.dekiru-card__img img { width:100%; height:100%; object-fit:cover; transition:transform .6s ease; }
.dekiru-card:hover .dekiru-card__img img { transform:scale(1.06); }
.dekiru-card__img-overlay { position:absolute; inset:0; background:linear-gradient(to top,rgba(61,43,31,.45) 0%,transparent 55%); }
.dekiru-card__img-label { position:absolute; bottom:1rem; left:1.25rem; font-size:.6875rem; font-weight:700; letter-spacing:.12em; text-transform:uppercase; color:rgba(255,255,255,.9); }
.dekiru-card__body { padding:1.625rem 1.75rem 1.875rem; flex:1; display:flex; flex-direction:column; }
.dekiru-card__icon { width:40px; height:40px; background:rgba(232,132,90,.1); border-radius:var(--r-md); display:flex; align-items:center; justify-content:center; color:var(--primary); font-size:1rem; margin-bottom:.875rem; }
.dekiru-card__title { font-size:1.0625rem; font-weight:700; margin-bottom:.5rem; color:var(--text); }
.dekiru-card__text { font-size:.875rem; color:var(--text-sub); line-height:1.85; }

/* ============================================
   Recruit Page — CTA ダーク
============================================ */
.cta-inner { position:relative; z-index:1; text-align:center; padding:1rem; }
.cta-inner::before { content:''; position:absolute; top:-80px; right:-100px; width:340px; height:340px; border-radius:50%; background:rgba(232,132,90,.07); z-index:0; pointer-events:none; }
.cta-inner::after { content:''; position:absolute; bottom:-100px; left:-100px; width:440px; height:440px; border-radius:50%; background:rgba(232,132,90,.04); z-index:0; pointer-events:none; }
.cta-inner > * { position:relative; z-index:1; }
.cta-label { display:block; font-size:.6875rem; font-weight:700; letter-spacing:.2em; text-transform:uppercase; color:var(--primary-light); margin-bottom:1.25rem; }
.cta-title { font-size:clamp(1.75rem,3.5vw,2.5rem); font-weight:900; color:#fff; line-height:1.5; margin-bottom:1.25rem; }
.cta-text { font-size:1.0625rem; color:rgba(255,255,255,.75); line-height:2.1; margin-bottom:2.75rem; max-width:520px; margin-left:auto; margin-right:auto; }
.cta-btns { display:flex; flex-wrap:wrap; gap:1rem; justify-content:center; margin-bottom:1.5rem; }
.cta-note { font-size:.8125rem; color:rgba(255,255,255,.42); }

/* ============================================
   Skip Link / Accessibility
============================================ */
.skip-link { position:absolute; top:-40px; left:0; background:var(--color-primary); color:#fff; padding:8px 16px; z-index:9999; border-radius:0 0 4px 0; }
.skip-link:focus { top:0; }

/* ============================================
   画像フォールバック（0バイト・読込失敗時）
   img[src]が空・壊れている場合のプレースホルダー
============================================ */
.product-value__feature-img-wrap,
.usage-card__img-wrap,
.product-card__image-wrap,
.story__image-wrap,
.num-card__img-wrap,
.omoi-item__img,
.dekiru-card__img,
.yaritai-img,
.intro-img {
    background: linear-gradient(135deg, var(--color-bg-section) 0%, var(--color-bg-warm) 100%);
}
/* 壊れた img タグを非表示にして背景を見せる */
img[src=""], img:not([src]) {
    visibility: hidden;
}

/* ============================================
   Responsive
============================================ */
@media (max-width:900px) {
  .r-hero { grid-template-columns:1fr; min-height:auto; }
  .r-hero__right { height:55vw; min-height:260px; }
  .r-hero__left { padding:3.5rem 2rem 3rem; }
  .r-hero__left::after { display:none; }
  .r-hero__right-overlay { background:linear-gradient(to bottom,var(--bg) 0%,transparent 18%); }
  .intro-wrap { grid-template-columns:1fr; }
  .num-card__num { font-size:2.75rem; }
  .yaritai-inner { grid-template-columns:1fr; }
  .omoi-item { grid-template-columns:1fr; }
  .omoi-item--rev .omoi-item__img { order:0; }
  .omoi-item--rev .omoi-item__body { order:0; }
  .omoi-item__img { min-height:240px; }
  .omoi-item__body { padding:2.25rem 2rem; }
  .dekiru-grid { grid-template-columns:1fr; }
  .sec { padding:4.5rem 0; }
  .intro-quote { padding:1.875rem 1.75rem; }
}
@media (max-width:768px) {
  .site-nav,.header-cta { display:none; }
  .hamburger { display:flex; }
  .grid-2,.grid-3,.grid-4 { grid-template-columns:1fr; }
  .story__grid,.store-info__grid,.about-group__inner { grid-template-columns:1fr; }
  .site-footer__grid { grid-template-columns:1fr; gap:2rem; }
  .site-footer__bottom-inner { flex-direction:column; text-align:center; }
  .hero__content { text-align:center; }
  .hero__subtitle { max-width:100%; }
  .btn-group { justify-content:center; }
  .empathy__bubble { padding:2rem 1.5rem; }
  .empathy__quote { font-size:1.25rem; }
  .chef-banner { flex-direction:column; gap:1rem; text-align:center; padding:1.75rem 1.5rem; }
}
@media (max-width:600px) {
  .nums-grid { grid-template-columns:1fr; }
  .num-card__img-wrap { aspect-ratio:16/9; }
  .dekiru-card__img { height:160px; }
  .r-hero__title { font-size:1.875rem; }
  .yaritai-tags { gap:.5rem; }
  .yaritai-tag { font-size:.875rem; padding:.5rem 1rem; }
}
@media (max-width:480px) {
  .hero { min-height:85vh; }
  .hero__title { font-size:2rem; }
  .btn { padding:12px 24px; }
  .btn--lg { padding:14px 32px; font-size:1rem; }
  .container { padding:0 1rem; }
}
