:root{
  --cream:#fffaf0; --paper:#fffdf8; --green:#7a9366; --deep:#4f5d3f;
  --brown:#a57845; --ink:#5a4a39; --line:#e9dcc8; --sky:#d9edf1;
  --shadow:0 18px 50px rgba(116,88,48,.14); --radius:28px;
}
*{box-sizing:border-box} html{scroll-behavior:smooth} body{margin:0;color:var(--ink);background:radial-gradient(circle at 20% 0,#fff 0,#fff7e8 28%,#fdf7ec 100%);font-family:'Kosugi Maru',system-ui,sans-serif;line-height:1.9;letter-spacing:.04em;overflow-x:hidden}
a{color:inherit;text-decoration:none} img{max-width:100%}.site-header{position:sticky;top:0;z-index:20;display:flex;align-items:center;gap:30px;min-height:88px;padding:16px clamp(20px,5vw,72px);background:rgba(255,250,240,.86);backdrop-filter:blur(14px);border-bottom:1px solid rgba(214,198,176,.35)}.brand{display:flex;align-items:center;gap:10px;color:var(--brown);min-width:max-content}.brand-mark{width:50px;height:50px;border-radius:50%;display:grid;place-items:center;background:var(--brown);color:white;font-size:24px;box-shadow:inset 0 0 0 3px #fff3}.brand strong{display:block;font-family:'Zen Old Mincho',serif;font-size:34px;line-height:1}.brand small{display:block;font-size:12px;letter-spacing:.02em}.global-nav{display:flex;gap:28px;margin-left:auto;font-size:13px;font-weight:700}.global-nav a{position:relative}.global-nav a:after{content:"";position:absolute;left:0;right:0;bottom:-8px;height:2px;background:var(--green);transform:scaleX(0);transition:.25s}.global-nav a:hover:after{transform:scaleX(1)}.reserve-btn,.btn{display:inline-flex;align-items:center;justify-content:center;gap:10px;border-radius:999px;padding:14px 28px;font-weight:700;border:1px solid transparent;box-shadow:0 10px 24px rgba(88,112,72,.14);transition:.25s}.reserve-btn{background:var(--green);color:white}.reserve-btn:before{content:"▣"}.btn:after{content:"→"}.btn.primary{background:var(--green);color:white}.btn.secondary{background:#fffaf4;border-color:#c9ad8d;color:#6d5a45}.btn:hover,.reserve-btn:hover{transform:translateY(-2px)}.nav-toggle{display:none;margin-left:auto;border:0;background:var(--green);color:white;border-radius:12px;padding:8px 12px;font-size:22px}.hero{position:relative;display:grid;grid-template-columns:minmax(330px,45%) 1fr;align-items:center;min-height:720px;padding:30px clamp(24px,6vw,96px) 72px;overflow:hidden}.hero:after{content:"";position:absolute;left:-3%;right:-3%;bottom:30px;height:70px;background:var(--cream);border-radius:0 0 50% 50%;border-bottom:3px solid #dad0bd;z-index:0}.hero-copy{position:relative;z-index:2;padding-left:4vw}.eyebrow{color:var(--green);font-weight:700;text-transform:uppercase;letter-spacing:.12em}.hero h1,.hotel-text h2,.cta h2,.service-copy h2{font-family:'Zen Old Mincho',serif;font-weight:600;line-height:1.45;margin:.2em 0;color:#4c3e30}.hero h1{font-size:clamp(42px,5vw,78px)}.hero h1 span{color:var(--green)}.lead{font-weight:700;font-size:17px}.hero-actions{display:flex;gap:18px;flex-wrap:wrap;margin-top:28px}.hero-visual{position:relative;z-index:1;height:610px;border-radius:0 0 0 160px;overflow:hidden}.cafe-bg{position:absolute;inset:0;background:linear-gradient(90deg,rgba(255,250,240,.15),rgba(255,250,240,.45)),radial-gradient(circle at 72% 45%,#fff 0 8%,transparent 9%),linear-gradient(180deg,#fff7e6,#f5dfbd 62%,#d7b783 63%,#e8c98d);box-shadow:var(--shadow)}.cafe-bg:before{content:"";position:absolute;inset:0;background:repeating-linear-gradient(90deg,rgba(123,91,52,.08) 0 2px,transparent 2px 85px),linear-gradient(to bottom,transparent 62%,rgba(119,79,33,.15) 63% 64%,transparent 65%)}.counter{position:absolute;left:38%;top:20%;width:260px;height:150px;background:#9eb191;border-radius:18px 18px 6px 6px;color:white;text-align:center;padding-top:36px;font-family:'Zen Old Mincho',serif;font-size:26px;box-shadow:0 20px 40px #0001}.surfboard{position:absolute;right:14%;top:20%;width:45px;height:300px;border-radius:50% 50% 22px 22px;background:linear-gradient(90deg,#72a7b4 0 35%,#f7d89e 36% 48%,#6aa9b7 49%);transform:rotate(8deg);box-shadow:18px 10px 0 #ce996a}.dog{position:absolute;display:block;border-radius:45% 45% 40% 40%;background:radial-gradient(circle at 36% 32%,#362617 0 4px,transparent 5px),radial-gradient(circle at 65% 32%,#362617 0 4px,transparent 5px),radial-gradient(circle at 50% 45%,#5c3926 0 6px,transparent 7px),radial-gradient(circle at 50% 55%,#f6b6a0 0 9px,transparent 10px),#d89a55;box-shadow:inset 0 0 0 10px rgba(255,255,255,.15),0 24px 35px #5d3b1d22}.dog:before,.dog:after{content:"";position:absolute;top:12%;width:38%;height:48%;background:#c98743;border-radius:50%;z-index:-1}.dog:before{left:-22%;transform:rotate(18deg)}.dog:after{right:-22%;transform:rotate(-18deg)}.dog-main{right:26%;bottom:9%;width:230px;height:310px}.flower{position:absolute;color:#d87465;font-size:66px;text-shadow:8px 8px 0 #f2c88b;z-index:3}.flower-left{left:10px;bottom:72px}.leaf-right{right:30px;top:90px;font-size:90px;color:#6d875d;transform:rotate(25deg)}.worries{padding:30px clamp(24px,6vw,96px) 22px;text-align:center}.worries h2,.reasons h2,.day-flow h3{font-family:'Zen Old Mincho',serif;font-size:28px}.worry-list{display:grid;grid-template-columns:repeat(4,1fr);gap:30px;max-width:1100px;margin:22px auto}.worry-list article{display:flex;align-items:center;gap:16px;text-align:left;justify-content:center}.worry-list span{width:72px;height:72px;border:3px solid #dfdfca;border-radius:50%;display:grid;place-items:center;color:var(--green);font-size:36px}.worry-list p{font-size:13px;font-weight:700}.solution{font-family:'Zen Old Mincho',serif;font-size:30px;font-weight:700}.hotel-card,.reasons,.service-grid,.cta{max-width:1180px;margin:42px auto;padding:clamp(22px,4vw,42px);background:rgba(255,253,248,.84);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow);position:relative}.hotel-card{display:grid;grid-template-columns:40% 1fr;gap:20px;overflow:hidden}.hotel-text h2{font-size:40px}.hotel-text ul{list-style:none;padding:0}.hotel-text li{margin:8px 0;font-weight:700}.hotel-text li:before{content:"✓";color:var(--green);font-weight:900;margin-right:10px}.hotel-illustration{min-height:360px;border-radius:22px;background:linear-gradient(180deg,#fff8e9,#fff4d8 56%,#e0bf82 57%,#f2dba5);position:relative;overflow:hidden}.hotel-illustration:before{content:"";position:absolute;left:10%;top:8%;width:44%;height:48%;border:10px solid #f8ead5;border-radius:8px;background:linear-gradient(90deg,#e2f2f1,#fff6dc)}.hotel-illustration:after{content:"";position:absolute;right:8%;top:16%;width:120px;height:120px;background:#8cb0a8;border-radius:18px;box-shadow:-80px 30px 0 #82a5ac}.aloha{position:absolute;right:22%;top:12%;font-family:'Zen Old Mincho',serif;color:var(--green);font-size:28px;transform:rotate(-8deg)}.dog-a{left:38%;bottom:12%;width:80px;height:110px;background-color:#f0d09f}.dog-b{left:56%;bottom:10%;width:92px;height:126px}.dog-c{right:8%;bottom:12%;width:76px;height:100px;background-color:#2e2d2b}.day-flow{grid-column:1/-1;text-align:center;border-top:1px solid var(--line);padding-top:22px}.flow-items{display:grid;grid-template-columns:repeat(6,1fr);align-items:start;gap:12px;position:relative}.flow-items:before{content:"";position:absolute;left:8%;right:8%;top:47px;border-top:3px solid #d7d0ad}.flow-items article{position:relative;z-index:1}.flow-items span{display:block;width:86px;height:86px;margin:0 auto 10px;border-radius:50%;background:linear-gradient(145deg,#e8f6f6,#f8d7a4);border:6px solid #fbf7ec}.flow-items i{display:block;color:#c99038;font-style:normal;font-weight:700}.flow-items p{font-size:12px;font-weight:700}.reason-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:24px}.reason-grid article{background:#fffdf8;border:1px solid var(--line);border-radius:14px;padding:12px;text-align:center;box-shadow:0 8px 20px #0000000d}.photo,.service-photo{min-height:170px;border-radius:12px;background:linear-gradient(135deg,#f2dfc4,#fff7e8);position:relative;overflow:hidden}.photo:after,.service-photo:after{position:absolute;inset:auto 10px 10px 10px;display:grid;place-items:center;min-height:60%;border-radius:14px;background:rgba(255,255,255,.4);font-size:54px}.room:after{content:"🌿"}.sofa:after{content:"🐩"}.trim:after{content:"✂️"}.phone:after{content:"📱"}.reason-grid h3{color:var(--green);margin-bottom:0}.reason-grid p{font-size:13px;font-weight:700}.service-grid{display:grid;grid-template-columns:1.1fr 1fr 1fr 1fr;gap:16px;background:transparent;border:0;box-shadow:none;padding:0}.service-copy{background:rgba(255,253,248,.9);border:1px solid var(--line);border-radius:18px;padding:32px}.service-copy h2{font-size:29px}.service-photo{min-height:250px;box-shadow:var(--shadow)}.scissors:after{content:"🐩✂️"}.seminar:after{content:"👥"}.exterior:after{content:"🏠"}.class:after{content:"🧑‍🏫"}.goods:after{content:"🛍️"}.service-grid .goods{grid-column:span 2}.cta{display:grid;grid-template-columns:140px 1fr 270px;gap:24px;align-items:center;background:linear-gradient(180deg,#fffdf7 0,#e2f1ee 65%,#d6ecef 100%);overflow:hidden}.signpost{display:grid;gap:4px;transform:rotate(-3deg)}.signpost span{display:block;background:#c79659;color:#5b3a1e;padding:3px 10px;border-radius:4px;font-weight:700;text-align:center;border:2px solid #a97844}.cta h2{font-size:34px;margin:0}.cta-dogs{position:relative;height:150px}.cta-dogs span{position:absolute;bottom:0;width:105px;height:135px;border-radius:45%;background:#d99e58}.cta-dogs span:first-child{right:95px}.cta-dogs span:last-child{right:0;background:#6f6862}.site-footer{display:grid;grid-template-columns:auto 1fr auto;gap:20px;align-items:center;padding:34px clamp(24px,6vw,96px);background:#fff8e8;border-top:1px solid var(--line);font-size:13px}.site-footer nav{display:flex;gap:24px;justify-content:center;font-weight:700}.site-footer p{grid-column:2/3;margin:0;text-align:center}.sns{display:flex;gap:12px;color:var(--green);font-weight:700}.section-fade{opacity:0;transform:translateY(18px);transition:opacity .8s ease,transform .8s ease}.section-fade.is-visible{opacity:1;transform:none}@media (max-width:980px){.nav-toggle{display:block}.global-nav,.reserve-btn{display:none}.site-header.is-open .global-nav{display:grid;position:absolute;left:16px;right:16px;top:82px;padding:24px;background:#fffaf0;border:1px solid var(--line);border-radius:18px;box-shadow:var(--shadow)}.site-header.is-open .reserve-btn{display:flex;position:absolute;right:24px;top:330px}.hero{grid-template-columns:1fr;min-height:auto;padding-top:40px}.hero-copy{padding-left:0}.hero-visual{height:480px;border-radius:40px;margin-top:20px}.worry-list,.reason-grid{grid-template-columns:repeat(2,1fr)}.hotel-card{grid-template-columns:1fr}.service-grid{grid-template-columns:1fr 1fr}.cta{grid-template-columns:1fr}.site-footer{grid-template-columns:1fr;text-align:center}.site-footer nav{flex-wrap:wrap}.site-footer p{grid-column:auto}}@media (max-width:620px){.brand strong{font-size:26px}.hero h1{font-size:38px}.hero-actions{display:grid}.worry-list,.reason-grid,.service-grid,.flow-items{grid-template-columns:1fr}.flow-items:before{display:none}.service-grid .goods{grid-column:auto}.cta-dogs{display:none}.hotel-text h2,.service-copy h2,.cta h2{font-size:28px}}


/* Generated image assets */
.cafe-bg{
  background-image:linear-gradient(90deg,rgba(255,250,240,.08),rgba(255,250,240,.18)),url("../images/hero.png");
  background-size:cover;
  background-position:center;
}
.cafe-bg:before,.counter,.surfboard,.dog-main{display:none;}
.hotel-illustration{
  background-image:url("../images/hotel-room.png");
  background-size:cover;
  background-position:center;
}
.hotel-illustration:before,.hotel-illustration:after,.aloha,.hotel-illustration .dog{display:none;}
.photo,.service-photo{
  background-size:cover;
  background-position:center;
  background-repeat:no-repeat;
}
.photo:after,.service-photo:after{display:none;}
.room{background-image:url("../images/cage-free.png");}
.sofa{background-image:url("../images/stay.png");}
.trim{background-image:url("../images/health-support.png");}
.phone{background-image:url("../images/photo-share.png");}
.scissors{background-image:url("../images/trimming.png");}
.seminar{background-image:url("../images/seminar.png");}
.exterior{background-image:url("../images/exterior.png");}
.class{background-image:url("../images/seminar.png");}
.goods{background-image:url("../images/goods.png");}
.cta{
  background-image:linear-gradient(90deg,rgba(255,253,247,.94),rgba(226,241,238,.82)),url("../images/exterior.png");
  background-size:cover;
  background-position:center;
}

/* Additional generated mockup assets */
.worry-list span{
  color:transparent;
  font-size:0;
  border:none;
  border-radius:0;
  background-image:url("../images/worry-icons.png");
  background-repeat:no-repeat;
  background-size:400% 100%;
  background-position:0 0;
  width:86px;
  height:86px;
  flex:0 0 86px;
}
.worry-list article:nth-child(2) span{background-position:33.333% 0}
.worry-list article:nth-child(3) span{background-position:66.666% 0}
.worry-list article:nth-child(4) span{background-position:100% 0}

.flow-items i{display:none}
.flow-items span{
  width:96px;
  height:96px;
  background-color:transparent;
  border:none;
  background-image:url("../images/day-flow-icons.png");
  background-repeat:no-repeat;
  background-size:600% 100%;
  background-position:0 0;
  margin-bottom:12px;
}
.flow-items article:nth-child(2) span{background-position:20% 0}
.flow-items article:nth-child(3) span{background-position:40% 0}
.flow-items article:nth-child(4) span{background-position:60% 0}
.flow-items article:nth-child(5) span{background-position:80% 0}
.flow-items article:nth-child(6) span{background-position:100% 0}
.flow-items:before{top:48px}

.reason-grid article{position:relative;overflow:hidden}
.reason-grid article::after{
  content:"";
  position:absolute;
  right:8px;
  bottom:8px;
  width:54px;
  height:54px;
  background:url("../images/leaf-sprig.png") center/contain no-repeat;
  opacity:.9;
  pointer-events:none;
}

.hero .flower-left{
  color:transparent;
  text-shadow:none;
  font-size:0;
  width:128px;
  height:150px;
  left:-6px;
  bottom:48px;
  background:url("../images/corner-left.png") left bottom/contain no-repeat;
}
.hero .leaf-right{
  color:transparent;
  font-size:0;
  width:120px;
  height:120px;
  right:26px;
  top:92px;
  transform:none;
  background:url("../images/leaf-sprig.png") center/contain no-repeat;
}

.cta{
  background-image:linear-gradient(90deg,rgba(255,253,247,.92),rgba(255,253,247,.46) 34%,rgba(255,253,247,.22) 54%,rgba(255,253,247,.35) 100%),url("../images/cta-beach-bg.png");
  background-size:cover;
  background-position:center;
}
.cta::before,
.cta::after{
  content:"";
  position:absolute;
  bottom:0;
  pointer-events:none;
  z-index:0;
}
.cta::before{
  left:0;
  width:190px;
  height:190px;
  background:url("../images/corner-left.png") left bottom/contain no-repeat;
}
.cta::after{
  right:0;
  width:200px;
  height:210px;
  background:url("../images/corner-right.png") right bottom/contain no-repeat;
}
.cta > *{position:relative;z-index:1}
.signpost{
  min-height:250px;
  background:url("../images/cta-signpost.png") center/contain no-repeat;
  transform:none;
}
.signpost span{display:none}
.cta-dogs{
  height:180px;
  background:url("../images/cta-dogs.png") right bottom/contain no-repeat;
}
.cta-dogs span{display:none}

@media (max-width:980px){
  .cta::before{width:140px;height:140px}
  .cta::after{width:145px;height:150px}
  .signpost{min-height:220px;max-width:180px}
  .cta-dogs{height:160px}
}
@media (max-width:620px){
  .hero .flower-left{width:100px;height:112px;bottom:34px}
  .hero .leaf-right{width:92px;height:92px;top:72px;right:12px}
  .worry-list span,.flow-items span{margin-left:auto;margin-right:auto}
  .cta::before{width:110px;height:110px}
  .cta::after{width:115px;height:120px}
}

/* ===== Mockup refinement pass ===== */
body{
  background:#e9e5de;
  color:#5b4a39;
}
.site-header,
main,
.site-footer{
  max-width:1540px;
  margin-left:auto;
  margin-right:auto;
}
.site-header{
  margin-top:10px;
  padding:18px clamp(18px,3vw,36px);
  border:1px solid #dbcdb8;
  border-bottom:none;
  border-radius:34px 34px 0 0;
  background:rgba(255,251,245,.92);
  box-shadow:none;
}
main{
  background:#fffdf8;
  border-left:1px solid #dbcdb8;
  border-right:1px solid #dbcdb8;
}
.site-footer{
  border:1px solid #dbcdb8;
  border-top:none;
  border-radius:0 0 34px 34px;
  background:#fff8ea;
  margin-bottom:12px;
}
.section-fade{opacity:1;transform:none}

.hero{
  min-height:680px;
  padding:14px 48px 86px;
  background:
    linear-gradient(90deg,#fffdf9 0 43%,rgba(255,253,249,.90) 50%,rgba(255,253,249,.35) 58%,rgba(255,253,249,0) 62%),
    radial-gradient(circle at 2% 10%, rgba(113,149,120,.11), transparent 18%),
    #fffdf8;
  border-bottom:1px solid #ebe0cf;
}
.hero:before{
  content:"";
  position:absolute;
  inset:0;
  background:linear-gradient(90deg,rgba(255,255,255,.84) 0 34%,rgba(255,255,255,.52) 40%,rgba(255,255,255,0) 56%);
  z-index:0;
  pointer-events:none;
}
.hero:after{
  left:3%;
  right:3%;
  bottom:18px;
  height:62px;
  background:transparent;
  border-bottom:3px solid #d9d0bd;
  border-radius:0 0 55% 55% / 0 0 100% 100%;
}
.hero-copy,
.hero-visual,
.hero .flower-left,
.hero .leaf-right{z-index:1}
.hero-copy{max-width:580px;padding-left:12px}
.hero .eyebrow{display:none}
.hero h1{
  font-size:clamp(40px,4.3vw,68px);
  line-height:1.55;
  letter-spacing:.03em;
  margin-bottom:18px;
}
.hero .lead{font-size:18px;line-height:2.0;font-weight:700}
.hero-visual{
  height:585px;
  border-radius:24px;
  box-shadow:none;
}
.cafe-bg{border-radius:24px}
.hero-actions .btn{min-width:248px}
.reserve-btn{padding:14px 22px}
.global-nav{gap:20px}
.brand strong{font-size:30px}
.brand-mark{width:56px;height:56px}

.worries{
  padding-top:30px;
  padding-bottom:34px;
}
.worries h2{
  font-size:clamp(30px,3vw,42px);
  margin-bottom:22px;
}
.worry-list{
  gap:30px;
  align-items:start;
}
.worry-list article{gap:12px}
.worry-list p{font-size:15px;line-height:1.75}
.worry-list span{
  width:92px;
  height:92px;
  background-image:none;
  background-size:contain;
  background-repeat:no-repeat;
  background-position:center;
}
.worry-list article:nth-child(1) span{background-image:url("../images/worries/worry-01-cage.png")}
.worry-list article:nth-child(2) span{background-image:url("../images/worries/worry-02-suitcase.png")}
.worry-list article:nth-child(3) span{background-image:url("../images/worries/worry-03-care.png")}
.worry-list article:nth-child(4) span{background-image:url("../images/worries/worry-04-heart.png")}
.solution{font-size:22px;margin-top:8px}

.hotel-card{
  grid-template-columns:minmax(300px,38%) 1fr;
  gap:28px 26px;
  margin-top:8px;
  padding:30px 34px 34px;
  border-radius:30px;
  background:#fffdf8;
  box-shadow:none;
}
.hotel-text h2{font-size:48px;line-height:1.55;margin-top:4px}
.hotel-text p,
.hotel-text li{font-size:16px}
.hotel-illustration{
  min-height:382px;
  border-radius:22px;
  border:1px solid #efe5d4;
}
.day-flow{
  padding-top:24px;
  margin-top:4px;
}
.day-flow h3{
  font-family:'Zen Old Mincho',serif;
  font-size:26px;
  font-weight:600;
  margin:0 0 18px;
  color:#564637;
}
.day-flow h3 small{font-size:.78em;color:#6b5a49}
.flow-items{
  grid-template-columns:repeat(6,minmax(0,1fr));
  gap:10px;
  align-items:start;
}
.flow-items:before{
  left:4%;
  right:4%;
  top:66px;
  border-top:5px solid #d9d0ad;
}
.flow-items article{padding:0 4px}
.flow-items span{
  width:132px;
  height:132px;
  margin:0 auto 14px;
  background-image:none;
  background-size:contain;
  background-position:center;
  background-repeat:no-repeat;
}
.flow-items article:nth-child(1) span{background-image:url("../images/day-flow/day-01-walk.png")}
.flow-items article:nth-child(2) span{background-image:url("../images/day-flow/day-02-play.png")}
.flow-items article:nth-child(3) span{background-image:url("../images/day-flow/day-03-nap.png")}
.flow-items article:nth-child(4) span{background-image:url("../images/day-flow/day-04-staff.png")}
.flow-items article:nth-child(5) span{background-image:url("../images/day-flow/day-05-evening-walk.png")}
.flow-items article:nth-child(6) span{background-image:url("../images/day-flow/day-06-night-sleep.png")}
.flow-items p{
  font-size:14px;
  line-height:1.5;
  letter-spacing:.02em;
  color:#5f4f3e;
  margin:0;
  white-space:nowrap;
}

.reasons{padding-top:28px}
.reasons h2{
  font-family:'Zen Old Mincho',serif;
  font-size:34px;
  margin-bottom:18px;
}
.reason-grid article{
  border-radius:16px;
  padding:12px;
}
.reason-grid .photo{min-height:180px}
.reason-grid h3{font-size:26px;font-family:'Zen Old Mincho',serif;font-weight:600}
.reason-grid p{font-size:14px;line-height:1.7;margin:8px 8px 10px}

.service-grid{
  margin-top:18px;
  gap:18px;
}
.service-copy,
.service-photo{
  border-radius:18px;
  border:1px solid #ebe0cf;
}
.service-copy{padding:34px 28px}
.service-copy h2{
  font-size:38px;
  line-height:1.55;
  margin-top:0;
}
.service-copy p{font-size:15px;line-height:1.9}
.service-photo{min-height:280px}

.cta{
  margin-top:18px;
  border-top:1px solid #e9dcc8;
  border-bottom:1px solid #e9dcc8;
  border-radius:0 0 30px 30px;
  grid-template-columns:210px 1fr 360px;
  min-height:220px;
  padding:28px 24px 18px;
}
.cta h2{
  font-size:48px;
  line-height:1.65;
  margin-bottom:8px;
}
.cta p{font-size:16px;font-weight:700;margin:0 0 20px}
.signpost{min-height:262px;background-position:left bottom}
.cta-dogs{height:210px;background-size:contain;background-position:right bottom}

@media (max-width:1200px){
  .hero{grid-template-columns:1fr;gap:18px;padding:18px 28px 74px}
  .hero-copy{max-width:none;padding-left:0}
  .hero-visual{height:500px}
  .flow-items span{width:112px;height:112px}
  .flow-items p{white-space:normal;font-size:13px}
  .cta{grid-template-columns:170px 1fr 260px}
  .cta h2{font-size:40px}
}
@media (max-width:980px){
  .site-header{border-radius:26px 26px 0 0}
  main{border-left:1px solid #dbcdb8;border-right:1px solid #dbcdb8}
  .worry-list{grid-template-columns:repeat(2,1fr)}
  .hotel-card{grid-template-columns:1fr;padding:24px}
  .flow-items{grid-template-columns:repeat(3,1fr);row-gap:24px}
  .flow-items:before{display:none}
  .flow-items p{white-space:normal}
  .service-grid{grid-template-columns:1fr 1fr}
  .cta{grid-template-columns:1fr;gap:18px}
  .cta-dogs{display:block;max-width:320px;width:100%;margin-left:auto}
  .signpost{max-width:180px}
}
@media (max-width:620px){
  .site-header{padding:14px 16px}
  .hero{padding:14px 16px 58px}
  .hero h1{font-size:34px}
  .hero .lead{font-size:15px}
  .hero-actions .btn{min-width:0;width:100%}
  .worries,.reasons{padding-left:16px;padding-right:16px}
  .hotel-card{margin-left:16px;margin-right:16px;padding:20px}
  .hotel-text h2,.service-copy h2,.cta h2{font-size:30px}
  .flow-items{grid-template-columns:1fr 1fr;gap:18px 12px}
  .flow-items span{width:108px;height:108px}
  .flow-items p{font-size:12px}
  .reason-grid,.service-grid{grid-template-columns:1fr}
  .service-grid{padding:0 16px}
  .cta{padding:22px 16px;border-radius:0 0 24px 24px}
  .cta-dogs{display:none}
  .site-footer{border-radius:0 0 24px 24px;padding:24px 16px}
}

/* ===== Final comparison-based adjustments ===== */
main,
.site-header,
.site-footer{max-width:1650px;}

.hero{
  grid-template-columns:minmax(420px,42%) 1fr;
  min-height:620px;
  padding:16px 28px 54px;
}
.hero:before{
  background:linear-gradient(90deg,rgba(255,255,255,.90) 0 37%,rgba(255,255,255,.55) 44%,rgba(255,255,255,.08) 58%,rgba(255,255,255,0) 66%);
}
.hero:after{
  left:2.5%;
  right:2.5%;
  bottom:8px;
  height:36px;
  border-bottom-width:2px;
}
.hero-copy{
  padding:8px 0 0 18px;
  max-width:640px;
}
.hero h1{
  font-size:clamp(34px,4.2vw,64px);
  line-height:1.72;
  letter-spacing:.02em;
  margin-bottom:14px;
}
.hero .lead{
  font-size:17px;
  line-height:1.95;
}
.hero-actions{margin-top:22px}
.hero-actions .btn{
  min-width:220px;
  padding:14px 24px;
  font-size:14px;
}
.hero-visual{
  height:500px;
  align-self:start;
}
.hero .flower-left{left:-2px;bottom:24px;width:108px;height:124px}
.hero .leaf-right{top:76px;right:20px;width:100px;height:100px}

.worries{
  padding-top:16px;
  padding-bottom:28px;
}
.worries h2{margin-bottom:16px}
.worry-list{gap:18px}
.worry-list article{gap:10px}
.worry-list p{font-size:14px}
.solution{font-size:18px}

.hotel-card{
  max-width:1500px;
  margin-left:auto;
  margin-right:auto;
  padding:24px 26px 28px;
}
.hotel-text h2{
  font-size:44px;
  line-height:1.58;
}
.hotel-text p, .hotel-text li{font-size:15px}
.hotel-illustration{min-height:350px}
.day-flow{
  padding-top:18px;
}
.day-flow h3{font-size:24px;margin-bottom:14px}
.flow-items{
  gap:6px;
}
.flow-items:before{
  left:5%;
  right:5%;
  top:52px;
  border-top-width:4px;
}
.flow-items article{
  max-width:170px;
  margin:0 auto;
}
.flow-items span{
  width:clamp(78px,5.8vw,96px);
  height:clamp(78px,5.8vw,96px);
  margin-bottom:8px;
}
.flow-items p{
  font-size:11px;
  line-height:1.45;
  white-space:normal;
}

.reasons{padding-top:22px}
.reasons h2{font-size:32px}
.reason-grid{gap:16px}
.reason-grid .photo{min-height:160px}
.reason-grid h3{font-size:24px}

.service-grid{gap:14px}
.service-copy{padding:28px 24px}
.service-copy h2{font-size:34px}
.service-copy p{font-size:14px}
.service-photo{min-height:250px}

.cta{
  grid-template-columns:180px 1fr 300px;
  min-height:200px;
  padding:20px 22px 14px;
}
.cta h2{font-size:38px;line-height:1.55}
.cta p{font-size:14px;margin-bottom:14px}
.signpost{min-height:220px}
.cta-dogs{height:170px}

.site-footer{padding:26px 24px}
.site-footer nav{gap:18px;font-size:12px}
.site-footer p{font-size:12px}

@media (max-width:1100px){
  .hero{grid-template-columns:1fr;padding:16px 22px 46px}
  .hero-copy{max-width:none;padding-left:0}
  .hero h1{font-size:42px;line-height:1.6}
  .hero-visual{height:440px}
  .hotel-card{padding:22px}
  .flow-items{grid-template-columns:repeat(3,1fr);row-gap:16px}
  .flow-items:before{display:none}
  .flow-items span{width:92px;height:92px}
  .flow-items p{font-size:12px}
  .cta{grid-template-columns:1fr;gap:12px}
}
@media (max-width:700px){
  .hero h1{font-size:34px}
  .hero .lead{font-size:15px}
  .worry-list{grid-template-columns:1fr 1fr}
  .flow-items{grid-template-columns:repeat(2,1fr)}
  .flow-items span{width:88px;height:88px}
  .service-grid{grid-template-columns:1fr}
  .cta h2{font-size:28px}
}

/* =====================================================================
   Mockup fidelity pass
   - Hero: 右側を main の右端まで全幅で配置、写真下端を大きな曲線でカット
   - Hotel illustration: 右端まで全幅、下端を曲線
   - Photo cards (reason / service): 下端をやさしい曲線に
   - 装飾の調整
   ===================================================================== */

/* ----- Hero ----- */
.hero{
  padding:14px 0 38px 0;          /* 下パディングを圧縮 */
  grid-template-columns:minmax(420px,43%) 1fr;
  column-gap:0;
  overflow:hidden;
  min-height:auto;
}
.hero-copy{
  padding:14px 22px 0 clamp(22px,2.4vw,46px);
  max-width:none;
}
.hero h1{
  font-size:clamp(30px,3.4vw,52px);
  line-height:1.55;
  word-break:keep-all;
  overflow-wrap:break-word;
  margin-bottom:14px;
}
.hero .lead{font-size:15px;line-height:1.95}
.hero-visual{
  height:430px;                    /* 600 → 430 に圧縮 */
  align-self:start;
  margin:0;
  border-radius:0;
  overflow:visible;
  position:relative;
  z-index:1;
}
.cafe-bg{
  position:absolute;
  inset:0;
  border-radius:60px 0 50% 50% / 60px 0 12% 12%;
  /* 浅く広いカーブに調整 */
  box-shadow:0 18px 40px rgba(116,88,48,.14);
}
.hero:after{
  left:2.5%;
  right:2.5%;
  bottom:6px;
  height:24px;
  border-bottom:1px solid #d9d0bd;
  border-radius:0 0 55% 55% / 0 0 100% 100%;
  background:transparent;
}
/* 左下装飾 */
.hero .flower-left{
  left:0;
  bottom:14px;
  width:120px;
  height:135px;
  z-index:2;
}
/* 右上リーフは写真の上に被せる */
.hero .leaf-right{
  top:24px;
  right:6px;
  width:108px;
  height:108px;
  opacity:1;
  z-index:2;
}

/* ----- Hotel illustration: 右端ブリード + 下端カーブ ----- */
.hotel-card{
  overflow:hidden;
  padding:24px 0 22px 26px;        /* 全体パディング圧縮 */
  grid-template-columns:minmax(320px,40%) 1fr;
  max-width:1200px;
}
.hotel-text{
  padding-right:18px;
}
.hotel-text h2{
  font-size:clamp(26px,2.6vw,36px);
  line-height:1.55;
  word-break:keep-all;
  overflow-wrap:break-word;
  margin-top:4px;
}
.hotel-text p,
.hotel-text li{font-size:14px;line-height:1.85}
.service-copy h2{
  font-size:clamp(22px,2.2vw,30px);
  word-break:keep-all;
  overflow-wrap:break-word;
  line-height:1.55;
}
.service-copy p{font-size:13px;line-height:1.85}
.service-copy{padding:24px 22px}
.hotel-illustration{
  margin-right:0;
  border:none;
  border-radius:24px 0 44% 44% / 24px 0 10% 10%;
  min-height:330px;
  box-shadow:0 14px 30px rgba(116,88,48,.12);
}
@media (max-width:980px){
  .hotel-card{padding-right:24px}
  .hotel-text{padding-right:0}
  .hotel-illustration{
    border-radius:24px 24px 38% 38% / 24px 24px 14% 14%;
  }
}

/* ----- 選ばれる理由カード: 写真下端をやさしい曲線に ----- */
.reasons{padding:22px;max-width:1200px}
.reasons h2{font-size:26px;margin-bottom:14px}
.reason-grid{gap:14px}
.reason-grid .photo{
  min-height:130px;
  border-radius:12px 12px 38% 38% / 12px 12px 12% 12%;
}
.reason-grid h3{font-size:18px;margin-top:8px}
.reason-grid p{font-size:12px;line-height:1.7;margin:6px 6px 8px}

/* ----- サービス写真（トリミング/セミナー/外観）: 下端を曲線に ----- */
.service-grid{gap:10px;max-width:1200px}
.service-photo{
  min-height:236px;
  border-radius:14px 14px 32% 32% / 14px 14px 9% 9%;
}

/* ----- お悩み: 圧縮 ----- */
.worries{padding-top:18px;padding-bottom:18px}
.worries h2{font-size:24px;margin-bottom:14px}
.worry-list{gap:18px}
.worry-list span{width:74px;height:74px}
.worry-list p{font-size:12px;line-height:1.65}
.solution{font-size:16px;margin-top:6px}

/* ----- 1日の過ごし方: アイコンを小さく、線を細く ----- */
.day-flow h3{font-size:20px;margin-bottom:12px}
.flow-items{gap:6px}
.flow-items:before{
  top:38px;
  border-top:2px solid #d9d0ad;
}
.flow-items span{
  width:74px;
  height:74px;
  margin-bottom:6px;
}
.flow-items p{
  font-size:11px;
  line-height:1.45;
}

/* ----- CTA: 圧縮 ----- */
.cta{
  min-height:170px;
  padding:14px 22px 12px;
  grid-template-columns:160px 1fr 280px;
}
.cta h2{font-size:30px;line-height:1.5;margin-bottom:6px}
.cta p{font-size:13px;margin-bottom:10px}
.signpost{min-height:180px}
.cta-dogs{height:160px}

/* ----- フッター: 圧縮 ----- */
.site-footer{padding:14px 22px}
.site-footer p{font-size:11px}
.site-header .brand strong{font-size:26px;letter-spacing:.01em}
.site-footer .brand strong{font-size:22px}
.brand small{font-size:11px}
.brand-mark{width:50px;height:50px;font-size:22px}
.site-footer .brand-mark{width:42px;height:42px;font-size:18px}

/* ----- Hero photo を背景に少しなじませる（box-shadow 軽減＋下端ぼかし） ----- */
.cafe-bg{
  box-shadow:0 12px 28px rgba(116,88,48,.10);
}

/* ----- ヒーロー画像のレスポンシブ調整 ----- */
@media (max-width:1100px){
  .hero{
    padding:14px 0 38px 0;
    grid-template-columns:1fr;
  }
  .hero-copy{
    padding:8px 22px 0 22px;
  }
  .hero-visual{height:360px}
  .cafe-bg{
    border-radius:32px 32px 46% 46% / 32px 32px 12% 12%;
    margin:0 22px;
    inset:0;
  }
  .hotel-card{padding-right:24px}
  .hotel-text{padding-right:0}
  .hotel-illustration{
    border-radius:22px 22px 36% 36% / 22px 22px 10% 10%;
  }
}
@media (max-width:700px){
  .hero-visual{height:280px}
  .cafe-bg{
    border-radius:22px 22px 46% 46% / 22px 22px 14% 14%;
    margin:0 14px;
  }
  .hero .flower-left{width:88px;height:99px;bottom:8px}
  .hero .leaf-right{width:64px;height:64px;top:18px}
  .reason-grid .photo,
  .service-photo{
    border-radius:12px 12px 30% 30% / 12px 12px 14% 14%;
  }
}

/* =====================================================================
   v6: Hero overlay redesign + 全体レスポンシブ化（clamp / vw）
   - Hero: 写真を section 全体の背景に、テキストを左にオーバーレイ
   - 左側に半透明のクリームグラデで可読性確保
   - 全セクションを clamp() で固定px値を解消
   ===================================================================== */

/* ===== Layout: 外側コンテナを vw 連動に ===== */
.site-header,
main,
.site-footer{
  max-width:min(1540px, 100%);
  width:100%;
}

/* ===== Hero: 写真背景＋テキストオーバーレイ ===== */
.hero{
  position:relative;
  display:block;                   /* grid を解除 */
  min-height:clamp(360px, 42vw, 580px);
  padding:0;
  overflow:hidden;
  background:
    linear-gradient(90deg,
      rgba(255,251,243,.94) 0 24%,
      rgba(255,251,243,.62) 42%,
      rgba(255,251,243,.18) 58%,
      rgba(255,251,243,0) 70%),
    url("../images/hero.png") center right / cover no-repeat;
  background-color:#fffdf8;
  border-bottom:1px solid #ebe0cf;
}
/* 旧構造（カードカラム）を退避 */
.hero-visual,
.hero-visual .cafe-bg{display:none}
/* 旧オーバーレイ／カーブを撤去 */
.hero:before,
.hero:after{display:none !important}

.hero-copy{
  position:relative;
  z-index:2;
  max-width:clamp(320px, 52%, 640px);
  padding:clamp(40px, 5.4vw, 88px) clamp(20px, 4vw, 56px) clamp(36px, 4.4vw, 64px);
  margin:0;
}
.hero .eyebrow{
  display:block;
  color:var(--green);
  font-weight:700;
  letter-spacing:.14em;
  font-size:clamp(11px, .9vw, 13px);
  margin-bottom:8px;
  text-transform:uppercase;
}
.hero h1{
  font-family:'Zen Old Mincho',serif;
  font-weight:600;
  font-size:clamp(28px, 3.8vw, 54px);
  line-height:1.5;
  letter-spacing:.02em;
  margin:0 0 clamp(12px, 1.4vw, 18px);
  color:#4c3e30;
  word-break:keep-all;
  overflow-wrap:break-word;
}
.hero h1 span{color:var(--green)}
.hero .lead{
  font-size:clamp(13px, 1.05vw, 16px);
  line-height:1.95;
  font-weight:700;
  color:#5a4a39;
  margin:0 0 clamp(20px, 2.5vw, 32px);
}
.hero-actions{
  display:flex;
  gap:clamp(10px, 1.2vw, 18px);
  flex-wrap:wrap;
}
.hero-actions .btn{
  min-width:clamp(160px, 18vw, 230px);
  padding:clamp(11px, 1.1vw, 15px) clamp(18px, 2vw, 28px);
  font-size:clamp(12px, .95vw, 14px);
}
/* 装飾: 左下フラワーは残す、右リーフは写真にあるので非表示 */
.hero .flower-left{
  z-index:3;
  left:clamp(-4px, .4vw, 8px);
  bottom:clamp(6px, 1.2vw, 18px);
  width:clamp(82px, 8.4vw, 124px);
  height:clamp(92px, 9.4vw, 138px);
  background:url("../images/corner-left.png") left bottom/contain no-repeat;
  color:transparent;font-size:0;text-shadow:none;
}
.hero .leaf-right{display:none}

/* ===== タブレット: 〜1024px ===== */
@media (max-width:1024px){
  .hero{
    min-height:clamp(340px, 50vw, 480px);
    background:
      linear-gradient(90deg,
        rgba(255,251,243,.95) 0 32%,
        rgba(255,251,243,.65) 52%,
        rgba(255,251,243,.20) 70%,
        rgba(255,251,243,0) 82%),
      url("../images/hero.png") center right / cover no-repeat;
  }
  .hero-copy{
    max-width:64%;
    padding:clamp(30px, 5vw, 56px) clamp(18px, 3.2vw, 36px);
  }
}

/* ===== SP: 〜700px (テキストを上、写真は下にフェードで重ねる) ===== */
@media (max-width:700px){
  .hero{
    min-height:520px;
    background:
      linear-gradient(180deg,
        rgba(255,251,243,.96) 0 38%,
        rgba(255,251,243,.66) 56%,
        rgba(255,251,243,.10) 78%,
        rgba(255,251,243,0) 100%),
      url("../images/hero.png") center 60% / cover no-repeat;
  }
  .hero-copy{
    max-width:100%;
    padding:24px 18px 20px;
  }
  .hero h1{
    font-size:clamp(28px, 8vw, 38px);
    line-height:1.5;
  }
  .hero-actions{flex-direction:column;width:100%}
  .hero-actions .btn{min-width:0;width:100%}
  .hero .flower-left{
    width:74px;height:84px;bottom:6px;left:-4px;
    opacity:.85;
  }
}

/* ===== セクション全体のレスポンシブ・クランプ化 ===== */
.worries,
.reasons,
.cta{
  padding-left:clamp(16px, 3vw, 36px);
  padding-right:clamp(16px, 3vw, 36px);
}
.hotel-card{
  padding:clamp(18px, 2.4vw, 26px) 0 clamp(18px, 2vw, 22px) clamp(18px, 2.4vw, 26px);
}
.service-grid{
  padding:0 clamp(16px, 3vw, 36px);
}
.service-copy{
  padding:clamp(18px, 2.6vw, 28px) clamp(16px, 2.2vw, 24px);
}
.site-header{
  padding:clamp(12px, 1.6vw, 20px) clamp(16px, 3vw, 36px);
}
.site-footer{
  padding:clamp(12px, 1.6vw, 18px) clamp(16px, 3vw, 28px);
}

/* タブレット時: hotel-card / service-grid を縦組みに */
@media (max-width:1024px){
  .hotel-card{
    grid-template-columns:1fr;
    padding-right:clamp(18px, 3vw, 28px);
  }
  .hotel-text{padding-right:0}
  .hotel-illustration{
    border-radius:22px 22px 36% 36% / 22px 22px 10% 10%;
    min-height:clamp(220px, 36vw, 320px);
  }
  .service-grid{
    grid-template-columns:1fr 1fr;
    gap:12px;
  }
  .service-grid .goods{grid-column:auto}
  .reason-grid{grid-template-columns:repeat(2,1fr)}
  .worry-list{grid-template-columns:repeat(2,1fr)}
  .flow-items{grid-template-columns:repeat(3,1fr);row-gap:18px}
  .flow-items:before{display:none}
  .cta{
    grid-template-columns:1fr;
    text-align:center;
    gap:14px;
  }
  .cta-dogs{margin:0 auto}
  .signpost{margin:0 auto}
}

/* SP: 1カラム化 ＆ 文字さらに圧縮 */
@media (max-width:700px){
  .site-header{
    flex-wrap:wrap;
    gap:12px;
    padding:12px 16px;
  }
  .global-nav{display:none}
  .site-header.is-open .global-nav{
    display:grid;
    grid-template-columns:1fr;
    gap:8px;
    width:100%;
    padding:12px;
    background:#fffaf0;
    border:1px solid var(--line);
    border-radius:14px;
  }
  .reserve-btn{display:none}
  .site-header.is-open .reserve-btn{display:flex;width:100%}
  .nav-toggle{display:block;margin-left:auto}

  .worry-list{grid-template-columns:repeat(2,1fr);gap:14px}
  .worry-list article{flex-direction:column;text-align:center;align-items:center}
  .worry-list span{margin:0 auto}
  .worry-list p{text-align:center}

  .reason-grid{grid-template-columns:1fr 1fr;gap:12px}
  .reason-grid h3{font-size:16px}
  .reason-grid p{font-size:11px}

  .flow-items{grid-template-columns:repeat(2,1fr);row-gap:16px;gap:12px}
  .flow-items span{width:clamp(64px, 18vw, 84px);height:clamp(64px, 18vw, 84px)}

  .service-grid{grid-template-columns:1fr;gap:10px}
  .service-copy h2{font-size:clamp(20px, 6vw, 26px)}

  .cta h2{font-size:clamp(22px, 5.5vw, 28px)}
  .cta-dogs{height:140px;max-width:280px}
  .signpost{min-height:150px;max-width:160px}

  .site-footer{
    grid-template-columns:1fr;
    text-align:center;
    gap:10px;
  }
  .site-footer nav{flex-wrap:wrap;justify-content:center;gap:12px}
  .site-footer p{grid-column:auto;font-size:10px}
}



/* =====================================================================
   v7: 公式ロゴ・本家サイト準拠フッター・サブページ共通スタイル
   ===================================================================== */

/* ----- 旧 brand-mark を撤去し brand-logo に置換 ----- */
.brand{
  gap:14px;
  align-items:center;
  text-decoration:none;
  color:inherit;
}
.brand-mark{display:none}
.brand-logo{
  height:clamp(34px, 3.6vw, 52px);
  width:auto;
  display:block;
}
.site-footer .brand-logo{
  height:clamp(28px, 2.8vw, 38px);
}
.brand-tag{
  display:block;
  font-size:clamp(10px, .85vw, 12px);
  letter-spacing:.06em;
  color:#7a6553;
  font-family:'Zen Old Mincho',serif;
  margin-top:2px;
}
/* 旧 brand>span>strong の塊スタイルを上書き */
.brand strong,
.site-header .brand strong,
.site-footer .brand strong,
.brand small{
  display:none !important;
}

/* ----- フッターのリッチ化 ----- */
.site-footer{
  display:grid;
  grid-template-columns:auto 1fr auto;
  gap:18px clamp(20px, 3vw, 36px);
  align-items:center;
}
.footer-nav{
  display:flex;
  flex-wrap:wrap;
  gap:clamp(10px, 1.4vw, 22px);
  justify-content:center;
  font-weight:700;
  font-size:clamp(11px, .9vw, 13px);
}
.footer-nav a{
  color:#5b4a39;
  position:relative;
}
.footer-nav a:hover{color:var(--green)}
.footer-info{
  grid-column:1 / -1;
  text-align:center;
  font-size:clamp(11px, .85vw, 13px);
  color:#6b5a47;
  margin:6px 0 0;
}
.footer-info a{color:inherit;font-weight:700}
.footer-info a:hover{color:var(--green)}
.site-footer .sns{
  display:flex;
  gap:clamp(8px, 1.2vw, 14px);
  font-size:clamp(11px, .85vw, 13px);
  font-weight:700;
}
.site-footer .sns a{
  color:var(--green);
  padding:4px 10px;
  border:1px solid var(--green);
  border-radius:999px;
  transition:.2s;
}
.site-footer .sns a:hover{background:var(--green);color:#fff}
@media (max-width:980px){
  .site-footer{
    grid-template-columns:1fr;
    text-align:center;
  }
  .site-footer .sns{justify-content:center}
}

/* ----- サブページ共通: page-hero ----- */
.page-hero{
  position:relative;
  min-height:clamp(180px, 22vw, 280px);
  padding:clamp(40px, 5vw, 80px) clamp(20px, 4vw, 56px);
  background:
    linear-gradient(90deg, rgba(255,251,243,.94) 0 30%, rgba(255,251,243,.55) 50%, rgba(255,251,243,.10) 70%, transparent 80%),
    url("../images/hero.png") center / cover no-repeat;
  background-color:#fffdf8;
  display:flex;
  flex-direction:column;
  justify-content:center;
}
.page-hero .eyebrow{
  color:var(--green);
  font-weight:700;
  letter-spacing:.14em;
  font-size:clamp(11px, .9vw, 13px);
  margin-bottom:8px;
  text-transform:uppercase;
}
.page-hero h1{
  font-family:'Zen Old Mincho',serif;
  font-weight:600;
  font-size:clamp(28px, 3.6vw, 48px);
  line-height:1.5;
  margin:0;
  color:#4c3e30;
}

/* ----- サブページ共通: コンテンツコンテナ ----- */
.page-section{
  max-width:1100px;
  margin:0 auto;
  padding:clamp(28px, 4vw, 56px) clamp(18px, 3vw, 36px);
}
.page-section h2{
  font-family:'Zen Old Mincho',serif;
  font-weight:600;
  font-size:clamp(22px, 2.4vw, 32px);
  line-height:1.55;
  margin:0 0 clamp(14px, 1.6vw, 22px);
  color:#4c3e30;
  border-left:4px solid var(--green);
  padding-left:14px;
}
.page-section h3{
  font-family:'Zen Old Mincho',serif;
  font-weight:600;
  font-size:clamp(18px, 1.8vw, 22px);
  margin:clamp(20px, 2.4vw, 28px) 0 10px;
  color:#5a4a39;
}
.page-section p{
  font-size:clamp(13px, 1vw, 15px);
  line-height:2;
  margin:0 0 1em;
}
.page-section ul,
.page-section ol{
  font-size:clamp(13px, 1vw, 15px);
  line-height:2;
  padding-left:1.2em;
}
.page-section ul li{list-style:disc}
.page-section a{
  color:var(--green);
  text-decoration:underline;
}

/* ----- 料金表 (table) ----- */
.menu-table{
  width:100%;
  border-collapse:collapse;
  margin:14px 0 28px;
  font-size:clamp(13px, 1vw, 14px);
}
.menu-table th,
.menu-table td{
  padding:12px 14px;
  border-bottom:1px solid var(--line);
  text-align:left;
}
.menu-table th{
  background:#fff8ea;
  font-weight:700;
  color:#5a4a39;
}
.menu-table td.price{
  text-align:right;
  font-weight:700;
  color:var(--green);
  white-space:nowrap;
}
@media (max-width:620px){
  .menu-table th,.menu-table td{padding:10px 8px}
}

/* ----- グッズグリッド ----- */
.goods-grid{
  display:grid;
  grid-template-columns:repeat(auto-fill, minmax(220px, 1fr));
  gap:clamp(14px, 1.6vw, 22px);
  margin:18px 0;
}
.goods-card{
  background:#fffdf8;
  border:1px solid var(--line);
  border-radius:14px;
  padding:18px;
  display:flex;
  flex-direction:column;
  gap:6px;
}
.goods-card .name{font-weight:700;color:#4c3e30}
.goods-card .price{
  color:var(--green);
  font-weight:700;
  font-size:1.1em;
}
.goods-card .note{font-size:.85em;color:#7a6553}

/* ----- 店舗情報 dl ----- */
.info-list{
  display:grid;
  grid-template-columns:max-content 1fr;
  gap:10px clamp(16px, 2vw, 28px);
  margin:18px 0;
  font-size:clamp(13px, 1vw, 15px);
  line-height:1.85;
}
.info-list dt{
  font-weight:700;
  color:var(--green);
  white-space:nowrap;
}
.info-list dd{margin:0;color:#5a4a39}
@media (max-width:620px){
  .info-list{grid-template-columns:1fr;gap:2px 0}
  .info-list dt{margin-top:8px}
}

/* ----- お問い合わせフォーム ----- */
.contact-form{
  display:grid;
  gap:14px;
  max-width:680px;
  margin:14px 0 28px;
}
.contact-form label{
  display:flex;
  flex-direction:column;
  font-size:clamp(12px, .9vw, 14px);
  font-weight:700;
  color:#5a4a39;
  gap:6px;
}
.contact-form input,
.contact-form textarea{
  font:inherit;
  padding:10px 14px;
  border:1px solid var(--line);
  border-radius:10px;
  background:#fffdf8;
  font-weight:400;
}
.contact-form input:focus,
.contact-form textarea:focus{
  outline:2px solid var(--green);
  outline-offset:1px;
}
.contact-form textarea{min-height:140px;resize:vertical}
.contact-form .submit{
  background:var(--green);
  color:white;
  border:0;
  border-radius:999px;
  padding:14px 28px;
  font-weight:700;
  font-size:clamp(13px, 1vw, 15px);
  cursor:pointer;
  width:max-content;
  transition:.2s;
}
.contact-form .submit:hover{transform:translateY(-2px);box-shadow:0 10px 24px rgba(88,112,72,.18)}

/* ----- FAQ accordion ----- */
.faq{
  display:grid;
  gap:10px;
  margin:18px 0;
}
.faq details{
  background:#fffdf8;
  border:1px solid var(--line);
  border-radius:14px;
  padding:14px 18px;
}
.faq summary{
  cursor:pointer;
  font-weight:700;
  color:#4c3e30;
  list-style:none;
  position:relative;
  padding-right:24px;
}
.faq summary::-webkit-details-marker{display:none}
.faq summary:after{
  content:"＋";
  position:absolute;
  right:4px;
  top:50%;
  transform:translateY(-50%);
  color:var(--green);
  font-weight:900;
}
.faq details[open] summary:after{content:"−"}
.faq p{margin:10px 0 0;font-size:clamp(12px, .95vw, 14px);line-height:1.85}

/* =====================================================================
   v8: 1日の過ごし方を2列レイアウト + 画像大きめに
   ===================================================================== */
.flow-items{
  grid-template-columns:repeat(2, 1fr) !important;
  gap:clamp(20px, 2.4vw, 36px) clamp(20px, 3vw, 48px);
  max-width:760px;
  margin:0 auto;
  padding:8px 0 0;
}
/* 横線（タイムライン）は2列レイアウトでは不要 */
.flow-items:before{display:none}
.flow-items article{
  display:grid;
  grid-template-columns:auto 1fr;
  align-items:center;
  gap:clamp(14px, 1.8vw, 22px);
  max-width:none;
  margin:0;
  text-align:left;
  padding:0;
}
.flow-items i{display:none}
.flow-items span{
  width:clamp(140px, 16vw, 180px) !important;
  height:clamp(140px, 16vw, 180px) !important;
  margin:0 !important;
  border-radius:50%;
  background-size:cover;
  background-position:center;
  box-shadow:0 10px 24px rgba(116,88,48,.16);
  flex-shrink:0;
}
.flow-items p{
  font-size:clamp(13px, 1.05vw, 16px) !important;
  font-family:'Zen Old Mincho',serif;
  font-weight:600;
  line-height:1.55;
  color:#4c3e30;
  white-space:normal !important;
  margin:0;
}

@media (max-width:700px){
  .flow-items{
    grid-template-columns:1fr !important;
    gap:18px;
    max-width:420px;
  }
  .flow-items span{
    width:clamp(120px, 36vw, 160px) !important;
    height:clamp(120px, 36vw, 160px) !important;
  }
}

/* =====================================================================
   v9: service-copy h2 の改行を整える
   - <br> 後の文節がさらに折返すと汚いので、レイアウト切替を早めに発火
   - 4col → 2col への閾値を 1100px に引き上げ
   - service-copy h2 を column 幅に応じて縮小
   ===================================================================== */
@media (max-width:1100px){
  .service-grid{
    grid-template-columns:1fr 1fr !important;
    gap:14px;
  }
  .service-grid .goods{grid-column:auto}
}
.service-copy h2{
  font-size:clamp(20px, 1.9vw, 26px) !important;
  line-height:1.55;
  word-break:keep-all !important;
  overflow-wrap:break-word !important;
  text-wrap:balance;
}
@media (max-width:880px){
  .service-copy h2{
    font-size:clamp(20px, 4.6vw, 24px) !important;
  }
  .service-copy br{display:none}  /* 強制改行を解除して自然折返しに */
}
@media (max-width:560px){
  .service-grid{
    grid-template-columns:1fr !important;
  }
}


/* =====================================================================
   v10: 下層ページごとの page-hero 背景を個別指定
   ===================================================================== */
.page-hero{
  background-image:
    linear-gradient(90deg,
      rgba(255,251,243,.94) 0 30%,
      rgba(255,251,243,.55) 50%,
      rgba(255,251,243,.10) 70%,
      transparent 80%),
    var(--hero-img, url("../images/hero.png"));
  background-size:cover;
  background-position:center;
  background-repeat:no-repeat;
}
.page-menu .page-hero{
  --hero-img:url("../images/page-heroes/hero-menu.png");
}
.page-goods .page-hero{
  --hero-img:url("../images/page-heroes/hero-goods.png");
}
.page-about .page-hero{
  --hero-img:url("../images/page-heroes/hero-about.png");
}
.page-contact .page-hero{
  --hero-img:url("../images/page-heroes/hero-contact.png");
}

/* =====================================================================
   v11: goods カード内の商品画像
   ===================================================================== */
.goods-card{
  padding:0;
  overflow:hidden;
  transition:transform .2s, box-shadow .2s;
}
.goods-card:hover{
  transform:translateY(-3px);
  box-shadow:0 12px 28px rgba(116,88,48,.18);
}
.goods-card img{
  display:block;
  width:100%;
  aspect-ratio:1 / 1;
  object-fit:cover;
  background:#fff;
  border-bottom:1px solid var(--line);
}
.goods-card .name,
.goods-card .price,
.goods-card .note{
  padding-left:14px;
  padding-right:14px;
}
.goods-card .name{
  margin-top:14px;
  min-height:2.7em;
  line-height:1.4;
  display:-webkit-box;
  -webkit-line-clamp:2;
  -webkit-box-orient:vertical;
  overflow:hidden;
}
.goods-card .price{
  margin-top:6px;
  display:block;
}
.goods-card .note{
  padding-bottom:14px;
  margin-top:4px;
}

/* =====================================================================
   v12: トリミング・セミナーセクションを実物写真に差し替え
   上段: トリミング作業 / シャンプー＆カット作業 / カット後のプードル正面
   下段: スタッフ＋犬抱きしめ笑顔 / セミナー全景
   ===================================================================== */
.scissors{
  background-image:url("../images/photos/trimming-grooming.jpg") !important;
  background-position:center 25%;
}
.seminar{
  background-image:url("../images/photos/shampoo-trimming.jpg") !important;
  background-position:center;
}
.exterior{
  background-image:url("../images/photos/trimming-3.jpg") !important;
  background-position:center 30%;
}
.class{
  background-image:url("../images/photos/staff-with-dog.jpg") !important;
  background-position:center 30%;
}
.service-grid .goods{
  background-image:url("../images/photos/seminar-real.jpg") !important;
  background-position:center top;
}

/* =====================================================================
   v13: スマホ向け徹底修正
   - Hero: 写真位置調整（人物・犬を上に、テキストを下に）
   - 横スクロール発生防止: 全セクションに max-width:100vw + overflow:clip
   - Reasons: 葉っぱ装飾を非表示
   - Service grid: 写真比率を縦長に、幅を強制 100%
   - CTA: 1カラム化、画像背景比率調整
   - Footer: 中央寄せ整形
   ===================================================================== */

/* 横スクロール完全防止 */
@media (max-width:700px){
  html, body{
    overflow-x:hidden;
    max-width:100vw;
  }
  body{
    background:#fffdf8;          /* 縦帯のグレーが見えないように */
  }
  .site-header,
  main,
  .site-footer{
    max-width:100% !important;
    width:100% !important;
    margin:0 !important;
    border-radius:0 !important;
    border-left:none !important;
    border-right:none !important;
  }
  .site-header{border-radius:0 !important;border-bottom:1px solid var(--line) !important}
  .site-footer{border-top:1px solid var(--line) !important;margin-bottom:0 !important}

  /* セクション全体のはみ出し防止 */
  section, .hotel-card, .reasons, .service-grid, .cta, .worries, .day-flow{
    max-width:100% !important;
    margin-left:0 !important;
    margin-right:0 !important;
    box-sizing:border-box;
  }

  /* Hero: テキストを下に押し下げ、写真の人物/犬が上半分に収まるように */
  .hero{
    min-height:auto !important;
    padding:0 !important;
    background:
      linear-gradient(180deg,
        rgba(255,251,243,0) 0 38%,
        rgba(255,251,243,.85) 50%,
        rgba(255,251,243,.98) 62%,
        #fffdf8 100%),
      url("../images/hero.png") center 32% / cover no-repeat #fffdf8 !important;
  }
  .hero{
    display:flex;
    flex-direction:column;
    justify-content:flex-end;
    aspect-ratio:auto;
    min-height:560px !important;
  }
  .hero-copy{
    max-width:100% !important;
    padding:240px 18px 24px !important;
    margin-top:auto;
  }
  .hero h1{
    font-size:clamp(26px, 7vw, 34px) !important;
    line-height:1.55 !important;
  }
  .hero .lead{font-size:14px !important;line-height:1.85 !important}
  .hero-actions{
    flex-direction:column !important;
    width:100% !important;
    gap:10px !important;
  }
  .hero-actions .btn{
    width:100% !important;
    min-width:0 !important;
    padding:14px 20px !important;
  }
  .hero .flower-left{
    width:64px !important;
    height:74px !important;
    bottom:6px !important;
    left:0 !important;
    z-index:1 !important;
  }

  /* Reasons: 葉っぱ装飾を非表示にしてテキスト可読性確保 */
  .reason-grid article::after{display:none !important}
  .reason-grid{
    grid-template-columns:1fr 1fr !important;
    gap:12px !important;
  }
  .reason-grid article{padding:8px !important}
  .reason-grid h3{font-size:15px !important;margin:8px 0 4px !important;color:var(--green) !important}
  .reason-grid p{font-size:11px !important;line-height:1.6 !important;margin:0 4px 6px !important}
  .reason-grid .photo{
    min-height:auto !important;
    aspect-ratio:1 / 1 !important;
    border-radius:10px !important;
  }

  /* Service grid: 1列化＆写真は16:10で幅100% */
  .service-grid{
    grid-template-columns:1fr !important;
    gap:14px !important;
    padding:0 16px !important;
  }
  .service-grid .goods{grid-column:auto !important}
  .service-photo{
    min-height:auto !important;
    aspect-ratio:16 / 10 !important;
    width:100% !important;
    border-radius:14px !important;
    background-size:cover !important;
  }
  .service-copy{padding:22px 20px !important}
  .service-copy h2{font-size:clamp(20px, 5.6vw, 26px) !important;line-height:1.55 !important}
  .service-copy br{display:none !important}
  .service-copy p{font-size:13px !important}

  /* Hotel card: 1列＆写真比率 */
  .hotel-card{
    grid-template-columns:1fr !important;
    padding:18px !important;
  }
  .hotel-text h2{font-size:clamp(22px, 6vw, 30px) !important}
  .hotel-text br{display:none !important}
  .hotel-illustration{
    aspect-ratio:16 / 10 !important;
    min-height:auto !important;
    border-radius:14px !important;
  }

  /* CTA: 1カラム、画像背景は固定比率に */
  .cta{
    grid-template-columns:1fr !important;
    padding:24px 18px !important;
    text-align:center !important;
    gap:14px !important;
    background-size:cover !important;
    background-position:center !important;
    border-radius:14px !important;
    margin:14px 0 !important;
  }
  .cta::before, .cta::after{display:none !important}  /* 標識・葉装飾を消す */
  .signpost{display:none !important}
  .cta h2{font-size:clamp(20px, 5.4vw, 26px) !important;line-height:1.55 !important}
  .cta p{font-size:13px !important}
  .cta-dogs{display:none !important}

  /* Worries: 縦並び圧縮 */
  .worries{padding:18px 16px !important}
  .worries h2{font-size:20px !important}
  .worry-list{grid-template-columns:1fr 1fr !important;gap:12px !important}
  .worry-list article{flex-direction:column;text-align:center;gap:6px !important}
  .worry-list span{margin:0 auto !important;width:60px !important;height:60px !important}
  .worry-list p{font-size:11px !important;text-align:center !important;line-height:1.6 !important}
  .worry-list br{display:none}

  /* day-flow: 1列＆画像縮小 */
  .flow-items{
    grid-template-columns:1fr !important;
    gap:14px !important;
    max-width:100% !important;
    padding:0 8px !important;
  }
  .flow-items article{
    grid-template-columns:80px 1fr !important;
    gap:14px !important;
  }
  .flow-items span{
    width:80px !important;
    height:80px !important;
  }
  .flow-items p{font-size:13px !important}

  /* Footer: 中央揃え */
  .site-footer{
    display:flex !important;
    flex-direction:column !important;
    align-items:center !important;
    text-align:center !important;
    padding:24px 16px !important;
    gap:14px !important;
  }
  .footer-nav{
    flex-wrap:wrap !important;
    justify-content:center !important;
    gap:10px 14px !important;
  }
  .footer-info{font-size:11px !important;line-height:1.7 !important}
  .site-footer .sns{justify-content:center !important}

  /* Page-hero（下層）はテキスト中央寄せに */
  .page-hero{
    min-height:200px !important;
    padding:36px 18px !important;
    background-position:center !important;
  }
  .page-hero h1{font-size:clamp(22px, 6vw, 28px) !important}

  /* Header logo の位置/予約ボタン */
  .reserve-btn{display:none !important}
  .site-header.is-open .reserve-btn{
    display:flex !important;
    width:100% !important;
    margin-top:8px;
  }
  .nav-toggle{display:block !important;margin-left:auto !important}

  /* page-section: padding 圧縮 */
  .page-section{padding:24px 16px !important}
  .menu-table{font-size:12px !important}
  .menu-table th, .menu-table td{padding:8px 6px !important}
  .info-list{grid-template-columns:1fr !important}
  .info-list dt{margin-top:8px !important}
  .goods-grid{grid-template-columns:1fr 1fr !important;gap:12px !important}
  .goods-card .name{font-size:13px !important}
  .goods-card .price{font-size:14px !important}
  .goods-card .note{font-size:11px !important}
}

/* =====================================================================
   v14: SP徹底再修正 - 写真は全部表示、テキスト切れなし
   - hero: aspect-ratio 4:3 で全画像表示
   - 各 service-photo は natural aspect-ratio にあわせる
   - text overflow を完全防止
   ===================================================================== */
@media (max-width:700px){
  /* グローバルリセット - はみ出し完全防止 */
  *{
    max-width:100% !important;
    box-sizing:border-box;
  }
  html, body{
    overflow-x:hidden !important;
    width:100% !important;
    max-width:100vw !important;
  }
  img, video{
    height:auto;
    max-width:100% !important;
  }

  /* Hero: 写真を全表示 + テキストはその下 */
  .hero{
    min-height:auto !important;
    padding:0 !important;
    background:#fffdf8 !important;
    display:block !important;
  }
  .hero::before{
    content:"" !important;
    display:block !important;
    width:100% !important;
    aspect-ratio:1448 / 1086 !important;     /* hero.png natural ratio */
    background:url("../images/hero.png") center / cover no-repeat #fffdf8 !important;
    background-position:right center !important;  /* 犬を画面に入れる */
  }
  .hero::after{display:none !important}
  .hero-copy{
    position:relative !important;
    padding:24px 18px 28px !important;
    max-width:100% !important;
    width:100% !important;
    margin:0 !important;
    background:#fffdf8 !important;
  }
  .hero-visual{display:none !important}
  .hero h1{
    font-size:clamp(24px, 6.5vw, 32px) !important;
    line-height:1.55 !important;
    margin-bottom:14px !important;
    word-break:keep-all !important;
    overflow-wrap:break-word !important;
  }
  .hero .lead{
    font-size:13px !important;
    line-height:1.85 !important;
    margin-bottom:18px !important;
  }
  .hero .lead br{display:none !important}
  .hero-actions{
    flex-direction:column !important;
    width:100% !important;
    gap:8px !important;
  }
  .hero-actions .btn{
    width:100% !important;
    min-width:0 !important;
    padding:14px 20px !important;
    font-size:13px !important;
  }
  .hero .flower-left{
    z-index:2 !important;
    width:60px !important;
    height:68px !important;
    bottom:auto !important;
    top:0 !important;       /* 写真側に重ねる */
    left:0 !important;
    transform:translateY(-30%) !important;
    pointer-events:none;
  }
  .hero .leaf-right{display:none !important}

  /* セクション全幅化＆余計な margin 削除 */
  section, .hotel-card, .reasons, .service-grid, .cta, .worries, .day-flow{
    max-width:100% !important;
    width:100% !important;
    margin-left:0 !important;
    margin-right:0 !important;
    box-sizing:border-box !important;
    overflow:visible !important;
  }

  /* hotel-card: hotel-illustration を全表示 */
  .hotel-card{
    grid-template-columns:1fr !important;
    padding:18px 16px !important;
    gap:16px !important;
  }
  .hotel-text{padding:0 !important}
  .hotel-text h2{font-size:clamp(22px, 6vw, 30px) !important;line-height:1.55 !important}
  .hotel-text br{display:none !important}
  .hotel-illustration{
    aspect-ratio:1448 / 1086 !important;   /* hotel-room.png ratio */
    min-height:auto !important;
    width:100% !important;
    border-radius:14px !important;
    background-size:cover !important;       /* 1448x1086でちょうど良い */
    background-position:center !important;
  }

  /* day-flow: 2列、画像を crop せず表示 */
  .day-flow{padding:18px 12px !important}
  .day-flow h3{font-size:18px !important;margin-bottom:14px !important}
  .flow-items{
    grid-template-columns:1fr 1fr !important;
    gap:14px 10px !important;
    max-width:100% !important;
    padding:0 !important;
  }
  .flow-items article{
    grid-template-columns:1fr !important;     /* 縦並び */
    gap:6px !important;
    text-align:center !important;
    max-width:100% !important;
    padding:0 4px !important;
  }
  .flow-items span{
    width:clamp(90px, 24vw, 120px) !important;
    height:clamp(90px, 24vw, 120px) !important;
    margin:0 auto !important;
  }
  .flow-items p{font-size:11px !important;line-height:1.5 !important;text-align:center !important}

  /* Reasons: 葉装飾 OFF + 2列で写真全表示 */
  .reasons{padding:18px 12px !important}
  .reasons h2{font-size:20px !important;line-height:1.55 !important;text-align:left}
  .reason-grid article::after{display:none !important}
  .reason-grid{
    grid-template-columns:1fr 1fr !important;
    gap:10px !important;
  }
  .reason-grid article{padding:8px !important;border-radius:12px !important}
  .reason-grid h3{font-size:14px !important;margin:8px 0 4px !important;color:var(--green) !important;font-family:'Zen Old Mincho',serif}
  .reason-grid p{font-size:11px !important;line-height:1.55 !important;margin:0 4px 4px !important}
  .reason-grid .photo{
    aspect-ratio:1448 / 1086 !important;
    min-height:auto !important;
    width:100% !important;
    border-radius:10px !important;
    background-size:cover !important;
    background-position:center !important;
  }

  /* service-grid: 1列、各写真を natural aspect-ratio で全表示 */
  .service-grid{
    grid-template-columns:1fr !important;
    gap:14px !important;
    padding:0 14px !important;
  }
  .service-grid .goods{grid-column:auto !important}
  .service-copy{
    padding:20px 18px !important;
    border-radius:14px !important;
    width:100% !important;
  }
  .service-copy h2{
    font-size:clamp(18px, 5vw, 24px) !important;
    line-height:1.55 !important;
    word-break:keep-all !important;
    overflow-wrap:break-word !important;
  }
  .service-copy br{display:none !important}
  .service-copy p{font-size:13px !important;line-height:1.85 !important}
  .service-photo{
    width:100% !important;
    min-height:auto !important;
    border-radius:14px !important;
    background-size:cover !important;
    background-position:center !important;
  }
  /* 各写真の natural aspect-ratio で表示（cropなし） */
  .scissors{aspect-ratio:1200 / 1600 !important}      /* 縦長 trimming-grooming */
  .seminar{aspect-ratio:600 / 400 !important}         /* 横長 shampoo-trimming */
  .exterior{aspect-ratio:856 / 1118 !important}       /* 縦長 trimming-3 */
  .class{aspect-ratio:1600 / 1200 !important}         /* 横長 staff-with-dog */
  .service-grid .goods{aspect-ratio:853 / 640 !important}  /* 横長 seminar-real */

  /* CTA: 1カラム、画像全表示 */
  .cta{
    grid-template-columns:1fr !important;
    padding:24px 18px !important;
    text-align:center !important;
    gap:14px !important;
    border-radius:14px !important;
    margin:14px 0 !important;
    background-position:center !important;
    background-size:cover !important;
  }
  .cta::before, .cta::after{display:none !important}
  .signpost{display:none !important}
  .cta h2{font-size:20px !important;line-height:1.55 !important}
  .cta p{font-size:13px !important;line-height:1.7 !important}
  .cta-dogs{display:none !important}
  .cta .btn.primary{width:100% !important}

  /* Worries: 2列、シンプル */
  .worries{padding:20px 14px !important;text-align:center}
  .worries h2{font-size:20px !important;margin-bottom:14px !important}
  .worry-list{grid-template-columns:1fr 1fr !important;gap:12px !important}
  .worry-list article{flex-direction:column !important;text-align:center !important;gap:6px !important;align-items:center !important}
  .worry-list span{margin:0 auto !important;width:60px !important;height:60px !important;flex:0 0 60px !important}
  .worry-list p{font-size:11px !important;text-align:center !important;line-height:1.6 !important}
  .worry-list br{display:none}
  .solution{font-size:14px !important;margin-top:8px !important}

  /* Header */
  .site-header{padding:12px 14px !important;min-height:auto !important;border-radius:0 !important;border-left:none !important;border-right:none !important;max-width:100% !important;width:100% !important;margin:0 !important}
  .reserve-btn{display:none !important}
  .nav-toggle{display:block !important;margin-left:auto !important}
  .global-nav{display:none !important}
  .site-header.is-open .global-nav{
    display:flex !important;
    flex-direction:column !important;
    position:absolute !important;
    left:0 !important;
    right:0 !important;
    top:64px !important;
    padding:12px !important;
    background:#fffaf0 !important;
    border-bottom:1px solid var(--line) !important;
    gap:10px !important;
  }

  /* Footer */
  .site-footer{
    display:flex !important;
    flex-direction:column !important;
    align-items:center !important;
    text-align:center !important;
    padding:24px 16px !important;
    gap:12px !important;
    border-radius:0 !important;
    border-left:none !important;
    border-right:none !important;
    max-width:100% !important;
    width:100% !important;
    margin:0 !important;
  }
  .footer-nav{flex-wrap:wrap !important;justify-content:center !important;gap:8px 14px !important;font-size:12px !important}
  .footer-info{font-size:11px !important;line-height:1.7 !important;padding:0 8px !important}
  .site-footer .sns{justify-content:center !important;gap:10px !important}

  /* Page-hero（下層）: 全画像表示 */
  .page-hero{
    min-height:auto !important;
    padding:0 !important;
    aspect-ratio:1536 / 1024 !important;
    display:flex !important;
    flex-direction:column !important;
    justify-content:flex-end !important;
    background-size:cover !important;
    background-position:center !important;
  }
  .page-hero .eyebrow,
  .page-hero h1{
    padding-left:18px !important;
    padding-right:18px !important;
  }
  .page-hero .eyebrow{margin:0 !important;padding-top:14px !important}
  .page-hero h1{
    font-size:22px !important;
    margin:6px 0 18px !important;
    background:linear-gradient(180deg, transparent, rgba(255,251,243,.85) 50%) !important;
    padding-bottom:18px !important;
  }

  /* page-section */
  .page-section{padding:24px 16px !important;max-width:100% !important;margin:0 !important}
  .page-section h2{font-size:20px !important;line-height:1.55 !important}
  .page-section h3{font-size:16px !important}
  .page-section p{font-size:13px !important;line-height:1.85 !important}
  .menu-table{font-size:11px !important}
  .menu-table th, .menu-table td{padding:8px 6px !important}
  .info-list{grid-template-columns:1fr !important;gap:2px 0 !important}
  .info-list dt{margin-top:8px !important}
  .goods-grid{grid-template-columns:1fr 1fr !important;gap:10px !important}
  .goods-card{padding:0 !important}
  .goods-card img{
    aspect-ratio:1 / 1 !important;
    object-fit:cover !important;
  }
  .goods-card .name{font-size:12px !important;padding:10px 10px 0 !important;min-height:auto !important}
  .goods-card .price{font-size:13px !important;padding:0 10px !important}
  .goods-card .note{font-size:10px !important;padding:0 10px 10px !important}

  /* contact form */
  .contact-form input, .contact-form textarea{font-size:14px !important;padding:10px !important}
  .contact-form .submit{width:100% !important;justify-content:center}
}

/* =====================================================================
   v15: SP grid overflow を minmax(0,1fr) で根本修正
   1fr のデフォルト minmax(auto,1fr) が子の min-content (画像natural width)
   を最小幅にして grid を viewport より広げてしまう問題を解決
   ===================================================================== */
@media (max-width:700px){
  /* すべての grid を min:0 化 */
  .service-grid{
    grid-template-columns:minmax(0, 1fr) !important;
  }
  .reason-grid{
    grid-template-columns:minmax(0, 1fr) minmax(0, 1fr) !important;
  }
  .worry-list{
    grid-template-columns:minmax(0, 1fr) minmax(0, 1fr) !important;
  }
  .flow-items{
    grid-template-columns:minmax(0, 1fr) minmax(0, 1fr) !important;
  }
  .goods-grid{
    grid-template-columns:minmax(0, 1fr) minmax(0, 1fr) !important;
  }
  .hotel-card{
    grid-template-columns:minmax(0, 1fr) !important;
  }
  .cta{
    grid-template-columns:minmax(0, 1fr) !important;
  }
  /* grid item / flex item に min-width:0 を強制 */
  .service-photo,
  .service-copy,
  .reason-grid article,
  .reason-grid .photo,
  .worry-list article,
  .flow-items article,
  .flow-items span,
  .goods-card,
  .goods-card img,
  .hotel-illustration,
  .hotel-text{
    min-width:0 !important;
  }
}

/* v16: hero::before 強制 relative で写真を可視化 */
@media (max-width:700px){
  .hero::before{
    position:static !important;
    inset:auto !important;
    z-index:auto !important;
  }
}

/* =====================================================================
   v25: 滞在型ホテル下層ページ（hotel.html）
   ===================================================================== */
/* ページヒーロー背景 */
.page-hotel .page-hero{
  --hero-img:url("../images/page-heroes/hero-hotel.png");
}

/* 1日の過ごし方セクションの導入文・注記 */
.day-flow-lead{
  max-width:760px;
  margin:0 auto 22px;
  text-align:center;
  font-size:clamp(13px,1vw,15px);
  line-height:1.9;
  color:#5a4a39;
}
.day-flow-note{
  margin:18px 0 0;
  text-align:center;
  color:#7a6553;
}
/* タイムラインの時刻ラベル（円形イラスト下の太字） */
.flow-items p b{
  display:inline-block;
  margin-bottom:2px;
  color:var(--green);
  font-size:1.08em;
  letter-spacing:.04em;
}

/* お問い合わせ／CTA のボタン横並び */
.contact-actions{
  display:flex;
  flex-wrap:wrap;
  gap:14px;
  margin:20px 0 26px;
}
.cta .btn + .btn{margin-top:12px}
/* LINE ボタン（公式グリーン） */
.line-btn{
  background:#06C755 !important;
  border-color:#06C755 !important;
  color:#fff !important;
}
.line-btn:before{content:"LINE";font-weight:800;letter-spacing:.04em}
@media (max-width:560px){
  .contact-actions{flex-direction:column}
  .contact-actions .btn{width:100%}
}

/* =====================================================================
   v26: 岸辺店オープン — 2店舗表記まわり
   ===================================================================== */
/* 「2026年5月オープン」などの NEW バッジ */
.badge-new{
  display:inline-block;
  margin-left:10px;
  padding:3px 10px;
  border-radius:999px;
  background:var(--coral, #D8553F);
  color:#fff;
  font-family:'Kosugi Maru',sans-serif;
  font-size:.62em;
  font-weight:700;
  letter-spacing:.04em;
  vertical-align:middle;
  white-space:nowrap;
}
/* フッターは2店舗で行数が増えるため行間を少し詰める */
.site-footer .footer-info{line-height:1.85}
.site-footer .footer-info b{
  color:var(--green);
  font-weight:700;
  margin-right:2px;
}

/* =====================================================================
   v27: 歯みがき（スリーステップマウスケア）＋ SNS 2店舗
   ===================================================================== */
/* 3ステップカード */
.step-cards{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:clamp(12px,1.6vw,20px);
  margin:18px 0 22px;
}
.step-cards article{
  background:#fffdf8;
  border:1px solid var(--line);
  border-radius:14px;
  padding:20px 16px;
  box-shadow:0 8px 20px #0000000d;
  text-align:center;
}
.step-cards .step-no{
  display:inline-block;
  font-family:'Kosugi Maru',sans-serif;
  font-size:.72em;
  font-weight:700;
  letter-spacing:.06em;
  color:#fff;
  background:var(--green);
  border-radius:999px;
  padding:3px 12px;
  margin-bottom:8px;
}
.step-cards h3{
  margin:4px 0 6px;
  font-family:'Zen Old Mincho',serif;
  font-size:clamp(17px,1.6vw,20px);
  color:#4c3e30;
}
.step-cards p{font-size:clamp(12px,.95vw,14px);line-height:1.7;margin:0;color:#5a4a39}

/* 特典・注目情報のコールアウト */
.callout{
  background:linear-gradient(180deg,#fff6e9,#fdeccf);
  border:1px solid #ecd8af;
  border-radius:16px;
  padding:clamp(18px,2.2vw,26px);
  margin:18px 0 26px;
}
.callout .callout-title{
  font-family:'Zen Old Mincho',serif;
  font-size:clamp(17px,1.6vw,21px);
  font-weight:700;
  color:var(--coral,#D8553F);
  margin:0 0 8px;
}
.callout p{margin:0 0 .6em;line-height:1.9;font-size:clamp(13px,1vw,15px)}
.callout p:last-child{margin-bottom:0}
.callout a{color:var(--green);text-decoration:underline;font-weight:700}

@media (max-width:560px){
  .step-cards{grid-template-columns:1fr;gap:12px}
}

/* SNS を店舗ごとに2行表示（フッター） */
.site-footer .sns{
  flex-direction:column;
  gap:8px;
  align-items:flex-start;
}
.sns-store{display:flex;align-items:center;gap:12px;flex-wrap:wrap}
.sns-label{
  font-weight:700;
  color:#7a6553;
  min-width:3.4em;
  font-size:.92em;
}
@media (max-width:980px){
  .site-footer .sns{align-items:center}
  .sns-store{justify-content:center}
}

/* =====================================================================
   v28: 店舗タブ（料金表）＋ グランドオープン告知
   ===================================================================== */
.store-note{
  font-size:clamp(13px,1vw,15px);
  line-height:1.9;
  color:#5a4a39;
  margin:0 0 16px;
}
.store-note small{color:#7a6553}

/* 店舗切り替えタブ */
.store-tabs{
  display:flex;
  gap:8px;
  margin:0 0 24px;
  border-bottom:2px solid var(--line);
}
.store-tab{
  appearance:none;
  border:1px solid var(--line);
  border-bottom:none;
  background:#f3ead9;
  color:#7a6553;
  font-family:'Zen Old Mincho',serif;
  font-weight:600;
  font-size:clamp(14px,1.3vw,17px);
  padding:12px clamp(16px,2.4vw,30px);
  border-radius:12px 12px 0 0;
  cursor:pointer;
  margin-bottom:-2px;
  transition:.2s;
}
.store-tab:hover{color:var(--green)}
.store-tab.is-active{
  background:var(--green);
  border-color:var(--green);
  color:#fff;
}
.store-panel.is-hidden{display:none}

/* グランドオープン キャンペーン コールアウト */
.callout-campaign{
  background:linear-gradient(180deg,#fff2ef,#ffe2db);
  border:2px solid var(--coral,#D8553F);
}
.callout-campaign .callout-title{font-size:clamp(18px,1.8vw,23px)}
.campaign-list{
  list-style:none;
  padding:0;
  margin:8px 0 14px;
  display:grid;
  gap:10px;
}
.campaign-list li{
  display:flex;
  align-items:center;
  gap:12px;
  flex-wrap:wrap;
  background:#fffdf8;
  border:1px solid #f0d5cd;
  border-radius:12px;
  padding:12px 14px;
  font-size:clamp(14px,1.2vw,17px);
}
.campaign-list strong{color:var(--coral,#D8553F);font-size:1.15em}
.campaign-tag{
  display:inline-block;
  flex:none;
  font-family:'Kosugi Maru',sans-serif;
  font-size:.8em;
  font-weight:700;
  color:#fff;
  border-radius:999px;
  padding:4px 12px;
  white-space:nowrap;
}
.campaign-tag.new{background:var(--coral,#D8553F)}
.campaign-tag.repeat{background:var(--green)}

/* トップページ お知らせバナー */
.news-banner{
  max-width:1180px;
  margin:0 auto;
  display:flex;
  align-items:center;
  gap:14px;
  flex-wrap:wrap;
  background:linear-gradient(180deg,#fff2ef,#ffe6df);
  border:1px solid #f0c9c0;
  border-radius:16px;
  padding:16px clamp(18px,2.4vw,28px);
}
.news-badge{
  flex:none;
  font-family:'Kosugi Maru',sans-serif;
  font-weight:700;
  font-size:.82em;
  letter-spacing:.06em;
  color:#fff;
  background:var(--coral,#D8553F);
  border-radius:999px;
  padding:5px 14px;
}
.news-banner p{
  margin:0;
  font-size:clamp(13px,1vw,15px);
  line-height:1.8;
  color:#5a4a39;
  flex:1 1 260px;
}
.news-banner b{color:var(--coral,#D8553F)}
.news-banner a{color:var(--green);font-weight:700;text-decoration:underline;white-space:nowrap}

@media (max-width:620px){
  .store-tabs{gap:4px}
  .store-tab{flex:1;text-align:center;padding:11px 8px}
}

/* 両店舗共通セクションの見出しラベル */
.both-stores{
  display:inline-block;
  margin-left:12px;
  padding:3px 12px;
  border-radius:999px;
  background:#eef2e7;
  border:1px solid var(--green);
  color:var(--green);
  font-family:'Kosugi Maru',sans-serif;
  font-size:.5em;
  font-weight:700;
  vertical-align:middle;
  white-space:nowrap;
}
.common-head{margin-top:clamp(28px,3vw,40px)}
