*{margin:0;padding:0;box-sizing:border-box;}
:root{
  --bg:#f5f5f5;
  --surface:#ffffff;
  --surface-lowest:#ffffff;
  --surface-low:#eef2ef;
  --surface2:#e3ebe6;
  --border:rgba(1,110,73,0.14);
  --text:#1f2822;
  --dim:#5e7e6b;
  --accent:#016e49;
  --accent2:#2f7e61;
  --accent-pale:#e6f0eb;
  --accent-grad: linear-gradient(135deg,#016e49,#2f7e61);
  --tertiary:#eda833;
  --tertiary-bright:#eda833;
  --tertiary-pale:#fcf2df;
  --secondary:#5e7e6b;
  --navy:#355646;
  --shadow-ambient: 0 10px 28px rgba(31,40,34,0.08);
  --font-headline: 'Zen Kaku Gothic New', 'Noto Sans JP', sans-serif;
  --font-body:     'Noto Sans JP', sans-serif;
  --font-label:    'Noto Sans JP', sans-serif;
}
[data-theme="dark"]{
  --bg:#111714;
  --surface:#18211c;
  --surface-lowest:#1f2923;
  --surface-low:#141b17;
  --surface2:#202a24;
  --border:rgba(160,190,175,0.18);
  --text:#ecf2ee;
  --dim:#a4b8ac;
  --accent:#5f9f84;
  --accent2:#79b095;
  --accent-pale:#173126;
  --tertiary:#d89c38;
  --tertiary-bright:#eda833;
  --tertiary-pale:#2f2615;
  --secondary:#7b9084;
  --navy:#8fa79a;
  --shadow-ambient:0 12px 28px rgba(0,0,0,.34);
}
body{background:var(--bg);color:var(--text);font-family:var(--font-body);overflow:hidden;height:100vh;width:100vw;cursor:grab;user-select:none;}
body.works-map-static-body{
  overflow:auto;
  height:auto;
  min-height:100vh;
  width:auto;
  cursor:default;
  user-select:auto;
}
:root{--sidebar-w:212px;--sidebar-w-expanded:212px;--sidebar-w-collapsed:76px;}
html.sidebar-collapsed{--sidebar-w:var(--sidebar-w-collapsed);}
.map-sidebar{
  position:fixed;top:0;left:0;bottom:0;z-index:100;
  width:var(--sidebar-w);
  display:flex;flex-direction:column;gap:22px;
  padding:16px 12px 18px;
  background:linear-gradient(180deg,rgba(255,255,255,.98),rgba(245,245,245,.96));
  border-right:1px solid rgba(1,110,73,.08);
  box-shadow:8px 0 24px rgba(31,40,34,.06);
  backdrop-filter:blur(12px);
  cursor:default;user-select:auto;
}
[data-theme="dark"] .map-sidebar{
  background:linear-gradient(180deg,rgba(13,17,20,.98),rgba(13,17,20,.94));
  box-shadow:14px 0 36px rgba(0,0,0,.24);
}
.sidebar-topbar{
  display:flex;
  align-items:center;
  gap:10px;
  position:relative;
}
.sidebar-brand{
  display:flex;
  justify-content:flex-start;
  min-width:0;
  flex:1;
  text-decoration:none;
  color:inherit;
}
.sidebar-brand-mark{
  width:40px;height:40px;border-radius:12px;
  display:flex;align-items:center;justify-content:center;
  background:transparent;
  color:var(--accent);
  font-family:var(--font-headline);
  font-size:24px;font-weight:800;
  box-shadow:none;
}
.sidebar-brand-word{
  width:100%;
  height:auto;
  min-height:44px;
  border-radius:0;
  justify-content:flex-start;
  padding:0 6px 0 6px;
  font-size:20px;
  letter-spacing:.04em;
}
.sidebar-collapse-btn{
  width:36px;
  min-width:36px;
  height:44px;
  padding:0;
  border:none;
  border-radius:14px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  background:rgba(255,255,255,.78);
  color:var(--dim);
  box-shadow:0 8px 18px rgba(27,29,15,.08);
  cursor:pointer;
  transition:background .18s ease,color .18s ease,transform .18s ease;
}
.sidebar-collapse-btn:hover{
  background:var(--surface);
  color:var(--accent);
  transform:translateY(-1px);
}
[data-theme="dark"] .sidebar-collapse-btn{
  background:rgba(21,28,33,.88);
}
.sidebar-collapse-btn svg{
  width:18px;
  height:18px;
  flex-shrink:0;
  transition:transform .2s ease;
}
.flash-stack{position:fixed;top:22px;left:calc(var(--sidebar-w) + 24px);z-index:160;display:flex;flex-direction:column;gap:8px;pointer-events:none;}
.flash-banner{padding:10px 14px;border-radius:10px;font-size:12px;line-height:1.5;box-shadow:0 6px 20px rgba(27,29,15,.08);max-width:420px;opacity:1;transform:translateY(0);transition:opacity .24s ease,transform .24s ease;pointer-events:auto;}
.flash-banner.is-hiding{opacity:0;transform:translateY(-8px);}
.flash-notice{background:#edf8f1;color:#0f5b34;border:1px solid rgba(1,110,73,.18);}
.flash-alert{background:#fff3ea;color:#8b421d;border:1px solid rgba(190,100,64,.22);}
.flash-banner.is-sticky{display:flex;align-items:flex-start;gap:12px;max-width:520px;}
.flash-banner-copy{flex:1;min-width:0;}
.flash-banner-action{
  display:inline-flex;align-items:center;justify-content:center;
  min-width:52px;padding:7px 14px;border-radius:999px;
  border:1px solid rgba(1,110,73,.18);background:#fff;color:var(--accent);
  font:600 12px/1 var(--font-body);cursor:pointer;flex-shrink:0;
}
.flash-banner-action:hover{background:rgba(255,255,255,.72);}
.flash-banner-action-alert{
  border-color:rgba(190,100,64,.22);
  color:#8b421d;
}

#map-container{width:calc(100% - var(--sidebar-w));height:100%;margin-left:var(--sidebar-w);position:relative;background:var(--bg);touch-action:none;}
#map-world{position:absolute;width:6000px;height:5500px;transform-origin:0 0;}
.map-feed-sidebar{
  position:fixed;
  right:24px;
  top:24px;
  width:320px;
  max-height:calc(100vh - 280px);
  z-index:95;
  pointer-events:none;
}
.map-feed-sidebar-card{
  max-height:calc(100vh - 280px);
  display:flex;
  flex-direction:column;
  border-radius:20px;
  background:rgba(255,255,255,.96);
  border:1px solid rgba(1,110,73,.08);
  box-shadow:0 12px 36px rgba(31,40,34,.08);
  overflow-y:auto;
  overflow-x:hidden;
  -webkit-overflow-scrolling:touch;
  overscroll-behavior:contain;
  pointer-events:auto;
}
[data-theme="dark"] .map-feed-sidebar-card{
  background:rgba(24,33,28,.96);
  border-color:rgba(160,190,175,.14);
  box-shadow:0 20px 48px rgba(0,0,0,.32);
}
.map-feed-section{border-bottom:1px solid rgba(1,110,73,.08);}
.map-feed-section:last-child{border-bottom:none;}
.map-feed-section-head{
  padding:16px 18px 10px;
}
.map-feed-section-title{
  display:flex;
  align-items:center;
  gap:8px;
  font-size:17px;
  font-weight:700;
  color:var(--text);
  font-family:var(--font-headline);
}
.map-feed-section-icon{
  width:18px;
  height:18px;
}
.map-feed-section-icon.rating{color:#8c4b00;}
.map-feed-section-icon.fresh{color:var(--accent);}
.map-feed-pill{
  display:inline-flex;
  align-items:center;
  padding:2px 8px;
  border-radius:999px;
  border:1px solid transparent;
  font-size:10px;
  font-weight:700;
  line-height:1.2;
}
.map-feed-pill-hot{
  color:#8c4b00;
  background:rgba(237,168,51,.14);
  border-color:rgba(237,168,51,.24);
}
.map-feed-pill-new{
  color:#fff;
  background:var(--accent);
}
.map-feed-list{
  padding:0 14px 14px;
  display:flex;
  flex-direction:column;
  gap:10px;
}
.map-feed-item{
  width:100%;
  text-align:left;
  border:none;
  border-radius:14px;
  padding:14px;
  background:#fff;
  border:1px solid rgba(1,110,73,.12);
  cursor:pointer;
  transition:transform .14s ease, box-shadow .14s ease, border-color .14s ease;
}
.map-feed-item-hot{
  background:rgba(237,168,51,.12);
  border-color:rgba(237,168,51,.18);
}
.map-feed-item-fresh{
  background:rgba(1,110,73,.08);
  border-color:rgba(1,110,73,.18);
}
.map-feed-item:hover{
  transform:translateY(-1px);
  box-shadow:0 12px 24px rgba(31,40,34,.08);
  border-color:rgba(1,110,73,.22);
}
[data-theme="dark"] .map-feed-item{
  background:rgba(255,255,255,.03);
  border-color:rgba(255,255,255,.08);
}
.map-feed-item-top{
  display:flex;
  align-items:flex-start;
  gap:10px;
}
.map-feed-user-badge{
  width:28px;
  height:28px;
  border-radius:999px;
  display:flex;
  align-items:center;
  justify-content:center;
  background:rgba(237,168,51,.18);
  color:#8c4b00;
  font-size:12px;
  font-weight:700;
  flex-shrink:0;
}
.map-feed-user-badge-fresh{
  background:rgba(1,110,73,.14);
  color:var(--accent);
}
.map-feed-item-meta{
  min-width:0;
  flex:1;
}
.map-feed-author-row{
  display:flex;
  align-items:center;
  gap:6px;
  flex-wrap:wrap;
}
.map-feed-author{
  font-size:13px;
  font-weight:700;
  color:var(--accent);
}
.map-feed-time{
  font-size:11px;
  color:var(--dim);
}
.map-feed-work-title{
  margin-top:4px;
  font-size:12px;
  color:var(--dim);
  line-height:1.5;
}
.map-feed-score{
  display:inline-flex;
  align-items:center;
  gap:4px;
  color:#8c4b00;
  font-size:12px;
  font-weight:700;
  flex-shrink:0;
}
.map-feed-score svg{
  width:14px;
  height:14px;
}
.map-feed-body{
  margin-top:10px;
  font-size:14px;
  line-height:1.6;
  color:var(--text);
  white-space:normal;
  word-break:break-word;
  overflow-wrap:anywhere;
}
.map-feed-body > *{
  margin:0;
}
.map-feed-empty{
  padding:20px 18px 24px;
  text-align:center;
  color:var(--dim);
  font-size:13px;
}
.map-feed-empty-icon{
  width:46px;
  height:46px;
  border-radius:999px;
  display:flex;
  align-items:center;
  justify-content:center;
  margin:0 auto 10px;
}
.map-feed-empty-icon.star{
  background:rgba(237,168,51,.14);
  color:#8c4b00;
}
.map-feed-empty-icon.fresh{
  background:rgba(1,110,73,.12);
  color:var(--accent);
}
.map-feed-empty-icon svg{
  width:20px;
  height:20px;
}
.map-feed-empty p{font-weight:600;}
.map-feed-empty-sub{
  margin-top:4px;
  font-size:12px;
  font-weight:500 !important;
  color:#8fa396;
}

.genre-island,.sub-island{position:absolute;border-radius:50%;border:1.5px solid;pointer-events:auto;}
.sub-island{opacity:0.5;transition:opacity .3s;}
.island-label{position:absolute;left:50%;transform:translateX(-50%);font-family:var(--font-headline);font-weight:700;letter-spacing:.1em;white-space:nowrap;text-align:center;pointer-events:none;transition:opacity .3s;}
.island-label .cnt{display:block;font-size:10px;font-weight:300;font-family:var(--font-body);opacity:.6;margin-top:1px;}

.work-card{position:absolute;transform:translate(-50%,-50%);cursor:pointer;transition:opacity .3s;}
.work-card:hover{z-index:10;}
.work-thumb{
  border-radius:1px;
  overflow:visible;
  box-shadow:0 8px 24px rgba(27,29,15,.08),0 2px 8px rgba(27,29,15,.05);
  border:none;
  transition:width .3s,height .3s,padding .3s;
  position:relative;
  background:#fff;
  padding:3px 3px 16px 3px;
  display:flex;
  align-items:center;
  justify-content:center;
}
.masking-tape{
  position:absolute;
  top:-9px;
  height:13px;
  z-index:20;
  border-radius:1px;
  opacity:.82;
  pointer-events:none;
}
.work-title{font-size:9px;font-weight:400;color:#888;text-align:center;margin-top:2px;max-width:130px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;transition:opacity .3s;font-family:var(--font-label);letter-spacing:.03em;}
.map-pin-badge{
  position:absolute;top:-7px;right:-7px;
  min-width:18px;height:18px;
  background:#001B44;
  color:#fff;
  border-radius:9px;
  border:2px solid #fff;
  font-family:var(--font-label);font-size:9px;font-weight:700;
  display:flex;align-items:center;justify-content:center;
  padding:0 4px;
  z-index:15;
  pointer-events:none;
  box-shadow:0 2px 6px rgba(0,27,68,.4);
  transition:opacity .3s;
}
/* 画像上のミニピン */
.map-mini-pin{
  position:absolute;
  border-radius:50%;
  pointer-events:none;
  z-index:12;
  transition:opacity .3s;
  box-shadow:0 1px 4px rgba(0,0,0,.4);
  display:flex;align-items:center;justify-content:center;
  font-family:var(--font-label);font-weight:700;
  color:#fff;
  line-height:1;
}
.map-mini-pin.type-author{ background:#EDA833; }
.map-mini-pin.type-mine{   background:#001B44; border:2px solid #fff; }
.map-mini-pin.type-others{ background:#001B44; }
/* 画像ラッパー（overflow:hidden でミニピンをクリップ） */
.work-img-wrap{
  position:relative;
  overflow:hidden;
  flex:0 0 auto;
}
.work-img-wrap img{
  display:block;width:100%;height:100%;object-fit:contain;
}

.work-dot{position:absolute;transform:translate(-50%,-50%);border-radius:50%;cursor:pointer;transition:all .3s;}
.work-dot:hover{transform:translate(-50%,-50%);z-index:10;}
.work-dot.isnew{background:var(--accent)!important;box-shadow:0 0 8px rgba(0,83,54,.5);}
.work-dot.isnew::after{content:'';position:absolute;top:50%;left:50%;width:100%;height:100%;border-radius:50%;background:rgba(0,83,54,.3);animation:pulse 1.6s ease-out infinite;}
.work-card.isnew .work-thumb{border-color:rgba(0,83,54,.4);box-shadow:0 0 0 2px rgba(0,83,54,.15),0 2px 12px rgba(0,83,54,.12);}
.work-card.isnew::after{content:'NEW';position:absolute;top:-10px;right:-10px;background:var(--tertiary);color:#533400;font-family:var(--font-headline);font-size:8px;font-weight:700;padding:3px 7px;border-radius:6px;z-index:20;box-shadow:1px 2px 4px rgba(0,0,0,.14);}
@keyframes pulse{0%{transform:translate(-50%,-50%) scale(1);opacity:.7;}100%{transform:translate(-50%,-50%) scale(2.6);opacity:0;}}

.zoom-controls{position:fixed;bottom:32px;right:24px;display:flex;flex-direction:column;gap:4px;z-index:100;}
.zoom-btn{width:36px;height:36px;background:var(--surface);border:1px solid var(--border);border-radius:8px;color:var(--text);font-size:18px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s;box-shadow:0 1px 6px rgba(0,83,54,.08);}
.zoom-btn:hover{background:var(--accent-pale);color:var(--accent);border-color:rgba(0,83,54,.3);}
.edge-toggle{width:36px;height:36px;background:var(--surface);border:1px solid var(--border);border-radius:8px;color:var(--dim);font-size:14px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s;margin-top:4px;position:relative;box-shadow:0 1px 6px rgba(0,83,54,.08);}
.edge-toggle:hover{background:var(--accent-pale);color:var(--accent);}
.edge-toggle.on{background:var(--accent-pale);border-color:rgba(0,83,54,.4);color:var(--accent);}
.edge-toggle-tip{position:absolute;right:calc(100% + 8px);top:50%;transform:translateY(-50%);background:var(--surface);border:1px solid var(--border);border-radius:6px;padding:4px 8px;font-size:11px;font-family:var(--font-body);white-space:nowrap;color:var(--text);pointer-events:none;opacity:0;transition:opacity .15s;box-shadow:0 2px 8px rgba(0,83,54,.08);}
.edge-toggle:hover .edge-toggle-tip{opacity:1;}

.zoom-indicator{position:fixed;bottom:32px;left:calc(var(--sidebar-w) + 24px);z-index:100;display:flex;flex-direction:column;gap:6px;}
.pin-toggle-btn{
  position:fixed;bottom:100px;left:calc(var(--sidebar-w) + 24px);z-index:100;
  display:flex;align-items:center;gap:7px;
  background:var(--surface);
  border:1px solid var(--border);
  border-radius:var(--radius-md);
  padding:8px 14px;
  font-family:var(--font-label);font-size:12px;font-weight:500;
  color:var(--text);cursor:pointer;
  box-shadow:var(--shadow-ambient);
  transition:all .18s;
  user-select:none;
}
.pin-toggle-btn:hover{background:var(--surface-low);}
.pin-toggle-btn.pins-hidden{color:var(--on-surface-dim);}
.pin-toggle-dot{
  width:9px;height:9px;border-radius:50%;
  background:#001B44;flex-shrink:0;
  transition:opacity .18s;
}
.pin-toggle-btn.pins-hidden .pin-toggle-dot{opacity:.3;}
.zoom-level-label{font-size:11px;color:var(--dim);font-family:var(--font-label);letter-spacing:.1em;text-transform:uppercase;}
.zoom-steps{display:flex;gap:6px;align-items:center;}
.zoom-step{width:28px;height:3px;background:var(--border);border-radius:2px;transition:background .3s;}
.zoom-step.active{background:var(--accent);}

.hover-card{position:fixed;background:var(--surface);border:1px solid rgba(190,201,192,0.15);border-radius:12px;padding:12px;width:200px;max-width:200px;pointer-events:none;z-index:200;display:none;box-shadow:0 4px 20px rgba(0,83,54,.12);}
.hover-card.visible{display:block;}
.hover-card-img-wrap{width:176px;overflow:hidden;position:relative;border-radius:8px;margin-bottom:8px;}
.hover-card img{width:100%;height:auto;max-height:176px;object-fit:contain;background:#f0f0eb;display:block;border-radius:8px;}
.hc-title{font-size:13px;font-weight:500;color:var(--text);margin-bottom:2px;}
.hc-author{font-size:11px;color:var(--dim);}
.hc-genre{display:inline-block;margin-top:8px;padding:2px 8px;border-radius:20px;font-size:10px;font-family:var(--font-headline);letter-spacing:.05em;}

#minimap-wrap{position:fixed;bottom:28px;right:24px;z-index:100;display:flex;flex-direction:column;align-items:flex-end;gap:6px;}
#mm-badge{background:var(--accent);color:#fff;font-family:var(--font-headline);font-size:10px;font-weight:700;padding:2px 8px;border-radius:20px;cursor:pointer;box-shadow:0 2px 8px rgba(0,83,54,.3);}
#mm-list{background:var(--surface);border:1px solid var(--border);border-radius:12px;padding:8px;width:220px;display:none;flex-direction:column;gap:6px;box-shadow:0 8px 24px rgba(0,83,54,.1);}
#mm-list.open{display:flex;}
#mm-canvas{width:220px;height:176px;border-radius:12px;border:1px solid var(--border);cursor:pointer;display:block;box-shadow:0 10px 28px rgba(0,83,54,.08);}
.ni{display:flex;align-items:center;gap:8px;padding:4px 6px;border-radius:7px;cursor:pointer;transition:background .15s;}
.ni:hover{background:var(--accent-pale);}
.ni-dot{width:7px;height:7px;border-radius:50%;flex-shrink:0;}
.ni-title{font-size:11px;color:var(--text);}
.ni-meta{font-size:10px;color:var(--dim);}
.ni-jump{font-size:10px;color:var(--accent);margin-left:auto;opacity:0;transition:opacity .15s;}
.ni:hover .ni-jump{opacity:1;}

.pin-indicator{position:fixed;top:60px;left:50%;transform:translateX(-50%);background:var(--accent-pale);border:1px solid rgba(0,83,54,.3);color:var(--accent);font-family:var(--font-headline);font-size:11px;letter-spacing:.1em;padding:6px 16px;border-radius:20px;z-index:100;pointer-events:none;opacity:0;transition:opacity .3s;}
.pin-indicator.show{opacity:1;}
.pin-marker{position:absolute;transform:translate(-50%,-100%);z-index:50;pointer-events:all;cursor:pointer;}
.pin-bubble{position:absolute;transform:translate(-50%,-100%) translateY(-30px);background:var(--surface);border:1px solid var(--border);border-radius:10px;padding:8px 10px;min-width:140px;max-width:200px;z-index:60;pointer-events:none;display:none;box-shadow:0 4px 20px rgba(0,83,54,.12);}
.pb-text{font-size:11px;color:var(--text);line-height:1.5;word-break:break-all;}
.pb-author{font-size:10px;color:var(--dim);margin-top:4px;}
.pin-popup{position:fixed;z-index:300;background:var(--surface);border:1px solid rgba(0,83,54,.25);border-radius:12px;padding:14px;width:240px;box-shadow:0 8px 32px rgba(0,83,54,.15);display:none;}
.pin-popup.show{display:block;}
.pp-label{font-size:11px;color:var(--accent);font-family:var(--font-headline);letter-spacing:.08em;margin-bottom:8px;}
.pp-ta{width:100%;background:var(--surface-low);border:1px solid var(--border);border-radius:8px;color:var(--text);font-family:var(--font-body);font-size:12px;padding:8px;resize:none;outline:none;}
.pp-ta:focus{border-color:rgba(0,83,54,.4);}
.pp-actions{display:flex;justify-content:flex-end;gap:6px;margin-top:8px;}
.pp-btn{padding:5px 12px;border-radius:6px;font-size:11px;font-family:var(--font-body);cursor:pointer;border:1px solid var(--border);}
.pp-cancel{background:none;color:var(--dim);}
.pp-submit{background:var(--accent);color:#fff;border-color:var(--accent);font-weight:500;}

/* ── Search ── */
.floating-search{
  position:fixed;
  top:16px;
  left:calc(var(--sidebar-w) + 32px);
  z-index:110;
  width:min(360px, calc(100vw - var(--sidebar-w) - 60px));
}
#search-wrap{position:relative;width:100%;max-width:none;display:flex;flex-direction:column;align-items:stretch;gap:4px;pointer-events:all;}
#search-box{display:flex;align-items:center;background:var(--surface);border:1px solid var(--border);border-radius:10px;padding:6px 12px;gap:8px;width:100%;transition:border-color .2s;box-shadow:0 2px 12px rgba(0,83,54,.08);}
#search-box:focus-within{border-color:rgba(0,83,54,.4);}
#search-icon{color:var(--dim);display:inline-flex;align-items:center;justify-content:center;flex-shrink:0;}
#search-icon svg{width:14px;height:14px;display:block;}
#search-input{background:none;border:none;outline:none;color:var(--text);font-family:var(--font-body);font-size:13px;width:100%;}
#search-input::placeholder{color:var(--dim);}
#search-results{position:absolute;top:calc(100% + 4px);left:0;right:0;background:var(--surface);border:1px solid var(--border);border-radius:10px;overflow:hidden;box-shadow:0 6px 24px rgba(0,83,54,.1);display:none;z-index:300;}
#search-results.show{display:block;}
.sr-item{display:flex;align-items:center;gap:10px;padding:8px 12px;cursor:pointer;transition:background .15s;}
.sr-item:hover{background:var(--accent-pale);}
.sr-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0;}
.sr-title{font-size:12px;color:var(--text);}
.sr-meta{font-size:10px;color:var(--dim);}
.sr-empty{padding:10px 12px;font-size:12px;color:var(--dim);text-align:center;}

/* ── Sub island clickable ── */
.sub-island{cursor:pointer!important;pointer-events:all!important;}
.sub-island:hover{filter:brightness(.92);}

/* ── Sidebar Actions ── */
.sidebar-actions{
  display:flex;
  flex-direction:column;
  gap:14px;
  align-items:stretch;
  margin-top:10px;
  min-height:0;
  flex:1;
}
.sidebar-primary,
.sidebar-secondary{
  display:flex;
  flex-direction:column;
  gap:10px;
}
.sidebar-secondary{
  margin-top:auto;
}
.sidebar-about-card{
  appearance:none;
  width:100%;
  text-align:left;
  display:flex;
  flex-direction:column;
  gap:4px;
  padding:10px 12px;
  border-radius:12px;
  border:1px solid var(--border);
  background:var(--surface-low);
  text-decoration:none;
  color:inherit;
  transition:background .15s, border-color .15s;
  cursor:pointer;
  font:inherit;
}
.sidebar-about-card:hover{background:var(--accent-pale);border-color:rgba(1,110,73,.24);}
.sidebar-about-title{font-family:var(--font-label);font-size:12px;font-weight:700;color:var(--accent);}
.sidebar-about-desc{font-size:11px;color:var(--dim);line-height:1.5;}
.about-overlay{
  position:fixed;
  inset:0;
  z-index:420;
  display:flex;
  align-items:center;
  justify-content:center;
  padding:32px;
  background:rgba(27,29,15,.32);
  backdrop-filter:blur(6px);
}
.about-overlay[hidden]{display:none !important;}
.about-panel{
  position:relative;
  width:min(760px, calc(100vw - 64px));
  max-height:calc(100vh - 64px);
  overflow-y:auto;
  padding:34px 34px 30px;
  border-radius:28px;
  background:#fff;
  border:1px solid rgba(1,110,73,.12);
  box-shadow:0 24px 60px rgba(27,29,15,.12);
}
.about-close{
  position:absolute;
  top:18px;
  right:18px;
  width:38px;
  height:38px;
  border:none;
  border-radius:999px;
  background:rgba(1,110,73,.08);
  color:var(--accent);
  display:inline-flex;
  align-items:center;
  justify-content:center;
  cursor:pointer;
}
.about-close svg{width:18px;height:18px;}
.about-eyebrow{
  font-size:12px;
  font-family:var(--font-label);
  font-weight:700;
  letter-spacing:.12em;
  color:var(--secondary);
}
.about-title{
  margin:10px 0 12px;
  font-family:var(--font-headline);
  font-size:34px;
  line-height:1.3;
  color:var(--text);
}
.about-lead{
  margin:0 0 24px;
  font-size:15px;
  line-height:1.9;
  color:var(--dim);
}
.about-section{
  padding:22px 24px;
  border-radius:22px;
  background:var(--surface);
  border:1px solid rgba(1,110,73,.1);
}
.about-section-title{
  margin:0 0 18px;
  font-family:var(--font-headline);
  font-size:22px;
  line-height:1.4;
  color:var(--text);
}
.about-steps{
  display:flex;
  flex-direction:column;
  gap:14px;
  margin:0;
  padding:0;
  list-style:none;
}
.about-step{
  display:flex;
  align-items:flex-start;
  gap:14px;
  padding:18px 18px 16px;
  border-radius:18px;
  background:#fff;
  border:1px solid rgba(1,110,73,.1);
}
.about-step-num{
  width:32px;
  height:32px;
  border-radius:999px;
  background:var(--accent);
  color:#fff;
  font-family:var(--font-label);
  font-size:13px;
  font-weight:700;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  flex-shrink:0;
}
.about-step-title{
  font-family:var(--font-headline);
  font-size:18px;
  line-height:1.4;
  margin-bottom:6px;
  color:var(--text);
}
.about-step p{
  margin:0;
  font-size:14px;
  line-height:1.8;
  color:var(--dim);
}
.sidebar-random-work-card{
  display:flex;
  flex-direction:column;
  gap:10px;
  padding:12px;
  border-radius:16px;
  border:1px solid rgba(1,110,73,.14);
  background:rgba(255,255,255,.92);
  box-shadow:0 8px 20px rgba(31,40,34,.08);
  text-decoration:none;
  color:inherit;
  transition:transform .18s ease, box-shadow .18s ease, border-color .18s ease, background .18s ease;
}
.sidebar-random-work-card:hover{
  transform:translateY(-1px);
  box-shadow:0 12px 24px rgba(31,40,34,.12);
  border-color:rgba(1,110,73,.24);
  background:#fff;
}
.sidebar-random-work-head{
  display:flex;
  align-items:center;
  justify-content:flex-start;
}
.sidebar-random-work-badge{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-height:22px;
  padding:0 10px;
  border-radius:999px;
  background:rgba(237,168,51,.16);
  color:#8c4b00;
  font-family:var(--font-label);
  font-size:11px;
  font-weight:700;
}
.sidebar-random-work-image-wrap{
  width:100%;
  aspect-ratio:1 / 1;
  border-radius:12px;
  overflow:hidden;
  background:var(--surface-low);
  border:1px solid var(--border);
}
.sidebar-random-work-image{
  width:100%;
  height:100%;
  object-fit:cover;
  display:block;
}
.sidebar-random-work-title{
  font-family:var(--font-headline);
  font-size:14px;
  line-height:1.45;
  color:var(--text);
  display:-webkit-box;
  -webkit-line-clamp:2;
  -webkit-box-orient:vertical;
  overflow:hidden;
}
.sidebar-random-work-author{
  font-size:12px;
  color:var(--dim);
  line-height:1.4;
}
.sidebar-login-bottom{
  margin-top:auto;
}
.nav-notice{position:relative;}
.nav-notice-badge{
  min-width:18px;
  height:18px;
  padding:0 5px;
  display:inline-flex;
  border-radius:999px;
  background:#c95b34;
  color:#fff;
  font-size:10px;
  font-family:var(--font-label);
  font-weight:700;
  align-items:center;
  justify-content:center;
  line-height:1;
  margin-left:6px;
}
.nav-notice-menu{
  position:absolute;
  top:44px;
  right:0;
  width:280px;
  max-height:340px;
  overflow:auto;
  display:none;
  flex-direction:column;
  gap:6px;
  padding:8px;
  border-radius:16px;
  border:1px solid rgba(1,83,54,.12);
  background:#fff;
  box-shadow:0 16px 40px rgba(16,36,27,.12);
  z-index:30;
}
.nav-notice-menu.open{display:flex;}
.nav-notice-item{
  display:block;
  padding:10px 12px;
  border-radius:12px;
  text-decoration:none;
  color:inherit;
  background:#f7faf7;
}
.nav-notice-item.unread{background:#edf7f1;}
.nav-notice-title{
  font-family:var(--font-label);
  font-size:12px;
  font-weight:700;
  color:var(--text);
}
.nav-notice-meta{
  margin-top:3px;
  font-size:11px;
  color:var(--dim);
}
.nav-notice-empty{
  padding:12px;
  font-size:12px;
  color:var(--dim);
}
.nav-user{font-family:var(--font-label);font-size:12px;font-weight:700;color:var(--accent);}
.nav-logout-form{display:flex;width:100%;}
.nav-btn{
  width:100%;
  min-height:44px;
  padding:0 14px;border-radius:12px;
  font-family:var(--font-body);font-size:13px;
  cursor:pointer;border:1.5px solid var(--border);
  transition:all .15s;background:var(--surface-lowest);color:var(--text);
  box-shadow:0 1px 4px rgba(0,83,54,.06);
  display:flex;align-items:center;justify-content:flex-start;gap:10px;
  text-decoration:none;
}
.nav-row-btn svg{width:18px;height:18px;display:block;flex-shrink:0;}
.nav-row-btn span{line-height:1;}
.nav-row-btn{white-space:nowrap;}
.nav-btn:hover{background:var(--accent-pale);border-color:rgba(0,83,54,.3);color:var(--accent);}
.nav-logout{background:var(--surface-lowest);}
.nav-theme{background:var(--surface);}
[data-theme="dark"] .nav-btn{box-shadow:0 8px 20px rgba(0,0,0,.24);}
.nav-post{
  background:var(--accent);color:#fff;
  border-color:var(--accent);font-weight:700;
  box-shadow:0 2px 10px rgba(0,83,54,.25);
}
.nav-post:hover{background:var(--accent2);box-shadow:0 4px 16px rgba(0,83,54,.4);}
.nav-pin-toggle{
  background:rgba(1,110,73,.12);
  border-style:solid;
  border-color:rgba(1,110,73,.28);
  color:var(--accent);
  box-shadow:none;
  justify-content:space-between;
}
.nav-pin-toggle:hover{
  background:rgba(1,110,73,.16);
  border-color:rgba(1,110,73,.34);
  color:var(--accent);
  box-shadow:none;
}
.nav-pin-toggle-copy{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:8px;
  flex:1;
}
.nav-pin-toggle.pins-hidden{
  background:rgba(245,245,245,.92);
  border-style:dashed;
  border-color:rgba(94,126,107,.28);
  color:var(--secondary);
}
html.sidebar-collapsed .sidebar-brand-word{
  width:44px;
  min-width:44px;
  padding:0;
  justify-content:center;
  overflow:hidden;
  color:transparent;
  opacity:0;
}
html.sidebar-collapsed .sidebar-collapse-btn{
  position:absolute;
  top:0;
  left:0;
  width:44px;
  min-width:44px;
  height:44px;
  z-index:2;
}
html.sidebar-collapsed .sidebar-collapse-btn svg{
  transform:rotate(180deg);
}
html.sidebar-collapsed .nav-row-btn span{
  display:none;
}
html.sidebar-collapsed .sidebar-about-card,
html.sidebar-collapsed .sidebar-random-work-card{
  display:none;
}
html.sidebar-collapsed .nav-btn{
  justify-content:center;
  padding:0;
}
html.sidebar-collapsed .nav-notice-badge{
  position:absolute;
  top:4px;
  right:4px;
  margin-left:0;
}
html.sidebar-collapsed .nav-notice-menu{
  left:calc(100% + 8px);
  right:auto;
}

@media (max-width: 980px){
  :root{--sidebar-w:176px;--sidebar-w-expanded:176px;}
  .floating-search{
    width:min(300px, calc(100vw - var(--sidebar-w) - 52px));
  }
}
@media (max-width: 1180px){
  .map-feed-sidebar{display:none;}
  .zoom-controls{right:24px;}
  #minimap-wrap{right:24px;}
}
@media (max-width: 760px){
  .about-overlay{
    padding:16px;
  }
  .about-panel{
    width:100%;
    max-height:calc(100vh - 32px);
    padding:28px 20px 22px;
  }
  .about-title{
    font-size:28px;
  }
  .about-section{
    padding:18px 16px;
  }
}

/* ── Post Overlay ── */
#post-overlay{
  position:fixed;inset:0;z-index:500;
  display:none;flex-direction:column;
  height:100dvh;
  max-height:100dvh;
  overflow:hidden;
  background:#f5f3ee;
  animation:overlayIn .25s ease;
}
#post-overlay.open{display:flex;}
[data-theme="dark"] #post-overlay{background:#0d1114;}

/* 新規登録・ログインモーダル */
#auth-modal-wrap{
  position:fixed;inset:0;z-index:600;
  display:none;align-items:center;justify-content:center;
  background:rgba(27,29,15,.45);
  backdrop-filter:blur(4px);
  animation:fadeIn .2s ease;
}
#auth-modal-wrap.open{display:flex;}
[data-theme="dark"] #auth-modal-wrap{background:rgba(0,0,0,.55);}
@keyframes fadeIn{from{opacity:0;}to{opacity:1;}}
.auth-modal{
  background:var(--surface);
  border-radius:16px;
  padding:40px 44px;
  width:420px;
  box-shadow:0 24px 64px rgba(27,29,15,.18);
  position:relative;
  animation:slideUp .22s ease;
}
@keyframes slideUp{from{opacity:0;transform:translateY(16px);}to{opacity:1;transform:translateY(0);}}
.auth-close{
  position:absolute;top:16px;right:16px;
  width:30px;height:30px;border-radius:50%;
  background:none;border:none;cursor:pointer;
  display:flex;align-items:center;justify-content:center;
  color:var(--on-surface-dim);font-size:16px;
  transition:background .15s;
}
.auth-close:hover{background:var(--surface-low);}
.auth-logo{
  display:flex;align-items:center;gap:7px;
  font-family:var(--font-headline);font-weight:700;font-size:16px;
  color:var(--accent);margin-bottom:24px;
}
.auth-logo-pip{
  width:8px;height:8px;border-radius:50%;
  background:var(--tertiary-bright);
}
.auth-title{
  font-family:var(--font-headline);font-weight:700;
  font-size:22px;letter-spacing:-.02em;
  color:var(--on-surface);margin-bottom:6px;
}
.auth-sub{
  font-size:13px;color:var(--on-surface-dim);
  line-height:1.7;margin-bottom:28px;
}
.auth-field{margin-bottom:16px;}
.auth-label{
  display:block;
  font-family:var(--font-label);font-size:11px;font-weight:500;
  color:var(--on-surface-dim);letter-spacing:.05em;
  margin-bottom:6px;
}
.auth-input{
  width:100%;height:44px;
  background:var(--surface-lowest);
  border:1px solid var(--outline-variant);
  border-radius:var(--radius-md);
  padding:0 14px;
  font-family:var(--font-body);font-size:14px;
  color:var(--on-surface);outline:none;
  transition:border-color .2s,box-shadow .2s;
}
.auth-input:focus{
  border-color:rgba(0,83,54,.35);
  box-shadow:0 0 0 3px rgba(0,83,54,.08);
}
.auth-input::placeholder{color:var(--on-surface-dim);opacity:.34;}
.auth-input.error{border-color:var(--tertiary);}
.auth-error{
  font-family:var(--font-label);font-size:11px;
  color:var(--tertiary);margin-top:4px;
  display:none;
}
.auth-error.show{display:block;}
.auth-banner{
  margin:14px 0 18px;
  padding:10px 12px;
  border-radius:12px;
  font-family:var(--font-body);
  font-size:12px;
  line-height:1.6;
}
.auth-banner-error{
  background:#fff3ea;
  color:#8b421d;
  border:1px solid rgba(190,100,64,.22);
}
.auth-submit{
  width:100%;height:46px;margin-top:8px;
  background:var(--accent-grad);color:#fff;
  border:none;border-radius:var(--radius-md);
  font-family:var(--font-label);font-size:14px;font-weight:500;
  cursor:pointer;
  box-shadow:0 4px 16px rgba(0,83,54,.25);
  transition:all .2s;
}
.auth-submit:hover{opacity:.92;box-shadow:0 6px 20px rgba(0,83,54,.35);}
.auth-divider{
  display:flex;align-items:center;gap:10px;
  margin:20px 0;
  font-family:var(--font-label);font-size:11px;color:var(--on-surface-dim);
}
.auth-divider::before,.auth-divider::after{
  content:'';flex:1;height:1px;
  background:var(--outline-variant);
}
.auth-switch{
  text-align:center;
  font-family:var(--font-label);font-size:12px;
  color:var(--on-surface-dim);margin-top:18px;
}
.auth-switch a{
  color:var(--accent);cursor:pointer;
  text-decoration:underline;text-underline-offset:3px;
}
.auth-terms{
  font-size:11px;color:var(--on-surface-dim);
  line-height:1.65;margin-top:14px;text-align:center;
  font-family:var(--font-label);
}
.auth-terms a{color:var(--accent);cursor:pointer;}

.post-header{
  height:52px;flex-shrink:0;
  display:flex;align-items:center;gap:16px;
  padding:0 20px;
  background:#fff;
  border-bottom:1px solid var(--border);
  box-shadow:0 1px 4px rgba(0,83,54,.06);
}
.post-header-title{
  font-family:var(--font-headline);font-weight:700;font-size:15px;
  color:var(--text);letter-spacing:.04em;
}

.post-body{
  flex:1 1 auto;
  display:flex;
  overflow:hidden;
  min-height:0;
  height:calc(100dvh - 52px);
}

/* 左：画像アップロード */
.post-image-pane{
  flex:0 0 50%;
  display:flex;flex-direction:column;
  border-right:1px solid var(--border);
  background:#eef0f8;
  padding:32px;
  min-height:0;
}
.upload-area{
  flex:1 1 0;
  min-height:0;
  border:2px dashed rgba(0,83,54,.25);
  border-radius:16px;
  background:#fff;
  position:relative;
  display:flex;align-items:center;justify-content:center;
  transition:border-color .2s,background .2s;
  cursor:pointer;
  overflow:hidden;
}
.upload-area:hover,.upload-area.dragover{
  border-color:rgba(0,83,54,.5);
  background:var(--accent-pale);
}
.upload-placeholder{
  display:flex;flex-direction:column;align-items:center;gap:8px;
  color:var(--dim);font-family:var(--font-body);
  pointer-events:none;
}
.upload-icon{width:48px;height:48px;opacity:.52;margin-bottom:4px;color:var(--secondary);}
.upload-icon svg{width:100%;height:100%;display:block;}
.upload-text{font-size:14px;color:var(--text);font-weight:500;}
.upload-sub{font-size:12px;}
.upload-btn{
  pointer-events:all;
  padding:8px 20px;border-radius:8px;
  background:var(--accent);color:#fff;
  font-family:var(--font-body);font-size:13px;font-weight:700;
  border:none;cursor:pointer;
  box-shadow:0 2px 8px rgba(0,83,54,.25);
  transition:background .15s;
}
.upload-btn:hover{background:var(--accent2);}
.upload-hint{font-size:11px;color:var(--dim);margin-top:4px;}
.preview-img{
  max-width:100%;max-height:100%;
  width:auto;height:auto;
  object-fit:contain;
  border-radius:14px;
}
.upload-area.has-preview{cursor:pointer;}
.upload-area.editing-locked{
  cursor:default;
}
.upload-area.editing-locked:hover,
.upload-area.editing-locked.dragover{
  border-color:rgba(0,83,54,.25);
  background:#fff;
}
.upload-area.editing-locked .preview-remove{
  display:none !important;
}
.preview-remove{
  position:absolute;top:12px;right:12px;
  width:28px;height:28px;border-radius:50%;
  background:rgba(0,0,0,.5);color:#fff;
  border:none;cursor:pointer;font-size:12px;
  display:flex;align-items:center;justify-content:center;
  transition:background .15s;
}
.preview-remove:hover{background:rgba(0,0,0,.75);}

/* 右：フォーム */
.post-form-pane{
  flex:1;display:flex;flex-direction:column;
  overflow:hidden;background:#f5f3ee;
  min-height:0;
}
.post-form-scroll{
  flex:1 1 auto;
  min-height:0;
  overflow-y:auto;
  overscroll-behavior:contain;
  padding:28px 24px;
  display:flex;flex-direction:column;gap:20px;
}
.post-form-scroll::-webkit-scrollbar{width:5px;}
.post-form-scroll::-webkit-scrollbar-thumb{background:rgba(0,83,54,.15);border-radius:3px;}

.pf-group{display:flex;flex-direction:column;gap:6px;}
.pf-label{
  font-family:var(--font-headline);font-size:12px;font-weight:700;
  color:var(--text);letter-spacing:.06em;
  display:flex;align-items:center;gap:6px;
}
.pf-required{
  font-size:10px;font-family:var(--font-body);font-weight:400;
  background:rgba(0,83,54,.1);color:var(--accent);
  padding:1px 6px;border-radius:4px;letter-spacing:0;
}
.pf-optional{
  font-size:10px;font-family:var(--font-body);font-weight:400;
  background:var(--surface-low);color:var(--dim);
  padding:1px 6px;border-radius:4px;letter-spacing:0;
}
.pf-input,.pf-ta{
  background:#fff;
  border:1.5px solid var(--border);border-radius:10px;
  color:var(--text);font-family:var(--font-body);
  font-size:13px;line-height:1.6;
  padding:10px 14px;outline:none;
  transition:border-color .2s;
  width:100%;
}
.pf-input:focus,.pf-ta:focus{border-color:rgba(0,83,54,.4);}
.pf-input::placeholder,.pf-ta::placeholder{color:var(--dim);}
.pf-ta{resize:none;}
.pf-counter{font-size:11px;color:var(--dim);text-align:right;font-family:var(--font-body);}
.pf-hint{font-size:11px;color:var(--dim);font-family:var(--font-body);}

/* タグ入力 */
.tag-input-wrap{
  background:#fff;
  border:1.5px solid var(--border);border-radius:10px;
  padding:8px 10px;
  display:flex;flex-wrap:wrap;gap:6px;
  cursor:text;
  transition:border-color .2s;
  min-height:44px;
}
.tag-input-wrap:focus-within{border-color:rgba(0,83,54,.4);}
.tag-item{
  display:flex;align-items:center;gap:4px;
  background:var(--accent-pale);color:var(--accent);
  border:1px solid rgba(0,83,54,.2);
  border-radius:6px;padding:3px 8px;
  font-size:12px;font-family:var(--font-body);
}
.tag-remove{
  background:none;border:none;cursor:pointer;
  color:var(--dim);font-size:12px;line-height:1;
  padding:0 2px;transition:color .15s;
}
.tag-remove:hover{color:var(--accent);}
.tag-input{
  border:none;outline:none;background:none;
  color:var(--text);font-family:var(--font-body);font-size:13px;
  min-width:120px;flex:1;
}
.tag-input::placeholder{color:var(--dim);}

/* ジャンル選択 */
.genre-select{display:flex;gap:8px;}
.gs-btn{
  flex:1;padding:12px 8px;border-radius:10px;
  border:1.5px solid var(--border);
  background:#fff;color:var(--text);
  font-family:var(--font-body);font-size:13px;
  cursor:pointer;transition:all .15s;
  display:flex;align-items:center;justify-content:center;gap:8px;
  box-shadow:0 1px 4px rgba(30,40,120,.06);
}
.gs-btn:hover{border-color:rgba(0,83,54,.3);background:var(--accent-pale);}
.gs-btn.selected{
  border-color:var(--accent);
  background:var(--accent-pale);
  color:var(--accent);font-weight:700;
  box-shadow:0 0 0 3px rgba(0,83,54,.1);
}
.gs-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0;}

/* サブジャンル選択 */
.sub-select{display:flex;flex-wrap:wrap;gap:8px;}
.ss-btn{
  padding:8px 14px;border-radius:8px;
  border:1.5px solid var(--border);
  background:#fff;color:var(--text);
  font-family:var(--font-body);font-size:12px;
  cursor:pointer;transition:all .15s;
}
.ss-btn:hover{border-color:rgba(0,83,54,.3);background:var(--accent-pale);}
.ss-btn.selected{
  border-color:var(--accent);background:var(--accent-pale);
  color:var(--accent);font-weight:700;
}

/* 送信ボタン */
.pf-check{
  display:flex;
  align-items:center;
  gap:10px;
  font-size:13px;
  color:var(--text);
  font-family:var(--font-body);
}
.pf-check input{
  width:16px;
  height:16px;
  accent-color:var(--accent);
}
.pf-submit-wrap{padding-top:8px;}
.pf-submit{
  width:100%;padding:14px;border-radius:12px;
  background:var(--accent);color:#fff;
  font-family:var(--font-headline);font-weight:700;font-size:14px;
  letter-spacing:.04em;border:none;cursor:pointer;
  box-shadow:0 4px 16px rgba(0,83,54,.3);
  transition:all .2s;
}
.pf-submit:hover{background:var(--accent2);box-shadow:0 6px 20px rgba(0,83,54,.4);transform:translateY(-1px);}
.pf-submit:disabled{background:var(--dim);box-shadow:none;cursor:not-allowed;transform:none;}

/* ── Comment Feed（右サイドパネル） ── */











/* 空状態 */



/* コメントカード */



/* 左のアクセントライン */











 



#detail-overlay{
  position:fixed;inset:0;z-index:500;
  display:none;flex-direction:column;
  background:var(--bg);
  animation:overlayIn .22s ease;
}
#detail-overlay.open{display:flex;}
@keyframes overlayIn{from{opacity:0;transform:translateY(8px);}to{opacity:1;transform:translateY(0);}}

.detail-header{
  height:56px;flex-shrink:0;
  display:flex;align-items:center;gap:14px;
  padding:0 24px;
  border-bottom:1px solid rgba(190,201,192,0.15);
  background:var(--surface);
}
.detail-back{
  display:flex;align-items:center;gap:5px;
  background:none;border:none;
  color:var(--dim);font-family:var(--font-body);font-size:12px;
  cursor:pointer;padding:6px 10px;border-radius:8px;
  transition:background .15s,color .15s;white-space:nowrap;
}
.detail-back:hover{background:var(--accent-pale);color:var(--accent);}
.detail-back svg{flex-shrink:0;}
.dh-sep{width:1px;height:20px;background:var(--border);flex-shrink:0;}
.detail-header-title{
  font-family:var(--font-headline);font-weight:600;font-size:15px;
  color:var(--text);letter-spacing:-.2px;
}
.detail-header-author{
  font-size:12px;color:var(--dim);
  font-family:var(--font-body);
}
.detail-header-genre{
  margin-left:auto;
  padding:4px 12px;border-radius:20px;
  font-family:var(--font-body);font-size:11px;font-weight:500;
}
.detail-owner-menu{
  position:relative;
  margin-left:10px;
}
.detail-owner-trigger{
  width:34px;height:34px;
  border:1px solid var(--border);
  border-radius:10px;
  background:#fff;
  display:flex;align-items:center;justify-content:center;gap:3px;
  cursor:pointer;
  box-shadow:var(--shadow-ambient);
}
.detail-owner-trigger span{
  width:4px;height:4px;border-radius:50%;
  background:var(--dim);
  display:block;
}
.detail-owner-dropdown{
  position:absolute;
  top:calc(100% + 8px);
  right:0;
  min-width:132px;
  padding:6px;
  border:1px solid var(--border);
  border-radius:12px;
  background:#fff;
  box-shadow:0 16px 40px rgba(27,29,15,.12);
  display:none;
  flex-direction:column;
  gap:4px;
  z-index:80;
}
.detail-owner-menu.open .detail-owner-dropdown{display:flex;}
.detail-owner-action{
  border:none;
  background:#fff;
  color:var(--text);
  border-radius:8px;
  padding:9px 12px;
  font-size:12px;
  text-align:left;
  cursor:pointer;
  font-family:var(--font-body);
}
.detail-owner-action:hover{background:var(--surface-low);}
.detail-owner-action.danger{color:#8b421d;}
.detail-owner-action.danger:hover{background:#fff3ea;}

.detail-body{flex:1;display:flex;overflow:hidden;position:relative;min-height:0;}

/* 左右ナビ矢印 */
.work-nav-btn{
  position:absolute;top:50%;transform:translateY(-50%);
  width:40px;height:64px;
  background:rgba(255,255,255,.88);
  border:1px solid var(--outline-variant);
  border-radius:var(--radius-md);
  display:flex;align-items:center;justify-content:center;
  cursor:pointer;z-index:40;
  transition:all .18s;
  backdrop-filter:blur(8px);
  box-shadow:var(--shadow-ambient);
  color:var(--on-surface-dim);
}
.work-nav-btn:hover{
  background:#fff;
  color:var(--accent);
  border-color:rgba(0,83,54,.25);
  box-shadow:0 8px 24px rgba(0,83,54,.12);
}
.work-nav-btn:disabled{
  opacity:.25;cursor:not-allowed;
  box-shadow:none;
}
.work-nav-btn svg{width:18px;height:18px;flex-shrink:0;}
.work-nav-prev{left:8px;}
.work-nav-next{right:calc(36% + 8px);}
.work-nav-tooltip{
  position:absolute;
  background:var(--on-surface);color:#fff;
  font-family:var(--font-label);font-size:11px;
  padding:5px 10px;border-radius:6px;
  white-space:nowrap;pointer-events:none;
  opacity:0;transition:opacity .15s;
  bottom:calc(100% + 6px);left:50%;transform:translateX(-50%);
  z-index:20;
}
.work-nav-btn:hover .work-nav-tooltip{opacity:1;}

/* LEFT PANE */
.image-pane{
  flex:0 0 64%;
  display:flex;flex-direction:column;
  border-right:1px solid var(--border);
  background:#ffffff;
  overflow:hidden;
  position:relative;
  min-height:0;
}
.image-wrap{
  flex:1 1 0;
  min-height:0;
  position:relative;
  overflow:hidden;
  cursor:default;
  display:flex;align-items:center;justify-content:center;
  padding:24px;
}
.image-wrap img{
  max-width:100%;max-height:100%;
  object-fit:contain;
  border-radius:10px;
  display:block;
  pointer-events:none;user-select:none;
  box-shadow:0 8px 40px rgba(0,83,54,.18);
}
#pin-layer{position:absolute;inset:0;pointer-events:none;}
.detail-image-controls{
  position:absolute;
  right:20px;
  bottom:20px;
  display:flex;
  align-items:center;
  gap:8px;
  z-index:25;
}

/* ── ピン基本スタイル ── */
.pin-circle{
  position:absolute;
  width:30px;height:30px;border-radius:50%;
  transform:translate(-50%,-50%);
  display:flex;align-items:center;justify-content:center;
  font-family:var(--font-label);font-weight:700;font-size:11px;
  cursor:pointer;pointer-events:all;
  transition:transform .15s,box-shadow .15s;
  z-index:10;
}
.pin-circle:hover{transform:translate(-50%,-50%) scale(1.18);}
.pin-circle[data-tooltip]:hover::after{
  content:attr(data-tooltip);
  position:absolute;
  left:50%;
  bottom:calc(100% + 10px);
  transform:translateX(-50%);
  min-width:120px;
  max-width:220px;
  padding:9px 11px;
  border-radius:10px;
  background:rgba(27,29,15,.94);
  color:#fff;
  font-family:var(--font-body);
  font-size:12px;
  font-weight:400;
  line-height:1.55;
  text-align:left;
  white-space:normal;
  box-shadow:0 10px 30px rgba(27,29,15,.22);
  pointer-events:none;
  z-index:30;
}

/* 他人のピン: 紫・枠なし */
.pin-circle.pin-others{
  background:#001B44;
  border:none;
  color:#fff;
  box-shadow:0 3px 10px rgba(0,27,68,.45);
}
.pin-circle.pin-others:hover{box-shadow:0 5px 18px rgba(0,27,68,.6);}

/* 自分のピン: 紫・白枠 */
.pin-circle.pin-mine{
  background:#001B44;
  border:2.5px solid #fff;
  color:#fff;
  box-shadow:0 3px 12px rgba(0,27,68,.5);
}
.pin-circle.pin-mine:hover{box-shadow:0 5px 20px rgba(0,27,68,.65);}

/* 投稿者のピン: アンバーゴールド・枠なし */
.pin-circle.pin-author{
  background:#EDA833;
  border:none;
  color:#fff;
  box-shadow:0 3px 12px rgba(237,168,51,.5);
}
.pin-circle.pin-author:hover{box-shadow:0 5px 20px rgba(237,168,51,.65);}

/* アクティブ状態（共通）: 白抜き・枠がそれぞれの色 */
.pin-circle.pin-others.active{
  background:#fff;border:2.5px solid #001B44;color:#001B44;
  box-shadow:0 0 0 4px rgba(0,27,68,.15);
}
.pin-circle.pin-mine.active{
  background:#fff;border:2.5px solid #001B44;color:#001B44;
  box-shadow:0 0 0 4px rgba(0,27,68,.15);
}
.pin-circle.pin-author.active{
  background:#fff;border:2.5px solid #EDA833;color:#EDA833;
  box-shadow:0 0 0 4px rgba(237,168,51,.18);
}

/* pending（仮置き）: 自分のピンと同じ紫 + 白枠 */
.pin-circle.pending-pin{
  background:#001B44;
  border:2.5px solid #fff;
  color:#fff;
  box-shadow:0 4px 16px rgba(0,27,68,.42);
  animation:pendingPulse .9s ease-in-out infinite alternate;
}
@keyframes pendingPulse{
  from{box-shadow:0 0 0 0 rgba(0,27,68,.34);}
  to{box-shadow:0 0 0 10px rgba(0,27,68,0);}
}

.image-guide{
  flex-shrink:0;padding:9px 20px;
  font-size:11px;color:var(--dim);
  font-family:var(--font-body);
  border-top:1px solid var(--border);
  background:var(--surface);
  display:flex;align-items:center;gap:8px;
}
.detail-meta{
  flex-shrink:0;
  padding:16px 20px 14px;
  border-top:1px solid rgba(190,201,192,0.15);
  background:#fff;
  display:flex;
  flex-direction:column;
  gap:12px;
  cursor:default;
}
.detail-meta-copy{
  font-size:13px;
  line-height:1.75;
  color:var(--text);
  font-family:var(--font-body);
  cursor:text;
  user-select:text;
}
.detail-meta-tags{
  display:flex;
  flex-wrap:wrap;
  gap:8px;
  cursor:default;
}
.detail-tag{
  display:inline-flex;
  align-items:center;
  padding:5px 10px;
  border-radius:999px;
  background:var(--accent-pale);
  border:1px solid rgba(1,83,54,.14);
  color:var(--accent);
  font-size:11px;
  font-family:var(--font-label);
  letter-spacing:.02em;
  cursor:default;
}
.pin-toggle-inline{
  position:static !important;
  bottom:auto !important;left:auto !important;
  margin-left:auto;
  padding:5px 11px;
  font-size:11px;
  box-shadow:none;
  border-radius:var(--radius-sm);
}
.detail-pin-toggle{
  position:static !important;
  bottom:auto !important;
  left:auto !important;
  align-self:flex-end;
  margin:0 20px 10px auto;
  min-height:38px;
  padding:0 14px;
  background:rgba(255,255,255,.92);
  box-shadow:0 10px 28px rgba(27,29,15,.12);
}
.detail-pin-toggle:hover{
  background:#fff;
}
.guide-pip{
  width:7px;height:7px;border-radius:50%;
  background:var(--accent);flex-shrink:0;
  animation:pulse 1.8s ease-out infinite;
}

/* RIGHT PANE */
.comment-pane{
  flex:1;display:flex;flex-direction:column;
  overflow:hidden;background:var(--surface-low);
  min-height:0;
}

/* 入力エリア */
.pin-input-area{
  flex-shrink:0;padding:18px;
  border-bottom:1px solid rgba(190,201,192,0.15);
  background:var(--surface);
}
.pin-input-area.is-idle{
  display:none;
}
.pia-waiting{
  display:flex;align-items:flex-start;gap:11px;padding:14px 16px;
  border:1.5px dashed rgba(0,83,54,.22);border-radius:12px;
  color:var(--dim);font-size:12px;
  font-family:var(--font-body);line-height:1.65;
  background:var(--accent-pale);
}
.pia-waiting-dot{
  width:8px;height:8px;border-radius:50%;
  background:var(--accent);flex-shrink:0;margin-top:5px;
  animation:pulse 1.8s ease-out infinite;
}
.pia-form{display:none;flex-direction:column;gap:10px;}
.pia-form.show{display:flex;}
.pia-label-wrap{display:flex;flex-direction:column;gap:4px;}
.pia-label{
  display:flex;align-items:center;gap:9px;
  font-family:var(--font-headline);font-size:11px;
  color:var(--dim);letter-spacing:.06em;font-weight:500;text-transform:uppercase;
}
.pia-label label{cursor:text;}
.pia-subtext{
  font-size:12px;
  line-height:1.5;
  color:var(--dim);
}
.pia-pin-num{
  width:26px;height:26px;border-radius:50%;
  background:var(--accent);color:#fff;
  font-family:var(--font-label);font-weight:600;font-size:12px;
  display:flex;align-items:center;justify-content:center;flex-shrink:0;
  box-shadow:0 2px 8px rgba(0,83,54,.3);
}
.pia-ta{
  width:100%;
  background:var(--bg);
  border:1px solid var(--border);border-radius:10px;
  color:var(--text);
  font-family:var(--font-body);font-size:13px;line-height:1.7;
  padding:11px 13px;resize:none;outline:none;
  transition:border-color .2s,background .2s;
}
.pia-ta:focus{border-color:rgba(0,83,54,.45);background:#fff;}
.pia-ta::placeholder{color:var(--dim);}
.pia-actions{display:flex;justify-content:space-between;align-items:center;gap:8px;}
.pia-hint{font-size:10px;color:var(--dim);font-family:var(--font-body);opacity:.8;}
.pia-btns{display:flex;gap:7px;}
.pia-btn{
  padding:7px 15px;border-radius:8px;
  font-size:12px;font-family:var(--font-body);
  cursor:pointer;border:1px solid var(--border);transition:all .15s;
}
.pia-cancel{background:var(--surface);color:var(--dim);}
.pia-cancel:hover{background:#ffffff;color:var(--text);}
.pia-submit{
  background:var(--accent);color:#fff;
  border-color:var(--accent);font-weight:500;
  box-shadow:0 2px 10px rgba(0,83,54,.22);
}
.pia-submit:hover{background:var(--accent2);box-shadow:0 4px 14px rgba(0,83,54,.35);}

.pia-image-row{
  display:flex;
  align-items:flex-start;
  gap:10px;
  flex-wrap:wrap;
}
.pia-file-input{display:none;}
.pia-img-btn{
  display:inline-flex;
  align-items:center;
  gap:6px;
  min-height:38px;
  padding:0 12px;
  border:1px dashed rgba(0,83,54,.35);
  border-radius:10px;
  font-size:12px;
  color:var(--dim);
  background:var(--surface-low);
  cursor:pointer;
  font-family:var(--font-body);
  font-weight:500;
  transition:all .15s;
}
.pia-img-btn:hover{border-color:var(--accent);color:var(--accent);background:var(--accent-pale);}
.pia-img-preview{
  display:flex;
  align-items:center;
  gap:10px;
  min-height:56px;
  padding:8px 10px;
  border:1px solid var(--border);
  border-radius:12px;
  background:var(--surface-low);
}
.pia-img-preview[hidden]{display:none;}
.pia-img-preview.is-file::before{
  content:'PDF';
  display:flex;
  align-items:center;
  justify-content:center;
  width:64px;
  height:64px;
  border-radius:8px;
  border:1px solid var(--border);
  background:var(--accent-pale);
  color:var(--accent);
  font-size:12px;
  font-family:var(--font-label);
  font-weight:700;
}
.pia-img-preview img{
  width:64px;
  height:64px;
  border-radius:8px;
  object-fit:cover;
  border:1px solid var(--border);
}
.pia-img-meta{
  display:flex;
  flex-direction:column;
  gap:6px;
  min-width:0;
}
.pia-img-name{
  max-width:160px;
  color:var(--text);
  font-size:12px;
  line-height:1.4;
  word-break:break-all;
}
.pia-img-remove{
  align-self:flex-start;
  padding:0;
  border:none;
  background:none;
  color:var(--accent);
  font-size:12px;
  font-family:var(--font-body);
  cursor:pointer;
}
.pia-img-remove:hover{text-decoration:underline;}

.ci-image{
  display:block;
  width:100%;
  max-height:240px;
  object-fit:contain;
  border-radius:10px;
  margin-top:8px;
  border:1px solid var(--border);
  background:var(--surface-lowest);
  cursor:pointer;
}
.ci-image:hover{opacity:.9;}
.ci-file{
  display:inline-flex;
  align-items:center;
  margin-top:8px;
  padding:8px 12px;
  border-radius:10px;
  border:1px solid var(--border);
  background:var(--surface-low);
  color:var(--accent);
  text-decoration:none;
  font-size:12px;
  line-height:1.4;
  word-break:break-all;
}
.ci-file:hover{background:var(--accent-pale);}

/* コメント一覧 */
.comment-list{
  flex:1;overflow-y:auto;
  padding:16px;
  display:flex;flex-direction:column;gap:8px;
}
.comment-list::-webkit-scrollbar{width:4px;}
.comment-list::-webkit-scrollbar-track{background:transparent;}
.comment-list::-webkit-scrollbar-thumb{background:rgba(0,83,54,.15);border-radius:2px;}
.comment-list::-webkit-scrollbar-thumb:hover{background:rgba(0,83,54,.3);}
.comment-empty{
  flex:1;display:flex;flex-direction:column;
  align-items:center;justify-content:center;gap:12px;padding:40px 20px;text-align:center;
}
.comment-empty-pip{
  width:44px;height:44px;border-radius:50%;
  background:var(--surface);border:1px solid var(--border);
  display:flex;align-items:center;justify-content:center;
}
.comment-empty-pip svg{width:20px;height:20px;color:var(--g3);}
.comment-empty-title{font-size:13px;font-weight:500;color:var(--text);font-family:var(--font-body);}
.comment-empty-sub{font-size:11px;color:var(--dim);font-family:var(--font-body);line-height:1.6;}
.comment-item{
  background:var(--surface);
  border:1px solid rgba(190,201,192,0.15);border-radius:12px;
  padding:13px 15px;cursor:pointer;
  transition:border-color .15s,box-shadow .15s,transform .12s;
  display:flex;flex-direction:column;gap:8px;
}
.comment-item:hover{
  border-color:rgba(0,83,54,.28);
  box-shadow:0 3px 12px rgba(0,83,54,.07);
  transform:translateY(-1px);
}
.comment-item.active{
  border-color:var(--accent);
  box-shadow:0 0 0 3px rgba(0,83,54,.1);
}
.comment-item.active{
  border-color:var(--accent);
  border-color:var(--accent);box-shadow:0 0 0 3px rgba(0,83,54,.1);
}
.ci-top{display:flex;align-items:center;gap:10px;}
.ci-pin{
  width:22px;height:22px;border-radius:50%;
  background:var(--accent);color:#fff;
  font-family:var(--font-headline);font-weight:700;font-size:11px;
  display:flex;align-items:center;justify-content:center;flex-shrink:0;
  box-shadow:0 1px 5px rgba(0,83,54,.3);
}
.ci-author{font-size:11px;color:var(--dim);font-family:var(--font-body);}
.ci-text{font-size:13px;color:var(--text);line-height:1.7;word-break:break-all;font-family:var(--font-body);}
.ci-actions{
  display:flex;
  align-items:center;
  gap:8px;
  justify-content:flex-end;
}
.ci-link-btn{
  border:none;
  background:transparent;
  color:var(--dim);
  font-family:var(--font-label);
  font-size:11px;
  cursor:pointer;
  padding:4px 2px;
  white-space:nowrap;
}
.ci-link-btn:hover{
  color:var(--accent);
}
.ci-like-btn{
  display:inline-flex;
  align-items:center;
  gap:6px;
  border:1px solid rgba(1,83,54,.12);
  background:var(--surface-lowest, #fff);
  color:var(--dim);
  border-radius:999px;
  padding:6px 10px;
  font-size:11px;
  line-height:1;
  cursor:pointer;
  transition:all .15s ease;
}
.ci-like-btn:hover{
  border-color:rgba(1,83,54,.28);
  color:var(--accent);
}
.ci-like-btn.liked{
  background:var(--accent-pale);
  border-color:rgba(1,83,54,.28);
  color:var(--accent);
}
.ci-like-icon{display:inline-flex;align-items:center;justify-content:center;}
.ci-like-icon svg{width:12px;height:12px;display:block;}
.ci-like-count{
  font-family:var(--font-label);
  font-weight:700;
  min-width:1ch;
}
.ci-replies{
  display:flex;
  flex-direction:column;
  gap:8px;
  margin-top:4px;
  padding-left:16px;
  border-left:2px solid rgba(1,83,54,.08);
}
.comment-item.is-reply{
  background:rgba(255,255,255,.72);
  box-shadow:none;
}
.ci-reply-compose{
  display:flex;
  flex-direction:column;
  gap:8px;
  margin-top:6px;
  padding:10px;
  border-radius:12px;
  background:rgba(255,255,255,.82);
  border:1px solid rgba(1,83,54,.08);
}
.ci-reply-textarea{
  width:100%;
  resize:vertical;
  min-height:76px;
  border:1px solid rgba(1,83,54,.12);
  border-radius:10px;
  padding:10px 12px;
  font-family:var(--font-body);
  font-size:13px;
  color:var(--text);
  background:#fff;
  outline:none;
}
.ci-compose-actions{
  display:flex;
  justify-content:flex-end;
  gap:8px;
}
.ci-compose-btn{
  border:none;
  border-radius:999px;
  padding:7px 12px;
  font-family:var(--font-label);
  font-size:11px;
  cursor:pointer;
}
.ci-compose-cancel{
  background:#eef3ef;
  color:var(--dim);
}
.ci-compose-submit{
  background:var(--accent);
  color:#fff;
}
.ci-menu{
  margin-left:auto;
  position:relative;
}
.ci-menu-trigger{
  width:26px;
  height:26px;
  border:none;
  border-radius:999px;
  background:transparent;
  cursor:pointer;
  display:flex;
  align-items:center;
  justify-content:center;
  gap:2px;
}
.ci-menu-trigger span{
  width:3px;
  height:3px;
  border-radius:50%;
  background:var(--dim);
}
.ci-menu-dropdown{
  position:absolute;
  top:30px;
  right:0;
  min-width:96px;
  padding:6px;
  border-radius:12px;
  border:1px solid rgba(1,83,54,.12);
  background:#fff;
  box-shadow:0 12px 28px rgba(14,39,28,.12);
  display:none;
  z-index:4;
}
.ci-menu.open .ci-menu-dropdown{
  display:flex;
  flex-direction:column;
  gap:4px;
}
.ci-menu-action{
  border:none;
  background:transparent;
  text-align:left;
  padding:8px 10px;
  border-radius:8px;
  font-family:var(--font-body);
  font-size:12px;
  color:var(--text);
  cursor:pointer;
}
.ci-menu-action:hover{
  background:#f2f6f2;
}
.ci-menu-action.danger{
  color:#b14d27;
}
.comment-list-header{
  display:flex;align-items:center;justify-content:space-between;
  padding:4px 2px 10px;border-bottom:1px solid var(--border);margin-bottom:2px;
}
.clh-label{font-family:var(--font-headline);font-size:11px;color:var(--dim);letter-spacing:.1em;}
.clh-count{font-family:var(--font-headline);font-size:12px;font-weight:700;color:var(--accent);}

@media (max-width: 768px){
  .detail-header{
    height:auto;
    min-height:56px;
    padding:12px 14px;
    gap:10px;
    flex-wrap:wrap;
    align-items:flex-start;
  }
  .detail-back{
    order:1;
    padding:6px 8px;
  }
  .dh-sep{
    display:none;
  }
  .detail-header > div{
    order:2;
    min-width:0;
    flex:1 1 auto;
  }
  .detail-header-title{
    font-size:14px;
    line-height:1.35;
    word-break:break-word;
  }
  .detail-header-author{
    font-size:11px;
  }
  .detail-header-genre{
    order:3;
    margin-left:0;
    margin-top:2px;
  }
  .detail-owner-menu{
    order:4;
    margin-left:auto;
  }

  .detail-body{
    flex-direction:column;
    overflow-y:auto;
    overflow-x:hidden;
  }

  .work-nav-btn{
    top:clamp(180px, 28vh, 260px);
    width:34px;
    height:54px;
  }
  .work-nav-prev{
    left:6px;
  }
  .work-nav-next{
    right:6px;
  }
  .work-nav-tooltip{
    display:none;
  }

  .image-pane{
    flex:none;
    width:100%;
    border-right:none;
    border-bottom:1px solid var(--border);
  }
  .image-wrap{
    flex:none;
    min-height:300px;
    max-height:52vh;
    padding:14px 14px 12px;
  }
  .image-wrap img{
    max-height:calc(52vh - 28px);
    border-radius:8px;
  }
  .detail-image-controls{
    right:14px;
    bottom:14px;
  }
  .detail-meta{
    padding:14px 14px 12px;
    gap:10px;
  }
  .detail-meta-copy{
    font-size:12px;
    line-height:1.7;
  }
  .image-guide{
    padding:8px 14px;
  }

  .comment-pane{
    flex:none;
    width:100%;
    overflow:visible;
    background:var(--surface-low);
  }
  .pin-input-area{
    padding:14px;
  }
  .pin-input-area.is-idle{
    display:none;
  }
  .pia-actions{
    flex-direction:column;
    align-items:stretch;
  }
  .pia-hint{
    order:2;
  }
  .pia-btns{
    width:100%;
    justify-content:flex-end;
  }
  .comment-list{
    flex:none;
    overflow:visible;
    padding:14px;
    padding-bottom:24px;
  }
  .comment-item{
    padding:12px 13px;
  }
  .ci-text{
    font-size:12px;
  }
  .ci-replies{
    padding-left:12px;
  }
}
