:root{
  /* 白ベース：シャンパンゴールド／アイボリーを差し色に */
  --ink:#ffffff;            /* base = white */
  --ink-2:#faf6ee;          /* soft warm section */
  --panel:#f5eee0;          /* ivory accent panel */
  --panel-2:#efe6d4;
  --ivory:#2a241d;          /* main text (warm near-black) */
  --ivory-soft:#564e42;     /* secondary text */
  --muted:#8c8376;          /* warm grey */
  --line:rgba(176,138,68,.32);    /* champagne hairline */
  --line-soft:rgba(42,36,29,.12); /* faint dark hairline */
  --champagne:#a8823f;      /* legible champagne (labels/links) */
  --champagne-2:#c2a36b;    /* decorative champagne（装飾専用。13px等の本文系には使わない） */
  --champagne-deep:#7d6128; /* AA適合シャンパン（panel上5.03:1・白上5.81:1）小サイズ強調用 */
  --navy:#18202e;
  --bordeaux:#5a2e2e;
  --serif:"Cormorant Garamond",serif;
  --mincho:"Shippori Mincho","Noto Serif JP",serif;
  --sans:"Noto Sans JP","Helvetica Neue",Arial,sans-serif;
  --maxw:1180px;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  background:var(--ink);
  color:var(--ivory);
  font-family:var(--sans);
  font-weight:300;
  line-height:2.3;
  letter-spacing:.02em;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
body::before{ /* quiet depth: vignette + faint grain */
  content:"";position:fixed;inset:0;pointer-events:none;z-index:0;
  background:
    radial-gradient(120% 80% at 82% -12%, rgba(194,163,107,.10), transparent 58%),
    radial-gradient(100% 70% at -5% 108%, rgba(245,238,224,.7), transparent 55%);
}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 32px;position:relative;z-index:1}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}

/* ── labels & type ── */
.eyebrow{
  font-family:var(--sans);font-weight:500;font-size:11px;
  letter-spacing:.42em;text-transform:uppercase;color:var(--champagne);
}
.serif{font-family:var(--serif)}
h1,h2,h3{font-weight:400;letter-spacing:.01em}
.section-no{font-family:var(--serif);font-style:italic;font-size:15px;color:var(--champagne);opacity:.8}

/* ── header ── */
header{
  position:fixed;top:0;left:0;right:0;z-index:50;
  background:linear-gradient(180deg, rgba(255,255,255,.94), rgba(255,255,255,.70));
  backdrop-filter:blur(8px);
  border-bottom:1px solid var(--line-soft);
}
.hbar{display:flex;align-items:center;justify-content:flex-end;height:74px;position:relative}
.brand{display:flex;flex-direction:column;line-height:1.15}
.brand .bn{font-family:var(--serif);font-size:20px;letter-spacing:.22em;color:var(--ivory)}
.brand .bs{font-size:9px;letter-spacing:.46em;text-transform:uppercase;color:var(--muted);margin-top:2px}
nav.main{display:flex;align-items:center;gap:34px}
nav.main a{font-size:12px;letter-spacing:.16em;color:var(--ivory-soft);transition:color .3s}
nav.main a:hover{color:var(--champagne)}
.btn{
  display:inline-flex;align-items:center;gap:9px;
  font-size:12px;letter-spacing:.18em;
  padding:13px 26px;border:1px solid var(--champagne);
  color:var(--champagne);background:transparent;
  transition:all .4s cubic-bezier(.16,1,.3,1);white-space:nowrap;
}
.btn:hover{background:var(--champagne);color:var(--ink)}
.btn-ghost{border-color:var(--line);color:var(--ivory-soft)}
.btn-ghost:hover{border-color:var(--ivory);background:transparent;color:var(--ivory)}
.nav-cta{font-size:11px;letter-spacing:.18em;padding:11px 22px}
.ham{display:none;flex-direction:column;gap:5px;background:none;border:0;cursor:pointer;padding:6px}
.ham span{width:24px;height:1px;background:var(--ivory)}

