@charset "UTF-8";

/* ============================================
   SAN+お施主様インタビュー動画集
   ============================================ */

.owner-interview-main{
  --oi-primary:#1c3a51;
  --oi-primary-dark:#10283a;
  --oi-blue:#4a90c8;
  --oi-light-blue:#eaf5fc;
  --oi-bg:#f5f7fa;
  --oi-border:#dfe6ec;
  --oi-text:#333;
  --oi-muted:#666;
  --oi-white:#fff;
  --oi-shadow:0 8px 24px rgba(28,58,81,.10);
  color:var(--oi-text);
  line-height:1.8;
}

.owner-interview-main *,
.owner-interview-main *::before,
.owner-interview-main *::after{
  box-sizing:border-box;
}

.owner-interview-container{
  width:min(1120px, calc(100% - 40px));
  margin:0 auto;
}

.owner-interview-main img{
  max-width:100%;
  height:auto;
  vertical-align:bottom;
}

.owner-interview-main h1,
.owner-interview-main h2,
.owner-interview-main h3,
.owner-interview-main p,
.owner-interview-main ul{
  margin:0;
}

.owner-interview-main ul{
  padding:0;
  list-style:none;
}

.owner-interview-main a{
  text-decoration:none;
}

.owner-interview-main h2{
  color:var(--oi-primary);
  font-size:30px;
  line-height:1.45;
  text-align:center;
  margin-bottom:18px;
  font-weight: 600;
}

.owner-interview-section-lead{
  max-width:820px;
  margin:0 auto 36px!important;
  color:var(--oi-muted);
  text-align:center;
  font-size:15px;
}

/* button */
.owner-interview-btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-height:46px;
  padding:0 28px;
  border-radius:999px;
  font-weight:700;
  font-size:15px;
  line-height:1.4;
  transition:all .25s ease;
  border:2px solid transparent;
}

.owner-interview-btn--primary{
  background:var(--oi-primary);
  color:#fff;
  box-shadow:0 4px 12px rgba(28,58,81,.18);
}

.owner-interview-btn--primary:hover{
  background:var(--oi-primary-dark);
  transform:translateY(-2px);
}

.owner-interview-btn--outline{
  background:#fff;
  color:var(--oi-primary);
  border-color:var(--oi-primary);
}

.owner-interview-btn--outline:hover{
  background:var(--oi-primary);
  color:#fff;
}

.owner-interview-btn--white{
  color:#fff;
  border-color:rgba(255,255,255,.85);
  background:rgba(255,255,255,.06);
}

.owner-interview-btn--white:hover{
  background:#fff;
  color:var(--oi-primary);
}

.owner-interview-btn--small{
  min-height:38px;
  padding:0 18px;
  font-size:13px;
}

