
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: smooth; -webkit-text-size-adjust: 100%; }
body { min-height: 100vh; line-height: 1.6; }
img { display: block; max-width: 100%; height: auto; }
a { text-decoration: none; }
ul, ol { list-style: none; }
button { cursor: pointer; border: none; background: none; font: inherit; }

@import url('https://fonts.googleapis.com/css2?family=Libre+Baskerville:ital,wght@0,400;0,700;1,400&family=Source+Serif+4:opsz,wght@8..60,400;8..60,600&display=swap');
:root { --np-bg: #faf8f5; --np-ink: #1a1a1a; --np-red: #c0392b; --np-rule: #ccc;
  --np-font-head: 'Libre Baskerville', serif; --np-font: 'Source Serif 4', serif; }
body { font-family: var(--np-font); background: var(--np-bg); color: var(--np-ink); font-size: 16px; }
.np-masthead { border-bottom: 3px double var(--np-ink); padding: 16px 0; text-align: center; }
.np-masthead__name { font-family: var(--np-font-head); font-size: 2.4rem; font-weight: 700;
  letter-spacing: -0.02em; text-transform: uppercase; }
.np-masthead__date { font-size: 0.75rem; color: #666; margin-top: 4px; }
.np-masthead__nav { display: flex; justify-content: center; gap: 24px; margin-top: 12px;
  border-top: 1px solid var(--np-ink); border-bottom: 1px solid var(--np-ink); padding: 8px 0; }
.np-masthead__nav a { font-size: 0.8rem; text-transform: uppercase; letter-spacing: 0.08em; color: var(--np-ink); font-weight: 600; }
.np-masthead__nav a:hover { color: var(--np-red); }
.np-sheet { max-width: 1080px; margin: 0 auto; padding: 0 24px; }
.np-headline { font-family: var(--np-font-head); font-size: clamp(1.8rem, 4vw, 2.8rem); line-height: 1.15;
  border-bottom: 2px solid var(--np-red); padding-bottom: 12px; margin: 24px 0; }
.np-columns { column-count: 3; column-gap: 32px; column-rule: 1px solid var(--np-rule); }
.np-columns--2 { column-count: 2; }
.np-section { margin: 32px 0; break-inside: avoid; }
.np-section__kicker { font-size: 0.7rem; text-transform: uppercase; letter-spacing: 0.15em;
  color: var(--np-red); font-weight: 700; margin-bottom: 8px; }
.np-section__title { font-family: var(--np-font-head); font-size: 1.2rem; margin-bottom: 12px; }
.np-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 24px; }
.np-card { break-inside: avoid; border-bottom: 1px solid var(--np-rule); padding-bottom: 16px; }
.np-card__headline { font-family: var(--np-font-head); font-size: 1rem; font-weight: 700; line-height: 1.3; }
.np-alert { border: 2px solid var(--np-red); padding: 16px; background: #fff; margin: 16px 0; }
.np-alert::before { content: '⚠ 重要公告'; display: block; color: var(--np-red); font-weight: 700;
  font-size: 0.75rem; text-transform: uppercase; margin-bottom: 8px; }
.np-body-text { line-height: 1.75; text-align: justify; hyphens: auto; }
.np-body-text h2 { font-family: var(--np-font-head); font-size: 1.3rem; margin: 1.2em 0 0.4em; color: var(--np-red); }
.np-spread { display: grid; grid-template-columns: 1fr 2fr; gap: 32px; padding: 24px 0;
  border-top: 1px solid var(--np-rule); border-bottom: 1px solid var(--np-rule); }
.np-spread__photo img { width: 100%; filter: grayscale(30%); }
.np-spread__thumbs { display: flex; gap: 4px; margin-top: 8px; }
.np-spread__title { font-family: var(--np-font-head); font-size: 1.8rem; line-height: 1.2; }
.np-spread__price { font-size: 1.1rem; font-weight: 700; color: var(--np-red); margin: 12px 0; }
.np-spread__facts { font-size: 0.9rem; margin: 16px 0; }
.np-spread__facts dt { font-weight: 700; display: inline; }
.np-spread__facts dd { display: inline; margin-right: 16px; }
.np-spread__facts dd::after { content: ' | '; color: var(--np-rule); }
.np-btn { display: inline-block; background: var(--np-ink); color: #fff; padding: 8px 20px;
  font-size: 0.8rem; text-transform: uppercase; letter-spacing: 0.05em; }
.np-breadcrumb { font-size: 0.75rem; color: #666; padding: 12px 0; }
.np-breadcrumb a { color: var(--np-red); }
.np-filters { display: flex; flex-wrap: wrap; gap: 8px; margin-bottom: 16px; font-size: 0.85rem; }
.np-pagination { text-align: center; padding: 24px 0; font-size: 0.85rem; }
.np-article { max-width: 720px; margin: 0 auto; padding: 32px 0; }
.np-article__title { font-family: var(--np-font-head); font-size: 2rem; line-height: 1.2; }
.np-article__byline { font-size: 0.8rem; color: #666; font-style: italic; margin: 12px 0 24px;
  border-bottom: 1px solid var(--np-rule); padding-bottom: 12px; }
.np-footer { border-top: 3px double var(--np-ink); padding: 24px 0; margin-top: 40px; }
.np-footer__cols { display: grid; grid-template-columns: 2fr 1fr 1fr; gap: 24px; font-size: 0.85rem; }
.np-footer__title { font-family: var(--np-font-head); font-size: 0.9rem; font-weight: 700; margin-bottom: 8px; }
.np-footer__areas a { color: #555; display: inline-block; margin-right: 8px; }
.np-footer__copy { text-align: center; font-size: 0.75rem; color: #888; margin-top: 16px;
  border-top: 1px solid var(--np-rule); padding-top: 12px; }
@media (max-width: 768px) {
  .np-columns { column-count: 1; } .np-grid { grid-template-columns: 1fr; }
  .np-spread { grid-template-columns: 1fr; } .np-footer__cols { grid-template-columns: 1fr; }
}
.np-m1 { margin: 2px; }
.np-p1 { padding: 2px; }
.np-gap1 { gap: 1px; }
.np-w1 { width: 5px; max-width: 100%; }
.np-fw4 { font-weight: 400; }
.np-op1 { opacity: 0.1; }
.np-m2 { margin: 4px; }
.np-p2 { padding: 4px; }
.np-gap2 { gap: 2px; }
.np-w2 { width: 10px; max-width: 100%; }
.np-m3 { margin: 6px; }
.np-p3 { padding: 6px; }
.np-gap3 { gap: 3px; }
.np-w3 { width: 15px; max-width: 100%; }
.np-m4 { margin: 8px; }
.np-p4 { padding: 8px; }
.np-gap4 { gap: 4px; }
.np-w4 { width: 20px; max-width: 100%; }
.np-m5 { margin: 10px; }
.np-p5 { padding: 10px; }
.np-gap5 { gap: 5px; }
.np-w5 { width: 25px; max-width: 100%; }
.np-m6 { margin: 12px; }
.np-p6 { padding: 12px; }
.np-gap6 { gap: 6px; }
.np-w6 { width: 30px; max-width: 100%; }
.np-fw5 { font-weight: 500; }
.np-op2 { opacity: 0.2; }
.np-m7 { margin: 14px; }
.np-p7 { padding: 14px; }
.np-gap7 { gap: 7px; }
.np-w7 { width: 35px; max-width: 100%; }
.np-m8 { margin: 16px; }
.np-p8 { padding: 16px; }
.np-gap8 { gap: 8px; }
.np-w8 { width: 40px; max-width: 100%; }
.np-m9 { margin: 18px; }
.np-p9 { padding: 18px; }
.np-gap9 { gap: 9px; }
.np-w9 { width: 45px; max-width: 100%; }
.np-m10 { margin: 20px; }
.np-p10 { padding: 20px; }
.np-gap10 { gap: 10px; }
.np-w10 { width: 50px; max-width: 100%; }
.np-m11 { margin: 22px; }
.np-p11 { padding: 22px; }
.np-gap11 { gap: 11px; }
.np-w11 { width: 55px; max-width: 100%; }
.np-fw6 { font-weight: 600; }
.np-op3 { opacity: 0.3; }
.np-m12 { margin: 24px; }
.np-p12 { padding: 24px; }
.np-gap12 { gap: 12px; }
.np-w12 { width: 60px; max-width: 100%; }
.np-m13 { margin: 26px; }
.np-p13 { padding: 26px; }
.np-gap13 { gap: 13px; }
.np-w13 { width: 65px; max-width: 100%; }
.np-m14 { margin: 28px; }
.np-p14 { padding: 28px; }
.np-gap14 { gap: 14px; }
.np-w14 { width: 70px; max-width: 100%; }
.np-m15 { margin: 30px; }
.np-p15 { padding: 30px; }
.np-gap15 { gap: 15px; }
.np-w15 { width: 75px; max-width: 100%; }
.np-m16 { margin: 32px; }
.np-p16 { padding: 32px; }
.np-gap16 { gap: 16px; }
.np-w16 { width: 80px; max-width: 100%; }
.np-fw7 { font-weight: 700; }
.np-op4 { opacity: 0.4; }
.np-m17 { margin: 34px; }
.np-p17 { padding: 34px; }
.np-gap17 { gap: 17px; }
.np-w17 { width: 85px; max-width: 100%; }
.np-m18 { margin: 36px; }
.np-p18 { padding: 36px; }
.np-gap18 { gap: 18px; }
.np-w18 { width: 90px; max-width: 100%; }
.np-m19 { margin: 38px; }
.np-p19 { padding: 38px; }
.np-gap19 { gap: 19px; }
.np-w19 { width: 95px; max-width: 100%; }
.np-m20 { margin: 40px; }
.np-p20 { padding: 40px; }
.np-gap20 { gap: 20px; }
.np-w20 { width: 100px; max-width: 100%; }
.np-m21 { margin: 42px; }
.np-p21 { padding: 42px; }
.np-gap21 { gap: 21px; }
.np-w21 { width: 105px; max-width: 100%; }
.np-fw8 { font-weight: 800; }
.np-op5 { opacity: 0.5; }
.np-m22 { margin: 44px; }
.np-p22 { padding: 44px; }
.np-gap22 { gap: 22px; }
.np-w22 { width: 110px; max-width: 100%; }
.np-m23 { margin: 46px; }
.np-p23 { padding: 46px; }
.np-gap23 { gap: 23px; }
.np-w23 { width: 115px; max-width: 100%; }
.np-m24 { margin: 48px; }
.np-p24 { padding: 48px; }
.np-gap24 { gap: 24px; }
.np-w24 { width: 120px; max-width: 100%; }
.np-m25 { margin: 50px; }
.np-p25 { padding: 50px; }
.np-gap25 { gap: 25px; }
.np-w25 { width: 125px; max-width: 100%; }
.np-m26 { margin: 52px; }
.np-p26 { padding: 52px; }
.np-gap26 { gap: 26px; }
.np-w26 { width: 130px; max-width: 100%; }
.np-fw9 { font-weight: 900; }
.np-op6 { opacity: 0.6; }
.np-m27 { margin: 54px; }
.np-p27 { padding: 54px; }
.np-gap27 { gap: 27px; }
.np-w27 { width: 135px; max-width: 100%; }
.np-m28 { margin: 56px; }
.np-p28 { padding: 56px; }
.np-gap28 { gap: 28px; }
.np-w28 { width: 140px; max-width: 100%; }
.np-m29 { margin: 58px; }
.np-p29 { padding: 58px; }
.np-gap29 { gap: 29px; }
.np-w29 { width: 145px; max-width: 100%; }
.np-m30 { margin: 60px; }
.np-p30 { padding: 60px; }
.np-gap30 { gap: 30px; }
.np-w30 { width: 150px; max-width: 100%; }
.np-m31 { margin: 62px; }
.np-p31 { padding: 62px; }
.np-gap31 { gap: 31px; }
.np-w31 { width: 155px; max-width: 100%; }
.np-fw10 { font-weight: 1000; }
.np-op7 { opacity: 0.7; }
.np-m32 { margin: 64px; }
.np-p32 { padding: 64px; }
.np-gap32 { gap: 32px; }
.np-w32 { width: 160px; max-width: 100%; }
.np-m33 { margin: 66px; }
.np-p33 { padding: 66px; }
.np-gap33 { gap: 33px; }
.np-w33 { width: 165px; max-width: 100%; }
.np-m34 { margin: 68px; }
.np-p34 { padding: 68px; }
.np-gap34 { gap: 34px; }
.np-w34 { width: 170px; max-width: 100%; }
.np-m35 { margin: 70px; }
.np-p35 { padding: 70px; }
.np-gap35 { gap: 35px; }
.np-w35 { width: 175px; max-width: 100%; }
.np-m36 { margin: 72px; }
.np-p36 { padding: 72px; }
.np-gap36 { gap: 36px; }
.np-w36 { width: 180px; max-width: 100%; }
.np-fw11 { font-weight: 1100; }
.np-op8 { opacity: 0.8; }
.np-m37 { margin: 74px; }
.np-p37 { padding: 74px; }
.np-gap37 { gap: 37px; }
.np-w37 { width: 185px; max-width: 100%; }
.np-m38 { margin: 76px; }
.np-p38 { padding: 76px; }
.np-gap38 { gap: 38px; }
.np-w38 { width: 190px; max-width: 100%; }
.np-m39 { margin: 78px; }
.np-p39 { padding: 78px; }
.np-gap39 { gap: 39px; }
.np-w39 { width: 195px; max-width: 100%; }
.np-m40 { margin: 80px; }
.np-p40 { padding: 80px; }
.np-gap40 { gap: 40px; }
.np-w40 { width: 200px; max-width: 100%; }
.np-m41 { margin: 82px; }
.np-p41 { padding: 82px; }
.np-gap41 { gap: 41px; }
.np-w41 { width: 205px; max-width: 100%; }
.np-fw12 { font-weight: 1200; }
.np-op9 { opacity: 0.9; }
.np-m42 { margin: 84px; }
.np-p42 { padding: 84px; }
.np-gap42 { gap: 42px; }
.np-w42 { width: 210px; max-width: 100%; }
.np-m43 { margin: 86px; }
.np-p43 { padding: 86px; }
.np-gap43 { gap: 43px; }
.np-w43 { width: 215px; max-width: 100%; }
.np-m44 { margin: 88px; }
.np-p44 { padding: 88px; }
.np-gap44 { gap: 44px; }
.np-w44 { width: 220px; max-width: 100%; }
.np-m45 { margin: 90px; }
.np-p45 { padding: 90px; }
.np-gap45 { gap: 45px; }
.np-w45 { width: 225px; max-width: 100%; }