/* ── hero ── */
.hero{position:relative;padding:190px 0 130px;overflow:hidden}
.hero::after{ /* faint catalog plate behind copy */
  content:"";position:absolute;right:-6%;top:18%;width:46%;height:64%;
  background:
    radial-gradient(closest-side, rgba(194,163,107,.10), transparent 70%),
    conic-gradient(from 200deg at 50% 50%, rgba(236,228,214,.05), transparent 40%);
  filter:blur(2px);border-radius:50%;pointer-events:none;
}
.hero-eye{margin-bottom:30px}
.hero h1{
  font-family:var(--mincho);font-weight:500;
  font-size:clamp(34px,5.4vw,68px);line-height:1.42;color:var(--ivory);
  letter-spacing:.04em;
}
.hero h1 .en{
  display:block;font-family:var(--serif);font-style:italic;font-weight:400;
  font-size:clamp(16px,2vw,24px);letter-spacing:.14em;color:var(--champagne);
  margin-top:22px;opacity:.92;
}
.hero p.lead{
  max-width:620px;margin:36px 0 46px;color:var(--ivory);
  font-size:16px;line-height:2.6;font-weight:400;text-shadow:0 1px 14px rgba(255,255,255,.7);
}
.hero-cta{display:flex;gap:18px;flex-wrap:wrap}
.scrollcue{margin-top:84px;display:flex;align-items:center;gap:14px;color:var(--muted);font-size:11px;letter-spacing:.3em;text-transform:uppercase}
.scrollcue .ln{width:54px;height:1px;background:var(--line)}

/* ── section frame ── */
section.blk{padding:118px 0;position:relative}
.blk + .blk{border-top:1px solid var(--line-soft)}
.head{display:flex;align-items:baseline;gap:18px;margin-bottom:14px}
.head .eyebrow{margin:0}
.sec-title{
  font-family:var(--mincho);font-weight:500;font-size:clamp(26px,3.4vw,40px);
  color:var(--ivory);line-height:1.4;margin:10px 0 6px;letter-spacing:.03em;
}
.sec-sub{color:var(--muted);font-size:14px;line-height:2.0;max-width:680px;margin-bottom:56px}

/* ── philosophy ── */
.pillars{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:var(--line-soft);border:1px solid var(--line-soft)}
.pillar{background:var(--ink);padding:44px 32px;transition:background .5s}
.pillar:hover{background:var(--panel)}
.pillar .pn{font-family:var(--serif);font-style:italic;font-size:34px;color:var(--champagne);opacity:.55}
.pillar h3{font-family:var(--serif);font-size:23px;letter-spacing:.05em;margin:18px 0 4px;color:var(--ivory)}
.pillar .jp{font-family:var(--mincho);font-size:15px;color:var(--champagne-deep);letter-spacing:.1em}
.pillar p{font-size:13px;color:var(--ivory-soft);margin-top:16px;line-height:2}

