/* ============================================
   Trust Home — 不動産仲介
   Theme: Navy Corporate / Left Sidebar Nav / Property Cards
   STANDALONE — Unique: Sidebar navigation layout
   ============================================ */
*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{font-family:'Noto Sans JP','Inter',sans-serif;color:#64748b;background:#f8fafc;font-size:14px;line-height:1.85;-webkit-font-smoothing:antialiased;overflow-x:hidden}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
::selection{background:rgba(59,130,246,.15)}

:root{
  --navy:#0f2a4a;--navy2:#1e3a5f;--blue:#3b82f6;--blue2:#2563eb;--blue-light:#eff6ff;
  --heading:#0f172a;--text:#64748b;--border:#e2e8f0;
  --sans:'Noto Sans JP','Inter',sans-serif;--fe:'Inter',sans-serif;
  --r:10px;--r2:999px;
  --sidebar:240px;
}

/* === SIDEBAR NAV (Desktop) === */
.sidebar{position:fixed;top:0;left:0;width:var(--sidebar);height:100vh;background:#fff;border-right:1px solid var(--border);z-index:800;display:flex;flex-direction:column;padding:1.5rem;overflow-y:auto}
.sidebar-logo{font-family:var(--fe);font-size:.85rem;font-weight:800;color:var(--navy);margin-bottom:.3rem;letter-spacing:.02em}
.sidebar-logo span{color:var(--blue)}
.sidebar-sub{font-size:.55rem;color:var(--text);letter-spacing:.03em;margin-bottom:2rem}
.sidebar-nav{flex:1}
.sidebar-nav a{display:flex;align-items:center;gap:.6rem;font-size:.75rem;font-weight:500;color:var(--text);padding:.6rem .75rem;border-radius:var(--r);margin-bottom:.2rem;transition:all .2s}
.sidebar-nav a:hover{color:var(--heading);background:var(--blue-light);opacity:1}
.sidebar-nav a.active{color:var(--blue);background:var(--blue-light);font-weight:600}
.sidebar-nav a .icon{font-size:.9rem;width:20px;text-align:center}
.sidebar-cta{margin-top:auto;padding-top:1rem;border-top:1px solid var(--border)}
.sidebar-cta a{display:block;text-align:center;padding:.6rem;background:var(--blue);color:#fff;border-radius:var(--r);font-size:.72rem;font-weight:700;transition:all .3s}
.sidebar-cta a:hover{background:var(--blue2);opacity:1;box-shadow:0 4px 12px rgba(59,130,246,.2)}
.sidebar-cta .tel{display:block;text-align:center;font-family:var(--fe);font-size:.7rem;color:var(--text);margin-top:.5rem}

/* === MAIN CONTENT (Offset by sidebar) === */
.main{margin-left:var(--sidebar)}

/* === Mobile: no sidebar === */
.mobile-hdr{display:none;position:fixed;top:0;left:0;width:100%;z-index:800;background:#fff;border-bottom:1px solid var(--border);padding:.75rem 1rem;justify-content:space-between;align-items:center}
.mobile-hdr .logo{font-family:var(--fe);font-size:.85rem;font-weight:800;color:var(--navy)}
.mobile-hdr .logo span{color:var(--blue)}
.mobile-hdr-btn{font-size:.65rem;font-weight:700;padding:.4rem 1rem;background:var(--blue);color:#fff;border-radius:var(--r)}
@media(max-width:900px){
  .sidebar{display:none}
  .main{margin-left:0}
  .mobile-hdr{display:flex}
  .main{padding-top:52px}
}

/* === HERO — Full-width banner with search bar === */
.hero-re{position:relative;background:var(--navy);padding:clamp(5rem,10vw,8rem) clamp(1.5rem,4vw,3rem) clamp(3rem,6vw,4rem);overflow:hidden}
.hero-re::before{content:'';position:absolute;inset:0;background:url('https://images.unsplash.com/photo-1560518883-ce09059eeffa?w=1920&h=800&fit=crop&q=80') center/cover;opacity:.15}
.hero-re-content{position:relative;z-index:1;max-width:600px}
.hero-re h1{font-size:clamp(1.5rem,3.5vw,2.5rem);font-weight:800;color:#fff;line-height:1.4;margin-bottom:.75rem}
.hero-re p{font-size:.82rem;color:rgba(255,255,255,.5);margin-bottom:1.5rem;line-height:1.9}
/* Search bar */
.search-bar{display:flex;gap:.5rem;background:#fff;padding:.5rem;border-radius:var(--r);box-shadow:0 8px 30px rgba(0,0,0,.1)}
.search-bar input{flex:1;padding:.6rem .85rem;border:1px solid var(--border);border-radius:6px;font-size:.8rem;font-family:var(--sans);outline:none}
.search-bar input:focus{border-color:var(--blue)}
.search-bar select{padding:.6rem .85rem;border:1px solid var(--border);border-radius:6px;font-size:.8rem;font-family:var(--sans);-webkit-appearance:none;background:#fff;outline:none;min-width:120px}
.search-bar button{padding:.6rem 1.5rem;background:var(--blue);color:#fff;border:none;border-radius:6px;font-size:.75rem;font-weight:700;cursor:pointer;font-family:var(--sans);transition:background .2s;white-space:nowrap}
.search-bar button:hover{background:var(--blue2)}
@media(max-width:640px){.search-bar{flex-direction:column}}

/* === PROPERTY CARDS === */
.section-re{padding:clamp(2rem,4vw,3rem) clamp(1.5rem,4vw,3rem)}
.section-re-hdr{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem}
.section-re-hdr h2{font-size:1.1rem;font-weight:800;color:var(--heading)}
.section-re-hdr a{font-size:.7rem;font-weight:600;color:var(--blue);display:flex;align-items:center;gap:.3rem;transition:gap .2s}
.section-re-hdr a:hover{gap:.6rem;opacity:1}

.prop-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem}
.prop{background:#fff;border:1px solid var(--border);border-radius:var(--r);overflow:hidden;transition:all .3s}
.prop:hover{box-shadow:0 8px 30px rgba(0,0,0,.06);transform:translateY(-3px)}
.prop img{width:100%;aspect-ratio:16/10;object-fit:cover}
.prop-body{padding:1rem 1.25rem}
.prop-price{font-family:var(--fe);font-size:1.1rem;font-weight:800;color:var(--blue);margin-bottom:.3rem}
.prop-price small{font-size:.65rem;font-weight:400;color:var(--text)}
.prop-name{font-size:.85rem;font-weight:700;color:var(--heading);margin-bottom:.25rem}
.prop-addr{font-size:.65rem;color:var(--text);margin-bottom:.5rem}
.prop-tags{display:flex;gap:.3rem;flex-wrap:wrap}
.prop-tag{font-size:.5rem;font-weight:600;padding:.15rem .5rem;border-radius:var(--r2);background:var(--blue-light);color:var(--blue)}
@media(max-width:768px){.prop-grid{grid-template-columns:1fr}}

/* === INFO CARDS === */
.info-grid-re{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem;margin-top:1.5rem}
.info-card-re{background:#fff;border:1px solid var(--border);border-radius:var(--r);padding:1.5rem;transition:all .3s}
.info-card-re:hover{border-color:var(--blue);box-shadow:0 4px 16px rgba(59,130,246,.06)}
.info-card-re .icon{font-size:1.5rem;margin-bottom:.75rem}
.info-card-re h3{font-size:.85rem;font-weight:700;color:var(--heading);margin-bottom:.3rem}
.info-card-re p{font-size:.7rem;line-height:1.8}
@media(max-width:768px){.info-grid-re{grid-template-columns:1fr}}

/* === STATS === */
.stats-re{display:grid;grid-template-columns:repeat(4,1fr);gap:1rem;margin-top:1.5rem}
.stat-re{background:#fff;border:1px solid var(--border);border-radius:var(--r);padding:1.25rem;text-align:center}
.stat-re-val{font-family:var(--fe);font-size:1.5rem;font-weight:800;color:var(--blue)}
.stat-re-lbl{font-size:.6rem;color:var(--text);margin-top:.15rem}
@media(max-width:640px){.stats-re{grid-template-columns:repeat(2,1fr)}}

/* === CTA === */
.cta-re{background:var(--navy);padding:clamp(3rem,6vw,4rem) clamp(1.5rem,4vw,3rem);text-align:center;color:#fff}
.cta-re h2{font-size:clamp(1.1rem,2.5vw,1.5rem);font-weight:800;margin-bottom:.5rem}
.cta-re p{font-size:.78rem;color:rgba(255,255,255,.4);margin-bottom:1.25rem}
.cta-re-btn{display:inline-flex;align-items:center;gap:.4rem;padding:.65rem 2rem;background:var(--blue);color:#fff;border-radius:var(--r);font-size:.75rem;font-weight:700;transition:all .3s}
.cta-re-btn:hover{opacity:1;background:var(--blue2);box-shadow:0 4px 16px rgba(59,130,246,.3)}

/* === FOOTER === */
.ftr-re{padding:1.5rem clamp(1.5rem,4vw,3rem);border-top:1px solid var(--border);display:flex;justify-content:space-between;font-size:.6rem;color:rgba(0,0,0,.2)}
@media(max-width:640px){.ftr-re{flex-direction:column;gap:.4rem}}

/* ANIMATIONS */
.sa{opacity:0;transform:translateY(18px);transition:opacity .6s cubic-bezier(.22,1,.36,1),transform .8s cubic-bezier(.22,1,.36,1)}
.sa.v{opacity:1;transform:none}
.d1{transition-delay:.1s}.d2{transition-delay:.2s}.d3{transition-delay:.3s}

.badge{position:fixed;bottom:1rem;right:1rem;font-size:.5rem;color:rgba(0,0,0,.1);display:flex;align-items:center;gap:.3rem;z-index:700}
.badge::before{content:'';width:4px;height:4px;background:var(--blue);border-radius:50%}
