@charset "utf-8";
/* =====================
   AMARU.  TOP only CSS 
======================== */

:root{
  --hamburger-color:#2f2f2f;
  --kv-shadow:0 8px 24px rgba(0,0,0,.18);
  --card-shadow:0 6px 20px rgba(0,0,0,.05);
  --line-gold:#CFAC02;
  --card-bg:#FDFCF9;
  --card-bd:#E1DED6;
  --site-max:1440px;
  --big-radius:clamp(32px, 14vw, 140px);
}

.top-page{ 
  background:#FEF7EC; 
  color:#565353; 
}

.top-hero {
  position: relative;
  width: 100%;
  max-width: var(--site-max);
  margin-inline: auto;
  margin-top: clamp(20px, 4vw, 60px);  
  min-height: clamp(360px, 56vw, 560px);
  display: flex;
  align-items: center;
  justify-content: center;
  overflow: hidden;
  background: #d8d8d8;
  border-radius: 18px;
  box-shadow: 0 10px 30px rgba(0, 0, 0, .06);
}

/* 背景スライド */
.top-slider{ 
  position:absolute; 
  inset:0; 
}
.top-slide{
  position:absolute; inset:0;
  background:center/cover no-repeat;
  filter:saturate(96%) contrast(98%);
  opacity:0; transition:opacity 1.6s ease;
}
.top-slide.is-active{ 
  opacity:1; 
}


.top-hero .top-hero-btn{
  display:inline-flex; margin-top:10px; border-radius:10px; overflow:hidden;
  box-shadow:var(--kv-shadow);
}

/* ロゴ＋ナビ束 */
.top-page .top-hero-head{
  position:absolute; z-index:10;
  top:clamp(24px,6vw,56px); left:50%; transform:translateX(-50%);
  width:min(1080px,92%);
  display:flex; flex-direction:column; align-items:center; gap:clamp(14px,3vw,24px);
  pointer-events:none;
}
.top-page .top-hero-head > *{ 
  pointer-events:auto; 
}

/* ロゴを大きめに */
.top-page .top-hero-head .brand img{
  height:clamp(80px,14vw,140px); width:auto;
  filter:drop-shadow(0 8px 20px rgba(0,0,0,.35));
  transition:transform .4s ease, filter .4s ease;
}
@media(hover:hover){
  .top-page .top-hero-head .brand:hover img{
    transform:scale(1.05); filter:drop-shadow(0 12px 26px rgba(0,0,0,.45));
  }
}

/* PC：水平ナビ、SP：ハンバーガー */
@media(min-width:768px){
  .top-page .top-hero-head .nav-pc{ display:flex; }
  .top-page .top-hero-head .nav-btn{ display:none; }
}
@media(max-width:767.98px){
  .top-page .top-hero-head .nav-pc{ display:none; }
}

/* PCナビ：長い下線アニメ */
.top-page .top-hero-head .nav-pc .nav-link{
  position:relative; 
  padding-bottom:10px; 
  color: rgba(0, 0, 0, 0.75); 
  text-shadow:0 1px 2px rgba(0,0,0,.35);
}
.nav-link:hover {
  color: #CFAC02;
}
.top-page .top-hero-head .nav-pc .nav-link::after{
  content:""; 
  position:absolute; 
  left:6px; 
  right:6px; 
  bottom:3px; 
  height:2px;
  background:rgba(255,255,255,.95); 
  transform:scaleX(0); 
  transform-origin:center;
  transition:transform .35s ease-in-out;
  pointer-events:none;
}
.top-page .top-hero-head .nav-pc .nav-link:hover::after,
.top-page .top-hero-head .nav-pc .nav-link:focus-visible::after,
.top-page .top-hero-head .nav-pc .nav-link.is-current::after{ transform:scaleX(1); }

