/* featured-property.css — 新着物件特集 写真推し新レイアウト
   名前空間 fp- で既存(columns/wiziwig)と分離。ビルド不要の手書きCSS。
   配色: 青#1C75EA(情報) / オレンジ#FF6B00(主CTA) / LINE緑#06C755 */
.fp-single{
  --fp-blue:#1C75EA; --fp-orange:#FF6B00; --fp-line:#06C755; --fp-line-ink:#057a44;
  --fp-blue-dk:#1559b0;
  --fp-ink:#1a1a1a; --fp-sub:#667085; --fp-mute:#8a94a6; --fp-border:#e3e8ef;
  --fp-surface:#f5f7fa; --fp-photo:#e8edf3; --fp-ok:#0a7a3f; --fp-ok-bg:#e6f5ec;
  color:var(--fp-ink);
}
.fp-single *{box-sizing:border-box;}
.fp-wrap{max-width:1180px;margin:0 auto;padding:8px 20px 40px;}

/* head */
.fp-badges{display:flex;flex-wrap:wrap;align-items:center;gap:7px;margin-bottom:6px;}
.fp-badge{font-size:12px;padding:2px 9px;border-radius:4px;text-decoration:none;line-height:1.6;}
.fp-badge--new{background:var(--fp-orange);color:#fff;}
.fp-badge--cat{background:#eef4fb;color:var(--fp-blue);}
.fp-date{font-size:12px;color:var(--fp-mute);}
.fp-title{font-size:24px;font-weight:500;line-height:1.4;color:var(--fp-blue);margin:2px 0 0;}
.fp-catch{font-size:14px;color:var(--fp-sub);margin:4px 0 0;}

/* hero */
.fp-hero{display:grid;grid-template-columns:minmax(0,1.9fr) minmax(0,1fr);gap:18px;align-items:start;margin-top:16px;}
.fp-gallery{min-width:0;}
.fp-gallery-main{min-width:0;border-radius:10px;overflow:hidden;background:var(--fp-photo);aspect-ratio:16/10;}
.fp-gallery-main .swiper-slide{position:relative;overflow:hidden;height:auto;}
.fp-lightbox-trigger{position:absolute;inset:0;width:100%;height:100%;padding:0;border:0;background:none;cursor:zoom-in;}
.fp-gallery-img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;display:block;}
.fp-zoom{position:absolute;right:10px;bottom:10px;display:inline-flex;align-items:center;gap:4px;background:#fff;color:#475467;border:0.5px solid #cdd5e0;border-radius:6px;padding:2px 8px;font-size:12px;line-height:1;}
.fp-zoom .fp-ico-zoom{font-style:normal;line-height:1;}
.fp-gallery-main .swiper-button-prev,.fp-gallery-main .swiper-button-next{color:var(--fp-blue);background:rgba(255,255,255,.92);width:34px;height:34px;border-radius:50%;box-shadow:0 1px 4px rgba(0,0,0,.18);}
.fp-gallery-main .swiper-button-prev:after,.fp-gallery-main .swiper-button-next:after{font-family:inherit;font-size:18px;font-weight:700;line-height:1;}
.fp-gallery-main .swiper-button-prev:after{content:"\276E";}
.fp-gallery-main .swiper-button-next:after{content:"\276F";}
.fp-gallery-main .swiper-pagination-bullet-active{background:var(--fp-blue);}
.fp-gallery-thumbs{margin-top:8px;}
.fp-gallery-thumbs .swiper-slide{position:relative;border-radius:6px;overflow:hidden;cursor:pointer;opacity:.55;border:2px solid transparent;aspect-ratio:1/1;}
.fp-gallery-thumbs .swiper-slide-thumb-active{opacity:1;border-color:var(--fp-blue);}
.fp-thumb-img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;display:block;}
.fp-gallery-empty{aspect-ratio:16/10;border-radius:10px;background:var(--fp-photo);display:flex;align-items:center;justify-content:center;color:var(--fp-mute);font-size:14px;}
.fp-naiken-note{display:flex;align-items:center;gap:6px;font-size:13px;color:var(--fp-blue);background:#eef4fb;border-radius:6px;padding:8px 11px;margin:10px 0 0;}

/* sticky side card */
.fp-side{position:sticky;top:90px;max-height:calc(100vh - 110px);overflow-y:auto;}
.fp-card{border:1px solid var(--fp-border);border-radius:12px;padding:13px;display:flex;flex-direction:column;gap:9px;background:#fff;}
.fp-card-label{font-size:11px;color:var(--fp-mute);display:block;}
.fp-stations .fp-station-row{display:flex;justify-content:space-between;font-size:13px;line-height:1.8;}
.fp-walk{color:var(--fp-blue);white-space:nowrap;}
.fp-spec-box{background:var(--fp-surface);border-radius:7px;padding:7px 9px;}
.fp-spec-strong{font-size:15px;font-weight:500;}
.fp-spec-strong small{font-size:11px;color:var(--fp-mute);font-weight:400;}
.fp-spec-grid{display:grid;grid-template-columns:1fr 1fr;gap:7px;}
.fp-spec-cell{background:var(--fp-surface);border-radius:7px;padding:7px 9px;font-size:13px;font-weight:500;}
.fp-spec-cell--full{grid-column:1 / -1;}
.fp-spec-cell small{font-size:11px;color:var(--fp-mute);font-weight:400;display:block;}
.fp-spec-cell--ok{background:var(--fp-ok-bg);color:var(--fp-ok);}
.fp-spec-cell--ok .fp-card-label{color:var(--fp-ok);}

/* CTA */
.fp-cta{display:block;text-align:center;padding:11px 12px;border-radius:8px;font-size:14px;font-weight:500;text-decoration:none;line-height:1.4;}
.fp-cta--primary{background:var(--fp-orange);color:#fff;}
.fp-cta--primary:hover{background:#e05f00;}
.fp-cta--line{background:var(--fp-line);color:#fff;border:1px solid var(--fp-line);}
.fp-cta--line:hover{background:#05b14c;border-color:#05b14c;}
.fp-cta--tel{background:var(--fp-blue);color:#fff;border:1px solid var(--fp-blue);font-size:13px;}
.fp-cta--tel:hover{background:var(--fp-blue-dk);border-color:var(--fp-blue-dk);}
.fp-cta-note{font-size:11px;color:var(--fp-mute);text-align:center;margin:2px 0 0;}

/* tags（グラデーションのピル型・白文字） */
.fp-tags{display:flex;flex-wrap:wrap;gap:9px;list-style:none;padding:0;margin:22px 0 0;}
.fp-tag{display:inline-flex;align-items:center;font-size:13px;font-weight:500;border:0;border-radius:999px;
  padding:6px 14px;color:#fff;line-height:1.4;letter-spacing:.02em;
  background:linear-gradient(135deg,#3b8af2,#0b57c9);box-shadow:0 2px 7px rgba(11,87,201,.22);}
.fp-tag:before{content:"\2713";margin-right:6px;font-weight:700;opacity:.95;}
/* エリアタグ（区名・リンク・オレンジ系で差別化） */
.fp-tag--area{text-decoration:none;background:linear-gradient(135deg,#ff9a4d,#ff6b00);box-shadow:0 2px 7px rgba(255,107,0,.28);transition:filter .15s;}
.fp-tag--area:hover{filter:brightness(1.05);}
.fp-tag--area:before{content:"\25C9";margin-right:6px;opacity:.95;}

/* body / sections */
.fp-body{margin:22px 0;font-size:15px;line-height:1.9;}
/* 「この物件のポイント」＝the_content をリッチに装飾 */
.fp-body h2{font-size:19px;font-weight:600;color:var(--fp-blue);margin:26px 0 14px;padding:10px 14px;
  background:linear-gradient(90deg,#eef4fb,#f8fbff);border-left:5px solid var(--fp-orange);border-radius:0 8px 8px 0;}
.fp-body h2:first-child{margin-top:0;}
.fp-body > ul{list-style:none;padding:0;margin:14px 0;display:grid;grid-template-columns:1fr 1fr;gap:10px;}
.fp-body > ul > li{position:relative;background:#fff;border:1px solid var(--fp-border);border-radius:10px;
  padding:13px 14px 13px 42px;font-size:14px;line-height:1.7;box-shadow:0 1px 4px rgba(16,40,80,.04);}
.fp-body > ul > li:before{content:"\2713";position:absolute;left:12px;top:13px;width:20px;height:20px;
  display:flex;align-items:center;justify-content:center;border-radius:50%;background:var(--fp-orange);
  color:#fff;font-size:12px;font-weight:700;line-height:1;}
.fp-body > ul > li strong{display:block;color:var(--fp-blue);font-weight:600;margin-bottom:2px;}
.fp-body p{margin:12px 0;}
.fp-body > p:last-child{font-size:13px;color:var(--fp-sub);background:var(--fp-surface);border-radius:8px;padding:11px 13px;}
@media (max-width:768px){ .fp-body > ul{grid-template-columns:1fr;} }
.fp-section{margin:24px 0;}
.fp-h2{font-size:18px;font-weight:500;color:var(--fp-blue);border-left:4px solid var(--fp-orange);padding-left:10px;margin:0 0 12px;}
.fp-spec-table{width:100%;border-collapse:collapse;font-size:14px;}
.fp-spec-table th,.fp-spec-table td{border-bottom:0.5px solid var(--fp-border);padding:9px 10px;text-align:left;vertical-align:top;}
.fp-spec-table th{width:30%;color:var(--fp-sub);background:var(--fp-surface);font-weight:400;}

/* フロア図面（地図と2列・高さを揃える／低画質なので拡大しすぎない） */
.fp-floorplan{margin:0;min-width:0;}
.fp-floorplan-trigger{position:relative;display:block;width:100%;height:320px;padding:0;border:0;background:none;cursor:zoom-in;}
.fp-floorplan-img{width:100%;height:100%;object-fit:contain;display:block;background:var(--fp-surface);border:1px solid var(--fp-border);border-radius:8px;}

/* map + staff */
.fp-meta-row{display:grid;grid-template-columns:1fr 1fr;gap:16px;align-items:start;margin:24px 0;}
.fp-meta-row > :only-child{grid-column:1 / -1;}
.fp-map{margin:0;min-width:0;}
.fp-map iframe{width:100%;height:320px;border:0;border-radius:10px;display:block;}
/* 担当者（2列の下に全幅で1列表示） */
.fp-staff--full{margin:24px 0;}
.fp-staff{border:0.5px solid var(--fp-border);border-radius:10px;padding:12px;display:flex;gap:11px;align-items:flex-start;}
.fp-staff-photo{width:72px;height:72px;border-radius:50%;background:#eef4fb;color:var(--fp-blue);display:flex;align-items:center;justify-content:center;overflow:hidden;flex:0 0 auto;}
.fp-staff-photo img{width:100%;height:100%;object-fit:cover;}
.fp-staff-name{font-size:12px;color:var(--fp-mute);margin:0;}
.fp-staff-cmt{font-size:13px;line-height:1.6;margin:2px 0;}
.fp-staff-line{font-size:12px;color:var(--fp-line-ink);text-decoration:none;}

/* mini FAQ（アイコン付き・目立たせ版） */
.fp-faq{border:1px solid var(--fp-border);border-radius:12px;overflow:hidden;margin:28px 0;box-shadow:0 2px 10px rgba(16,40,80,.05);}
.fp-faq-head{display:flex;align-items:center;gap:9px;font-size:15px;font-weight:600;color:#fff;background:var(--fp-blue);padding:12px 16px;}
.fp-faq-headmark{flex:0 0 auto;display:inline-flex;align-items:center;justify-content:center;width:22px;height:22px;border-radius:50%;background:#fff;color:var(--fp-blue);font-size:14px;font-weight:700;}
.fp-faq-item{border-top:1px solid var(--fp-border);}
.fp-faq-item:first-of-type{border-top:0;}
.fp-faq-q{width:100%;display:flex;align-items:center;gap:11px;padding:14px 16px;background:#fff;border:0;font-size:15px;text-align:left;cursor:pointer;color:var(--fp-ink);font-weight:500;transition:background .15s;}
.fp-faq-q:hover,.fp-faq-q[aria-expanded="true"]{background:#f5f8fc;}
.fp-faq-qmark{flex:0 0 auto;display:inline-flex;align-items:center;justify-content:center;width:26px;height:26px;border-radius:50%;background:var(--fp-blue);color:#fff;font-size:14px;font-weight:700;line-height:1;}
.fp-faq-qtext{flex:1;}
.fp-faq-q .fp-ico-chev{flex:0 0 auto;color:var(--fp-mute);transition:transform .2s,color .2s;}
.fp-faq-q[aria-expanded="true"] .fp-ico-chev{transform:rotate(180deg);color:var(--fp-blue);}
.fp-faq-a{display:none;gap:11px;padding:2px 16px 16px;font-size:14px;line-height:1.85;color:var(--fp-sub);background:#f5f8fc;}
.fp-faq-q[aria-expanded="true"] + .fp-faq-a{display:flex;}
.fp-faq-amark{flex:0 0 auto;display:inline-flex;align-items:center;justify-content:center;width:26px;height:26px;border-radius:50%;background:var(--fp-orange);color:#fff;font-size:14px;font-weight:700;line-height:1;}
.fp-faq-a-text{flex:1;padding-top:3px;}

/* CTA band（人物写真を背景にブレンド） */
.fp-cta-band{position:relative;overflow:hidden;border-radius:14px;padding:26px 30px;color:#fff;margin:28px 0;
  background:linear-gradient(108deg,#0a52b8 0%,var(--fp-blue) 55%,#4a90f0 100%);}
.fp-cta-band-photo{position:absolute;top:0;right:0;bottom:0;width:48%;
  background:url(../images/fp-cta-person.jpg) top right/cover no-repeat;
  -webkit-mask-image:linear-gradient(90deg,transparent 0%,rgba(0,0,0,.6) 45%,#000 100%);
  mask-image:linear-gradient(90deg,transparent 0%,rgba(0,0,0,.6) 45%,#000 100%);
  opacity:.92;pointer-events:none;}
.fp-cta-band-inner{position:relative;z-index:1;max-width:64%;}
.fp-cta-band-title{font-size:19px;font-weight:600;line-height:1.5;margin:0 0 6px;text-shadow:0 1px 4px rgba(0,28,68,.35);}
.fp-cta-band-sub{font-size:13px;color:#dbe7f7;margin:0 0 16px;line-height:1.7;text-shadow:0 1px 3px rgba(0,28,68,.35);}
.fp-cta-band-btns{display:flex;gap:10px;align-items:center;flex-wrap:wrap;}
.fp-cta-band-btns .fp-cta{display:inline-flex;align-items:center;justify-content:center;gap:6px;}
.fp-cta-band-btns .fp-cta--primary{box-shadow:0 4px 14px rgba(255,107,0,.4);}
.fp-cta--line-light{background:var(--fp-line);color:#fff;border:1px solid var(--fp-line);}
.fp-cta--line-light:hover{background:#05b14c;border-color:#05b14c;}
.fp-cta--tel-light{color:var(--fp-blue);background:#fff;border:1px solid #fff;}
@media (max-width:768px){
  .fp-cta-band{padding:22px 18px;text-align:center;}
  .fp-cta-band-photo{width:100%;opacity:.16;-webkit-mask-image:none;mask-image:none;}
  .fp-cta-band-inner{max-width:100%;}
  .fp-cta-band-btns{justify-content:center;}
}

/* related featured posts（他の新着物件特集・最新5件） */
.fp-related{margin:30px 0;}
.fp-related-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:12px;}
.fp-related-card{display:flex;flex-direction:column;border:1px solid var(--fp-border);border-radius:10px;overflow:hidden;background:#fff;text-decoration:none;color:inherit;transition:box-shadow .15s,transform .15s;}
.fp-related-card:hover{box-shadow:0 6px 18px rgba(16,40,80,.12);transform:translateY(-2px);}
.fp-related-thumb{position:relative;margin:0;aspect-ratio:4/3;background:var(--fp-photo);overflow:hidden;}
.fp-related-img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;display:block;}
.fp-related-noimg{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;color:var(--fp-mute);font-size:12px;}
.fp-related-body{padding:9px 11px 12px;display:flex;flex-direction:column;gap:3px;}
.fp-related-date{font-size:11px;color:var(--fp-mute);}
.fp-related-title{font-size:13px;font-weight:600;line-height:1.45;margin:0;color:var(--fp-ink);display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;}
.fp-related-catch{font-size:11px;color:var(--fp-sub);line-height:1.5;margin:0;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;}
@media (max-width:1024px){.fp-related-grid{grid-template-columns:repeat(3,1fr);}}
@media (max-width:640px){.fp-related-grid{grid-template-columns:repeat(2,1fr);}}

/* area（背景に街の写真をブレンド） */
.fp-area{position:relative;overflow:hidden;border:1px solid var(--fp-border);border-radius:12px;padding:18px 20px;background:#fafbfc;margin:24px 0;}
.fp-area-photo{position:absolute;top:0;right:0;bottom:0;width:44%;
  background:url(../images/fp-area-bg.jpg) center right/cover no-repeat;
  -webkit-mask-image:linear-gradient(90deg,transparent 0%,rgba(0,0,0,.5) 50%,#000 100%);
  mask-image:linear-gradient(90deg,transparent 0%,rgba(0,0,0,.5) 50%,#000 100%);
  opacity:.55;pointer-events:none;}
.fp-area > :not(.fp-area-photo){position:relative;z-index:1;}
.fp-area .fp-h2{background:rgba(255,255,255,.6);display:inline-block;border-radius:0 6px 6px 0;padding-right:10px;}
.fp-area-desc{font-size:14px;line-height:1.9;margin:0 0 12px;max-width:62%;}
.fp-area-link{display:inline-flex;align-items:center;gap:6px;font-size:13px;color:#fff;text-decoration:none;background:var(--fp-blue);border:1px solid var(--fp-blue);border-radius:7px;padding:8px 14px;font-weight:500;}
.fp-area-link:hover{background:var(--fp-blue-dk);}
@media (max-width:768px){
  .fp-area-photo{width:100%;opacity:.12;-webkit-mask-image:none;mask-image:none;}
  .fp-area-desc{max-width:100%;}
}

/* mobile fixed CTA bar */
.fp-mobilebar{display:none;}
@media (max-width:768px){
  .fp-hero{grid-template-columns:1fr;}
  .fp-side{position:static;max-height:none;overflow:visible;margin-top:6px;}
  .fp-meta-row{grid-template-columns:1fr;}
  .fp-title{font-size:21px;}
  .fp-mobilebar{display:flex;position:fixed;left:0;right:0;bottom:0;z-index:9999;gap:1px;background:var(--fp-border);
    padding-bottom:env(safe-area-inset-bottom);}
  .fp-mbtn{flex:1;display:flex;align-items:center;justify-content:center;gap:5px;min-height:52px;
    text-decoration:none;font-size:13px;font-weight:500;background:#fff;}
  .fp-mbtn--primary{flex:1.6;background:var(--fp-orange);color:#fff;}
  .fp-mbtn--line{color:var(--fp-line-ink);}
  .fp-mbtn--tel{flex:0 0 56px;color:var(--fp-blue);}
}
body.fp-has-mobilebar{padding-bottom:0;}
@media (max-width:768px){ body.fp-has-mobilebar{padding-bottom:62px;} }

/* lightbox */
.fp-lb{position:fixed;inset:0;z-index:10000;background:rgba(0,0,0,.9);display:flex;align-items:center;justify-content:center;}
.fp-lb[hidden]{display:none;}
.fp-lb img{max-width:92vw;max-height:88vh;object-fit:contain;}
.fp-lb-btn{position:absolute;background:rgba(255,255,255,.15);color:#fff;border:0;width:46px;height:46px;border-radius:50%;font-size:22px;cursor:pointer;display:flex;align-items:center;justify-content:center;}
.fp-lb-close{top:16px;right:16px;}
.fp-lb-prev{left:14px;top:50%;transform:translateY(-50%);}
.fp-lb-next{right:14px;top:50%;transform:translateY(-50%);}
.fp-lb-count{position:absolute;bottom:18px;left:0;right:0;text-align:center;color:#fff;font-size:13px;}

/* icons (unicode, decorative) */
.fp-ico-mail:before{content:"\2709";}
.fp-ico-tel:before{content:"\260E";}
.fp-ico-arrow:before{content:"\2192";}
.fp-ico-chev:before{content:"\25BE";}
.fp-ico-zoom:before{content:"\2922";}
