/* 白斑とともに — media homepage modules (extends site/styles.css) */

/* first-steps entry band (home FOR YOU) */
.firststeps-band{display:flex;align-items:center;justify-content:space-between;gap:18px;background:var(--clay);color:#fff;border-radius:14px;padding:22px 26px;margin-bottom:26px;text-decoration:none;box-shadow:0 18px 38px -24px rgba(58,92,65,.8);transition:transform .25s ease,box-shadow .25s ease}
.firststeps-band:hover{transform:translateY(-2px);box-shadow:0 24px 46px -24px rgba(58,92,65,.9)}
.firststeps-band__k{font-size:11px;letter-spacing:.22em;font-weight:700;color:rgba(255,255,255,.82);margin-bottom:7px}
.firststeps-band__t{font-family:var(--serif);font-weight:700;font-size:clamp(15px,2.1vw,18px);line-height:1.6;text-wrap:pretty}
.firststeps-band__go{flex-shrink:0;font-weight:700;font-size:14px;white-space:nowrap;background:rgba(255,255,255,.16);padding:11px 18px;border-radius:999px}
@media(max-width:600px){.firststeps-band{flex-direction:column;align-items:flex-start;gap:14px}}

/* search icon in nav */
.nav-search{display:inline-flex;align-items:center;gap:7px;color:rgba(255,255,255,.94);font-size:13px;font-weight:500;cursor:pointer;text-decoration:none;transition:color .45s ease,opacity .2s ease}
.nav-search:hover{opacity:.7}
.nav-search .mag{width:15px;height:15px;border:1.8px solid currentColor;border-radius:50%;position:relative;display:inline-block}
.nav-search .mag::after{content:"";position:absolute;right:-4px;bottom:-3px;width:6px;height:1.8px;background:currentColor;transform:rotate(45deg);border-radius:2px}
.topbar.scrolled .nav-search{color:var(--ink)}

/* mobile slide-down menu */
.mobile-menu{display:none}
@media (max-width:879px){
  .mobile-menu{display:block;position:fixed;left:0;right:0;top:64px;background:rgba(252,250,242,.98);backdrop-filter:blur(14px);border-bottom:1px solid var(--line);transform:translateY(-12px);opacity:0;pointer-events:none;transition:transform .25s ease,opacity .25s ease;z-index:45;max-height:calc(100vh - 64px);overflow:auto}
  .mobile-menu.open{transform:none;opacity:1;pointer-events:auto}
  .mobile-menu a{display:block;padding:16px 24px;border-top:1px solid var(--line);color:var(--ink);text-decoration:none;font-weight:700;font-size:15px}
  .mobile-menu a:first-child{border-top:none}
  .mobile-menu a.active{color:var(--clay)}
}
.menu.x span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.menu.x span:nth-child(2){transform:rotate(-45deg)}

/* update badge — signals a living media site */
.update-tag{display:inline-flex;align-items:center;gap:8px;font-size:11.5px;color:var(--ink-soft);font-weight:600;letter-spacing:.04em}
.update-tag .ping{width:7px;height:7px;border-radius:50%;background:var(--clay);position:relative}
.update-tag .ping::after{content:"";position:absolute;inset:-4px;border-radius:50%;border:1px solid var(--clay);opacity:.5;animation:ping 2.2s ease-out infinite}
@keyframes ping{0%{transform:scale(.6);opacity:.6}100%{transform:scale(1.6);opacity:0}}
@media (prefers-reduced-motion: reduce){.update-tag .ping::after{animation:none}}

/* section header row (title + see-all) */
.sec-head{display:flex;align-items:flex-end;justify-content:space-between;gap:16px;margin-bottom:26px;flex-wrap:wrap}
.sec-head .l .kicker{margin-bottom:10px}
.sec-head h2{font-family:var(--serif);font-weight:700;font-size:clamp(24px,4vw,36px);line-height:1.35;color:var(--ink);text-wrap:balance}
.sec-head h2 .sub{display:block;font-size:clamp(13px,1.7vw,15px);font-weight:500;color:var(--ink-soft);margin-top:8px}
.see-all{font-size:13px;font-weight:700;color:var(--clay);text-decoration:none;white-space:nowrap;border-bottom:1.5px solid var(--clay);padding-bottom:3px}
.see-all:hover{color:var(--clay-deep)}

.cat{display:inline-block;font-size:10.5px;font-weight:700;letter-spacing:.08em;padding:4px 10px;border-radius:3px;color:#fff}
.cat--treat{background:#4F7A56}
.cat--research{background:#3F6E86}
.cat--story{background:#B06A3C}
.cat--life{background:#7A8350}
.cat--news{background:#8A7A5C}
.date{font-size:12px;color:var(--ink-soft);font-variant-numeric:tabular-nums;letter-spacing:.02em}

/* ===== LATEST: featured + feed ===== */
.latest-grid{display:grid;grid-template-columns:1fr;gap:34px}
.feature{display:block;text-decoration:none;color:inherit;group:feature}
.feature__img{position:relative;aspect-ratio:16/10;border-radius:6px;overflow:hidden;margin-bottom:18px}
.feature__img img{width:100%;height:100%;object-fit:cover;transition:transform .8s cubic-bezier(.2,.7,.2,1)}
.feature:hover .feature__img img{transform:scale(1.04)}
.feature__meta{display:flex;align-items:center;gap:12px;margin-bottom:12px}
.feature__title{font-family:var(--serif);font-weight:700;font-size:clamp(21px,3.2vw,30px);line-height:1.45;color:var(--ink);margin-bottom:10px;text-wrap:balance}
.feature__subt{display:block;font-family:var(--sans);font-weight:500;font-size:.52em;letter-spacing:.06em;color:var(--ink-soft);margin-top:7px}
.feature__dek{font-size:14px;color:var(--ink-soft);line-height:1.85;text-wrap:pretty}
.feature__more{display:inline-block;margin-top:14px;font-size:13px;font-weight:700;color:var(--clay);border-bottom:1.5px solid var(--clay);padding-bottom:2px}

.feed{display:flex;flex-direction:column}
.feed__item{display:block;text-decoration:none;color:inherit;padding:18px 0;border-top:1px solid var(--line)}
.feed__item:first-child{border-top:none;padding-top:0}
.feed__meta{display:flex;align-items:center;gap:10px;margin-bottom:8px}
.feed__title{font-family:var(--serif);font-weight:700;font-size:16px;line-height:1.6;color:var(--ink);transition:color .2s ease;text-wrap:pretty}
.feed__item:hover .feed__title{color:var(--clay)}

/* ===== TOPICS (findability) ===== */
.topics-wrap{background:var(--surface);border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.topics{display:grid;grid-template-columns:1fr;gap:1px;background:var(--line);border:1px solid var(--line);border-radius:8px;overflow:hidden}
.topic{display:flex;align-items:flex-start;gap:16px;background:var(--surface);padding:22px 22px;text-decoration:none;color:inherit;transition:background .2s ease}
.topic:hover{background:#fff}
.topic__no{font-family:var(--serif);font-style:italic;font-weight:700;font-size:15px;line-height:26px;color:var(--clay);flex-shrink:0;width:26px}
.topic__body{flex:1}
.topic__t{font-family:var(--serif);font-weight:700;font-size:17px;line-height:26px;color:var(--ink);margin-bottom:3px;display:flex;align-items:center;gap:9px;text-wrap:pretty}
.topic__d{font-size:12.5px;color:var(--ink-soft);line-height:1.6}
.topic__go{color:var(--clay);font-size:20px;line-height:26px;flex-shrink:0}

/* ===== STORIES (体験談) ===== */
.stories{display:grid;grid-template-columns:1fr;gap:18px}
.story{position:relative;border-radius:6px;overflow:hidden;text-decoration:none;color:#fff;aspect-ratio:3/4;display:block}
.story img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;transition:transform .8s cubic-bezier(.2,.7,.2,1)}
.story:hover img{transform:scale(1.05)}
.story__scrim{position:absolute;inset:0;background:linear-gradient(transparent 30%,rgba(28,34,18,.86))}
.story__body{position:absolute;left:0;right:0;bottom:0;padding:24px 20px 20px}
.story__who{font-size:12px;color:rgba(255,255,255,.82);margin-bottom:8px;letter-spacing:.02em}
.story__quote{font-family:var(--serif);font-weight:700;font-size:19px;line-height:1.5;text-wrap:balance}
.story__more{display:inline-block;margin-top:12px;font-size:12px;font-weight:700;color:#fff;border-bottom:1.5px solid rgba(255,255,255,.7);padding-bottom:2px}

/* ===== slim figures band ===== */
.figband{background:var(--clay-deep);color:#EAE7D6}
.figband__grid{display:grid;grid-template-columns:1fr 1fr;gap:26px 16px}
.figband__n{font-family:var(--serif);font-weight:700;font-size:clamp(30px,7vw,44px);line-height:1;color:#fff}
.figband__l{font-size:11.5px;color:rgba(234,231,214,.78);margin-top:8px;line-height:1.55;text-wrap:pretty}
.figband__src{margin-top:22px;font-family:var(--serif);font-style:italic;font-size:11px;color:rgba(234,231,214,.6)}

@media (min-width:880px){
  .latest-grid{grid-template-columns:1.55fr 1fr;gap:52px}
  .feed{padding-top:4px}
  .topics{grid-template-columns:1fr 1fr}
  .stories{grid-template-columns:repeat(3,1fr);gap:20px}
  .figband__grid{grid-template-columns:repeat(4,1fr);gap:30px}
}

/* ===== event detail chips ===== */
.event-facts{display:flex;flex-wrap:wrap;gap:10px;margin-top:16px}
.fact{background:#fff;border:1px solid var(--line);border-radius:6px;padding:9px 14px;font-size:12.5px;color:var(--ink)}
.fact b{color:var(--green-deep);font-weight:700;margin-right:7px}

/* ===== 体験談 recruit block ===== */
.recruit{display:grid;grid-template-columns:1fr;gap:24px;align-items:stretch}
.recruit__photo{position:relative;border-radius:6px;overflow:hidden;min-height:260px}
.recruit__photo img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.recruit__photo .tag{position:absolute;left:16px;top:16px;background:rgba(46,51,40,.78);color:#fff;font-size:11px;font-weight:700;letter-spacing:.08em;padding:6px 12px;border-radius:3px}
.recruit__box{background:var(--surface);border:1px solid var(--line);border-radius:8px;padding:26px 24px}
.recruit__box h3{font-family:var(--serif);font-weight:700;font-size:20px;color:var(--ink);margin-bottom:10px}
.recruit__box p{font-size:13.5px;color:var(--ink-soft);line-height:1.85;margin-bottom:16px;text-wrap:pretty}
.recruit__list{list-style:none;margin:0 0 18px;padding:0}
.recruit__list li{font-size:13px;color:var(--ink);line-height:1.6;padding-left:20px;position:relative;margin-bottom:7px}
.recruit__list li::before{content:"";position:absolute;left:2px;top:9px;width:7px;height:7px;border-radius:50%;background:var(--green)}
.dm{display:flex;gap:10px;flex-wrap:wrap}
.dm a{flex:1;min-width:130px;text-align:center;text-decoration:none;font-weight:700;font-size:13px;padding:12px;border-radius:4px}
.dm a.ig{background:var(--green);color:#fff}
.dm a.x{border:1.5px solid var(--green);color:var(--green-deep)}

/* ===== booklet teaser ===== */
.booklet{display:grid;grid-template-columns:1fr;gap:26px;align-items:center}
.booklet__cover{background:var(--cream);border:1px solid var(--line);border-radius:6px;aspect-ratio:5/6.5;display:flex;align-items:center;justify-content:center;padding:30px;text-align:center;box-shadow:0 18px 40px -22px rgba(40,46,24,.4)}
.booklet__cover .inner{border:1px solid var(--green);border-radius:3px;width:100%;height:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:14px;padding:24px}
.booklet__cover .t{font-family:var(--serif);font-weight:700;font-size:20px;line-height:1.6;color:var(--green-deep)}
.booklet__cover .n{font-family:var(--serif);font-size:54px;font-weight:800;color:var(--green);line-height:1}
.booklet__cover .s{font-size:11px;color:var(--ink-soft);letter-spacing:.1em}
.booklet__cats{display:flex;flex-direction:column;gap:12px;margin:18px 0}
.bcat{display:flex;gap:14px;align-items:baseline;padding:14px 0;border-top:1px solid var(--line)}
.bcat__n{font-family:var(--serif);font-style:italic;font-weight:700;color:var(--green);font-size:14px;flex-shrink:0}
.bcat__t{font-family:var(--serif);font-weight:700;font-size:15.5px;color:var(--ink)}
.bcat__d{font-size:12px;color:var(--ink-soft);margin-top:3px}
.bcat__st{margin-left:auto;font-size:10.5px;font-weight:700;padding:3px 9px;border-radius:999px;flex-shrink:0;white-space:nowrap}
.bcat__st.open{background:#E4EFE6;color:var(--green-deep)}
.bcat__st.paid{background:#F0E8D8;color:#8A6A38}

/* "準備中" disabled button */
.btn--soon{display:inline-flex;align-items:center;gap:8px;background:var(--cream-deep);color:var(--ink-soft);border:1px dashed var(--line);cursor:not-allowed}
.btn--soon::before{content:"";width:8px;height:8px;border-radius:50%;background:var(--gold);opacity:.6}

/* ===== CANVAS gallery (body-art photos) ===== */
.canvas-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:12px;margin-top:8px}
.canvas-item{position:relative;display:block;margin:0;border-radius:12px;overflow:hidden;
  background:var(--cream-deep);box-shadow:0 16px 34px -26px rgba(60,40,30,.6)}
.canvas-item img{width:100%;height:100%;object-fit:cover;display:block;aspect-ratio:4/5;
  transition:transform .8s cubic-bezier(.2,.7,.2,1)}
.canvas-item:hover img{transform:scale(1.045)}
.canvas-item figcaption{position:absolute;left:0;right:0;bottom:0;padding:30px 16px 14px;
  background:linear-gradient(to top,rgba(34,28,20,.66),rgba(34,28,20,0));
  color:#fff;display:flex;align-items:flex-end;justify-content:space-between;gap:8px}
.canvas-item .cap-jp{font-family:var(--serif);font-weight:700;font-size:14px;line-height:1.4;text-shadow:0 1px 8px rgba(0,0,0,.4)}
.canvas-item .cap-en{font-size:9px;letter-spacing:.2em;color:rgba(255,255,255,.82);flex-shrink:0}
.canvas-note{margin-top:16px;font-size:12.5px;color:var(--ink-soft);line-height:1.85;text-wrap:pretty}

@media (min-width:760px){
  .canvas-grid{grid-template-columns:repeat(4,1fr);gap:16px}
  .canvas-item .cap-jp{font-size:15px}
}

@media (min-width:880px){
  .recruit{grid-template-columns:1fr 1fr}
  .booklet{grid-template-columns:300px 1fr;gap:48px}
}
