:root{
    --ink:#0c0a08; --ink-2:#161210; --char:#201a15;
    --cream:#f3e7d0; --cream-soft:#c5b69b;
    --amber:#e0a64a; --amber-deep:#bf7f2a;
    --beni:#b5362c; --noodle:#e8d2a0;
    --line:rgba(243,231,208,.12); --line-2:rgba(243,231,208,.2);
    --gold:#c9a24a;
    --shadow:0 30px 80px -30px rgba(0,0,0,.8);
  }
  *{box-sizing:border-box;margin:0;padding:0}
  html{scroll-behavior:smooth}
  body{font-family:"Noto Sans JP",sans-serif;color:var(--cream);background:var(--ink);
    line-height:1.9;font-weight:300;-webkit-font-smoothing:antialiased;overflow-x:hidden}
  body[data-lang="ja"] h1,body[data-lang="ja"] h2,body[data-lang="ja"] h3,
  body[data-lang="ja"] p,body[data-lang="ja"] .lead,body[data-lang="ja"] li{
    word-break:auto-phrase;line-break:strict}
  body::after{content:"";position:fixed;inset:0;z-index:9;pointer-events:none;opacity:.045;
    background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='120' height='120'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='3'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E")}
  .mincho{font-family:"Shippori Mincho",serif}
  .serif{font-family:"Cormorant Garamond",serif}
  .wrap{max-width:1240px;margin:0 auto;padding:0 30px;position:relative;z-index:2}
  img{display:block;max-width:100%}

  /* layered visual: SVG underneath, photo on top (onerror hides photo) */
  .vis{position:relative;overflow:hidden;background:var(--char)}
  .vis svg{position:absolute;inset:0;width:100%;height:100%}
  .vis img.ph{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:1;
    opacity:0;transition:opacity .8s ease}
  .vis img.ph.loaded{opacity:1}

  /* hairline gold accents */
  .rule{width:46px;height:2px;background:linear-gradient(90deg,var(--amber),transparent)}

  /* ---------- Header ---------- */
  header{position:fixed;top:0;left:0;right:0;z-index:1000;transition:.4s}
  header.solid{background:rgba(12,10,8,.84);backdrop-filter:blur(14px);border-bottom:1px solid var(--line)}
  .bar{display:flex;align-items:center;justify-content:space-between;height:74px}
  .brand{display:flex;align-items:center;gap:13px;text-decoration:none;color:var(--cream)}
  .seal{width:42px;height:42px;border-radius:9px;background:var(--beni);color:#fff;display:grid;place-items:center;
    font-family:"Shippori Mincho",serif;font-weight:800;font-size:22px}
  .seal-emblem{width:44px;height:44px;display:inline-block;flex:none}
  .seal-emblem svg{width:100%;height:100%;display:block}
  .brand b{font-family:"Shippori Mincho",serif;font-weight:700;font-size:18px;letter-spacing:.08em;display:block}
  .brand span{font-size:9.5px;letter-spacing:.34em;color:var(--cream-soft);text-transform:uppercase}
  nav{display:flex;align-items:center;gap:30px}
  .navlinks{display:flex;gap:26px}
  nav a{color:var(--cream-soft);text-decoration:none;font-size:12.5px;letter-spacing:.12em;transition:.2s}
  nav a:hover{color:var(--amber)}
  .lang{display:flex;border:1px solid var(--cream-soft);border-radius:40px;overflow:hidden;font-size:11.5px}
  .lang button{border:0;background:transparent;color:var(--cream);padding:6px 13px;cursor:pointer;
    font-family:inherit;letter-spacing:.12em;font-weight:500;transition:.2s}
  .lang button.on{background:var(--amber);color:var(--ink)}

  /* ---------- HERO ---------- */
  .hero{min-height:100svh;display:flex;align-items:center;position:relative;overflow:hidden;background:#0c0a08;padding:88px 0 44px}
  .hero-bg{position:absolute;inset:0;z-index:0;background:url("/assets/img/hero.jpg") center/cover no-repeat}
  .hero-scrim{position:absolute;inset:0;z-index:1;background:
    linear-gradient(90deg,rgba(12,10,8,.95) 0%,rgba(12,10,8,.82) 40%,rgba(12,10,8,.42) 72%,rgba(12,10,8,.62) 100%),
    linear-gradient(0deg,rgba(12,10,8,.92),transparent 46%)}
  .hero-glow{display:none}
  .seigaiha{position:absolute;left:0;right:0;bottom:0;height:120px;opacity:.06;z-index:1;
    background-repeat:repeat-x;background-size:80px 40px;
    background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='80' height='40'%3E%3Cg fill='none' stroke='%23e0a64a' stroke-width='2'%3E%3Cpath d='M0 40 A40 40 0 0 1 80 40'/%3E%3Cpath d='M-40 40 A40 40 0 0 1 40 40'/%3E%3Cpath d='M40 40 A40 40 0 0 1 120 40'/%3E%3C/g%3E%3C/svg%3E")}
  .hero .wrap{position:relative;z-index:2;width:100%}
  .hero-txt{max-width:35em}
  .hero .rule{margin-bottom:26px}
  .kicker{font-size:12px;letter-spacing:.42em;color:var(--amber);text-transform:uppercase;margin-bottom:22px;text-shadow:0 1px 10px rgba(0,0,0,.65)}
  .hero h1{font-family:"Shippori Mincho",serif;font-weight:800;line-height:1.16;
    font-size:clamp(34px,5.2vw,66px);letter-spacing:.02em;margin-bottom:22px;text-shadow:0 2px 26px rgba(0,0,0,.55)}
  .hero h1 .o{color:var(--amber)}
  .hero p.lead{font-size:16.5px;color:var(--cream);max-width:30em;font-weight:300;text-shadow:0 1px 14px rgba(0,0,0,.7)}
  .hero-cta{margin-top:38px;display:flex;gap:15px;flex-wrap:wrap}
  .btn{display:inline-flex;align-items:center;gap:9px;padding:15px 30px;border-radius:46px;text-decoration:none;
    font-size:14px;letter-spacing:.08em;font-weight:500;transition:.25s;cursor:pointer;border:0;font-family:inherit}
  .btn-fill{background:var(--amber);color:var(--ink)}
  .btn-fill:hover{background:var(--cream);transform:translateY(-2px)}
  .btn-ghost{background:transparent;color:var(--cream);border:1px solid var(--cream-soft)}
  .btn-ghost:hover{border-color:var(--amber);color:var(--amber)}
  .hero-vis{position:relative;height:560px;display:grid;place-items:center}
  .hero-kanji{position:absolute;font-family:"Shippori Mincho",serif;font-weight:800;font-size:clamp(220px,30vw,380px);
    color:rgba(243,231,208,.04);line-height:1;z-index:0;user-select:none}
  .scroll-cue{position:absolute;bottom:28px;left:50%;transform:translateX(-50%);font-size:10px;
    letter-spacing:.4em;color:var(--cream-soft);text-transform:uppercase;writing-mode:vertical-rl;animation:bob 2s ease-in-out infinite;z-index:3}
  @keyframes bob{0%,100%{transform:translateX(-50%) translateY(0)}50%{transform:translateX(-50%) translateY(8px)}}
  .steam path{stroke:var(--cream);stroke-width:3;fill:none;stroke-linecap:round;opacity:0;animation:rise 4s ease-in-out infinite}
  .steam path:nth-child(2){animation-delay:1s}.steam path:nth-child(3){animation-delay:2s}.steam path:nth-child(4){animation-delay:1.5s}
  @keyframes rise{0%{opacity:0;transform:translateY(14px)}30%{opacity:.5}70%{opacity:.25}100%{opacity:0;transform:translateY(-18px)}}

  /* ---------- Marquee ---------- */
  .strip{background:var(--amber);color:var(--ink);padding:14px 0;overflow:hidden;white-space:nowrap}
  .strip .run{display:inline-block;animation:slide 30s linear infinite;font-family:"Shippori Mincho",serif;font-weight:700;font-size:16px;letter-spacing:.06em}
  .strip .run span{margin:0 24px;opacity:.92}.strip .run .dot{opacity:.45}
  @keyframes slide{from{transform:translateX(0)}to{transform:translateX(-50%)}}

  /* ---------- Section frame ---------- */
  section{padding:108px 0;position:relative}
  .sec-head{max-width:48em;margin:0 auto 60px;text-align:center}
  .sec-head .lbl{font-size:11.5px;letter-spacing:.42em;color:var(--amber);text-transform:uppercase}
  .sec-head .jpsub{font-family:"Shippori Mincho",serif;font-size:13px;letter-spacing:.3em;color:var(--cream-soft);margin-top:8px}
  .sec-head h2{font-family:"Shippori Mincho",serif;font-weight:700;font-size:clamp(30px,4.4vw,50px);margin:14px 0 18px;letter-spacing:.05em;line-height:1.25}
  .sec-head p{color:var(--cream-soft);font-size:15.5px}

  /* ---------- Gallery ---------- */
  .gallery{background:var(--ink-2);border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
  .gal-grid{display:grid;grid-template-columns:repeat(6,1fr);grid-auto-rows:170px;gap:14px}
  .gtile{position:relative;overflow:hidden;border-radius:12px;border:1px solid var(--line)}
  .gtile .vis{position:absolute;inset:0}
  .gtile .cap{position:absolute;left:0;right:0;bottom:0;z-index:2;padding:14px 14px 12px;
    background:linear-gradient(transparent,rgba(12,10,8,.85));font-family:"Shippori Mincho",serif;font-size:13px;letter-spacing:.06em}
  .gtile .cap small{display:block;font-family:"Cormorant Garamond",serif;font-size:11px;letter-spacing:.18em;color:var(--amber);font-style:italic}
  .g-wide{grid-column:span 2}.g-tall{grid-row:span 2}
  /* feature-explanation cards (中央セクション) */
  .feat-grid{display:grid;grid-template-columns:1fr 1fr;gap:22px}
  .fcard{border:1px solid var(--line);border-radius:16px;overflow:hidden;background:var(--ink);display:grid;grid-template-columns:43% 1fr;transition:.3s}
  .fcard:hover{border-color:var(--line-2);transform:translateY(-3px);box-shadow:var(--shadow)}
  .fcard .vis{position:relative;min-height:210px;overflow:hidden}
  .fcard .fbody{padding:26px 28px;display:flex;flex-direction:column;justify-content:center}
  .fcard .flbl{font-family:"Cormorant Garamond",serif;font-size:13px;letter-spacing:.2em;color:var(--amber);font-style:italic;text-transform:uppercase;margin-bottom:8px}
  .fcard h3{font-family:"Shippori Mincho",serif;font-weight:700;font-size:18.5px;letter-spacing:.03em;line-height:1.5;margin-bottom:11px}
  .fcard p{font-size:13px;color:var(--cream-soft);line-height:1.95}
  @media(max-width:960px){.feat-grid{grid-template-columns:1fr}}
  @media(max-width:560px){.fcard{grid-template-columns:1fr}.fcard .vis{height:200px}}

  /* ---------- Feature blocks ---------- */
  .feature{display:grid;grid-template-columns:1fr 1fr;align-items:stretch;border:1px solid var(--line);
    border-radius:18px;overflow:hidden;margin-bottom:28px;background:var(--ink-2)}
  .feature:nth-child(even){direction:rtl}.feature:nth-child(even)>*{direction:ltr}
  .feature .vis{min-height:360px}
  .feature .txt{padding:54px 52px;display:flex;flex-direction:column;justify-content:center}
  .feature .txt .n{font-family:"Cormorant Garamond",serif;font-size:20px;color:var(--amber);letter-spacing:.2em}
  .feature .txt h3{font-family:"Shippori Mincho",serif;font-weight:700;font-size:27px;margin:10px 0 16px;letter-spacing:.04em}
  .feature .txt p{color:var(--cream-soft);font-size:15px}

  /* ---------- History timeline ---------- */
  .history{background:var(--ink);position:relative}
  .history .asanoha{position:absolute;inset:0;opacity:.04;z-index:0;background-size:60px 104px;
    background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='60' height='104'%3E%3Cg fill='none' stroke='%23e0a64a' stroke-width='1.4'%3E%3Cpath d='M30 0 V52 M30 52 L0 35 M30 52 L60 35 M30 52 L0 69 M30 52 L60 69 M30 52 V104 M0 0 L30 17 L60 0 M0 104 L30 87 L60 104'/%3E%3C/g%3E%3C/svg%3E")}
  .tl{max-width:760px;margin:0 auto;position:relative;padding:10px 0}
  .tl::before{content:"";position:absolute;left:50%;top:0;bottom:0;width:1px;background:var(--line-2);transform:translateX(-.5px)}
  .tl-item{position:relative;width:50%;padding:0 42px 46px;box-sizing:border-box}
  .tl-item:nth-child(odd){left:0;text-align:right}
  .tl-item:nth-child(even){left:50%}
  .tl-item .dot{position:absolute;top:6px;width:13px;height:13px;border-radius:50%;background:var(--amber);box-shadow:0 0 0 5px rgba(224,166,74,.16)}
  .tl-item:nth-child(odd) .dot{right:-6.5px}.tl-item:nth-child(even) .dot{left:-6.5px}
  .tl-item .yr{font-family:"Cormorant Garamond",serif;font-size:26px;color:var(--amber);letter-spacing:.04em;line-height:1}
  .tl-item h4{font-family:"Shippori Mincho",serif;font-weight:700;font-size:17px;margin:7px 0 8px;letter-spacing:.03em}
  .tl-item p{font-size:13.5px;color:var(--cream-soft);line-height:1.8}

  /* ---------- Health ---------- */
  .health{background:var(--ink-2);border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
  .health-in{display:grid;grid-template-columns:.95fr 1.05fr;gap:56px;align-items:center}
  .health .vis{height:430px;border-radius:16px;border:1px solid var(--line)}
  .tag{display:inline-block;background:var(--beni);color:#fff;font-size:11px;letter-spacing:.2em;padding:6px 15px;border-radius:30px;margin-bottom:22px;text-transform:uppercase}
  .health-copy h3{font-family:"Shippori Mincho",serif;font-weight:700;font-size:clamp(26px,3.4vw,38px);margin-bottom:20px;letter-spacing:.04em;line-height:1.3}
  .health-copy p{color:var(--cream-soft);font-size:15px;margin-bottom:15px}
  .stats{display:grid;grid-template-columns:repeat(4,1fr);gap:15px;margin-top:30px}
  .stat{border:1px solid var(--line);border-radius:12px;padding:20px 10px;text-align:center;background:var(--char)}
  .stat b{display:block;font-family:"Cormorant Garamond",serif;font-size:32px;color:var(--amber);line-height:1}
  .stat span{font-size:10.5px;color:var(--cream-soft);letter-spacing:.02em}

  /* ---------- Map + filters ---------- */
  .filters{display:flex;flex-wrap:wrap;gap:9px;justify-content:center;margin-bottom:26px;align-items:center}
  .filters .flabel{font-size:11px;letter-spacing:.2em;color:var(--cream-soft);text-transform:uppercase;margin-right:4px}
  .chip{border:1px solid var(--line-2);background:transparent;color:var(--cream-soft);border-radius:40px;
    padding:8px 17px;font-size:12.5px;cursor:pointer;font-family:inherit;letter-spacing:.06em;transition:.2s}
  .chip:hover{border-color:var(--amber);color:var(--cream)}
  .chip.on{background:var(--amber);color:var(--ink);border-color:var(--amber);font-weight:500}
  .chip.sandai.on{background:var(--beni);color:#fff;border-color:var(--beni)}
  .chip .sep{margin:0 8px;color:var(--line-2)}
  .map-layout{display:grid;grid-template-columns:1fr 380px;border:1px solid var(--line);border-radius:18px;
    overflow:hidden;box-shadow:var(--shadow);background:var(--ink-2);min-height:640px}
  #map{height:680px;width:100%;background:#0a0a0a}
  .leaflet-container{font-family:"Noto Sans JP",sans-serif;background:#0a0a0a}
  .list-pane{border-left:1px solid var(--line);display:flex;flex-direction:column;max-height:680px}
  .lp-head{padding:18px 22px;border-bottom:1px solid var(--line);display:flex;justify-content:space-between;align-items:baseline}
  .lp-head b{font-family:"Shippori Mincho",serif;font-size:16px}
  .lp-head small{color:var(--amber);font-size:11px;letter-spacing:.12em}
  .shop-list{overflow-y:auto;flex:1}
  .shop-item{display:flex;cursor:pointer;border-bottom:1px solid var(--line);transition:.25s;align-items:stretch}
  .shop-item:hover,.shop-item.active{background:var(--char)}
  .shop-item .thumb{width:100px;flex:none;position:relative;overflow:hidden}
  .shop-item .thumb .vis{position:absolute;inset:0}
  .shop-item .thumb img.up{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:3}
  .shop-item .body{padding:14px 17px}
  .shop-item .loc{font-size:11px;color:var(--amber);letter-spacing:.13em;margin-bottom:3px;display:flex;gap:7px;align-items:center}
  .shop-item .sd{font-size:9px;background:var(--beni);color:#fff;padding:2px 7px;border-radius:20px;letter-spacing:.08em}
  .shop-item h4{font-family:"Shippori Mincho",serif;font-weight:700;font-size:14.5px;letter-spacing:.02em;margin-bottom:4px}
  .shop-item p{font-size:11.5px;color:var(--cream-soft);line-height:1.55}
  .empty-list{padding:40px 20px;text-align:center;color:var(--cream-soft);font-size:13px}
  .note{font-size:12px;color:var(--cream-soft);margin-top:16px;text-align:center;opacity:.7}
  .pin-n{font-family:"Cormorant Garamond",serif}

  /* ---------- Detail modal ---------- */
  .overlay{position:fixed;inset:0;background:rgba(6,5,4,.74);backdrop-filter:blur(5px);z-index:2000;display:none;align-items:center;justify-content:center;padding:24px}
  .overlay.show{display:flex}
  .detail{background:var(--ink-2);max-width:680px;width:100%;max-height:90vh;overflow-y:auto;border-radius:20px;box-shadow:var(--shadow);position:relative;border:1px solid var(--line)}
  .detail-hero{height:240px;position:relative;overflow:hidden;background:var(--char)}
  .detail-hero .vis{position:absolute;inset:0}
  .detail-hero img.up{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:3}
  .detail-hero .scrim{position:absolute;inset:0;z-index:4;background:linear-gradient(180deg,transparent 38%,rgba(12,10,8,.92))}
  .detail-hero .vt{position:absolute;left:26px;top:22px;z-index:5;writing-mode:vertical-rl;font-family:"Shippori Mincho",serif;font-weight:800;color:rgba(243,231,208,.92);font-size:30px;letter-spacing:.3em;text-shadow:0 3px 14px rgba(0,0,0,.6)}
  .detail-hero .loc-badge{position:absolute;left:26px;bottom:18px;z-index:5;background:var(--beni);color:#fff;font-size:11px;letter-spacing:.18em;padding:6px 14px;border-radius:30px}
  .photo-btn{position:absolute;right:18px;bottom:16px;z-index:5;background:rgba(12,10,8,.72);color:var(--cream);border:1px solid var(--cream-soft);border-radius:30px;padding:7px 15px;font-size:12px;cursor:pointer;font-family:inherit;letter-spacing:.06em;transition:.2s}
  .photo-btn:hover{background:var(--amber);color:var(--ink);border-color:var(--amber)}
  .close-x{position:absolute;top:14px;right:16px;z-index:6;width:38px;height:38px;border-radius:50%;border:0;background:rgba(12,10,8,.72);cursor:pointer;font-size:19px;color:var(--cream)}
  .detail-body{padding:30px 34px 36px}
  .detail-body h3{font-family:"Shippori Mincho",serif;font-weight:700;font-size:26px;letter-spacing:.03em}
  .detail-body .sub{color:var(--cream-soft);font-size:13px;margin:4px 0 18px}
  .meta-row{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:22px}
  .meta-row span{border:1px solid var(--line);border-radius:30px;padding:5px 13px;font-size:12px;color:var(--cream-soft)}
  .detail-body .desc{font-size:15px;color:var(--cream-soft);margin-bottom:26px}
  .rev-head{font-family:"Shippori Mincho",serif;font-size:17px;border-top:1px solid var(--line);padding-top:24px;margin-bottom:16px;display:flex;justify-content:space-between;align-items:center}
  .review{border:1px solid var(--line);border-radius:12px;padding:15px 17px;margin-bottom:12px;background:var(--char)}
  .review .rv-top{display:flex;justify-content:space-between;align-items:center;margin-bottom:6px}
  .review .stars{color:var(--amber);letter-spacing:2px;font-size:14px}
  .review .who{font-size:12px;color:var(--cream-soft);font-weight:500}
  .review p{font-size:13.5px;color:var(--cream)}.review .date{font-size:11px;color:var(--amber);margin-top:4px}
  .empty-rev{font-size:13px;color:var(--cream-soft);font-style:italic;padding:6px 0 16px}
  .add-rev{margin-top:8px;background:var(--char);border:1px dashed var(--line);border-radius:14px;padding:20px}
  .add-rev label{display:block;font-size:12px;letter-spacing:.06em;margin-bottom:8px;color:var(--cream-soft)}
  .add-rev input,.add-rev textarea{width:100%;border:1px solid var(--line);border-radius:9px;padding:10px 13px;font-family:inherit;font-size:13.5px;background:var(--ink-2);color:var(--cream);margin-bottom:12px;resize:vertical}
  .star-pick{display:flex;gap:4px;margin-bottom:12px;font-size:24px;cursor:pointer}
  .star-pick span{color:var(--line-2);transition:.15s}.star-pick span.lit{color:var(--amber)}

  /* ---------- Journal feed ---------- */
  .journal{background:var(--ink-2);border-top:1px solid var(--line)}
  .jfeed{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
  .jcard{border:1px solid var(--line);border-radius:16px;overflow:hidden;background:var(--ink);cursor:pointer;transition:.3s;display:flex;flex-direction:column}
  .jcard:hover{transform:translateY(-5px);box-shadow:var(--shadow);border-color:var(--line-2)}
  .jcard .vis{height:188px}
  .jcard .jbody{padding:22px 24px 24px;display:flex;flex-direction:column;flex:1}
  .jcard .jmeta{display:flex;justify-content:space-between;align-items:center;margin-bottom:11px}
  .jcard .jdate{font-family:"Cormorant Garamond",serif;font-size:13px;letter-spacing:.14em;color:var(--amber)}
  .jcard .jshop{font-size:11px;letter-spacing:.1em;color:var(--cream-soft);border:1px solid var(--line);border-radius:30px;padding:3px 11px}
  .jcard .jstars{color:var(--amber);font-size:12px;letter-spacing:1px;margin-bottom:8px}
  .jcard h4{font-family:"Shippori Mincho",serif;font-weight:700;font-size:18px;letter-spacing:.03em;margin-bottom:10px;line-height:1.5}
  .jcard p{font-size:13px;color:var(--cream-soft);line-height:1.8;flex:1}
  .jcard .jmore{margin-top:14px;font-size:12px;letter-spacing:.1em;color:var(--amber)}
  .byline{display:flex;align-items:center;gap:8px;justify-content:center;margin-top:6px;font-size:12px;color:var(--cream-soft);letter-spacing:.08em}
  .byline .pen{width:22px;height:22px;border-radius:50%;background:var(--beni);color:#fff;display:grid;place-items:center;font-family:"Shippori Mincho",serif;font-size:12px}

  /* author journal block in detail */
  .author-journal{border:1px solid rgba(224,166,74,.35);border-radius:14px;padding:20px 22px;margin-bottom:24px;
    background:linear-gradient(160deg,rgba(224,166,74,.08),rgba(224,166,74,.02))}
  .author-journal .aj-label{display:flex;align-items:center;gap:9px;font-family:"Shippori Mincho",serif;font-size:14px;letter-spacing:.08em;color:var(--amber);margin-bottom:12px}
  .author-journal .aj-label .pen{width:24px;height:24px;border-radius:50%;background:var(--beni);color:#fff;display:grid;place-items:center;font-size:13px}
  .author-journal .aj-date{font-family:"Cormorant Garamond",serif;font-size:12px;letter-spacing:.12em;color:var(--cream-soft);margin-left:auto}
  .author-journal h5{font-family:"Shippori Mincho",serif;font-weight:700;font-size:17px;margin-bottom:9px;letter-spacing:.03em}
  .author-journal .aj-stars{color:var(--amber);letter-spacing:2px;font-size:14px;margin-bottom:10px}
  .author-journal p{font-size:14px;color:var(--cream);line-height:1.9;margin-bottom:10px}
  .author-journal .aj-sign{font-size:12px;color:var(--cream-soft);text-align:right;font-style:italic}

  @media(max-width:920px){.jfeed{grid-template-columns:1fr}}

  /* ---------- Footer ---------- */
  footer{background:var(--ink-2);color:var(--cream-soft);padding:64px 0 30px;border-top:1px solid var(--line)}
  .ft-grid{display:flex;justify-content:space-between;align-items:flex-start;flex-wrap:wrap;gap:30px}
  footer b{font-family:"Shippori Mincho",serif;color:var(--cream);font-size:18px;letter-spacing:.06em}
  footer small{display:block;font-size:10px;letter-spacing:.22em;color:var(--cream-soft);margin-top:4px}
  .ft-note{font-size:12.5px;max-width:30em;line-height:1.8}
  .copy{margin-top:40px;border-top:1px solid var(--line);padding-top:20px;font-size:11px;letter-spacing:.1em;text-align:center;opacity:.6}

  .jp-only,.en-only{display:none}
  body[data-lang="ja"] .jp-only{display:revert}
  body[data-lang="en"] .en-only{display:revert}

  @media(max-width:960px){
    .gal-grid{grid-template-columns:repeat(3,1fr);grid-auto-rows:140px}
  }
  @media(max-width:920px){
    .hero .wrap{grid-template-columns:1fr}.hero-vis{height:320px;order:-1}
    .feature{grid-template-columns:1fr}.feature:nth-child(even){direction:ltr}
    .feature .vis{min-height:240px}.feature .txt{padding:38px 32px}
    .health-in{grid-template-columns:1fr;gap:34px}.health .vis{height:300px}
    .stats{grid-template-columns:repeat(2,1fr)}
    .map-layout{grid-template-columns:1fr}.list-pane{border-left:0;border-top:1px solid var(--line);max-height:440px}
    #map{height:440px}.navlinks{display:none}
    .tl::before{left:18px}.tl-item{width:100%;left:0!important;text-align:left!important;padding:0 0 40px 46px}
    .tl-item .dot{left:11.5px!important;right:auto!important}
  }
  @media(max-width:560px){.gal-grid{grid-template-columns:repeat(2,1fr)}.g-wide{grid-column:span 2}}