/* hero */
.owner-interview-hero{
  padding:72px 0;
  background:
    linear-gradient(135deg, rgba(234,245,252,.96), rgba(255,255,255,.90)),
    linear-gradient(135deg, #eaf5fc, #fff);
}

.owner-interview-hero__inner{
  display:grid;
  grid-template-columns:1.05fr .95fr;
  gap:44px;
  align-items:center;
}

.owner-interview-kicker{
  display:inline-block;
  margin-bottom:20px!important;
  padding:4px 14px;
  border-radius:999px;
  background:#fff;
  color:var(--oi-blue);
  font-weight:700;
  font-size:13px;
  letter-spacing:.08em;
}

.owner-interview-hero h1{
  color:var(--oi-primary);
  font-size:30px;
  font-weight: 600;
  line-height:1.35;
  margin-bottom:20px;
}

.owner-interview-hero__lead{
  color:#344;
  font-size:16px;
  line-height:2;
  margin-bottom:28px!important;
  text-align: left;
}

.owner-interview-hero__buttons{
  display:flex;
  gap:14px;
  flex-wrap:wrap;
}

.owner-interview-hero__visual{
  position:relative;
  min-height:360px;
}

.owner-interview-hero__thumb{
  position:absolute;
  overflow:hidden;
  border-radius:18px;
  background:#fff;
  box-shadow:var(--oi-shadow);
}

.owner-interview-hero__thumb img{
  width:100%;
  height:100%;
  object-fit:cover;
}

.owner-interview-hero__thumb--large{
  width:80%;
  height:255px;
  right:0;
  top:0;
}

.owner-interview-hero__thumb:not(.owner-interview-hero__thumb--large){
  width:43%;
  height:135px;
}

.owner-interview-hero__thumb:nth-child(2){
  left:0;
  bottom:48px;
}

.owner-interview-hero__thumb:nth-child(3){
  right:12%;
  bottom:0;
}

/* benefits */
.owner-interview-benefits{
  padding:72px 0;
  background:#fff;
}

.owner-interview-benefits__grid{
  display:grid;
  grid-template-columns:repeat(3, 1fr);
  gap:22px;
}

.owner-interview-benefit{
  padding:26px 22px;
  border:1px solid var(--oi-border);
  border-radius:16px;
  background:#fff;
  box-shadow:0 4px 16px rgba(28,58,81,.06);
}

.owner-interview-benefit__icon{
  display:flex;
  align-items:center;
  justify-content:center;
  width:80px;
  height:80px;
  margin:0 auto 14px;
  border-radius:50%;
  background:var(--oi-light-blue);
}

.owner-interview-benefit__icon img{
  width:50px;
  height:50px;
  object-fit:contain;
}

.owner-interview-benefit h3{
  color:var(--oi-primary);
  font-size:18px;
  line-height:1.5;
  margin-bottom:8px;
  font-weight: 500;
}

.owner-interview-benefit p{
  color:var(--oi-muted);
  font-size:14px;
  line-height:1.8;
  text-align: left;
}

/* videos */
.owner-interview-videos{
  padding:76px 0;
  background:var(--oi-bg);
}

.owner-interview-videos__grid{
  display:grid;
  grid-template-columns:repeat(3, 1fr);
  gap:26px;
}

.owner-interview-card{
  overflow:hidden;
  border-radius:6px;
  background:#fff;
  border:1px solid var(--oi-border);
  box-shadow:0 6px 20px rgba(28,58,81,.08);
  transition:transform .25s ease, box-shadow .25s ease;
}

.owner-interview-card:hover{
  transform:translateY(-4px);
  box-shadow:var(--oi-shadow);
}

.owner-interview-card__thumb{
  position:relative;
  display:block;
  aspect-ratio:16/9;
  overflow:hidden;
  background:#ddd;
}

.owner-interview-card__thumb img{
  width:100%;
  height:100%;
  object-fit:cover;
  transition:transform .3s ease;
}

.owner-interview-card:hover .owner-interview-card__thumb img{
  transform:scale(1.05);
}

.owner-interview-card__play{
  position:absolute;
  left:50%;
  top:50%;
  transform:translate(-50%, -50%);
  display:flex;
  align-items:center;
  justify-content:center;
  width:60px;
  height:60px;
  border-radius:50%;
  background:rgba(255,255,255,.94);
  color:var(--oi-primary);
  font-size:24px;
  box-shadow:0 4px 16px rgba(0,0,0,.20);
  padding-left:4px;
}

.owner-interview-card__body{
  padding:22px;
}

.owner-interview-card__area{
  color:var(--oi-blue);
  font-size:13px;
  font-weight:700;
  margin-bottom:6px;
}

.owner-interview-card h3{
  color:var(--oi-primary);
  font-size:16px;
  line-height:1.5;
  margin-bottom:10px;
  font-weight: 500;
}

.owner-interview-card__body > p:not(.owner-interview-card__area){
  color:var(--oi-muted);
  font-size:13px;
  line-height:1.75;
  margin-bottom:14px;
  text-align: left;
}

.owner-interview-tags{
  display:flex;
  flex-wrap:wrap;
  gap:7px;
  margin-bottom:18px !important;
}

.owner-interview-tags li{
  display:inline-flex;
  align-items:center;
  min-height:26px;
  padding:3px 10px;
  border-radius:999px;
  background:var(--oi-light-blue);
  color:var(--oi-primary);
  font-size:12px;
  font-weight:700;
}

.owner-interview-card__buttons{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:10px;
}

/* recommend */
.owner-interview-recommend{
  padding:72px 0;
  background:#fff;
}

.owner-interview-recommend__grid{
  display:grid;
  grid-template-columns:repeat(5, 1fr);
  gap:16px;
}

.owner-interview-recommend__grid div{
  min-height:112px;
  padding:22px 16px;
  border-radius:16px;
  background:#fff;
  border:1px solid var(--oi-border);
  box-shadow:0 6px 18px rgba(28,58,81,.08);
  color:var(--oi-primary);
  font-weight:700;
  font-size:14px;
  line-height:1.7;
  text-align:center;
}

.owner-interview-recommend__grid div::before{
  content:"✓";
  display:block;
  width:34px;
  height:34px;
  margin:0 auto 10px;
  border-radius:50%;
  background:var(--oi-light-blue);
  color:var(--oi-blue);
  line-height:34px;
}

/* crosslink */
.owner-interview-crosslink{
  padding:72px 0;
  background:var(--oi-bg);
  text-align:center;
}

.owner-interview-crosslink p{
  max-width:760px;
  margin:0 auto 28px;
  color:var(--oi-muted);
  font-size:15px;
  line-height:1.9;
}

/* cta */
.owner-interview-cta{
  padding:70px 0;
  background:linear-gradient(135deg, var(--oi-primary-dark), #2d5b82);
  text-align:center;
}

.owner-interview-cta h2{
  color:#fff;
  margin-bottom:28px;
}

.owner-interview-cta__buttons{
  display:flex;
  justify-content:center;
  gap:14px;
  flex-wrap:wrap;
}

/* responsive */
@media screen and (max-width: 1024px){
  .owner-interview-hero__inner{
    grid-template-columns:1fr;
  }

  .owner-interview-hero__visual{
    max-width:680px;
    width:100%;
    margin:0 auto;
  }

  .owner-interview-benefits__grid,
  .owner-interview-videos__grid{
    grid-template-columns:repeat(2, 1fr);
  }

  .owner-interview-recommend__grid{
    grid-template-columns:repeat(3, 1fr);
  }
}

@media screen and (max-width: 640px){
  .owner-interview-container{
    width:min(100% - 28px, 1120px);
	
  }

  .owner-interview-hero{
    padding:30px 0;
  }

  .owner-interview-hero h1{
    font-size:22px;
  }

  .owner-interview-hero__lead{
    font-size:14px;
    line-height:1.9;
  }

  .owner-interview-hero__buttons{
    flex-direction:column;
  }

  .owner-interview-btn{
    width:100%;
  }

  .owner-interview-hero__visual{
    min-height:260px;
  }

  .owner-interview-hero__thumb--large{
    width:92%;
    height:190px;
  }

  .owner-interview-hero__thumb:not(.owner-interview-hero__thumb--large){
    height:105px;
  }

  .owner-interview-main h2{
    font-size:22px;
	font-weight: 600;
  }

  .owner-interview-benefits,
  .owner-interview-videos,
  .owner-interview-recommend,
  .owner-interview-crosslink,
  .owner-interview-cta{
    padding:52px 0;
  }

  .owner-interview-benefits__grid,
  .owner-interview-videos__grid,
  .owner-interview-recommend__grid{
    grid-template-columns:1fr;
  }

  .owner-interview-card__buttons{
    grid-template-columns:1fr;
  }

  .owner-interview-cta__buttons{
    flex-direction:column;
  }
}

/* ============================================
   背景だけ画面幅いっぱいにする
   ============================================ */

.owner-interview-main > section{
  position: relative;
  isolation: isolate;
  background: transparent !important;
  overflow: visible;
}

.owner-interview-main > section::before{
  content: "";
  position: absolute;
  top: 0;
  bottom: 0;
  left: 50%;
  width: 100vw;
  transform: translateX(-50%);
  z-index: -1;
  background: var(--oi-section-bg, transparent);
}

/* 各セクション背景 */
.owner-interview-hero{
  --oi-section-bg:
    linear-gradient(135deg, rgba(234,245,252,.96), rgba(255,255,255,.90)),
    linear-gradient(135deg, #eaf5fc, #fff);
}

.owner-interview-benefits{
  --oi-section-bg: #fff;
}

.owner-interview-videos{
  --oi-section-bg: var(--oi-bg);
}

.owner-interview-recommend{
  --oi-section-bg: #fff;
}

.owner-interview-crosslink{
  --oi-section-bg: var(--oi-bg);
}

.owner-interview-cta{
  --oi-section-bg: linear-gradient(135deg, var(--oi-primary-dark), #2d5b82);
}

.owner-interview-hero .owner-interview-btn--primary{
  color:#fff !important;
}

.owner-interview-hero .owner-interview-btn--primary:visited,
.owner-interview-hero .owner-interview-btn--primary:hover{
  color:#fff !important;
}

.owner-interview-sp-br{
  display:none;
}

@media screen and (max-width: 640px){
  .owner-interview-sp-br{
    display:block;
  }
}

@media screen and (max-width: 640px){

  .owner-interview-hero__inner{
    display:flex;
    flex-direction:column;
    gap:24px;
  }

  .owner-interview-hero__text{
    display:flex;
    flex-direction:column;
  }

  .owner-interview-kicker{
    order:1;
  }

  .owner-interview-hero h1{
    order:2;
    margin-bottom:16px;
	letter-spacing: 0.15rem;
  }

  .owner-interview-hero__visual{
    order:3;
    min-height:auto;
    margin:0 auto 18px;
  }

  .owner-interview-hero__lead{
    order:4;
  }

  .owner-interview-hero__buttons{
    order:5;
  }

  .owner-interview-hero__thumb{
    position:static;
    display:none;
  }

  .owner-interview-hero__thumb--large{
    display:block;
    width:100%;
    height:auto;
    aspect-ratio:16 / 9;
    border-radius:5px;
  }

  .owner-interview-hero__thumb--large img{
    width:100%;
    height:100%;
    object-fit:cover;
  }
}

.owner-interview-card__buttons .owner-interview-btn--primary,
.owner-interview-card__buttons .owner-interview-btn--primary:visited,
.owner-interview-card__buttons .owner-interview-btn--primary:hover{
  color:#fff !important;
}

/* ============================================
   ボタン文字色の調整
   ============================================ */

/* 青背景・濃色背景の主要ボタンは白文字 */
.owner-interview-main .owner-interview-btn--primary,
.owner-interview-main .owner-interview-btn--primary:link,
.owner-interview-main .owner-interview-btn--primary:visited,
.owner-interview-main .owner-interview-btn--primary:hover,
.owner-interview-main .owner-interview-btn--primary:active,
.owner-interview-main .owner-interview-btn--primary * {
  color: #fff !important;
}

/* 白背景のアウトラインボタンは通常時、紺文字 */
.owner-interview-main .owner-interview-btn--outline,
.owner-interview-main .owner-interview-btn--outline:link,
.owner-interview-main .owner-interview-btn--outline:visited,
.owner-interview-main .owner-interview-btn--outline * {
  color: var(--oi-primary) !important;
}

/* アウトラインボタンはhover時だけ白文字 */
.owner-interview-main .owner-interview-btn--outline:hover,
.owner-interview-main .owner-interview-btn--outline:hover * {
  color: #fff !important;
}

/* 濃色CTAエリア内の白枠ボタンは通常時、白文字 */
.owner-interview-main .owner-interview-cta .owner-interview-btn--white,
.owner-interview-main .owner-interview-cta .owner-interview-btn--white:link,
.owner-interview-main .owner-interview-cta .owner-interview-btn--white:visited,
.owner-interview-main .owner-interview-cta .owner-interview-btn--white:active,
.owner-interview-main .owner-interview-cta .owner-interview-btn--white * {
  color: #fff !important;
}

/* 白枠ボタンはhoverで背景が白になるので、hover時は紺文字 */
.owner-interview-main .owner-interview-cta .owner-interview-btn--white:hover,
.owner-interview-main .owner-interview-cta .owner-interview-btn--white:hover * {
  color: var(--oi-primary) !important;
}

@media screen and (max-width:640px){
  .owner-interview-hero__inner.owner-interview-container{
    width:100%;
    margin-left:0;
    margin-right:0;
  }

  .owner-interview-hero__text{
    width:calc(100% - 28px);
    margin-left:auto;
    margin-right:auto;
  }

  .owner-interview-hero__visual{
    width:100%;
  }
}

/* ============================================
   SPのみ：本文コンテンツ下と共通パーツの余白
   ============================================ */
@media screen and (max-width: 640px){
  .owner-interview-main{
    margin-bottom: 48px;
  }
}

/* ============================================
   SPのみ：こんな方におすすめの動画ですカード内の”✓”位置
   ============================================ */
@media screen and (max-width:640px){

  .owner-interview-recommend__grid div{
    min-height:auto;
    display:flex;
    align-items:center;
    justify-content:flex-start;
    gap:10px;
    padding:16px 18px;
    text-align:left;
  }

  .owner-interview-recommend__grid div::before{
    flex:0 0 28px;
    display:flex;
    align-items:center;
    justify-content:center;
    width:28px;
    height:28px;
    margin:0;
    line-height:1;
  }
}

/* ============================================
   Hero visual：1枚画像表示
   ============================================ */

.owner-interview-hero__visual--single{
  position:relative;
  min-height:auto;
  border-radius:22px;
  overflow:hidden;
  background:#fff;
  box-shadow:var(--oi-shadow);
}

.owner-interview-hero__visual--single img{
  display:block;
  width:100%;
  height:auto;
  aspect-ratio:3 / 2;
  object-fit:cover;
  object-position:center center;
}

/* 3枚重ね時のabsolute指定を無効化 */
.owner-interview-hero__visual--single .owner-interview-hero__thumb{
  position:static;
}

.owner-interview-hero__movie-link{
  display:block;
  cursor:pointer;
}

.owner-interview-hero__movie-link::after{
  content:"";
  position:absolute;
  inset:0;
  background:rgba(16,40,58,.08);
  transition:background .25s ease;
}

.owner-interview-hero__movie-link:hover::after{
  background:rgba(16,40,58,.16);
}

.owner-interview-hero__play{
  position:absolute;
  left:50%;
  top:50%;
  transform:translate(-50%, -50%);
  z-index:2;
  display:flex;
  align-items:center;
  justify-content:center;
  width:78px;
  height:78px;
  border-radius:50%;
  background:rgba(255,255,255,.94);
  color:var(--oi-primary);
  font-size:30px;
  padding-left:5px;
  box-shadow:0 8px 24px rgba(0,0,0,.22);
  transition:transform .25s ease, background .25s ease;
}

.owner-interview-hero__movie-link:hover .owner-interview-hero__play{
  transform:translate(-50%, -50%) scale(1.06);
  background:#fff;
}

@media screen and (max-width:640px){
  .owner-interview-hero__play{
    width:62px;
    height:62px;
    font-size:24px;
  }
}