*{box-sizing:border-box;margin:0;padding:0}
:root{--bg:#f5f0e6;--paper:#fffdf8;--ink:#2e2a22;--accent:#c5673f;--mut:#6b6454;--mut2:#807868;--mut3:#a4977f;--line:rgba(46,42,34,.12);--line2:rgba(46,42,34,.2);--serif:'Shippori Mincho',serif;--sans:'Zen Kaku Gothic New',sans-serif}
html{-webkit-text-size-adjust:100%}
body{background:var(--bg);color:var(--ink);font-family:var(--sans);line-height:1.85;-webkit-font-smoothing:antialiased;overflow-x:hidden}
::selection{background:var(--ink);color:var(--bg)}
a{color:inherit;text-decoration:none}
img{display:block}
.wrap{max-width:1180px;margin:0 auto;padding:0 28px}
.progress{position:fixed;top:0;left:0;height:3px;width:0;background:var(--accent);z-index:60}
.eyebrow span,.sechead{font-family:var(--sans)}
/* util */
.util{background:var(--bg)}
.util .in{height:42px;display:flex;align-items:center;justify-content:space-between}
.util .date{font-size:12px;letter-spacing:.14em;color:var(--mut3)}
.util .links{display:flex;align-items:center;gap:16px;font-size:12.5px;letter-spacing:.04em;color:var(--mut)}
.util .links a:hover{color:var(--ink)}
.udiv{width:1px;height:13px;background:var(--line2);flex:none}
.sns{display:flex;align-items:center;gap:3px}
.sns .sn{display:flex;align-items:center;justify-content:center;width:28px;height:28px;transition:transform .2s,opacity .2s}
.sns .sn:hover{transform:translateY(-2px);opacity:.75}
.sn-spotify{color:#1DB954}.sn-tiktok{color:#2e2a22}.sn-x{color:#2e2a22}.sn-instagram{color:#E4405F}.sn-facebook{color:#1877F2}.sn-threads{color:#2e2a22}
/* masthead */
.mast{background:rgba(245,240,230,.86);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);border-bottom:1px solid var(--line);position:sticky;top:0;z-index:40;transition:box-shadow .3s}
.mast .in{padding:22px 0;display:flex;align-items:center;justify-content:space-between;gap:24px}
.brand{display:flex;align-items:center;gap:15px}
.logoimg{width:46px;height:46px;flex:none;object-fit:contain}
.wm b{display:block;font-family:var(--serif);font-weight:800;font-size:26px;letter-spacing:.02em;line-height:1}
.wm small{display:block;margin-top:7px;font-size:10px;font-weight:600;letter-spacing:.32em;color:var(--mut3)}
.actions{display:flex;align-items:center;gap:14px}
.videobtn{display:inline-flex;align-items:center;gap:10px;height:44px;padding:0 22px;background:var(--ink);color:var(--bg);border-radius:32px;font-size:14px;font-weight:700;letter-spacing:.04em;white-space:nowrap;transition:transform .3s,box-shadow .3s,background .3s}
.videobtn:hover{transform:translateY(-2px);box-shadow:0 14px 28px -12px rgba(197,103,63,.7);background:#3a352b}
.play{display:inline-flex;align-items:center;justify-content:center;width:22px;height:16px;background:var(--accent);border-radius:4px;flex:none}
.play::after{content:"";width:0;height:0;border-left:6px solid #fff;border-top:4px solid transparent;border-bottom:4px solid transparent;margin-left:1px}
/* nav */
.nav{background:rgba(245,240,230,.9);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);border-bottom:1px solid var(--line);position:sticky;top:88px;z-index:30}
.nav .in{display:flex;gap:2px;overflow-x:auto;scrollbar-width:none;-webkit-mask-image:linear-gradient(to right,#000 calc(100% - 34px),transparent);mask-image:linear-gradient(to right,#000 calc(100% - 34px),transparent)}
.nav .in::-webkit-scrollbar{display:none}
.nav a{position:relative;flex:none;padding:15px 15px 14px;font-size:14.5px;font-weight:600;color:var(--mut);white-space:nowrap;transition:color .15s}
.nav a:hover{color:var(--ink)}
.nav a.on{color:var(--ink)}
.nav a.on::after{content:"";position:absolute;left:15px;right:15px;bottom:-1px;height:2px;background:var(--accent)}
/* hero */
.hero{padding:58px 28px 26px}
.eyebrow{display:flex;align-items:center;gap:12px;margin-bottom:26px}
.eyebrow span{font-size:12px;letter-spacing:.28em;color:var(--accent);font-weight:700}
.eyebrow i{flex:0 0 38px;height:1px;background:#d8c9ad}
.eyebrow time{font-size:12px;letter-spacing:.16em;color:var(--mut3)}
.herogrid{display:grid;grid-template-columns:1.04fr .96fr;gap:48px;align-items:center}
@media(max-width:820px){.herogrid{grid-template-columns:1fr;gap:28px}}
.catline{display:inline-flex;align-items:center;gap:8px;margin-bottom:16px}
.dot{width:8px;height:8px;border-radius:50%;flex:none}
.catname{font-size:12.5px;font-weight:700;color:#5f5848}
.herotitle{display:block;font-family:var(--serif);font-weight:800;font-size:42px;line-height:1.42;letter-spacing:.01em;word-break:auto-phrase;cursor:pointer;transition:color .2s}
.herotitle:hover{color:var(--accent)}
@media(max-width:820px){.herotitle{font-size:31px}}
.herosum{font-size:15.5px;line-height:2;color:var(--mut);margin:20px 0 26px;max-width:520px}
.cta{display:inline-flex;align-items:center;gap:9px;background:var(--ink);color:var(--bg);font-size:14px;font-weight:700;padding:13px 26px;border-radius:32px;transition:transform .3s,box-shadow .3s}
.cta:hover{transform:translateY(-2px);box-shadow:0 14px 28px -12px rgba(197,103,63,.7)}
.heroimgwrap{position:relative}
.glow{position:absolute;width:160px;height:160px;border-radius:50%;background:radial-gradient(circle,rgba(197,103,63,.22),rgba(197,103,63,0) 70%);right:-22px;top:-26px;animation:floaty 7s ease-in-out infinite}
@keyframes floaty{0%,100%{transform:translateY(0)}50%{transform:translateY(-14px)}}
.heroimg{display:block;position:relative;border-radius:22px;overflow:hidden;border:1px solid rgba(46,42,34,.08);box-shadow:0 20px 44px -26px rgba(70,50,25,.45);transition:transform .45s cubic-bezier(.2,.7,.2,1),box-shadow .45s}
.heroimg:hover{transform:translateY(-6px);box-shadow:0 30px 60px -28px rgba(70,50,25,.55)}
.heroimg .ph{display:block;height:380px;background:#e3d8c0 center/cover;transition:transform .7s cubic-bezier(.2,.7,.2,1)}
.heroimg:hover .ph{transform:scale(1.05)}
@media(max-width:820px){.heroimg .ph{height:260px}}
/* sections */
.sec{padding:50px 28px 8px}
.sechead{display:flex;align-items:flex-end;gap:16px;margin-bottom:24px}
.sechead h2{font-family:var(--serif);font-weight:700;font-size:23px}
.sechead i{flex:1;height:1px;background:var(--line)}
.sechead .more{font-size:13px;font-weight:600;color:var(--accent)}
/* 特集 + grid cards */
.featgrid,.grid{display:grid;grid-template-columns:1fr 1fr;gap:28px}
.grid{grid-template-columns:repeat(3,1fr)}
@media(max-width:900px){.grid{grid-template-columns:1fr 1fr}}
@media(max-width:620px){.featgrid,.grid{grid-template-columns:1fr}}
.card{display:block;background:var(--paper);border-radius:18px;overflow:hidden;border:1px solid rgba(46,42,34,.07);transition:transform .45s cubic-bezier(.2,.7,.2,1),box-shadow .45s}
.card:hover{transform:translateY(-7px);box-shadow:0 26px 56px -28px rgba(70,50,25,.5)}
.card .ph{height:200px;background:#e3d8c0 center/cover;transition:transform .55s cubic-bezier(.2,.7,.2,1)}
.card:hover .ph{transform:scale(1.06)}
.card .body{padding:20px 22px 24px}
.card .meta{display:flex;align-items:center;gap:8px;margin-bottom:10px}
.card .meta .cn{font-size:11.5px;font-weight:700;color:var(--mut2)}
.card .meta .cd{font-size:11px;color:var(--mut3);margin-left:auto}
.card .ct{font-family:var(--serif);font-weight:700;font-size:20px;line-height:1.55;margin-bottom:9px;word-break:auto-phrase}
.card:hover .ct{color:var(--accent)}
.card .cx{font-size:13px;line-height:1.85;color:var(--mut2);display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
/* 最新リスト */
.rows{border-top:1px solid var(--line)}
.row{display:grid;grid-template-columns:128px 1fr auto;gap:24px;align-items:center;padding:20px 14px;border-bottom:1px solid var(--line);transition:background .35s}
.row>div{min-width:0}
.row:hover{background:#fffdf8}
@media(max-width:620px){.row{grid-template-columns:92px 1fr;gap:16px}.row .rstat{display:none}}
.row .rthumb{width:128px;height:84px;border-radius:12px;overflow:hidden}
@media(max-width:620px){.row .rthumb{width:92px;height:66px}}
.row .rthumb .ph{width:100%;height:100%;background:#e3d8c0 center/cover;transition:transform .5s}
.row:hover .rthumb .ph{transform:scale(1.07)}
.row .rmeta{display:flex;align-items:center;gap:9px;margin-bottom:7px}
.row .rmeta .cn{font-size:11.5px;font-weight:700;color:var(--mut2)}
.row .rmeta .cd{font-size:11px;color:var(--mut3)}
.row .rt{font-family:var(--serif);font-weight:700;font-size:19px;line-height:1.5;margin-bottom:5px;word-break:auto-phrase}
.row:hover .rt{color:var(--accent)}
.row .rx{font-size:12.5px;line-height:1.6;color:var(--mut2);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.row .rstat{display:flex;flex-direction:column;align-items:flex-end;gap:6px}
.row .rnum{font-family:var(--serif);font-weight:800;font-size:25px;line-height:1}
.row .rarrow{font-size:20px;color:var(--ink);opacity:.5;transition:transform .35s,opacity .35s}
.row:hover .rarrow{transform:translateX(7px);opacity:1}
/* intro (category pages) */
.intro{padding:54px 0 6px}
.intro .eyebrow span{color:var(--accent)}
.intro h2{margin-top:18px;font-family:var(--serif);font-weight:700;font-size:28px;line-height:1.5;word-break:auto-phrase}
/* article */
.artwrap{padding:26px 0 0}
.wrapA{max-width:850px;margin:0 auto;padding:0 28px}
.artlayout{display:flex;gap:30px;max-width:850px;margin:20px auto 0;padding:0 28px}
.sharerail{flex:0 0 46px}
@media(max-width:720px){.sharerail{display:none}}
.sharerail .sticky{position:sticky;top:120px;display:flex;flex-direction:column;align-items:center;gap:12px}
.sbtn{width:44px;height:44px;border-radius:50%;border:1.5px solid var(--line2);display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:700;color:var(--ink);cursor:pointer;transition:transform .25s,background .25s,color .25s,border-color .25s}
.sbtn:hover{transform:translateY(-3px);background:var(--ink);color:var(--bg);border-color:var(--ink)}
.art{flex:1;min-width:0}
.ameta{display:flex;align-items:center;gap:10px;margin-bottom:15px}
.catchip{display:inline-flex;align-items:center;gap:7px;border:1.5px solid var(--line2);font-size:12px;font-weight:700;color:#5f5848;padding:5px 13px;border-radius:30px}
.ameta time{font-size:12.5px;color:var(--mut3)}
.atitle{font-family:var(--serif);font-weight:800;font-size:34px;line-height:1.5;letter-spacing:.01em;margin-bottom:18px;word-break:auto-phrase}
@media(max-width:620px){.atitle{font-size:27px}}
.lead{font-size:17px;line-height:2;color:#5f5848;font-weight:500;margin-bottom:28px}
.art .hero{width:100%;border-radius:20px;overflow:hidden;border:1px solid rgba(46,42,34,.08);aspect-ratio:1200/630;object-fit:cover;background:#e3d8c0;margin-bottom:10px}
.pull{border-left:5px solid var(--accent);padding:8px 0 8px 24px;margin:34px 0}
.pull .pn{font-family:var(--serif);font-weight:800;line-height:1;font-size:60px}
.pull .pu{font-size:30px}
.pull .pl{font-size:14px;color:var(--mut2);margin-top:10px;font-weight:500}
.art p{font-size:16.5px;line-height:2.1;color:#3a342a;margin:0 0 22px}
.art h2{font-family:var(--serif);font-weight:700;font-size:23px;line-height:1.6;margin:42px 0 16px}
.art h3{font-family:var(--serif);font-weight:700;font-size:19px;margin:32px 0 12px}
.art strong{font-weight:700;background:linear-gradient(transparent 58%,#ffe1a8 58%);padding:0 1px}
.art ul{margin:20px 0;padding:0;list-style:none}
.art li{position:relative;padding:7px 0 7px 20px;line-height:1.85}
.art li::before{content:"";position:absolute;left:1px;top:15px;width:7px;height:7px;border-radius:50%;background:var(--accent)}
.art a{color:var(--accent)}.art a:hover{text-decoration:underline}
hr{border:0;border-top:1px solid var(--line);margin:28px 0}
.srcbox{border:1px dashed #c9bda3;border-radius:14px;padding:18px 22px;margin:32px 0 8px}
.srcbox .k{font-size:11px;letter-spacing:.2em;color:#b07a4c;font-weight:700;margin-bottom:9px}
.srcbox .b{font-size:13px;line-height:1.8;color:var(--mut)}
.videocta{display:flex;align-items:center;justify-content:center;gap:11px;height:54px;background:var(--ink);color:var(--bg);border-radius:32px;font-weight:700;font-size:15px;margin:30px 0 6px;transition:transform .3s,box-shadow .3s}
.videocta:hover{transform:translateY(-2px);box-shadow:0 14px 28px -12px rgba(197,103,63,.7)}
.back{display:inline-block;font-size:13.5px;font-weight:600;color:var(--mut)}
.relwrap{margin-top:40px}
.relhd{display:flex;align-items:center;gap:16px;margin-bottom:20px}
.relhd h2{font-family:var(--serif);font-weight:700;font-size:21px}
.relhd i{flex:1;height:1px;background:var(--line)}
.relgrid{display:grid;grid-template-columns:1fr 1fr;gap:20px}
@media(max-width:560px){.relgrid{grid-template-columns:1fr}}
.relcard{background:var(--paper);border-radius:16px;overflow:hidden;border:1px solid rgba(46,42,34,.07);transition:transform .4s,box-shadow .4s}
.relcard:hover{transform:translateY(-5px);box-shadow:0 20px 44px -26px rgba(70,50,25,.5)}
.relcard .ph{height:128px;background:#e3d8c0 center/cover;transition:transform .5s}
.relcard:hover .ph{transform:scale(1.06)}
.relcard .b{padding:15px 17px 18px}
.relcard .rcn{font-size:11px;font-weight:700;color:var(--mut2);margin-bottom:8px;display:flex;align-items:center;gap:6px}
.relcard .rct{font-family:var(--serif);font-weight:700;font-size:16px;line-height:1.55;word-break:auto-phrase}
/* shop */
.shop{margin:34px 0 0;border:1px solid #ece0c8;background:#fbf6ea;border-radius:18px;padding:22px 24px}
.shop .rh{font-family:var(--serif);font-weight:700;font-size:16px;margin-bottom:14px;display:flex;align-items:center;gap:9px}
.shop .rh::before{content:"";width:18px;height:2px;background:var(--accent)}
.pcard{display:flex;gap:14px;align-items:center;background:#fff;border:1px solid rgba(46,42,34,.1);border-radius:12px;padding:12px;margin-bottom:10px}
.pcard:hover{border-color:var(--ink)}
.pimg{width:84px;height:84px;flex:none;display:flex;align-items:center;justify-content:center}
.pimg img{max-width:100%;max-height:84px;object-fit:contain}
.pbody{display:flex;flex-direction:column;gap:9px;min-width:0}
.ptitle{font-size:14.5px;font-weight:700;line-height:1.5;color:var(--ink);display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.pbtn{align-self:flex-start;font-size:13px;font-weight:700;color:#fff;background:var(--ink);border-radius:30px;padding:7px 16px}
.pcard:hover .pbtn{background:var(--accent)}
.shopnote{font-size:11.5px;color:var(--mut3);line-height:1.7;margin-top:4px}
ins.adsbygoogle{display:block}
/* footer */
.foot{background:#2e2a22;color:#cdc4b2;margin-top:66px}
.foot .fin{display:flex;flex-wrap:wrap;gap:30px;align-items:flex-start;justify-content:space-between;padding-top:48px;padding-bottom:24px}
.fbrand{max-width:330px}
.fname{font-family:var(--serif);font-weight:700;font-size:20px;color:var(--bg)}
.fen{font-size:9px;letter-spacing:.34em;color:#8a7f6a;margin-top:4px}
.fdesc{font-size:13px;line-height:1.95;color:#a99e89;margin-top:16px}
.flinks{display:flex;flex-direction:column;gap:11px;font-size:13.5px}
.flinks a{color:#cdc4b2}.flinks a:hover{color:var(--bg)}
.ffollow .fhd{font-size:11px;letter-spacing:.2em;color:#8a7f6a;font-weight:700;margin-bottom:13px}
.fpills{display:flex;flex-wrap:wrap;gap:9px;max-width:240px}
.snspill{border:1.5px solid #56503f;border-radius:30px;padding:6px 13px;font-size:11.5px;color:#cdc4b2;transition:transform .25s,background .25s,color .25s,border-color .25s}
.snspill:hover{transform:translateY(-2px);background:var(--accent);color:#fff;border-color:var(--accent)}
.fdis{border-top:1px solid #46402f;margin-top:10px;padding-top:18px;padding-bottom:30px;font-size:11.5px;line-height:1.8;color:#8a7f6a}
/* ===== mobile ===== */
@media(max-width:640px){
.wrap{padding:0 18px}
.util .in{height:38px}.util .date{display:none}.util .links{gap:9px;margin-left:auto}.sns{gap:1px}.sns .sn{width:26px;height:26px}
.mast .in{padding:14px 0;gap:12px}
.logoimg{width:38px;height:38px}
.wm b{font-size:20px;line-height:1.25}.wm small{letter-spacing:.24em;margin-top:5px}
.videobtn{height:40px;padding:0 15px;font-size:12.5px;gap:8px}
.nav{top:0;position:sticky}
.nav a{padding:13px 12px 12px;font-size:14px}
.hero{padding:30px 18px 14px}
.eyebrow{margin-bottom:18px}
.herogrid{gap:22px}
.herotitle{font-size:27px;line-height:1.46}
.herosum{font-size:14.5px;margin:16px 0 22px}
.heroimg .ph{height:240px}
.glow{width:110px;height:110px;right:-10px;top:-16px}
.sec{padding:34px 18px 4px}
.sechead h2{font-size:21px}
.featgrid{gap:18px}
.row{grid-template-columns:88px 1fr;gap:14px;padding:16px 6px}
.row .rthumb{width:88px;height:62px}
.row .rstat{display:none}
.row .rt{font-size:16.5px}
.intro{padding:34px 0 4px}.intro h2{font-size:23px}
.atitle{font-size:25px}
.pull .pn{font-size:44px}.pull .pu{font-size:22px}
.art p{font-size:16px}
.foot .fin{flex-direction:column;gap:24px;padding-top:38px}
}