
:root{--washi:#ece4d2;--paper:#f4eee0;--card:#f8f3e7;--sumi:#211d16;--sumi2:#3a342a;--mut:#867c66;--line:#d8cdb4;--shu:#a8472e;--shu-d:#8c3823;--maxw:1080px}
*{box-sizing:border-box}html{scroll-behavior:smooth}
body{margin:0;color:var(--sumi);background:var(--washi);font-family:"Noto Sans JP",system-ui,sans-serif;font-size:16px;line-height:1.95}
a{color:inherit;text-decoration:none}
.ww{max-width:var(--maxw);margin:0 auto;padding:0 26px}.narrow{max-width:760px}.tc{text-align:center}
.lg-n,.dh,.hero-h,.ph h1,.gcard-ja,.grow-ja,.scard-n{font-family:"Shippori Mincho",serif}
.eb,.ph-en,.grow-en,.gcard-en{font-family:"Shippori Mincho",serif}

/* enhancement: fee / anshin / jisseki / voices */
.fee5{display:grid;grid-template-columns:repeat(5,1fr);gap:12px;max-width:760px;margin:8px auto 0}
.fee{background:var(--card);border:1px solid var(--line);border-radius:4px;padding:18px 10px;display:flex;flex-direction:column;gap:7px}
.fee b{font-size:12.5px;color:var(--sumi2);font-weight:700}
.fee span{font-family:"Shippori Mincho",serif;font-size:22px;font-weight:700;color:var(--shu)}
.anshin{width:100%;border-collapse:collapse;text-align:left;margin:6px auto 0;max-width:700px}
.anshin th,.anshin td{padding:13px 16px;border-bottom:1px solid var(--line);font-size:14px;vertical-align:top}
.anshin th{width:38%;color:var(--sumi);font-weight:700;background:var(--card);font-family:"Shippori Mincho",serif}
.anshin td{color:var(--sumi2)}
.jgrp{margin-top:22px;border-top:1px solid var(--line);padding-top:18px}
.jgh{font-size:16px;color:var(--sumi);font-family:"Shippori Mincho",serif;margin:0 0 12px}
.jgh a:hover{color:var(--shu)}
.jbs{display:flex;flex-wrap:wrap;gap:9px}
.jb{padding:8px 16px;background:var(--card);border:1px solid var(--line);border-radius:4px;font-size:13.5px;color:var(--sumi2);font-weight:700;transition:.18s}
.jb:hover{border-color:var(--shu);color:var(--shu)}
.voices{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;margin-top:8px}
.vcard{background:var(--card);border:1px dashed var(--line);border-radius:4px;padding:26px 20px;text-align:center}
.vseal{display:inline-flex;align-items:center;justify-content:center;width:30px;height:30px;background:var(--line);color:var(--mut);font-family:"Shippori Mincho",serif;border-radius:3px;font-size:15px;margin-bottom:10px}
.vq{font-family:"Shippori Mincho",serif;font-size:18px;color:var(--mut);margin:0 0 8px}
.vn{font-size:12px;color:var(--mut);margin:0}

/* seal motif */
.seal{display:inline-flex;align-items:center;justify-content:center;width:34px;height:34px;background:var(--shu);color:#fff;font-family:"Shippori Mincho",serif;font-weight:700;border-radius:3px;font-size:18px;line-height:1}
.seal.big{width:46px;height:46px;font-size:24px}
.hero-seal{width:54px;height:54px;font-size:28px;margin-bottom:22px;box-shadow:0 6px 18px rgba(168,71,46,.25)}

/* header */
.hd{position:sticky;top:0;z-index:60;background:rgba(236,228,210,.95);backdrop-filter:blur(6px);border-bottom:1px solid var(--line)}
.hd-in{max-width:var(--maxw);margin:0 auto;padding:0 26px;height:72px;display:flex;align-items:center;gap:20px}
.lg{display:flex;align-items:center;gap:12px}
.lg-t{display:flex;flex-direction:column;line-height:1.15}
.lg-n{font-size:19px;font-weight:700;color:var(--sumi)}
.lg-s{font-size:9.5px;letter-spacing:.12em;color:var(--mut)}
.nav{display:flex;gap:20px;margin-left:auto;font-size:13.5px}
.nav a{padding:6px 2px;border-bottom:1px solid transparent;color:var(--sumi2)}
.nav a:hover{color:var(--shu);border-color:var(--shu)}
.hd-cta{background:var(--sumi);color:var(--washi);font-size:13px;font-weight:700;padding:10px 20px;white-space:nowrap}
.hd-cta:hover{background:var(--shu)}
.bg{display:none;flex-direction:column;gap:5px;width:42px;height:42px;align-items:center;justify-content:center;cursor:pointer;border:1px solid var(--line)}
.bg span{display:block;width:20px;height:1.5px;background:var(--sumi);transition:.25s}

/* crumb */
.cr{border-bottom:1px solid var(--line);font-size:12px;color:var(--mut)}
.cr .ww{padding:11px 26px}.cr a:hover{color:var(--shu)}

/* headings */
.eb{letter-spacing:.22em;font-size:12px;color:var(--shu);margin:0 0 8px;text-transform:uppercase}
.eb.shu{color:var(--shu)}
.dh{font-size:clamp(26px,3.6vw,38px);font-weight:600;margin:0 0 24px;color:var(--sumi);letter-spacing:.04em}
.dh.light{color:var(--washi)}

/* hero */
.hero{padding:86px 0 76px;background:radial-gradient(120% 100% at 50% 0%,#f3ecda,var(--washi));border-bottom:1px solid var(--line)}
.hero-k{font-size:11.5px;letter-spacing:.16em;color:var(--mut);margin:0 0 20px}
.hero-h{font-size:clamp(40px,7vw,80px);font-weight:600;line-height:1.16;margin:0 0 24px;color:var(--sumi);letter-spacing:.06em}
.hero-l{max-width:600px;margin:0 auto 28px;color:var(--sumi2)}
.hero-b{display:flex;gap:14px;justify-content:center;flex-wrap:wrap;margin-bottom:26px}
.hero-p{display:flex;flex-wrap:wrap;gap:8px 22px;justify-content:center;list-style:none;padding:0;margin:0;font-size:13px;color:var(--sumi2)}
.hero-p li{position:relative;padding-left:18px}
.hero-p li::before{content:"・";position:absolute;left:2px;color:var(--shu);font-weight:700}

/* buttons */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:14px 30px;font-weight:700;font-size:14px;border:1px solid var(--sumi);transition:.18s}
.btn-s{background:var(--sumi);color:var(--washi);border-color:var(--sumi)}.btn-s:hover{background:var(--shu);border-color:var(--shu)}
.btn-o{background:transparent;color:var(--sumi)}.btn-o:hover{background:var(--sumi);color:var(--washi)}
.btn-so{background:transparent;color:var(--washi);border-color:rgba(255,255,255,.5)}.btn-so:hover{background:var(--washi);color:var(--sumi);border-color:var(--washi)}

/* bands */
.band{padding:66px 0}.band.paper{background:var(--paper)}.band.sumi{background:var(--sumi);color:#e6ddc9}
.band-l{max-width:680px;margin:0 0 24px;color:var(--sumi2)}.tc .band-l,.band.sumi .band-l{margin-left:auto;margin-right:auto}
.band.sumi .band-l,.band-l.light{color:#bcb39c}
.more{margin-top:24px}.more a{color:var(--shu);font-weight:700}.more a.shu-l{color:#e8a48f}.more a:hover{text-decoration:underline}
.muted{color:var(--mut)}.small{font-size:12px}.rl{font-weight:700;color:var(--mut);margin:0 0 10px;font-size:13px}

/* genre cards (index) */
.ggrid{display:grid;grid-template-columns:repeat(3,1fr);gap:0;border:1px solid var(--line);background:var(--card)}
.gcard{display:flex;flex-direction:column;gap:6px;padding:28px 24px;border-right:1px solid var(--line);border-bottom:1px solid var(--line);border-top:3px solid var(--tone,var(--shu));transition:.18s}
.gcard:hover{background:var(--sumi);color:var(--washi)}
.gcard-en{font-size:11px;letter-spacing:.14em;color:var(--shu)}.gcard:hover .gcard-en{color:#e8a48f}
.gcard-ja{font-size:19px;font-weight:700}.gcard-l{font-size:12.5px;color:var(--mut)}.gcard:hover .gcard-l{color:#cabfa8}

/* genre rows (genre.html) */
.grows{display:flex;flex-direction:column;border-top:1px solid var(--line)}
.grow{padding:22px 4px;border-bottom:1px solid var(--line)}
.grow-h{display:flex;align-items:baseline;gap:14px;border-left:3px solid var(--tone);padding-left:14px}
.grow-en{font-size:11px;letter-spacing:.12em;color:var(--shu)}
.grow-ja{font-size:21px;font-weight:700}
.grow-l{font-size:13px;color:var(--mut);margin:8px 0 8px 17px}
.grow-s{display:flex;flex-wrap:wrap;gap:5px 16px;font-size:12.5px;color:var(--sumi2);margin-left:17px}
.grow-s a{border-bottom:1px solid transparent}.grow-s a:hover{color:var(--shu);border-color:var(--shu)}

/* meisho cards (産地・様式) */
.mgrid{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin-top:8px}
.mcard{display:flex;flex-direction:column;gap:7px;padding:20px 22px;background:var(--card);border:1px solid var(--line);transition:.18s}
.mcard:hover{border-color:var(--shu);background:#fff}
.mcard-n{font-family:"Shippori Mincho",serif;font-size:17px;font-weight:700;color:var(--sumi)}
.mcard-d{font-size:12.5px;line-height:1.7;color:var(--sumi2)}

/* sub cards */
.sgrid{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;margin-top:8px}
.scard{display:flex;justify-content:space-between;align-items:center;padding:18px 20px;background:var(--card);border:1px solid var(--line);transition:.18s}
.scard:hover{border-color:var(--shu);background:#fff}
.scard-n{font-weight:600;font-size:15px}.scard-g{color:var(--shu);font-weight:700}

/* prov box */
.prov{display:flex;gap:20px;background:var(--card);border:1px solid var(--line);padding:28px 30px;align-items:flex-start}
.prov-seal{flex:none;width:46px;height:46px;background:var(--shu);color:#fff;display:flex;align-items:center;justify-content:center;font-family:"Shippori Mincho",serif;font-size:22px;border-radius:3px}
.prov h3{font-family:"Shippori Mincho",serif;margin:0 0 12px;font-size:18px;color:var(--sumi)}
.prov ul{margin:0;padding:0;list-style:none}
.prov li{padding:8px 0 8px 20px;border-bottom:1px dotted var(--line);position:relative;font-size:14px;color:var(--sumi2)}
.prov li::before{content:"・";position:absolute;left:2px;color:var(--shu);font-weight:700}
.prov b{color:var(--sumi)}

/* note box (legal) */
.notebox{display:flex;gap:14px;align-items:flex-start;background:#f6ece2;border:1px solid #e0c4ab;padding:18px 22px}
.notebox-m{flex:none;width:26px;height:26px;background:var(--shu);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:700;border-radius:50%}
.notebox p{margin:0;font-size:13.5px;color:var(--sumi2)}

/* estate grid */
.kgrid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-top:8px}
.kbox{background:var(--card);border:1px solid var(--line);padding:26px;text-align:center}
.kbox h3{font-family:"Shippori Mincho",serif;margin:0 0 9px;font-size:18px;color:var(--sumi)}.kbox p{margin:0;font-size:13.5px;color:var(--sumi2)}

/* steps */
.steps{list-style:none;padding:0;margin:0;display:grid;grid-template-columns:repeat(3,1fr);gap:18px;text-align:center}
.steps li{border:1px solid rgba(255,255,255,.16);padding:28px 22px;font-size:13.5px;color:#bcb39c}
.steps span{font-family:"Shippori Mincho",serif;font-weight:700;font-size:26px;color:#e8a48f;display:block}
.steps b{display:block;margin:8px 0 6px;font-size:16px;color:var(--washi)}
.steps2{list-style:none;counter-reset:s;padding:0;margin:0}
.steps2 li{position:relative;padding:0 0 26px 56px;border-left:1px solid var(--line);margin-left:18px}
.steps2 li:last-child{border-color:transparent}
.steps2 li::before{counter-increment:s;content:counter(s);position:absolute;left:-18px;top:-4px;width:36px;height:36px;background:var(--shu);color:#fff;display:flex;align-items:center;justify-content:center;font-family:"Shippori Mincho",serif;font-size:16px}
.steps2 b{display:block;font-size:16px;margin-bottom:4px;color:var(--sumi)}.steps2 p{margin:0;color:var(--sumi2);font-size:14px}

/* page header */
.ph{background:var(--paper);border-bottom:1px solid var(--line);padding:58px 0}
.ph.gph{border-top:4px solid var(--tone)}
.ph-en{font-size:13px;letter-spacing:.18em;color:var(--shu);margin:0 0 10px}
.ph h1{font-size:clamp(28px,4.4vw,46px);font-weight:600;margin:0 0 14px;color:var(--sumi);letter-spacing:.04em}
.ph-l{color:var(--sumi2);margin:0 auto;max-width:730px}

/* methods/checks/tips/tags/faq */
.m3{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.mb{border:1px solid var(--line);background:var(--card);padding:26px;text-align:center}
.mb span{display:inline-flex;align-items:center;justify-content:center;width:40px;height:40px;background:var(--shu);color:#fff;font-family:"Shippori Mincho",serif;border-radius:3px;font-size:15px;margin-bottom:6px}
.mb h3{font-family:"Shippori Mincho",serif;margin:6px 0 9px;font-size:18px}.mb p{margin:0;font-size:13.5px;color:var(--sumi2)}
.checks,.tips{list-style:none;padding:0;margin:0}
.checks li{position:relative;padding:11px 0 11px 22px;border-bottom:1px solid var(--line);font-size:14.5px}
.checks li::before{content:"・";position:absolute;left:2px;color:var(--shu);font-weight:700}
.tips li{padding:14px 0;border-bottom:1px solid var(--line);font-size:14.5px;color:var(--sumi2)}.tips b{color:var(--sumi)}
.tags{display:flex;flex-wrap:wrap;gap:8px}.tags a{border:1px solid var(--line);padding:8px 16px;font-size:13px;transition:.18s;background:var(--card)}.tags a:hover{border-color:var(--shu);color:var(--shu)}
.faq{margin:0}.qa{border-bottom:1px solid var(--line);padding:16px 0}
.qa dt{font-weight:700;color:var(--sumi);position:relative;padding-left:26px}
.qa dt::before{content:"問";position:absolute;left:0;color:var(--shu);font-family:"Shippori Mincho",serif;font-weight:700;font-size:15px}
.qa dd{margin:8px 0 0 26px;color:var(--sumi2);font-size:14.5px}
.gb{padding:22px 0;border-bottom:1px solid var(--line)}.gb h3{font-family:"Shippori Mincho",serif;font-size:19px;color:var(--sumi);margin:0 0 8px}.gb p{margin:0 0 10px;color:var(--sumi2)}.gb p:last-child{margin-bottom:0}
.gb .artdl{margin:14px 0 4px}.artdl-row{display:grid;grid-template-columns:170px 1fr;gap:14px;padding:11px 0;border-top:1px solid var(--line)}
.artdl-row dt{font-family:"Shippori Mincho",serif;font-weight:600;font-size:14.5px;color:var(--shu-d)}.artdl-row dd{margin:0;color:var(--sumi2);font-size:14px;line-height:1.85}
.gb .art-list{margin:12px 0 4px;padding-left:0;list-style:none}.art-list li{position:relative;padding:9px 0 9px 22px;border-bottom:1px solid var(--line);font-size:14.5px;color:var(--sumi2)}.art-list li::before{content:"・";position:absolute;left:4px;color:var(--shu);font-weight:700;top:8px}
.art-toc{border:1px solid var(--line);background:var(--card);padding:20px 24px;margin:0 0 8px}
.art-toc-t{font-family:"Shippori Mincho",serif;font-weight:600;letter-spacing:.1em;font-size:14px;color:var(--shu-d);margin:0 0 10px}
.art-toc ol{margin:0;padding-left:1.3em;font-size:14.5px;line-height:1.95;color:var(--sumi2)}.art-toc a{color:var(--sumi2)}.art-toc a:hover{color:var(--shu);text-decoration:underline}
.art-lead{font-size:15.5px;line-height:1.95;margin:0 0 22px;color:var(--sumi2)}
@media(max-width:600px){.artdl-row{grid-template-columns:1fr;gap:3px}}
.ctab{display:flex;gap:14px;justify-content:center;flex-wrap:wrap}

/* genre search */
.gsi{width:100%;font:inherit;padding:14px 18px;border:1px solid var(--sumi);background:var(--card);margin-bottom:8px}
.gsi:focus{outline:none;border-color:var(--shu)}
.bcount{font-size:12.5px;color:var(--mut);margin:0 0 14px}.bnone{color:var(--mut);padding:24px 0}

/* form/table */
.frm{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin-top:18px;background:var(--card);border:1px solid var(--line);padding:30px}
.frm label{display:flex;flex-direction:column;gap:6px;font-size:12px;font-weight:700;color:var(--sumi)}.frm .full{grid-column:1/-1}
.frm input,.frm textarea{font:inherit;font-weight:400;padding:11px 14px;border:1px solid var(--line);background:#fff}
.frm input:focus,.frm textarea:focus{outline:none;border-color:var(--shu)}
.frm .btn{grid-column:1/-1;justify-self:start}.frm .fn{grid-column:1/-1;margin:0;font-size:11px;color:var(--mut)}
.ctbl{width:100%;border-collapse:collapse}.ctbl th,.ctbl td{text-align:left;padding:14px 16px;border-bottom:1px solid var(--line);font-size:14.5px}
.ctbl th{width:34%;background:var(--card);color:var(--sumi);font-weight:700;white-space:nowrap}
.pv h3{font-family:"Shippori Mincho",serif;font-size:17px;color:var(--sumi);margin:22px 0 6px}.pv p{margin:0;color:var(--sumi2)}

/* footer */
.ft{background:var(--sumi);color:#bcb39c;border-top:3px solid var(--shu)}
.ft-in{display:grid;grid-template-columns:1.8fr 1fr 1fr 1fr;gap:30px;padding:54px 26px 36px}
.ft-n{font-family:"Shippori Mincho",serif;font-size:18px;color:var(--washi);margin:14px 0 8px}.ft-n span{font-size:11px;color:#9a9075;letter-spacing:.1em}
.ft-b p{font-size:13px;margin:0 0 12px}.ft-b .mini{font-size:11.5px;color:#8b8268}
.ft-c h3{font-family:"Shippori Mincho",serif;font-size:14px;color:var(--washi);margin:0 0 14px}
.ft-c a{display:block;font-size:13px;padding:5px 0;color:#ada487}.ft-c a:hover{color:#e8a48f}
.cc{border-top:1px solid #38322a;font-size:12px;color:#827a64}.cc .ww{padding:16px 26px}

@media(max-width:960px){
  .nav{display:none}.bg{display:flex}
  #nv:checked ~ header .bg span:nth-child(1){transform:translateY(7px) rotate(45deg)}
  #nv:checked ~ header .bg span:nth-child(2){opacity:0}
  #nv:checked ~ header .bg span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}
  #nv:checked ~ header .nav{display:flex;position:fixed;top:72px;left:0;right:0;bottom:0;background:var(--washi);flex-direction:column;gap:0;padding:14px 26px;z-index:55;overflow:auto}
  #nv:checked ~ header .nav a{padding:16px 0;border-bottom:1px solid var(--line);font-size:16px}
  .ggrid,.sgrid,.kgrid,.steps,.m3,.mgrid{grid-template-columns:1fr 1fr}.sgrid{grid-template-columns:1fr 1fr}
  .fee5{grid-template-columns:1fr 1fr 1fr}.voices{grid-template-columns:1fr}
  .prov{flex-direction:column}.ft-in{grid-template-columns:1fr 1fr}.frm{grid-template-columns:1fr}
}
@media(max-width:600px){
  .hd-cta{display:none}.hd-in{height:64px}
  .ggrid,.sgrid,.kgrid,.steps,.m3,.mgrid{grid-template-columns:1fr}
  .fee5{grid-template-columns:1fr 1fr}.anshin th{width:48%}
  .band{padding:46px 0}.hero{padding:56px 0 48px}.ft-in{grid-template-columns:1fr}
}
