/*
Theme Name: ＆WORLD
Theme URI: https://andworld.shop/
Description: ＆WORLD（アンドワールド）公式サイト専用テーマ。「地域に安堵を。世界に安堵を。」モノトーン基調のミニマルなブランドサイト。
Author: 一般社団法人ちちぶ結いまち
Version: 1.1.1
Requires at least: 6.0
Tested up to: 6.5
Requires PHP: 7.4
License: GNU General Public License v2 or later
Text Domain: andworld
*/

:root{
  --black:#0d0d0d;--ink:#1a1a1a;--white:#ffffff;--paper:#f5f4f1;
  --gray:#7d7d7d;--line:#e4e2dc;--line-dark:#333333;--max:1200px;
  --ease:cubic-bezier(.22,.61,.36,1);
}
*{margin:0;padding:0;box-sizing:border-box;}
html{scroll-behavior:smooth;}
body{font-family:'Noto Sans JP',sans-serif;color:var(--ink);background:var(--white);
  line-height:1.8;-webkit-font-smoothing:antialiased;overflow-x:hidden;}
img{max-width:100%;display:block;height:auto;}
a{color:inherit;text-decoration:none;}
.wrap{max-width:var(--max);margin:0 auto;padding:0 24px;}

/* ===== ヘッダー ===== */
.site-header{
  position:fixed;top:0;left:0;right:0;z-index:100;
  display:flex;align-items:center;justify-content:space-between;
  padding:14px 28px;background:rgba(13,13,13,.97);
  box-shadow:0 1px 0 rgba(255,255,255,.06);
}
.site-header--home{
  padding:18px 28px;background:rgba(13,13,13,0);box-shadow:none;
  transition:background .4s var(--ease),padding .4s var(--ease);
}
.site-header--home.scrolled{
  background:rgba(13,13,13,.95);padding:12px 28px;
  box-shadow:0 1px 0 rgba(255,255,255,.06);
}
.site-header .logo img{height:26px;width:auto;}
.nav{display:flex;align-items:center;gap:30px;}
.nav a{color:var(--white);font-size:13px;font-weight:500;letter-spacing:.04em;position:relative;padding:4px 0;}
.nav a::after{content:"";position:absolute;left:0;bottom:0;width:0;height:1px;background:var(--white);transition:width .3s var(--ease);}
.nav a:hover::after{width:100%;}
.nav a.current::after{width:100%;}
.nav .nav-shop{border:1px solid rgba(255,255,255,.5);padding:8px 18px;border-radius:2px;}
.nav .nav-shop:hover{background:var(--white);color:var(--black);}
.nav .nav-shop::after{display:none;}
.burger{display:none;flex-direction:column;gap:5px;background:none;border:0;cursor:pointer;padding:6px;}
.burger span{display:block;width:24px;height:2px;background:var(--white);transition:.3s var(--ease);}

