/* ============================================================
   船釣りJP 公開サイト CSS
   デザイン: funetsurijp-design-v1.6 トークン準拠
   ============================================================ */

:root {
  --d-bg:    #0E1822;
  --d-card:  #162030;
  --d-hover: #1C2E42;
  --d-line:  #1E3040;
  --d-line2: #2A4258;
  --d-text:  #FFFFFF;
  --d-sub:   #A8BCC8;
  --d-dim:   #5A7080;
  --l-bg:    #F5F2EE;
  --l-card:  #FFFFFF;
  --l-line:  #DDD8D2;
  --l-text:  #18252F;
  --l-sub:   #425060;
  --l-dim:   #8A9AA5;
  --red:     #C8341A;
  --red-dk:  #8C240E;
  --red-lt:  #FAECEA;
  --gold:    #A87830;
  --marine:   #1C6890;
  --marine-lt:#2B85B3;
  --seafoam:  #4A9B8E;
  --ease:     cubic-bezier(.4, 0, .2, 1);
  --t-fast:   .15s;
  --t-med:    .3s;
  --t-slow:   .5s;
  --photo-grade: saturate(.85) contrast(1.08) brightness(.97);
  --ph-hero: #2A3D50;
  --ph-card: #BEC8D0;
  --ph-txt:  #8A9AA8;
  --sh-card: 0 2px 12px rgba(14, 24, 34, .06);
  --sh-hero: 0 8px 32px rgba(14, 24, 34, .10);
  --ja:   'Shippori Mincho B1', 'Noto Serif JP', serif;
  --en:   'Cormorant Garamond', serif;
  --mono: 'JetBrains Mono', monospace;
}

*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { font-size: 16px; }
body {
  font-family: var(--ja);
  line-height: 1.85;
  -webkit-font-smoothing: antialiased;
  background: var(--l-bg);
  color: var(--l-text);
}
a { color: inherit; text-decoration: none; cursor: pointer; }
.wrap { max-width: 1320px; margin: 0 auto; padding: 0 40px; }

/* ============================================================
   HEADER
   ============================================================ */
