@import url('https://fonts.googleapis.com/css2?family=Hanken+Grotesk:ital,wght@0,200;0,300;0,400;0,500;0,600&family=Source+Serif+4:ital,opsz,wght@0,8..60,300;0,8..60,400;0,8..60,500;1,8..60,400&family=Archivo+Black&display=swap');
/* BUDDY&CO. ECモック / typography matched to free stitch (fs-store.jp): aktiv-grotesk(thin)→Hanken Grotesk, kepler-std→Source Serif 4, YuGothic */
:root{
  --paper:#ffffff; --paper-2:#f4f4f4; --ink:#111111; --ink-2:#333333; --ink-soft:#8c8c8c;
  --line:#e3e3e3; --accent:#c0562f; --accent-soft:#f4e3da; --sage:#777777; --dark:#111111;
  --line-green:#111111;
  --grotesk:"Hanken Grotesk","Helvetica Neue",Arial,sans-serif;
  --serif:"Source Serif 4","Kepler",Georgia,"Hiragino Mincho ProN",serif;
  --jp:"YuGothic","Yu Gothic","Hiragino Kaku Gothic ProN","Noto Sans JP",sans-serif;
  --sans:"Hanken Grotesk","YuGothic","Yu Gothic","Hiragino Kaku Gothic ProN","Noto Sans JP",sans-serif;
  --pw:min(1280px,90vw); --r:1px;
  --img:grayscale(1) contrast(1.04);
}
*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{background:var(--paper);color:var(--ink-2);font-family:var(--sans);font-weight:300;
  line-height:2.1;font-size:13px;-webkit-font-smoothing:antialiased;overflow-x:hidden;letter-spacing:.04em}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
