/* =========================================================
   Variables
   ========================================================= */
:root{
  --point:#AB1F00;
  --point2:#D80002;

  --header-h: 0px;                 /* fixed時の押し下げ量（必要なら実高さに合わせる） */

  --wf-point: var(--point, #AB1F00);

  --ink: #0b1220;
  --muted: rgba(11,18,32,.72);
  --soft: rgba(11,18,32,.06);
  --card: #ffffff;

  --radius: 16px;
  --shadow: 0 18px 50px rgba(0,0,0,.10);

  /* pricing用（あなたの後半定義を正式に変数化） */
  --max: 1300px;
  --line: rgba(11,18,32,.12);
  --brand:#b58a3a;
  --brand2:#d6b26a;
  --bg:#ffffff;

  /* 波の色（下のセクション背景色） */
  --wave-fill:#ffffff;
}

/* =========================================================
   Utilities
   ========================================================= */
.point_color{ color: var(--point2); }

/* PCでは改行しない（brを消す） */
.br-sp{ display:none; }
/* スマホだけ改行する（brを出す） */
@media (max-width:566px){
  .br-sp{ display:inline; }
}

/* =========================================================
   Base
   ========================================================= */
*,*::before,*::after{ box-sizing:border-box; }

html,body{
  margin:0;
  padding:0;
  width:100%;
  overflow-x:hidden;
  font-family:"Hiragino Sans","Hiragino Kaku Gothic ProN",Meiryo,sans-serif;
  color:#333;
}

img,video{ max-width:100%; height:auto; }
a{ color:inherit; text-decoration:none; }

#main{
  margin: 0;
  padding: 0;
  max-width: 100%;
  height: auto;
}

/* =========================================================
   Section background (wappa-a + wave)
   ========================================================= */
.wappa-a{
  margin: 0;
  padding: 0;
  background-color: #FFEFAA;
  position: relative;
  overflow: hidden;
  padding-bottom: 30px; /* 波の高さ分 */
}

/* wave */
.wave-divider{
  position: absolute;
  left: 0;
  right: 0;
  bottom: 0;
  width: 100%;
  height: 30px;
  line-height: 0;
  pointer-events: none;
}
.wave-divider svg{
  display:block;
  width:100%;
  height:100%;
}

/* wide */
@media (min-width: 900px){
  .wappa-a{ padding-bottom: 70px; }
  .wave-divider{ height: 70px; }
}

/* mobile: 波を非表示 + 余白戻す */
@media (max-width: 600px){
  .wave-divider{ display:none; }
  .wappa-a{ padding-bottom:0; }
}

/* =========================================================
   Header / Nav (2段)
   ========================================================= */
.header{
  padding:0;
  margin:0;

  /* デフォルト：固定しない */
  position: static;
  top:auto; left:auto; right:auto;
  z-index:auto;
  box-shadow:none;
  border-bottom:0;
}

/* 2段の器 */
.header__inner{
  display:flex;
  flex-direction:column;
  gap:0;
  background:#FDD10D;
  margin:0;
  padding:0;
}

/* 各段 */
.header__row{
  display:flex;
  align-items:center;
  gap:12px;
  padding:6px 0;
}


/* 1段目：brand */
.header__row--top{
  justify-content:flex-start;
  background:#FFFFFF;
}

/* 2段目：nav/actions */
.header__row--bottom{
  justify-content:space-between;
  border-top:1px solid rgba(0,0,0,.08);
}

/* --- Brand（ロゴ＋2行） 正式HTML版 --- */
.brand{ flex:0 0 auto; }

.brand__title{
  margin:0 0 0 1rem;
  font-size: 1.3rem;   /* 見た目の基準 */
  font-weight: 700;
  line-height: 1.1;
}

.brand__link{
  display:flex;
  align-items:center;
  gap:10px;
  color:inherit;
  text-decoration:none;
}

.brand__logo{
  display:block;
  width:34px;
  height:34px;
}

.brand__text{
  display:flex;
  flex-direction:column;
  justify-content:center;
  align-items:flex-start;
  line-height:1.1;
}

.brand__kicker{
  display:block;
  margin:0 0 2px;
  font-size:.7rem;
  font-weight:400;
  line-height:1.1;
}

.brand__name{
    display: block;
    font-size: 1.35rem;
    font-weight: bold;
    line-height: 1;
    font-family: "Comic Sans MS", cursive;
    font-style: normal;
    font-variant: normal;
}
.brand__name span{
    color: #E78F00;
    font-style: italic;
    letter-spacing: 0.06em;  /* 0.06文字分だけ広げる */
    font-family: "Hiragino Sans", "Hiragino Kaku Gothic ProN", Meiryo, sans-serif;
}
/* gnav */
.gnav{
  display:flex;
  gap:12px;
  align-items:center;
  white-space:nowrap;
  margin-left:auto;
  margin-right:auto;
}
.gnav a{
  display:block;
  background:#fff;
  border-radius:8px;
  padding:.5rem 1rem .4rem;
  font-size:1rem;
  text-align:center;
}

/* actions */
.actions{
  display:flex;
  align-items:center;
  gap:10px;
  white-space:nowrap;
  margin-right:1rem;
}
.action-link{
  font-weight:700;
  padding:8px 6px;
  font-size:1rem;
}
.action-link2{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  padding:.5rem 1rem .4rem;
  border-radius:8px;
  background:var(--point);
  color:#fff;
  font-weight:700;
  font-size:1rem;
}

/* =========================================================
   Hamburger (details)
   ========================================================= */
.menu{ display:none; margin-right:1rem; }
.menu__details{ position:relative; }

