:root { --primary: #ffccbc; --dark: #ff8a65; --bg: #fff5f0; --text: #5d4037; --muted: #8d6e63; --card: #fff; }
* { box-sizing: border-box; margin: 0; padding: 0; }
body { font-family: Meiryo, sans-serif; background: var(--bg); color: var(--text); }
a { color: var(--dark); }
img { max-width: 100%; height: auto; display: block; }
.pet-top { text-align: center; padding: 2rem 1rem 1rem; }
.pet-top h1 { font-size: 2rem; color: var(--dark); }
.pet-top p { color: var(--muted); margin-top: 0.5rem; }
.h-scroll-wrap { overflow: hidden; padding: 1rem 0 2rem; }
.h-scroll { display: flex; gap: 1.25rem; overflow-x: auto; scroll-snap-type: x mandatory; padding: 0 1.5rem 1rem; -webkit-overflow-scrolling: touch; }
.h-scroll::-webkit-scrollbar { height: 6px; }
.h-scroll::-webkit-scrollbar-thumb { background: var(--primary); border-radius: 3px; }
.h-card { flex: 0 0 260px; scroll-snap-align: start; background: var(--card); border-radius: 16px; overflow: hidden; cursor: pointer; box-shadow: 0 6px 20px rgba(255,138,101,0.15); }
.h-card img { height: 200px; width: 100%; object-fit: cover; }
.h-card .info { padding: 1rem; }
.h-card .price { color: var(--dark); font-weight: 700; }
.nav-dock { display: flex; justify-content: center; gap: 2rem; padding: 1rem; background: var(--card); border-top: 1px solid #ffe0d6; flex-wrap: wrap; }
.nav-dock button { border: none; background: none; font: inherit; color: var(--muted); cursor: pointer; padding: 0.5rem; }
.nav-dock button:hover { color: var(--dark); }
html { scroll-behavior: smooth; }
.block { scroll-margin-top: 1rem; }
a { color: var(--dark); }
.stack-products { max-width: 500px; margin: 2rem auto; padding: 0 1rem; }
.stack-products article { margin-bottom: 1.5rem; border-left: 4px solid var(--dark); padding-left: 1rem; cursor: pointer; }
.stack-products img { width: 100%; height: 180px; object-fit: cover; border-radius: 8px; margin-bottom: 0.5rem; }
.detail-pet { max-width: 640px; margin: 2rem auto; padding: 1.5rem; }
.detail-pet img { width: 100%; height: 350px; object-fit: cover; border-radius: 12px; }
.legal { max-width: 640px; margin: 0 auto 3rem; padding: 1.5rem; }
.legal h1 { color: var(--dark); margin-bottom: 1rem; }
.legal p { color: var(--muted); line-height: 1.75; margin-bottom: 0.65rem; }
