/* ============================================================
   介護ックス — ポップ × ダーク テーマ
   深いダークグリーンに、ネオンなパステルグリーンを光らせて
   ============================================================ */
:root{
  --maxw:    900px;
  --bg:      #0f1d18;       /* 背景（深いダークグリーン） */
  --bg-2:    #0a1410;
  --surface: #18271f;       /* 一段明るい面（チップ等） */
  --card:    #1a2c24;       /* カード */
  --card-2:  #20382d;
  --ink:     #e9f6ef;       /* 本文（淡いミントホワイト） */
  --ink-soft:#a8c8b7;
  --ink-mute:#71907f;
  --line:    #2c4438;       /* 罫線 */
  --green:   #4fe3a0;       /* ネオン・ポップグリーン */
  --green-dk:#34c98a;
  --green-deep:#1f8f5f;
  --green-soft:rgba(79,227,160,.14);
  --mint:    #7bf0bd;
  --accent:  #ffd56b;       /* サニーイエロー */
  --peach:   #ffb59e;
  --heart:   #ff6f91;       /* ポップピンク（いいね） */
  --sky:     #6fd4f0;
  --danger:  #ff6f66;
  --pop:   "Mochiy Pop One", "Hiragino Maru Gothic ProN", sans-serif;
  --round: "Zen Maru Gothic", "Hiragino Maru Gothic ProN", "M PLUS Rounded 1c", "Yu Gothic", system-ui, sans-serif;
  --shadow:    0 12px 30px rgba(0,0,0,.42), 0 2px 8px rgba(0,0,0,.3);
  --shadow-sm: 0 4px 14px rgba(0,0,0,.32);
  --glow:      0 8px 22px rgba(79,227,160,.30);
  --radius: 24px;
}

*{box-sizing:border-box}
html{-webkit-text-size-adjust:100%;scroll-behavior:smooth}
body{
  margin:0;
  font-family:var(--round);
  font-weight:500;
  color:var(--ink);
  line-height:1.85;
  font-size:16px;
  background:
    radial-gradient(circle at 11% 5%,  rgba(79,227,160,.18), transparent 30%),
    radial-gradient(circle at 91% 8%,  rgba(255,213,107,.12), transparent 30%),
    radial-gradient(circle at 86% 90%, rgba(111,212,240,.12), transparent 34%),
    radial-gradient(circle at 6% 93%,  rgba(255,111,145,.12), transparent 32%),
    linear-gradient(180deg, var(--bg) 0%, var(--bg-2) 100%);
  background-attachment:fixed;
  min-height:100vh;
}

/* ごく薄い質感 */
.grain{
  position:fixed;inset:0;z-index:9000;pointer-events:none;opacity:.04;mix-blend-mode:overlay;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='180' height='180'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
}

.wrap{width:100%;max-width:var(--maxw);margin:0 auto;padding:0 20px}
a{color:var(--green);text-decoration:none}