/* ── keyphrase ── */
.keyband{padding:96px 0;text-align:center;background:
  linear-gradient(180deg, #faf6ee, #f5eee0 50%, #faf6ee);
  border-top:1px solid var(--line-soft);border-bottom:1px solid var(--line-soft)}
.keyband .q{font-family:var(--mincho);font-weight:500;font-size:clamp(22px,3.2vw,38px);color:var(--ivory);letter-spacing:.08em;line-height:1.7}
.keyband .q .gold{color:var(--champagne)}
.keyband .en{font-family:var(--serif);font-style:italic;font-size:16px;color:var(--muted);margin-top:22px;letter-spacing:.12em}

/* ── services ── */
.svc{display:flex;flex-direction:column}
.svc-row{
  display:grid;grid-template-columns:90px 1fr 1.1fr auto;gap:30px;align-items:center;
  padding:34px 6px;border-top:1px solid var(--line-soft);transition:background .5s;
}
.svc-row:last-child{border-bottom:1px solid var(--line-soft)}
.svc-row:hover{background:linear-gradient(90deg,var(--panel),transparent)}
.svc-no{font-family:var(--serif);font-style:italic;font-size:30px;color:var(--champagne);opacity:.7}
.svc-name{font-family:var(--mincho);font-size:21px;color:var(--ivory);letter-spacing:.04em}
.svc-name .en{display:block;font-family:var(--serif);font-size:13px;letter-spacing:.16em;color:var(--muted);margin-top:5px;font-style:italic}
.svc-desc{font-size:13.5px;color:var(--ivory-soft);line-height:2}
.svc-row .go{color:var(--champagne);font-size:20px;opacity:.6;transition:transform .4s,opacity .4s}
.svc-row:hover .go{transform:translateX(6px);opacity:1}

/* ── brand hierarchy ── */
.brands{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:var(--line-soft);border:1px solid var(--line-soft)}
.bcol{background:var(--ink);padding:38px 28px}
.bcol .tier{font-family:var(--serif);font-style:italic;font-size:14px;color:var(--champagne);letter-spacing:.1em}
.bcol h3{font-family:var(--mincho);font-size:16px;color:var(--ivory);margin:6px 0 22px;letter-spacing:.06em;font-weight:500}
.bcol ul{list-style:none}
.bcol li{font-size:13.5px;color:var(--ivory-soft);padding:7px 0;border-bottom:1px solid rgba(42,36,29,.08);transition:color .3s,padding-left .3s}
.bcol li:hover{color:var(--champagne-2);padding-left:6px}

/* ── flow ── */
.flow{display:grid;grid-template-columns:repeat(5,1fr);gap:0}
.step{position:relative;padding:30px 22px 30px 0}
.step .sn{font-family:var(--serif);font-style:italic;font-size:15px;color:var(--champagne)}
.step .sline{height:1px;background:var(--line);margin:16px 0;position:relative}
.step .sline::after{content:"";position:absolute;left:0;top:-2px;width:5px;height:5px;border-radius:50%;background:var(--champagne)}
.step h3{font-family:var(--mincho);font-size:17px;color:var(--ivory);font-weight:500;letter-spacing:.05em;margin-bottom:8px}
.step p{font-size:12.5px;color:var(--muted);line-height:1.9}
.flow-note{margin-top:42px;padding:24px 28px;border:1px solid var(--line);background:var(--panel);font-size:13px;color:var(--ivory-soft);line-height:2}
.flow-note b{color:var(--champagne-deep);font-weight:500}

/* ── content ── */
.cards{display:grid;grid-template-columns:repeat(3,1fr);gap:26px}
.card{border:1px solid var(--line-soft);padding:40px 32px;transition:border-color .5s,transform .5s;background:linear-gradient(180deg,var(--ink),var(--ink-2))}
.card:hover{border-color:var(--line);transform:translateY(-4px)}
.card .ct-eye{font-family:var(--serif);font-style:italic;font-size:14px;color:var(--champagne);letter-spacing:.1em}
.card h3{font-family:var(--mincho);font-size:20px;color:var(--ivory);margin:14px 0 16px;font-weight:500;letter-spacing:.04em}
.card p{font-size:13px;color:var(--ivory-soft);line-height:2}
.card .more{display:inline-block;margin-top:22px;font-size:11px;letter-spacing:.2em;color:var(--champagne);text-transform:uppercase}

/* ── contact ── */
.contact{background:linear-gradient(180deg,var(--ink),var(--panel));border-top:1px solid var(--line-soft)}
.ct-grid{display:grid;grid-template-columns:1.1fr .9fr;gap:64px;align-items:center}
.ct-grid h2{font-family:var(--mincho);font-size:clamp(24px,3vw,36px);color:var(--ivory);line-height:1.5;font-weight:500;letter-spacing:.03em}
.ct-grid .en{font-family:var(--serif);font-style:italic;color:var(--champagne);font-size:17px;margin-top:14px;letter-spacing:.1em}
.ct-grid p{color:var(--ivory-soft);font-size:14px;margin-top:24px;line-height:2.1;max-width:440px}
.channels{display:flex;flex-direction:column;gap:26px}
.chan{display:flex;align-items:center;justify-content:space-between;gap:18px;padding:32px 30px;border:1px solid var(--line);transition:background .4s,border-color .4s}
.chan:hover{background:var(--panel-2);border-color:var(--champagne)}
.chan .cl{font-family:var(--mincho);font-size:15px;color:var(--ivory)}
.chan .cs{font-size:11px;color:var(--muted);letter-spacing:.12em;margin-top:3px}
.chan .cv{font-family:var(--serif);font-style:italic;color:var(--champagne);font-size:16px}

/* ── footer ── */
footer{background:var(--ink);border-top:1px solid var(--line-soft);padding:70px 0 40px}
.fgrid{display:flex;justify-content:space-between;gap:40px;flex-wrap:wrap}
.fbrand .bn{font-family:var(--serif);font-size:22px;letter-spacing:.22em;color:var(--ivory)}
.fbrand .bs{font-size:9px;letter-spacing:.42em;text-transform:uppercase;color:var(--muted);margin-top:4px}
.fbrand p{color:var(--muted);font-size:12.5px;margin-top:20px;max-width:380px;line-height:2}
.fnav{display:flex;gap:54px}
.fnav .col .col-label{font-size:10px;letter-spacing:.28em;text-transform:uppercase;color:var(--champagne);margin-bottom:16px}
.fnav .col a{display:block;font-size:13px;color:var(--ivory-soft);padding:5px 0;transition:color .3s}
.fnav .col a:hover{color:var(--champagne-2)}
.fnote{margin-top:54px;padding-top:26px;border-top:1px solid var(--line-soft);font-size:11px;color:var(--muted);line-height:1.9}
.fcopy{margin-top:18px;font-size:11px;color:var(--muted);letter-spacing:.1em}

/* ── reveal ── */
.fu{opacity:0;transform:translateY(26px);transition:opacity 1s cubic-bezier(.16,1,.3,1),transform 1s cubic-bezier(.16,1,.3,1)}
.fu.vis{opacity:1;transform:none}

/* ── responsive ── */
@media(max-width:980px){
  .pillars,.brands{grid-template-columns:repeat(2,1fr)}
  .flow{grid-template-columns:repeat(2,1fr);gap:14px}
  .cards{grid-template-columns:1fr}
  .ct-grid{grid-template-columns:1fr;gap:40px}
  .svc-row{grid-template-columns:60px 1fr;gap:14px}
  .svc-desc,.svc-row .go{display:none}
}
@media(max-width:680px){
  .wrap{padding:0 22px}
  nav.main{display:none}
  .ham{display:flex;position:relative;z-index:60}
  .ham span{transition:transform .25s, opacity .2s}
  .ham.open span:nth-child(1){transform:translateY(6px) rotate(45deg)}
  .ham.open span:nth-child(2){opacity:0}
  .ham.open span:nth-child(3){transform:translateY(-6px) rotate(-45deg)}
  body.menu-open{overflow:hidden}
  body.menu-open nav.main{
    display:flex;flex-direction:column;align-items:stretch;gap:0;
    position:fixed;top:74px;left:0;right:0;
    background:rgba(255,255,255,.985);backdrop-filter:blur(10px);
    border-top:1px solid var(--line-soft);border-bottom:1px solid var(--line-soft);
    padding:20px 22px 28px;z-index:55;
    box-shadow:0 10px 24px rgba(0,0,0,.05);
    max-height:calc(100vh - 74px);overflow-y:auto;
  }
  body.menu-open nav.main a{
    font-size:14px;letter-spacing:.18em;color:var(--ivory);
    padding:18px 4px;border-bottom:1px solid var(--line-soft);
  }
  body.menu-open nav.main a.nav-cta{
    margin-top:18px;border:1px solid var(--champagne);
    text-align:center;letter-spacing:.2em;
  }
  .hero{padding:150px 0 90px}
  .pillars,.brands{grid-template-columns:1fr}
  .flow{grid-template-columns:1fr}
  .fnav{gap:32px}
}

/* ====== sub-page additions ====== */
.crumb{font-size:11px;letter-spacing:.16em;color:var(--muted);margin-bottom:26px}
.crumb a{color:var(--muted)} .crumb a:hover{color:var(--champagne)}
.phero{padding:168px 0 86px;border-bottom:1px solid var(--line-soft);position:relative;overflow:hidden}
.phero::after{content:"";position:absolute;right:-8%;top:6%;width:42%;height:80%;
  background:radial-gradient(closest-side,rgba(194,163,107,.10),transparent 70%);filter:blur(4px);pointer-events:none}
.phero h1{font-family:var(--mincho);font-weight:500;font-size:clamp(28px,4.4vw,52px);color:var(--ivory);line-height:1.42;letter-spacing:.04em}
.phero h1 .en{display:block;font-family:var(--serif);font-style:italic;font-weight:400;font-size:clamp(15px,1.9vw,22px);color:var(--champagne);margin-top:16px;letter-spacing:.12em}
.phero .lead{max-width:680px;margin-top:30px;color:var(--ivory-soft);font-size:15.5px;line-height:2.7}
.prose p{color:var(--ivory-soft);font-size:14.5px;line-height:2.7;margin-bottom:36px;max-width:780px}
.prose p strong{color:var(--ivory);font-weight:500}
.deflist{margin-top:8px}
.defrow{display:grid;grid-template-columns:230px 1fr;gap:26px;padding:52px 0;border-top:1px solid var(--line-soft)}
.defrow:last-child{border-bottom:1px solid var(--line-soft)}
.defrow dt{font-family:var(--mincho);font-size:17px;color:var(--ivory);letter-spacing:.04em;font-weight:500}
.defrow dt .en{display:block;font-family:var(--serif);font-style:italic;font-size:12px;color:var(--champagne);margin-top:5px;letter-spacing:.1em}
.defrow dd{color:var(--ivory-soft);font-size:14px;line-height:2.6}
.pills{display:flex;flex-wrap:wrap;gap:10px;margin-top:10px}
.pills span{border:1px solid var(--line);padding:9px 17px;font-size:12.5px;color:var(--ivory-soft);letter-spacing:.06em}

.ctaband{padding:96px 0;text-align:center;background:linear-gradient(180deg,var(--ink),var(--panel));border-top:1px solid var(--line-soft)}
.ctaband h2{font-family:var(--mincho);font-weight:500;font-size:clamp(22px,3vw,34px);color:var(--ivory);letter-spacing:.05em;line-height:1.6}
.ctaband .en{font-family:var(--serif);font-style:italic;color:var(--champagne);font-size:15px;margin-top:12px;letter-spacing:.1em}
.ctaband .hero-cta{justify-content:center;margin-top:34px}
@media(max-width:680px){.defrow{grid-template-columns:1fr;gap:8px}}



/* ===== hero full-screen video (low contrast) ===== */
.hero{min-height:100vh;display:flex;align-items:flex-start;padding:140px 0 80px}
.hero-media{position:absolute;inset:0;z-index:0;overflow:hidden;background:var(--ink)}
.hero-media video{width:100%;height:100%;object-fit:cover;display:block;
  filter:contrast(1.12) brightness(1.0) saturate(1.02)}
.hero-veil{position:absolute;inset:0;z-index:1;pointer-events:none;
  background:linear-gradient(180deg,rgba(255,255,255,.7),rgba(255,255,255,.46) 45%,rgba(255,255,255,.76))}
.hero::after{z-index:1}
.hero>.wrap{position:relative;z-index:2}
@media(max-width:680px){.hero{min-height:86vh;padding:124px 0 64px}}


/* ===== MAISON CHRONOS ロゴ（左上バッジ・ヒーローへ張り出し） ===== */
.logo{position:absolute;left:0;top:0;z-index:5;display:block;line-height:0;transition:opacity .25s}
.logo:hover{opacity:.85}
.logo-img{display:block;height:168px;width:auto;object-fit:contain;max-width:100%}
@media(max-width:1100px){.logo-img{height:147px}}
@media(max-width:900px){.logo-img{height:126px}}
@media(max-width:680px){.logo-img{height:98px}}
@media(max-width:480px){.logo-img{height:77px}}


/* ===== メインビジュアル/ヘッダー：横余白を縮小（端に寄せる） ===== */
header .wrap{max-width:1640px}
.hero>.wrap{max-width:1640px}
@media(max-width:680px){.hero>.wrap,header .wrap{max-width:none}}

/* サービス行：行全体をリンク化 */
a.svc-row{color:inherit;text-decoration:none;cursor:pointer}

/* ===== 対象ブランド：アコーディオン（案3／スマホ重視） ===== */
.brands-acc{border-top:1px solid var(--line-soft)}
.acc-item{border-bottom:1px solid var(--line-soft)}
.acc-head{display:flex;align-items:center;gap:20px;width:100%;background:none;border:0;cursor:pointer;text-align:left;padding:30px 6px;font-family:var(--sans);transition:padding-left .4s,background .4s}
.acc-head:hover{padding-left:18px;background:linear-gradient(90deg,var(--panel),transparent)}
.acc-tier{font-family:var(--serif);font-style:italic;font-size:20px;color:var(--champagne);min-width:22px}
.acc-name{font-family:var(--mincho);font-size:21px;color:var(--ivory);letter-spacing:.04em;flex:1}
.acc-meta{font-family:var(--serif);font-style:italic;font-size:13px;color:var(--muted);letter-spacing:.06em}
.acc-ar{font-size:13px;color:var(--champagne);transition:transform .45s;margin-left:6px}
.acc-item.open .acc-ar{transform:rotate(180deg)}
.acc-item.open .acc-head{background:linear-gradient(90deg,var(--panel),transparent)}
.acc-panel{max-height:0;overflow:hidden;transition:max-height .55s cubic-bezier(.16,1,.3,1)}
.acc-item.open .acc-panel{max-height:640px}
.acc-inner{display:grid;grid-template-columns:repeat(4,1fr);gap:2px 26px;padding:4px 6px 30px}
.acc-inner a{display:block;font-size:14px;color:var(--ivory-soft);padding:10px 0;border-bottom:1px solid rgba(42,36,29,.07);text-decoration:none;transition:color .3s,padding-left .3s}
.acc-inner a:hover{color:var(--champagne);padding-left:6px}
@media(max-width:880px){.acc-inner{grid-template-columns:repeat(2,1fr)}.acc-name{font-size:18px}}
@media(max-width:520px){.acc-inner{grid-template-columns:1fr}.acc-head{gap:14px}}

/* 査定相談フォームのCSSはフォーム廃止に伴い削除（2026-06-04）。再導入時はgit/アーカイブ参照 */
/* 電話番号の表示（お電話で相談カード） */
.chan .cv.ctel{font-style:normal;font-size:21px;letter-spacing:.03em;white-space:nowrap}

/* ===== 店舗一覧 ===== */
.store-area{margin-bottom:56px}
.store-area-ttl{display:flex;align-items:baseline;gap:16px;margin-bottom:22px;border-bottom:1px solid var(--line-soft);padding-bottom:14px}
.saa-no{font-family:var(--mincho);font-size:20px;color:var(--ivory);letter-spacing:.06em}
.saa-cnt{font-family:var(--serif);font-style:italic;font-size:13px;color:var(--champagne)}
.store-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;background:transparent;border:none}
.store-card{display:flex;flex-direction:column;gap:5px;background:transparent;padding:24px 22px;text-decoration:none;border:1px solid var(--line-soft);transition:background .4s,border-color .4s}
.store-card:hover{background:var(--panel);border-color:var(--champagne)}
.sc-region{font-family:var(--serif);font-style:italic;font-size:12px;color:var(--champagne);letter-spacing:.08em}
.sc-name{font-family:var(--mincho);font-size:17px;color:var(--ivory);letter-spacing:.03em}
.sc-addr{font-size:12px;color:var(--muted);line-height:1.8;margin-top:2px}
.sc-more{font-size:11px;letter-spacing:.16em;color:var(--champagne);margin-top:10px}
@media(max-width:880px){.store-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:560px){.store-grid{grid-template-columns:1fr}}
/* 古物営業法表記（フッター最下部） */
.flegal{margin-top:14px;font-size:11px;color:var(--muted);letter-spacing:.04em;line-height:1.9}