/* ===== ボタン ===== */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:10px;
  padding:15px 34px;font-size:13px;font-weight:700;letter-spacing:.08em;
  border-radius:2px;transition:.3s var(--ease);cursor:pointer;border:1px solid transparent;
}
.btn-light{background:var(--white);color:var(--black);}
.btn-light:hover{background:transparent;color:var(--white);border-color:var(--white);}
.btn-ghost{background:transparent;color:var(--white);border-color:rgba(255,255,255,.55);}
.btn-ghost:hover{background:var(--white);color:var(--black);border-color:var(--white);}
.btn-dark{background:var(--black);color:var(--white);border-color:var(--black);}
.btn-dark:hover{background:#333;border-color:#333;}

/* ===== ヒーロー（トップ） ===== */
.hero{
  position:relative;height:100svh;min-height:580px;
  display:flex;align-items:center;justify-content:center;
  background:var(--black);overflow:hidden;
}
.hero video{
  position:absolute;inset:0;width:100%;height:100%;object-fit:cover;
  filter:brightness(.5) contrast(1.06);transform:scale(1.12);transform-origin:left top;
}
.hero::after{
  content:"";position:absolute;inset:0;
  background:
    radial-gradient(ellipse 62% 52% at 50% 46%,rgba(13,13,13,.62) 0%,rgba(13,13,13,.1) 100%),
    linear-gradient(180deg,rgba(13,13,13,.6) 0%,rgba(13,13,13,.2) 48%,rgba(13,13,13,.92) 100%);
}
.hero-inner{position:relative;z-index:2;text-align:center;color:var(--white);padding:0 24px;}
.hero-logo{
  width:clamp(230px,34vw,400px);margin:0 auto 30px;
  filter:drop-shadow(0 4px 28px rgba(0,0,0,.95)) drop-shadow(0 0 14px rgba(0,0,0,.85));
}
.hero-copy{
  font-family:'Noto Serif JP',serif;font-weight:600;
  font-size:clamp(20px,3.4vw,34px);line-height:1.6;letter-spacing:.06em;margin-bottom:14px;
  text-shadow:0 2px 18px rgba(0,0,0,.95),0 0 10px rgba(0,0,0,.85);
}
.hero-sub{
  font-size:clamp(12px,1.5vw,14px);letter-spacing:.14em;
  color:rgba(255,255,255,.88);margin-bottom:36px;text-shadow:0 2px 14px rgba(0,0,0,.9);
}
.hero-actions{display:flex;gap:16px;justify-content:center;flex-wrap:wrap;}
.hero-actions .btn{min-width:250px;}
.scroll-cue{
  position:absolute;left:50%;bottom:26px;transform:translateX(-50%);z-index:2;
  color:rgba(255,255,255,.7);font-size:10px;letter-spacing:.2em;
  display:flex;flex-direction:column;align-items:center;gap:8px;
}
.scroll-cue::after{
  content:"";width:1px;height:42px;background:rgba(255,255,255,.5);
  animation:cue 1.8s var(--ease) infinite;
}
@keyframes cue{0%{transform:scaleY(0);transform-origin:top;}50%{transform:scaleY(1);transform-origin:top;}51%{transform-origin:bottom;}100%{transform:scaleY(0);transform-origin:bottom;}}

/* ===== セクション共通 ===== */
.section{padding:clamp(64px,10vw,120px) 0;}
.sec-head{text-align:center;margin-bottom:54px;}
.sec-head .en{display:block;font-size:12px;letter-spacing:.3em;color:var(--gray);font-weight:700;margin-bottom:12px;}
.sec-head .ja{font-family:'Noto Serif JP',serif;font-weight:600;font-size:clamp(22px,3.4vw,32px);letter-spacing:.04em;}

/* ===== コンセプト（トップ） ===== */
.concept{background:var(--paper);text-align:center;}
.concept .lead{
  font-family:'Noto Serif JP',serif;font-weight:600;
  font-size:clamp(20px,3.2vw,30px);line-height:1.9;letter-spacing:.04em;margin-bottom:28px;
}
.concept .body{max-width:680px;margin:0 auto;font-size:15px;color:#444;}
.concept .body p+p{margin-top:18px;}

/* ===== カテゴリー（トップ） ===== */
.cat-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;}
.cat-card{
  border:1px solid var(--line);padding:30px 22px;
  display:flex;align-items:center;justify-content:space-between;transition:.35s var(--ease);
}
.cat-card:hover{background:var(--black);border-color:var(--black);}
.cat-card .num{font-size:12px;color:var(--gray);font-weight:700;letter-spacing:.1em;}
.cat-card .name{font-size:17px;font-weight:700;margin:6px 0 2px;}
.cat-card .en{font-size:11px;letter-spacing:.18em;color:var(--gray);}
.cat-card:hover .name,.cat-card:hover .num,.cat-card:hover .en{color:var(--white);}
.cat-card .arrow{font-size:18px;transition:transform .35s var(--ease);}
.cat-card:hover .arrow{transform:translateX(6px);color:var(--white);}

/* ===== 商品カード（共通） ===== */
.prod-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:28px 24px;}
.prod-card{background:var(--white);border:1px solid var(--line);transition:.35s var(--ease);}
.prod-card:hover{transform:translateY(-6px);box-shadow:0 18px 40px rgba(0,0,0,.1);}
.prod-thumb{aspect-ratio:1/1;overflow:hidden;background:#fafafa;}
.prod-thumb img{width:100%;height:100%;object-fit:contain;transition:transform .5s var(--ease);}
.prod-card:hover .prod-thumb img{transform:scale(1.05);}
.prod-body{padding:18px 18px 22px;}
.prod-tag{display:inline-block;font-size:10px;letter-spacing:.1em;border:1px solid var(--line);padding:3px 10px;color:var(--gray);margin-bottom:10px;}
.prod-name{font-size:14px;font-weight:500;line-height:1.6;min-height:2.6em;}
.prod-price{font-size:16px;font-weight:700;margin-top:10px;}
.prod-price small{font-size:11px;color:var(--gray);font-weight:400;margin-left:3px;}

/* ===== ピックアップ（トップ） ===== */
.pickup{background:var(--paper);}
.pickup .more{text-align:center;margin-top:48px;}

/* ===== アバウト帯（トップ） ===== */
.about-band{background:var(--black);color:var(--white);}
.about-inner{display:grid;grid-template-columns:1.05fr 1fr;gap:54px;align-items:center;}
.about-logo{display:block;width:210px;max-width:58%;height:auto;margin:0 auto 20px;}
.about-text .en{font-size:12px;letter-spacing:.3em;color:rgba(255,255,255,.55);font-weight:700;}
.about-text h2{
  font-family:'Noto Serif JP',serif;font-weight:600;
  font-size:clamp(22px,2.8vw,30px);line-height:1.7;margin:14px 0 20px;letter-spacing:.04em;
}
.about-text p{font-size:15px;color:rgba(255,255,255,.78);margin-bottom:18px;}
.about-visual{border:1px solid var(--line-dark);padding:48px 30px;text-align:center;background:linear-gradient(160deg,#161616,#0d0d0d);}

/* ===== 動画（YouTube／トップ） ===== */
.movie{background:var(--paper);}
.yt-banner{position:relative;display:block;width:100%;aspect-ratio:21/9;max-height:540px;border-radius:6px;overflow:hidden;background:radial-gradient(ellipse 62% 75% at 50% 42%,rgba(255,42,42,.22),transparent 72%),radial-gradient(circle at 50% 38%,#2a2a2a,#0d0d0d 74%);box-shadow:0 18px 50px rgba(0,0,0,.28);transition:transform .5s var(--ease),box-shadow .5s var(--ease);}
.yt-banner:hover{transform:translateY(-5px);box-shadow:0 30px 70px rgba(0,0,0,.4);}
.yt-banner::after{content:"";position:absolute;left:0;right:0;bottom:0;height:55%;background:linear-gradient(to top,rgba(8,8,8,.92),transparent);pointer-events:none;}
.yt-badge{position:absolute;top:20px;left:20px;z-index:3;display:inline-flex;align-items:center;gap:7px;background:#ff0000;color:#fff;font-size:11px;font-weight:700;letter-spacing:.1em;padding:6px 11px 6px 9px;border-radius:4px;}
.yt-badge svg{width:17px;height:auto;display:block;}
.yt-play{position:absolute;top:46%;left:50%;transform:translate(-50%,-50%);width:clamp(76px,8.5vw,108px);z-index:2;}
.yt-play::before{content:"";position:absolute;inset:-30%;z-index:-1;border-radius:50%;background:radial-gradient(circle,rgba(255,0,0,.5),transparent 68%);animation:ytpulse 2.6s ease-in-out infinite;}
.yt-play-svg{width:100%;height:auto;display:block;filter:drop-shadow(0 8px 22px rgba(0,0,0,.55));transition:transform .4s var(--ease);}
.yt-banner:hover .yt-play-svg{transform:scale(1.1);}
@keyframes ytpulse{0%,100%{transform:scale(.82);opacity:.5;}50%{transform:scale(1.16);opacity:.92;}}
.yt-banner-foot{position:absolute;left:0;right:0;bottom:0;z-index:3;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:12px;padding:clamp(18px,3vw,32px);}
.yt-ch{color:#fff;font-family:'Noto Serif JP',serif;font-weight:600;font-size:clamp(15px,1.9vw,21px);letter-spacing:.04em;}
.yt-cta{display:inline-flex;align-items:center;gap:8px;color:#fff;font-size:13px;font-weight:700;letter-spacing:.06em;border:1px solid rgba(255,255,255,.65);padding:10px 20px;border-radius:3px;transition:.3s var(--ease);white-space:nowrap;}
.yt-cta .arrow{transition:transform .3s var(--ease);}
.yt-banner:hover .yt-cta{background:#fff;color:#0d0d0d;border-color:#fff;}
.yt-banner:hover .yt-cta .arrow{transform:translateX(4px);}
.movie-note{text-align:center;margin-top:22px;font-size:13px;color:var(--gray);letter-spacing:.03em;}
@media(prefers-reduced-motion:reduce){.yt-play::before{animation:none;}}
@media(max-width:640px){.yt-banner{aspect-ratio:4/3;}.yt-banner-foot{flex-direction:column;align-items:flex-start;gap:14px;}.yt-cta{align-self:stretch;justify-content:center;}}

/* ===== ニュース（トップ） ===== */
.news-list{max-width:760px;margin:0 auto;}
.news-item{
  display:flex;gap:24px;align-items:baseline;
  padding:20px 4px;border-bottom:1px solid var(--line);transition:.3s var(--ease);
}
.news-item:first-child{border-top:1px solid var(--line);}
.news-item:hover{background:var(--paper);padding-left:14px;padding-right:14px;}
.news-date{font-size:13px;color:var(--gray);font-weight:700;letter-spacing:.04em;white-space:nowrap;}
.news-cat{font-size:10px;letter-spacing:.08em;border:1px solid var(--line);padding:2px 9px;color:var(--gray);white-space:nowrap;}
.news-title{font-size:14px;}
.news-empty{text-align:center;color:var(--gray);font-size:14px;}

/* ===== CTA（共通・暗） ===== */
.cta{background:var(--black);color:var(--white);text-align:center;padding:clamp(70px,11vw,130px) 0;}
.cta h2{
  font-family:'Noto Serif JP',serif;font-weight:600;
  font-size:clamp(22px,3.6vw,36px);line-height:1.6;letter-spacing:.05em;margin-bottom:16px;
}
.cta p{font-size:14px;color:rgba(255,255,255,.7);margin-bottom:36px;}
.cta-actions{display:flex;gap:16px;justify-content:center;flex-wrap:wrap;}
.cta-actions .btn{min-width:230px;}

/* ===== ページヘッダー（下層共通） ===== */
.page-header{background:var(--black);color:#fff;padding:128px 0 58px;text-align:center;}
.page-header .en{font-size:12px;letter-spacing:.3em;color:rgba(255,255,255,.5);font-weight:700;}
.page-header h1{font-family:'Noto Serif JP',serif;font-weight:600;font-size:clamp(24px,4vw,38px);letter-spacing:.05em;margin-top:12px;}
.page-header .breadcrumb{margin-top:16px;font-size:12px;color:rgba(255,255,255,.5);letter-spacing:.04em;}
.page-header .breadcrumb a:hover{color:#fff;}

/* ===== アバウトページ ===== */
.page-intro{background:var(--black);color:#fff;text-align:center;padding:160px 24px 96px;}
.intro-en{font-size:12px;letter-spacing:.34em;color:rgba(255,255,255,.5);font-weight:700;}
.intro-title{font-family:'Noto Serif JP',serif;font-weight:600;font-size:clamp(30px,6vw,58px);line-height:1.45;letter-spacing:.04em;margin:22px 0 18px;}
.intro-en-sub{font-size:clamp(12px,1.6vw,15px);letter-spacing:.12em;color:rgba(255,255,255,.62);}
.intro-lead{max-width:600px;margin:32px auto 0;font-size:14px;line-height:2;color:rgba(255,255,255,.78);}
.intro-bc{margin-top:30px;font-size:12px;color:rgba(255,255,255,.4);letter-spacing:.04em;}
.intro-bc a:hover{color:#fff;}
.story{padding:clamp(72px,11vw,130px) 0;}
.story.light{background:var(--paper);}
.story.dark{background:var(--black);color:#fff;}
.story-inner{max-width:780px;margin:0 auto;text-align:center;}
.story-num{display:block;font-size:13px;font-weight:700;letter-spacing:.22em;color:var(--gray);margin-bottom:20px;}
.story.dark .story-num{color:rgba(255,255,255,.4);}
.story-en{display:block;font-size:12px;letter-spacing:.3em;font-weight:700;color:var(--gray);margin-bottom:14px;}
.story.dark .story-en{color:rgba(255,255,255,.5);}
.story-ja{font-family:'Noto Serif JP',serif;font-weight:600;font-size:clamp(23px,3.8vw,34px);line-height:1.55;letter-spacing:.04em;margin-bottom:30px;}
.story-body{max-width:600px;margin:0 auto;text-align:left;}
.story-body p{font-size:15.5px;line-height:2.05;color:#444;}
.story.dark .story-body p{color:rgba(255,255,255,.8);}
.story-body p + p{margin-top:18px;}
.amp-logo{display:block;width:150px;max-width:42%;height:auto;margin:4px auto 34px;}

/* ===== カタログ ===== */
.catalog{background:var(--paper);padding:clamp(48px,7vw,80px) 0 clamp(64px,10vw,110px);}
.filter-bar{display:flex;flex-wrap:wrap;gap:10px;justify-content:center;margin-bottom:44px;}
.filter-btn{
  padding:9px 20px;border:1px solid var(--line);background:#fff;
  font-family:inherit;font-size:13px;font-weight:500;color:var(--ink);
  cursor:pointer;border-radius:2px;transition:.25s var(--ease);
}
.filter-btn:hover{border-color:var(--black);}
.filter-btn.active{background:var(--black);color:#fff;border-color:var(--black);}
.filter-btn .count{color:var(--gray);font-size:11px;margin-left:5px;}
.filter-btn.active .count{color:rgba(255,255,255,.6);}
.result-note{text-align:center;color:var(--gray);font-size:13px;margin-top:40px;}

/* ===== 商品詳細 ===== */
.breadcrumb-bar{padding:96px 0 0;}
.breadcrumb{font-size:12px;color:var(--gray);letter-spacing:.04em;}
.breadcrumb a:hover{color:var(--ink);}
.product{padding:32px 0 clamp(56px,8vw,88px);}
.product-grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(28px,4vw,56px);}
.gallery-main{aspect-ratio:1/1;background:#fafafa;border:1px solid var(--line);}
.gallery-main img{width:100%;height:100%;object-fit:contain;}
.p-cat{display:inline-block;font-size:10px;letter-spacing:.1em;border:1px solid var(--line);padding:4px 11px;color:var(--gray);}
.p-name{font-family:'Noto Serif JP',serif;font-weight:600;font-size:clamp(21px,3vw,29px);line-height:1.5;margin:14px 0 16px;}
.p-price{font-size:26px;font-weight:700;}
.p-price small{font-size:12px;color:var(--gray);font-weight:400;margin-left:6px;}
.p-desc{font-size:14px;color:#444;margin:18px 0 26px;}
.p-block{margin-bottom:22px;}
.p-label{font-size:12px;font-weight:700;letter-spacing:.08em;margin-bottom:10px;}
.p-label .sub{color:var(--gray);font-weight:400;margin-left:8px;}
.size-chips{display:flex;gap:8px;flex-wrap:wrap;}
.size-chip{border:1px solid var(--line);padding:8px 15px;font-size:13px;font-weight:500;}
.buy-btn{
  display:block;width:100%;background:var(--black);color:#fff;text-align:center;
  padding:18px;font-size:14px;font-weight:700;letter-spacing:.06em;
  border-radius:2px;transition:.3s var(--ease);margin-top:6px;
}
.buy-btn:hover{background:#333;}
.p-note{font-size:12px;color:var(--gray);margin-top:12px;}
.p-ship{margin-top:24px;padding-top:22px;border-top:1px solid var(--line);font-size:12.5px;color:#555;}
.p-ship div{margin-bottom:5px;}
.p-ship strong{color:var(--ink);font-weight:700;}
.detail{background:var(--paper);padding:clamp(56px,8vw,90px) 0;}
.detail-inner{max-width:760px;margin:0 auto;}
.detail .sec-head{margin-bottom:40px;}
.detail .sec-head .ja{font-size:clamp(20px,3vw,28px);}
.detail-text p{font-size:15px;color:#444;line-height:2;}
.detail-text p + p{margin-top:16px;}
.spec{margin-top:34px;border-top:1px solid var(--line);}
.spec dl{display:flex;border-bottom:1px solid var(--line);padding:13px 4px;font-size:13.5px;}
.spec dt{width:130px;flex-shrink:0;font-weight:700;}
.spec dd{color:#444;}
.spec-note{font-size:12px;color:var(--gray);margin-top:16px;}
.size-table-wrap{margin-top:34px;overflow-x:auto;}
.size-table{width:100%;border-collapse:collapse;font-size:13px;min-width:480px;}
.size-table caption{text-align:left;font-size:12px;color:var(--gray);margin-bottom:8px;}
.size-table th,.size-table td{border:1px solid var(--line);padding:9px 6px;text-align:center;}
.size-table thead th{background:var(--black);color:#fff;font-weight:700;}
.size-table tbody th{background:#efede8;font-weight:700;}
.related{padding:clamp(56px,8vw,90px) 0;}
.related .prod-grid{gap:24px;}
.related .prod-body{padding:16px 16px 20px;}
.related .prod-name{font-size:13.5px;}
.related .prod-price{font-size:15px;}

/* ===== コンテンツページ（ガイド／法務） ===== */
.content{padding:clamp(54px,8vw,86px) 0;}
.content-inner{max-width:760px;margin:0 auto;}
.content-narrow{max-width:720px;}
.block{margin-bottom:clamp(42px,6vw,62px);}
.block:last-child{margin-bottom:0;}
.block-head{margin-bottom:24px;}
.block-head .en{display:block;font-size:11px;letter-spacing:.26em;color:var(--gray);font-weight:700;margin-bottom:8px;}
.block-head h2{font-family:'Noto Serif JP',serif;font-weight:600;font-size:clamp(19px,2.6vw,25px);letter-spacing:.03em;}
.lead{font-size:14.5px;color:#444;line-height:2;margin-bottom:24px;}
.content p{font-size:14.5px;color:#444;line-height:2;}
.content p + p{margin-top:14px;}

/* ガイド：購入ステップ */
.steps{display:flex;flex-direction:column;gap:14px;}
.step{display:flex;gap:20px;align-items:flex-start;border:1px solid var(--line);padding:22px 24px;}
.step-num{flex-shrink:0;width:52px;font-family:'Noto Serif JP',serif;font-size:27px;font-weight:700;color:var(--black);line-height:1;}
.step-num small{display:block;font-family:'Noto Sans JP',sans-serif;font-size:9px;letter-spacing:.16em;color:var(--gray);font-weight:700;margin-bottom:5px;}
.step-body h3{font-size:15px;font-weight:700;margin-bottom:6px;}
.step-body p{font-size:13.5px;color:#444;line-height:1.95;}

/* ガイド：情報リスト */
.info-list dl{display:flex;border-bottom:1px solid var(--line);padding:14px 4px;font-size:14px;}
.info-list dl:first-child{border-top:1px solid var(--line);}
.info-list dt{width:140px;flex-shrink:0;font-weight:700;}
.info-list dd{color:#444;}
.note{font-size:12.5px;color:var(--gray);margin-top:14px;line-height:1.9;}

/* ガイド：FAQ */
.faq details{border-bottom:1px solid var(--line);}
.faq details:first-child{border-top:1px solid var(--line);}
.faq summary{cursor:pointer;padding:17px 38px 17px 32px;font-size:14px;font-weight:700;list-style:none;position:relative;transition:color .2s var(--ease);}
.faq summary::-webkit-details-marker{display:none;}
.faq summary::before{content:"Q";position:absolute;left:6px;font-family:'Noto Serif JP',serif;color:var(--gray);font-weight:700;}
.faq summary::after{content:"+";position:absolute;right:10px;top:15px;font-size:18px;color:var(--gray);transition:transform .3s var(--ease);}
.faq details[open] summary::after{transform:rotate(45deg);}
.faq summary:hover{color:var(--black);}
.faq .faq-a{padding:0 32px 19px 32px;font-size:13.5px;color:#444;line-height:2;}

/* ガイド：クロージング */
.closing{background:var(--black);color:#fff;text-align:center;padding:clamp(60px,9vw,104px) 0;}
.closing h2{font-family:'Noto Serif JP',serif;font-weight:600;font-size:clamp(21px,3.2vw,30px);letter-spacing:.05em;margin-bottom:12px;}
.closing p{font-size:13.5px;color:rgba(255,255,255,.7);margin-bottom:30px;}

/* 法務：designstore案内ボックス */
.ds-box{background:var(--paper);border:1px solid var(--line);padding:clamp(30px,5vw,46px);text-align:center;margin-top:8px;}
.ds-box p{font-size:14px;color:#444;margin-bottom:22px;}
.ds-note{font-size:12px;color:var(--gray);margin-top:18px;line-height:1.9;}

/* プライバシー：条項ブロック */
.intro-text{font-size:14.5px;color:#444;line-height:2.05;margin-bottom:clamp(36px,5vw,48px);}
.policy{margin-bottom:clamp(32px,4.5vw,44px);}
.policy:last-of-type{margin-bottom:0;}
.policy h2{font-size:15.5px;font-weight:700;letter-spacing:.02em;padding-bottom:10px;margin-bottom:14px;border-bottom:1px solid var(--line);}
.policy h2 .n{font-family:'Noto Serif JP',serif;color:var(--gray);margin-right:10px;}
.policy p{font-size:14px;color:#444;line-height:2.05;}
.policy p + p{margin-top:12px;}
.policy ul{list-style:none;margin-top:10px;}
.policy ul li{font-size:14px;color:#444;line-height:1.95;padding-left:18px;position:relative;}
.policy ul li::before{content:"—";position:absolute;left:0;color:var(--gray);}
.revised{margin-top:clamp(40px,6vw,56px);padding-top:22px;border-top:1px solid var(--line);font-size:13px;color:var(--gray);text-align:right;}

/* ===== お問い合わせ（Contact Form 7） ===== */
.contact-routing{background:var(--paper);border:1px solid var(--line);padding:clamp(22px,3.5vw,28px) clamp(20px,4vw,32px);margin-bottom:clamp(34px,5vw,48px);}
.contact-routing h2{font-size:13.5px;font-weight:700;letter-spacing:.06em;margin-bottom:9px;}
.contact-routing p{font-size:13.5px;color:#555;line-height:2;}
.contact-routing p + p{margin-top:10px;}
.contact-routing a{text-decoration:underline;text-underline-offset:3px;}
.contact-routing a:hover{color:var(--black);}
.form-head{margin-bottom:22px;}
.form-head .en{display:block;font-size:11px;letter-spacing:.26em;color:var(--gray);font-weight:700;margin-bottom:8px;}
.form-head h2{font-family:'Noto Serif JP',serif;font-weight:600;font-size:clamp(19px,2.6vw,25px);letter-spacing:.03em;}

/* CF7フォーム本体 */
.contact-form .wpcf7{margin-top:0;}
.contact-form .andw-field{margin-bottom:20px;}
.contact-form label{display:block;font-size:13px;font-weight:700;letter-spacing:.03em;margin-bottom:7px;}
.contact-form .andw-req{display:inline-block;font-size:10px;font-weight:700;letter-spacing:.06em;color:#fff;background:var(--black);padding:2px 7px;border-radius:2px;margin-left:7px;vertical-align:1px;}
.contact-form .andw-any{display:inline-block;font-size:10px;font-weight:700;letter-spacing:.06em;color:var(--gray);border:1px solid var(--line);padding:1px 6px;border-radius:2px;margin-left:7px;vertical-align:1px;}
.contact-form .wpcf7-form-control-wrap{display:block;}
.contact-form input.wpcf7-text,
.contact-form input.wpcf7-email,
.contact-form textarea.wpcf7-textarea{width:100%;font-family:inherit;font-size:14px;color:var(--ink);background:#fff;border:1px solid var(--line);border-radius:2px;padding:12px 14px;transition:border-color .25s var(--ease);}
.contact-form input.wpcf7-text:focus,
.contact-form input.wpcf7-email:focus,
.contact-form textarea.wpcf7-textarea:focus{outline:none;border-color:var(--black);}
.contact-form textarea.wpcf7-textarea{display:block;min-height:170px;line-height:1.9;resize:vertical;}
.contact-form .andw-submit{text-align:center;margin-top:30px;}
.contact-form input.wpcf7-submit{display:inline-block;min-width:280px;background:var(--black);color:#fff;font-family:inherit;font-size:14px;font-weight:700;letter-spacing:.08em;border:1px solid var(--black);border-radius:2px;padding:16px 40px;cursor:pointer;transition:.3s var(--ease);}
.contact-form input.wpcf7-submit:hover{background:#333;border-color:#333;}
.contact-form .wpcf7-spinner{margin-left:10px;}
.contact-form .wpcf7-not-valid-tip{font-size:12px;color:#c0392b;font-weight:500;margin-top:6px;}
.contact-form .wpcf7-response-output{font-size:13px;line-height:1.9;border-radius:2px;margin:24px 0 0!important;padding:13px 18px!important;}
.contact-form .wpcf7-form.invalid .wpcf7-response-output,
.contact-form .wpcf7-form.unaccepted .wpcf7-response-output,
.contact-form .wpcf7-form.payment-required .wpcf7-response-output{border:1px solid #e3b7b2;background:#fbf0ef;color:#a23b30;}
.contact-form .wpcf7-form.sent .wpcf7-response-output{border:1px solid #bcd5c4;background:#eef5f0;color:#2f6b46;}

/* フォーム準備中（ショートコード未設置時の案内） */
.contact-pending{border:1px dashed var(--line);background:var(--paper);padding:30px 24px;text-align:center;}
.contact-pending p{font-size:14px;color:#555;line-height:2;}
.contact-pending .contact-pending-admin{margin-top:16px;font-size:12.5px;color:var(--gray);line-height:1.95;border-top:1px solid var(--line);padding-top:14px;}
.content .form-foot-note{font-size:12.5px;color:var(--gray);margin-top:24px;line-height:1.95;text-align:center;}
.content .form-foot-note a{text-decoration:underline;text-underline-offset:3px;}
.content .form-foot-note a:hover{color:var(--ink);}
@media(max-width:768px){
  .contact-form input.wpcf7-submit{width:100%;min-width:0;}
}

/* ===== お知らせ（一覧・記事詳細） ===== */
/* トップ／一覧への導線ボタン */
.news-more{text-align:center;margin-top:44px;}

/* お知らせ一覧：ページ送り */
.news-pagination{margin-top:46px;text-align:center;}
.news-pagination .page-numbers{display:inline-block;min-width:42px;padding:9px 12px;margin:0 3px;border:1px solid var(--line);font-size:13px;font-weight:700;color:var(--ink);transition:.25s var(--ease);}
.news-pagination a.page-numbers:hover{border-color:var(--black);}
.news-pagination .page-numbers.current{background:var(--black);color:#fff;border-color:var(--black);}
.news-pagination .page-numbers.dots{border-color:transparent;padding-left:4px;padding-right:4px;}
.news-pagination .screen-reader-text{position:absolute;width:1px;height:1px;overflow:hidden;clip:rect(1px,1px,1px,1px);}

/* 記事詳細：記事ヘッダー */
.article-head{background:var(--black);color:#fff;padding:122px 0 56px;text-align:center;}
.article-head .wrap{max-width:840px;}
.article-cat{display:inline-block;font-size:11px;font-weight:700;letter-spacing:.12em;background:#fff;color:var(--black);padding:5px 14px;border-radius:2px;}
.article-title{font-family:'Noto Serif JP',serif;font-weight:600;font-size:clamp(23px,3.6vw,34px);line-height:1.62;letter-spacing:.03em;margin-top:20px;}
.article-date{margin-top:18px;font-size:13px;color:rgba(255,255,255,.55);letter-spacing:.1em;}
.article-bc{margin-top:24px;font-size:12px;color:rgba(255,255,255,.45);letter-spacing:.04em;}
.article-bc a:hover{color:#fff;}

/* 記事詳細：本文エリア */
.article{padding:clamp(46px,7vw,74px) 0 clamp(52px,8vw,84px);}
.article-inner{max-width:720px;margin:0 auto;}
.article-eyecatch{background:var(--paper);border:1px solid var(--line);aspect-ratio:3/2;margin-bottom:clamp(34px,5vw,46px);overflow:hidden;}
.article-eyecatch img{width:100%;height:100%;object-fit:contain;}

/* 記事詳細：本文タイポグラフィ */
.article-body{font-size:15.5px;line-height:2.05;color:#3c3c3c;}
.article-body > *:first-child{margin-top:0;}
.article-body p{margin:0 0 20px;}
.article-body > p:first-child{font-size:16.5px;color:var(--ink);line-height:2;margin-bottom:28px;}
.article-body h2{font-family:'Noto Serif JP',serif;font-weight:600;font-size:clamp(19px,2.6vw,24px);color:var(--ink);letter-spacing:.03em;line-height:1.6;margin:46px 0 18px;padding-bottom:12px;border-bottom:1px solid var(--line);}
.article-body h3{font-weight:700;font-size:16.5px;color:var(--ink);line-height:1.7;margin:32px 0 14px;padding-left:14px;border-left:3px solid var(--black);}
.article-body h4{font-weight:700;font-size:15px;color:var(--ink);margin:26px 0 12px;}
.article-body ul,.article-body ol{margin:0 0 22px;}
.article-body ul{list-style:none;}
.article-body ul li{position:relative;padding-left:20px;margin-bottom:9px;}
.article-body ul li::before{content:"—";position:absolute;left:0;color:var(--gray);}
.article-body ol{list-style:decimal;padding-left:24px;}
.article-body ol li{margin-bottom:9px;padding-left:4px;}
.article-body a{color:var(--ink);text-decoration:underline;text-underline-offset:3px;transition:color .2s var(--ease);}
.article-body a:hover{color:var(--gray);}
.article-body strong{font-weight:700;color:var(--ink);}
.article-body em{font-style:italic;}
.article-body blockquote{margin:28px 0;padding:22px 26px;background:var(--paper);border-left:3px solid var(--black);font-family:'Noto Serif JP',serif;font-weight:600;font-size:16px;line-height:1.95;color:var(--ink);}
.article-body blockquote p{margin:0;}
.article-body img{height:auto;}
.article-body figure{margin:28px 0;}
.article-body figure img{width:100%;}
.article-body figcaption,.article-body .wp-caption-text{margin-top:9px;font-size:12px;color:var(--gray);text-align:center;letter-spacing:.02em;}
.article-body hr{border:0;border-top:1px solid var(--line);margin:34px 0;}

/* 記事詳細：記事フッター（カテゴリー） */
.article-foot{margin-top:clamp(34px,5vw,46px);padding-top:24px;border-top:1px solid var(--line);display:flex;flex-wrap:wrap;gap:12px;align-items:center;}
.article-foot-label{font-size:12px;font-weight:700;color:var(--ink);letter-spacing:.04em;}
.article-tag{display:inline-block;font-size:12px;letter-spacing:.06em;border:1px solid var(--line);padding:5px 14px;color:#555;border-radius:2px;transition:.25s var(--ease);}
.article-tag:hover{background:var(--black);color:#fff;border-color:var(--black);}

/* 記事詳細：前後の記事 */
.post-nav{border-top:1px solid var(--line);}
.post-nav .wrap{max-width:940px;display:grid;grid-template-columns:1fr 1fr;}
.post-nav-item{display:block;padding:30px 26px;transition:background .3s var(--ease);}
.post-nav-item.prev{border-right:1px solid var(--line);}
.post-nav-item.next{text-align:right;}
a.post-nav-item:hover{background:var(--paper);}
.post-nav-label{display:block;font-size:11px;font-weight:700;letter-spacing:.1em;color:var(--gray);margin-bottom:10px;}
.post-nav-title{display:block;font-size:14px;line-height:1.7;color:var(--ink);}

/* 記事詳細：最新のお知らせ */
.related-news{background:var(--paper);padding:clamp(54px,8vw,82px) 0;}
.related-news .wrap{max-width:820px;}
.related-news .sec-head{margin-bottom:34px;}
.related-news .news-item:hover{background:#fff;}
.related-more{text-align:center;margin-top:38px;}

@media(max-width:768px){
  .post-nav .wrap{grid-template-columns:1fr;}
  .post-nav-item.prev{border-right:0;border-bottom:1px solid var(--line);}
  .post-nav-item.next{text-align:left;}
}

/* ===== フッター ===== */
.site-footer{background:#080808;color:rgba(255,255,255,.6);padding:64px 0 28px;}
.foot-top{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:40px;padding-bottom:44px;border-bottom:1px solid var(--line-dark);}
.foot-brand img{height:30px;margin-bottom:18px;}
.foot-brand p{font-size:13px;line-height:1.9;}
.foot-col h4{color:var(--white);font-size:12px;letter-spacing:.16em;margin-bottom:16px;font-weight:700;}
.foot-col a{display:block;font-size:13px;padding:5px 0;transition:color .25s var(--ease);}
.foot-col a:hover{color:var(--white);}
.foot-yt{display:flex;align-items:center;gap:12px;margin-top:22px;max-width:300px;background:#ff0000;color:#fff;padding:13px 16px;border-radius:6px;transition:.3s var(--ease);}
.foot-yt:hover{background:#e60000;transform:translateY(-2px);box-shadow:0 12px 28px rgba(255,0,0,.3);}
.foot-yt-ico{flex:none;display:flex;}
.foot-yt-ico svg{width:32px;height:auto;display:block;}
.foot-yt-txt{display:flex;flex-direction:column;line-height:1.45;}
.foot-yt-txt strong{font-size:14px;font-weight:700;letter-spacing:.03em;color:#fff;}
.foot-yt-txt small{font-size:11px;color:rgba(255,255,255,.85);}
.foot-yt-arw{margin-left:auto;font-size:17px;transition:transform .3s var(--ease);}
.foot-yt:hover .foot-yt-arw{transform:translateX(4px);}
.foot-bottom{display:flex;justify-content:space-between;flex-wrap:wrap;gap:10px;padding-top:24px;font-size:11px;letter-spacing:.04em;}

/* ===== レスポンシブ ===== */
@media(max-width:880px){
  .about-inner{grid-template-columns:1fr;gap:36px;}
  .foot-top{grid-template-columns:1fr 1fr;}
  .foot-brand{grid-column:1/-1;}
}
@media(max-width:768px){
  .burger{display:flex;}
  .nav{
    position:fixed;inset:0 0 0 auto;width:78%;max-width:320px;background:rgba(13,13,13,.98);
    flex-direction:column;align-items:flex-start;justify-content:center;gap:8px;padding:60px 36px;
    transform:translateX(100%);transition:transform .4s var(--ease);
  }
  .nav.open{transform:translateX(0);}
  .nav a{font-size:16px;padding:12px 0;width:100%;}
  .nav .nav-shop{margin-top:14px;}
  .burger.active span:nth-child(1){transform:translateY(7px) rotate(45deg);}
  .burger.active span:nth-child(2){opacity:0;}
  .burger.active span:nth-child(3){transform:translateY(-7px) rotate(-45deg);}
  .cat-grid{grid-template-columns:1fr 1fr;}
  .prod-grid{grid-template-columns:1fr 1fr;gap:18px 14px;}
  .product-grid{grid-template-columns:1fr;}
  .step{flex-direction:column;gap:8px;}
  .cta-actions .btn,.hero-actions .btn{width:100%;}
}
@media(max-width:480px){
  .cat-grid{grid-template-columns:1fr;}
  .prod-grid{grid-template-columns:1fr 1fr;}
  .prod-name{font-size:13px;}
  .news-item{flex-wrap:wrap;gap:6px 14px;}
}
