:root{--ink:#0f1720;--mut:#5f6b76;--line:#e8eef3;--acc:#0b74d1;--acc2:#00b894}
*{box-sizing:border-box}body{margin:0;background:#fff;color:var(--ink);font:16px/1.6 system-ui,-apple-system,Segoe UI,Roboto,Arial}
a{color:var(--acc);text-decoration:none}.btn{background:var(--acc);color:#fff;padding:10px 14px;border-radius:10px;font-weight:700;border:none}
.btn.p{background:var(--acc)}.btn.o{background:#fff;border:1px solid var(--acc);color:var(--acc)}
.h{display:flex;gap:12px;align-items:center;justify-content:space-between;padding:12px 16px;border-bottom:1px solid var(--line);background:#fff;position:sticky;top:0;z-index:20}
.n a{margin:0 8px}.lg{width:56px;height:56px;border-radius:50%;border:1px solid var(--line)}
.w{max-width:1080px;margin:0 auto;padding:18px}
.hero{display:grid;grid-template-columns:1.05fr .95fr;gap:28px;align-items:center}
.hero-img{width:min(36vw,520px);max-width:520px;height:auto;aspect-ratio:1/1;object-fit:cover;border-radius:50%;border:1px solid var(--line);box-shadow:0 10px 30px rgba(0,0,0,.08);justify-self:center}
.hero-txt h1{font-size:2.2rem;line-height:1.2;margin:.2rem 0 .6rem}
.btns .btn{margin-right:8px;margin-bottom:8px}
.m{color:var(--mut)}.gr,.gr3{display:grid;gap:14px}.gr{grid-template-columns:repeat(4,1fr)}.gr3{grid-template-columns:repeat(3,1fr)}
.card{background:#fff;border:1px solid var(--line);border-radius:14px;padding:16px}
.f{border-top:1px solid var(--line);padding:16px;text-align:center;color:var(--mut)}
.ttl{margin:12px 16px}
.p{font-size:1.2rem;font-weight:800;margin-top:8px}.hid{display:none}
.mapwrap{position:relative;width:100%;padding-top:56.25%}
.mapwrap iframe{position:absolute;left:0;top:0;width:100%;height:100%;border:0}
@media(min-width:1400px){
  .w{max-width:1200px}
  .hero{grid-template-columns:1fr 1fr}
  .hero-img{width:520px}
}
@media(max-width:900px){
  .hero{grid-template-columns:1fr;gap:18px}
  .hero-img{width:68vw;max-width:420px}
}


/* === Mobile refinements (<=480px) === */
@media(max-width:480px){
  .h{padding:10px 12px}
  .lg{width:46px;height:46px}
  .hero-txt h1{font-size:1.82rem;line-height:1.15;margin:.2rem 0 .4rem}
  .hero p{margin:.35rem 0}
  .btn{padding:12px 14px;font-weight:700}
  .btns{display:grid;grid-template-columns:1fr;gap:10px}
  .btns .btn{width:100%; text-align:center}
  .hero-img{width:72vw;max-width:360px;margin:10px auto 0}
  .m{font-size:.95rem}
}
/* Slightly narrow phones */
@media(max-width:360px){
  .hero-txt h1{font-size:1.68rem}
}
