*{box-sizing:border-box}
:root{--orange:#ff7900;--green:#13a05f;--blue:#2477e7;--text:#201812;--muted:#746d66;--line:#eee5dc;--cream:#fff7ee;--shadow:0 18px 44px rgba(36,24,12,.10)}
body{margin:0;background:#fffaf5;color:var(--text);font-family:-apple-system,BlinkMacSystemFont,"Noto Sans JP","Helvetica Neue",Arial,sans-serif}
button,input{font:inherit}button{border:0;background:none;cursor:pointer;color:inherit}
.site-header{height:68px;display:flex;align-items:center;justify-content:space-between;padding:0 28px;background:rgba(255,255,255,.92);border-bottom:1px solid var(--line);position:sticky;top:0;z-index:10;backdrop-filter:blur(10px)}
.brand{display:flex;align-items:center;gap:9px;color:var(--orange);font-size:22px}.paw-logo{font-size:20px;color:var(--orange)}.desktop-nav{display:flex;gap:10px}.desktop-nav button{padding:10px 14px;border-radius:999px}.desktop-nav button:hover{background:var(--cream);color:var(--orange)}
main{max-width:1180px;margin:0 auto;padding:22px}.page{display:none}.page.active{display:block}
.home-grid{display:grid;grid-template-columns:.78fr 1.22fr;gap:18px}.hero-panel,.map-panel,.content-section,.filters,.results-area,.detail-card,.review-summary,.review-card,.mypage-card,.menu-list,.admin-main,.admin-side{background:#fff;border:1px solid var(--line);border-radius:26px;box-shadow:var(--shadow);overflow:hidden}
.hero-image{height:240px;background:url('https://images.unsplash.com/photo-1587300003388-59208cc962cb?q=80&w=1000&auto=format&fit=crop') center/cover}.hero-content{padding:28px}h1{font-size:34px;line-height:1.25;margin:0 0 14px}.hero-content p{line-height:1.8;color:#3d332b}.primary{background:var(--orange);color:#fff;border-radius:14px;padding:14px 18px;font-weight:800;box-shadow:0 8px 20px rgba(255,121,0,.18)}.search-button{width:100%;margin-top:12px;background:#fff;border:1px solid var(--line);border-radius:14px;padding:14px;font-weight:800}.hero-content .primary{width:100%}
.category-cards{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;margin-top:20px}.category-cards button{border:1px solid var(--line);border-radius:16px;padding:14px 8px;background:#fff;display:flex;flex-direction:column;align-items:center;gap:6px}.category-cards b{font-size:13px}.category-cards small{font-size:18px;font-weight:900}
.icon{display:inline-block;width:30px;height:30px;position:relative;color:currentColor}.icon.paw{color:var(--green)}.icon.cafe{color:var(--orange)}.icon.hotel{color:var(--blue)}
.icon.paw:before{content:'';position:absolute;width:13px;height:13px;border-radius:50%;background:currentColor;left:8px;top:13px;box-shadow:-8px -6px 0 -3px currentColor,8px -6px 0 -3px currentColor,-4px -12px 0 -4px currentColor,4px -12px 0 -4px currentColor}
.icon.cafe:before{content:'';position:absolute;width:16px;height:12px;border:3px solid currentColor;border-radius:2px 2px 8px 8px;left:3px;top:10px}.icon.cafe:after{content:'';position:absolute;width:8px;height:8px;border:3px solid currentColor;border-left:0;border-radius:0 9px 9px 0;right:2px;top:12px}
.icon.hotel:before{content:'';position:absolute;width:20px;height:20px;border:3px solid currentColor;border-radius:3px;left:5px;top:5px}.icon.hotel:after{content:'';position:absolute;width:3px;height:3px;background:currentColor;left:11px;top:11px;box-shadow:7px 0 currentColor,0 7px currentColor,7px 7px currentColor}
.map-top{height:54px;display:flex;align-items:center;justify-content:space-between;padding:0 18px;border-bottom:1px solid var(--line);font-weight:800}.map-top button{color:var(--orange)}
.mock-map{position:relative;min-height:520px;background:linear-gradient(90deg,rgba(255,255,255,.35) 49%,rgba(255,255,255,.75) 50%,rgba(255,255,255,.35) 51%),linear-gradient(0deg,rgba(255,255,255,.35) 49%,rgba(255,255,255,.75) 50%,rgba(255,255,255,.35) 51%),#dcebdd;background-size:84px 84px;overflow:hidden}
.mock-map:before{content:'';position:absolute;width:70%;height:80px;border-radius:999px;background:#badcff;left:12%;top:48%;transform:rotate(-18deg);opacity:.85}.mock-map:after{content:'';position:absolute;width:55%;height:64px;border-radius:999px;background:#badcff;right:-12%;top:65%;transform:rotate(24deg);opacity:.75}
.map-pin{position:absolute;z-index:2;width:46px;height:46px;border-radius:50% 50% 50% 8px;display:grid;place-items:center;transform:rotate(-45deg);box-shadow:0 8px 18px rgba(0,0,0,.18)}.map-pin .icon{transform:rotate(45deg);background:#fff;border-radius:50%;width:26px;height:26px}.map-pin.green{background:var(--green)}.map-pin.orange{background:var(--orange)}.map-pin.blue{background:var(--blue)}.my-location{position:absolute;z-index:3;left:49%;top:52%;width:24px;height:24px;border-radius:50%;background:#1d8cff;border:5px solid #fff;box-shadow:0 0 0 10px rgba(29,140,255,.18)}
.content-section{margin-top:18px;padding:22px}.section-title{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px}.section-title h2{margin:0}.section-title button{color:var(--orange);font-weight:800}
.nearby-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:12px}.near-card{border:1px solid var(--line);border-radius:18px;overflow:hidden;background:#fff}.near-card img{width:100%;height:145px;object-fit:cover;display:block}.near-card div{padding:12px}.near-card h3{font-size:15px;margin:0 0 4px}.near-card p{margin:0;color:var(--muted);font-size:13px}
.wide-card-list{display:grid;grid-template-columns:repeat(3,1fr);gap:12px}.wide-card{display:grid;grid-template-columns:105px 1fr;gap:12px;border:1px solid var(--line);border-radius:18px;padding:10px;background:#fff}.wide-card img{width:105px;height:90px;border-radius:12px;object-fit:cover}.wide-card h3{font-size:15px;margin:0 0 4px}.wide-card p{margin:0;color:var(--muted);font-size:13px}.tag{display:inline-block;font-size:11px;border-radius:999px;padding:5px 8px;font-weight:800;background:#fff0df;color:var(--orange);margin-right:4px}.cert{background:#e9f8ef;color:var(--green)}.rec{background:#fff1e1;border:1px solid #ffd2a3;color:var(--orange)}
.hint-card{display:grid;grid-template-columns:180px 1fr;gap:16px;align-items:center}.hint-card img{width:100%;height:130px;border-radius:16px;object-fit:cover}.hint-card a{color:var(--orange);font-weight:800}
.search-layout{display:grid;grid-template-columns:300px 1fr;gap:18px}.filters{padding:20px;height:max-content;position:sticky;top:90px}.filters h2{margin-top:0}.filters input{width:100%;border:1px solid var(--line);border-radius:12px;padding:12px;margin-bottom:12px}.chips{display:flex;flex-wrap:wrap;gap:8px;margin:10px 0 14px}.chip{border:1px solid var(--line);border-radius:999px;padding:9px 12px;background:#fff}.chip.active{background:var(--orange);color:#fff;border-color:var(--orange)}.filters label{display:block;margin:10px 0}.full{width:100%;margin-top:12px}
.results-area{padding:20px}.result-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px}.result-head h1{font-size:24px}.result-head p{color:var(--muted);margin:0}.desktop-result-grid{display:grid;grid-template-columns:1fr .9fr;gap:14px}.result-list{display:flex;flex-direction:column;gap:12px}.result-row{display:grid;grid-template-columns:110px 1fr;gap:12px;border:1px solid var(--line);border-radius:18px;background:#fff;padding:10px}.result-row img{width:110px;height:90px;border-radius:14px;object-fit:cover}.result-row h3{margin:0 0 5px;font-size:16px}.sticky-map{border-radius:22px;min-height:620px}
.back{margin-bottom:14px;color:var(--muted)}.detail-card{overflow:hidden}.detail-hero{height:420px;background:center/cover}.detail-gallery{display:flex;gap:10px;overflow-x:auto;padding:14px 18px;background:#fff;border-bottom:1px solid var(--line)}.detail-gallery-item{flex:0 0 112px;border:0;background:transparent;padding:0;cursor:pointer}.detail-gallery-item img{width:112px;height:78px;object-fit:cover;border-radius:14px;display:block}.detail-body{display:grid;grid-template-columns:1fr .9fr;gap:24px;padding:24px}.detail-actions{display:flex;gap:10px;flex-wrap:wrap}.info-list{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;margin:18px 0}.info-list span{background:#f4faf6;color:var(--green);border-radius:14px;text-align:center;padding:12px;font-weight:800}.detail-table{border:1px solid var(--line);border-radius:18px;overflow:hidden;margin-top:18px}.detail-table div{display:grid;grid-template-columns:145px 1fr;border-bottom:1px solid var(--line)}.detail-table div:last-child{border-bottom:0}.detail-table b{background:#fff7ef;padding:12px}.detail-table span{padding:12px}.official{display:inline-block;background:#fff;border:1px solid var(--orange);color:var(--orange);border-radius:14px;padding:13px 18px;font-weight:800;text-decoration:none}
.reviews-layout{display:grid;grid-template-columns:280px 1fr;gap:18px}.review-summary{padding:22px}.big-score{font-size:56px;font-weight:900}.sort-tabs{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:12px}.sort-tabs button{border:1px solid var(--line);background:#fff;border-radius:999px;padding:10px 12px}.sort-tabs .active{background:var(--orange);color:#fff}.review-list{display:flex;flex-direction:column;gap:12px}.review-card{padding:16px}.review-head{display:grid;grid-template-columns:44px 1fr auto;gap:10px;align-items:center}.review-head img{width:44px;height:44px;border-radius:50%;object-fit:cover}.review-head b{display:block}.review-head small{color:var(--muted)}.stars{color:var(--orange);font-weight:900}.review-tags{display:flex;gap:6px;flex-wrap:wrap;margin:10px 0}.review-tags span{font-size:11px;border-radius:999px;background:#f7f4ef;padding:6px 8px}.review-photos{display:grid;grid-template-columns:repeat(3,1fr);gap:6px;margin-top:10px}.review-photos img{width:100%;height:78px;object-fit:cover;border-radius:10px}
.mypage-card{text-align:center;padding:26px}.mypage-card img{width:96px;height:96px;border-radius:50%;object-fit:cover}.mypage-stats{display:flex;justify-content:center;gap:30px}.mypage-stats b{display:block;font-size:22px}.menu-list{margin-top:16px}.menu-list button{display:block;width:100%;text-align:left;padding:18px 22px;border-bottom:1px solid var(--line)}
.admin-layout{display:grid;grid-template-columns:240px 1fr;gap:18px}.admin-side{padding:18px;background:#13202c;color:#fff}.admin-side button{display:block;color:#fff;padding:12px;width:100%;text-align:left}.admin-main{padding:22px}.admin-section{display:none}.admin-section.active{display:block}.admin-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:12px}.admin-stats div{background:var(--cream);padding:20px;border-radius:16px;font-size:28px;font-weight:900;color:var(--orange)}table{width:100%;border-collapse:collapse}td,th{border-bottom:1px solid var(--line);padding:12px;text-align:left}.csv-tabs{display:flex;gap:8px;margin-bottom:12px}.csv-tabs button{border:1px solid var(--line);border-radius:999px;padding:9px 12px}.upload{border:2px dashed var(--line);border-radius:18px;height:130px;display:grid;place-items:center;color:var(--orange);font-weight:800;margin-bottom:12px}pre{background:#fff7ef;border-radius:18px;padding:16px;white-space:pre-wrap;font-size:12px}
.bottom-nav{display:none;position:fixed;bottom:0;left:0;right:0;height:68px;background:#fff;border-top:1px solid var(--line);z-index:20;align-items:center;justify-content:space-around}.bottom-nav button{display:flex;flex-direction:column;gap:2px;align-items:center;color:#534b44}.bottom-nav button.active,.bottom-nav button:hover{color:var(--orange)}.bottom-nav span{font-size:10px}
@media(max-width:860px){.site-header{height:56px;justify-content:center}.desktop-nav{display:none}.brand{font-size:18px}.brand .paw-logo{font-size:18px}main{padding:0 12px 80px}.home-grid,.search-layout,.desktop-result-grid,.detail-body,.reviews-layout,.admin-layout{grid-template-columns:1fr}.hero-panel,.map-panel,.content-section,.filters,.results-area,.detail-card,.review-summary,.review-card,.mypage-card,.menu-list{border-radius:20px}.home-grid{gap:12px}.hero-panel{order:1}.home-map{order:2;display:block}.hero-image{height:178px}.hero-content{padding:22px}h1{font-size:27px}.category-cards{grid-template-columns:repeat(3,1fr)}.map-panel .mock-map{min-height:260px}.content-section{padding:16px}.nearby-grid{display:flex;overflow-x:auto;gap:12px;padding-bottom:4px}.near-card{min-width:132px}.near-card img{height:115px}.near-card h3{font-size:12px}.wide-card-list{grid-template-columns:1fr}.hint-card{grid-template-columns:110px 1fr}.hint-card img{height:96px}.filters{position:static}.result-head{display:block}.sticky-map{min-height:320px;order:-1}.result-row{grid-template-columns:88px 1fr}.result-row img{width:88px;height:78px}.detail-hero{height:260px}.detail-body{padding:18px}.info-list{grid-template-columns:repeat(2,1fr)}.detail-table div{grid-template-columns:115px 1fr}.review-head{grid-template-columns:42px 1fr}.stars{grid-column:2}.review-photos img{height:65px}.bottom-nav{display:flex}}

/* v3 revisions */
.wide-card-list{display:none}
#recommendList.nearby-grid,#certifiedListHome.nearby-grid{grid-template-columns:repeat(4,1fr)}
.filter-group{border-top:1px solid var(--line);padding-top:12px;margin-top:12px}
.filter-group strong{display:block;font-size:13px;margin-bottom:6px}
.detail-actions{justify-content:center;align-items:center}
.write-review-cta{display:block;text-align:center;background:var(--orange);color:#fff;border-radius:16px;padding:15px 18px;font-weight:900;text-decoration:none;box-shadow:0 8px 20px rgba(255,121,0,.18)}
.detail-cta-grid{display:grid;grid-template-columns:1fr 1fr 1fr;gap:10px;margin:18px 0}
.detail-cta-grid button,.detail-cta-grid a{margin:0;text-align:center;display:grid;place-items:center}
@media(max-width:860px){
  #recommendList.nearby-grid,#certifiedListHome.nearby-grid{display:flex;overflow-x:auto}
  .detail-cta-grid{grid-template-columns:1fr}
}

/* v4 compact filter UI */
.compact-filters{
  padding:18px;
  overflow:visible;
}
.home-filter-preview{
  box-shadow:none;
  border:0;
  padding:0;
}
.top-filter-section{
  padding:20px 22px;
}
.filter-title-row{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
  margin-bottom:14px;
}
.filter-title-row h2{
  margin:0;
  font-size:18px;
}
.text-button{
  color:var(--orange);
  font-weight:800;
  font-size:13px;
}
.always-filters{
  display:grid;
  grid-template-columns:1.1fr 1.25fr 1.8fr 1.25fr;
  gap:16px;
  align-items:start;
}
.filter-field label{
  display:block;
  font-size:12px;
  font-weight:900;
  margin:0 0 8px;
}
.filter-field input[type="text"],
.filter-field input:not([type]),
.filter-field select,
.always-filters input:not([type]){
  width:100%;
  min-height:38px;
  border:1px solid var(--line);
  border-radius:8px;
  padding:9px 10px;
  background:#fff;
}
.mini-checks{
  display:grid;
  gap:8px;
}
.mini-checks.two-col{
  grid-template-columns:repeat(2, minmax(0, 1fr));
}
.mini-checks label,
.filter-group label{
  display:flex!important;
  align-items:center!important;
  gap:7px;
  margin:0!important;
  min-height:22px;
  line-height:1.35;
  font-size:13px;
  font-weight:500!important;
}
.mini-checks input,
.filter-group input{
  width:14px;
  height:14px;
  flex:0 0 14px;
  margin:0;
  accent-color:var(--orange);
}
.detail-toggle{
  width:100%;
  margin:16px 0 0;
  border:1px solid var(--line);
  border-radius:12px;
  padding:12px;
  background:#fff;
  font-weight:900;
}
.detail-filters{
  display:none;
  margin-top:16px;
  border-top:1px solid var(--line);
  padding-top:16px;
}
.detail-filters.open{
  display:block;
}
.filter-grid{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:14px;
  margin-bottom:16px;
}
.detail-filter-groups{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:14px;
}
.detail-filter-groups .filter-group{
  border:1px solid var(--line);
  border-radius:14px;
  padding:12px;
  margin:0;
}
.detail-filter-groups .filter-group strong{
  margin-bottom:10px;
}
.filter-actions{
  display:flex;
  justify-content:center;
  gap:14px;
  margin-top:18px;
}
.filter-actions .full{
  width:auto;
  min-width:170px;
  margin:0;
}
@media(max-width:980px){
  .always-filters{
    grid-template-columns:1fr 1fr;
  }
  .filter-grid,.detail-filter-groups{
    grid-template-columns:1fr 1fr;
  }
}
@media(max-width:860px){
  .top-filter-section{
    display:none;
  }
  .compact-filters{
    padding:16px;
  }
  .always-filters{
    grid-template-columns:1fr;
    gap:14px;
  }
  .mini-checks.two-col{
    grid-template-columns:1fr 1fr;
  }
  .filter-grid,.detail-filter-groups{
    grid-template-columns:1fr;
  }
  .filter-actions{
    display:grid;
    grid-template-columns:1fr;
  }
  .filter-actions .full{
    width:100%;
  }
}


/* exact 3-fix patch: logo + filter alignment + detail CTA only */

/* 犬顔ロゴ */
.dog-face-logo{
  width:42px;
  height:42px;
  border-radius:50%;
  background:#ffe3bf;
  display:inline-block;
  position:relative;
  flex:0 0 auto;
}
.dog-face-logo:before,
.dog-face-logo:after{
  content:"";
  position:absolute;
  width:13px;
  height:15px;
  background:#d99555;
  border-radius:50%;
  top:2px;
}
.dog-face-logo:before{left:1px;transform:rotate(-35deg)}
.dog-face-logo:after{right:1px;transform:rotate(35deg)}
.dog-face-logo span:before{
  content:"";
  position:absolute;
  left:10px;
  top:12px;
  width:22px;
  height:19px;
  border-radius:50%;
  background:#fff0d6;
}
.dog-face-logo span:after{
  content:"•  •";
  position:absolute;
  left:10px;
  top:11px;
  font-size:12px;
  color:#6f3f18;
  letter-spacing:5px;
}
.brand{
  display:flex!important;
  align-items:center!important;
  gap:10px!important;
}
.brand-copy b{
  display:block;
  line-height:1;
}
.brand-copy small{
  display:block;
  color:var(--orange);
  font-size:10px;
  font-weight:900;
  text-align:center;
  margin-top:3px;
}

/* チェックボックス縦位置修正 */
.mini-checks label,
.filter-group label,
.checks label{
  display:flex!important;
  align-items:center!important;
  gap:7px!important;
  min-height:22px;
  line-height:1.35!important;
}
.mini-checks input[type="checkbox"],
.filter-group input[type="checkbox"],
.checks input[type="checkbox"]{
  width:14px!important;
  height:14px!important;
  margin:0!important;
  flex:0 0 14px!important;
  accent-color:var(--orange);
}

/* PC表示：トップの横長検索条件は4列、検索ページのサイドバーは1列で崩れ防止 */
@media(min-width:861px){
  .top-filter-section .always-filters{
    grid-template-columns:1.05fr 1.05fr 1.55fr 1.25fr!important;
    gap:18px!important;
  }
  .search-layout > .filters .always-filters{
    grid-template-columns:1fr!important;
    gap:14px!important;
  }
  .search-layout > .filters .filter-grid,
  .search-layout > .filters .detail-filter-groups{
    grid-template-columns:1fr!important;
  }
  .search-layout > .filters .mini-checks.two-col{
    grid-template-columns:1fr!important;
  }
}

/* 詳細ページCTA */
.detail-cta-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:10px;
  margin:18px 0;
}
.detail-cta-grid button,
.detail-cta-grid a{
  display:grid;
  place-items:center;
  text-align:center;
  min-height:48px;
  border-radius:14px;
  font-weight:900;
  text-decoration:none;
}
.detail-cta-grid .official{
  border:1px solid var(--orange);
  color:var(--orange);
  background:#fff;
}
.write-review-cta{
  background:#fff2e4;
  color:var(--orange);
  border:1px solid #ffc48f;
}
@media(max-width:860px){
  .dog-face-logo{
    width:36px;
    height:36px;
  }
  .detail-cta-grid{
    grid-template-columns:1fr;
  }
}

/* interaction patch: search button overflow, forms, favorites */
.search-layout > .filters .filter-actions{
  display:grid!important;
  grid-template-columns:1fr!important;
  gap:10px!important;
  width:100%;
}
.search-layout > .filters .filter-actions .full{
  width:100%!important;
  min-width:0!important;
  margin:0!important;
}
.form-card{
  max-width:760px;
  margin:0 auto;
  background:#fff;
  border:1px solid var(--line);
  border-radius:24px;
  padding:26px;
  box-shadow:var(--shadow);
}
.form-heading h1{
  margin:0 0 8px;
}
.form-heading p{
  color:var(--muted);
  margin:0 0 18px;
}
.form-card label{
  display:block;
  font-weight:900;
  font-size:13px;
  margin:14px 0 7px;
}
.form-card input,
.form-card select,
.form-card textarea{
  width:100%;
  border:1px solid var(--line);
  border-radius:13px;
  padding:12px;
  background:#fff;
}
.form-card textarea{
  min-height:140px;
  resize:vertical;
}
.form-grid{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:12px;
}
.star-input{
  display:flex;
  gap:6px;
  margin:8px 0 12px;
}
.star-input button{
  color:var(--orange);
  font-size:30px;
}
.upload-box{
  height:128px;
  display:grid;
  place-items:center;
  border:2px dashed var(--line);
  border-radius:18px;
  color:var(--orange);
  font-weight:900;
  background:#fffaf3;
}
.form-actions{
  display:flex;
  justify-content:center;
  gap:12px;
  margin-top:20px;
}
.settings-list{
  box-shadow:none;
  border:1px solid var(--line);
}
.near-card,
.result-row{
  position:relative;
}
.fav-btn{
  position:absolute;
  top:10px;
  right:10px;
  z-index:5;
  width:34px;
  height:34px;
  border-radius:50%;
  display:grid;
  place-items:center;
  background:rgba(255,255,255,.94);
  border:1px solid var(--line);
  color:var(--orange);
  font-size:19px;
  font-weight:900;
  box-shadow:0 6px 14px rgba(0,0,0,.12);
}
.fav-btn.active{
  background:var(--orange);
  color:#fff;
  border-color:var(--orange);
}
.empty-state{
  background:#fff;
  border:1px solid var(--line);
  border-radius:18px;
  padding:24px;
  color:var(--muted);
}
@media(max-width:860px){
  .form-grid{
    grid-template-columns:1fr;
  }
  .form-actions{
    display:grid;
    grid-template-columns:1fr;
  }
}

/* settings subpages + visited button */
.card-actions{
  position:absolute;
  top:10px;
  right:10px;
  z-index:6;
  display:flex;
  flex-direction:column;
  gap:6px;
  align-items:flex-end;
}
.fav-btn{
  position:static!important;
}
.visited-btn{
  min-width:34px;
  height:30px;
  border-radius:999px;
  display:grid;
  place-items:center;
  background:rgba(255,255,255,.94);
  border:1px solid var(--line);
  color:var(--green);
  font-size:11px;
  font-weight:900;
  padding:0 9px;
  box-shadow:0 6px 14px rgba(0,0,0,.12);
}
.visited-btn.active{
  background:var(--green);
  color:#fff;
  border-color:var(--green);
}
.visited-detail-btn{
  width:100%;
  margin-top:10px;
  min-height:48px;
  border-radius:14px;
  font-weight:900;
  color:var(--green);
  background:#f2fbf5;
  border:1px solid #ccebd7;
}
.visited-detail-btn.active{
  background:var(--green);
  color:#fff;
  border-color:var(--green);
}
.setting-toggle-row{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:18px;
  border:1px solid var(--line);
  border-radius:16px;
  padding:16px;
  margin-top:12px;
}
.setting-toggle-row strong{
  display:block;
}
.setting-toggle-row span{
  display:block;
  color:var(--muted);
  font-size:13px;
  margin-top:4px;
}
.switch{
  position:relative;
  width:48px;
  height:28px;
  flex:0 0 48px;
}
.switch input{
  display:none;
}
.switch span{
  position:absolute;
  inset:0;
  border-radius:999px;
  background:#ddd;
  transition:.2s;
}
.switch span:before{
  content:"";
  position:absolute;
  width:22px;
  height:22px;
  left:3px;
  top:3px;
  border-radius:50%;
  background:#fff;
  transition:.2s;
}
.switch input:checked + span{
  background:var(--orange);
}
.switch input:checked + span:before{
  transform:translateX(20px);
}
.danger-box{
  border:1px solid #ffd0d0;
  background:#fff6f6;
  border-radius:16px;
  padding:16px;
  margin-top:16px;
}
.danger-box button{
  color:#c0392b;
  font-weight:900;
}
.settings-form{
  max-width:780px;
}
@media(max-width:860px){
  .setting-toggle-row{
    align-items:flex-start;
  }
}

/* visit-history refinement */
.visited-btn{
  min-width:76px!important;
  height:32px!important;
  border-radius:999px!important;
  display:grid!important;
  place-items:center!important;
  background:rgba(255,255,255,.96)!important;
  border:1px solid var(--line)!important;
  color:var(--green)!important;
  font-size:11px!important;
  font-weight:900!important;
  padding:0 10px!important;
  box-shadow:0 6px 14px rgba(0,0,0,.12)!important;
  white-space:nowrap;
}
.visited-btn.active{
  background:var(--green)!important;
  color:#fff!important;
  border-color:var(--green)!important;
}
.visited-detail-btn{
  width:100%;
  margin-top:10px;
  min-height:48px;
  border-radius:14px;
  font-weight:900;
  color:var(--green);
  background:#f2fbf5;
  border:1px solid #ccebd7;
}
.visited-detail-btn.active{
  background:var(--green);
  color:#fff;
  border-color:var(--green);
}
.visit-summary-card{
  display:flex;
  justify-content:space-between;
  align-items:center;
  gap:12px;
  background:#f2fbf5;
  border:1px solid #ccebd7;
  border-radius:18px;
  padding:16px 18px;
  color:var(--green);
}
.visit-summary-card strong{
  font-size:16px;
}
.visit-summary-card span{
  color:#4f7b5f;
  font-size:13px;
}
@media(max-width:860px){
  .visited-btn{
    min-width:68px!important;
    font-size:10px!important;
  }
  .bottom-nav{
    justify-content:space-around;
  }
}

/* header visit history + non-overlay card action buttons */
.desktop-nav button{
  white-space:nowrap;
}

/* 画像上に被せず、カード本文の中に自然に配置 */
.card-actions{
  position:static!important;
  top:auto!important;
  right:auto!important;
  z-index:auto!important;
  display:flex!important;
  flex-direction:row!important;
  gap:8px!important;
  align-items:center!important;
  justify-content:flex-start!important;
  margin-top:10px!important;
}
.inline-actions{
  flex-wrap:wrap;
}
.fav-btn,
.visited-btn{
  position:static!important;
  width:auto!important;
  min-width:auto!important;
  height:30px!important;
  border-radius:999px!important;
  display:inline-grid!important;
  place-items:center!important;
  padding:0 10px!important;
  font-size:11px!important;
  line-height:1!important;
  font-weight:900!important;
  box-shadow:none!important;
  white-space:nowrap!important;
}
.fav-btn{
  background:#fff7ec!important;
  border:1px solid #ffd3a5!important;
  color:var(--orange)!important;
}
.fav-btn.active{
  background:var(--orange)!important;
  border-color:var(--orange)!important;
  color:#fff!important;
}
.visited-btn{
  background:#f2fbf5!important;
  border:1px solid #ccebd7!important;
  color:var(--green)!important;
}
.visited-btn.active{
  background:var(--green)!important;
  border-color:var(--green)!important;
  color:#fff!important;
}
.near-card img,
.result-row img{
  position:relative;
  z-index:1;
}
.visit-summary-card{
  margin-bottom:12px;
}
@media(max-width:860px){
  .bottom-nav{
    justify-content:space-around;
  }
  .bottom-nav button{
    flex:1;
    min-width:0;
  }
  .bottom-nav span{
    font-size:9px;
  }
  .near-card .fav-btn{
    width:30px!important;
    padding:0!important;
  }
  .near-card .visited-btn{
    padding:0 8px!important;
  }
}

/* detail page save/visited actions */
.detail-save-row{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:10px;
  margin:10px 0 18px;
}
.detail-fav-btn,
.detail-visited-btn{
  min-height:46px;
  border-radius:14px;
  font-weight:900;
  display:grid;
  place-items:center;
  text-align:center;
}
.detail-fav-btn{
  background:#fff7ec;
  border:1px solid #ffd3a5;
  color:var(--orange);
}
.detail-fav-btn.active{
  background:var(--orange);
  border-color:var(--orange);
  color:#fff;
}
.detail-visited-btn{
  background:#f2fbf5;
  border:1px solid #ccebd7;
  color:var(--green);
}
.detail-visited-btn.active{
  background:var(--green);
  border-color:var(--green);
  color:#fff;
}
@media(max-width:860px){
  .detail-save-row{
    grid-template-columns:1fr;
  }
}

/* detail CTA refined: avoid five equal buttons */
.detail-cta-grid,
.detail-save-row{
  display:none!important;
}
.detail-rating-line{
  display:flex;
  flex-wrap:wrap;
  align-items:center;
  gap:8px;
  color:var(--orange);
  font-weight:900;
}
.detail-rating-line button{
  color:var(--orange);
  text-decoration:underline;
  font-weight:900;
}
.detail-rating-line span{
  color:var(--muted);
  font-weight:700;
}
.detail-action-panel{
  margin:20px 0 18px;
  border:1px solid var(--line);
  border-radius:20px;
  background:#fffaf3;
  padding:16px;
}
.detail-main-cta{
  display:flex;
  justify-content:space-between;
  align-items:center;
  gap:14px;
  padding-bottom:14px;
  border-bottom:1px solid var(--line);
}
.detail-main-cta strong{
  display:block;
  font-size:16px;
}
.detail-main-cta span{
  display:block;
  color:var(--muted);
  font-size:13px;
  margin-top:4px;
  line-height:1.5;
}
.write-review-main{
  min-width:150px;
  min-height:48px;
  border-radius:14px;
  background:var(--orange);
  color:#fff;
  font-weight:900;
  box-shadow:0 8px 20px rgba(255,121,0,.18);
}
.detail-sub-actions{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:10px;
  margin-top:12px;
}
.review-link-btn,
.official-link-btn{
  min-height:42px;
  border-radius:12px;
  display:grid;
  place-items:center;
  text-align:center;
  font-weight:900;
  text-decoration:none;
}
.review-link-btn{
  background:#fff;
  border:1px solid var(--line);
  color:var(--text);
}
.official-link-btn{
  background:#fff;
  border:1px solid var(--orange);
  color:var(--orange);
}
.detail-save-actions{
  display:flex;
  gap:8px;
  flex-wrap:wrap;
  margin-top:12px;
}
.detail-save-actions .detail-fav-btn,
.detail-save-actions .detail-visited-btn{
  min-height:34px;
  width:auto;
  border-radius:999px;
  padding:0 12px;
  font-size:12px;
  box-shadow:none;
}
@media(max-width:860px){
  .detail-main-cta{
    display:block;
  }
  .write-review-main{
    width:100%;
    margin-top:12px;
  }
  .detail-sub-actions{
    grid-template-columns:1fr;
  }
}

/* detail CTA save actions centered */
.detail-save-actions{
  justify-content:center!important;
}

/* tested review sort + favorite summary */
.sort-tabs button,
.tabs button{
  cursor:pointer;
  position:relative;
  z-index:2;
}
.sort-tabs button.active,
.tabs button.active{
  background:var(--orange);
  color:#fff;
  border-color:var(--orange);
}
.favorite-summary-card{
  margin-bottom:12px;
}

/* review image modal + detail review section + certified/contact pages */
.review-photos{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:8px;
  margin-top:12px;
}
.review-photo-button{
  border:0;
  padding:0;
  background:transparent;
  border-radius:12px;
  overflow:hidden;
  cursor:pointer;
  display:block;
}
.review-photo-button img,
.review-photos img{
  width:100%;
  aspect-ratio:3/4;
  height:auto!important;
  object-fit:cover;
  border-radius:12px;
  display:block;
}
.photo-modal{
  position:fixed;
  inset:0;
  background:rgba(0,0,0,.72);
  z-index:9999;
  display:none;
  align-items:center;
  justify-content:center;
  padding:24px;
}
.photo-modal.open{
  display:flex;
}
.phone-photo-viewer{
  width:min(390px, 88vw);
  aspect-ratio:9/16;
  background:#111;
  border:10px solid #111;
  border-radius:36px;
  overflow:hidden;
  position:relative;
  box-shadow:0 20px 70px rgba(0,0,0,.35);
}
.phone-photo-viewer img{
  width:100%;
  height:100%;
  object-fit:cover;
  display:block;
}
.photo-close{
  position:absolute;
  top:10px;
  right:10px;
  width:34px;
  height:34px;
  border-radius:50%;
  background:rgba(255,255,255,.9);
  color:#111;
  z-index:2;
  font-weight:900;
}
.detail-review-section h2{
  margin:0 0 12px;
  font-size:20px;
}
.review-more-btn{
  width:100%;
  min-height:46px;
  border-radius:14px;
  background:#fff;
  border:1px solid var(--orange);
  color:var(--orange);
  font-weight:900;
  margin-top:8px;
}
.review-page-header{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
  margin-bottom:16px;
}
.certified-page,
.contact-page{
  background:#fff;
  border:1px solid var(--line);
  border-radius:24px;
  padding:28px;
  box-shadow:var(--shadow);
}
.certified-hero-box{
  text-align:center;
  max-width:760px;
  margin:0 auto 22px;
}
.certified-badge-large{
  display:inline-grid;
  place-items:center;
  min-height:42px;
  padding:0 18px;
  background:#f6b23b;
  color:#fff;
  border-radius:999px;
  font-weight:900;
  margin-bottom:14px;
}
.cert-rule-grid{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:14px;
  margin:22px 0;
}
.cert-rule-grid div{
  background:#fff8ef;
  border:1px solid var(--line);
  border-radius:16px;
  padding:16px;
}
.cert-rule-grid strong{
  display:block;
  margin-bottom:6px;
}
.cert-rule-grid span{
  display:block;
  color:var(--muted);
  font-size:13px;
  line-height:1.5;
}
.cert-flow{
  background:#f8fbf7;
  border:1px solid #dceee0;
  border-radius:18px;
  padding:18px;
  margin-bottom:22px;
}
.cert-flow li{
  margin:8px 0;
}
.contact-hero{
  text-align:center;
  max-width:760px;
  margin:0 auto 22px;
}
.contact-grid{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:18px;
}
.contact-card{
  border:1px solid var(--line);
  border-radius:20px;
  padding:20px;
  background:#fff;
}
.contact-card.corporate{
  background:#fffaf3;
}
.contact-card label{
  display:block;
  font-weight:900;
  font-size:13px;
  margin:14px 0 7px;
}
.contact-card input,
.contact-card select,
.contact-card textarea{
  width:100%;
  border:1px solid var(--line);
  border-radius:13px;
  padding:12px;
  background:#fff;
}
.contact-card textarea{
  min-height:130px;
  resize:vertical;
}
@media(max-width:860px){
  .review-page-header{
    display:grid;
    grid-template-columns:1fr;
  }
  .cert-rule-grid,
  .contact-grid{
    grid-template-columns:1fr;
  }
  .certified-page,
  .contact-page{
    padding:18px;
  }
}

/* final polish: contact alignment, mobile top card alignment, detail official only */
.detail-sub-actions.official-only{
  grid-template-columns:1fr;
}
.detail-sub-actions.official-only .official-link-btn{
  max-width:360px;
  width:100%;
  margin:0 auto;
}
.detail-rating-line span{
  color:var(--muted);
  font-weight:700;
}

/* お問い合わせPC表示：個人/法人カードの縦位置と送信ボタン位置を揃える */
@media(min-width:861px){
  .contact-grid{
    align-items:stretch;
  }
  .contact-card{
    display:flex;
    flex-direction:column;
  }
  .contact-card > p{
    min-height:54px;
  }
  .contact-card .primary.full{
    margin-top:auto!important;
  }
}

/* TOPセクションのカード表示を揃える */
.near-card{
  display:flex;
  flex-direction:column;
}
.near-card > div{
  display:flex;
  flex-direction:column;
  flex:1;
}
.near-card h3{
  line-height:1.35;
}
.near-card .inline-actions{
  margin-top:auto!important;
}

/* スマホTOP：文字数差でボタン位置がズレないよう固定 */
@media(max-width:860px){
  .near-card{
    min-width:148px;
    height:258px;
  }
  .near-card img{
    flex:0 0 115px;
  }
  .near-card > div{
    min-height:143px;
  }
  .near-card h3{
    min-height:34px;
    display:-webkit-box;
    -webkit-line-clamp:2;
    -webkit-box-orient:vertical;
    overflow:hidden;
  }
  .near-card p{
    min-height:36px;
  }
  .near-card .inline-actions{
    min-height:34px;
    align-items:flex-end!important;
  }
}

/* mobile card action fix + contact form typography */
.contact-card label,
.contact-card input,
.contact-card select,
.contact-card textarea{
  font-size:14px!important;
  line-height:1.5!important;
}
.contact-card input,
.contact-card select{
  min-height:44px;
}
.contact-card textarea{
  min-height:132px;
}

/* TOPカード：本文内で高さを揃え、ボタンがはみ出ないようにする */
.near-card{
  display:flex!important;
  flex-direction:column!important;
  overflow:hidden!important;
}
.near-card > div{
  display:flex!important;
  flex-direction:column!important;
  flex:1 1 auto!important;
  min-height:0!important;
}
.near-card h3{
  line-height:1.35!important;
}
.near-card p{
  line-height:1.45!important;
}
.near-card .inline-actions{
  margin-top:auto!important;
  display:flex!important;
  align-items:center!important;
  justify-content:center!important;
  gap:6px!important;
  width:100%!important;
  flex-wrap:nowrap!important;
}
.near-card .fav-btn,
.near-card .visited-btn{
  height:28px!important;
  min-height:28px!important;
  border-radius:999px!important;
  font-size:10px!important;
  padding:0 8px!important;
  white-space:nowrap!important;
}

@media(max-width:860px){
  .nearby-grid{
    align-items:stretch!important;
  }
  .near-card{
    min-width:154px!important;
    height:286px!important;
    flex:0 0 154px!important;
  }
  .near-card img{
    flex:0 0 112px!important;
    height:112px!important;
    object-fit:cover!important;
  }
  .near-card > div{
    padding:10px!important;
    min-height:174px!important;
  }
  .near-card h3{
    min-height:38px!important;
    margin-bottom:4px!important;
    display:-webkit-box!important;
    -webkit-line-clamp:2!important;
    -webkit-box-orient:vertical!important;
    overflow:hidden!important;
  }
  .near-card p{
    min-height:38px!important;
    margin-bottom:8px!important;
  }
  .near-card .inline-actions{
    min-height:34px!important;
    margin-top:auto!important;
    padding-top:4px!important;
  }
  .near-card .fav-btn{
    width:31px!important;
    min-width:31px!important;
    padding:0!important;
  }
  .near-card .visited-btn{
    flex:1 1 auto!important;
    min-width:78px!important;
    padding:0 7px!important;
  }
}

/* footer / legal pages */
.site-footer{
  max-width:1180px;
  margin:28px auto 0;
  padding:0 22px 92px;
}
.footer-inner{
  background:#fff;
  border:1px solid var(--line);
  border-radius:24px;
  padding:22px;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:18px;
  box-shadow:var(--shadow);
}
.footer-inner strong{
  color:var(--orange);
  font-size:20px;
}
.footer-inner p{
  margin:4px 0 0;
  color:var(--muted);
  font-size:13px;
}
.footer-nav{
  display:flex;
  gap:12px;
  flex-wrap:wrap;
}
.footer-nav button{
  color:var(--orange);
  font-weight:900;
}
.footer-inner small{
  color:var(--muted);
  white-space:nowrap;
}
.legal-page{
  background:#fff;
  border:1px solid var(--line);
  border-radius:24px;
  padding:28px;
  box-shadow:var(--shadow);
  line-height:1.8;
}
.legal-page h1{
  margin-top:0;
}
.legal-page h2{
  font-size:18px;
  margin-top:24px;
}
.legal-note{
  background:#fff7ef;
  border-radius:16px;
  padding:16px;
  margin-top:24px;
}
.company-table{
  width:100%;
  border-collapse:collapse;
  margin-top:18px;
  overflow:hidden;
  border-radius:16px;
}
.company-table th,
.company-table td{
  border-bottom:1px solid var(--line);
  padding:14px;
  text-align:left;
}
.company-table th{
  width:180px;
  background:#fff7ef;
}
@media(max-width:860px){
  .site-footer{
    padding:0 12px 86px;
  }
  .footer-inner{
    display:block;
    text-align:center;
  }
  .footer-nav{
    justify-content:center;
    margin:14px 0;
  }
  .footer-inner small{
    white-space:normal;
  }
  .legal-page{
    padding:20px;
  }
  .company-table th,
  .company-table td{
    display:block;
    width:100%;
  }
}

/* navigation final: back button spacing only, no design redesign */
.page > .back{
  margin-bottom:14px;
}
.star-input button{
  cursor:pointer;
}

/* final navigation pages */
#recommended-list .content-section,
#certified-list .content-section{
  margin-top:0;
}
#recommended-list .section-title,
#certified-list .section-title{
  margin-bottom:8px;
}
#recommended-list .section-title h1,
#certified-list .section-title h1{
  margin:0;
}


/* contact form overlap fix */
.contact-card{
  overflow:visible!important;
}
.contact-card textarea{
  display:block!important;
  width:100%!important;
  box-sizing:border-box!important;
  min-height:150px!important;
  margin-bottom:16px!important;
  flex-shrink:0!important;
}
.contact-card .primary.full{
  position:static!important;
  display:flex!important;
  align-items:center!important;
  justify-content:center!important;
  width:100%!important;
  min-height:48px!important;
  margin-top:16px!important;
  flex-shrink:0!important;
}
@media(min-width:861px){
  .contact-card{
    display:flex!important;
    flex-direction:column!important;
  }
  .contact-card.corporate textarea{
    min-height:150px!important;
  }
}