.menu__button{
  list-style:none;
  cursor:pointer;
  display:flex;
  align-items:center;
  gap:10px;
  padding:10px 12px;
  border-radius:10px;
  background:#fff;
  border:1px solid #ddd;
  font-weight:700;
  user-select:none;
}
.menu__button::-webkit-details-marker{ display:none; }
.menu__label{ font-size:12px; letter-spacing:.06em; color:#333; }

/* icon */
.menu__icon{ width:22px; height:14px; position:relative; display:inline-block; }
.menu__icon::before,
.menu__icon::after{
  content:"";
  position:absolute;
  left:0; right:0;
  height:2px;
  background:#333;
  border-radius:999px;
  transition: transform .15s ease, top .15s ease, bottom .15s ease, box-shadow .15s ease;
}
.menu__icon::before{ top:0; box-shadow:0 6px 0 #333; }
.menu__icon::after{ bottom:0; }
.menu__details[open] .menu__icon::before{ top:6px; box-shadow:none; transform:rotate(45deg); }
.menu__details[open] .menu__icon::after{ bottom:6px; transform:rotate(-45deg); }

/* panel */
.menu__panel{
  position:absolute;
  right:0;
  top: calc(100% + 10px);
  width: min(420px, calc(100vw - 24px));
  background-color:#FDD10D;
  border-bottom-left-radius:14px;
  border-bottom-right-radius:14px;
  box-shadow:0 18px 40px rgba(0,0,0,.18);
  padding:12px 12px 1.5rem;
  z-index:9999;
  margin-top:-5px;
}

.menu__group{
  padding:10px;
  border-radius:12px;
  background:#fafafa;
  border:1px solid #eee;
}
.menu__group + .menu__group{ margin-top:10px; }

.menu__title{
  margin:0 0 8px;
  font-size:12px;
  font-weight:700;
  color:#666;
  letter-spacing:.04em;
}

.menu__panel a{
  display:block;
  padding:10px;
  border-radius:10px;
  font-weight:700;
}
.menu__panel a:not(.menu__btn):hover{ background:#DFDFDF; }

/* menu CTA */
.menu__cta{
  display:grid;
  grid-template-columns:1fr;
  gap:10px;
  margin-top:10px;
}
.menu__btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  padding:12px;
  border-radius:12px;
  font-weight:700;
  border:1px solid transparent;
}
.menu__panel .menu__btn.menu__btn--apply{
  background:var(--point);
  color:#fff;
  text-align:center;
}
.menu__panel .menu__btn.menu__btn--apply:hover{
  background:#FDD10D;
  color:#333;
}
.menu__btn--apply:active{ transform:translateY(1px); }

/* =========================================================
   <=820px：gnav/actions非表示＋CTA外出し＋hamburger
   ========================================================= */
.cta-mobile{ display:none; }
@media (max-width:820px){
  .gnav, .actions{ display:none !important; }
  .header__row--bottom{ justify-content:flex-end; }

  .cta-mobile{
    display:inline-flex;
    align-items:center;
    justify-content:center;
    padding:10px 14px;
    border-radius:10px;
    background:var(--point);
    color:#fff;
    font-weight:700;
    white-space:nowrap;
    line-height:1;
    margin-right:8px;
  }
  .cta-mobile:hover{ opacity:.92; }

  .menu{ display:block; margin-right:1rem; }
}

/* =========================================================
   Header fixed (>=600px fixed / <600px non-fixed)
   ========================================================= */
@media (min-width:600px){
  .header{
    position:fixed;
    top:0; left:0; right:0;
    z-index:9999;
    background:#FDD10D;
    box-shadow:0 8px 18px rgba(0,0,0,.18);
    border-bottom:1px solid rgba(0,0,0,.08);
  }

  body{ padding-top:0; }
  #main{ padding-top:80px; } /* ←実高さに合わせて調整 */
}

@media (max-width:599px){
  #main{ padding-top:0; }
}

/* =========================================================
   Footer
   ========================================================= */
.footer{
  color:#e6e9ee;
  padding:60px 20px;
  background-image: linear-gradient(180deg, rgba(96,66,0,1) 0%, rgba(41,29,5,1) 100%);
}

.footer__inner{
  max-width:1200px;
  margin:0 auto;
  text-align:center;
}

.footer__lead{
  font-size:1.2rem;
  font-weight:600;
  margin-bottom:40px;
  letter-spacing:.05em;
}

.footer__nav{
  display:grid;
  grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
  gap:16px;
  margin-bottom:40px;
}

.footer__nav a{
  display:block;
  padding:14px 12px;
  border:1px solid rgba(255,255,255,.08);
  border-radius:6px;
  color:#fff;
  font-size:.95rem;
  transition: background .2s ease, transform .2s ease;
  background-image: linear-gradient(180deg, rgba(140,100,11,1) 0%, rgba(96,66,0,1) 100%);
}

.footer__nav a:hover{
  background: rgba(255,255,255,.15);
  transform: translateY(-2px);
}

.footer__line{
  width:100%;
  height:1px;
  background: linear-gradient(to right, transparent, rgba(255,255,255,.3), transparent);
  margin:40px 0;
}

.footer__company h2{
  font-size:1.4rem;
  margin-bottom:12px;
}
.footer__company h2 a{ color:#fff; }

.footer__company p{
  font-size:.95rem;
  line-height:1.8;
  margin:4px 0;
}

.footer__time{
  margin-top:10px;
  font-size:.85rem;
  color:#c9ced6;
}

@media (max-width:640px){
  .footer{ padding:40px 16px; }
  .footer__lead{ font-size:1rem; margin-bottom:30px; }
  .footer__nav{ gap:12px; }
}

/* =========================================================
   Video / Hero
   ========================================================= */
.hero__media{
  width:100%;
  margin-left:auto;
  margin-right:auto;
  padding:0;
}

.video-card{ position:relative; }

/*---------------------------------------------
無料貸出サービスのバナー（クリック可能ボタン）
-----------------------------------------------*/
.video-card__label{
    position: absolute;
    right: 4rem;
    padding-top: 8px;
    padding-right: 1.5rem;
    padding-left: 1.5rem;
    padding-bottom: 8px;
    border-radius: 999px;
    font-weight: normal;
    font-size: .9rem;
    color: #5A5A5A;
    z-index: 2;
    background: #fff;
    font-family: "Hiragino Sans", "Hiragino Kaku Gothic ProN", Meiryo, sans-serif;
    font-style: normal;
    font-variant: normal;
    line-height: 1.5;
    text-align: center;
    bottom: 150px;

    /* ★浮き上がるドロップシャドウ（多重影） */
    box-shadow:
      0 2px 6px rgba(0,0,0,.10),
      0 12px 28px rgba(0,0,0,.16),
      0 24px 60px rgba(0,0,0,.12);

    border: 1px solid rgba(0,0,0,.06);

    /* ★ボタン化（追加） */
    display: inline-flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    text-decoration: none;     /* aの下線を消す */
    cursor: pointer;
    user-select: none;
    -webkit-tap-highlight-color: transparent;

    transition: transform .15s ease, box-shadow .15s ease, filter .15s ease;
	opacity: 0.7;
}

/* ラベル内の文字 */
.video-card__label p{
    color: #D70003;
    font-family: "Hiragino Sans", "Hiragino Kaku Gothic ProN", Meiryo, sans-serif;
    font-style: normal;
    font-variant: normal;
    font-weight: bold;
    font-size: 1.2rem;
    margin: 0;
    padding: 0;
    letter-spacing: 0.08em;
    line-height: 1;
}

/* hover / focus（PC & キーボード操作） */
.video-card__label:hover,
.video-card__label:focus-visible{
    filter: brightness(0.98);
    transform: translateY(-2px);
    box-shadow:
      0 4px 10px rgba(0,0,0,.12),
      0 18px 38px rgba(0,0,0,.18),
      0 28px 70px rgba(0,0,0,.14);
    outline: none;
	opacity: 1;
}

/* 押したとき（クリック感） */
.video-card__label:active{
    transform: translateY(0);
    box-shadow:
      0 2px 6px rgba(0,0,0,.10),
      0 10px 22px rgba(0,0,0,.14),
      0 18px 44px rgba(0,0,0,.10);
}

/* PC/タブレットも高さ100svhで迫力優先（object-fit:cover） */
.video-wrap{
  position:relative;
  width:100%;
  height: calc(100svh - var(--header-h, 0px));
  max-height: calc(100svh - var(--header-h, 0px));
  overflow:hidden;
  border-radius:0;
  background:#000;
}

.video-wrap .vid_main{
  width:100%;
  height:100%;
  display:block;
  object-fit:cover;
  object-position:center;
}

/* スマホでの縦動画調整 */
@media (max-width:767px){
  .video-wrap{
    height: calc(100svh - var(--header-h, 0px));
    width: 100%;
  }
  .video-wrap .vid_main{
    min-width:auto;
    min-height:100%;
    height:100%;
    width:auto;
  }
}

/* =========================================================
   Sections / Grid / Cards
   ========================================================= */
.sec{
  padding:28px 0;
  margin-top:3rem;
  margin-bottom:6rem;
}
.sec__head{
  margin-bottom:14px;
  padding:0;
  max-width:1300px;
  margin-left:auto;
  margin-right:auto;
}
.sec__head img{
  max-width:150px;
  display:block;
  margin-left:auto;
  margin-right:auto;
}

@media (max-width:566px){
  .sec__head{ max-width:94%; }
}

.sec__title{
  margin: .5rem 0 5rem;
  font-size: clamp(32px, 2.2vw, 3rem);
  font-weight:bold;
  font-family:"Hiragino Sans","Hiragino Kaku Gothic ProN",Meiryo,sans-serif;
  text-align:center;
  color:#333;
}
@media (max-width:566px){
  .sec__title{ margin-bottom:3rem; }
}

.sec__lead{
  font-size:1rem;
  margin-bottom:2rem;
  color:var(--muted);
  line-height:1.95;
}

.grid{
  display:grid;
  gap:12px;
  max-width:1300px;
  margin-left:auto;
  margin-right:auto;
}
@media (max-width:566px){
  .grid{ max-width:94%; }
}

.grid--3{ grid-template-columns:repeat(3,1fr); }
.grid--2{ grid-template-columns:repeat(2,1fr); }

.card,.feature,.note{
  border:1px solid #e7e7e7;
  border-radius:12px;
  background:#fff;
  padding:14px;
  box-shadow: var(--shadow);
}

.feature{ padding:1.2rem; }
.feature img{
  border-radius:12px;
  margin-bottom:.7rem;
  display:block;
  margin-left:auto;
  margin-right:auto;
}
.card img{
  max-width:150px;
  display:block;
  margin-left:auto;
  margin-right:auto;
}

.card__title,.feature__title,.note__title{
    margin: 0 0 8px;
    font-size: 1.2rem;
    font-weight: bold;
    text-align: center;
    color: #333;
    font-family: "Hiragino Sans", "Hiragino Kaku Gothic ProN", Meiryo, sans-serif;
    font-style: normal;
    font-variant: normal;
}
.card__title{
    border-bottom: 1px dotted #CCCCCC;
    margin-bottom: 1rem;
    padding-bottom: 0.6rem;
}


.feature__title{
    font-size: 1.3rem;
    color: var(--point);
    font-weight: normal;
}

.card__text,.feature__text,.note__text{
  margin:0;
  color:#555;
  line-height: normal;
  font-size:.95rem;
}
.card_nolist{
    margin: 0;
    padding-left: 2rem;
    padding-right: 1rem;
}
.card_nolist li{
    margin-bottom: 1rem;
}
.card__note{
    padding-left: 0.9rem;
    padding-right: 0.9rem;
    line-height: normal;
    padding-top: 0;
    margin: 0;
    padding-bottom: 0;
}
.card__text img{
    max-width: 250px;
    height: auto;
    display: block;
    margin-right: auto;
    margin-left: auto;
    margin-bottom: 1rem;
}
.card__text a,
.card_nolist a,
.card__note a{
  text-decoration: underline;
  text-underline-offset: .15em; /* 見た目が少し良くなる（任意） */
}
.card--cta{ border-color:#f0d36a; background:#fffdf2; }

.btns{
  display:flex;
  gap:10px;
  flex-wrap:wrap;
  margin-top:10px;
  justify-content:center;
}

.sec__cta{
  display:flex;
  gap:10px;
  flex-wrap:wrap;
  margin-top:14px;
}

.btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  padding:10px 14px;
  border-radius:10px;
  border:1px solid #ddd;
  font-weight:900;
}
.btn--primary{ background:var(--point); color:#fff; border-color:transparent; }
.btn--ghost{ background:#fff; }

.steps{
  margin:0;
  padding:0;
  list-style:none;
  display:grid;
  gap:10px;
}
.step{
  border:1px solid #e7e7e7;
  border-radius:12px;
  background:#fff;
  padding:14px;
}
.step__title{ margin:0 0 6px; font-size:16px; font-weight:900; }
.step__text{ margin:0; color:#555; line-height:1.8; }

@media (max-width:1000px){
  .grid--3{ grid-template-columns:repeat(2,1fr); }
}
@media (max-width:640px){
  .grid--3,.grid--2{ grid-template-columns:1fr; }
}

/* =========================================================
   Workflow (6 steps)
   ========================================================= */
.wf{
  padding: clamp(36px, 4.5vw, 72px) 0;
  background:
    linear-gradient(135deg, rgba(253,209,13,.16), transparent 40%),
    linear-gradient(315deg, rgba(171,31,0,.10), transparent 35%);
}

.wf__inner{
  max-width:1300px;
  margin-left:auto;
  margin-right:auto;
  padding:0 16px;
  margin-bottom:5rem;
}

.wf__head{
  text-align:center;
  max-width:1300px;
  margin:0 auto 22px;
}

.wf__kicker{
  margin:0 0 8px;
  display:flex;
  justify-content:center;
  align-items:center;
  gap:10px;
  font-weight:900;
  letter-spacing:.12em;
  font-size:1rem;
  color:var(--wf-point);
  text-align:center;
  width:100%;
}
.wf__kicker::before,
.wf__kicker::after{
  content:"";
  width:18px;
  height:2px;
  background:var(--wf-point);
  opacity:.55;
  border-radius:999px;
}

.wf__title{
  margin:.5rem 0 5rem;
  font-size: clamp(32px, 2.2vw, 3rem);
  font-weight:900;
  color:var(--ink);
  letter-spacing:.02em;
}
@media (max-width:566px){
  .wf__title{ margin-bottom:3rem; }
}

.wf__lead{
  margin:0 auto;
  color:var(--muted);
  line-height:1.95;
  font-size:1rem;
  text-align:left;
}

/* rail */
.wf__rail{
  list-style:none;
  margin:0;
  padding:0;

  display:grid;
  grid-template-columns: repeat(6, minmax(0, 1fr));
  gap:10px;
  position:relative;
}

/* rail line */
.wf__rail::before{
  content:"";
  position:absolute;
  left:8px;
  right:8px;
  top:30px;
  height:2px;
  background: linear-gradient(90deg,
    rgba(171,31,0,.20),
    rgba(171,31,0,.40),
    rgba(171,31,0,.85)
  );
  border-radius:999px;
  opacity:.9;
}

/* card */
.wf-card{
  position:relative;
  border-radius: var(--radius);
  overflow:visible;
  background: var(--card);
  border:1px solid var(--soft);
  box-shadow: var(--shadow);
}
.wf-card::before,
.wf-card::after{
  content:none !important;
  display:none !important;
}

.wf-card__top{
  display:flex;
  align-items:center;
  justify-content:flex-start;
  gap:10px;
  padding:10px 10px 0;
}

.wf-card__no{
  width:44px;
  height:44px;
  border-radius:999px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  background:var(--wf-point);
  color:#fff;
  font-weight:900;
  font-size:12px;
  letter-spacing:.12em;
  box-shadow:0 14px 30px rgba(171,31,0,.18);
}

.wf-card__phase{
  font-size:1rem;
  font-weight:900;
  letter-spacing:.10em;
  color:#333;
  white-space:nowrap;
}

.wf-card__media{
  margin:10px 10px 0;
  border-radius:12px;
  overflow:hidden;
  background:#0b1220;
  border:1px solid #ccc;
  aspect-ratio: 1 / 1;
}
.wf-card__media img{
  width:100%;
  height:100%;
  display:block;
  object-fit:cover;
}

.wf-card__title{
  margin:1rem 10px 6px;
  font-size:.95rem;
  font-weight:bold;
  color:var(--ink);
  line-height:1.35;
}

.wf-card__text{
  margin:0 10px 1rem;
  font-size:.86rem;
  color:var(--muted);
  line-height:1.85;
}

@media (hover:hover){
  .wf-card{ transition: transform .18s ease, box-shadow .18s ease; }
  .wf-card:hover{
    transform: translateY(-2px);
    box-shadow: 0 26px 80px rgba(0,0,0,.14);
  }
}

/* Tablet: 3x2 rail off */
@media (max-width:1100px){
  .wf__rail{
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap:12px;
  }
  .wf__rail::before{ display:none; }

  .wf-card__title{ font-size:1rem; }
  .wf-card__text{ font-size:.95rem; }
}

/* Mobile: 1 column */
@media (max-width:566px){
  .wf__rail{
    grid-template-columns:1fr;
    gap:12px;
    padding-left:18px;
  }
  .wf__rail::before{ display:none !important; }
  .wf-card__no{ margin-left:-24px; }
  .wf-card__title{ font-size:1.02rem; }
  .wf-card__text{ font-size:.95rem; }
}

/* =========================================================
   Pricing
   ========================================================= */
.pricing{
  padding: clamp(36px, 4.5vw, 72px) 0;
  background:
    radial-gradient(900px 500px at 20% 0%, rgba(214,178,106,.20), transparent 55%),
    radial-gradient(900px 500px at 80% 10%, rgba(181,138,58,.14), transparent 55%),
    #fff;
}

.pricing__inner{
  max-width:1300px;
  margin:0 auto;
  padding:0 16px;
}

.pricing__head{
  text-align:center;
  max-width:1300px;
  margin:0 auto 22px;
}

.pricing__kicker{
  margin:0 0 8px;
  display:inline-flex;
  align-items:center;
  gap:10px;
  font-weight:900;
  letter-spacing:.12em;
  font-size:12px;
  color:var(--brand);
}
.pricing__kicker::before,
.pricing__kicker::after{
  content:"";
  width:18px;
  height:2px;
  background:var(--brand);
  opacity:.55;
  border-radius:999px;
}

.pricing__title{
  margin:0 0 10px;
  font-size: clamp(20px, 2.2vw, 34px);
  font-weight:900;
  color:var(--ink);
  letter-spacing:.02em;
}

.pricing__lead{
  margin:0 auto;
  max-width:75ch;
  color:var(--muted);
  line-height:1.95;
  font-size:1rem;
}

/* equation cards */
.pricing-eq{
  margin-top:24px;
  /*display:grid;
  grid-template-columns: 1fr auto 1fr;
  gap:14px;
  align-items:stretch;
	*/
}

.price-card{
  background:var(--card);
  border:1px solid var(--soft);
  border-radius:var(--radius);
  box-shadow:var(--shadow);
  padding:2rem;
}

.price-card__label{
  font-weight:bold;
  color:#A1742F;
  display:inline-block;
  padding:10px 14px 8px;
  border-top-right-radius:12px;
  border-top-left-radius:12px;
  letter-spacing:.06em;
  font-size:1.5rem;
  width:100%;
  text-align:center;
  border-bottom:1px solid #A1742F;
}

.price-card__price{
  margin-top:14px;
  display:flex;
  align-items:baseline;
  gap:8px;
  justify-content:center;
}

.price-card__yen{
  font-size:16px;
  color:var(--ink);
  font-weight:900;
}

.price-card__num{
  font-size:5rem;
  font-weight:900;
  color:#C70003;
  line-height:1;
}
.price-card__num2{
    font-size: 4rem;
    font-weight: bold;
    color: #C70003;
    line-height: 1;
    font-family: "Hiragino Sans", "Hiragino Kaku Gothic ProN", Meiryo, sans-serif;
    font-style: normal;
    font-variant: normal;
}

.price-card__num span{
  font-size:1rem;
  font-weight:normal;
  color:var(--ink);
}

.price-card__tax{ font-size:14px; color:var(--muted); font-weight:700; }

.price-card__note{
  margin:10px 0 0;
  text-align:center;
  color:var(--muted);
  font-size:.9rem;
}

.price-card__desc{
  margin:14px 0 0;
  color:var(--muted);
  line-height:1.9;
}

.price-card__pill{
  margin-top:14px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  padding:10px 12px;
  border-radius:12px;
  background: rgba(214,178,106,.22);
  border: 1px solid rgba(181,138,58,.18);
  font-weight:900;
  color:var(--ink);
  font-size:1rem;
  text-align:center;
  width:100%;
}

.pricing-eq__plus{
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 60px;
    font-weight: 900;
    color: #A1742F;
    user-select: none;
    margin-top: 1.5rem;
}

/* pricing table */
.pricing-table{
  margin-top:24px;
  background:var(--card);
  border:1px solid var(--soft);
  border-radius:var(--radius);
  box-shadow:var(--shadow);
  overflow:hidden;
}

.pricing-table__head{
  padding:16px;
  border-bottom:1px solid var(--soft);
  display:flex;
  flex-wrap:wrap;
  gap:10px;
  align-items:baseline;
  justify-content:center;
}

.pricing-table__title{
  margin:0;
  font-size:1.5rem;
  font-weight:900;
  color:var(--ink);
}

.pricing-table__title span{
  color:var(--muted);
  font-weight:normal;
  font-size:.75rem;
  display:block;
}

.tbl{
  width:100%;
  border-collapse:collapse;
  table-layout:fixed;
}

.tbl thead th{
  background: rgba(181,138,58,.18);
  color:var(--ink);
  font-weight:900;
  padding:14px 12px;
  border-bottom:1px solid var(--soft);
  text-align:center;
}

.tbl tbody td{
  padding:14px 12px;
  border-bottom:1px solid var(--soft);
  vertical-align:top;
  text-align:center;
}

.tbl tbody tr:nth-child(even){ background: rgba(0,0,0,.02); }
.tbl tbody td:nth-child(1){ font-weight:900; }
.tbl strong{ font-weight:900; }

.tbl .price_txt{
  color:#B40003;
  font-size:1.2rem;
  font-weight:bold;
  display:inline;
}
.tbl .price_txt span{
  font-size:1rem;
  font-weight:normal;
}

/* pricing foot */
.pricing-foot{ margin-top:18px; }

.pricing-foot__box{
  background: rgba(255,255,255,.8);
  border:1px solid var(--soft);
  border-radius:var(--radius);
  box-shadow:var(--shadow);
  padding:16px;
}
.pricing-foot__title{ margin:0 0 10px; font-weight:900; color:var(--ink); }
.pricing-foot__list{
  margin:0;
  padding-left:2rem;
  color:var(--muted);
  line-height:1.9;
}
.pricing-foot__note{
  margin:10px 0 0;
  color:var(--muted);
  font-size:13px;
}

.price_txt2{
  color:#B40003;
  font-weight:bold;
  display:inline;
}
.price_txt2 span{
    font-size: 0.8rem;
    color: var(--muted);
    font-weight: normal;
    font-variant: normal;
    font-style: normal;
    font-family: "Hiragino Sans", "Hiragino Kaku Gothic ProN", Meiryo, sans-serif;
}

/* pricing responsive */
@media (max-width:980px){
  .pricing-eq{ grid-template-columns:1fr; }
  .pricing-eq__plus{ font-size:40px; padding:6px 0; }
  .price-card__price{ /*justify-content:flex-start; */}
}

@media (max-width:680px){
  .price-card__num{
    font-size: 3rem;
	}
  .price-card__num2{
    font-size: 2rem;
	}
  .price-card__price{
    justify-content:center !important;
    text-align:center;
    width:100%;
  }
  .price-card__num{
    display:inline-flex;
    align-items:baseline;
  }

  .tbl thead{ display:none; }
  .tbl, .tbl tbody, .tbl tr, .tbl td{ display:block; width:100%; }
  .tbl tr{
    padding-top: 0.7rem;
    padding-right: 1rem;
    padding-left: 1rem;
    padding-bottom: 1rem;
    border-bottom: 1px dashed #ccc;
    background: #fff;
    margin-bottom: 1rem;
    width: 90%;
    margin-right: auto;
    margin-left: auto;
  }
  .tbl tbody tr:nth-child(even){ background:#fff; }
  .tbl td{
    border: 0;
    padding: 0 !important;
    margin-bottom: 0;
    border: 0px !important;
    width:100%;
	text-align: left !important;
  }
  .tbl td::before{
    content: attr(data-label);
    display: inline-block;
    min-width: 5rem;
    font-weight: normal;
    color: #965800;
    padding: 0;
    margin-right: 10px;
  }
  .tbl td:nth-child(1){
    padding-top:0;
    font-size:16px;
  }
	.tbl .sp{
    margin: 0;
    padding: 0;
    display: none;
	}
}

/* =========================================
   9:16縦動画：566px前後は黒帯を最小化
   （枠も9:16にして contain で欠けない）
   ========================================= */
@media (max-width: 566px){
  .video-wrap{
    height: auto !important;
    aspect-ratio: 9 / 16;
    max-height: calc(100svh - var(--header-h, 0px));
    background:#000;
  }

  .video-wrap .vid_main{
    width: 100% !important;
    height: 100% !important;
    object-fit: contain !important;
    object-position: center !important;
    min-width: 0 !important;
    min-height: 0 !important;
  }
	
 /*---------------------------------------------
  無料貸出サービスのバナー
  -----------------------------------------------*/
  .video-card__label{
    right: auto;
    left: 50%;
    transform: translateX(-50%);
    width: max-content;
    white-space: nowrap;
    top: auto;
    bottom: 40px;
    font-size: 0.75rem !important;
  }
  .video-card__label p{
    font-size: 1rem !important;
  }

  /* スマホでも押した感 */
  .video-card__label:active{
    transform: translateX(-50%) scale(0.99);
  }
  .video-card__label:hover,
  .video-card__label:focus-visible{
    transform: translateX(-50%) translateY(-2px) !important; /* ★Xも維持 */
  }

  .video-card__label:active{
    transform: translateX(-50%) scale(0.99) !important;      /* ★Xも維持 */
  }
}

/* iPhone(iOS Safari)だけ：黒帯ゼロにする（=coverで埋める） */
@supports (-webkit-touch-callout: none){
  @media (max-width: 600px){
    .video-wrap{
      height: calc(100dvh - var(--header-h, 0px));
      max-height: calc(100dvh - var(--header-h, 0px));
      background: #000;
    }
    .video-wrap .vid_main{
      width: 100% !important;
      height: 100% !important;
      object-fit: cover !important;
      object-position: center !important;
      min-width: 0 !important;
      min-height: 0 !important;
    }
  }
}

/* =========================================================
   ★Wave Fix Override（必ず一番最後）
   他CSSがsvg/pathを後から上書きしても、ここで勝つ
   ========================================================= */
.wappa-a > .wave-divider{
  z-index: 10;
  isolation: isolate;                 /* blend対策 */
}

.wappa-a > .wave-divider,
.wappa-a > .wave-divider *{
  mix-blend-mode: normal !important;  /* 合成で黄ばむ対策 */
  filter: none !important;            /* sepia等対策 */
  opacity: 1 !important;              /* 透過で黄ばむ対策 */
}

.wappa-a > .wave-divider svg{
  color: var(--wave-fill) !important; /* currentColor対策 */
}

.wappa-a > .wave-divider svg path{
  fill: var(--wave-fill) !important;  /* 最終強制：必ず白 */
}
/* =========================================================
   波を「動画の上」に描写する Fix（完全版）
   黄色(#FFEFAA)が見える問題を根本解決
   ========================================================= */

/* 波の高さを変数化（PCで大きく） */
:root{
  --wave-h: 30px;
}
@media (min-width: 900px){
  :root{ --wave-h: 70px; }
}

/* セクション背景 */
.wappa-a{
  margin: 0;
  padding: 0;
  background-color: #FFEFAA;
  position: relative;
  overflow: hidden;

  /* 波の高さ分の領域を確保（下セクションに食い込まないため） */
  padding-bottom: var(--wave-h);
}

/* ★ここが本命：確保した領域に「動画」を食い込ませる
   → 波の透明部分の下が #FFEFAA ではなく「動画」になる */
.wappa-a .hero__media{
  position: relative;
  z-index: 1;

  /* 波の高さぶん下へ伸ばす（透明部分が黄色を拾わない） */
  margin-bottom: calc(-1 * var(--wave-h));
}

/* 波本体（動画の上に重ねる） */
.wave-divider{
  position: absolute;
  left: 0;
  right: 0;
  bottom: 0;

  width: 100%;
  height: var(--wave-h);
  line-height: 0;

  pointer-events: none;
  z-index: 2; /* 動画より上 */
}

.wave-divider svg{
  display: block;
  width: 100%;
  height: 100%;
}

/* 波は必ず白 */
.wave-divider path{
  fill: #ffffff !important;
}

/* モバイルでは波を非表示（元の仕様を維持） */
@media (max-width: 600px){
  .wave-divider{ display: none; }
  .wappa-a{ padding-bottom: 0; }
  .wappa-a .hero__media{ margin-bottom: 0; }
}

/* =========================================================
   FAQ (details accordion)
   ========================================================= */
.wf--faq .wf__lead{
  max-width: 1300px;
  margin-left: auto;
  margin-right: auto;
}

.faq{
  max-width: 1300px;
  margin: 0 auto;
}

.faq__item{
  background: var(--card);
  border: 1px solid var(--soft);
  border-radius: var(--radius);
  box-shadow: var(--shadow);
  overflow: hidden;
}

.faq__item + .faq__item{
  margin-top: 12px;
}

/* summary */
.faq__q{
    list-style: none;
    cursor: pointer;
    padding: 16px 18px;
    display: flex;
    align-items: flex-start;
    gap: 12px;
    font-weight: 900;
    color: var(--ink);
    line-height: 1.3;
    user-select: none;
    /* ★高さの中央揃え */
    align-items: center;
    font-family: "Hiragino Sans", "Hiragino Kaku Gothic ProN", Meiryo, sans-serif;
    font-style: normal;
    font-variant: normal;
    font-size: 1.2rem;
}
.faq__q::-webkit-details-marker{ display: none; }

/* Qバッジ */
.faq__q::before{
  content: "Q";
  flex: 0 0 auto;
  width: 28px;
  height: 28px;
  border-radius: 999px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background: rgba(171,31,0,.10);
  border: 1px solid rgba(171,31,0,.18);
  color: var(--point);
  font-weight: 900;
  font-size: 12px;
  margin-top: 2px;
}

/* 開閉アイコン */
.faq__q::after{
  content: "+";
  margin-left: auto;
  flex: 0 0 auto;
  width: 34px;
  height: 34px;
  border-radius: 999px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background: rgba(0,0,0,.04);
  border: 1px solid var(--soft);
  color: #A1742F;
  font-size: 20px;
  line-height: 1;
}

.faq__item[open] .faq__q::after{
  content: "–";
}

/* answer */
.faq__a{
  padding: 0 18px 16px;
  border-top: 1px solid var(--soft);
  color: var(--muted);
  line-height: 1.9;
}

.faq__a p{
  margin: 12px 0 0;
}

.faq__a ul{
  margin: 10px 0 0;
  padding-left: 1.2em;
}

.faq__a li{
  margin: 6px 0;
}

.faq__a strong{
  color: var(--ink);
}

.faq__a a{
  text-decoration: underline;
}
.faq__a p img{
    display: block;
    margin-bottom: 1rem;
    margin-top: 1rem;
}


@media (max-width: 640px){
  .faq__q{ padding: 14px 14px; }
  .faq__a{ padding: 0 14px 14px; }
  .faq__q::after{ width: 30px; height: 30px; }
}

/* =========================================================
   TABX：ラジオ式タブ（CSSのみ）
   - 親フレーム内で最大表示（幅100%）
   - タブは横並び2列（各50%）※gapで余白
   - スマホは1列
========================================================= */

/* 親フレーム内で最大表示 */
.tabx{
  width: 100%;
  max-width: 1300px;        /* ← 1300px制限を解除して親幅いっぱい */
  margin-left: auto;
  margin-right: auto;

  /* タブ（label）を2列(50%/50%)で確実に横並びにする */
  display: grid;
  grid-template-columns: 1fr 1fr;  /* 50% + 50% */
  gap: 10px;                       /* 余白はgapで管理 */
  align-items: start;
}

/* radioは画面外へ（アクセシブルに残す） */
.tabx__input{
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0 0 0 0);
  white-space: nowrap;
  border: 0;
}

/* タブ見た目（Gridセル内で100%に伸ばす） */
.tabx__tab{
  display: flex;                 /* ← inline-flexをやめて崩れ防止 */
  align-items: center;
  justify-content: center;

  padding: 12px 18px;
  border-radius: 0;
  font-weight: 900;

  border: 1px solid var(--soft);
  background: #fff;
  color: var(--ink);
  cursor: pointer;
  user-select: none;

  box-shadow: 0 10px 26px rgba(0,0,0,.06);

  /* 2列でピッタリ50%になるように余計な幅/余白を排除 */
  width: 100%;
  margin: 0;
  min-width: 0;
  box-sizing: border-box;
}

/* フォーカス（キーボード操作） */
.tabx__input:focus + .tabx__tab{
  outline: 3px solid rgba(171,31,0,.25);
  outline-offset: 2px;
}

/* 選択状態（checked） */
#tabx_install:checked + label[for="tabx_install"],
#tabx_request:checked + label[for="tabx_request"]{
  background: var(--point);
  color: #fff;
  border-color: transparent;
  box-shadow: 0 18px 40px rgba(171,31,0,.18);
}

/* パネル（タブ2列の下に全幅で配置） */
.tabx__panels{
  grid-column: 1 / -1;   /* ← 2列の下に回して全幅 */
  margin-top: 10px;
}

.tabx__panel{
  display: none;
  padding: 14px;
  border-radius: 16px;
  border: 1px solid var(--soft);
  background: rgba(255,255,255,.82);
  box-shadow: var(--shadow);
  animation: tabxFade .18s ease both;
}

@keyframes tabxFade{
  from{ opacity: 0; transform: translateY(2px); }
  to  { opacity: 1; transform: translateY(0); }
}

/* checkedに応じて表示切替（CSSのみの本体） */
#tabx_install:checked ~ .tabx__panels .tabx__panel--install{ display: block; }
#tabx_request:checked ~ .tabx__panels .tabx__panel--request{ display: block; }

/* スマホ調整：1列 */
@media (max-width: 566px){
  .tabx{
    grid-template-columns: 1fr; /* 1列 */
  }
}
/*-----------------------------------------------------
無料貸出サービスのお問い合わせフォーム
------------------------------------------------------*/
.free2_box{
    max-width: 1300px;
    margin-right: auto;
    padding: 0;
    margin-left: auto;
    height: auto;
}
#free2_4column{
    max-width: 1300px;
    margin-right: auto;
    margin-left: auto;
    height: auto;
    display: flex;
    justify-content: space-between;
    gap: 1rem;
    margin-bottom: 3rem;
    margin-top: 1px;
	flex-wrap: wrap;    
}
#free2_4column div{
    width: calc((100% - 3rem)/4);
    border: 1px solid #BC9A00;
    border-radius: 16px;
    padding-top: 1rem;
    padding-right: 1rem;
    padding-left: 1rem;
    padding-bottom: 2rem;
    background-color: #FFFFFF;
    font-family: "Hiragino Sans", "Hiragino Kaku Gothic ProN", Meiryo, sans-serif;
    font-style: normal;
    font-variant: normal;
    font-weight: normal;
    font-size: .85rem;
    color: #515151;
}
#free2_4column div img{
    max-width: 120px;
    height: auto;
    margin-right: auto;
    margin-left: auto;
    display: block;
}
#free2_4column div h2{
    text-align: center;
    color: #333333;
    font-family: "Hiragino Sans", "Hiragino Kaku Gothic ProN", Meiryo, sans-serif;
    font-style: normal;
    font-variant: normal;
    font-weight: bold;
    font-size: 1.2rem;
}
#free2_2column{
    max-width: 1300px;
    margin-right: auto;
    margin-left: auto;
    height: auto;
    display: flex;
    justify-content: space-between;
    gap: 1rem;
    margin-bottom: 3rem;
    margin-top: 1px;
	flex-wrap: wrap;    
}
#free2_2column div{
    width: calc((100% - 1rem)/2);
    border: 1px solid #BC9A00;
    border-radius: 16px;
    padding-top: 1rem;
    padding-right: 1rem;
    padding-left: 1rem;
    padding-bottom: 2rem;
    background-color: #FFFFFF;
    font-family: "Hiragino Sans", "Hiragino Kaku Gothic ProN", Meiryo, sans-serif;
    font-style: normal;
    font-variant: normal;
    font-weight: normal;
    font-size: .85rem;
    color: #515151;
    -webkit-box-sizing: border-box;
    -moz-box-sizing: border-box;
    box-sizing: border-box;
}
.free2_3column div h2,
#free2_2column div h2{
    text-align: center;
    color: #333333;
    font-family: "Hiragino Sans", "Hiragino Kaku Gothic ProN", Meiryo, sans-serif;
    font-style: normal;
    font-variant: normal;
    font-weight: bold;
    font-size: 1.2rem;
}
#free2_2column div img{
    max-width: 283px;
    height: auto;
    margin-right: auto;
    margin-left: auto;
    display: block;
    margin-bottom: 1rem;
}
.free2_3column{
    max-width: 1300px;
    margin-right: auto;
    margin-left: auto;
    height: auto;
    display: flex;
    justify-content: space-between;
    gap: 1rem;
    margin-bottom: 3rem;
    margin-top: 1px;
	flex-wrap: wrap;    
}
.free2_3column div{
    width: calc((100% - 2rem)/3);
    border: 1px solid #BC9A00;
    border-radius: 16px;
    padding-top: 1rem;
    padding-right: 1rem;
    padding-left: 1rem;
    padding-bottom: 2rem;
    background-color: #FFFFFF;
    font-family: "Hiragino Sans", "Hiragino Kaku Gothic ProN", Meiryo, sans-serif;
    font-style: normal;
    font-variant: normal;
    font-weight: normal;
    font-size: .85rem;
    color: #515151;
    -webkit-box-sizing: border-box;
    -moz-box-sizing: border-box;
    box-sizing: border-box;
}
@media (max-width: 900px){
	#free2_4column div{
		width: calc((94% - 1rem)/2);
		margin-right: auto;
    	margin-left: auto;
	}
}
/* スマホ調整 */
@media (max-width: 566px){
	.free2_3column,
	#free2_2column,
	#free2_4column{
		gap: .75rem;
	}
	.free2_3column div,
	#free2_2column div,
	#free2_4column div{
    width: 94%;
    margin-right: auto;
    margin-left: auto;
	}
}
.voice_t{
    background: linear-gradient(transparent 60%, #FFE32A 90%);
    font-size: 1.65rem;
    font-family: "Hiragino Sans", "Hiragino Kaku Gothic ProN", Meiryo, sans-serif;
    font-style: normal;
    font-variant: normal;
    font-weight: bold;
    color: #C10003 !important;
    margin-bottom: 2rem;
    padding-bottom: 0px;
}
.download_b{
    display: block;
    padding: 14px 12px;
    border: 1px solid rgba(255,255,255,.08);
    border-radius: 6px;
    color: #fff;
    font-size: .95rem;
    transition: background .2s ease, transform .2s ease;
    background-image: linear-gradient(180deg, rgba(140,100,11,1) 0%, rgba(96,66,0,1) 100%);
    text-align: center;
}
.download_b:hover,
.download_b2:hover{
    background-image: -webkit-linear-gradient(270deg,rgba(96,66,0,1.00) 0%,rgba(140,100,11,1.00) 100%);
    background-image: -moz-linear-gradient(270deg,rgba(96,66,0,1.00) 0%,rgba(140,100,11,1.00) 100%);
    background-image: -o-linear-gradient(270deg,rgba(96,66,0,1.00) 0%,rgba(140,100,11,1.00) 100%);
    background-image: linear-gradient(180deg,rgba(96,66,0,1.00) 0%,rgba(140,100,11,1.00) 100%);
    transform: translateY(-2px);
}

.download__title{
    margin-right: 0;
    margin-left: 0;
    font-weight: bold;
    font-family: "Hiragino Sans","Hiragino Kaku Gothic ProN",Meiryo,sans-serif;
    text-align: center;
    color: #333;
    font-size: 1.5rem;
    font-style: normal;
    font-variant: normal;
}
	
/* 2ボタンを親要素いっぱいに横並び */
.download_row{
    display: flex;
    gap: 10px;              /* ボタン間の隙間（好みで） */
    width: 100% !important;
    margin: 0 !important;
    padding: 0 !important;
    border: 0px !important;
}

/* 既存の .download_b2 を上書きして横幅を分ける */
.download_b2{
  flex: 1 1 0;            /* 2つを均等幅にする */
  width: auto;            /* 念のため */
  display: flex;          /* 文字を中央に寄せやすく */
  align-items: center;
  justify-content: center;

  padding: 14px 12px;
  border: 1px solid rgba(255,255,255,.08);
  border-radius: 6px;
  color: #fff;
  font-size: .95rem;
  transition: background .2s ease, transform .2s ease;
  background-image: linear-gradient(180deg, rgba(140,100,11,1) 0%, rgba(96,66,0,1) 100%);
  text-align: center;
  text-decoration: none; /* aタグの下線消し（必要なら） */
}

/* スマホでは縦並びにしたい場合（任意） */
@media (max-width: 566px){
  .download_row{
    flex-direction: column;
  }
}

	
	
	
	
	
	
	
	