@media(max-width:767.98px){
  .top-page .top-hero-head .nav-btn{
    position:absolute; top:clamp(10px,3vw,16px); left:clamp(12px,4vw,20px);
    width:40px; height:40px; display:inline-flex; align-items:center; justify-content:center;
    background:transparent; border:0; z-index:11;
  }
  .top-page .top-hero-head .nav-btn::before,
  .top-page .top-hero-head .nav-btn::after{ 
    content:none !important; 
  }

  .top-page .top-hero-head .nav-btn > span{
    position:relative; 
    display:block; width:26px; 
    height:2px;
    background:var(--hamburger-color); 
    border-radius:1px;
  }
  .top-page .top-hero-head .nav-btn > span::before,
  .top-page .top-hero-head .nav-btn > span::after{
    content:""; 
    position:absolute; 
    left:0; 
    width:100%; 
    height:2px;
    background:var(--hamburger-color); 
    border-radius:1px;
  }
  .top-page .top-hero-head .nav-btn > span::before{ top:-8px; }
  .top-page .top-hero-head .nav-btn > span::after { top: 8px; }

  /* open時は×に（nav.jsの body.open を利用） */
  body.open .top-page .top-hero-head .nav-btn > span{ opacity:0; }
  body.open .top-page .top-hero-head .nav-btn > span::before{ transform:translateY(8px) rotate(45deg); }
  body.open .top-page .top-hero-head .nav-btn > span::after { transform:translateY(-8px) rotate(-45deg); }
}

.top-pickups{
  width:min(1024px,92%);
  margin:clamp(28px,6vw,64px) auto;
  display:flex; flex-direction:column; gap:clamp(28px,5vw,48px);
}
.top-pick{
  display:flex; align-items:center; justify-content:space-between;
  gap:clamp(24px,3vw,36px);
  padding:clamp(16px,3vw,22px);
  background:var(--card-bg); border:1px solid var(--card-bd);
  border-radius:14px; box-shadow:var(--card-shadow); overflow:hidden;
}
.top-pick.reverse{ flex-direction:row-reverse; }

/* 4枚とも同じ幅（指定どおり） */
.top-pick-fig{ 
  flex:0 0 clamp(300px,44vw,360px); 
  max-width:45%; display:flex; 
  align-items:center; 
  justify-content:center; 
}
.top-pick-fig img{ 
  width:100%; 
  height:auto; 
  display:block; 
  object-fit:cover; 
  border-radius:16px; 
}

.top-shape-tl img{ 
  border-radius:var(--big-radius) 16px 16px 16px; 
}
.top-shape-br img{ 
  border-radius:16px 16px var(--big-radius) 16px; 
}

/* テキスト */
.top-pick-body{ 
  flex:1 1 auto; 
  min-width:0; 
  display:flex; 
  flex-direction:column; 
  gap:.4em; 
  line-height:1.8; 
  color:#565353; 
}
.top-pick-title{ 
  font-family:"Playfair Display","Noto Serif JP",serif; font-size:clamp(18px,4.5vw,22px); 
  letter-spacing:.18em; color:#333; 
}
.top-pick-link{
  display:inline-block; 
  width:fit-content; 
  padding:8px 18px;
  border:1px solid var(--line-gold); 
  border-radius:999px; 
  font-size:.95em; 
  letter-spacing:.06em;
  background:#fff; 
  transition:background .3s ease, color .3s ease, box-shadow .3s ease;
}
.top-pick-link:hover{ 
  background:var(--line-gold); 
  color:#fff; 
  box-shadow:0 6px 18px rgba(207,172,2,.28); 
}

/* SPは縦積み */
@media(max-width:768px){
  .top-pick, .top-pick.reverse{ flex-direction:column; }
  .top-pick-fig{ max-width:100%; flex:none; }
  .top-pick{ gap:18px; }
}

/* フェードアップ（IntersectionObserver で .is-in を付与） */
.fx-fadeup{ 
  transform:translateY(24px); 
  opacity:0; transition:transform .8s ease, opacity .8s ease; 
  will-change:transform,opacity; 
}
.fx-fadeup.is-in{ 
  transform:translateY(0); 
  opacity:1; 
}

.recruit-cta{
  position:relative; width:min(1080px,94%);
  margin:clamp(28px,7vw,80px) auto;
  border-radius:16px; 
  overflow:hidden; 
  box-shadow:0 10px 30px rgba(0,0,0,.08);
}
.recruit-cta a{ 
  display:flex; 
  align-items:stretch; 
  justify-content:center; 
  text-decoration:none; 
}
.recruit-cta figure{ 
  flex:1 1 auto; 
  display:block; 
}
.recruit-cta img{ 
  width:100%; 
  height:auto; 
  display:block; 
}
.recruit-text{
  position:absolute; 
  inset:0; 
  display:flex; 
  flex-direction:column;
  align-items:center; justify-content:center; 
  gap:.6em; 
  text-align:center;
  padding:clamp(14px,4vw,28px); 
  color:#fff;
  background:linear-gradient(to bottom, rgba(0,0,0,.15), rgba(0,0,0,.35));
}
.recruit-text p:first-child{ 
  font-size:clamp(18px,4.8vw,24px); 
  letter-spacing:.12em; 
  text-shadow:0 10px 24px rgba(0,0,0,.35); 
}
.recruit-text p:last-child{ 
  max-width:900px; 
  line-height:1.9; 
  text-shadow:0 8px 20px rgba(0,0,0,.4); 
}