.header {
  background: var(--d-bg);
  border-bottom: 1px solid var(--d-line);
  position: sticky;
  top: 0;
  z-index: 100;
}
.header.scrolled { box-shadow: 0 2px 16px rgba(14, 24, 34, .25); }
.header-inner {
  max-width: 1320px;
  margin: 0 auto;
  padding: 0 40px;
  height: 58px;
  display: flex;
  align-items: center;
  gap: 36px;
}
.logo { flex-shrink: 0; display: flex; align-items: baseline; gap: 8px; }
.logo-ja {
  font-family: var(--ja);
  font-size: 21px;
  font-weight: 800;
  color: #fff;
  letter-spacing: .06em;
}
.logo-en {
  font-family: var(--en);
  font-size: 12px;
  letter-spacing: .28em;
  color: var(--d-sub);
  font-style: italic;
}
nav { display: flex; flex: 1; }
.nav-a {
  font-size: 14px;
  letter-spacing: .04em;
  color: var(--d-sub);
  height: 58px;
  display: flex;
  align-items: center;
  padding: 0 14px;
  transition: color .15s;
}
.nav-a:hover { color: #fff; }
.nav-a.on { color: #fff; border-bottom: 2px solid var(--red); }
.header-meta {
  margin-left: auto;
  font-family: var(--mono);
  font-size: 11px;
  letter-spacing: .1em;
  color: var(--d-sub);
  display: flex;
  gap: 20px;
  flex-shrink: 0;
}

/* スクロール時の固定ヘッダー対策 */
h1, h2, h3, h4, section[id], article[id], div[id] { scroll-margin-top: 80px; }

/* ============================================================
   HAMBURGER / DRAWER
   ============================================================ */
.hamburger {
  display: none;
  margin-left: auto;
  width: 40px;
  height: 40px;
  padding: 0;
  background: transparent;
  border: none;
  cursor: pointer;
  position: relative;
  flex-shrink: 0;
  -webkit-tap-highlight-color: transparent;
}
.hamburger-bar {
  position: absolute;
  left: 9px;
  right: 9px;
  height: 1.5px;
  background: #fff;
  transition: transform .25s var(--ease), opacity .15s, top .25s var(--ease);
}
.hamburger-bar:nth-child(1) { top: 13px; }
.hamburger-bar:nth-child(2) { top: 19px; }
.hamburger-bar:nth-child(3) { top: 25px; }
.hamburger.is-open .hamburger-bar:nth-child(1) { top: 19px; transform: rotate(45deg); }
.hamburger.is-open .hamburger-bar:nth-child(2) { opacity: 0; }
.hamburger.is-open .hamburger-bar:nth-child(3) { top: 19px; transform: rotate(-45deg); }

.drawer-overlay {
  position: fixed;
  inset: 0;
  background: rgba(14, 24, 34, .55);
  opacity: 0;
  pointer-events: none;
  transition: opacity .25s var(--ease);
  z-index: 199;
}
.drawer-overlay.is-open { opacity: 1; pointer-events: auto; }

.drawer {
  position: fixed;
  top: 0;
  right: 0;
  bottom: 0;
  width: 82%;
  max-width: 340px;
  background: var(--d-bg);
  border-left: 1px solid var(--d-line);
  transform: translateX(100%);
  transition: transform .3s var(--ease);
  z-index: 200;
  display: flex;
  flex-direction: column;
  overflow-y: auto;
  -webkit-overflow-scrolling: touch;
}
.drawer.is-open { transform: translateX(0); }
.drawer-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 0 20px;
  height: 58px;
  border-bottom: 1px solid var(--d-line);
  flex-shrink: 0;
}
.drawer-logo { display: flex; align-items: baseline; gap: 8px; }
.drawer-logo .logo-ja { font-family: var(--ja); font-size: 18px; font-weight: 800; color: #fff; letter-spacing: .06em; }
.drawer-logo .logo-en { font-family: var(--en); font-size: 11px; letter-spacing: .24em; color: var(--d-sub); font-style: italic; }
.drawer-close {
  width: 32px;
  height: 32px;
  background: transparent;
  border: none;
  cursor: pointer;
  position: relative;
  -webkit-tap-highlight-color: transparent;
}
.drawer-close::before,
.drawer-close::after {
  content: '';
  position: absolute;
  left: 6px;
  right: 6px;
  top: 50%;
  height: 1.5px;
  background: #fff;
}
.drawer-close::before { transform: rotate(45deg); }
.drawer-close::after  { transform: rotate(-45deg); }

.drawer-nav { display: block; padding: 8px 0; flex: none; }
.drawer-nav a {
  display: block;
  padding: 16px 24px;
  font-family: var(--ja);
  font-size: 16px;
  font-weight: 500;
  color: var(--d-sub);
  letter-spacing: .04em;
  border-bottom: 1px solid var(--d-line);
  transition: background .15s, color .15s;
}
.drawer-nav a:hover { background: var(--d-hover); color: #fff; }
.drawer-nav a.on { color: #fff; border-left: 2px solid var(--red); padding-left: 22px; }

.drawer-meta {
  padding: 18px 24px;
  border-top: 1px solid var(--d-line);
  display: flex;
  flex-wrap: wrap;
  gap: 14px;
  font-family: var(--mono);
  font-size: 11px;
  letter-spacing: .1em;
  color: var(--d-sub);
}

body.drawer-open { overflow: hidden; }

/* ============================================================
   BREADCRUMB
   ============================================================ */
.breadcrumb-bar {
  background: var(--l-card);
  border-bottom: 1px solid var(--l-line);
  padding: 12px 0;
}
.bc-inner {
  max-width: 1320px;
  margin: 0 auto;
  padding: 0 40px;
  display: flex;
  align-items: center;
  gap: 8px;
  font-family: var(--mono);
  font-size: 11px;
  color: var(--l-dim);
}
.bc-link { transition: color .15s; }
.bc-link:hover { color: var(--marine); }
.bc-sep { color: var(--l-line); }
.bc-current { color: var(--l-sub); }

/* ============================================================
   ARTICLE PAGE
   ============================================================ */

/* ARTICLE LAYOUT */
.article-wrap {
  max-width: 1320px;
  margin: 0 auto;
  padding: 0 40px;
  display: grid;
  grid-template-columns: 1fr 320px;
  gap: 48px;
  padding-top: 48px;
  padding-bottom: 64px;
  align-items: start;
}
.article-main { min-width: 0; }

/* ARTICLE HEADER */
.art-header { margin-bottom: 28px; }
.art-tags { display: flex; align-items: center; gap: 8px; margin-bottom: 16px; flex-wrap: wrap; }
.tag { font-family: var(--mono); font-size: 10px; letter-spacing: .13em; text-transform: uppercase; padding: 3px 10px; }
.tag-report { background: var(--red); color: #fff; }
.tag-area { border: 1px solid var(--l-line); color: var(--l-sub); }
.tag-method { border: 1px solid var(--red-dk); color: var(--red); }
.art-title { font-family: var(--ja); font-size: 30px; font-weight: 800; line-height: 1.4; color: var(--l-text); margin-bottom: 16px; letter-spacing: .02em; }
.art-meta-row { display: flex; align-items: center; gap: 20px; padding-bottom: 20px; border-bottom: 1px solid var(--l-line); flex-wrap: wrap; }
.meta-item { font-family: var(--mono); font-size: 11px; color: var(--l-dim); letter-spacing: .1em; display: flex; align-items: center; gap: 6px; }
.meta-dot { width: 3px; height: 3px; border-radius: 50%; background: var(--l-line); }

/* HERO PHOTO */
.art-hero-photo { margin-bottom: 32px; position: relative; overflow: hidden; }
.art-hero-photo .ph-hero-img { display: flex; align-items: center; justify-content: center; }
.art-photo-caption { margin-top: 8px; font-family: var(--mono); font-size: 10px; color: var(--l-dim); letter-spacing: .08em; }

/* ARTICLE BODY */
.art-body { font-size: 16px; color: var(--l-text); line-height: 2; letter-spacing: .03em; }
.art-body p { margin-bottom: 24px; }
.art-body .art-lead { font-size: 18px; font-weight: 500; color: var(--l-text); line-height: 1.95; letter-spacing: .02em; margin-bottom: 32px; }
.art-body .art-lead::first-letter { float: left; font-family: var(--ja); font-size: 4.2em; font-weight: 700; line-height: 0.95; margin: 6px 12px 0 0; color: var(--red); padding-top: 4px; }
.art-body .art-pullquote { margin: 48px 0; padding: 24px 0 24px 28px; border-left: 3px solid var(--red); font-family: var(--ja); font-size: 22px; font-style: italic; font-weight: 500; line-height: 1.75; color: var(--l-text); letter-spacing: .04em; }
.art-body .art-pullquote-cite { display: block; margin-top: 14px; font-family: var(--mono); font-size: 11px; font-style: normal; color: var(--l-dim); letter-spacing: .15em; font-weight: 400; }
.art-body h2 { font-family: var(--ja); font-size: 20px; font-weight: 700; color: var(--l-text); margin: 36px 0 16px; padding-bottom: 12px; border-bottom: 2px solid var(--l-line); letter-spacing: .04em; }
.art-body h3 { font-family: var(--ja); font-size: 17px; font-weight: 700; color: var(--l-text); margin: 28px 0 12px; padding-left: 12px; border-left: 3px solid var(--red); letter-spacing: .03em; }
.art-body table { width: 100%; border-collapse: collapse; margin: 16px 0; }
.art-body th, .art-body td { padding: 8px 12px; border: 1px solid var(--l-line); text-align: left; }
.art-body th { background: var(--l-bg); font-weight: 600; }
.art-body ul, .art-body ol { margin: 16px 0; padding-left: 24px; }
.art-body li { margin-bottom: 8px; }
.art-inline-photo { margin: 32px 0; }
.art-inline-photo .ph { height: 280px; }
.art-inline-caption { margin-top: 8px; font-family: var(--mono); font-size: 10px; color: var(--l-dim); letter-spacing: .08em; }

/* PR NOTICE */
.pr-notice { display: inline-flex; align-items: center; gap: 10px; padding: 7px 12px 7px 8px; margin-bottom: 14px; background: var(--l-card); border: 1px solid var(--l-line); border-left: 2px solid var(--marine); }
.pr-label { font-family: var(--mono); font-size: 10px; font-weight: 500; letter-spacing: .18em; color: #fff; background: var(--marine); padding: 3px 8px; text-transform: uppercase; }
.pr-text { font-family: var(--mono); font-size: 10px; letter-spacing: .08em; color: var(--l-sub); line-height: 1.5; }
.article-ad { margin: 24px 0; text-align: center; }

/* SOURCES (E-E-A-T) */
.article-sources { margin: 40px 0 28px; padding: 22px 24px 20px; background: var(--l-card); border: 1px solid var(--l-line); border-left: 3px solid var(--l-text); }
.sources-head { display: flex; align-items: baseline; gap: 10px; margin-bottom: 16px; padding-bottom: 12px; border-bottom: 1px solid var(--l-line); }
.sources-label-en { font-family: var(--en); font-size: 12px; font-style: italic; letter-spacing: .28em; color: var(--l-dim); }
.sources-label-ja { font-family: var(--ja); font-size: 13px; font-weight: 700; letter-spacing: .08em; color: var(--l-text); }
.sources-list { list-style: none; display: flex; flex-direction: column; gap: 12px; }
.source-item { display: flex; flex-direction: column; gap: 4px; padding: 10px 0; border-bottom: 1px dashed var(--l-line); }
.source-item:last-child { border-bottom: none; padding-bottom: 0; }
.source-title { font-family: var(--ja); font-size: 14px; font-weight: 500; color: var(--l-text); line-height: 1.5; }
.source-title a { color: var(--l-text); border-bottom: 1px solid transparent; transition: border-color .15s; }
.source-title a:hover { border-bottom-color: var(--l-text); }
.source-meta { display: flex; align-items: center; flex-wrap: wrap; gap: 10px; font-family: var(--mono); font-size: 10px; letter-spacing: .08em; color: var(--l-dim); }
.source-site { color: var(--marine); }
.source-url { color: var(--l-dim); word-break: break-all; overflow-wrap: anywhere; }

/* AUTHOR (E-E-A-T) */
.article-author { margin: 28px 0 40px; padding: 22px 24px; background: var(--l-card); border: 1px solid var(--l-line); display: grid; grid-template-columns: 72px 1fr; gap: 20px; align-items: start; }
.author-avatar { width: 72px; height: 72px; border-radius: 50%; background: var(--ph-card); overflow: hidden; display: flex; align-items: center; justify-content: center; flex-shrink: 0; }
.author-avatar::before { content: 'AVATAR'; font-family: var(--mono); font-size: 8px; letter-spacing: .15em; color: var(--ph-txt); }
.author-body { display: flex; flex-direction: column; gap: 6px; }
.author-head { display: flex; align-items: baseline; gap: 12px; flex-wrap: wrap; }
.author-label { font-family: var(--mono); font-size: 9px; letter-spacing: .22em; text-transform: uppercase; color: var(--marine); }
.author-name { font-family: var(--ja); font-size: 17px; font-weight: 700; color: var(--l-text); letter-spacing: .02em; }
.author-role { font-family: var(--mono); font-size: 10px; letter-spacing: .12em; color: var(--l-dim); }
.author-desc { font-size: 13px; line-height: 1.8; color: var(--l-sub); }

/* SHARE BUTTONS */
.art-share { margin: 40px 0; padding: 24px; border: 1px solid var(--l-line); background: var(--l-card); display: flex; align-items: center; gap: 16px; flex-wrap: wrap; }
.share-label { font-family: var(--mono); font-size: 10px; letter-spacing: .18em; text-transform: uppercase; color: var(--l-dim); flex-shrink: 0; }
.share-btn { font-family: var(--mono); font-size: 11px; letter-spacing: .1em; padding: 8px 18px; border: 1px solid var(--l-line); color: var(--l-sub); cursor: pointer; transition: all .15s; background: var(--l-card); }
.share-btn:hover { border-color: var(--l-text); color: var(--l-text); }

/* ARTICLE SIDEBAR */
.article-sidebar { position: sticky; top: 80px; display: flex; flex-direction: column; gap: 24px; }

/* 船宿カード */
.boat-card { border: 1px solid var(--l-line); background: var(--l-card); overflow: hidden; }
.boat-photo { position: relative; }
.boat-photo .ph-boat { display: flex; align-items: center; justify-content: center; }
.boat-card-body { padding: 20px; }
.boat-card-label { font-family: var(--mono); font-size: 9px; letter-spacing: .2em; text-transform: uppercase; color: var(--red); margin-bottom: 8px; display: block; }
.sidebar .boat-name, .boat-card .boat-name { font-family: var(--ja); font-size: 20px; font-weight: 700; color: var(--l-text); margin-bottom: 4px; letter-spacing: .03em; }
.boat-card .boat-area { font-family: var(--mono); font-size: 10px; color: var(--l-dim); letter-spacing: .1em; margin-bottom: 16px; }
.boat-info-rows { display: flex; flex-direction: column; gap: 0; }
.boat-info-row { display: flex; justify-content: space-between; align-items: center; padding: 9px 0; border-bottom: 1px solid var(--l-line); font-size: 13px; }
.boat-info-row:last-child { border: none; }
.bi-label { color: var(--l-dim); font-size: 12px; }
.bi-val { color: var(--l-text); font-weight: 500; }
.boat-cta { margin-top: 16px; display: flex; align-items: center; justify-content: center; gap: 8px; width: 100%; padding: 13px; background: var(--red); color: #fff; font-family: var(--ja); font-size: 14px; font-weight: 700; letter-spacing: .06em; text-align: center; text-decoration: none; cursor: pointer; transition: opacity .15s; border: none; box-sizing: border-box; }
.boat-cta:hover { opacity: .85; }
.boat-cta-ext { width: 11px; height: 11px; stroke: currentColor; stroke-width: 1.5; fill: none; flex-shrink: 0; opacity: .9; }
.boat-cta-sub { margin-top: 8px; display: block; width: 100%; padding: 11px; background: var(--l-card); color: var(--l-text); font-family: var(--ja); font-size: 13px; letter-spacing: .04em; text-align: center; text-decoration: none; cursor: pointer; transition: background .15s; border: 1px solid var(--l-line); box-sizing: border-box; }
.boat-cta-sub:hover { background: var(--l-bg); }

/* 直近釣果ミニ */
.sidebar-section { border: 1px solid var(--l-line); background: var(--l-card); overflow: hidden; }
.ss-head { padding: 14px 18px; border-bottom: 1px solid var(--l-line); background: var(--l-bg); }
.ss-title { font-family: var(--mono); font-size: 10px; letter-spacing: .18em; text-transform: uppercase; color: var(--l-dim); }
.ss-body { padding: 0; }
.catch-mini { padding: 14px 18px; border-bottom: 1px solid var(--l-line); }
.catch-mini:last-child { border: none; }
.cm-date { font-family: var(--mono); font-size: 9px; color: var(--l-dim); letter-spacing: .1em; margin-bottom: 4px; }
.cm-title { font-size: 13px; color: var(--l-text); font-weight: 500; line-height: 1.5; margin-bottom: 6px; }
.cm-num { font-family: var(--mono); font-size: 16px; font-weight: 500; color: var(--gold); }
.cm-num small { font-size: 10px; color: var(--l-dim); margin-left: 2px; }

/* 釣り方メモ */
.method-info { border: 1px solid var(--l-line); background: var(--l-card); overflow: hidden; }
.method-info-head { padding: 14px 18px; border-bottom: 1px solid var(--l-line); background: var(--d-bg); }
.mi-label { font-family: var(--mono); font-size: 10px; letter-spacing: .18em; text-transform: uppercase; color: var(--d-sub); }
.method-info-body { padding: 18px; }
.mi-method-name { font-family: var(--ja); font-size: 18px; font-weight: 700; color: var(--l-text); margin-bottom: 10px; }
.mi-desc { font-size: 13px; color: var(--l-sub); line-height: 1.8; margin-bottom: 14px; }
.mi-targets { display: flex; flex-wrap: wrap; gap: 5px; }
.mi-tag { font-size: 12px; color: var(--l-sub); border: 1px solid var(--l-line); padding: 3px 10px; background: var(--l-bg); }

/* RELATED ARTICLES */
.related-sec { background: var(--l-bg); border-top: 1px solid var(--l-line); padding: 52px 0; }
.related-inner { max-width: 1320px; margin: 0 auto; padding: 0 40px; }
.related-header { display: flex; align-items: flex-end; justify-content: space-between; margin-bottom: 24px; }
.related-label-en { font-family: var(--en); font-size: 12px; letter-spacing: .3em; font-style: italic; color: var(--l-dim); display: block; margin-bottom: 6px; }
.related-label-ja { font-family: var(--ja); font-size: 22px; font-weight: 700; letter-spacing: .05em; color: var(--l-text); }
.related-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 16px; }
.rel-card { background: var(--l-card); border: 1px solid var(--l-line); overflow: hidden; transition: box-shadow .2s; }
.rel-card:hover { box-shadow: 0 4px 16px rgba(0,0,0,.08); }
.rel-card.hero { border: none; border-left: 3px solid var(--red); box-shadow: var(--sh-hero); }
.rel-card.hero:hover { box-shadow: 0 12px 40px rgba(14,24,34,.14); }
.rel-card.hero .rel-photo .ph { height: 180px; }
.rel-card.hero .rel-title { font-size: 16px; }
.rel-photo .ph { height: 120px; }
.rel-body { padding: 16px 18px; }
.rel-tags { display: flex; gap: 6px; margin-bottom: 8px; }
.rel-title { font-size: 14px; font-weight: 600; color: var(--l-text); line-height: 1.55; margin-bottom: 10px; }
.rel-meta { font-family: var(--mono); font-size: 10px; color: var(--l-dim); letter-spacing: .08em; }

/* ============================================================
   BOAT DETAIL
   ============================================================ */

/* BOAT HERO */
.boat-hero { background: var(--d-bg); border-bottom: 1px solid var(--d-line); }

.gallery { display: grid; grid-template-columns: 2fr 1fr 1fr; grid-template-rows: 240px 160px; gap: 3px; background: var(--d-bg); }
.gallery-main { grid-row: 1 / 3; position: relative; overflow: hidden; }
.gallery-ph { width: 100%; height: 100%; background: var(--ph-card); display: flex; align-items: center; justify-content: center; }
.gallery-ph::before { content: 'PHOTO'; font-family: var(--mono); font-size: 11px; letter-spacing: .2em; color: var(--ph-txt); }
.gallery-sub { position: relative; overflow: hidden; }
.gallery-last { position: relative; }

.boat-info-header { max-width: 1320px; margin: 0 auto; padding: 28px 40px 32px; display: grid; grid-template-columns: 1fr auto; gap: 32px; align-items: start; }
.boat-area-tag { font-family: var(--mono); font-size: 10px; letter-spacing: .18em; text-transform: uppercase; color: var(--red); margin-bottom: 8px; display: flex; align-items: center; gap: 10px; }
.boat-area-tag::before { content: ''; width: 16px; height: 1px; background: var(--red); display: block; }

.boat-info-header .boat-name { font-family: var(--ja); font-size: 36px; font-weight: 800; color: #fff; letter-spacing: .04em; margin-bottom: 10px; }
.boat-location { display: flex; align-items: center; gap: 20px; margin-bottom: 16px; }
.boat-loc-item { font-family: var(--mono); font-size: 11px; color: var(--d-sub); letter-spacing: .1em; display: flex; align-items: center; gap: 6px; }
.boat-loc-sep { width: 3px; height: 3px; border-radius: 50%; background: var(--d-line2); }

.boat-today-box { border: 1px solid var(--d-line2); background: var(--d-card); padding: 20px 24px; min-width: 240px; }
.today-box-label { font-family: var(--mono); font-size: 9px; letter-spacing: .2em; text-transform: uppercase; color: var(--d-dim); margin-bottom: 12px; display: flex; align-items: center; gap: 8px; }
.today-dot { width: 6px; height: 6px; border-radius: 50%; background: var(--red); animation: pulse 2s ease-in-out infinite; }
@keyframes pulse { 0%,100%{opacity:1} 50%{opacity:.4} }
.today-num { font-family: var(--mono); font-size: 40px; font-weight: 500; color: var(--gold); line-height: 1; margin-bottom: 4px; letter-spacing: -.02em; }
.today-fish { font-size: 14px; color: var(--d-sub); margin-bottom: 12px; }
.today-rows { display: flex; flex-direction: column; gap: 0; border-top: 1px solid var(--d-line); padding-top: 12px; }
.today-row { display: flex; justify-content: space-between; align-items: center; padding: 6px 0; }
.today-row-lbl { font-family: var(--mono); font-size: 10px; color: var(--d-dim); letter-spacing: .1em; }
.today-row-val { font-family: var(--mono); font-size: 12px; color: var(--d-sub); }

/* PAGE LAYOUT */
.page-layout { max-width: 1320px; margin: 0 auto; padding: 40px 40px 64px; display: grid; grid-template-columns: 1fr 300px; gap: 40px; align-items: start; }
.main-col { display: flex; flex-direction: column; gap: 32px; }

/* 釣果履歴 */
.block-title { font-family: var(--ja); font-size: 20px; font-weight: 700; color: var(--l-text); letter-spacing: .04em; padding-bottom: 12px; border-bottom: 2px solid var(--l-line); margin-bottom: 20px; }
.block-title-light { color: #fff; border-bottom-color: var(--d-line); }
.catch-list { display: flex; flex-direction: column; gap: 1px; background: var(--l-line); border: 1px solid var(--l-line); }
.catch-item { background: var(--l-card); display: grid; grid-template-columns: 100px 1fr; transition: background .15s, box-shadow .2s; }
.catch-item:hover { background: #FDFAF8; }
.catch-item:hover .ci-title { color: var(--red); }
.catch-item.hero { border-left: 3px solid var(--red); box-shadow: var(--sh-hero); margin-bottom: 6px; }
.ci-date-col { padding: 16px 14px; display: flex; flex-direction: column; align-items: center; justify-content: center; border-right: 1px solid var(--l-line); text-align: center; background: var(--l-bg); }
.ci-date-mon { font-family: var(--mono); font-size: 9px; letter-spacing: .12em; color: var(--l-dim); text-transform: uppercase; }
.ci-date-day { font-family: var(--mono); font-size: 28px; font-weight: 500; color: var(--l-text); line-height: 1; }
.ci-date-dow { font-family: var(--mono); font-size: 9px; letter-spacing: .1em; color: var(--l-dim); text-transform: uppercase; }
.ci-body { padding: 16px 20px; display: flex; flex-direction: column; }
.ci-tags { display: flex; align-items: center; gap: 6px; margin-bottom: 6px; }
.ci-tag { font-family: var(--mono); font-size: 9px; letter-spacing: .12em; color: var(--red); border: 1px solid var(--red-dk); padding: 2px 7px; }
.ci-title { font-size: 15px; font-weight: 600; color: var(--l-text); line-height: 1.5; margin-bottom: 8px; transition: color .15s; }
.ci-foot { display: flex; align-items: center; gap: 12px; }
.ci-num { font-family: var(--mono); font-size: 20px; font-weight: 500; color: var(--gold); line-height: 1; }
.ci-fish { font-size: 13px; color: var(--l-sub); }
.ci-max { font-family: var(--mono); font-size: 11px; color: var(--l-dim); margin-left: auto; letter-spacing: .08em; }
.catch-empty { padding: 32px; text-align: center; color: var(--l-dim); font-size: 14px; }

/* 船宿詳細テーブル */
.detail-table { width: 100%; border-collapse: collapse; background: var(--l-card); border: 1px solid var(--l-line); }
.detail-table tr { border-bottom: 1px solid var(--l-line); }
.detail-table tr:last-child { border-bottom: none; }
.detail-th { font-family: var(--mono); font-size: 10px; letter-spacing: .12em; text-transform: uppercase; color: var(--l-dim); padding: 14px 20px; background: var(--l-bg); width: 140px; vertical-align: top; font-weight: 400; }
.detail-td { font-size: 14px; color: var(--l-text); padding: 14px 20px; line-height: 1.7; }
.detail-tel { display: inline-flex; align-items: center; gap: 8px; font-family: var(--mono); font-size: 17px; font-weight: 600; letter-spacing: .04em; color: var(--l-text); text-decoration: none; border-bottom: 1px solid transparent; transition: border-color .15s, color .15s; }
.detail-tel:hover { border-bottom-color: var(--l-text); }
.detail-tel-icon { width: 14px; height: 14px; stroke: var(--marine); stroke-width: 1.6; fill: none; flex-shrink: 0; }
.detail-tel-hours { display: block; font-family: var(--mono); font-size: 11px; letter-spacing: .06em; color: var(--l-dim); margin-top: 4px; }
.detail-td-note { font-size: 12px; color: var(--l-dim); margin-top: 4px; }

/* SIDEBAR */
.sidebar { position: sticky; top: 80px; display: flex; flex-direction: column; gap: 20px; }

/* 公式ページCTA */
.cta-card { border: 1px solid var(--l-line); background: var(--l-card); overflow: hidden; }
.cta-body { padding: 22px 20px; }
.cta-boat-name { font-family: var(--ja); font-size: 18px; font-weight: 700; color: var(--l-text); margin-bottom: 4px; }
.cta-boat-area { font-family: var(--mono); font-size: 10px; color: var(--l-dim); letter-spacing: .1em; margin-bottom: 16px; }
.btn-cta-primary { display: flex; align-items: center; justify-content: center; gap: 8px; width: 100%; padding: 14px; background: var(--red); color: #fff; font-family: var(--ja); font-size: 15px; font-weight: 700; letter-spacing: .06em; text-align: center; text-decoration: none; cursor: pointer; border: none; transition: opacity .15s; margin-bottom: 8px; box-sizing: border-box; }
.btn-cta-primary:hover { opacity: .88; }
.btn-cta-ext { width: 12px; height: 12px; stroke: currentColor; stroke-width: 1.5; fill: none; flex-shrink: 0; opacity: .9; }
.btn-cta-tel { display: flex; align-items: center; justify-content: center; gap: 10px; width: 100%; padding: 12px; background: var(--l-card); color: var(--l-text); border: 1px solid var(--l-line); font-family: var(--ja); font-size: 14px; font-weight: 500; letter-spacing: .04em; text-align: center; text-decoration: none; cursor: pointer; transition: background .15s, border-color .15s; margin-bottom: 10px; box-sizing: border-box; }
.btn-cta-tel:hover { background: var(--l-bg); border-color: var(--l-sub); }
.btn-cta-tel-icon { width: 14px; height: 14px; stroke: var(--marine); stroke-width: 1.6; fill: none; flex-shrink: 0; }
.btn-cta-tel-num { font-family: var(--mono); font-size: 15px; font-weight: 600; letter-spacing: .04em; color: var(--l-text); }
.cta-notice { font-family: var(--mono); font-size: 10px; color: var(--l-dim); letter-spacing: .06em; text-align: center; line-height: 1.7; }

/* 基本データ */
.info-card { border: 1px solid var(--l-line); background: var(--l-card); overflow: hidden; }
.ic-head { background: var(--l-bg); padding: 12px 16px; border-bottom: 1px solid var(--l-line); }
.ic-title { font-family: var(--mono); font-size: 10px; letter-spacing: .18em; text-transform: uppercase; color: var(--l-dim); }
.ic-rows { display: flex; flex-direction: column; }
.ic-row { display: flex; justify-content: space-between; align-items: center; padding: 11px 16px; border-bottom: 1px solid var(--l-line); }
.ic-row:last-child { border: none; }
.ic-lbl { font-size: 13px; color: var(--l-dim); }
.ic-val { font-size: 13px; color: var(--l-text); font-weight: 500; font-family: var(--mono); letter-spacing: .04em; }

/* 近隣の船宿 */
.nearby-card { border: 1px solid var(--l-line); background: var(--l-card); overflow: hidden; }
.nb-head { background: var(--l-bg); padding: 12px 16px; border-bottom: 1px solid var(--l-line); }
.nb-title { font-family: var(--mono); font-size: 10px; letter-spacing: .18em; text-transform: uppercase; color: var(--l-dim); }
.nb-row { display: flex; align-items: center; gap: 10px; padding: 11px 16px; border-bottom: 1px solid var(--l-line); transition: background .12s; }
.nb-row:last-child { border: none; }
.nb-row:hover { background: var(--l-bg); }
.nb-name { font-size: 14px; color: var(--l-text); font-weight: 500; flex: 1; }
.nb-port { font-family: var(--mono); font-size: 9px; color: var(--l-dim); letter-spacing: .08em; }

/* ============================================================
   TOP PAGE
   ============================================================ */

/* HERO */
.hero { position: relative; background: var(--d-bg); overflow: hidden; }
.ph-hero { position: absolute; inset: 0; background: var(--ph-hero); opacity: .4; }
.hero-content { position: relative; z-index: 1; }
.hero-inner {
  max-width: 1320px;
  margin: 0 auto;
  padding: 64px 40px 56px;
  display: grid;
  grid-template-columns: 1fr 380px;
  gap: 48px;
  align-items: start;
}
.hero-eyebrow { display: flex; align-items: center; gap: 12px; margin-bottom: 20px; }
.eyebrow-bar { width: 28px; height: 1.5px; background: var(--red); }
.eyebrow-txt { font-family: var(--mono); font-size: 11px; letter-spacing: .16em; color: var(--d-sub); }
.hero-h1 {
  font-family: var(--ja);
  font-size: 38px;
  font-weight: 800;
  color: #fff;
  line-height: 1.5;
  letter-spacing: .05em;
  margin-bottom: 20px;
}
.hero-copy { font-size: 15px; color: var(--d-sub); line-height: 2; margin-bottom: 28px; }
.hero-stats {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 16px;
  margin-top: 20px;
}
.h-stat { text-align: center; padding: 14px 8px; border: 1px solid var(--d-line); background: rgba(22, 32, 48, .6); }
.h-num { font-family: var(--mono); font-size: 28px; font-weight: 500; color: var(--gold); line-height: 1; margin-bottom: 6px; }
.h-num small { font-size: 11px; color: var(--d-sub); margin-left: 2px; }
.h-lbl { font-family: var(--mono); font-size: 9px; letter-spacing: .14em; color: var(--d-dim); text-transform: uppercase; }

/* Hero Side (highlights) */
.hero-side { display: flex; flex-direction: column; gap: 0; }
.side-hd { padding: 10px 16px; border-bottom: 1px solid var(--d-line); }
.catch-row { padding: 16px; border-bottom: 1px solid var(--d-line); transition: background .15s; }
.catch-row:hover { background: var(--d-hover); }
.catch-row:last-child { border-bottom: none; }
.c-loc { font-family: var(--mono); font-size: 9px; letter-spacing: .12em; color: var(--d-dim); margin-bottom: 6px; text-transform: uppercase; }
.c-ttl { font-size: 14px; color: #fff; font-weight: 600; line-height: 1.6; margin-bottom: 8px; }
.c-foot { display: flex; align-items: center; gap: 12px; }
.c-num { font-family: var(--mono); font-size: 18px; font-weight: 500; color: var(--gold); }
.c-num small { font-size: 10px; color: var(--d-sub); margin-left: 2px; }
.c-tag { font-family: var(--mono); font-size: 9px; letter-spacing: .12em; color: var(--red); border: 1px solid var(--red-dk); padding: 2px 8px; }

/* DIVIDER */
.divider-seigaiha {
  height: 12px;
  background: var(--d-bg);
  background-image: radial-gradient(ellipse 24px 10px at 50% 100%, transparent 8px, var(--l-bg) 8.5px);
  background-size: 24px 12px;
}

/* SECTIONS */
.light { background: var(--l-bg); }
.dark { background: var(--d-bg); }
.sec-head {
  display: flex;
  align-items: flex-end;
  justify-content: space-between;
  margin-bottom: 28px;
}
.sec-label { font-family: var(--en); font-size: 12px; letter-spacing: .3em; font-style: italic; color: var(--l-dim); display: block; margin-bottom: 6px; }
.sec-title { font-family: var(--ja); font-size: 22px; font-weight: 700; letter-spacing: .05em; color: var(--l-text); }
.more { font-family: var(--mono); font-size: 11px; letter-spacing: .1em; color: var(--l-dim); border-bottom: 1px solid var(--l-line); padding-bottom: 2px; transition: color .15s; }
.more:hover { color: var(--l-text); }

/* AREA SECTION */
.area-sec { padding: 56px 0; }
.area-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 16px; }
.area-card { background: var(--l-card); border: 1px solid var(--l-line); overflow: hidden; transition: box-shadow .2s; cursor: pointer; }
.area-card:hover { box-shadow: 0 4px 16px rgba(0,0,0,.08); }
.area-photo { position: relative; overflow: hidden; }
.ph-area { height: 120px; background: var(--ph-card); display: flex; align-items: center; justify-content: center; }
.ph-area::before { content: 'PHOTO'; font-family: var(--mono); font-size: 10px; letter-spacing: .18em; color: var(--ph-txt); }
.area-photo-label { position: absolute; bottom: 0; left: 0; right: 0; padding: 8px 14px; background: linear-gradient(transparent, rgba(14,24,34,.7)); }
.area-photo-name { font-family: var(--ja); font-size: 16px; font-weight: 700; color: #fff; }
.area-body { padding: 14px 16px; }
.a-region { font-family: var(--mono); font-size: 10px; letter-spacing: .1em; color: var(--l-dim); margin-bottom: 6px; }
.a-species { font-size: 13px; color: var(--l-sub); margin-bottom: 8px; }
.a-foot { display: flex; align-items: center; justify-content: space-between; }
.a-status { font-family: var(--mono); font-size: 10px; letter-spacing: .1em; color: var(--l-dim); }
.a-status.good { color: var(--red); }
.a-cnt { font-family: var(--mono); font-size: 10px; color: var(--l-dim); letter-spacing: .06em; }

/* ARTICLE SECTION */
.article-sec { padding: 56px 0; border-top: 1px solid var(--l-line); }
.art-grid { display: grid; grid-template-columns: 1fr 1fr 1fr; gap: 16px; }
.art-card { background: var(--l-card); border: 1px solid var(--l-line); overflow: hidden; transition: box-shadow .2s; display: flex; flex-direction: column; }
.art-card:hover { box-shadow: 0 4px 16px rgba(0,0,0,.08); }
.art-card.hero { grid-column: 1; grid-row: 1 / 3; border: none; border-left: 3px solid var(--red); box-shadow: var(--sh-hero); }
.art-card.hero:hover { box-shadow: 0 12px 40px rgba(14,24,34,.14); }
.art-photo { position: relative; overflow: hidden; }
.ph-art-lg { height: 240px; background: var(--ph-card); display: flex; align-items: center; justify-content: center; }
.ph-art-lg::before { content: 'PHOTO'; font-family: var(--mono); font-size: 11px; letter-spacing: .2em; color: var(--ph-txt); }
.ph-art-sm { height: 120px; background: var(--ph-card); display: flex; align-items: center; justify-content: center; }
.ph-art-sm::before { content: 'PHOTO'; font-family: var(--mono); font-size: 10px; letter-spacing: .18em; color: var(--ph-txt); }
.art-badge { position: absolute; top: 12px; left: 12px; font-family: var(--mono); font-size: 9px; letter-spacing: .14em; text-transform: uppercase; padding: 3px 10px; background: var(--red); color: #fff; }
.art-body-wrap { padding: 18px 20px; display: flex; flex-direction: column; flex: 1; }
.art-meta { display: flex; gap: 12px; margin-bottom: 8px; }
.art-date { font-family: var(--mono); font-size: 10px; color: var(--l-dim); letter-spacing: .1em; }
.top-page .art-title, .article-sec .art-title { font-family: var(--ja); font-size: 16px; font-weight: 700; color: var(--l-text); line-height: 1.55; margin-bottom: 10px; }
.article-sec .art-title.sm { font-size: 14px; }
.art-catch { display: flex; align-items: center; gap: 10px; margin-bottom: 12px; }
.art-num { font-family: var(--mono); font-size: 26px; font-weight: 500; color: var(--gold); line-height: 1; }
.art-fish { display: flex; flex-direction: column; }
.art-fish-name { font-size: 14px; font-weight: 600; color: var(--l-text); }
.art-fish-note { font-family: var(--mono); font-size: 10px; color: var(--l-dim); letter-spacing: .06em; }
.art-excerpt { font-size: 13px; color: var(--l-sub); line-height: 1.8; margin-bottom: 12px; flex: 1; }
.art-footer { display: flex; justify-content: space-between; font-family: var(--mono); font-size: 10px; color: var(--l-dim); letter-spacing: .06em; border-top: 1px solid var(--l-line); padding-top: 10px; margin-top: auto; }

/* RANKING SECTION */
.rank-sec { padding: 56px 0; border-top: 1px solid var(--l-line); }
.rank-cols { display: grid; grid-template-columns: 1fr 1fr; gap: 48px; }
.rank-list { margin-top: 20px; }
.r-item { display: flex; align-items: center; gap: 14px; padding: 12px 0; border-bottom: 1px solid var(--l-line); }
.r-item:last-child { border-bottom: none; }
.r-no { font-family: var(--mono); font-size: 14px; font-weight: 500; color: var(--l-dim); width: 24px; text-align: center; }
.r-no.top { color: var(--gold); font-weight: 700; }
.r-name { font-size: 14px; font-weight: 600; color: var(--l-text); flex: 1; }
.r-tag { font-family: var(--mono); font-size: 9px; letter-spacing: .1em; color: var(--l-dim); border: 1px solid var(--l-line); padding: 2px 8px; }
.r-val { font-family: var(--mono); font-size: 11px; color: var(--l-dim); letter-spacing: .06em; }
.r-val.up { color: var(--red); }

/* ============================================================
   FOOTER
   ============================================================ */
.footer {
  background: var(--d-bg);
  border-top: 1px solid var(--d-line);
  padding: 52px 0 28px;
  margin-top: 64px;
}
.f-grid {
  display: grid;
  grid-template-columns: 2fr 1fr 1fr 1fr;
  gap: 48px;
  padding-bottom: 36px;
  border-bottom: 1px solid var(--d-line);
  margin-bottom: 20px;
}
.f-desc {
  font-size: 14px;
  color: var(--d-sub);
  line-height: 2;
  margin-top: 14px;
}
.f-col-lbl {
  font-family: var(--mono);
  font-size: 10px;
  letter-spacing: .2em;
  text-transform: uppercase;
  color: var(--d-dim);
  display: block;
  margin-bottom: 14px;
}
.f-links {
  list-style: none;
  display: flex;
  flex-direction: column;
  gap: 10px;
}
.f-links a {
  font-size: 14px;
  color: var(--d-sub);
  transition: color .12s;
}
.f-links a:hover { color: #fff; }
.f-legal {
  max-width: 1320px;
  margin: 0 auto;
  padding: 0 40px 8px;
  display: flex;
  flex-wrap: wrap;
  gap: 18px;
  border-top: 1px solid var(--d-line);
  padding-top: 16px;
  margin-top: 16px;
}
.f-legal a {
  font-family: var(--mono);
  font-size: 10px;
  letter-spacing: .1em;
  color: var(--d-dim);
  transition: color .12s;
}
.f-legal a:hover { color: var(--d-sub); }
.f-bottom {
  display: flex;
  justify-content: space-between;
}
.f-copy {
  font-family: var(--mono);
  font-size: 10px;
  letter-spacing: .12em;
  color: var(--d-dim);
}

/* ============================================================
   EMPTY STATE
   ============================================================ */
.empty-state {
  padding: 40px 24px;
  text-align: center;
  color: var(--l-dim);
  font-size: 14px;
  line-height: 1.9;
  border: 1px dashed var(--l-line);
  background: var(--l-card);
}
.empty-state-dark {
  padding: 28px 20px;
  text-align: center;
  background: var(--d-bg);
  border: 1px solid var(--d-line);
}
.empty-state-dark p {
  font-size: 13px;
  color: var(--d-sub);
  line-height: 1.8;
}

/* ============================================================
   TICKER
   ============================================================ */
.ticker { background: var(--d-bg); border-bottom: 1px solid var(--d-line); display: flex; height: 32px; align-items: center; overflow: hidden; }
.ticker-tag { flex-shrink: 0; display: flex; align-items: center; gap: 7px; padding: 0 16px; border-right: 1px solid var(--d-line); height: 100%; }
.ticker .live-dot { width: 6px; height: 6px; border-radius: 50%; background: var(--red); animation: ticker-blink 2s ease-in-out infinite; }
@keyframes ticker-blink { 0%,100%{opacity:1} 50%{opacity:.3} }
.ticker-scroll { overflow: hidden; flex: 1; }
.ticker-text { font-size: 12px; letter-spacing: .04em; color: var(--d-sub); white-space: nowrap; display: inline-block; padding-left: 40px; animation: run 40s linear infinite; }
.ticker-empty { font-size: 12px; letter-spacing: .04em; color: var(--d-dim); padding: 0 16px; }
@keyframes run { 0%{transform:translateX(0)} 100%{transform:translateX(-50%)} }

/* ============================================================
   CONDITIONS SECTION
   ============================================================ */
.cond-sec { background: var(--d-card); border-top: 1px solid var(--d-line); border-bottom: 1px solid var(--d-line); padding: 60px 0; }
.cond-sec .sec-label { color: var(--d-dim); }
.cond-sec .sec-title { color: #fff; }
.cond-layout { display: grid; grid-template-columns: 210px 1fr; gap: 44px; align-items: start; }
.tide-panel { background: var(--d-bg); border: 1px solid var(--d-line); padding: 24px 20px; }
.tide-date { font-family: var(--mono); font-size: 10px; color: var(--d-dim); letter-spacing: .18em; margin-bottom: 8px; }
.tide-type { font-family: var(--ja); font-size: 26px; font-weight: 700; color: #fff; margin-bottom: 18px; }
.t-row { display: flex; justify-content: space-between; align-items: center; padding: 9px 0; border-bottom: 1px solid var(--d-line); }
.t-row:last-of-type { border: none; }
.t-lbl { font-family: var(--mono); font-size: 10px; color: var(--d-sub); letter-spacing: .1em; }
.t-val { font-family: var(--mono); font-size: 14px; font-weight: 500; color: #fff; }
.tide-note { margin-top: 14px; padding: 10px 12px; border-left: 2px solid var(--d-line2); }
.tide-note p { font-size: 12px; color: var(--d-sub); line-height: 1.8; }
.method-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 1px; background: var(--d-line); border: 1px solid var(--d-line); }
.m-card { background: var(--d-bg); padding: 22px 20px; }
.m-card-head { display: flex; justify-content: space-between; align-items: baseline; margin-bottom: 12px; }
.m-name { font-family: var(--ja); font-size: 16px; font-weight: 700; color: #fff; letter-spacing: .04em; }
.m-score { font-family: var(--mono); font-size: 18px; font-weight: 500; line-height: 1; letter-spacing: -.02em; }
.m-score.ok { color: var(--red); }
.m-score.mid { color: var(--marine-lt); }
.m-score small { font-size: 10px; color: var(--d-dim); margin-left: 1px; }
.m-dots { font-family: var(--mono); font-size: 14px; letter-spacing: 2px; margin-bottom: 12px; line-height: 1; }
.m-dots .on.red { color: var(--red); }
.m-dots .on.marine { color: var(--marine-lt); }
.m-dots .off { color: var(--d-dim); opacity: .4; }
.m-cond { font-size: 13px; color: var(--d-sub); margin-bottom: 5px; }
.m-cond.ok { color: var(--red); }
.m-cond.mid { color: var(--marine-lt); }
.m-area { font-family: var(--mono); font-size: 10px; color: var(--d-dim); letter-spacing: .08em; }
.tide-chart { margin-top: 4px; padding: 20px 0 14px; border-top: 1px solid rgba(255,255,255,.15); border-bottom: 1px solid rgba(255,255,255,.15); }
.tide-chart-head { display: flex; justify-content: space-between; align-items: baseline; margin-bottom: 8px; }
.tide-chart-title { font-family: var(--en); font-size: 11px; font-style: italic; letter-spacing: .2em; color: var(--d-sub); }
.tide-chart-meta { font-family: var(--mono); font-size: 10px; color: var(--d-dim); letter-spacing: .15em; }

/* ============================================================
   404 ERROR PAGE
   ============================================================ */
.error-page { text-align: center; padding: 80px 40px; min-height: 50vh; display: flex; flex-direction: column; align-items: center; justify-content: center; }
.error-code { font-family: var(--mono); font-size: 96px; font-weight: 500; color: var(--l-line); line-height: 1; margin-bottom: 16px; letter-spacing: -.04em; }
.error-title { font-family: var(--ja); font-size: 24px; font-weight: 700; color: var(--l-text); margin-bottom: 12px; }
.error-desc { font-size: 15px; color: var(--l-sub); line-height: 1.8; margin-bottom: 32px; }
.error-link { font-family: var(--mono); font-size: 12px; letter-spacing: .1em; color: var(--marine); border: 1px solid var(--marine); padding: 10px 28px; transition: background .15s, color .15s; }
.error-link:hover { background: var(--marine); color: #fff; }

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media (max-width: 1024px) {
  .hamburger { display: block; }
  .header-meta { display: none; }
  nav { display: none; }
  body { overflow-x: hidden; }
  .wrap, .header-inner, .f-grid {
    padding-left: 24px;
    padding-right: 24px;
  }
  .f-grid { grid-template-columns: repeat(2, 1fr); gap: 32px; }
  .article-wrap {
    max-width: 100%;
  }
  .article-wrap, .page-layout {
    grid-template-columns: 1fr !important;
    gap: 32px !important;
  }
  .article-sidebar { position: static; }
  .sidebar { position: static; }
  .boat-info-header { grid-template-columns: 1fr !important; padding: 24px; }
  .gallery { grid-template-columns: 1fr !important; grid-template-rows: auto !important; }
  .gallery > * { grid-row: auto !important; grid-column: auto !important; }
  .gallery-main .gallery-ph { height: 240px; }
  .gallery-sub, .gallery-last { display: none; }
  aside { border-left: none !important; padding-left: 0 !important; }
  .hero-inner { grid-template-columns: 1fr !important; }
  .hero-side { display: none; }
  .area-grid { grid-template-columns: repeat(2, 1fr) !important; }
  .art-grid { grid-template-columns: 1fr !important; }
  .art-card.hero { grid-column: 1; grid-row: auto; }
  .rank-cols { grid-template-columns: 1fr !important; gap: 32px !important; }
  .cond-layout { grid-template-columns: 1fr; }
  .method-grid { grid-template-columns: repeat(2, 1fr); }
  table { display: block; overflow-x: auto; -webkit-overflow-scrolling: touch; max-width: 100%; }
  img, svg, video, iframe { max-width: 100% !important; height: auto; }
  * { min-width: 0; }
}
@media (max-width: 768px) {
  html { font-size: 15px; }
  .wrap, .header-inner, .f-grid {
    padding-left: 16px;
    padding-right: 16px;
  }
  .f-grid { grid-template-columns: 1fr; gap: 24px; }
  .f-legal { padding: 16px 16px 8px; gap: 12px; }
  .bc-inner { padding: 0 16px; }
  .article-wrap { padding: 0 16px; padding-top: 32px; padding-bottom: 48px; }
  .art-title { font-size: 24px !important; }
  .art-body { font-size: 15px; }
  .art-body .art-lead { font-size: 16px; }
  .art-body .art-pullquote { font-size: 18px; padding-left: 18px; margin: 32px 0; }
  .related-grid { grid-template-columns: 1fr !important; }
  .art-share { flex-wrap: wrap; }
  .article-author { grid-template-columns: 56px 1fr; gap: 14px; padding: 18px; }
  .author-avatar { width: 56px; height: 56px; }
  .author-name { font-size: 15px; }
  .page-layout { padding: 24px 16px 48px; }
  .boat-info-header { padding: 20px 16px; }
  .boat-info-header .boat-name { font-size: 28px; }
  .catch-item { grid-template-columns: 80px 1fr; }
  .ci-date-day { font-size: 22px; }
  .header-meta span:not(:last-child) { display: none; }
  .hero-inner { padding: 40px 16px 36px !important; }
  .hero-h1 { font-size: 28px !important; }
  .hero-stats { grid-template-columns: repeat(3, 1fr); gap: 8px; }
  .h-num { font-size: 22px; }
  .area-grid { grid-template-columns: 1fr !important; }
  .method-grid { grid-template-columns: 1fr; }
  .tide-chart-head { flex-direction: column; gap: 4px; }
  .area-sec, .article-sec, .rank-sec, .cond-sec { padding: 36px 0 !important; }
  .ticker { height: 28px; }
  .ticker-tag { padding: 0 12px; }
  .error-code { font-size: 64px; }
  .error-page { padding: 60px 16px; }
}
@media (max-width: 480px) {
  .f-bottom { flex-direction: column; gap: 8px; }
}

/* ============================================================
   PREFECTURE PAGE
   ============================================================ */
.pref-hero { background: var(--d-bg); border-bottom: 1px solid var(--d-line); padding: 48px 0 40px; }
.pref-hero-inner { max-width: 1320px; margin: 0 auto; padding: 0 40px; }
.pref-name { font-family: var(--ja); font-size: 32px; font-weight: 800; color: #fff; letter-spacing: .04em; margin-bottom: 14px; }
.pref-desc { font-size: 15px; color: var(--d-sub); line-height: 2; margin-bottom: 24px; }
.pref-seas { display: flex; align-items: center; gap: 10px; flex-wrap: wrap; margin-bottom: 28px; }
.pref-seas-label { font-family: var(--mono); font-size: 10px; letter-spacing: .14em; color: var(--d-dim); text-transform: uppercase; }
.sea-badge { font-family: var(--mono); font-size: 11px; letter-spacing: .06em; color: var(--d-sub); padding: 5px 14px; border: 1px solid var(--d-line2); }
.sea-badge-link { transition: border-color .15s, color .15s; }
.sea-badge-link:hover { border-color: var(--d-sub); color: #fff; }
.pref-stats { display: grid; grid-template-columns: repeat(3, 1fr); gap: 16px; }
.ps { text-align: center; padding: 16px 12px; border: 1px solid var(--d-line); background: rgba(22, 32, 48, .6); }
.ps-label { font-family: var(--mono); font-size: 9px; letter-spacing: .14em; color: var(--d-dim); text-transform: uppercase; margin-bottom: 8px; }
.ps-val { font-family: var(--mono); font-size: 28px; font-weight: 500; color: var(--gold); line-height: 1; margin-bottom: 6px; }
.ps-val small { font-size: 11px; color: var(--d-sub); margin-left: 2px; }
.ps-sub { font-family: var(--mono); font-size: 10px; color: var(--d-dim); letter-spacing: .08em; }
.ps-sub.good { color: var(--seafoam); }

/* PORT GRID */
.port-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 16px; margin-bottom: 32px; }
.port-card { background: var(--l-card); border: 1px solid var(--l-line); overflow: hidden; transition: box-shadow .2s; display: block; }
.port-card:hover { box-shadow: 0 4px 16px rgba(0,0,0,.08); }
.port-card.hero { grid-column: 1 / -1; border-left: 3px solid var(--red); box-shadow: var(--sh-hero); }
.pc-head { padding: 16px 20px 12px; display: flex; justify-content: space-between; align-items: flex-start; }
.pc-name { font-family: var(--ja); font-size: 18px; font-weight: 700; color: var(--l-text); margin-bottom: 4px; }
.pc-city { font-family: var(--mono); font-size: 10px; color: var(--l-dim); letter-spacing: .08em; }
.pc-boat-count { font-family: var(--mono); font-size: 11px; color: var(--l-dim); letter-spacing: .06em; white-space: nowrap; }
.pc-today { padding: 0 20px 14px; }
.pc-today-label { font-family: var(--mono); font-size: 9px; letter-spacing: .14em; color: var(--l-dim); margin-bottom: 8px; display: flex; align-items: center; gap: 6px; }
.live-dot { width: 6px; height: 6px; border-radius: 50%; background: var(--red); animation: pulse 2s ease-in-out infinite; }
.pc-catch-rows { display: flex; flex-direction: column; gap: 4px; }
.pc-catch-row { display: flex; align-items: center; gap: 8px; }
.pc-method { font-family: var(--mono); font-size: 10px; color: var(--red); letter-spacing: .06em; }
.pc-num { font-family: var(--mono); font-size: 18px; font-weight: 500; color: var(--gold); }
.pc-fish { font-size: 12px; color: var(--l-sub); }
.pc-more { font-family: var(--mono); font-size: 10px; color: var(--l-dim); }
.pc-no-report { font-size: 12px; color: var(--l-dim); }
.pc-methods { padding: 0 20px 16px; display: flex; gap: 6px; flex-wrap: wrap; }
.pc-method-tag { font-family: var(--mono); font-size: 10px; letter-spacing: .06em; color: var(--l-dim); padding: 2px 8px; border: 1px solid var(--l-line); }
.pc-method-tag.key { color: var(--red); border-color: var(--red-dk); }

/* CATCH ROW (prefecture catch list) */
.catch-row-item { display: grid; grid-template-columns: 60px 1fr auto; background: var(--l-card); border-bottom: 1px solid var(--l-line); padding: 14px 20px; transition: background .15s; }
.catch-row-item:hover { background: #FDFAF8; }
.cr-date { font-family: var(--mono); font-size: 12px; color: var(--l-dim); letter-spacing: .06em; }
.cr-body { display: flex; flex-direction: column; gap: 4px; }
.cr-tags { display: flex; gap: 6px; }
.cr-tag { font-family: var(--mono); font-size: 9px; letter-spacing: .1em; padding: 2px 7px; }
.cr-tag-method { color: var(--red); border: 1px solid var(--red-dk); }
.cr-tag-port { color: var(--l-dim); border: 1px solid var(--l-line); }
.cr-title { font-size: 14px; color: var(--l-text); font-weight: 500; line-height: 1.5; }
.cr-right { text-align: right; display: flex; flex-direction: column; align-items: flex-end; gap: 2px; }
.cr-num { font-family: var(--mono); font-size: 22px; font-weight: 500; color: var(--gold); line-height: 1; }
.cr-fish { font-size: 11px; color: var(--l-sub); }
.cr-boat { font-family: var(--mono); font-size: 10px; color: var(--l-dim); letter-spacing: .06em; }

/* SEA LINKS (sidebar) */
.sea-links-card { border: 1px solid var(--l-line); background: var(--l-card); overflow: hidden; }
.sl-head { padding: 12px 16px; border-bottom: 1px solid var(--l-line); background: var(--l-bg); }
.sl-title { font-family: var(--mono); font-size: 10px; letter-spacing: .18em; text-transform: uppercase; color: var(--l-dim); }
.sl-body { display: flex; flex-direction: column; }
.sl-link { display: flex; justify-content: space-between; align-items: center; padding: 12px 16px; border-bottom: 1px solid var(--l-line); transition: background .12s; }
.sl-link:last-child { border-bottom: none; }
.sl-link:hover { background: var(--l-bg); }
.sl-name { font-size: 14px; color: var(--l-text); font-weight: 500; }
.sl-desc { font-family: var(--mono); font-size: 10px; color: var(--l-dim); letter-spacing: .06em; margin-top: 2px; }
.sl-arrow { font-family: var(--mono); font-size: 14px; color: var(--l-dim); }

/* METHODS BAR CHART (sidebar) */
.methods-card { border: 1px solid var(--l-line); background: var(--l-card); overflow: hidden; }
.mc-head { padding: 12px 16px; border-bottom: 1px solid var(--l-line); background: var(--l-bg); }
.mc-title { font-family: var(--mono); font-size: 10px; letter-spacing: .18em; text-transform: uppercase; color: var(--l-dim); }
.mc-body { padding: 12px 16px; display: flex; flex-direction: column; gap: 10px; }
.mc-row { display: grid; grid-template-columns: 80px 1fr 40px; align-items: center; gap: 8px; }
.mc-name { font-size: 13px; color: var(--l-text); }
.mc-bar-wrap { height: 6px; background: var(--l-bg); border-radius: 3px; overflow: hidden; }
.mc-bar { height: 100%; background: var(--red); border-radius: 3px; }
.mc-cnt { font-family: var(--mono); font-size: 11px; color: var(--l-dim); text-align: right; }

/* NEARBY PREFECTURE (sidebar) */
.nearby-pref-card { border: 1px solid var(--l-line); background: var(--l-card); overflow: hidden; }
.np-head { padding: 12px 16px; border-bottom: 1px solid var(--l-line); background: var(--l-bg); }
.np-title { font-family: var(--mono); font-size: 10px; letter-spacing: .18em; text-transform: uppercase; color: var(--l-dim); }
.np-row { display: flex; justify-content: space-between; align-items: center; padding: 11px 16px; border-bottom: 1px solid var(--l-line); transition: background .12s; }
.np-row:last-child { border-bottom: none; }
.np-row:hover { background: var(--l-bg); }
.np-name { font-size: 14px; color: var(--l-text); font-weight: 500; }
.np-cnt { font-family: var(--mono); font-size: 11px; color: var(--l-dim); }
.np-arrow { font-family: var(--mono); font-size: 14px; color: var(--l-dim); }

/* ============================================================
   PORT PAGE
   ============================================================ */
.port-hero { background: var(--d-bg); border-bottom: 1px solid var(--d-line); padding: 48px 0 40px; }
.port-hero-inner { max-width: 1320px; margin: 0 auto; padding: 0 40px; }
.port-title-row { display: grid; grid-template-columns: 1fr auto; gap: 32px; align-items: start; margin-bottom: 28px; }
.port-name { font-family: var(--ja); font-size: 32px; font-weight: 800; color: #fff; letter-spacing: .04em; margin-bottom: 10px; }
.port-location { font-family: var(--mono); font-size: 11px; color: var(--d-sub); letter-spacing: .1em; margin-bottom: 12px; }
.port-seo-text { font-size: 14px; color: var(--d-sub); line-height: 2; }
.port-live-box { border: 1px solid var(--d-line2); background: var(--d-card); padding: 20px 24px; min-width: 160px; text-align: center; }
.plb-label { font-family: var(--mono); font-size: 9px; letter-spacing: .2em; text-transform: uppercase; color: var(--d-dim); margin-bottom: 8px; display: flex; align-items: center; justify-content: center; gap: 6px; }
.plb-num { font-family: var(--mono); font-size: 40px; font-weight: 500; color: var(--gold); line-height: 1; margin-bottom: 4px; }
.plb-unit { font-size: 13px; color: var(--d-sub); }
.plb-rows { border-top: 1px solid var(--d-line); padding-top: 10px; margin-top: 10px; }
.plb-row { display: flex; justify-content: space-between; padding: 4px 0; font-family: var(--mono); font-size: 10px; }
.plb-lbl { color: var(--d-dim); }
.plb-val { color: var(--d-sub); }
.port-stats { display: grid; grid-template-columns: repeat(auto-fit, minmax(140px, 1fr)); gap: 16px; }

/* SEO TEXT BLOCK */
.seo-text-block { border: 1px solid var(--l-line); background: var(--l-card); padding: 28px 32px; }
.seo-text { font-size: 15px; color: var(--l-sub); line-height: 2; letter-spacing: .03em; }

/* BOATS SIDEBAR */
.boats-card { border: 1px solid var(--l-line); background: var(--l-card); overflow: hidden; }
.sc-head { padding: 12px 16px; border-bottom: 1px solid var(--l-line); background: var(--l-bg); display: flex; justify-content: space-between; align-items: center; }
.sc-title { font-family: var(--mono); font-size: 10px; letter-spacing: .18em; text-transform: uppercase; color: var(--l-dim); }
.sc-more { font-family: var(--mono); font-size: 10px; color: var(--l-dim); letter-spacing: .06em; }
.boat-row { display: flex; align-items: center; gap: 10px; padding: 10px 16px; border-bottom: 1px solid var(--l-line); }
.boat-row:last-child { border-bottom: none; }
.br-num { font-family: var(--mono); font-size: 12px; color: var(--l-dim); width: 20px; text-align: center; }
.br-num.top { color: var(--gold); font-weight: 700; }
.br-name { font-size: 14px; color: var(--l-text); font-weight: 500; flex: 1; }
.br-name a { transition: color .15s; }
.br-name a:hover { color: var(--marine); }
.br-method { font-family: var(--mono); font-size: 10px; color: var(--l-dim); }
.br-status { font-family: var(--mono); font-size: 10px; letter-spacing: .06em; }
.br-status.good { color: var(--seafoam); }

/* METHOD BAR (sidebar) */
.methods-body { padding: 12px 16px; display: flex; flex-direction: column; gap: 10px; }
.method-row { display: grid; grid-template-columns: 80px 1fr 40px; align-items: center; gap: 8px; }
.mr-name { font-size: 13px; color: var(--l-text); }
.mr-bar-wrap { height: 6px; background: var(--l-bg); border-radius: 3px; overflow: hidden; }
.mr-bar { height: 100%; background: var(--red); border-radius: 3px; }
.mr-cnt { font-family: var(--mono); font-size: 11px; color: var(--l-dim); text-align: right; }

/* NEARBY PORTS (sidebar) */
.nearby-ports-card { border: 1px solid var(--l-line); background: var(--l-card); overflow: hidden; }

/* BREADCRUMB ALT PATH */
.bc-alt { font-family: var(--mono); font-size: 10px; color: var(--l-dim); margin-left: 12px; letter-spacing: .08em; }
.bc-alt-link { color: var(--l-dim); transition: color .15s; }
.bc-alt-link:hover { color: var(--marine); }

/* BOAT NAME IN CATCH ITEM */
.ci-boat-name { font-family: var(--mono); font-size: 10px; color: var(--l-dim); letter-spacing: .06em; margin-top: 4px; }

/* ============================================================
   AREA (BAY) PAGE
   ============================================================ */
.area-hero { background: var(--d-bg); border-bottom: 1px solid var(--d-line); padding: 48px 0 40px; }
.area-hero-inner { max-width: 1320px; margin: 0 auto; padding: 0 40px; }
.area-title-row { display: flex; justify-content: space-between; align-items: flex-start; margin-bottom: 28px; }
.area-title-left { flex: 1; }
.area-name { font-family: var(--ja); font-size: 32px; font-weight: 800; color: #fff; letter-spacing: .04em; margin-bottom: 10px; }
.area-sub-name { font-family: var(--mono); font-size: 11px; color: var(--d-sub); letter-spacing: .1em; }
.area-stats { display: grid; grid-template-columns: repeat(auto-fit, minmax(140px, 1fr)); gap: 16px; }
.a-stat { text-align: center; padding: 16px 12px; border: 1px solid var(--d-line); background: rgba(22, 32, 48, .6); }
.a-stat-label { font-family: var(--mono); font-size: 9px; letter-spacing: .14em; color: var(--d-dim); text-transform: uppercase; margin-bottom: 8px; }
.a-stat-val { font-family: var(--mono); font-size: 28px; font-weight: 500; color: var(--gold); line-height: 1; margin-bottom: 6px; }
.a-stat-val small { font-size: 11px; color: var(--d-sub); margin-left: 2px; }
.a-stat-sub { font-family: var(--mono); font-size: 10px; color: var(--d-dim); letter-spacing: .08em; }
.a-stat-sub.good { color: var(--seafoam); }

/* REPORT CARD (area page) */
.report-list { display: flex; flex-direction: column; gap: 1px; background: var(--l-line); border: 1px solid var(--l-line); }
.report-card { background: var(--l-card); display: grid; grid-template-columns: 160px 1fr; transition: background .15s, box-shadow .2s; }
.report-card:hover { background: #FDFAF8; }
.report-card.hero { border-left: 3px solid var(--red); box-shadow: var(--sh-hero); margin-bottom: 6px; }
.rc-thumb { position: relative; overflow: hidden; }
.rc-thumb .ph { width: 100%; height: 100%; min-height: 110px; background: var(--ph-card); display: flex; align-items: center; justify-content: center; }
.rc-thumb .ph::before { content: 'PHOTO'; font-family: var(--mono); font-size: 9px; letter-spacing: .18em; color: var(--ph-txt); }
.rc-body { padding: 16px 20px; display: flex; flex-direction: column; }
.rc-tags { display: flex; align-items: center; gap: 6px; margin-bottom: 6px; flex-wrap: wrap; }
.rc-tag { font-family: var(--mono); font-size: 9px; letter-spacing: .1em; padding: 2px 7px; }
.rc-tag-method { color: var(--red); border: 1px solid var(--red-dk); }
.rc-tag-area { color: var(--l-dim); border: 1px solid var(--l-line); }
.rc-date { font-family: var(--mono); font-size: 10px; color: var(--l-dim); letter-spacing: .06em; }
.rc-title { font-size: 15px; font-weight: 600; color: var(--l-text); line-height: 1.5; margin-bottom: 8px; }
.rc-foot { display: flex; align-items: center; justify-content: space-between; margin-top: auto; }
.rc-catch { display: flex; align-items: center; gap: 6px; }
.rc-num { font-family: var(--mono); font-size: 20px; font-weight: 500; color: var(--gold); line-height: 1; }
.rc-fish { font-size: 13px; color: var(--l-sub); }
.rc-boat { font-family: var(--mono); font-size: 10px; color: var(--l-dim); letter-spacing: .06em; }

/* ============================================================
   BOAT LIST PAGE
   ============================================================ */
.boat-list { display: flex; flex-direction: column; gap: 1px; background: var(--l-line); border: 1px solid var(--l-line); }
.boat-card { background: var(--l-card); display: grid; grid-template-columns: 160px 1fr auto; transition: background .15s; cursor: pointer; text-decoration: none; color: inherit; }
.boat-card:hover { background: #FDFAF8; }
.boat-card.hero { grid-template-columns: 220px 1fr auto; border-left: 3px solid var(--red); box-shadow: var(--sh-hero); }
.bc-photo { position: relative; overflow: hidden; }
.bc-photo .ph { width: 100%; height: 100%; min-height: 100px; background: var(--ph-card); display: flex; align-items: center; justify-content: center; }
.bc-photo .ph::before { content: 'PHOTO'; font-family: var(--mono); font-size: 9px; letter-spacing: .18em; color: var(--ph-txt); }
.bc-body { padding: 16px 20px; display: flex; flex-direction: column; border-left: 1px solid var(--l-line); }
.bc-location { font-family: var(--mono); font-size: 10px; letter-spacing: .1em; color: var(--l-dim); text-transform: uppercase; margin-bottom: 4px; }
.bc-name { font-size: 17px; font-weight: 700; letter-spacing: .03em; margin-bottom: 6px; color: var(--l-text); transition: color var(--t-fast) var(--ease); }
.boat-card:hover .bc-name { color: var(--red); }
.bc-methods { display: flex; gap: 5px; flex-wrap: wrap; margin-top: auto; }
.bc-method-tag { font-family: var(--mono); font-size: 10px; letter-spacing: .08em; padding: 2px 8px; border: 1px solid var(--l-line); color: var(--l-sub); }
.bc-method-tag.primary { color: var(--red); border-color: var(--red-dk); }
.bc-foot { display: flex; align-items: center; gap: 12px; margin-top: 8px; padding-top: 8px; border-top: 1px solid var(--l-line); }
.bc-foot-item { font-family: var(--mono); font-size: 10px; color: var(--l-dim); letter-spacing: .06em; }
.bc-today { padding: 16px; min-width: 140px; display: flex; flex-direction: column; align-items: center; justify-content: center; border-left: 1px solid var(--l-line); }
.bc-today-label { font-family: var(--mono); font-size: 9px; letter-spacing: .12em; color: var(--l-dim); text-transform: uppercase; margin-bottom: 4px; }
.bc-today-num { font-family: var(--mono); font-size: 24px; font-weight: 500; color: var(--gold); line-height: 1; }
.bc-today-fish { font-size: 11px; color: var(--l-sub); margin-top: 4px; }

/* PAGE HERO (shared for list pages) */
.page-hero { background: var(--d-bg); padding: 48px 0 40px; }
.page-hero-inner { max-width: 1320px; margin: 0 auto; padding: 0 40px; display: grid; grid-template-columns: 1.3fr 1fr; gap: 48px; align-items: center; }
.page-hero-eyebrow { display: flex; align-items: center; gap: 10px; margin-bottom: 12px; }
.eyebrow-bar { width: 28px; height: 2px; background: var(--red); }
.eyebrow-txt { font-family: var(--mono); font-size: 10px; letter-spacing: .2em; color: var(--d-dim); text-transform: uppercase; }
.page-title { font-size: 36px; font-weight: 800; color: #fff; line-height: 1.25; margin-bottom: 10px; }
.page-desc { font-size: 14px; color: var(--d-sub); line-height: 1.8; }
.hero-stats { display: grid; grid-template-columns: repeat(auto-fit, minmax(100px, 1fr)); gap: 1px; background: var(--d-line); }
.hs-cell { padding: 18px 16px; background: var(--d-bg); }
.hs-lbl { font-family: var(--mono); font-size: 9px; letter-spacing: .12em; color: var(--d-dim); text-transform: uppercase; margin-bottom: 6px; }
.hs-val { font-family: var(--mono); font-size: 24px; font-weight: 500; color: #fff; line-height: 1; }
.hs-sub { font-size: 11px; color: var(--d-sub); margin-top: 4px; }

/* DIVIDER SEIGAIHA */
.divider-seigaiha { height: 32px; background: var(--d-bg); position: relative; overflow: hidden; }
.divider-seigaiha::before { content: ''; position: absolute; bottom: 0; left: 0; right: 0; height: 24px; background: var(--l-bg); border-radius: 50% 50% 0 0 / 100% 100% 0 0; }

/* PAGINATION */
.pagination { display: flex; gap: 0; margin-top: 28px; justify-content: center; }
.page-btn { font-family: var(--mono); font-size: 13px; width: 40px; height: 40px; display: flex; align-items: center; justify-content: center; border: 1px solid var(--l-line); background: var(--l-card); color: var(--l-text); text-decoration: none; transition: background var(--t-fast) var(--ease); }
.page-btn:hover { background: var(--l-bg); }
.page-btn.current { background: var(--red); color: #fff; border-color: var(--red); }
.page-btn.disabled { color: var(--l-line); pointer-events: none; }

/* ============================================================
   METHOD DETAIL PAGE
   ============================================================ */
.method-hero { background: var(--d-bg); padding: 48px 0 0; }
.method-hero-inner { max-width: 1320px; margin: 0 auto; padding: 0 40px; }
.method-title-row { display: grid; grid-template-columns: 1fr 320px; gap: 48px; }
.method-title-left { padding-bottom: 32px; }
.method-en { font-family: var(--en); font-size: 12px; font-style: italic; letter-spacing: .3em; color: var(--d-dim); margin-bottom: 8px; }
.method-name { font-size: 38px; font-weight: 800; color: #fff; line-height: 1.2; margin-bottom: 12px; }
.method-desc { font-size: 14px; color: var(--d-sub); line-height: 1.9; }
.method-targets { display: flex; align-items: center; gap: 10px; margin-top: 16px; flex-wrap: wrap; }
.target-label { font-family: var(--mono); font-size: 9px; letter-spacing: .12em; color: var(--d-dim); text-transform: uppercase; }
.target-fish { font-size: 13px; color: var(--d-sub); border: 1px solid var(--d-line); padding: 4px 12px; background: rgba(255,255,255,.03); }
.method-targets-label { font-family: var(--mono); font-size: 9px; letter-spacing: .12em; color: var(--d-dim); text-transform: uppercase; }
.method-target-tag { font-size: 13px; color: var(--d-sub); border: 1px solid var(--d-line); padding: 4px 12px; background: rgba(255,255,255,.03); }
.method-trend-box { border: 1px solid var(--d-line); background: var(--d-card); padding: 22px 24px; align-self: start; }
.mtb-label { font-family: var(--mono); font-size: 9px; letter-spacing: .12em; color: var(--d-dim); text-transform: uppercase; margin-bottom: 6px; }
.mtb-num { font-family: var(--mono); font-size: 24px; font-weight: 500; color: #fff; line-height: 1; margin-bottom: 4px; }
.mtb-latest { font-size: 11px; color: var(--d-sub); }
.trend-box-label { font-family: var(--mono); font-size: 9px; letter-spacing: .12em; color: var(--d-dim); text-transform: uppercase; margin-bottom: 12px; }
.trend-row { display: flex; justify-content: space-between; padding: 9px 0; border-bottom: 1px solid var(--d-line); }
.trend-row:last-child { border-bottom: none; }
.trend-lbl { font-size: 13px; color: var(--d-sub); }
.trend-val { font-family: var(--mono); font-size: 14px; font-weight: 500; color: #fff; }
.method-stats { display: grid; grid-template-columns: repeat(auto-fit, minmax(100px, 1fr)); gap: 1px; background: var(--d-line); }
.m-stat { padding: 18px 24px; background: var(--d-bg); }
.m-stat-label { font-family: var(--mono); font-size: 9px; letter-spacing: .12em; color: var(--d-dim); text-transform: uppercase; margin-bottom: 6px; }
.m-stat-val { font-family: var(--mono); font-size: 24px; font-weight: 500; color: #fff; line-height: 1; }
.m-stat-sub { font-size: 11px; color: var(--d-sub); margin-top: 4px; }

/* AREA RANK CARD (method sidebar) */
.area-rank-card { border: 1px solid var(--l-line); background: var(--l-card); }
.area-rank-card .sc-head { padding: 13px 18px; background: var(--l-bg); border-bottom: 1px solid var(--l-line); display: flex; justify-content: space-between; }
.area-row { display: flex; align-items: center; gap: 12px; padding: 12px 18px; border-bottom: 1px solid var(--l-line); transition: background var(--t-fast); }
.area-row:last-child { border-bottom: none; }
.area-row:hover { background: var(--l-bg); }
.area-row-num { font-family: var(--en); font-size: 16px; font-weight: 300; color: var(--l-dim); width: 20px; text-align: center; }
.area-row-num.top { color: var(--gold); }
.area-row-name { font-size: 14px; font-weight: 600; flex: 1; }
.area-row-cnt { font-family: var(--mono); font-size: 10px; color: var(--l-dim); letter-spacing: .06em; }

/* RELATED METHODS CARD */
.related-methods-card { border: 1px solid var(--l-line); background: var(--l-card); }
.rm-body { padding: 14px 18px; }
.rm-item { display: flex; align-items: center; gap: 12px; padding: 11px 0; border-bottom: 1px solid var(--l-line); text-decoration: none; color: inherit; }
.rm-item:last-child { border-bottom: none; }
.rm-name { font-size: 14px; font-weight: 500; flex: 1; color: var(--l-text); }
.rm-target { font-size: 12px; color: var(--l-dim); }
.rm-arrow { font-family: var(--mono); font-size: 11px; color: var(--l-dim); }

/* ============================================================
   BAY LIST PAGE
   ============================================================ */
.bay-featured { display: grid; grid-template-columns: repeat(3, 1fr); gap: 16px; margin-bottom: 20px; }
.bay-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 16px; }
.bay-card { display: flex; flex-direction: column; background: var(--l-card); border: 1px solid var(--l-line); text-decoration: none; color: inherit; cursor: pointer; transition: box-shadow var(--t-med) var(--ease), transform var(--t-med) var(--ease); }
.bay-card:hover { box-shadow: 0 8px 28px rgba(14,24,34,.10); transform: translateY(-2px); }
.bay-card.hero { grid-column: span 2; border-left: 3px solid var(--red); box-shadow: var(--sh-hero); }
.bay-photo { position: relative; aspect-ratio: 16/9; overflow: hidden; }
.bay-card.hero .bay-photo { aspect-ratio: 3/1; max-height: 280px; }
.bay-photo .ph { width: 100%; height: 100%; background: var(--ph-card); display: flex; align-items: center; justify-content: center; }
.bay-photo .ph::before { content: 'PHOTO'; font-family: var(--mono); font-size: 9px; letter-spacing: .18em; color: var(--ph-txt); }
.bay-body { padding: 18px 22px; display: flex; flex-direction: column; flex: 1; }
.bay-card.hero .bay-body { padding: 22px 26px; }
.bay-region { font-family: var(--mono); font-size: 10px; color: var(--l-dim); letter-spacing: .1em; margin-bottom: 6px; }
.bay-name { font-size: 18px; font-weight: 700; letter-spacing: .04em; margin-bottom: 8px; color: var(--l-text); }
.bay-card:hover .bay-name { color: var(--red); }
.bay-species { font-size: 13px; color: var(--l-sub); line-height: 1.75; margin-bottom: auto; }
.bay-stats { display: grid; grid-template-columns: repeat(3, 1fr); gap: 14px; padding-top: 14px; border-top: 1px solid var(--l-line); margin-top: 14px; }
.bay-stat-lbl { font-family: var(--mono); font-size: 9px; letter-spacing: .1em; color: var(--l-dim); text-transform: uppercase; }
.bay-stat-val { font-family: var(--mono); font-size: 18px; font-weight: 500; color: var(--gold); line-height: 1; margin-top: 4px; }

/* SEC (shared section styling) */
.sec { padding: 56px 0; }
.sec .wrap { max-width: 1320px; margin: 0 auto; padding: 0 40px; }
.sec-head { margin-bottom: 28px; }
.sec-label { font-family: var(--en); font-size: 12px; font-style: italic; color: var(--l-dim); letter-spacing: .2em; margin-bottom: 4px; }
.sec-title { font-size: 24px; font-weight: 700; color: var(--l-text); }
.sec-desc { font-size: 13px; color: var(--l-sub); line-height: 1.9; margin-top: 8px; }

/* ============================================================
   AREA LIST PAGE
   ============================================================ */
.featured-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 16px; margin-bottom: 48px; }
.featured-card { display: flex; flex-direction: column; background: var(--l-card); border: 1px solid var(--l-line); text-decoration: none; color: inherit; transition: box-shadow var(--t-med), transform var(--t-med); }
.featured-card:hover { box-shadow: var(--sh-hero); transform: translateY(-2px); }
.fc-photo { position: relative; aspect-ratio: 16/9; overflow: hidden; }
.fc-photo .ph { width: 100%; height: 100%; background: var(--ph-card); display: flex; align-items: center; justify-content: center; }
.fc-photo .ph::before { content: 'PHOTO'; font-family: var(--mono); font-size: 9px; letter-spacing: .18em; color: var(--ph-txt); }
.fc-body { padding: 18px 22px; display: flex; flex-direction: column; }
.fc-name { font-size: 18px; font-weight: 700; letter-spacing: .04em; margin-bottom: 8px; }
.featured-card:hover .fc-name { color: var(--red); }
.fc-meta { display: flex; gap: 14px; font-family: var(--mono); font-size: 10px; color: var(--l-dim); letter-spacing: .06em; }
.fc-meta strong { color: var(--gold); font-weight: 500; }
.fc-stats { display: flex; gap: 16px; margin-top: auto; padding-top: 12px; border-top: 1px solid var(--l-line); }
.fc-stats .fs { text-align: center; flex: 1; }
.fc-stats .fs-lbl { font-family: var(--mono); font-size: 9px; letter-spacing: .1em; color: var(--l-dim); margin-bottom: 4px; }
.fc-stats .fs-val { font-family: var(--en); font-size: 20px; font-weight: 700; color: var(--l-text); letter-spacing: .04em; }
.fc-stats .fs-val small { font-size: 11px; font-weight: 400; color: var(--l-dim); margin-left: 2px; }

/* REGION BLOCK */
.region-block { margin-bottom: 48px; }
.region-block:last-child { margin-bottom: 0; }
.region-header { display: flex; align-items: baseline; gap: 16px; margin-bottom: 16px; padding-bottom: 12px; border-bottom: 1px solid var(--l-line); }
.region-name { font-size: 20px; font-weight: 700; }
.region-en { font-family: var(--en); font-size: 13px; font-style: italic; color: var(--l-dim); letter-spacing: .2em; }
.region-stats { font-family: var(--mono); font-size: 11px; color: var(--l-dim); letter-spacing: .08em; margin-left: auto; }
.pref-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 1px; background: var(--l-line); }
.pref-card { padding: 18px; background: var(--l-card); display: flex; flex-direction: column; gap: 6px; border-left: 3px solid transparent; text-decoration: none; color: inherit; transition: background var(--t-fast), border-color var(--t-fast); }
.pref-card:hover { background: #FDFAF8; border-left-color: var(--red); }
.pref-card:hover .pc-name { color: var(--red); }
.pc-head { display: flex; justify-content: space-between; align-items: baseline; }
.pc-name { font-size: 16px; font-weight: 700; letter-spacing: .04em; transition: color var(--t-fast); }
.pc-en { font-family: var(--en); font-size: 10px; font-style: italic; color: var(--l-dim); }
.pc-stats { display: flex; gap: 12px; font-family: var(--mono); font-size: 10px; color: var(--l-dim); letter-spacing: .06em; }
.pc-stats strong { color: var(--gold); font-weight: 500; }

/* ============================================================
   METHOD LIST PAGE
   ============================================================ */
.ranking-sec { background: var(--d-bg); padding: 56px 0; border-bottom: 1px solid var(--d-line); }
.ranking-sec .wrap { max-width: 1320px; margin: 0 auto; padding: 0 40px; }
.rank-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 1px; background: var(--d-line); }
.rank-item { background: var(--d-card); padding: 24px; display: flex; flex-direction: column; gap: 12px; text-decoration: none; color: inherit; transition: background var(--t-fast); }
.rank-item:hover { background: var(--d-hover); }
.rank-head { display: flex; align-items: baseline; gap: 12px; }
.rank-no { font-family: var(--en); font-size: 22px; font-weight: 300; color: var(--gold); width: 28px; }
.rank-no.lower { color: var(--d-dim); }
.rank-name { font-size: 18px; font-weight: 700; color: #fff; }
.rank-name small { font-family: var(--en); font-size: 10px; font-style: italic; color: var(--d-dim); font-weight: 400; display: block; }
.rank-count { font-family: var(--mono); font-size: 13px; color: var(--d-sub); margin-left: auto; }
.rank-desc { font-size: 12px; color: var(--d-sub); line-height: 1.75; display: flex; gap: 8px; flex-wrap: wrap; }
.rank-category { font-family: var(--mono); font-size: 10px; letter-spacing: .08em; color: var(--d-dim); }
.rank-targets { color: var(--d-sub); }
.rank-area { font-family: var(--mono); font-size: 10px; color: var(--d-dim); letter-spacing: .08em; padding-top: 8px; border-top: 1px solid var(--d-line); margin-top: auto; }

/* CATEGORY BLOCK */
.category-block { margin-bottom: 48px; }
.category-block:last-child { margin-bottom: 0; }
.category-header { display: flex; align-items: baseline; gap: 16px; margin-bottom: 16px; padding-bottom: 12px; border-bottom: 1px solid var(--l-line); }
.category-name { font-size: 20px; font-weight: 700; }
.category-count { font-family: var(--mono); font-size: 11px; color: var(--l-dim); margin-left: auto; }
.method-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 1px; background: var(--l-line); }
.method-card { padding: 20px; background: var(--l-card); display: flex; flex-direction: column; gap: 8px; text-decoration: none; color: inherit; transition: background var(--t-fast); }
.method-card:hover { background: #FDFAF8; }
.method-card:hover .mc-name { color: var(--red); }
.mc-name { font-size: 16px; font-weight: 700; letter-spacing: .04em; transition: color var(--t-fast); }
.mc-name small { font-family: var(--en); font-size: 10px; font-style: italic; color: var(--l-dim); font-weight: 400; display: block; }
.mc-target { font-size: 12px; color: var(--l-sub); }
.mc-count { font-family: var(--mono); font-size: 10px; color: var(--l-dim); letter-spacing: .06em; margin-top: auto; }

/* ============================================================
   RESPONSIVE (area pages)
   ============================================================ */
@media (max-width: 1024px) {
  .port-grid { grid-template-columns: 1fr !important; }
  .port-card.hero { grid-column: 1; }
  .pref-stats { grid-template-columns: repeat(3, 1fr); }
  .port-title-row { grid-template-columns: 1fr !important; }
  .port-live-box { display: none; }
  .report-card { grid-template-columns: 120px 1fr; }
}
@media (max-width: 768px) {
  .pref-hero-inner, .port-hero-inner, .area-hero-inner { padding: 0 16px; }
  .pref-name, .port-name, .area-name { font-size: 24px; }
  .pref-stats, .port-stats, .area-stats { grid-template-columns: 1fr 1fr; gap: 8px; }
  .ps-val, .a-stat-val { font-size: 22px; }
  .catch-row-item { grid-template-columns: 50px 1fr; }
  .cr-right { display: none; }
  .report-card { grid-template-columns: 1fr; }
  .rc-thumb { display: none; }
}

/* Responsive for list pages */
@media (max-width: 1024px) {
  .page-hero-inner { grid-template-columns: 1fr; gap: 24px; }
  .method-title-row { grid-template-columns: 1fr; gap: 24px; }
  .method-trend-box { display: none; }
  .boat-list .boat-card { grid-template-columns: 64px 1fr; }
  .boat-list .boat-card.hero { grid-template-columns: 64px 1fr; }
  .boat-list .bc-photo .ph { min-height: 64px; }
  .bc-today { border-left: none; border-top: 1px solid var(--l-line); flex-direction: row; gap: 12px; }
  .bay-featured { grid-template-columns: repeat(2, 1fr); }
  .bay-grid { grid-template-columns: repeat(2, 1fr); }
  .bay-card.hero { grid-column: span 2; }
  .featured-grid { grid-template-columns: repeat(2, 1fr); }
  .pref-grid { grid-template-columns: repeat(3, 1fr); }
  .rank-grid { grid-template-columns: repeat(2, 1fr); }
  .method-grid { grid-template-columns: repeat(2, 1fr); }
  .method-stats { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 768px) {
  .page-title { font-size: 26px; }
  .method-name { font-size: 28px; }
  .hero-stats { grid-template-columns: repeat(2, 1fr); }
  .bay-featured { grid-template-columns: 1fr; }
  .bay-grid { grid-template-columns: 1fr; }
  .bay-card.hero { grid-column: 1; }
  .featured-grid { grid-template-columns: 1fr; }
  .pref-grid { grid-template-columns: repeat(2, 1fr); }
  .rank-grid { grid-template-columns: 1fr; }
  .method-grid { grid-template-columns: 1fr; }
  .method-stats { grid-template-columns: 1fr; }
  .pagination { flex-wrap: wrap; }
}

/* アクセシビリティ */
@media (prefers-reduced-motion: reduce) {
  .drawer, .drawer-overlay, .hamburger-bar { transition: none; }
}

/* ============================================================
   情報ページ（免責事項・プライバシーポリシー・お問い合わせ）
   ============================================================ */
.info-page {
  padding: 2rem 1rem 3rem;
  max-width: 800px;
  margin: 0 auto;
}
.info-page h1 {
  font-family: 'Shippori Mincho B1', serif;
  font-size: 1.8rem;
  font-weight: 700;
  color: var(--l-text);
  margin-bottom: .5rem;
  border-bottom: 2px solid var(--l-line);
  padding-bottom: .5rem;
}
.info-updated {
  color: var(--l-sub);
  font-size: .85rem;
  margin-bottom: 2rem;
}
.info-page section {
  margin-bottom: 2rem;
}
.info-page h2 {
  font-size: 1.15rem;
  font-weight: 600;
  color: var(--l-text);
  margin-bottom: .6rem;
  padding-left: .6rem;
  border-left: 3px solid var(--marine);
}
.info-page p {
  color: var(--l-sub);
  line-height: 1.8;
  margin-bottom: .8rem;
}
.info-page ul {
  color: var(--l-sub);
  line-height: 1.8;
  margin-left: 1.5rem;
  margin-bottom: .8rem;
}
.info-page a {
  color: var(--marine);
  text-decoration: underline;
}
.info-page a:hover {
  color: var(--marine-lt);
}
.info-table {
  width: 100%;
  border-collapse: collapse;
  margin-top: .5rem;
}
.info-table th,
.info-table td {
  padding: .6rem .8rem;
  border-bottom: 1px solid var(--l-line);
  text-align: left;
  color: var(--l-sub);
}
.info-table th {
  width: 30%;
  font-weight: 600;
  color: var(--l-text);
  background: var(--l-bg);
}
@media (max-width: 600px) {
  .info-page h1 { font-size: 1.4rem; }
  .info-table th { width: 35%; }
}

/* ============================================================
   CALLOUT BOXES (A-4)
   ============================================================ */
.callout {
  display: flex;
  gap: 16px;
  padding: 18px 20px;
  border-left: 4px solid;
  margin: 24px 0;
}
.callout-info {
  background: #EEF4FB;
  border-color: #2E6DA8;
}
.callout-tip {
  background: #EEF8F3;
  border-color: #2E7D52;
}
.callout-warn {
  background: #FDF5E8;
  border-color: #B07A1A;
}
.callout-icon {
  font-family: var(--mono);
  font-size: 11px;
  font-weight: 600;
  letter-spacing: .08em;
  flex-shrink: 0;
  padding-top: 2px;
}
.callout-info  .callout-icon { color: #2E6DA8; }
.callout-tip   .callout-icon { color: #2E7D52; }
.callout-warn  .callout-icon { color: #B07A1A; }
.callout-title {
  font-family: var(--ja);
  font-size: 14px;
  font-weight: 700;
  margin-bottom: 6px;
  letter-spacing: .03em;
}
.callout-info  .callout-title { color: #1E4A78; }
.callout-tip   .callout-title { color: #1E5538; }
.callout-warn  .callout-title { color: #7A5210; }
.callout-text {
  font-size: 14px;
  line-height: 1.8;
  letter-spacing: .02em;
}
.callout-info  .callout-text { color: #2A5580; }
.callout-tip   .callout-text { color: #256040; }
.callout-warn  .callout-text { color: #806018; }

/* ============================================================
   SKIP NAVIGATION (C-3)
   ============================================================ */
.skip-nav {
  position: absolute;
  left: -9999px;
  top: auto;
  width: 1px;
  height: 1px;
  overflow: hidden;
  z-index: 999;
  font-family: var(--mono);
  font-size: 13px;
  letter-spacing: .08em;
  color: #fff;
  background: var(--d-bg);
  padding: 12px 24px;
  text-decoration: none;
}
.skip-nav:focus {
  position: fixed;
  left: 16px;
  top: 8px;
  width: auto;
  height: auto;
  overflow: visible;
  border: 2px solid var(--marine);
}

/* ============================================================
   PREFERS-REDUCED-MOTION (C-1 + R-4)
   ============================================================ */
@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after {
    animation-duration: 0.01ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: 0.01ms !important;
    scroll-behavior: auto !important;
  }
}
