/* ============================================================
   PEPPER CYCLE LP - PC (1440px)
   ============================================================ */
:root{
  --primary:#4ECDC4;
  --primary-dark:#3DB8A8;
  --accent:#F0A030;
  --accent-light:#FFF3E0;
  --bg-hero:#F0FAF6;
  --bg-light:#F8F8F8;
  --border:#E5E5E5;
  --green-light:#E8F8F5;
  --text-dark:#333333;
  --text-gray:#666666;
  --text-light:#999999;
  --white:#FFFFFF;
}
*{margin:0;padding:0;box-sizing:border-box;}
html{ -webkit-text-size-adjust:100%; scroll-behavior:smooth; }
section[id]{ scroll-margin-top:88px; }
body{
  font-family:'Inter','Noto Sans JP',sans-serif;
  color:var(--text-dark);
  background:#fff;
  line-height:1.5;
  -webkit-font-smoothing:antialiased;
}
img{display:block;max-width:100%;-webkit-user-drag:none;user-drag:none;-webkit-user-select:none;user-select:none;}
a{text-decoration:none;color:inherit;}
.lp{width:100%;margin:0 auto;background:#fff;overflow:hidden;}
.lucide,[data-lucide]{stroke-width:2;}

/* ============ 01 HEADER ============ */
.header{
  display:flex;align-items:center;justify-content:space-between;
  padding:10px 40px;background:transparent;
  position:fixed;top:0;left:0;right:0;z-index:1000;
  transition:background .25s ease,box-shadow .25s ease;
}
.header.scrolled{
  background:rgba(255,255,255,.95);
  box-shadow:0 2px 14px rgba(0,0,0,.08);
  -webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);
}
.logo-area{display:flex;align-items:center;gap:8px;}
.logo-icon{width:36px;height:36px;}
.logo-icon img{width:36px;height:36px;object-fit:contain;}
.logo-row{display:flex;align-items:flex-end;}
.logo-pepper{font-size:20px;font-weight:800;color:#2A2622;letter-spacing:.3px;}
.logo-cycle{font-size:20px;font-weight:700;color:#3DB8A8;letter-spacing:.3px;margin-left:8px;}
.nav-area{display:flex;align-items:center;gap:24px;}
.nav-area a{font-size:13px;color:var(--text-dark);}
.cta-area{display:flex;align-items:center;gap:12px;}
.header-cta{
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  background:var(--primary);border-radius:6px;padding:10px 24px;
}
.header-cta-main{font-size:16px;font-weight:700;color:#fff;}
.header-cta-sub{font-size:10px;color:#fff;opacity:.8;}

/* ============ 02 HERO ============ */
.hero{
  display:flex;
  background-image:url('../assets/images/hero-background.webp');
  background-size:cover;background-position:center;
  overflow:hidden;
  padding-top:56px;
}
.hero-left{
  flex:1;display:flex;flex-direction:column;align-items:center;gap:28px;
  padding:40px 40px 40px 60px;
}
.hero-heading{
  font-size:40px;font-weight:800;line-height:1.4;
  background:linear-gradient(180deg,#2ABFBF,#4A90D9);
  -webkit-background-clip:text;background-clip:text;
  -webkit-text-fill-color:transparent;color:transparent;
}
.hero-sub{font-size:18px;font-weight:400;color:#555;line-height:1.6;}
.badge-row{display:flex;gap:16px;}
.hero-badge{
  width:99px;height:99px;background:#fff;border-radius:12px;
  display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px;
  padding:8px 12px 6px;
}
.hero-badge-img{
  width:56px;height:56px;border-radius:12px;
  background-size:cover;background-position:center;
}
.hero-badge span{font-size:10px;font-weight:700;color:var(--text-dark);}
.hero-mockup{position:relative;width:640px;height:350px;}
.mockup-laptop{
  position:absolute;left:60px;top:0;width:580px;height:340px;
  border-radius:8px;background-size:cover;background-position:center;
}
.mockup-green-badge{
  position:absolute;left:0;top:220px;width:120px;height:120px;border-radius:60px;
  background:var(--primary-dark);
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  box-shadow:0 4px 12px rgba(0,0,0,.19);
}
.mgb-top{font-size:14px;font-weight:600;color:#fff;}
.mgb-num{font-size:32px;font-weight:800;color:#fff;line-height:1.1;}
.mockup-phone{
  position:absolute;left:480px;top:60px;width:140px;height:260px;
  border-radius:16px;background:#333;border:3px solid #222;
}
.mockup-phone-screen{
  position:absolute;left:5px;top:10px;width:130px;height:240px;
  border-radius:12px;background-size:cover;background-position:center;
}
.hero-stats{display:flex;gap:40px;}
.stat{display:flex;align-items:center;gap:8px;}
.stat-label{font-size:15px;font-weight:500;color:var(--text-gray);}
.stat-icon{width:16px;height:16px;color:var(--accent);}
.stat-val{font-size:28px;font-weight:800;color:var(--accent);}
.hero-disclaimer{font-size:10px;color:var(--text-light);}

.hero-right{width:440px;display:flex;flex-direction:column;padding:20px 30px 20px 10px;}
.form-banner{
  background:var(--accent);border-radius:20px 20px 0 0;padding:12px 24px;
  text-align:center;font-size:17px;font-weight:700;color:#fff;
}
.form-card{
  background:#fff;border-radius:0 0 12px 12px;padding:24px;
  display:flex;flex-direction:column;gap:14px;
  box-shadow:0 4px 16px rgba(0,0,0,.094);
}
.field{display:flex;flex-direction:column;gap:6px;}
.field label{font-size:15px;font-weight:700;color:var(--text-dark);}
.input{
  height:44px;border:1px solid var(--border);border-radius:6px;background:#fff;
  display:flex;align-items:center;padding:0 12px;
}
.input .ph{font-size:16px;color:var(--text-light);}
.input-select{justify-content:space-between;}
.input-select i{width:18px;height:18px;color:var(--text-light);}
/* real form controls (hero form) */
input.input,select.input{display:block;width:100%;font-family:inherit;font-size:16px;color:var(--text-dark);appearance:none;-webkit-appearance:none;outline:none;}
input.input::placeholder{color:var(--text-light);}
select.input{cursor:pointer;padding-right:36px;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='24' height='24' viewBox='0 0 24 24' fill='none' stroke='%23999999' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='m6 9 6 6 6-6'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center;background-size:18px;}
select.input:invalid{color:var(--text-light);}
input.input:focus,select.input:focus{border-color:var(--primary);box-shadow:0 0 0 3px rgba(78,205,196,.15);}
.check-row{display:flex;align-items:center;gap:8px;cursor:pointer;}
.checkbox{width:18px;height:18px;border:1.5px solid var(--border);border-radius:3px;background:#fff;flex:none;}
input.checkbox{appearance:none;-webkit-appearance:none;margin:0;position:relative;cursor:pointer;}
input.checkbox:checked{background:var(--primary);border-color:var(--primary);}
input.checkbox:checked::after{content:"";position:absolute;left:5px;top:1px;width:5px;height:10px;border:solid #fff;border-width:0 2px 2px 0;transform:rotate(45deg);}
input.checkbox:focus-visible{box-shadow:0 0 0 3px rgba(78,205,196,.25);}
/* textarea / 必須バッジ / ハニーポット / 送信ステータス */
textarea.input{display:block;width:100%;height:auto;min-height:104px;padding:12px;font-family:inherit;font-size:16px;color:var(--text-dark);line-height:1.7;resize:vertical;appearance:none;outline:none;}
textarea.input::placeholder{color:var(--text-light);}
textarea.input:focus{border-color:var(--primary);box-shadow:0 0 0 3px rgba(78,205,196,.15);}
.req{display:inline-block;font-size:10px;font-weight:700;color:#fff;background:var(--accent);border-radius:3px;padding:1px 6px;margin-left:4px;vertical-align:middle;letter-spacing:.5px;}
.hp-field{position:absolute!important;left:-9999px;top:auto;width:1px;height:1px;overflow:hidden;opacity:0;pointer-events:none;}
.form-status{font-size:15px;line-height:1.6;min-height:1.2em;margin:2px 0;text-align:center;}
.form-status.is-error{color:#D64545;}
.form-status.is-success{color:var(--primary-dark);}
.cf-turnstile{display:flex;justify-content:center;margin:4px 0;min-height:65px;}
/* プライバシーポリシー モーダル */
.privacy-modal{position:fixed;inset:0;z-index:1000;display:none;align-items:center;justify-content:center;padding:20px;background:rgba(0,0,0,.5);}
.privacy-modal.active{display:flex;}
.privacy-modal-box{background:#fff;border-radius:16px;max-width:680px;width:100%;max-height:85vh;display:flex;flex-direction:column;overflow:hidden;box-shadow:0 20px 60px rgba(0,0,0,.3);}
.privacy-modal-head{display:flex;align-items:center;justify-content:space-between;padding:18px 28px;border-bottom:1px solid var(--border);}
.privacy-modal-head h2{font-size:20px;font-weight:800;color:var(--text-dark);}
.privacy-modal-close{background:none;border:none;cursor:pointer;width:36px;height:36px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:24px;line-height:1;color:var(--text-gray);}
.privacy-modal-close:hover{background:var(--bg-light);color:var(--text-dark);}
.privacy-modal-body{padding:24px 28px;overflow-y:auto;font-size:15px;color:var(--text-gray);line-height:1.9;}
.privacy-modal-body h3{font-size:16px;font-weight:700;color:var(--text-dark);margin:18px 0 6px;}
.privacy-modal-body p{margin-bottom:10px;}
.privacy-modal-body ul{margin:0 0 10px;padding-left:1.3em;}
.privacy-modal-body li{margin-bottom:4px;list-style:disc;}
.privacy-modal-body .privacy-rev{margin-top:16px;font-size:14px;color:var(--text-light);}
body.modal-open{overflow:hidden;}
.check-label{font-size:15px;color:var(--text-dark);}
.privacy-text{font-size:11px;color:var(--text-light);}
.submit-btn{
  background:var(--primary);border:none;border-radius:8px;padding:16px;cursor:pointer;
  display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px;
}
.sb-small{font-size:11px;color:#fff;}
.sb-large{font-size:20px;font-weight:700;color:#fff;}

/* ============ 02b LOCAL SUPPORT ============ */
.local{
  display:flex;flex-direction:column;align-items:center;gap:48px;padding:80px;
  background-image:
    linear-gradient(to bottom,
      rgba(255,255,255,0) calc(100% - 104px),
      rgba(255,255,255,1) calc(100% - 6px),
      rgba(255,255,255,1) 100%),
    linear-gradient(rgba(255,255,255,.3333),rgba(255,255,255,.3333)),
    linear-gradient(180deg,
      rgba(255,255,255,0) 0%,
      rgba(255,255,255,.3765) 4%,
      rgba(255,255,255,.5647) 8%,
      rgba(255,255,255,.7333) 15%,
      rgba(255,255,255,.7333) 100%),
    url('../assets/images/local-support-bg.webp');
  background-size:100% 100%,100% 100%,100% 100%,cover;
  background-position:center,center,center,center;
  background-repeat:no-repeat;
}
.local-header{display:flex;flex-direction:column;align-items:center;gap:20px;width:100%;}
.local-pill{background:var(--primary);border-radius:20px;padding:8px 24px;font-size:16px;font-weight:700;color:#fff;}
.local-title-row{display:flex;align-items:center;gap:8px;}
.ltr-a{font-size:36px;font-weight:900;color:var(--text-dark);line-height:1;}
.ltr-b{font-size:48px;font-weight:900;color:var(--text-dark);line-height:1;}
.local-subtitle{width:700px;font-size:17px;color:var(--text-gray);line-height:1.8;text-align:center;}

.local-cards{display:flex;gap:24px;width:100%;}
.local-card{
  flex:1;background:#fff;border-radius:16px;
  box-shadow:0 4px 20px rgba(0,0,0,.063);
  display:flex;flex-direction:column;gap:16px;padding:48px 0 0;
  position:relative;
}
.lc-badge{
  position:absolute;left:50%;transform:translateX(-50%);top:-24px;
  width:48px;height:48px;border-radius:24px;
  background:linear-gradient(180deg,#3DB8A8,#5ED4C8);
  display:flex;align-items:center;justify-content:center;
  font-size:20px;font-weight:700;color:#fff;
}
.lc-content{display:flex;flex-direction:column;gap:16px;padding:0 24px;}
.lc-icon{width:48px;height:48px;color:var(--primary-dark);}
.lc-title{display:flex;flex-direction:column;}
.lc-t1{font-size:24px;font-weight:900;color:var(--text-dark);}
.lc-t2{font-size:26px;font-weight:900;color:var(--text-dark);}
.lc-tag{align-self:flex-start;background:var(--primary);border-radius:4px;padding:6px 16px;font-size:15px;font-weight:700;color:#fff;}
.lc-desc{font-size:16px;color:var(--text-gray);line-height:1.8;}
.lc-photo{height:260px;background-size:cover;background-position:center;}
.lc-bottom{
  display:flex;align-items:center;gap:12px;background:#F8FAF9;
  border-radius:0 0 16px 16px;padding:16px 20px;margin-top:auto;
}
.lc-check{width:20px;height:20px;color:var(--primary-dark);flex:none;}
.lc-bottom p{font-size:15px;color:#555;line-height:1.6;}

.local-footer{display:flex;flex-direction:column;align-items:center;gap:16px;}
.local-footer-txt{font-size:20px;font-weight:700;color:var(--text-dark);}
.pepper-logo{display:flex;align-items:center;gap:20px;}
.pepper-logo-icon{width:122px;height:122px;}
.pepper-logo-icon img{width:122px;height:122px;object-fit:contain;}
.pepper-logo-col{display:flex;flex-direction:column;gap:14px;}
.pepper-logo-text{display:flex;align-items:flex-end;}
.plt-pepper{font-size:54px;font-weight:800;color:#2A2622;letter-spacing:.3px;}
.plt-cycle{font-size:54px;font-weight:700;color:#3DB8A8;letter-spacing:.3px;margin-left:24px;}
.pepper-logo-sub{font-family:'Zen Kaku Gothic New',sans-serif;font-size:18px;font-weight:500;color:#8A7E6E;letter-spacing:1px;}

/* ============ 03 EASY BOOKING ============ */
.easy{display:flex;flex-direction:column;align-items:center;gap:40px;padding:60px 120px;background:#fff;position:relative;margin-top:-1px;}
.easy-header{display:flex;flex-direction:column;align-items:center;gap:12px;width:100%;}
.easy-sub{font-size:16px;font-weight:600;color:var(--primary);}
.easy-title{font-size:28px;font-weight:700;color:var(--text-dark);text-align:center;}
.easy-desc{width:700px;font-size:17px;color:var(--text-gray);line-height:1.8;text-align:center;}
.steps-row{display:flex;align-items:center;justify-content:center;gap:32px;width:100%;}
.step{display:flex;flex-direction:column;align-items:center;gap:8px;}
.step-circle{
  width:48px;height:48px;border-radius:24px;background:var(--primary);
  display:flex;align-items:center;justify-content:center;
  font-size:22px;font-weight:700;color:#fff;
}
.step-circle-accent{background:var(--accent);}
.step-label{font-size:16px;font-weight:600;color:var(--text-dark);}
.step-arrow{width:24px;height:24px;color:var(--primary);}
.booking-image-title{font-size:38px;font-weight:800;color:var(--text-dark);text-align:center;letter-spacing:.02em;margin:0;}
.booking-image-title .bit-accent{color:#06C755;}
.booking-image{width:1375px;max-width:none;height:auto;border-radius:12px;}

/* ============ 04 REASONS ============ */
.reasons{display:flex;flex-direction:column;align-items:center;gap:60px;padding:80px 200px;background:var(--green-light);}
.reasons-header{display:flex;flex-direction:column;align-items:center;gap:12px;width:100%;}
.reasons-eyebrow{font-size:16px;color:var(--text-gray);}
.reasons-title{display:flex;justify-content:center;}
.reasons-title span{font-size:28px;font-weight:700;}
.rt-dark{color:var(--text-dark);}
.rt-accent{color:var(--accent);}
.reasons-lead{font-size:16px;color:var(--text-gray);}
.reasons-cards{display:flex;flex-direction:column;gap:40px;width:100%;}
.reason-card{
  display:flex;align-items:center;gap:32px;padding:40px 48px;border-radius:12px;
  background-size:cover;background-position:center;
  box-shadow:0 4px 20px rgba(0,0,0,.071);
}
.reason-text{flex:1;display:flex;flex-direction:column;gap:12px;}
.reason-num{font-size:48px;font-weight:700;color:var(--accent);line-height:1;}
.reason-card-title{font-size:22px;font-weight:700;color:var(--text-dark);}
.reason-card-desc{font-size:16px;color:var(--text-gray);line-height:1.8;}
.reason-img{flex:none;background-size:contain;background-repeat:no-repeat;background-position:center;}
.reason-img-wrap{width:248px;height:248px;flex:none;position:relative;overflow:visible;}
.reason-img3{position:absolute;left:-40px;top:0;width:248px;height:248px;}

/* ============ 04b FEATURES ============ */
.features{
  display:flex;flex-direction:column;align-items:center;gap:48px;padding:80px 100px;
  background-image:url('../assets/images/features-section-bg.webp');
  background-size:cover;background-position:center;
}
.features-header{display:flex;flex-direction:column;align-items:center;gap:16px;width:100%;}
.features-label{display:flex;align-items:center;justify-content:center;gap:12px;}
.fl-line{width:40px;height:1px;background:var(--primary);}
.fl-text{font-size:16px;font-weight:500;color:var(--primary);}
.features-title{font-size:32px;font-weight:800;color:var(--text-dark);text-align:center;}
.sp-br{display:none;} /* SP版のみ改行として表示 */
.features-subtitle{font-size:16px;color:var(--text-gray);text-align:center;}
.feature-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;width:100%;}
.feature-card{
  position:relative;background:#fff;border-radius:12px;padding:64px 24px 24px;
  display:flex;flex-direction:column;justify-content:space-between;gap:8px;min-height:220px;
  transition:transform .25s ease, box-shadow .25s ease;
}
.feature-card:hover{transform:translateY(-4px);box-shadow:0 12px 28px rgba(0,0,0,.10);}
.fc-badge{
  position:absolute;left:0;top:0;width:56px;height:56px;
  border-radius:12px 0 56px 0;
  background:linear-gradient(225deg,#8EE0D5,#3DB8A8);
  display:flex;align-items:flex-start;justify-content:center;
  padding-top:10px;font-size:15px;font-weight:700;color:#fff;
}
.fc-content{display:flex;gap:16px;}
.fc-icon{width:96px;height:96px;border-radius:48px;flex:none;background-size:cover;background-position:center;}
.fc-text{display:flex;flex-direction:column;gap:4px;}
.fc-text h3{font-size:20px;font-weight:700;color:var(--text-dark);}
.fc-text h3.fc-title-sm{font-size:18px;}
.fc-text p{font-size:14px;color:var(--text-gray);line-height:1.7;}
.fc-arrow{display:flex;justify-content:flex-end;}
.fc-arrow-circle{
  display:inline-flex;align-items:center;justify-content:center;
  width:34px;height:34px;border-radius:50%;
  background:var(--green-light);color:var(--primary);
  transition:transform .25s ease, background-color .25s ease, color .25s ease, box-shadow .25s ease;
}
.fc-arrow-circle i,.fc-arrow-circle svg{width:18px;height:18px;}
.feature-card:hover .fc-arrow-circle{
  background:var(--primary);color:#fff;
  transform:translateX(6px);
  box-shadow:0 6px 14px rgba(78,205,196,.45);
}
.features-bar{
  display:flex;align-items:center;gap:24px;width:100%;
  background:rgba(255,255,255,.8);border-radius:12px;padding:20px 32px;
}
.fb-icon{width:24px;height:24px;color:var(--primary);flex:none;}
.fb-text{font-size:17px;font-weight:600;color:var(--text-dark);}
.fb-spacer{flex:1;}
.fb-item{display:flex;align-items:center;gap:6px;font-size:15px;font-weight:600;color:var(--text-dark);}
.fb-item i{width:18px;height:18px;color:var(--primary);}
.features-btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;align-self:center;background:var(--primary);border-radius:50px;padding:16px 56px;font-size:18px;font-weight:700;color:#fff;box-shadow:0 4px 12px rgba(0,0,0,.125);transition:background .2s,transform .2s;}
.features-btn:hover{background:var(--primary-dark);transform:translateY(-2px);}
.features-btn i{width:20px;height:20px;}

/* ============ 05 / 08 CTA BAND ============ */
.cta-band{display:flex;flex-direction:column;align-items:center;gap:24px;padding:48px 120px;background:var(--primary);}
.cta-pill{
  background:#fff;border-radius:50px;padding:20px 80px;
  display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px;
  box-shadow:0 4px 16px rgba(0,0,0,.125);
}
.cta-pill-main{font-size:24px;font-weight:700;color:var(--primary);}
.cta-pill-note{font-size:14px;color:var(--text-gray);}
.cta2-check{display:flex;align-items:center;gap:8px;}
.cta2-check i{width:20px;height:20px;color:#fff;}
.cta2-check span{font-size:18px;font-weight:600;color:#fff;}
.cta2-sec{
  display:flex;align-items:center;gap:8px;border:2px solid #fff;border-radius:50px;padding:16px 48px;
  font-size:18px;font-weight:600;color:#fff;
}
.cta2-sec i{width:18px;height:18px;}

/* ============ 06 PRICING ============ */
.pricing{display:flex;flex-direction:column;align-items:center;gap:24px;padding:70px 200px;background:#fff;}
.pricing-label{font-size:16px;color:var(--text-gray);text-align:center;}
.pricing-title{font-size:28px;font-weight:700;color:var(--text-dark);text-align:center;}
.pricing-card{
  width:700px;background:#fff;border-radius:12px;border-top:3px solid var(--primary);
  padding:40px 48px;display:flex;flex-direction:column;align-items:center;gap:20px;
  box-shadow:0 4px 24px rgba(0,0,0,.078);
}
.price-label{font-size:15px;color:var(--text-gray);text-align:center;}
.price-row{display:flex;align-items:flex-end;justify-content:center;gap:4px;}
.price-num{font-size:48px;font-weight:700;color:var(--text-dark);line-height:1;}
.price-suffix{font-size:20px;color:var(--text-gray);}
.init-row{display:flex;align-items:center;justify-content:center;gap:10px;}
.old-price{font-size:17px;color:var(--text-gray);}
.init-arrow{font-size:17px;color:var(--text-gray);}
.free-text{font-size:20px;font-weight:700;color:var(--accent);}
.price-divider{width:100%;height:1px;background:var(--border);}
.price-desc{font-size:16px;color:var(--text-gray);line-height:1.7;text-align:center;}

/* ============ 07 OPTIONS ============ */
.options{
  display:flex;flex-direction:column;align-items:center;gap:40px;padding:50px 0 60px;
  background-image:linear-gradient(rgba(255,255,255,.91),rgba(255,255,255,.91)),url('../assets/images/options-section-bg.webp');
  background-size:cover;background-position:center;
}
.options-inner{width:800px;display:flex;flex-direction:column;align-items:center;gap:32px;}
.options-header{display:flex;flex-direction:column;align-items:center;gap:10px;width:100%;}
.options-badge{background:var(--green-light);border-radius:20px;padding:6px 16px;font-size:15px;font-weight:600;color:var(--primary);}
.options-title{font-size:24px;font-weight:700;color:var(--text-dark);text-align:center;}
.options-desc{font-size:16px;color:var(--text-gray);line-height:1.8;text-align:center;}
.options-cards{display:flex;gap:20px;width:100%;}
.option-card{
  flex:1;background:var(--green-light);border-radius:12px;padding:24px;
  display:flex;flex-direction:column;align-items:center;gap:12px;
}
.oc-icon{width:44px;height:44px;border-radius:22px;background:var(--primary);display:flex;align-items:center;justify-content:center;}
.oc-icon-accent{background:var(--accent);}
.oc-icon i{width:22px;height:22px;color:#fff;}
.oc-title{font-size:17px;font-weight:700;color:var(--text-dark);}
.oc-desc{font-size:14px;color:var(--text-gray);line-height:1.7;text-align:center;}
.options-btn{
  display:flex;align-items:center;justify-content:center;gap:8px;
  background:var(--primary);border-radius:50px;padding:14px 40px;
  font-size:18px;font-weight:700;color:#fff;box-shadow:0 4px 12px rgba(0,0,0,.125);
}
.options-btn i{width:20px;height:20px;}

/* ============ 12 GUIDE ============ */
.guide{display:flex;flex-direction:column;align-items:center;gap:40px;padding:70px 0;background:var(--green-light);}
.guide-inner{width:900px;display:flex;flex-direction:column;align-items:center;gap:40px;}
.guide-title{font-size:24px;font-weight:700;color:var(--text-dark);text-align:center;}
.guide-box{
  width:100%;background:#fff;border-radius:16px;border:2px solid var(--primary);
  padding:32px 40px;display:flex;flex-direction:column;align-items:center;gap:28px;
}
.guide-box-title{font-size:20px;font-weight:700;color:var(--text-dark);text-align:center;}
.guide-steps{display:flex;align-items:flex-start;justify-content:center;gap:20px;}
.guide-step{display:flex;flex-direction:column;align-items:center;gap:12px;}
.gs-circle{
  width:52px;height:52px;border-radius:26px;background:var(--primary);
  display:flex;align-items:center;justify-content:center;font-size:24px;font-weight:700;color:#fff;
}
.gs-label{font-size:17px;font-weight:600;color:var(--text-dark);}
.gs-desc{width:140px;font-size:14px;color:var(--text-gray);line-height:1.6;text-align:center;}
.gs-arrow{width:28px;height:28px;color:var(--primary);margin-top:14px;flex:none;}
.guide-reassure{display:flex;flex-direction:column;align-items:center;gap:8px;}
.guide-lock{display:flex;align-items:center;gap:6px;}
.guide-lock i{width:18px;height:18px;color:var(--primary);}
.guide-lock span{font-size:15px;color:var(--text-gray);}
.guide-support{font-size:15px;color:var(--text-light);text-align:center;}
/* SP版専用ガイドボックス（PCでは非表示） */
.guide-box-sp{display:none;width:100%;background:#fff;border-radius:16px;border:2px solid var(--primary);overflow:hidden;flex-direction:column;}
.gbsp-item{display:flex;align-items:center;gap:14px;padding:20px;}
.gbsp-icon{width:28px;height:28px;color:var(--primary);flex:none;}
.gbsp-text{display:flex;flex-direction:column;gap:4px;}
.gbsp-title{font-size:16px;font-weight:700;color:var(--text-dark);}
.gbsp-desc{font-size:14px;color:var(--text-gray);line-height:1.7;}
.gbsp-sep{height:1px;background:var(--border);width:100%;}

/* ============ 12b FAQ ============ */
.faq{display:flex;flex-direction:column;align-items:center;gap:40px;padding:80px 120px;background:var(--bg-light);}
.faq-inner{width:100%;max-width:860px;display:flex;flex-direction:column;align-items:center;gap:40px;}
.faq-header{display:flex;flex-direction:column;align-items:center;gap:14px;}
.faq-title{font-size:32px;font-weight:800;color:var(--text-dark);text-align:center;}
.faq-subtitle{font-size:16px;color:var(--text-gray);text-align:center;}
.faq-list{width:100%;display:flex;flex-direction:column;gap:16px;}
.faq-item{background:#fff;border-radius:12px;border:1px solid var(--border);overflow:hidden;transition:box-shadow .2s;}
.faq-item[open]{box-shadow:0 4px 20px rgba(0,0,0,.06);}
.faq-q{display:flex;align-items:center;gap:16px;padding:20px 24px;cursor:pointer;list-style:none;}
.faq-q::-webkit-details-marker{display:none;}
.faq-q-mark{flex:none;width:32px;height:32px;border-radius:8px;background:var(--primary);color:#fff;display:flex;align-items:center;justify-content:center;font-size:18px;font-weight:800;}
.faq-q-text{flex:1;font-size:18px;font-weight:700;color:var(--text-dark);line-height:1.5;}
.faq-chevron{flex:none;width:20px;height:20px;color:var(--primary);transition:transform .25s;}
.faq-item[open] .faq-chevron{transform:rotate(180deg);}
.faq-a{display:flex;gap:16px;padding:0 24px 22px;}
.faq-a-mark{flex:none;width:32px;height:32px;border-radius:8px;background:var(--accent-light);color:var(--accent);display:flex;align-items:center;justify-content:center;font-size:18px;font-weight:800;}
.faq-a p{flex:1;font-size:16px;color:var(--text-gray);line-height:1.8;padding-top:3px;}
.faq-a-body{flex:1;display:flex;flex-direction:column;gap:12px;padding-top:3px;}
.faq-a-body p{flex:0 1 auto;font-size:16px;color:var(--text-gray);line-height:1.8;padding-top:0;}

/* ============ 13 BOTTOM FORM ============ */
.bform{display:flex;flex-direction:column;align-items:center;gap:32px;padding:60px 0;background:var(--primary-dark);}
.bform-header{display:flex;flex-direction:column;align-items:center;gap:8px;}
.bform-h1{font-size:18px;font-weight:700;color:#fff;}
.bform-h2{font-size:16px;color:rgba(255,255,255,.8);}
.bform-card{width:700px;background:#fff;border-radius:12px;padding:40px;display:flex;flex-direction:column;gap:16px;}
.bform-card .field{gap:4px;}
.bform-card .input .ph{font-size:15px;}
.select-caret{font-size:14px;color:var(--text-light);}
.bform-btn{background:var(--primary);border:none;border-radius:8px;padding:16px;font-size:18px;font-weight:700;color:#fff;cursor:pointer;}
.staff-wrap{display:flex;align-items:center;gap:16px;}
.staff-img{width:120px;height:120px;border-radius:12px;background:#fff;overflow:hidden;display:flex;align-items:center;justify-content:center;}
.staff-img img{width:120px;height:120px;object-fit:contain;}
.staff-text{display:flex;flex-direction:column;gap:4px;}
.staff-t1{font-size:16px;font-weight:700;color:#fff;}
.staff-t2{font-size:15px;color:rgba(255,255,255,.8);}

/* ============ 14 PHONE BAR ============ */
.phone-bar{display:flex;align-items:center;justify-content:center;gap:16px;padding:28px 120px;background:var(--primary);}
.phone-icon{width:24px;height:24px;color:#fff;}
.phone-num{font-size:32px;font-weight:800;color:#fff;}
.phone-hours{display:flex;flex-direction:column;align-items:center;gap:2px;}
.phone-hours .ph1{font-size:14px;color:#fff;}
.phone-hours .ph2{font-size:11px;color:#fff;opacity:.7;}

/* ============ 15 FOOTER ============ */
.footer{display:flex;flex-direction:column;align-items:center;gap:20px;padding:40px 120px;background:#F5F5F5;}
.footer-links{display:flex;align-items:center;justify-content:center;gap:32px;width:100%;flex-wrap:wrap;}
.footer-links a{font-size:14px;color:var(--text-gray);}
.footer-divider{width:100%;height:1px;background:var(--border);}
.footer-copy{font-size:11px;color:var(--text-light);}

/* ============ NEWS ============ */
.news{display:flex;flex-direction:column;align-items:center;gap:44px;padding:80px 120px;background:#fff;}
.news-eyebrow{display:flex;flex-direction:column;align-items:center;gap:14px;}
.news-eyebrow-en{font-size:15px;font-weight:700;letter-spacing:3px;color:var(--text-dark);}
.news-eyebrow-line{width:1px;height:28px;background:var(--primary);}
.news-title{font-size:32px;font-weight:800;color:var(--text-dark);text-align:center;letter-spacing:2px;}
.news-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:32px;width:100%;max-width:1120px;}
/* トップページのニュースは4枚（地域2＋一般2）→ PCは4カラム */
@media (min-width:861px){ #news .news-grid{grid-template-columns:repeat(4,1fr);} }
.news-card{display:flex;flex-direction:column;gap:14px;color:inherit;transition:transform .2s;}
.news-card:hover{transform:translateY(-4px);}
.news-card:hover .news-card-title{color:var(--primary);}
.news-thumb{position:relative;aspect-ratio:16/9;border-radius:12px;overflow:hidden;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;padding:20px;text-align:center;background:var(--bg-light);}
.news-thumb i{width:48px;height:48px;}
.news-thumb img{width:100%;height:100%;object-fit:cover;display:block;}
.news-thumb-title{font-size:19px;font-weight:800;line-height:1.5;}
.news-thumb-1{background:linear-gradient(135deg,#E3F7E8,#B8E6C5);}
.news-thumb-1 i,.news-thumb-1 .news-thumb-title{color:#2E9E6B;}
.news-thumb-2{background:linear-gradient(135deg,#E6F0FC,#BFD8F5);}
.news-thumb-2 i,.news-thumb-2 .news-thumb-title{color:#3A78C2;}
.news-thumb-3{background:linear-gradient(135deg,#FFF1DC,#FFD7A6);}
.news-thumb-3 i,.news-thumb-3 .news-thumb-title{color:#E0892B;}
.news-body{display:flex;flex-direction:column;gap:8px;}
.news-tag{align-self:flex-start;background:#FF6F91;color:#fff;font-size:11px;font-weight:700;padding:3px 12px;border-radius:20px;}
.news-card-title{font-size:17px;font-weight:700;color:var(--text-dark);line-height:1.6;transition:color .2s;}
.news-excerpt{font-size:15px;color:var(--text-light);line-height:1.7;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;}
.news-more{display:inline-flex;align-items:center;justify-content:center;gap:10px;align-self:center;min-width:300px;padding:17px 40px;border:2px solid var(--primary);border-radius:50px;color:var(--primary);font-size:17px;font-weight:700;letter-spacing:1px;transition:background .2s,color .2s;}
.news-more:hover{background:var(--primary);color:#fff;}
.news-more i{width:18px;height:18px;}

/* ============ ARTICLE DETAIL ============ */
.article-screen{padding:96px 20px 64px;}
.article{max-width:820px;margin:0 auto;background:#fff;border-radius:16px;box-shadow:0 6px 30px rgba(0,0,0,.06);padding:48px 48px 56px;}
@media (max-width:680px){.article{padding:32px 22px 40px;}}
.breadcrumb{display:flex;flex-wrap:wrap;gap:8px;align-items:center;font-size:14px;color:var(--text-light);margin-bottom:28px;}
.breadcrumb a{color:var(--text-gray);}
.breadcrumb a:hover{color:var(--primary);}
.breadcrumb .sep{color:var(--border);}
.article-meta{display:flex;align-items:center;gap:12px;margin-bottom:16px;}
.article-cat{background:#FF6F91;color:#fff;font-size:11px;font-weight:700;padding:4px 14px;border-radius:20px;}
.article-date{font-size:15px;color:var(--text-light);}
.article-title{font-size:30px;font-weight:800;line-height:1.5;color:var(--text-dark);margin-bottom:32px;}
.article-eyecatch{aspect-ratio:16/9;border-radius:16px;margin-bottom:44px;overflow:hidden;}
.article-eyecatch img{width:100%;height:100%;object-fit:cover;display:block;}
.article-eyecatch .news-thumb-title{font-size:24px;}
.article-eyecatch i{width:52px;height:52px;}
.article-body{font-size:17px;line-height:2;color:var(--text-gray);}
.article-body p{margin-bottom:20px;}
.article-body h2{font-size:24px;font-weight:800;color:var(--text-dark);margin:44px 0 18px;padding-left:14px;border-left:5px solid var(--primary);line-height:1.5;}
.article-body h3{font-size:19px;font-weight:700;color:var(--text-dark);margin:30px 0 12px;}
.article-body ul{margin:0 0 20px;padding:0;list-style:none;display:flex;flex-direction:column;gap:12px;}
.article-body ul li{position:relative;padding-left:30px;}
.article-body ul li::before{content:"";position:absolute;left:0;top:7px;width:18px;height:18px;border-radius:50%;background:var(--green-light);}
.article-body ul li::after{content:"";position:absolute;left:6px;top:11px;width:5px;height:9px;border:solid var(--primary);border-width:0 2px 2px 0;transform:rotate(45deg);}
.article-body strong{color:var(--text-dark);font-weight:700;}
.article-cta{margin-top:52px;background:linear-gradient(135deg,var(--primary),var(--primary-dark));border-radius:16px;padding:36px 40px;text-align:center;display:flex;flex-direction:column;align-items:center;gap:14px;}
.article-cta h3{font-size:23px;font-weight:800;color:#fff;}
.article-cta p{font-size:17px;color:rgba(255,255,255,.95);line-height:1.9;}
.article-cta .options-btn{margin-top:6px;background:#fff;color:var(--primary-dark);}
.article-cta .options-btn i{color:var(--primary-dark);}
.article-cta .options-btn:hover{background:var(--bg-light);}

/* リード文 */
.article-lead{background:var(--green-light);border-left:4px solid var(--primary);border-radius:0 10px 10px 0;padding:20px 24px;margin:0 0 32px;font-size:17px;line-height:1.9;color:var(--text-gray);}
/* 目次 */
.article-toc{background:var(--bg-light);border:1px solid var(--border);border-radius:12px;padding:24px 28px;margin:0 0 36px;}
.article-toc-h{font-size:18px;font-weight:700;color:var(--text-dark);margin:0 0 14px;}
.article-toc ol{margin:0;padding-left:20px;}
.article-toc li{margin:8px 0;line-height:1.6;}
.article-toc a{color:var(--text-gray);}
.article-toc a:hover{color:var(--primary);text-decoration:underline;}
.article-body h2{scroll-margin-top:88px;}
/* 本文インライン画像 */
.article-img{margin:32px 0;}
.article-img img{width:100%;height:auto;border-radius:12px;display:block;}
/* 画像プレースホルダ（画像未挿入の枠） */
.article-img-placeholder{margin:32px 0;aspect-ratio:16/9;border-radius:12px;border:2px dashed var(--primary);background:linear-gradient(135deg,#EAFBF8 0%,#D6F3ED 100%);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:10px;text-align:center;padding:16px;}
.article-img-placeholder i{width:40px;height:40px;color:var(--primary);opacity:.75;}
.article-img-placeholder figcaption{font-size:15px;color:var(--text-gray);line-height:1.7;}
/* 補足ボックス */
.article-body .note-box{background:#FFF8EC;border:1px solid #F5D9A6;border-radius:10px;padding:18px 22px;margin:24px 0;font-size:16px;line-height:1.85;color:var(--text-gray);}
.article-body .note-box a{color:var(--primary-dark);font-weight:700;text-decoration:underline;}

.article-back{display:flex;justify-content:center;margin-top:48px;}
.back-to-list{display:inline-flex;align-items:center;gap:10px;padding:14px 34px;background:#fff;border:2px solid var(--primary);border-radius:999px;color:var(--primary-dark);font-size:17px;font-weight:700;box-shadow:0 2px 10px rgba(0,0,0,.06);transition:background .2s,color .2s,box-shadow .2s,transform .2s;}
.back-to-list:hover{background:var(--primary);color:#fff;box-shadow:0 8px 22px rgba(78,205,196,.35);transform:translateY(-2px);}
.back-to-list i{width:18px;height:18px;transition:transform .2s;}
.back-to-list:hover i{transform:translateX(-3px);}
.article-related{margin-top:56px;}
.article-related h2{font-size:22px;font-weight:800;color:var(--text-dark);margin-bottom:20px;padding-left:14px;border-left:5px solid var(--primary);}
/* 関連記事も一覧と同じ行リスト（記事カード内なのでパネル装飾は外す） */
.article-related .news-list{background:transparent;box-shadow:none;border-radius:0;max-width:none;}
.article-related .news-list .news-card{padding:20px 0;}
.article-related .news-list .news-card:first-child{border-top:1px solid var(--border);}

/* ============ BOOKING PAGE ============ */
.booking{max-width:760px;margin:0 auto;padding:104px 24px 88px;}
.booking-head{display:flex;flex-direction:column;align-items:center;gap:12px;text-align:center;margin-bottom:40px;}
.booking-eyebrow{font-size:15px;font-weight:700;letter-spacing:3px;color:var(--primary);}
.booking-title{font-size:30px;font-weight:800;color:var(--text-dark);}
.booking-desc{font-size:16px;color:var(--text-gray);line-height:1.8;}
.booking-card{background:#fff;border:1px solid var(--border);border-radius:16px;padding:36px 32px;display:flex;flex-direction:column;gap:32px;box-shadow:0 4px 24px rgba(0,0,0,.05);}
.booking-step{display:flex;flex-direction:column;gap:14px;}
.step-head{display:flex;align-items:center;gap:12px;}
.step-no{width:30px;height:30px;border-radius:50%;background:var(--primary);color:#fff;display:flex;align-items:center;justify-content:center;font-size:17px;font-weight:800;flex:none;}
.step-title{font-size:20px;font-weight:700;color:var(--text-dark);}
.booking-date{max-width:280px;cursor:pointer;}
.booking-note{font-size:14px;color:var(--text-light);line-height:1.7;}
.time-slots{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;}
.time-slot-btn{padding:12px 0;border:1.5px solid var(--border);border-radius:8px;background:#fff;font-size:17px;font-weight:700;color:var(--text-dark);cursor:pointer;transition:all .15s;font-family:inherit;}
.time-slot-btn:hover{border-color:var(--primary);color:var(--primary);}
.time-slot-btn.selected{background:var(--primary);border-color:var(--primary);color:#fff;}
.time-slots-loading,.time-slots-empty{grid-column:1/-1;font-size:15px;color:var(--text-gray);padding:10px 0;}
.booking-fields{display:grid;grid-template-columns:1fr 1fr;gap:16px;}
.booking-fields .field-full{grid-column:1/-1;}
.booking-privacy{font-size:11px;color:var(--text-light);text-align:center;}
.booking-submit{background:var(--primary);border:none;border-radius:50px;padding:18px;font-size:19px;font-weight:700;color:#fff;cursor:pointer;transition:background .2s;box-shadow:0 4px 16px rgba(78,205,196,.3);}
.booking-submit:hover{background:var(--primary-dark);}
.booking-submit:disabled{opacity:.6;cursor:not-allowed;}
/* 予約完了パネル */
.booking-complete[hidden]{display:none;}
.booking-complete{max-width:600px;margin:0 auto;background:#fff;border:1px solid var(--border);border-radius:16px;padding:48px 36px;text-align:center;display:flex;flex-direction:column;align-items:center;gap:18px;box-shadow:0 8px 32px rgba(0,0,0,.07);}
.bc-icon{width:76px;height:76px;border-radius:50%;background:var(--primary);display:flex;align-items:center;justify-content:center;box-shadow:0 6px 18px rgba(78,205,196,.4);}
.bc-icon i{width:40px;height:40px;color:#fff;stroke-width:3;}
.bc-title{font-size:26px;font-weight:800;color:var(--text-dark);}
.bc-lead{font-size:16px;color:var(--text-gray);}
.bc-datetime{font-size:24px;font-weight:800;color:var(--primary-dark);background:var(--green-light);border-radius:12px;padding:18px 28px;letter-spacing:.5px;}
.bc-info{width:100%;display:flex;flex-direction:column;gap:12px;text-align:left;margin-top:4px;}
.bc-info p{display:flex;align-items:flex-start;gap:10px;font-size:15px;color:var(--text-gray);line-height:1.8;}
.bc-info i{width:18px;height:18px;color:var(--primary);flex:none;margin-top:3px;}
.bc-info p span{flex:1;}
.bc-info strong{color:var(--text-dark);font-weight:700;}
.bc-btn{display:inline-flex;align-items:center;justify-content:center;margin-top:8px;padding:15px 44px;border-radius:50px;background:var(--primary);color:#fff;font-size:17px;font-weight:700;transition:background .2s;}
.bc-btn:hover{background:var(--primary-dark);}

/* ============ FEATURE DETAIL PAGE ============ */
.feat-page-header{display:flex;flex-direction:column;align-items:center;gap:16px;padding:104px 120px 40px;background:url('../assets/images/wallpaper-aqua.webp') center/cover fixed;}
.feat-eyebrow{font-size:16px;font-weight:600;color:#0E6256;letter-spacing:3px;}
.feat-page-title{font-size:36px;font-weight:800;color:var(--text-dark);text-align:center;}
.feat-page-desc{font-size:17px;color:var(--text-gray);text-align:center;}
.feat-nav{display:flex;flex-wrap:wrap;justify-content:center;gap:10px;padding:8px 20px 0;}
.feat-nav a{display:inline-flex;align-items:center;gap:6px;padding:12px 16px;border-radius:8px;font-size:14px;font-weight:500;background:#F5F7FA;color:var(--text-dark);transition:background .2s,color .2s;}
.feat-nav a i{width:16px;height:16px;color:var(--primary);}
.feat-nav a:hover{background:var(--green-light);}
.feat-nav a.is-active{background:var(--primary);color:#fff;font-weight:600;}
.feat-nav a.is-active i{color:#fff;}
.feat-section{display:flex;align-items:stretch;gap:60px;padding:60px 120px;min-height:500px;scroll-margin-top:88px;}
.feat-section:nth-child(even){background:var(--bg-light);}
.feat-section-bg{background-size:cover;background-position:center;background-repeat:no-repeat;background-attachment:fixed;}
/* mint背景上ではアクセント(ティール)文字を濃色にして可読性を確保 */
.feat-section-bg .feat-label,
.feat-section-bg .feat-num{color:#0E6256;}
.feat-section-bg .feat-bar{background:#0E6256;}
.feat-section-bg .feat-func-item i{color:#0E6256;}
.feat-section-bg .feat-func-item{color:#244B45;}
.feat-text{flex:1;display:flex;flex-direction:column;justify-content:center;gap:20px;}
.feat-badge{display:flex;align-items:center;gap:12px;}
.feat-bar{width:4px;height:28px;border-radius:2px;background:var(--primary);}
.feat-num{font-size:28px;font-weight:700;color:var(--primary);}
.feat-label{font-size:16px;font-weight:600;color:var(--primary);letter-spacing:1px;}
.feat-heading{font-size:25px;font-weight:700;color:var(--text-dark);line-height:1.5;}
.feat-desc{font-size:16px;color:var(--text-gray);line-height:1.8;}
.feat-func{display:flex;flex-direction:column;gap:10px;margin-top:4px;}
.feat-func-label{font-size:15px;font-weight:700;color:var(--text-dark);}
.feat-func-item{display:flex;align-items:center;gap:8px;font-size:15px;color:var(--text-gray);}
.feat-func-item i{width:16px;height:16px;color:var(--primary);flex:none;}
.feat-img{flex:1;align-self:stretch;min-height:380px;border-radius:12px;overflow:hidden;background:#F5F7FA;}
.feat-img img{width:100%;height:100%;object-fit:contain;display:block;}

/* ============ NEWS LIST PAGE ============ */
.news-screen{background-image:url('../assets/images/wallpaper-mint.webp');background-size:cover;background-position:center;background-attachment:fixed;background-repeat:no-repeat;}
/* 一覧：白パネル内に横並びの行リスト（参考デザイン準拠） */
.news-list{width:100%;max-width:900px;margin:0 auto;background:#fff;border-radius:16px;box-shadow:0 6px 30px rgba(0,0,0,.06);overflow:hidden;display:flex;flex-direction:column;}
.news-list .news-card{display:flex;flex-direction:row;gap:24px;align-items:center;padding:22px 28px;border-bottom:1px solid var(--border);transition:background .2s;}
.news-list .news-card:last-child{border-bottom:none;}
.news-list .news-card:hover{background:var(--bg-light);}
/* サムネは画像そのもの（親要素なし）。背景枠なしで画像が直接表示される */
.news-list .news-thumb{display:block;width:200px;flex-shrink:0;aspect-ratio:16/10;border-radius:12px;object-fit:cover;padding:0;background:transparent;}
.news-list .news-body{display:flex;flex-direction:column;gap:8px;flex:1;min-width:0;}
.news-list .news-meta{display:flex;align-items:center;gap:8px;}
.news-cat{display:inline-block;font-size:14px;font-weight:700;color:var(--primary-dark);background:var(--green-light);padding:3px 12px;border-radius:999px;}
.news-list .news-date{font-size:13px;font-weight:600;color:var(--text-gray);letter-spacing:.02em;}
.news-list .news-card-title{font-size:20px;font-weight:700;color:var(--text-dark);line-height:1.6;transition:color .2s;}
.news-list .news-card:hover .news-card-title{color:var(--primary);}
.news-list .news-excerpt{font-size:16px;color:var(--text-gray);line-height:1.8;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;}
.news-list-hero{display:flex;flex-direction:column;align-items:center;gap:14px;padding:64px 24px 8px;}
.news-list-sub{font-size:16px;color:var(--text-gray);text-align:center;line-height:1.7;max-width:680px;}
.pager{display:flex;flex-wrap:wrap;align-items:center;justify-content:center;gap:8px;margin-top:8px;}
.pager a,.pager span{display:inline-flex;align-items:center;justify-content:center;gap:4px;min-width:44px;height:44px;padding:0 16px;border-radius:8px;font-size:16px;font-weight:700;border:1px solid var(--border);color:var(--text-gray);background:#fff;transition:all .2s;}
.pager a:hover{border-color:var(--primary);color:var(--primary);}
.pager .is-current{background:var(--primary);border-color:var(--primary);color:#fff;}
.pager .is-disabled{opacity:.4;pointer-events:none;}
.pager i{width:16px;height:16px;}

/* ============================================================
   RESPONSIVE / SP（SP版デザイン fPBrS を参考）
   ============================================================ */
.nav-toggle{display:none;background:none;border:none;cursor:pointer;width:42px;height:42px;align-items:center;justify-content:center;color:var(--text-dark);padding:0;}
.nav-toggle i{width:26px;height:26px;}

/* タブレット：大きすぎる左右余白を圧縮 */
@media (max-width:1000px){
  .reasons{padding:64px 24px;}
  .pricing{padding:64px 24px;}
  .features{padding:64px 24px;}
  .feat-section{padding:48px 32px;}
  .options-inner,.guide-inner{width:100%;}
}

/* ===== SP（〜860px）：1カラム＆ハンバーガー ===== */
@media (max-width:860px){
  /* header */
  .header{height:56px;padding:0 16px;flex-wrap:wrap;align-content:flex-start;}
  .logo-area{order:1;}
  .nav-toggle{order:2;display:flex;margin-left:auto;}
  .nav-area{order:3;}
  .cta-area{order:4;}
  .nav-area,.cta-area{display:none;}
  .header.nav-open{height:auto;background:#fff;box-shadow:0 10px 24px rgba(0,0,0,.12);}
  .header.nav-open .nav-area{
    display:flex;flex-direction:column;align-items:stretch;gap:0;
    flex-basis:100%;width:100%;background:#fff;
    padding:4px 0 0;
    max-height:calc(100vh - 140px);overflow:auto;
  }
  .header.nav-open .nav-area a{padding:14px 6px;border-top:1px solid var(--border);font-size:14px;}
  .header.nav-open .cta-area{
    display:flex;flex-basis:100%;width:100%;justify-content:center;
    padding:12px 6px 14px;border-top:1px solid var(--border);
  }
  .header.nav-open .header-cta{width:100%;justify-content:center;text-align:center;}

  /* hero → 縦並び（SP版は背景画像が別） */
  .hero{flex-direction:column;padding-top:56px;
    background-image:url('../assets/images/hero-background-sp.webp');}
  .hero-left{width:100%;padding:28px 16px 4px;gap:18px;}
  .hero-heading{font-size:22px;text-align:center;max-width:100%;}
  .hero-sub{font-size:13px;text-align:center;}
  /* SP版：バッジを小さくして横1列に */
  .badge-row{width:100%;flex-wrap:nowrap;justify-content:center;gap:8px;}
  .hero-badge{flex:1 1 0;min-width:0;width:auto;height:auto;aspect-ratio:1;padding:8px 4px 6px;gap:4px;}
  .hero-badge-img{width:40px;height:40px;}
  .hero-badge span{font-size:9px;text-align:center;line-height:1.25;}
  .hero-mockup{zoom:.54;margin:0 auto;}
  .hero-stats{justify-content:center;}
  .hero-right{width:100%;padding:4px 20px 28px;align-items:center;}
  .form-banner,.form-card{width:100%;max-width:420px;margin:0 auto;}

  /* local support（SP版は背景画像が別＋50%白オーバーレイ） */
  .local{padding:48px 20px;gap:32px;
    background-image:
      linear-gradient(rgba(255,255,255,.5),rgba(255,255,255,.5)),
      url('../assets/images/local-support-bg-sp.webp');
    background-size:cover,cover;
    background-position:center,center;
    background-repeat:no-repeat;}
  .local-cards{flex-direction:column;gap:48px;}
  .local-card{height:auto;}
  .local-card .lc-icon{display:none;}
  /* SP版：地域密着タイトルを縦並び */
  .local-title-row{flex-direction:column;align-items:center;gap:2px;}
  .ltr-a{font-size:26px;} .ltr-b{font-size:34px;}
  .local-subtitle{width:auto;}
  .local-footer-txt{font-size:15px;text-align:center;}
  .pepper-logo{flex-direction:column;gap:10px;text-align:center;}
  .plt-pepper,.plt-cycle{font-size:34px;}
  .pepper-logo-icon,.pepper-logo-icon img{width:80px;height:80px;}

  /* easy booking */
  .easy{padding:48px 20px;}
  .easy-title{font-size:22px;} .easy-desc{width:auto;}
  /* SP版：予約ステップを縦並び（矢印は下向き） */
  .steps-row{flex-direction:column;flex-wrap:nowrap;gap:12px;}
  .step-arrow{transform:rotate(90deg);}
  .booking-image-title{font-size:26px;}
  .booking-image{width:100%;}

  /* reasons */
  .reasons{padding:48px 20px;}
  .reason-card{flex-direction:column;gap:18px;padding:28px 22px;}
  /* SP版は理由カードの背景画像が別（インライン指定を上書き） */
  .reasons-cards .reason-card:nth-of-type(1){background-image:url('../assets/images/reason-card-bg-sp-1.webp')!important;}
  .reasons-cards .reason-card:nth-of-type(2){background-image:url('../assets/images/reason-card-bg-sp-2.webp')!important;}
  .reasons-cards .reason-card:nth-of-type(3){background-image:url('../assets/images/reason-card-bg-sp-3.webp')!important;}
  .reason-card-title{font-size:18px;}
  .reasons .reason-img{width:100%!important;max-width:260px;height:190px!important;margin:0 auto;}
  .reason-img-wrap{width:100%!important;height:auto!important;}
  .reason-img3{position:static!important;left:auto!important;width:100%!important;max-width:240px;height:200px!important;margin:0 auto;}

  /* features */
  .features{padding:48px 16px;}
  .features-title{font-size:23px;}
  .sp-br{display:inline;}
  .feature-grid{grid-template-columns:repeat(2,1fr);gap:14px;}
  /* SP版：最後の1枚（9枚目・奇数で余る）は中央寄せ */
  .feature-grid .feature-card:last-child:nth-child(odd){grid-column:1 / -1;justify-self:center;width:calc(50% - 7px);}
  .features-bar{flex-wrap:wrap;justify-content:center;gap:12px 18px;}
  .fb-spacer{display:none;}
  .features-btn{width:100%;max-width:360px;}

  /* CTA bands */
  .cta-band{padding:36px 20px;}
  .cta-pill{padding:18px 32px;width:100%;max-width:360px;}
  .cta-pill-main{font-size:18px;}
  .cta2-sec{width:100%;max-width:360px;text-align:center;justify-content:center;}

  /* pricing */
  .pricing{padding:48px 20px;}
  .pricing-title{font-size:22px;}
  .pricing-card{width:100%;max-width:480px;padding:32px 24px;}
  .price-num{font-size:40px;}

  /* options */
  .options{padding:44px 16px;}
  .options-inner{width:100%;}
  .options-cards{flex-direction:column;}
  .options-btn{width:100%;max-width:360px;}

  /* guide */
  .guide{padding:44px 16px;}
  .guide-inner{width:100%;}
  .guide-title{font-size:18px;}
  /* SP版：PC版ボックス＋reassureを隠してアイコン縦リストに差し替え */
  .guide-box,.guide-reassure{display:none;}
  .guide-box-sp{display:flex;}

  /* FAQ */
  .faq{padding:48px 16px;gap:28px;}
  .faq-title{font-size:23px;}
  .faq-list{gap:12px;}
  .faq-q{padding:16px 14px;gap:12px;}
  .faq-q-mark,.faq-a-mark{width:26px;height:26px;font-size:14px;border-radius:6px;}
  .faq-q-text{font-size:14px;}
  .faq-a{padding:0 14px 18px;gap:12px;}
  .faq-a p,.faq-a-body p{font-size:13px;line-height:1.75;}

  /* bottom form */
  .bform{padding:44px 16px;}
  .bform-h1{font-size:16px;text-align:center;}
  .bform-h2{text-align:center;}
  .bform-card{width:100%;max-width:480px;padding:28px 22px;}
  .staff-wrap{flex-direction:column;text-align:center;}

  /* phone bar */
  .phone-bar{flex-direction:column;gap:6px;padding:22px 16px;text-align:center;}
  .phone-num{font-size:26px;}

  /* footer */
  .footer{padding:32px 20px;}
  .footer-links{flex-wrap:wrap;gap:12px 18px;}

  /* NEWS */
  .news{padding:56px 16px;}
  .news-title{font-size:26px;}
  /* SP版：トップのニュースカードは横2つ */
  .news-grid{grid-template-columns:repeat(2,1fr);max-width:none;gap:16px 12px;}
  .news-grid .news-card{gap:8px;}
  .news-grid .news-card-title{font-size:13px;line-height:1.55;}
  .news-tag{font-size:10px;padding:2px 10px;}
  /* SP版：一覧の行リストは縦積み（サムネ上→本文下） */
  .news-list .news-card{flex-direction:column;align-items:stretch;gap:12px;padding:18px 16px;}
  .news-list .news-thumb{width:100%;}
  .news-list .news-card-title{font-size:16px;}
  .news-list .news-excerpt{font-size:13px;}
  .news-list-sub{font-size:13px;}
  /* iOS等でのfixed背景の不具合回避 */
  .news-screen{background-attachment:scroll;}
  /* ページネーションをコンパクトに（1行に収める） */
  .pager{gap:5px;flex-wrap:wrap;}
  .pager a,.pager span{min-width:32px;height:34px;padding:0 7px;font-size:12px;gap:2px;}
  .pager svg,.pager i{width:14px;height:14px;}
  .pager-arrow{padding:0 8px;}

  /* 機能詳細ページ（背景はPC版と同じ固定パララックスのまま） */
  .feat-page-header{padding:84px 16px 24px;}
  .feat-page-title{font-size:23px;}
  .feat-page-desc{font-size:13px;}
  /* SP版：機能ナビは3列グリッドで均等・整列 */
  .feat-nav{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;padding:8px 16px 0;width:100%;box-sizing:border-box;}
  .feat-nav a{justify-content:center;text-align:center;padding:10px 4px;font-size:10.5px;line-height:1.3;gap:4px;}
  .feat-nav a i{width:13px;height:13px;}
  /* モバイルでは縦積み＋背景固定を解除（iOSでの崩れ回避） */
  .feat-section{flex-direction:column;gap:22px;padding:36px 16px;min-height:0;}
  /* 全セクションで「テキスト→画像」の順に統一（偶数セクションのDOM順を補正） */
  .feat-section .feat-text{order:1;}
  .feat-section .feat-img{order:2;}
  .feat-num{font-size:24px;}
  .feat-heading{font-size:20px;line-height:1.45;}
  .feat-desc{font-size:13px;}
  .feat-img{min-height:0;aspect-ratio:4/3;align-self:auto;}

  /* 予約ページ */
  .booking{padding:96px 18px 64px;}
  .booking-card{padding:24px 18px;gap:26px;}
  .booking-fields{grid-template-columns:1fr;}
  .time-slots{grid-template-columns:repeat(3,1fr);}
  .booking-title{font-size:24px;}

  /* 記事詳細 */
  .article-screen{padding:84px 14px 56px;}
  .article{padding:32px 22px 40px;}
  .article-title{font-size:23px;}
  .article-body h2{font-size:19px;}
  .article-related .news-grid{grid-template-columns:repeat(2,1fr);}
}

/* ===== 小型スマホ（〜480px） ===== */
@media (max-width:480px){
  .feature-grid{grid-template-columns:repeat(2,1fr);gap:12px;}
  .feature-grid .feature-card:last-child:nth-child(odd){width:calc(50% - 6px);}
  .feature-card{padding:40px 12px 14px;min-height:0;gap:6px;}
  .feature-card .fc-content{flex-direction:column;align-items:center;gap:8px;}
  .feature-card .fc-icon{width:56px;height:56px;border-radius:28px;}
  .feature-card .fc-text{align-items:center;text-align:center;gap:2px;}
  .feature-card .fc-text h3,.feature-card .fc-text h3.fc-title-sm{font-size:13px;}
  .feature-card .fc-text p{font-size:10px;line-height:1.6;}
  .feature-card .fc-arrow{display:none;}
  .feature-card .fc-badge{width:36px;height:36px;border-radius:12px 0 36px 0;font-size:12px;}
  .hero-heading{font-size:20px;}
  .time-slots{grid-template-columns:repeat(2,1fr);}
  .ltr-a{font-size:22px;} .ltr-b{font-size:30px;}
  .news-list-hero{padding-top:84px;}
}