.floating-cta{
  position:fixed; 
  right:clamp(12px,3vw,24px); 
  top:clamp(12px,3vw,24px);
  z-index:999; 
  opacity:0; 
  transform:translate(16px,-16px) scale(.98);
  transition:transform .35s ease, opacity .35s ease; 
  pointer-events:none;
}
.floating-cta.is-show{ 
  opacity:1; 
  transform:translate(0,0) scale(1); 
  pointer-events:auto; 
}
.floating-cta figure{ 
  width:clamp(120px,26vw,180px); 
  border-radius:12px; 
  overflow:hidden; 
  box-shadow:0 10px 26px rgba(0,0,0,.18); 
}
.floating-cta.is-dim{ 
  opacity:.35; 
}


/* 末尾スペース（フッター前の余白） */
.top-tail-space{ 
  height:clamp(16px,3vw,24px); 
}


/* 全体の行間 */
.top-page .footer-inner {
  gap: clamp(16px, 4vw, 28px);
}

/*  ロゴ  */
.top-page .footer-logo img {
  width: clamp(100px, 18vw, 140px);
  height: auto;
  display: block;
  margin: 0 auto;
}

/*  地図 */
.top-page .footer-map figure{
  width: min(960px, 96%);            
  margin: clamp(12px, 3vw, 22px) auto 0;
  border-radius: 12px;
  overflow: hidden;
  background: #f2f2f2;
  box-shadow: 0 10px 30px rgba(0,0,0,.12);
  border: 1px solid rgba(0,0,0,.08);
}
.top-page .footer-map iframe{
  display: block;
  width: 100%;
  height: clamp(300px, 45vw, 420px); /* ← 高さもしっかり確保 */
  border: 0;
}


/*  CONTACTセクション  */
.top-page .footer-heading {
  font-size: clamp(14px, 2.6vw, 16px);
  letter-spacing: .28em;
  color: #3c3c3c;
  margin: .8em 0 .6em;
  text-align: center;
}
.top-page .footer-address p {
  margin: .2em 0;
  text-align: center;
}
.top-page .footer-tel {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 12px;
  margin-top: .4em;
  letter-spacing: .12em;
}
.top-page .footer-tel-label {
  font-size: clamp(14px, 2.8vw, 16px);
}
.top-page .footer-tel-link {
  font-size: clamp(20px, 6vw, 26px);
  color: #111;
  text-decoration: none;
}

/*  予約バナー  */
.top-page .footer-actions {
  display: flex;
  justify-content: center;
}
.top-page .footer-hpb img {
  width: clamp(180px, 40vw, 240px);
  height: auto;
  display: block;
}


/* --- コピーライト --- */
.top-page .footer-copy {
  color: #3f3f3f;
  letter-spacing: .12em;
  text-align: center;
}
.top-slide.gray {
  background-color: rgba(255, 255, 255, 0.45); 
  backdrop-filter: blur(6px);                  
  background-image: none !important;
}




/* ▼ ヒーロー中央コピーを下げて、白ベールを消す */
.top-hero-copy {
  position: relative;
  z-index: 20;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 1em;
  background: none;         /*  白ベール削除 */
  backdrop-filter: none;    /*  ぼかし削除 */
  border-radius: 0;
  margin-top: clamp(60px, 12vh, 150px); /*  ナビとの余白 */
  text-align: center;
}
/*  コピーライト */
.footer-copy {
  font-size: 0.7rem;         /* 小さめ・上品に */
  color: rgba(0, 0, 0, 0.5); /* 薄めのグレーで主張を抑える */
  text-align: center;
  margin-top: 40px;
  letter-spacing: 0.05em;    /* 少しだけ文字間を空ける */
  line-height: 1.6;
}