/* ヒーロー文字の判読性向上（動画背景から浮かせる） */
.hero h1{text-shadow:0 1px 24px rgba(255,255,255,.6),0 0 2px rgba(255,255,255,.5)}
.hero h1 .en{text-shadow:0 1px 16px rgba(255,255,255,.55)}
.hero .scrollcue{color:var(--ivory-soft);text-shadow:0 1px 10px rgba(255,255,255,.7)}

/* ヒーローCTAの判読性（動画背景の上で読みやすく） */
.hero .btn{background:var(--champagne);color:#fff;border-color:var(--champagne);box-shadow:0 6px 20px rgba(0,0,0,.12)}
.hero .btn:hover{background:#b89456;color:#fff;border-color:#b89456}
.hero .btn-ghost{background:#ead8ad;color:#6e561f;border-color:var(--champagne);backdrop-filter:none;-webkit-backdrop-filter:none;box-shadow:0 6px 20px rgba(0,0,0,.10);text-shadow:none}
.hero .btn-ghost:hover{background:#e0caa0;color:#574215;border-color:var(--champagne)}

/* ===== 古物営業法表記モーダル（店舗ページ） ===== */
.kobutsu-btn{background:none;border:0;color:var(--champagne);font-family:var(--sans);font-size:14px;cursor:pointer;padding:0;text-decoration:underline;text-underline-offset:4px;letter-spacing:.03em}
.kobutsu-btn:hover{color:var(--champagne-2)}
.kmodal{position:fixed;inset:0;z-index:1000;display:flex;align-items:center;justify-content:center;padding:24px}
.kmodal[hidden]{display:none}
.kmodal-bg{position:absolute;inset:0;background:rgba(20,16,12,.5);-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}
.kmodal-card{position:relative;z-index:1;background:#fbf8f1;max-width:580px;width:100%;padding:40px 40px 46px;border:1px solid var(--line);box-shadow:0 30px 80px rgba(0,0,0,.32)}
.kmodal-close{position:absolute;top:18px;right:22px;background:none;border:0;font-size:19px;color:var(--muted);cursor:pointer;line-height:1}
.kmodal-close:hover{color:var(--ink)}
.kmodal-ttl{font-family:var(--mincho);font-size:21px;color:var(--ivory);letter-spacing:.05em;margin-bottom:26px;padding-bottom:18px;border-bottom:1px solid var(--line-soft);font-weight:600}
.kmodal-dl{display:flex;flex-direction:column}
.kmodal-row{display:grid;grid-template-columns:130px 1fr}
.kmodal-row+.kmodal-row{margin-top:-1px}
.kmodal-row dt{background:#1a1410;color:#ece4d6;font-family:var(--mincho);font-size:14px;padding:18px 12px;display:flex;align-items:center;justify-content:center;text-align:center;line-height:1.5}
.kmodal-row dd{background:#fff;color:var(--ivory-soft);font-size:14.5px;padding:18px 20px;line-height:1.8;border:1px solid var(--line-soft);border-left:none}
@media(max-width:520px){.kmodal-row{grid-template-columns:96px 1fr}.kmodal-card{padding:32px 24px 36px}}

/* ===== LINEで相談カード（上品な→カード＋QR） ===== */
.chan-line{flex-direction:column;align-items:stretch;gap:0;cursor:default}
.chan-line:hover{background:transparent}
.line-head{display:flex;align-items:center;justify-content:space-between;gap:18px;text-decoration:none;color:inherit}
.line-head .cl{font-family:var(--mincho);font-size:15px;color:var(--ivory)}
.line-head .cs{font-size:11px;color:var(--muted);letter-spacing:.12em;margin-top:3px}
.line-head .cv{font-family:var(--serif);font-style:italic;color:var(--champagne);font-size:22px;line-height:1}

/* ===== A11y: フォーカス可視化（WCAG 2.4.7）＋スキップリンク（2026-06-04追加） ===== */
a:focus-visible,button:focus-visible,[tabindex]:focus-visible{outline:2px solid var(--champagne);outline-offset:2px;border-radius:2px}
.skip-link{position:absolute;left:-9999px;top:0;z-index:2000;background:var(--ivory);color:var(--ink);padding:10px 18px;font-size:13px;letter-spacing:.1em;text-decoration:none}
.skip-link:focus{left:0}

/* ===== A11y: prefers-reduced-motion（2026-06-04追加） ===== */
@media (prefers-reduced-motion: reduce){
  html{scroll-behavior:auto}
  *,*::before,*::after{animation-duration:.01ms !important;animation-iteration-count:1 !important;transition-duration:.01ms !important}
  .fu{opacity:1;transform:none}
}
