/**
 * wannya コンポーネントCSS v2.0
 */

/* ══════════════════════════════════════
   PET CARD (.pc)
══════════════════════════════════════ */
.pc{
  background:var(--wh);border-radius:14px;
  border:1px solid var(--bdr);overflow:hidden;
  cursor:pointer;transition:all .25s cubic-bezier(.4,0,.2,1);
}
.pc:hover{
  box-shadow:0 10px 30px rgba(0,0,0,.12);
  transform:translateY(-4px) rotate(.3deg);
  border-color:transparent;
}
.pc-img{
  width:100%;aspect-ratio:1/1;position:relative;overflow:hidden;
}
.pc-img-br{background:linear-gradient(145deg,#FFE8CC,#FFBF80,#F4956A);}
.pc-img-sp{background:linear-gradient(145deg,#D8EEFF,#A0C8FF,#7AAFF5);}
.pc-img-sh{background:linear-gradient(145deg,#C8F0DC,#88DDB0,#4EC98A);}
.pc-img-br2{background:linear-gradient(145deg,#FFD4B8,#F5A06A,#E8784A);}
.pc-img-sp2{background:linear-gradient(145deg,#CCE4FF,#90BFFF,#5899F0);}
.pc-img img{width:100%;height:100%;object-fit:cover;}
.pc-emoji{
  position:absolute;inset:0;display:flex;align-items:center;justify-content:center;
  font-size:clamp(36px,7vw,52px);filter:drop-shadow(0 2px 8px rgba(0,0,0,.12));
}
.pc-ov{
  position:absolute;bottom:0;left:0;right:0;padding:8px;
  display:flex;justify-content:space-between;align-items:flex-end;
  background:linear-gradient(to top,rgba(0,0,0,.18),transparent);z-index:3;
}
.ptype{padding:3px 9px;border-radius:6px;font-size:10px;font-weight:700;line-height:1.4;}
.t-br{background:var(--or);color:#fff;}
.t-sp{background:var(--bl);color:#fff;}
.t-sh{background:var(--gr);color:#fff;}
.pfav{
  width:30px;height:30px;border-radius:50%;
  background:rgba(255,255,255,.92);
  display:flex;align-items:center;justify-content:center;
  font-size:15px;transition:all .2s;flex-shrink:0;
  box-shadow:0 2px 8px rgba(0,0,0,.12);
}
.pfav:hover{transform:scale(1.15);background:#fff;}
.pc-body{padding:11px 11px 13px;}
.pc-breed{
  font-family:'Outfit',sans-serif;
  font-size:13px;font-weight:700;margin-bottom:4px;line-height:1.3;
}
.pc-meta{font-size:11px;color:var(--soft);margin-bottom:6px;display:flex;gap:6px;flex-wrap:wrap;}
.pc-price{
  font-family:'Outfit',sans-serif;
  font-size:16px;font-weight:800;letter-spacing:-.02em;
}
.pc-price-s{font-size:11px;color:var(--soft);font-weight:400;font-family:'Noto Sans JP';}
.pc-tags{display:flex;gap:4px;margin-top:7px;flex-wrap:wrap;}
.tg{padding:2px 8px;border-radius:5px;font-size:10px;font-weight:600;}
.tg-or{background:var(--or-l);color:var(--or-d);}
.tg-gr{background:var(--gr-l);color:var(--gr-d);}
.tg-bl{background:var(--bl-l);color:var(--bl-d);}
.tg-gy{background:var(--bdr2);color:var(--mid);}
@media(max-width:600px){
  .pc-breed{font-size:12px;}
  .pc-price{font-size:14px;}
  .pc-body{padding:9px 9px 11px;}
  .pc-meta{font-size:10px;}
}

/* ══════════════════════════════════════
   PROVIDER CARD (.provcard) - additional
══════════════════════════════════════ */
/* styles defined in main.css */

/* ══════════════════════════════════════
   REVIEW CARD (.rvcard) - additional
══════════════════════════════════════ */
/* styles defined in main.css */

/* ══════════════════════════════════════
   BUTTONS (legacy support)
══════════════════════════════════════ */
.btn{
  display:inline-block;padding:12px 32px;border-radius:9999px;
  font-weight:700;font-size:1rem;text-align:center;cursor:pointer;
  border:none;transition:all .2s;
}
.btn--primary{background:var(--or);color:#fff;}
.btn--primary:hover{opacity:.9;color:#fff;}
.btn--outline{border:2px solid var(--or);color:var(--or);background:transparent;}
.btn--outline:hover{background:var(--or);color:#fff;}
.btn--white{background:#fff;color:var(--or);}
.btn--line{background:#06C755;color:#fff;}
.btn--line:hover{opacity:.9;color:#fff;}
.btn--lg{padding:16px 48px;font-size:1.1rem;}

/* ══════════════════════════════════════
   BADGE
══════════════════════════════════════ */
.badge{display:inline-block;padding:3px 10px;border-radius:9999px;font-size:.75rem;font-weight:700;}
.badge--new{background:#FF6B6B;color:#fff;font-size:.7rem;padding:3px 8px;border-radius:4px;letter-spacing:.05em;}
.badge--available{background:var(--gr-l);color:var(--gr-d);}
.badge--sold{background:var(--bdr2);color:var(--mid);}
.badge--shop{background:var(--or-l);color:var(--or-d);}

/* ══════════════════════════════════════
   PET DETAIL (legacy)
══════════════════════════════════════ */
.pet-detail__main{display:grid;grid-template-columns:1fr 1fr;gap:40px;margin-bottom:40px;}
@media(max-width:768px){.pet-detail__main{grid-template-columns:1fr;gap:24px;}}
.pet-detail__main-image img{width:100%;border-radius:12px;aspect-ratio:4/3;object-fit:cover;}
.pet-detail__thumbnails{display:flex;gap:8px;margin-top:12px;overflow-x:auto;}
.pet-detail__thumb{
  flex-shrink:0;width:80px;height:80px;border:2px solid transparent;
  border-radius:8px;overflow:hidden;cursor:pointer;background:none;padding:0;
}
.pet-detail__thumb.active{border-color:var(--or);}
.pet-detail__thumb img{width:100%;height:100%;object-fit:cover;}
.pet-detail__header{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;margin-bottom:12px;}
.pet-detail__title{font-size:1.75rem;font-weight:700;}
.pet-detail__price{font-size:2rem;font-weight:700;color:var(--or);margin-bottom:20px;}
.pet-detail__price-tax{font-size:.85rem;color:var(--soft);font-weight:400;}
.pet-detail__specs{display:grid;grid-template-columns:100px 1fr;gap:8px 16px;font-size:.9rem;margin-bottom:24px;}
.pet-detail__specs dt{color:var(--soft);font-weight:500;}
.pet-detail__section{margin-bottom:40px;}
.pet-detail__section-title{font-size:1.25rem;font-weight:700;margin-bottom:16px;padding-bottom:8px;border-bottom:2px solid var(--or);}
.primary-cta{display:flex;flex-direction:column;gap:12px;}
.detail-table{width:100%;border-collapse:collapse;}
.detail-table th,.detail-table td{padding:12px 16px;border-bottom:1px solid var(--bdr);font-size:.9rem;text-align:left;}
.detail-table th{background:var(--bdr2);font-weight:500;width:180px;}
.pet-detail__cta-banner{background:var(--or-l);border-radius:12px;padding:32px;text-align:center;margin-bottom:40px;}
.pet-detail__cta-banner p{font-weight:700;margin-bottom:16px;font-size:1.1rem;}
.pet-detail__video iframe{width:100%;aspect-ratio:16/9;border:none;border-radius:12px;}

/* Shop Info */
.shop-info__card{display:flex;align-items:center;gap:16px;padding:16px;background:var(--bdr2);border-radius:12px;}
.shop-info__img{width:64px;height:64px;border-radius:50%;object-fit:cover;}
.shop-info__img-placeholder{width:64px;height:64px;border-radius:50%;background:var(--bdr);display:flex;align-items:center;justify-content:center;font-size:1.5rem;}
.shop-info__name{font-weight:700;font-size:1rem;}
.shop-info__area{font-size:.85rem;color:var(--soft);}

/* Floating CTA */
.floating-cta{
  position:fixed;bottom:0;left:0;right:0;
  background:rgba(255,255,255,.95);backdrop-filter:blur(10px);
  padding:12px 0;box-shadow:0 -2px 10px rgba(0,0,0,.1);z-index:100;
  transform:translateY(100%);transition:transform .3s ease;
}
.floating-cta.visible{transform:translateY(0);}
.floating-cta__inner{display:flex;align-items:center;justify-content:space-between;gap:16px;max-width:1120px;margin:0 auto;padding:0 20px;}
.floating-cta__price{font-size:1.25rem;font-weight:700;color:var(--or);}
.floating-cta__button{display:inline-block;background:var(--or);color:#fff;padding:12px 32px;border-radius:8px;font-weight:700;font-size:.95rem;}

/* ══════════════════════════════════════
   SEARCH FORM (legacy)
══════════════════════════════════════ */
.search-form{background:var(--wh);padding:24px;border-radius:16px;box-shadow:0 2px 12px rgba(0,0,0,.08);margin-bottom:32px;}
.search-form__grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;}
@media(max-width:768px){.search-form__grid{grid-template-columns:1fr 1fr;}}
@media(max-width:480px){.search-form__grid{grid-template-columns:1fr;}}
.search-form__label{display:block;font-size:.8rem;font-weight:700;margin-bottom:4px;color:var(--soft);}
.search-form__select,.search-form__input{width:100%;padding:10px 12px;border:1px solid var(--bdr);border-radius:8px;font-size:.9rem;background:var(--bg);}
.search-form__price-range{display:flex;align-items:center;gap:8px;}
.search-form__price-range input{flex:1;}
.search-form__actions{text-align:center;margin-top:16px;}

/* ══════════════════════════════════════
   ARCHIVE
══════════════════════════════════════ */
.container{max-width:1120px;margin:0 auto;padding:0 20px;}
.archive-header{margin-bottom:24px;}
.archive-header__title{font-size:1.75rem;font-weight:700;}
.archive-header__desc{margin-top:8px;color:var(--soft);font-size:.9rem;}
.archive-count{font-size:.9rem;color:var(--soft);margin-bottom:16px;}
.no-results{text-align:center;padding:60px 0;color:var(--soft);}

/* Pet Grid (archive) */
.pet-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:24px;}
@media(max-width:1024px){.pet-grid{grid-template-columns:repeat(3,1fr);}}
@media(max-width:768px){.pet-grid,.pet-grid--small{grid-template-columns:repeat(2,1fr);gap:12px;}}

/* Column Grid (archive) */
.column-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:32px;}
@media(max-width:768px){.column-grid{grid-template-columns:repeat(2,1fr);gap:16px;}}

/* Pagination */
.pagination{margin-top:40px;text-align:center;}
.pagination .nav-links{display:flex;justify-content:center;gap:4px;}
.pagination .page-numbers{
  display:inline-flex;align-items:center;justify-content:center;
  width:40px;height:40px;border-radius:8px;
  background:var(--wh);border:1px solid var(--bdr);font-size:.9rem;font-weight:500;
}
.pagination .page-numbers.current{background:var(--or);color:#fff;border-color:var(--or);}

/* Section (legacy) */
.section{padding:60px 0;}
.section__title{font-size:1.75rem;font-weight:700;text-align:center;margin-bottom:2rem;position:relative;}
.section__title::after{content:'';display:block;width:60px;height:3px;background:var(--or);margin:12px auto 0;border-radius:2px;}
.section__more{text-align:center;margin-top:2rem;}
.site-main{margin-top:var(--nav);}

/* Post Grid (index) */
.post-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;}
@media(max-width:768px){.post-grid{grid-template-columns:1fr;}}
.post-card{background:var(--wh);border-radius:14px;overflow:hidden;border:1px solid var(--bdr);transition:all .25s;}
.post-card:hover{box-shadow:var(--sha-h);transform:translateY(-3px);}
.post-card__image img{width:100%;aspect-ratio:16/9;object-fit:cover;}
.post-card__content{padding:16px;}
.post-card__title{font-size:1rem;font-weight:700;margin-bottom:8px;}
.post-card__title a{color:var(--ink);}
.post-card__excerpt{font-size:.85rem;color:var(--mid);line-height:1.7;}

/* Column Card (template) */
.column-card{
  background:var(--wh);border-radius:14px;overflow:hidden;
  box-shadow:0 1px 8px rgba(0,0,0,.04);transition:all .25s;border:1px solid var(--bdr);
}
.column-card:hover{transform:translateY(-4px);box-shadow:var(--sha-h);}
.column-card__link{display:block;color:inherit;}
.column-card__image{overflow:hidden;}
.column-card__image img{width:100%;aspect-ratio:16/9;object-fit:cover;transition:transform .6s;}
.column-card:hover .column-card__image img{transform:scale(1.05);}
.column-card__body{padding:16px;}
.column-card__title{font-size:.95rem;font-weight:700;line-height:1.6;margin-bottom:8px;}
.column-card__date{font-size:.8rem;color:var(--soft);}

/* Pet Card (template-parts/common/card-pet legacy) */
.pet-card{
  background:var(--wh);border-radius:14px;overflow:hidden;
  box-shadow:0 1px 8px rgba(0,0,0,.04);transition:all .25s;
  display:flex;flex-direction:column;border:1px solid var(--bdr);
}
.pet-card:hover{transform:translateY(-4px);box-shadow:var(--sha-h);}
.pet-card__link{display:block;color:inherit;}
.pet-card__image{position:relative;aspect-ratio:1/1;overflow:hidden;}
.pet-card__image img{width:100%;height:100%;object-fit:cover;}
.pet-card__noimage{background:var(--bdr2);display:flex;align-items:center;justify-content:center;height:100%;color:var(--soft);}
.pet-card__status{position:absolute;top:8px;left:8px;}
.pet-card__body{padding:11px 11px 13px;}
.pet-card__title{font-size:13px;font-weight:700;margin-bottom:4px;line-height:1.3;}
.pet-card__breed{font-size:11px;color:var(--soft);margin-bottom:6px;}
.pet-card__meta{display:flex;justify-content:space-between;align-items:center;}
.pet-card__price{font-size:16px;font-weight:800;color:var(--or);font-family:'Outfit',sans-serif;}
.pet-card__gender{font-size:.9rem;}
.pet-card__area{font-size:10px;color:var(--soft);margin-top:4px;}