::selection{background:var(--accent);color:#fff}

/* display = thin grotesque (matches aktiv-grotesk-thin), wide tracking, restrained size */
.h-serif{font-family:var(--sans);font-weight:300;font-size:clamp(22px,3.2vw,40px);line-height:1.7;letter-spacing:.16em;margin:0;color:var(--ink)}
.h-serif--light{color:#fff;font-weight:200}
/* eyebrow = kepler-like serif accent */
.eyebrow{font-family:var(--serif);font-weight:400;font-size:13px;letter-spacing:.12em;color:var(--accent);margin:0 0 20px}
.eyebrow--light{color:#cfcfcf}
.section__note{color:var(--ink-soft);font-size:12px;margin:16px 0 0;max-width:48ch;line-height:2.2;letter-spacing:.06em}

/* buttons: aktiv-grotesk-style, thin, squared, wide tracking, small */
.btn{display:inline-block;margin-top:28px;padding:15px 40px;border:1px solid var(--ink);border-radius:var(--r);
  font-family:var(--grotesk);font-weight:400;font-size:11px;letter-spacing:.26em;text-transform:uppercase;
  background:transparent;color:var(--ink);transition:.4s ease}
.btn:hover{background:var(--ink);color:var(--paper)}
.btn--solid{background:var(--ink);border-color:var(--ink);color:var(--paper)}
.btn--solid:hover{background:transparent;color:var(--ink)}
.btn--light{border-color:rgba(255,255,255,.8);color:#fff}
.btn--light:hover{background:#fff;color:var(--ink)}
.btn--line{border-color:var(--line-green);color:var(--line-green)}
.btn--line:hover{background:var(--line-green);color:#fff}

/* clean natural image treatment (free stitch = bright, natural) */
.hero__bg,.cat__img,.pcard__img>div,.life__fig .ph,.banner__bg,.look__media .ph,
.pdp__main-img,.pdp__thumbs .swiper-slide,.about-hero .ph{filter:var(--img)}

/* 1. promo marquee — tiny, tracked */
.promo{background:var(--dark);color:rgba(255,255,255,.82);overflow:hidden;font-size:10.5px;letter-spacing:.24em;text-transform:uppercase;white-space:nowrap;font-family:var(--grotesk)}
.promo__track{display:inline-flex;gap:50px;align-items:center;padding:11px 0;will-change:transform}
.promo__track .dot{color:var(--accent-soft);font-size:5px}

/* 2. header — minimal, small tracked nav */
.header{position:sticky;top:0;z-index:50;background:rgba(255,255,255,.92);backdrop-filter:blur(10px);
  border-bottom:1px solid var(--line);display:flex;align-items:center;justify-content:space-between;
  gap:24px;padding:22px clamp(20px,4vw,52px);transition:transform .45s ease}
.header.is-hidden{transform:translateY(-100%)}
.header__logo{font-family:var(--grotesk);font-size:22px;letter-spacing:.14em;font-weight:300;color:var(--ink)}
.header__logo span{color:var(--accent);font-weight:400}
.header__nav{display:flex;gap:30px;font-family:var(--grotesk);font-size:11.5px;letter-spacing:.14em;text-transform:uppercase}
.header__nav a{position:relative;padding:6px 0;color:var(--ink);transition:color .3s;font-weight:400}
.header__nav a::after{content:"";position:absolute;left:0;bottom:0;width:100%;height:1px;background:var(--accent);
  transform:scaleX(0);transform-origin:right;transition:transform .4s ease}
.header__nav a:hover{color:var(--accent)}
.header__nav a:hover::after{transform:scaleX(1);transform-origin:left}
.header__logo{display:inline-flex;align-items:center;line-height:1}
.header__logo .logo-word{font-family:'Archivo Black','Hanken Grotesk',sans-serif;font-size:21px;letter-spacing:-.01em;color:var(--ink);line-height:1;white-space:nowrap}
.header__logo .logo-img{height:26px;width:auto;display:block}
.header__icons{display:flex;gap:22px;align-items:center}
.header__icons .hicon{background:none;border:0;padding:0;margin:0;cursor:pointer;color:var(--ink);display:inline-flex;align-items:center;line-height:0;transition:opacity .25s}
.header__icons .hicon svg{display:block}
.header__icons .hicon:hover{opacity:.5}
.header__line{font-family:var(--grotesk);font-size:10.5px;letter-spacing:.2em;text-transform:uppercase;color:var(--ink);
  border:1px solid var(--line);padding:9px 15px;border-radius:var(--r);transition:.3s}
.header__line:hover{border-color:var(--ink)}
/* hamburger — hidden on desktop, shown ≤980px */
.header__burger{display:none;flex-direction:column;justify-content:center;gap:5px;width:26px;height:26px;
  background:none;border:0;padding:0;cursor:pointer;order:-1}
.header__burger span{display:block;width:22px;height:1px;background:var(--ink);transition:transform .35s ease,opacity .25s ease}
@media(max-width:980px){
  .header__nav{display:none}
  .header__burger{display:flex}
}

/* mobile drawer */
.mobile-nav{position:fixed;inset:0;z-index:90;visibility:hidden;pointer-events:none}
.mobile-nav.is-open{visibility:visible;pointer-events:auto}
.mobile-nav__overlay{position:absolute;inset:0;background:rgba(17,17,17,.4);opacity:0;transition:opacity .4s ease}
.mobile-nav.is-open .mobile-nav__overlay{opacity:1}
.mobile-nav__panel{position:absolute;top:0;right:0;height:100%;width:min(84vw,360px);background:var(--paper);
  padding:30px clamp(24px,7vw,40px);display:flex;flex-direction:column;
  transform:translateX(100%);transition:transform .5s cubic-bezier(.16,1,.3,1);overflow-y:auto}
.mobile-nav.is-open .mobile-nav__panel{transform:none}
.mobile-nav__top{display:flex;align-items:center;justify-content:space-between;margin-bottom:34px}
.mobile-nav__brand{font-family:'Archivo Black','Hanken Grotesk',sans-serif;font-size:18px;letter-spacing:-.01em;color:var(--ink)}
.mobile-nav__brand span{color:var(--accent)}
.mobile-nav__close{background:none;border:0;font-size:26px;line-height:1;cursor:pointer;color:var(--ink);font-weight:200}
.mobile-nav__links{display:flex;flex-direction:column;border-top:1px solid var(--line)}
.mobile-nav__links a{display:flex;align-items:baseline;gap:12px;padding:18px 2px;border-bottom:1px solid var(--line);
  font-family:var(--sans);font-weight:300;font-size:16px;letter-spacing:.08em;color:var(--ink)}
.mobile-nav__links a .en{font-family:var(--serif);font-style:italic;font-size:12px;color:var(--accent);letter-spacing:.04em}
.mobile-nav__cta{margin-top:30px;text-align:center}
.mobile-nav__sub{margin-top:auto;padding-top:30px;display:flex;gap:20px;font-family:var(--grotesk);font-size:11px;
  letter-spacing:.16em;text-transform:uppercase;color:var(--ink-soft)}
body.nav-open{overflow:hidden}

/* 3. hero — thin wide-tracked title, airy */
.hero{position:relative}
.hero__swiper{height:92vh;min-height:580px}
.hero__slide{position:relative;overflow:hidden}
.hero__bg{position:absolute;inset:-6% 0;background-size:cover;background-position:center;will-change:transform}
.hero__slide::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(17,17,17,.08) 0%,rgba(17,17,17,0) 40%,rgba(17,17,17,.42) 100%)}
.hero__copy{position:absolute;z-index:2;left:0;right:0;bottom:clamp(48px,9vh,110px);text-align:center;color:#fff;padding:0 20px}
.hero__kicker{font-family:var(--serif);font-style:italic;font-size:17px;letter-spacing:.06em;opacity:.95;margin:0 0 20px;font-weight:400}
.hero__title{font-family:var(--sans);font-weight:200;font-size:clamp(30px,5vw,60px);line-height:1.5;margin:0;color:#fff;letter-spacing:.18em}
.hero__lead{margin:24px 0 0;font-size:12px;opacity:.88;letter-spacing:.14em;font-weight:300}
.hero .btn{color:#fff;border-color:rgba(255,255,255,.75)}
.hero .btn:hover{background:#fff;color:var(--ink)}
.hero__pagination{bottom:24px!important}
.swiper-pagination-bullet{background:#fff;opacity:.4;width:6px;height:6px}
.swiper-pagination-bullet-active{opacity:1;background:#fff}

/* sections — generous whitespace */
.section{padding:clamp(72px,10vw,140px) 0;width:var(--pw);margin:0 auto}
.section--alt{width:100%;background:var(--paper-2);padding-left:0;padding-right:0}
.section--alt .section__head,.section--alt .prod-swiper{width:var(--pw);margin-left:auto;margin-right:auto}
.section__head{margin-bottom:52px}
.section__head--row{display:flex;align-items:flex-end;justify-content:space-between;gap:20px}
.link-more{font-family:var(--grotesk);font-size:11px;letter-spacing:.2em;text-transform:uppercase;color:var(--ink-soft);transition:.3s}
.link-more:hover{color:var(--accent)}

/* 3b. member band — light & minimal (free stitch is airy) */
.member-band{width:100%;background:var(--paper-2);color:var(--ink-2);padding:clamp(70px,9vw,128px) 0;border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.member-band__inner{width:var(--pw);margin:0 auto;display:grid;grid-template-columns:1.25fr 1fr;gap:clamp(40px,6vw,96px);align-items:center}
.member-band__lead{color:var(--ink-soft);margin:24px 0 0;font-size:13px;max-width:50ch;line-height:2.3}
.member-band__list{list-style:none;margin:0;padding:0;display:grid;gap:0;border-top:1px solid var(--line)}
.member-band__list li{display:flex;gap:20px;align-items:baseline;padding:18px 4px;border-bottom:1px solid var(--line);font-size:13px;color:var(--ink-2);letter-spacing:.05em}
.member-band__list span{font-family:var(--serif);font-style:italic;color:var(--accent);font-size:15px;min-width:26px}
@media(max-width:820px){.member-band__inner{grid-template-columns:1fr}}

/* 4. breed grid */
.cat-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:clamp(16px,2.2vw,30px)}
.cat__img{aspect-ratio:4/5;background-size:cover;background-position:center;overflow:hidden;border-radius:var(--r);transition:transform 1.1s cubic-bezier(.16,1,.3,1)}
.cat span{display:block;margin-top:20px;font-family:var(--sans);font-weight:300;font-size:14px;text-align:center;letter-spacing:.12em}
.cat:hover .cat__img{transform:scale(1.05)}
@media(max-width:720px){.cat-grid{grid-template-columns:repeat(2,1fr)}}

/* product carousels & cards */
.prod-swiper{overflow:visible}
.prod-swiper .swiper-slide{width:clamp(230px,25vw,310px);height:auto}
.pcard{display:block}
.pcard__img{position:relative;aspect-ratio:4/5;background:var(--paper-2);overflow:hidden;border-radius:var(--r)}
.pcard__img>div{width:100%;height:100%;background-size:cover;background-position:center;transition:transform 1.1s cubic-bezier(.16,1,.3,1)}
.pcard:hover .pcard__img>div{transform:scale(1.05)}
.pcard__badge{position:absolute;top:14px;left:14px;background:rgba(252,250,246,.92);color:var(--ink);
  font-family:var(--grotesk);font-size:9.5px;letter-spacing:.2em;text-transform:uppercase;padding:5px 11px;border-radius:var(--r);font-weight:400}
.pcard__badge--soon{background:rgba(17,17,17,.8);color:#fff}
.pcard__breed{margin:20px 0 6px;font-family:var(--serif);font-style:italic;font-size:12.5px;color:var(--accent)}
.pcard__name{font-family:var(--sans);font-weight:400;font-size:13.5px;margin:0 0 7px;letter-spacing:.05em;line-height:1.7}
.pcard__price{font-family:var(--serif);font-size:13px;color:var(--ink-soft);letter-spacing:.06em}
.pcard__size{font-size:11px;color:var(--ink-soft);margin-top:6px;letter-spacing:.04em}

/* 6. banner */
.banner{position:relative;height:clamp(460px,64vw,680px);display:flex;align-items:center;justify-content:center;
  text-align:center;overflow:hidden;color:#fff}
.banner__bg{position:absolute;inset:-8% 0;background-size:cover;background-position:center;will-change:transform}
.banner::after{content:"";position:absolute;inset:0;background:rgba(17,17,17,.34)}
.banner__copy{position:relative;z-index:2;padding:0 20px}

/* 9. life grid */
.life{width:var(--pw);margin:0 auto;padding:clamp(72px,10vw,140px) 0}
.life__head{text-align:center;margin-bottom:58px}
.life__head .section__note{margin-left:auto;margin-right:auto}
.life__grid{display:grid;grid-template-columns:repeat(4,1fr);grid-auto-rows:1fr;gap:clamp(16px,2.2vw,26px)}
.life__fig{margin:0;overflow:hidden;border-radius:var(--r)}
.life__fig .ph{aspect-ratio:4/5;background-size:cover;background-position:center;transition:transform 1.2s cubic-bezier(.16,1,.3,1)}
.life__fig--tall{grid-row:span 2}
.life__fig--tall .ph{aspect-ratio:3/5.5;height:100%}
.life__fig:hover .ph{transform:scale(1.05)}
@media(max-width:720px){.life__grid{grid-template-columns:repeat(2,1fr)}.life__fig--tall{grid-row:span 1}}

/* 10. story split */
.look{display:grid;grid-template-columns:1fr 1fr;align-items:center;gap:clamp(36px,6vw,104px);width:var(--pw);margin:0 auto;padding:clamp(72px,10vw,140px) 0}
.look__media{margin:0;overflow:hidden;border-radius:var(--r)}
.look__media .ph{aspect-ratio:4/5;background-size:cover;background-position:center;will-change:transform}
.look__lead{color:var(--ink-soft);margin:24px 0 0;max-width:44ch;line-height:2.3;font-size:13px}
@media(max-width:820px){.look{grid-template-columns:1fr}}

/* 11. FAQ */
.faq__list{max-width:820px;margin:0 auto;border-top:1px solid var(--line)}
.faq__item{border-bottom:1px solid var(--line)}
.faq__item summary{cursor:pointer;list-style:none;padding:28px 4px;font-family:var(--sans);font-weight:400;font-size:14px;letter-spacing:.06em;
  display:flex;justify-content:space-between;align-items:center;gap:16px}
.faq__item summary::-webkit-details-marker{display:none}
.faq__item summary::after{content:"+";font-family:var(--serif);font-size:20px;color:var(--accent);transition:transform .3s;font-weight:300}
.faq__item[open] summary::after{content:"–"}
.faq__item p{margin:0 4px 28px;color:var(--ink-soft);font-size:13px;line-height:2.2}

/* 12. footer */
.footer{background:var(--dark);color:#fff;padding:clamp(64px,9vw,112px) clamp(20px,5vw,60px) 46px}
.footer__news{text-align:center;max-width:640px;margin:0 auto 74px}
.footer__news .h-serif{color:#fff}
.footer__form{display:flex;gap:0;margin:26px auto 0;max-width:440px;border-bottom:1px solid rgba(255,255,255,.28)}
.footer__form input{flex:1;background:none;border:0;padding:13px 4px;color:#fff;font-family:var(--grotesk);font-size:12px;letter-spacing:.06em}
.footer__form input::placeholder{color:rgba(255,255,255,.45)}
.footer__form input:focus{outline:none}
.footer__form button{background:none;border:0;color:#fff;font-size:20px;cursor:pointer;padding:0 8px}
.footer__cols{display:grid;grid-template-columns:repeat(4,1fr);gap:30px;max-width:var(--pw);margin:0 auto;
  border-top:1px solid rgba(255,255,255,.14);padding-top:60px}
.footer__cols h4{font-family:var(--grotesk);font-size:11px;letter-spacing:.2em;text-transform:uppercase;margin:0 0 20px;color:rgba(255,255,255,.6);font-weight:400}
.footer__cols a{display:block;color:rgba(255,255,255,.74);font-size:13px;padding:6px 0;letter-spacing:.05em}
.footer__cols a:hover{color:#fff}
.footer__base{max-width:var(--pw);margin:54px auto 0;display:flex;justify-content:space-between;align-items:center;
  gap:16px;flex-wrap:wrap;font-size:10.5px;color:rgba(255,255,255,.42);letter-spacing:.08em;font-family:var(--grotesk)}
.footer__logo{font-family:'Archivo Black',var(--grotesk);font-size:19px;letter-spacing:-.01em;color:#fff;font-weight:400}
.footer__legal{display:flex;gap:16px;flex-wrap:wrap}
.footer__logo-img{height:22px;width:auto;display:block;filter:invert(1) brightness(2)}
.footer__base a{color:rgba(255,255,255,.72)}
.footer__base a:hover{color:#fff}

/* scroll reveal */
.js-scroll-target{opacity:0;transform:translateY(36px);transition:opacity 1.1s cubic-bezier(.16,1,.3,1),transform 1.1s cubic-bezier(.16,1,.3,1)}
.js-scroll-target.is-on{opacity:1;transform:none}

/* ===== sub-page shared ===== */
.page-head{width:var(--pw);margin:0 auto;padding:clamp(48px,6vw,92px) 0 10px}
.crumb{font-family:var(--grotesk);font-size:11px;color:var(--ink-soft);margin-bottom:24px;letter-spacing:.12em;text-transform:uppercase}
.crumb a:hover{color:var(--accent)}
.page-head h1{font-family:var(--sans);font-weight:300;font-size:clamp(26px,4vw,46px);margin:0;line-height:1.6;letter-spacing:.16em}
.page-head .lead{color:var(--ink-soft);margin:20px 0 0;max-width:58ch;line-height:2.3;font-size:13px}

/* filter chips */
.filters{width:var(--pw);margin:34px auto 0;display:flex;flex-wrap:wrap;gap:10px}
.chip{font-family:var(--grotesk);font-size:11px;letter-spacing:.12em;padding:10px 22px;border:1px solid var(--line);border-radius:999px;color:var(--ink-soft);cursor:pointer;transition:.3s;background:none;text-transform:uppercase}
.chip:hover{border-color:var(--accent);color:var(--accent)}
.chip.is-active{background:var(--ink);border-color:var(--ink);color:var(--paper)}

/* product grid */
.plp{width:var(--pw);margin:0 auto;padding:clamp(38px,4vw,60px) 0 clamp(72px,10vw,130px)}
.plp__grid{display:grid;grid-template-columns:repeat(4,1fr);gap:clamp(18px,2.4vw,38px)}
@media(max-width:980px){.plp__grid{grid-template-columns:repeat(3,1fr)}}
@media(max-width:680px){.plp__grid{grid-template-columns:repeat(2,1fr)}}

/* PDP */
.pdp{width:var(--pw);margin:0 auto;padding:clamp(32px,4vw,56px) 0 clamp(72px,10vw,130px);
  display:grid;grid-template-columns:1.1fr .9fr;gap:clamp(40px,5vw,88px);align-items:start}
@media(max-width:900px){.pdp{grid-template-columns:1fr;gap:34px}}
.pdp__gallery,.pdp__info{min-width:0}
.pdp__gallery{position:relative}
.pdp__gallery .swiper{border-radius:var(--r);overflow:hidden;width:100%}
.pdp__main-img{aspect-ratio:4/5;background-size:cover;background-position:center;background-color:var(--paper-2)}
.pdp__thumbs{display:flex;gap:12px;margin-top:14px}
.pdp__thumbs .swiper-slide{width:88px;height:110px;border-radius:var(--r);overflow:hidden;cursor:pointer;opacity:.5;background-size:cover;background-position:center;border:1px solid transparent;transition:.3s}
.pdp__thumbs .swiper-slide-thumb-active{opacity:1;border-color:var(--accent)}
.pdp__info{position:sticky;top:100px}
.pdp__breed{font-family:var(--serif);font-style:italic;color:var(--accent);font-size:14px}
.pdp__title{font-family:var(--sans);font-weight:300;font-size:clamp(22px,3vw,34px);margin:12px 0 10px;line-height:1.6;letter-spacing:.1em}
.pdp__price{font-family:var(--serif);font-size:19px;margin:0 0 4px;letter-spacing:.05em;color:var(--ink)}
.pdp__tax{font-size:11px;color:var(--ink-soft)}
.pdp__drop{display:flex;gap:14px;align-items:flex-start;margin:26px 0;padding:18px 22px;background:var(--paper-2);border-radius:var(--r);font-size:12.5px;line-height:2}
.pdp__drop b{color:var(--accent);font-weight:500}
.pdp__desc{color:var(--ink-soft);font-size:13.5px;margin:22px 0;line-height:2.3}
.pdp__label{font-family:var(--grotesk);font-weight:400;font-size:11px;letter-spacing:.18em;text-transform:uppercase;margin:28px 0 13px;color:var(--ink-2)}
.swatches,.sizes{display:flex;gap:12px;flex-wrap:wrap}
.swatch{width:32px;height:32px;border-radius:50%;border:1px solid var(--line);cursor:pointer}
.swatch.is-active{outline:1px solid var(--accent);outline-offset:3px}
.size-btn{min-width:54px;padding:11px 17px;border:1px solid var(--line);border-radius:var(--r);background:none;cursor:pointer;
  font-family:var(--grotesk);font-size:12px;transition:.25s;text-align:center;letter-spacing:.06em}
.size-btn:hover{border-color:var(--ink)}
.size-btn.is-active{background:var(--ink);border-color:var(--ink);color:var(--paper)}
.pdp__cta{display:flex;flex-direction:column;gap:12px;margin-top:32px}
.pdp__cta .btn{margin-top:0;width:100%;text-align:center;letter-spacing:.12em;padding:16px 22px;white-space:nowrap}
.pdp__note{font-size:11.5px;color:var(--ink-soft);margin-top:18px;line-height:1.9}
.pdp__acc{margin-top:32px;border-top:1px solid var(--line)}

/* size guide */
.sizeguide{width:var(--pw);margin:0 auto clamp(72px,10vw,130px)}
.sizeguide__box{background:var(--paper-2);border-radius:var(--r);padding:clamp(28px,3.5vw,52px)}
table.size{width:100%;border-collapse:collapse;font-size:13px;margin-top:20px;background:var(--paper);border-radius:var(--r);overflow:hidden}
table.size th,table.size td{border:1px solid var(--line);padding:12px;text-align:center;letter-spacing:.04em}
table.size th{background:var(--ink);color:var(--paper);font-weight:400;font-family:var(--grotesk);font-size:11px;letter-spacing:.12em;text-transform:uppercase}
table.size td:first-child{font-family:var(--grotesk);font-weight:500;background:var(--paper-2)}

/* about */
.about-hero{width:100%;height:clamp(360px,48vw,580px);overflow:hidden;position:relative}
.about-hero .ph{position:absolute;inset:-6% 0;background-size:cover;background-position:center;will-change:transform}
.about-hero::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(17,17,17,.16),rgba(17,17,17,.4))}
.about-hero__copy{position:absolute;z-index:2;inset:0;display:flex;flex-direction:column;justify-content:center;align-items:center;color:#fff;text-align:center;padding:0 20px}
.prose{width:min(680px,90vw);margin:0 auto;padding:clamp(60px,8vw,120px) 0}
.prose p{font-size:14px;line-height:2.5;color:var(--ink-2);letter-spacing:.05em}
.prose .big{font-family:var(--sans);font-weight:300;font-size:clamp(20px,2.8vw,28px);line-height:2;margin:0 0 38px;color:var(--ink);letter-spacing:.12em}
.values{width:var(--pw);margin:0 auto clamp(72px,10vw,130px);display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(20px,2.6vw,36px)}
.value{border-top:1px solid var(--line);padding:32px 4px 0}
.value .n{font-family:var(--serif);font-style:italic;color:var(--accent);font-size:20px}
.value h3{font-family:var(--sans);font-weight:300;font-size:17px;margin:16px 0 12px;letter-spacing:.1em}
.value p{color:var(--ink-soft);font-size:13px;margin:0;line-height:2.1}
@media(max-width:800px){.values{grid-template-columns:1fr;gap:0}.value{padding:28px 0}}

/* ===== 追加ページ共通の部品 ===== */
/* ステータスタグ */
.tag{display:inline-block;font-family:var(--grotesk);font-size:10.5px;letter-spacing:.16em;text-transform:uppercase;padding:4px 11px;border-radius:999px;font-weight:500}
.tag--soon{background:var(--paper-2);color:var(--ink-soft)}
.tag--few{background:var(--accent-soft);color:var(--accent)}
.tag--soldout{background:var(--ink);color:var(--paper)}
.tag--live{background:var(--line-green);color:#fff}

/* フォーム */
.form{width:min(620px,92vw);margin:0 auto}
.field{margin-bottom:20px}
.field label{display:block;font-family:var(--grotesk);font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--ink-2);margin-bottom:8px}
.field input,.field textarea,.field select{width:100%;border:1px solid var(--line);border-radius:var(--r);padding:13px 14px;font-family:var(--sans);font-size:14px;background:var(--card,#fff);color:var(--ink)}
.field textarea{min-height:140px;resize:vertical}
.field input:focus,.field textarea:focus,.field select:focus{outline:none;border-color:var(--accent)}
.field .hint{font-size:12px;color:var(--ink-soft);margin-top:6px}

/* カート */
.cart{width:var(--pw);margin:0 auto;padding:clamp(28px,4vw,52px) 0 clamp(64px,9vw,120px);display:grid;grid-template-columns:1.6fr .8fr;gap:clamp(28px,4vw,64px);align-items:start}
@media(max-width:860px){.cart{grid-template-columns:1fr}}
.cart__items{min-width:0;border-top:1px solid var(--line)}
.cart__row{display:grid;grid-template-columns:90px 1fr auto;gap:18px;padding:20px 0;border-bottom:1px solid var(--line);align-items:center}
.cart__thumb{width:90px;aspect-ratio:4/5;border-radius:var(--r);background-size:cover;background-position:center;filter:var(--img)}
.cart__name{font-family:var(--sans);font-size:14px;letter-spacing:.04em;margin:0 0 4px}
.cart__breed{font-family:var(--serif);font-style:italic;color:var(--accent);font-size:12px}
.cart__meta{font-size:12px;color:var(--ink-soft);margin-top:4px}
.cart__price{font-family:var(--serif);font-size:14px;white-space:nowrap}
.qty{display:inline-flex;align-items:center;border:1px solid var(--line);border-radius:999px;margin-top:8px}
.qty button{background:none;border:0;width:30px;height:30px;cursor:pointer;color:var(--ink);font-size:15px}
.qty span{min-width:28px;text-align:center;font-size:13px}
.cart__summary{position:sticky;top:100px;border:1px solid var(--line);border-radius:var(--r);padding:24px 22px;background:var(--card,#fff)}
.summary-row{display:flex;justify-content:space-between;font-size:13.5px;padding:8px 0;color:var(--ink-2)}
.summary-row.total{border-top:1px solid var(--line);margin-top:8px;padding-top:14px;font-size:16px;font-weight:500}
.summary-row .num{font-family:var(--serif)}
.cart__note{font-size:12px;color:var(--ink-soft);margin-top:14px;line-height:1.8}
.cart-empty{width:var(--pw);margin:0 auto;padding:clamp(60px,10vw,140px) 0;text-align:center}

/* マイページ */
.account{width:var(--pw);margin:0 auto;padding:clamp(28px,4vw,52px) 0 clamp(64px,9vw,120px);display:grid;grid-template-columns:230px 1fr;gap:clamp(28px,4vw,60px);align-items:start}
@media(max-width:820px){.account{grid-template-columns:1fr}}
.account__nav{border-top:1px solid var(--line)}
.account__nav a{display:block;padding:13px 4px;border-bottom:1px solid var(--line);font-size:13.5px;color:var(--ink-2);letter-spacing:.04em}
.account__nav a.is-active,.account__nav a:hover{color:var(--accent)}
.stat-cards{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;margin-bottom:32px}
@media(max-width:600px){.stat-cards{grid-template-columns:1fr}}
.stat{border:1px solid var(--line);border-radius:var(--r);padding:20px}
.stat .k{font-family:var(--grotesk);font-size:10.5px;letter-spacing:.16em;text-transform:uppercase;color:var(--ink-soft)}
.stat .v{font-family:var(--serif);font-size:26px;margin-top:8px;color:var(--ink)}
.order-row{display:grid;grid-template-columns:1fr auto;gap:12px;padding:16px 0;border-bottom:1px solid var(--line);font-size:13.5px}
.order-row .meta{color:var(--ink-soft);font-size:12px}

/* ドロップ一覧 */
.drop-list{width:var(--pw);margin:0 auto;padding:clamp(20px,3vw,44px) 0 clamp(64px,9vw,120px);display:grid;gap:clamp(16px,2vw,26px)}
.drop-card{display:grid;grid-template-columns:1.1fr 1.3fr;gap:0;border:1px solid var(--line);border-radius:var(--r);overflow:hidden;background:var(--card,#fff)}
@media(max-width:760px){.drop-card{grid-template-columns:1fr}}
.drop-card__media{overflow:hidden}
.drop-card__media .ph{width:100%;height:100%;min-height:240px;background-size:cover;background-position:center;filter:var(--img);transition:transform 1.1s cubic-bezier(.16,1,.3,1)}
.drop-card:hover .drop-card__media .ph{transform:scale(1.04)}
.drop-card__body{padding:clamp(22px,3vw,40px);display:flex;flex-direction:column;justify-content:center}
.drop-card__date{font-family:var(--serif);font-style:italic;color:var(--accent);font-size:15px;margin-bottom:10px}
.drop-card__title{font-family:var(--sans);font-weight:300;font-size:clamp(20px,2.6vw,30px);letter-spacing:.1em;line-height:1.5;margin:0 0 12px}
.drop-card__desc{color:var(--ink-soft);font-size:13.5px;line-height:2;margin:0 0 16px}

/* ジャーナル */
.journal-grid{width:var(--pw);margin:0 auto;padding:clamp(20px,3vw,44px) 0 clamp(64px,9vw,120px);display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(18px,2.4vw,34px)}
@media(max-width:880px){.journal-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:560px){.journal-grid{grid-template-columns:1fr}}
.jcard .ph{aspect-ratio:3/2;background-size:cover;background-position:center;border-radius:var(--r);overflow:hidden;filter:var(--img);transition:transform 1.1s cubic-bezier(.16,1,.3,1)}
.jcard:hover .ph{transform:scale(1.04)}
.jcard__cat{font-family:var(--serif);font-style:italic;color:var(--accent);font-size:12px;margin:16px 0 6px}
.jcard__title{font-family:var(--sans);font-weight:400;font-size:15px;letter-spacing:.04em;line-height:1.7;margin:0}
.jcard__date{font-size:12px;color:var(--ink-soft);margin-top:6px}
.article-hero{width:min(900px,92vw);margin:0 auto;padding:clamp(30px,4vw,56px) 0 0;text-align:center}
.article-hero .ph{aspect-ratio:16/9;background-size:cover;background-position:center;border-radius:var(--r);filter:var(--img);margin-top:24px}

/* 404 / 汎用センター */
.err{width:var(--pw);margin:0 auto;min-height:58vh;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;gap:6px;padding:60px 0}
.err .code{font-family:var(--serif);font-style:italic;color:var(--accent);font-size:clamp(48px,9vw,110px);line-height:1}

/* legal/doc */
.doc{width:min(760px,90vw);margin:0 auto;padding:clamp(40px,6vw,80px) 0 clamp(64px,9vw,120px)}
.doc h2{font-family:var(--sans);font-weight:400;font-size:17px;letter-spacing:.06em;margin:36px 0 12px;padding-bottom:8px;border-bottom:1px solid var(--line)}
.doc p,.doc li{font-size:14px;color:var(--ink-2);line-height:2.1}
.doc dl{margin:0}
.doc dt{font-family:var(--grotesk);font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:var(--ink-soft);margin-top:18px}
.doc dd{margin:4px 0 0;font-size:14px}
.doc .updated{font-size:12px;color:var(--ink-soft)}

/* breed LP intro (reuse about-hero/banner) */
.breed-intro{width:min(760px,90vw);margin:0 auto;padding:clamp(48px,7vw,96px) 0;text-align:center}
.breed-intro p{font-size:15px;line-height:2.3;color:var(--ink-2)}

/* 洋服（商品画像）はカラー・それ以外はモノトーン（--img=grayscale）。商品セレクタを後勝ちでカラー上書き */
.pcard__img>div,.pdp__main-img,.pdp__thumbs .swiper-slide,.cart__thumb{filter:contrast(1.03) saturate(1.05)}

/* ===== スマホ最適化（フッター・余白） ===== */
@media(max-width:720px){
  .footer{padding:clamp(40px,11vw,60px) 22px 34px}
  .footer__news{margin-bottom:40px}
  /* フッターをアコーディオン化（＋で開閉・既定は閉） */
  .footer__cols{grid-template-columns:1fr;gap:0;padding-top:4px;border-top:1px solid rgba(255,255,255,.14)}
  .footer__cols > div{border-bottom:1px solid rgba(255,255,255,.14)}
  .footer__cols h4{margin:0;padding:17px 2px;cursor:pointer;position:relative;display:block}
  .footer__cols h4::after{content:"+";position:absolute;right:4px;top:50%;transform:translateY(-50%);font-size:18px;font-weight:300;color:rgba(255,255,255,.55)}
  .footer__cols > div.open h4::after{content:"–"}
  .footer__cols > div:not(.open) a{display:none}
  .footer__cols > div.open{padding-bottom:12px}
  .footer__cols a{padding:8px 0}
  .footer__base{flex-direction:column;align-items:flex-start;gap:12px;margin-top:30px}
  .footer__legal{gap:14px;flex-wrap:wrap}
  .promo{font-size:9.5px;letter-spacing:.16em}
  .section__head--row{flex-wrap:wrap}
}

/* reduced motion */
@media(prefers-reduced-motion:reduce){
  .js-scroll-target{opacity:1!important;transform:none!important;transition:none}
  .promo__track{animation:none!important}
  .hero__bg,.banner__bg,.look__media .ph,.about-hero .ph{transform:none!important}
}