/* ============================ ヘッダー ============================ */
.site-head{
  position:relative;overflow:hidden;color:#eafaf1;
  padding:34px 0 40px;margin-bottom:6px;
  border-radius:0 0 34px 34px;
  background:
    radial-gradient(130% 120% at 86% -12%, rgba(79,227,160,.40) 0%, rgba(79,227,160,0) 55%),
    linear-gradient(140deg, #173a2c 0%, #102a20 55%, #0b1d17 100%);
  box-shadow:0 16px 40px rgba(0,0,0,.5), inset 0 -1px 0 rgba(79,227,160,.18);
}
.head-glow{
  position:absolute;top:-70%;left:-12%;width:60%;height:220%;pointer-events:none;
  background:radial-gradient(circle, rgba(123,240,189,.20) 0%, rgba(123,240,189,0) 62%);
}
.site-head::after{
  content:"";position:absolute;right:-44px;bottom:-44px;width:170px;height:170px;border-radius:50%;
  background:radial-gradient(circle, rgba(255,213,107,.32), rgba(255,213,107,0) 70%);pointer-events:none;
}
.site-head .wrap{position:relative}
.logo{display:inline-flex;align-items:center;gap:13px;color:#eafaf1}
.logo-mark{
  display:grid;place-items:center;width:48px;height:48px;border-radius:18px;
  background:linear-gradient(135deg, var(--mint), var(--green-dk));color:#08231a;transform:rotate(-6deg);
  box-shadow:0 6px 18px rgba(79,227,160,.45);
}
.logo-text{
  font-family:var(--pop);font-weight:400;font-size:1.85rem;letter-spacing:.03em;
  color:#f3fff8;text-shadow:0 0 18px rgba(79,227,160,.45);
}
.tagline{
  margin:14px 0 0;font-size:.95rem;font-weight:500;color:#b9dcc9;letter-spacing:.04em;
}

/* ヘッダー内検索 */
.search-box{display:flex;margin-top:20px;max-width:460px;
  background:rgba(8,18,14,.55);border:1px solid var(--line);border-radius:999px;
  box-shadow:inset 0 1px 4px rgba(0,0,0,.4);overflow:hidden}
.search-box input{
  flex:1;border:0;background:transparent;padding:12px 20px;font:inherit;font-weight:500;color:var(--ink);min-width:0;
}
.search-box input::placeholder{color:var(--ink-mute)}
.search-box input:focus{outline:none}
.search-box button{
  border:0;background:var(--accent);color:#5a3d00;padding:0 20px;display:grid;place-items:center;cursor:pointer;
  transition:filter .2s, transform .15s;
}
.search-box button:hover{filter:brightness(1.08)}
.search-box button:active{transform:scale(.94)}

/* ヘッダー内ナビ */
.head-nav{display:flex;flex-wrap:wrap;gap:8px;margin-top:16px}
.head-nav a{
  background:rgba(8,18,14,.4);border:1px solid var(--line);border-radius:999px;
  padding:6px 15px;font-size:.8rem;font-weight:700;color:#cdeede;letter-spacing:.02em;
  transition:background .18s, transform .15s, color .18s;
}
.head-nav a:hover{background:var(--green-soft);color:var(--mint);transform:translateY(-1px)}

main.wrap{padding-top:26px;padding-bottom:64px;position:relative;z-index:1}

/* トップの導入文（SEO/AIO用の本文ブロック） */
.lead-intro{
  background:linear-gradient(180deg, var(--card-2), var(--card));
  border:1px solid var(--line);border-radius:var(--radius);padding:20px 22px;margin-bottom:20px;
  box-shadow:var(--shadow);animation:fade-up .5s cubic-bezier(.2,.8,.3,1) both;
}
.lead-intro h1{
  font-family:var(--pop);font-weight:400;font-size:1.18rem;line-height:1.55;color:var(--mint);
  margin:0 0 9px;text-shadow:0 0 16px rgba(79,227,160,.25);
}
.lead-intro p{font-size:.9rem;line-height:1.9;color:var(--ink-soft);margin:0}
.lead-intro strong{color:var(--ink);font-weight:700}
.lead-intro a{color:var(--green);font-weight:700}
@media (max-width:520px){.lead-intro h1{font-size:1.05rem}}

/* ============================ 規約・ポリシー等のドキュメント ============================ */
.doc{
  background:var(--card);border:1px solid var(--line);border-radius:var(--radius);
  padding:28px 26px;box-shadow:var(--shadow);
  animation:fade-up .55s cubic-bezier(.2,.8,.3,1) both;
}
.doc h1{font-family:var(--pop);font-weight:400;font-size:1.5rem;color:var(--mint);margin:0 0 6px;
  text-shadow:0 0 16px rgba(79,227,160,.3)}
.doc .doc-meta{color:var(--ink-mute);font-size:.8rem;margin:0 0 22px}
.doc h2{
  font-family:var(--round);font-weight:700;font-size:1.06rem;color:var(--green);
  margin:28px 0 10px;padding-left:13px;border-left:4px solid var(--green);
}
.doc p{font-size:.95rem;line-height:1.95;color:var(--ink-soft);margin:8px 0}
.doc ul{padding-left:1.3em;margin:8px 0}
.doc li{font-size:.95rem;line-height:1.9;color:var(--ink-soft);margin:5px 0}
.doc strong{color:var(--ink);font-weight:700}
.doc a{color:var(--green)}
.doc .callout{
  background:var(--green-soft);border:1px solid rgba(79,227,160,.35);border-radius:16px;
  padding:16px 18px;margin:24px 0 4px;font-size:.92rem;color:var(--ink);line-height:1.9;
}
.doc .callout strong{color:var(--mint)}
.doc .lead-text{font-size:1rem;color:var(--ink);font-weight:500;margin:0 0 6px}
.doc h3.faq-q{font-family:var(--round);font-weight:700;font-size:.98rem;color:var(--mint);
  margin:18px 0 4px;padding-left:0;border:0}

/* コラムカード一覧 */
.column-list{display:grid;grid-template-columns:1fr;gap:14px;margin:16px 0 6px}
@media (min-width:560px){.column-list{grid-template-columns:1fr 1fr}}
.column-card{
  display:block;background:var(--card);border:1px solid var(--line);border-radius:16px;
  padding:16px 18px;box-shadow:var(--shadow-sm);transition:transform .18s, border-color .18s, box-shadow .2s;
}
.column-card:hover{transform:translateY(-3px);border-color:rgba(79,227,160,.45);box-shadow:0 14px 30px rgba(0,0,0,.4)}
.column-card h2,.column-card h3{
  font-family:var(--round);font-weight:700;font-size:.98rem;line-height:1.5;color:var(--mint);
  margin:0 0 6px;padding:0;border:0;text-shadow:none;
}
.column-card p{font-size:.84rem;line-height:1.7;color:var(--ink-soft);margin:0}

/* トップのコラム枠 */
.home-columns{
  margin-top:28px;background:linear-gradient(180deg,var(--card-2),var(--card));
  border:1px solid var(--line);border-radius:var(--radius);padding:20px 22px;box-shadow:var(--shadow);
}
.home-columns > h2{font-family:var(--pop);font-weight:400;font-size:1.12rem;color:var(--mint);margin:0 0 4px}
.home-columns-lead{font-size:.85rem;color:var(--ink-soft);margin:0 0 6px}
.more-link{margin:12px 0 0;font-size:.86rem;font-weight:700}
.more-link a{color:var(--green)}
.more-link a:hover{color:var(--mint)}

/* ============================ カテゴリ（残置・現在は未使用） ============================ */
.cat-badge{
  display:inline-block;background:var(--green-soft);color:var(--green);
  border-radius:999px;padding:3px 12px;font-size:.72rem;font-weight:700;letter-spacing:.02em;
}

/* ============================ 投稿フォーム ============================ */
.composer{
  background:var(--card);border:1px solid var(--line);border-radius:var(--radius);
  padding:20px;box-shadow:var(--shadow);margin-bottom:24px;position:relative;
  animation:fade-up .55s cubic-bezier(.2,.8,.3,1) both;
}
.composer textarea{
  width:100%;border:1.5px solid var(--line);border-radius:16px;
  padding:14px 16px;font:inherit;font-weight:500;line-height:1.7;color:var(--ink);resize:vertical;background:#13201a;
  transition:border-color .2s, box-shadow .2s;
}
.composer textarea::placeholder{color:var(--ink-mute)}
.composer textarea:focus{outline:none;border-color:var(--green);box-shadow:0 0 0 4px var(--green-soft)}
.composer-row{display:flex;flex-wrap:wrap;gap:14px;align-items:flex-end;margin-top:13px}
.field{display:flex;flex-direction:column;gap:6px;font-size:.8rem}
.field-label{color:var(--ink-soft);font-weight:700;letter-spacing:.03em}
.composer select{
  border:1.5px solid var(--line);border-radius:13px;padding:10px 13px;font:inherit;font-weight:600;background:#13201a;
  color:var(--ink);cursor:pointer;
}
.composer select:focus{outline:none;border-color:var(--green);box-shadow:0 0 0 4px var(--green-soft)}
.file-field input[type=file]{font-size:.78rem;max-width:220px;color:var(--ink-soft)}
.file-field input[type=file]::file-selector-button{
  border:1px solid var(--line);background:var(--surface);border-radius:11px;
  padding:8px 14px;font:inherit;font-weight:700;font-size:.78rem;margin-right:10px;cursor:pointer;color:var(--green);
  transition:transform .15s, filter .2s;
}
.file-field input[type=file]::file-selector-button:hover{transform:translateY(-1px);filter:brightness(1.1)}
.composer-foot{display:flex;align-items:center;justify-content:space-between;margin-top:15px;gap:12px}
.hint{font-size:.76rem;color:var(--ink-mute);letter-spacing:.02em}
.btn-post{
  background:linear-gradient(135deg, var(--mint) 0%, var(--green-dk) 100%);
  color:#08231a;border:0;border-radius:999px;padding:12px 30px;font-family:var(--round);
  font-weight:900;font-size:.98rem;letter-spacing:.05em;cursor:pointer;
  box-shadow:var(--glow);transition:transform .15s, box-shadow .2s, filter .2s;
}
.btn-post:hover{transform:translateY(-2px) scale(1.02);filter:brightness(1.06);box-shadow:0 12px 28px rgba(79,227,160,.45)}
.btn-post:active{transform:translateY(0) scale(.98)}

.reply-composer{background:linear-gradient(180deg,#1c2f26,#16261f)}

/* 検索フォーム */
.search-form .composer-row{margin-top:0}
.search-input{
  flex:1;min-width:180px;border:1.5px solid var(--line);border-radius:16px;
  padding:12px 16px;font:inherit;font-weight:500;background:#13201a;color:var(--ink);
}
.search-input::placeholder{color:var(--ink-mute)}
.search-input:focus{outline:none;border-color:var(--green);box-shadow:0 0 0 4px var(--green-soft)}

/* ============================ フラッシュ ============================ */
.flash{
  background:var(--green-soft);border:1px solid rgba(79,227,160,.4);color:var(--mint);font-weight:700;
  padding:13px 18px;border-radius:16px;margin-bottom:18px;font-size:.9rem;
  animation:pop-in .45s cubic-bezier(.2,.9,.3,1.2) both;
}
.flash.err{background:rgba(255,111,102,.14);border-color:rgba(255,111,102,.4);color:#ff9c95}

/* ============================ 投稿カード ============================ */
.timeline{display:flex;flex-direction:column;gap:16px}
.post{
  background:var(--card);border:1px solid var(--line);border-radius:var(--radius);
  padding:19px 22px;box-shadow:var(--shadow);
  transition:transform .2s cubic-bezier(.2,.8,.3,1), box-shadow .2s, border-color .2s;
  animation:fade-up .55s cubic-bezier(.2,.8,.3,1) both;
}
.post:hover{transform:translateY(-3px);box-shadow:0 18px 38px rgba(0,0,0,.5);border-color:rgba(79,227,160,.45)}
.timeline .post:nth-child(1){animation-delay:.04s}
.timeline .post:nth-child(2){animation-delay:.10s}
.timeline .post:nth-child(3){animation-delay:.16s}
.timeline .post:nth-child(4){animation-delay:.22s}
.timeline .post:nth-child(5){animation-delay:.28s}
.timeline .post:nth-child(6){animation-delay:.34s}
.post.lead{
  border-color:rgba(79,227,160,.4);background:linear-gradient(180deg,#20382d 0%,#1a2c24 100%);
  box-shadow:0 14px 34px rgba(0,0,0,.5), 0 0 0 1px rgba(79,227,160,.12);
}
.post-head{display:flex;align-items:center;gap:11px;margin-bottom:11px}
.avatar{
  width:40px;height:40px;border-radius:14px;flex:0 0 auto;transform:rotate(-4deg);
  display:grid;place-items:center;font-family:var(--pop);font-weight:400;font-size:1.05rem;
  color:#08231a;text-transform:uppercase;
  background:linear-gradient(135deg, var(--mint) 0%, var(--green-dk) 100%);
  box-shadow:0 5px 14px rgba(79,227,160,.4);
}
.avatar.small{width:34px;height:34px;font-size:.9rem;border-radius:12px}
.author{font-size:.84rem;color:var(--ink-soft);font-weight:700;letter-spacing:.02em}
.aid{font-size:.72rem;color:var(--ink-mute);margin-left:5px;font-weight:500}
.post-head time{margin-left:auto;font-size:.74rem;color:var(--ink-mute);white-space:nowrap}
.post-head .cat-badge{margin-left:2px}
.post-body{
  white-space:normal;word-break:break-word;font-size:1.04rem;line-height:1.9;color:var(--ink);font-weight:500;
}

/* 添付画像 */
.post-image{
  display:block;margin-top:14px;border-radius:18px;overflow:hidden;border:1px solid var(--line);
  box-shadow:var(--shadow-sm);
}
.post-image img{display:block;width:100%;max-height:520px;object-fit:cover;background:#13201a;
  transition:transform .4s ease}
.post-image:hover img{transform:scale(1.03)}
.admin-thumb{max-width:240px}

/* アクション */
.post-actions{display:flex;align-items:center;gap:10px;margin-top:15px;flex-wrap:wrap}
.act{
  display:inline-flex;align-items:center;gap:6px;background:var(--surface);border:0;
  color:var(--ink-soft);font:inherit;font-weight:700;font-size:.82rem;cursor:pointer;
  padding:7px 14px;border-radius:999px;transition:color .18s, transform .18s, background .18s;
}
.act .ico{font-size:1.05rem;line-height:1;transition:transform .25s}
.act:hover{transform:translateY(-2px)}
.act.like:hover{color:var(--heart);background:rgba(255,111,145,.16)}
.act.like:hover .ico{transform:scale(1.18)}
.act.like.on{color:var(--heart);background:rgba(255,111,145,.20)}
.act.like.on .ico{animation:heart-pop .45s ease}
.act.report:hover{color:var(--danger);background:rgba(255,111,102,.16)}
.act.reply:hover{color:var(--green);background:var(--green-soft)}
.act.reply:hover .ico{transform:translateY(-1px)}
.act .cnt{min-width:8px}
.act.to-thread{margin-left:auto;color:var(--green);background:var(--green-soft)}
.act.to-thread:hover{color:#08231a;background:var(--green)}

/* ============================ ページ送り ============================ */
.pager{display:flex;align-items:center;justify-content:space-between;margin:30px 0 0;gap:12px}
.pg{
  background:var(--card);border:1px solid var(--line);border-radius:999px;
  padding:10px 20px;font-size:.88rem;font-weight:700;box-shadow:var(--shadow-sm);color:var(--green);
  transition:transform .15s, border-color .15s;
}
.pg:hover{transform:translateY(-2px);border-color:rgba(79,227,160,.45)}
.pg.disabled{color:var(--ink-mute);box-shadow:none;background:transparent;border-color:var(--line)}
.pg-now{font-size:.84rem;color:var(--ink-soft);font-weight:700}

.empty{
  text-align:center;color:var(--ink-soft);padding:48px 0;font-size:1rem;font-weight:700;
  font-family:var(--pop);letter-spacing:.03em;
}
.back{margin:6px 0 18px;font-size:.88rem;font-weight:700}
.back a:hover{color:var(--mint)}

/* パンくずリスト */
.crumbs{display:flex;flex-wrap:wrap;align-items:center;gap:8px;margin:4px 0 18px;font-size:.82rem;font-weight:700}
.crumbs a{color:var(--green)}
.crumbs a:hover{color:var(--mint)}
.crumbs .sep{color:var(--ink-mute)}
.crumbs span:last-child{color:var(--ink-soft)}

/* スクリーンリーダー専用（視覚的に非表示） */
.sr-only{position:absolute!important;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}
.replies-title{
  font-family:var(--pop);font-size:1.1rem;color:var(--mint);margin:30px 0 15px;
  font-weight:400;letter-spacing:.03em;display:flex;align-items:center;gap:11px;
}
.replies-title::after{content:"";flex:1;height:2px;border-radius:2px;
  background:linear-gradient(90deg,rgba(79,227,160,.5),transparent)}
.replies{margin-top:0}

/* ============================ フッター ============================ */
.site-foot{
  margin-top:44px;padding:28px 0 38px;
  background:linear-gradient(180deg, rgba(0,0,0,0), rgba(0,0,0,.28));
  border-top:1px solid var(--line);
}
.rules{font-size:.78rem;color:var(--ink-soft);margin:0 0 10px;line-height:1.8;font-weight:500}
.foot-nav{display:flex;flex-wrap:wrap;gap:16px;margin:0 0 12px}
.foot-nav a{font-size:.8rem;font-weight:700;color:var(--ink-soft)}
.foot-nav a:hover{color:var(--green)}
.copy{font-size:.74rem;color:var(--ink-mute);margin:0;font-family:var(--pop);letter-spacing:.05em}

/* ============================ 管理画面 ============================ */
.admin .admin-bar{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px}
.tabs{display:flex;gap:10px}
.tabs a{background:var(--card);border:1px solid var(--line);border-radius:999px;
  padding:8px 17px;font-size:.85rem;font-weight:700;box-shadow:var(--shadow-sm);color:var(--ink-soft)}
.tabs a.on{background:linear-gradient(135deg,var(--mint),var(--green-dk));color:#08231a;border-color:transparent}
.logout{font-size:.82rem;color:var(--ink-soft);font-weight:700}
.logout:hover{color:var(--danger)}
.login{max-width:400px;margin:40px auto;animation:pop-in .5s cubic-bezier(.2,.9,.3,1.2) both}
.login h2{margin:0 0 15px;font-family:var(--pop);font-weight:400;font-size:1.3rem;color:var(--mint)}
.login input[type=password]{width:100%;border:1.5px solid var(--line);border-radius:16px;
  padding:13px 16px;font:inherit;font-weight:500;background:#13201a;color:var(--ink)}
.login input[type=password]:focus{outline:none;border-color:var(--green);box-shadow:0 0 0 4px var(--green-soft)}
.admin-post.hidden-post{opacity:.55;background:#15211b}
.admin-meta{font-size:.8rem;color:var(--ink-soft);margin-top:11px;font-weight:600}
.admin-meta strong{color:var(--danger)}
.badge{background:rgba(255,111,102,.16);color:#ff9c95;border-radius:8px;padding:2px 9px;margin-left:8px;font-size:.72rem;font-weight:700}
.admin-actions{display:flex;gap:10px;margin-top:13px}
.btn-mini{border:1px solid var(--line);background:var(--surface);border-radius:11px;
  padding:7px 16px;font:inherit;font-weight:700;font-size:.82rem;cursor:pointer;color:var(--ink-soft);transition:transform .15s, background .18s}
.btn-mini:hover{transform:translateY(-1px);background:var(--card-2)}
.btn-mini.danger{color:#ff9c95;border-color:rgba(255,111,102,.4)}
.btn-mini.ok{color:var(--mint);border-color:rgba(79,227,160,.4)}
.admin-post em{font-style:normal;color:var(--ink-mute);font-size:.78rem;margin:0 5px}

/* ============================ アニメーション ============================ */
@keyframes fade-up{
  from{opacity:0;transform:translateY(16px)}
  to{opacity:1;transform:translateY(0)}
}
@keyframes pop-in{
  0%{opacity:0;transform:scale(.92)}
  100%{opacity:1;transform:scale(1)}
}
@keyframes heart-pop{
  0%{transform:scale(1)}
  35%{transform:scale(1.5)}
  60%{transform:scale(.88)}
  100%{transform:scale(1)}
}
@media (prefers-reduced-motion: reduce){
  *{animation:none !important;transition:none !important;scroll-behavior:auto}
}

/* ============================ レスポンシブ ============================ */
@media (max-width:520px){
  .logo-text{font-size:1.5rem}
  .post{padding:16px 17px}
  .wrap{padding:0 15px}
}
