:root{
  --accent:#04ae56;
  --bg:#f5f6f8;
  --bubble-me:#a8e6a3;
  --bubble-other:#ffffff;
  --text:#1a1a1a;
  --muted:#8a8f98;
  --line:#e4e7eb;
}
*{box-sizing:border-box;-webkit-tap-highlight-color:transparent}
[hidden]{display:none!important}
html,body{margin:0;height:100%;font-family:-apple-system,BlinkMacSystemFont,"Hiragino Sans","Noto Sans JP",sans-serif;color:var(--text)}
body{background:var(--bg);overflow:hidden}
.screen{display:none;height:100dvh;width:100%}
.screen.active{display:flex}

/* ===== ログイン ===== */
#login{position:relative;align-items:center;justify-content:center;background:linear-gradient(160deg,#eef2f5,#e6ece9);padding:env(safe-area-inset-top) 16px;overflow:auto}
/* 入口画面のプルリフレッシュ表示（上から引っ張ると画面全体が下がる） */
.login-ptr{position:absolute;top:0;left:0;right:0;padding:18px 0;display:flex;align-items:center;justify-content:center;color:var(--muted);font-size:12px;opacity:0;transition:opacity .15s ease;pointer-events:none;z-index:1}
.login-ptr.pulling{opacity:1}
.login-ptr.ready{color:var(--accent);font-weight:700}
.login-card{position:relative;z-index:2;will-change:transform}
.login-card{background:#fff;border-radius:20px;padding:28px 22px;width:100%;max-width:380px;box-shadow:0 14px 40px rgba(0,0,0,.08);margin:auto}
.login-logo{display:block;width:76px;height:76px;margin:0 auto;border-radius:20px;box-shadow:0 6px 16px rgba(153,204,0,.35);object-fit:cover}
.login-card h1{font-size:26px;text-align:center;margin:12px 0 2px;letter-spacing:.12em;font-weight:800}
.login-card h1.brand{margin-top:10px}
.brand-pre{display:block;font-size:13px;letter-spacing:.16em;color:var(--muted);font-weight:700;margin-bottom:1px}
.role-note{text-align:center;font-size:13px;font-weight:700;color:var(--accent);background:color-mix(in srgb,var(--accent) 10%,#fff);border-radius:10px;padding:8px;margin-bottom:14px}
.install-banner{width:100%;margin:14px 0 4px;padding:12px;background:#fff;border:2px solid var(--accent);color:var(--accent);font-size:14px;font-weight:700;border-radius:12px}
.install-banner:active{background:color-mix(in srgb,var(--accent) 8%,#fff)}
/* ログイン画面の「アプリとして追加」だけ大きく目立たせる（最初のCTA） */
#installBanner{margin:6px 0 18px;padding:18px 16px;font-size:17px;line-height:1.4;background:var(--accent);color:#fff;border-color:var(--accent);box-shadow:0 8px 22px color-mix(in srgb,var(--accent) 38%,transparent);animation:installPulse 2.2s ease-in-out infinite}
#installBanner:active{background:var(--accent);transform:scale(.99)}
#installBanner .ib-paren{font-size:14px}/* 「ホーム画面に置く」を2pt下げて1行に収める */
#installBanner .ib-sub{display:block;font-size:12.5px;font-weight:600;opacity:.92;margin-top:6px}
@keyframes installPulse{0%,100%{box-shadow:0 8px 22px color-mix(in srgb,var(--accent) 30%,transparent)}50%{box-shadow:0 8px 30px color-mix(in srgb,var(--accent) 60%,transparent)}}
@media (prefers-reduced-motion:reduce){#installBanner{animation:none}}
.install-intro{font-size:13.5px;line-height:1.75;color:var(--text);margin:0 0 14px}
.install-intro b{color:var(--accent)}
.install-steps .install-lead,.install-login .install-lead{font-weight:800;font-size:15px;margin:0 0 10px}
.install-ol{margin:0;padding-left:22px;line-height:1.65;font-size:14.5px}
.install-ol>li{margin-bottom:12px}
.install-ol .install-sub{display:block;font-size:12.5px;font-weight:400;color:var(--muted);margin-top:3px;line-height:1.6}
.install-steps b,.install-login b{color:var(--accent)}
.install-steps .install-note{margin-top:10px;font-size:13px;color:var(--muted);background:var(--bg);padding:10px 12px;border-radius:10px}
.install-login{margin-top:18px;padding-top:16px;border-top:1px solid var(--line)}
.install-login>.install-sub{font-size:13px;color:var(--muted);line-height:1.7;margin:0 0 10px}
.sub{color:var(--muted);text-align:center;font-size:13px;margin:0 0 18px}
.community-list{display:grid;gap:10px;margin-bottom:18px}
.ci-empty{padding:14px;border:1.5px dashed var(--line);border-radius:12px;color:var(--muted);font-size:13.5px;text-align:center;line-height:1.7}
/* グループの公開設定 */
.chan-acl-btn{margin-left:auto;flex-shrink:0;background:var(--bg);border:1px solid var(--line);border-radius:8px;color:var(--muted);font-size:11.5px;font-weight:700;padding:5px 8px;white-space:nowrap}
.chan-acl-btn.mode-public{color:var(--accent)}
.chan-acl-btn.mode-limited{color:#c8862a}
.chan-acl-btn.mode-private{color:#e1473d}
.ca-tg{font-size:13.5px;padding:11px 6px}
.ca-toggle{display:flex;gap:8px;margin-bottom:10px}
.ca-tg{flex:1;padding:11px;border:1.5px solid var(--line);border-radius:12px;background:#fff;font-size:14px;font-weight:700;color:var(--text)}
.ca-tg.on{background:var(--accent);color:#fff;border-color:var(--accent)}
html.dark .ca-tg{background:#1f242b;color:#e8eaed}
.ca-note{font-size:12.5px;color:var(--muted);margin:0 0 12px;line-height:1.6}
.ca-members{display:flex;flex-direction:column;gap:6px;margin-bottom:14px;max-height:50vh;overflow-y:auto}
.ca-member{display:flex;align-items:center;gap:11px;width:100%;text-align:left;background:#fff;border:1.5px solid var(--line);border-radius:12px;padding:11px 13px;font-size:16px;color:var(--text)}
html.dark .ca-member{background:#1f242b}
.ca-member.on{border-color:var(--accent);background:color-mix(in srgb,var(--accent) 8%,#fff)}
html.dark .ca-member.on{background:#1f2a24}
.ca-member .ca-ava{width:34px;height:34px;border-radius:50%;overflow:hidden;flex-shrink:0;background:#dfe3e8}
.ca-member .ca-name{flex:1;font-weight:600;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.ca-member .ca-check{font-size:12px;font-weight:700;color:var(--muted);flex-shrink:0}
.ca-member.on .ca-check{color:var(--accent)}
.community-item{display:flex;align-items:center;gap:12px;padding:12px 14px;border:2px solid var(--line);border-radius:14px;cursor:pointer;transition:.15s;background:#fff}
.community-item:hover{border-color:#cfd4da}
.community-item.selected{border-color:var(--c);background:color-mix(in srgb,var(--c) 8%,#fff)}
.community-item .emoji{font-size:26px;width:44px;height:44px;display:grid;place-items:center;border-radius:12px;background:color-mix(in srgb,var(--c) 14%,#fff);overflow:hidden}
.community-item .emoji img{width:100%;height:100%;object-fit:cover}
.community-item .ci-name{font-weight:700;font-size:15px}
.community-item .ci-meta{font-size:12px;color:var(--muted)}
.field{display:block;margin-bottom:14px}
.field span{display:block;font-size:12px;color:var(--muted);margin-bottom:5px}
.field input,.field select{width:100%;padding:12px;border:1.5px solid var(--line);border-radius:12px;font-size:15px;background:#fff}
/* チェックボックス／ラジオは全幅化しない（ラベルが画面外に押し出されるのを防ぐ） */
.field input[type=checkbox],.field input[type=radio]{width:auto;flex:none;padding:0;border-radius:0;font-size:inherit}
button{font-family:inherit;cursor:pointer;border:none}
.primary{width:100%;padding:14px;background:var(--accent);color:#fff;font-size:16px;font-weight:700;border-radius:12px;transition:.15s}
.primary.is-dim{background:#cfd5db;color:#eef1f4;box-shadow:none}
html.dark .primary.is-dim{background:#3a4048;color:#8b929b}
.primary:disabled{opacity:.4}
#joinBtn{opacity:.55}
#joinBtn.ready{opacity:1;box-shadow:0 6px 16px color-mix(in srgb,var(--accent) 40%,transparent)}
.login-hint{text-align:center;font-size:13px;color:#e06b00;margin-top:8px;min-height:18px}
.primary.small{width:auto;padding:10px 18px;font-size:14px}
/* Googleログインボタン */
.google-btn{width:100%;padding:13px;display:flex;align-items:center;justify-content:center;gap:10px;background:#fff;color:#1f2937;font-size:15px;font-weight:600;border:1.5px solid var(--line);border-radius:12px;transition:.15s}
.google-btn:hover{background:#f7f8fa}
html.dark .google-btn{background:#1f242b;color:#e8eaed;border-color:#3a4048}
/* ログイン済みユーザー表示 */
/* ログイン中アカウント＝NINEグリーン(#99CC00)でコミュニティ選択ボタンとはっきり区別 */
.login-user{display:flex;align-items:center;gap:12px;padding:12px 14px;border:2px solid #99CC00;border-radius:14px;margin-bottom:14px;background:color-mix(in srgb,#99CC00 14%,#fff)}
html.dark .login-user{background:color-mix(in srgb,#99CC00 22%,#1a1d22)}
.login-user-ava{width:42px;height:42px;border-radius:50%;background:#dfe3e8;object-fit:cover;flex-shrink:0;border:2px solid #99CC00}
.login-user-text{min-width:0;flex:1}
.login-user-tag{display:inline-block;font-size:11px;font-weight:800;color:#5f7d00;background:#fff;border:1px solid #99CC00;border-radius:999px;padding:1px 8px;margin-bottom:3px}
html.dark .login-user-tag{background:#1a1d22;color:#b7e000}
.login-user-name{font-weight:800;font-size:15px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.logout-link{font-size:12px;color:#e03131;font-weight:700;text-decoration:underline;background:none;padding:2px 0;margin-top:2px}
/* コミュニティカード：招待リンクボタン */
.community-item .ci-body{flex:1;min-width:0}
.ci-invite{flex:none;width:38px;height:38px;border-radius:10px;border:1px solid var(--line);background:#fff;font-size:17px;cursor:pointer;display:grid;place-items:center}
.ci-invite:active{background:var(--bg)}
html.dark .ci-invite{background:#23272e}
.ghost{width:100%;padding:12px;background:transparent;color:var(--muted);font-size:13px;margin-top:10px}

/* ===== チャット ===== */
#chat{display:none}
#chat.active{display:flex}
#sidebar{width:260px;background:#fff;border-right:1px solid var(--line);display:flex;flex-direction:column;flex-shrink:0;padding-top:env(safe-area-inset-top);overflow-y:auto;-webkit-overflow-scrolling:touch}
.side-head{display:flex;align-items:center;gap:10px;padding:16px;border-bottom:1px solid var(--line)}
.side-head-text{flex:1;min-width:0}
.side-close{display:none;background:var(--bg);width:34px;height:34px;border-radius:10px;font-size:15px;color:var(--muted);flex-shrink:0}
#sideOverlay{display:none}
.side-emoji{position:relative;font-size:24px;width:42px;height:42px;display:grid;place-items:center;border-radius:12px;background:color-mix(in srgb,var(--accent) 14%,#fff);overflow:hidden;flex-shrink:0}
.side-emoji img{width:100%;height:100%;object-fit:cover}
.side-emoji.editable{cursor:pointer}
.side-emoji .cam{position:absolute;right:-2px;bottom:-2px;width:18px;height:18px;border-radius:50%;background:var(--accent);color:#fff;font-size:10px;display:grid;place-items:center;border:2px solid #fff}
.side-name{font-weight:700}
.side-name.editable{cursor:pointer}
.side-name.editable::after{content:" ✏️";font-size:11px;opacity:.6}
.side-online{font-size:12px;color:var(--muted)}
.side-online::before{content:"●";color:var(--accent);font-size:9px;margin-right:4px}
.side-section{padding:14px 12px;border-bottom:1px solid var(--line)}
.side-label{font-size:11px;color:var(--muted);font-weight:700;letter-spacing:.05em;margin:0 4px 8px}
.channel{display:flex;align-items:center;gap:6px;padding:9px 10px;border-radius:9px;cursor:pointer;font-size:14px}
.channel .row-name{flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.channel.editing{background:var(--bg);margin-bottom:6px;gap:8px;padding:11px 10px}
.drag-hint{font-size:12px;color:var(--muted);background:color-mix(in srgb,var(--accent) 8%,#fff);border-radius:8px;padding:7px 10px;margin-bottom:6px;text-align:center}
.grip{font-size:24px;color:var(--muted);cursor:grab;flex-shrink:0;touch-action:none;width:34px;min-height:38px;display:grid;place-items:center;text-align:center;user-select:none;-webkit-user-select:none}
.grip:active{cursor:grabbing}
.channel.dragging{box-shadow:0 10px 28px rgba(0,0,0,.26);background:#fff;position:relative;z-index:5;will-change:transform}
.channel.board-edit{flex-wrap:wrap}
.channel.board-edit .row-name{flex:1;font-weight:700}
.board-controls{flex-basis:100%;display:flex;gap:6px;margin-top:7px;padding-left:34px}
.mini-btn{flex-shrink:0;background:#fff;border:1px solid var(--line);border-radius:8px;color:var(--text);line-height:1;height:32px;display:grid;place-items:center}
.mini-btn.vis{font-weight:700;color:var(--accent);font-size:12px;padding:0 10px}
.mini-btn.icon{width:38px;font-size:18px}
.mini-btn:active{background:var(--bg)}
.channel:hover{background:var(--bg)}
.channel.active{background:color-mix(in srgb,var(--accent) 12%,#fff);font-weight:700}
.channel .hash{color:var(--muted)}
.channel .badge{margin-left:auto;background:#ff3b30;color:#fff;font-size:11px;min-width:18px;height:18px;padding:0 5px;border-radius:9px;display:grid;place-items:center;font-weight:700}
/* 個別相談の状態バッジ */
.dm-badge{flex-shrink:0;font-size:11px;font-weight:700;padding:2px 8px;border-radius:10px;white-space:nowrap}
.dm-badge.flag{background:#ffe3e3;color:#e0245e}
.dm-badge.new{background:color-mix(in srgb,var(--accent) 16%,#fff);color:var(--accent)}
.dm-badge.unread{background:#fff0db;color:#d97706}
.dm-badge.read{background:var(--bg);color:var(--muted)}
/* 要返信スター */
.dm-star{align-self:flex-start;margin:2px 0 0 4px;background:transparent;border:none;font-size:18px;color:#f0a500;cursor:pointer;line-height:1;padding:0}
.dm-star.on{color:#f5a623}
.msg.me .dm-star{align-self:flex-end}
.side-add,.side-nav{width:100%;text-align:left;background:transparent;color:var(--muted);font-size:13px;padding:8px 10px;border-radius:8px;margin-top:4px}
.channel-toggle{padding:8px 10px;border-radius:8px;font-size:13px;font-weight:700;color:var(--accent);cursor:pointer;margin-top:2px}
.channel-toggle:hover{background:var(--bg)}
.side-add:hover,.side-nav:hover{background:var(--bg)}
.side-foot{margin-top:auto;padding:12px;display:grid;gap:8px;padding-bottom:calc(12px + env(safe-area-inset-bottom))}
.side-install{background:var(--accent);color:#fff;padding:11px;border-radius:10px;font-weight:700;font-size:13px}
.side-leave{background:var(--bg);color:var(--muted);padding:10px;border-radius:10px;font-size:13px}
/* 上部：コミュニティ切り替え（未読タグ合計バッジ付き） */
.side-switch{display:flex;align-items:center;justify-content:center;gap:8px;width:calc(100% - 24px);margin:6px 12px 8px;padding:11px;border-radius:10px;background:var(--bg);color:var(--accent);border:1px solid var(--line);font-size:13px;font-weight:800}
html.dark .side-switch{background:#1f242b;border-color:#3a4048}
.side-badge{background:#e03131;color:#fff;font-size:11px;font-weight:800;min-width:18px;height:18px;border-radius:9px;display:inline-flex;align-items:center;justify-content:center;padding:0 5px}
.side-logout{color:#c0392b;font-weight:700}
html.dark .side-logout{color:#ff6b60}
.chan-limit{display:inline-flex;align-items:center;font-size:12px;line-height:1;flex-shrink:0;white-space:nowrap;opacity:.85}
.chan-limit b{font-weight:800;color:#7a8aa0;margin-left:1px}

#main{flex:1;display:flex;flex-direction:column;min-width:0}
.main-head{display:flex;align-items:center;gap:8px;padding:12px 14px;background:#fff;border-bottom:1px solid var(--line);padding-top:calc(12px + env(safe-area-inset-top))}
.main-title{font-weight:700;flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.icon-btn{position:relative;background:transparent;font-size:20px;width:38px;height:38px;border-radius:10px;flex-shrink:0}
.icon-btn:hover{background:var(--bg)}
/* 右上の4アイコン（To Do/イベント/検索/ベル）の間隔だけ詰めて、ベル側に寄せる */
.main-head #calBtn,.main-head #searchBtn,.main-head #notifyBtn{margin-left:-6px}
#menuBtn{display:none}

/* 引っ張って更新（プルリフレッシュ）の表示バー */
.ptr{height:0;overflow:hidden;display:flex;align-items:center;justify-content:center;color:var(--muted);font-size:13px;background:var(--bg);transition:height .2s ease}
.ptr.pulling{transition:none}
.ptr.ready{color:var(--accent);font-weight:700}
.messages{flex:1;overflow-y:auto;overflow-x:hidden;overscroll-behavior:contain;touch-action:pan-y;-webkit-overflow-scrolling:touch;padding:18px 16px;display:flex;flex-direction:column;gap:16px;background:var(--bg)}
.messages>*{max-width:100%}
.msg{max-width:84%;display:flex;flex-direction:column;gap:4px}
.msg.me{align-self:flex-end;align-items:flex-end}
.msg .who{font-size:12px;color:var(--muted);margin:0 4px 1px;cursor:pointer}
.msg .row{display:flex;align-items:flex-end;gap:7px}
.msg.me .row{flex-direction:row-reverse}
/* LINE風：相手の吹き出しの左に小さいアイコン */
.msg-line{display:flex;gap:10px;align-items:flex-start}
.msg-body{display:flex;flex-direction:column;gap:4px;min-width:0}
.ava{width:40px;height:40px;border-radius:50%;overflow:hidden;flex-shrink:0;cursor:pointer;background:#dfe3e8}
/* くちばし（吹き出しのしっぽ）がアバターに被って白く抜けるのを防ぐ：アバターを前面に */
.msg-line>.ava{position:relative;z-index:2}
.ava img,.ava-img{width:100%;height:100%;object-fit:cover;display:block}
.ava-init{width:100%;height:100%;display:grid;place-items:center;color:#fff;font-weight:700;font-size:17px}
.bubble{position:relative;background:var(--bubble-other);padding:11px 15px;border-radius:18px;font-size:15px;line-height:1.6;white-space:pre-wrap;word-break:break-word;box-shadow:0 1px 2px rgba(0,0,0,.05)}
/* 吹き出しのしっぽ（くちばし）：先端をアイコン側へ尖らせ、ゆるくカーブ。
   しっぽは吹き出しの“背面(z-index:-1)”に置き、::after＝背景色で削って曲線と先端を作る */
.msg .bubble:not(.album):not(.img):not(.file):not(.caption):not(.share-card)::before,
.msg .bubble:not(.album):not(.img):not(.file):not(.caption):not(.share-card)::after{
  content:"";position:absolute;z-index:-1;top:-1px;height:17px;
}
/* --- 相手（左上向き・白） --- */
.msg:not(.me) .bubble:not(.album):not(.img):not(.file):not(.caption):not(.share-card)::before{
  left:-7px;width:18px;background:var(--bubble-other);
  border-top-right-radius:16px;
}
.msg:not(.me) .bubble:not(.album):not(.img):not(.file):not(.caption):not(.share-card)::after{
  left:-20px;width:22px;background:var(--bg);
  border-top-right-radius:13px;
}
/* --- 自分（右上向き・緑） --- */
.msg.me .bubble:not(.album):not(.img):not(.file):not(.caption):not(.share-card)::before{
  right:-7px;width:18px;background:var(--bubble-me);
  border-top-left-radius:16px;
}
.msg.me .bubble:not(.album):not(.img):not(.file):not(.caption):not(.share-card)::after{
  right:-20px;width:22px;background:var(--bg);
  border-top-left-radius:13px;
}
/* --- 自分のリプライ（左寄せ・緑） --- */
.msg.in-reply.reply-mine .bubble:not(.album):not(.img):not(.file):not(.caption):not(.share-card)::before{
  background:var(--bubble-me);
}
.msg.me .bubble{background:var(--bubble-me)}
.bubble.img{padding:4px}
.bubble.img img{max-width:220px;max-height:260px;border-radius:12px;display:block;cursor:pointer}
.bubble.file a{color:var(--accent);text-decoration:none;font-weight:600}
/* ファイル種別バッジ（PDF/DOC/XLS…） チャット・一覧で共用 */
.file-badge{display:inline-flex;align-items:center;justify-content:center;font-weight:800;color:#fff;border-radius:7px;background:#8a94a6;letter-spacing:.3px;flex-shrink:0;line-height:1}
.fb-pdf{background:#e23b3b}.fb-doc{background:#2b6cb0}.fb-xls{background:#2f855a}.fb-ppt{background:#dd6b20}.fb-zip{background:#7c5cd6}.fb-aud{background:#0d9488}.fb-vid{background:#db2777}.fb-txt{background:#64748b}.fb-gen{background:#8a94a6}
.bubble.file .file-link{display:flex;align-items:center;gap:10px;text-decoration:none}
.bubble.file .file-badge{width:40px;height:40px;font-size:12px}
.bubble.file .fl-meta{display:flex;flex-direction:column;min-width:0}
.bubble.file .fl-name{font-weight:600;color:var(--accent);word-break:break-all}
.bubble.file .fl-size{font-size:11px;color:var(--muted);font-weight:400}
.bubble a{color:#1558b0;text-decoration:underline;word-break:break-all}
.msg.me .bubble a{color:#0a4a9e}
/* リアクション（スタンプ） */
.react-row{display:flex;flex-wrap:wrap;gap:4px;margin-top:3px;align-items:center}
.msg.me .react-row{justify-content:flex-end}
.rchip{background:#fff;border:1px solid var(--line);border-radius:14px;font-size:12px;padding:2px 9px;cursor:pointer;line-height:1.7}
.rchip.mine{background:color-mix(in srgb,var(--accent) 15%,#fff);border-color:var(--accent);color:var(--accent);font-weight:700}
.react-add{background:transparent;border:none;font-size:13px;opacity:.45;cursor:pointer;padding:2px 4px}
.react-add:hover{opacity:1}
.react-picker{background:#fff;border-radius:18px;padding:14px;display:flex;gap:4px;margin:auto;box-shadow:0 12px 40px rgba(0,0,0,.2)}
.remoji{font-size:30px;background:transparent;border:none;cursor:pointer;padding:6px;border-radius:12px;line-height:1}
.remoji:active{background:var(--bg)}
/* 長押しメニュー：スタンプ＋（必要時）削除ボタンを縦に重ねる */
#reactPicker.open{flex-direction:column;align-items:center;justify-content:center;gap:12px}
#reactPicker .react-picker{margin:0}
/* 長押しメニューの操作項目（返信/引用/ピン/コピー類） */
.menu-actions{background:#fff;border-radius:16px;box-shadow:0 12px 40px rgba(0,0,0,.2);display:flex;flex-direction:column;overflow:hidden;min-width:248px;max-width:88vw}
html.dark .menu-actions{background:#23272e}
/* 長押しメニューはネイティブの文字選択（コピー/翻訳…の吹き出し）を出さない */
.msg-menu,.msg-menu *,.menu-actions,.ma-btn{-webkit-user-select:none;user-select:none;-webkit-touch-callout:none}
.ma-btn{background:transparent;border:none;text-align:left;padding:14px 18px;font-size:15px;font-weight:600;color:var(--text);cursor:pointer;border-bottom:1px solid var(--line)}
.ma-btn:last-child{border-bottom:none}
.ma-btn:active{background:var(--bg)}
html.dark .ma-btn{color:#e8eaed}
/* メニュー一覧内の編集・削除行（別カードにせず一覧の中に統一） */
.ma-btn.ma-edit{color:var(--accent)}
.ma-btn.ma-del{color:#e1473d}
html.dark .ma-btn.ma-del{color:#ff6b60}
/* 部分コピー用テキスト（iOS標準の選択・コピーを使えるように） */
.copy-text{width:100%;min-height:140px;max-height:46vh;font-size:15px;line-height:1.6;padding:12px;border:1.5px solid var(--line);border-radius:12px;font-family:inherit;-webkit-user-select:text;user-select:text;-webkit-touch-callout:default;margin-bottom:12px;background:#fff;color:var(--text)}
html.dark .copy-text{background:#1b1f25;color:#e8eaed}
/* ===== To Do ===== */
.thread-todos{margin:2px 0 8px 40px;display:flex;flex-direction:column;gap:6px}
.todo-card{display:flex;align-items:center;gap:10px;background:#fff7e6;border:1.5px solid #f0d28a;border-radius:12px;padding:10px 12px}
html.dark .todo-card{background:#2a2718;border-color:#5a4f2e}
.todo-card.urgent{background:#ffeceb;border-color:#f3b0aa}
html.dark .todo-card.urgent{background:#2e1d1d;border-color:#6e3b38}
.todo-card.status-done{opacity:.6}
.todo-card.status-hold{background:#f1f3f5;border-color:var(--line)}
html.dark .todo-card.status-hold{background:#23272e;border-color:#3a4048}
.todo-card .tc-main{flex:1;min-width:0}
.tc-title{font-weight:700;font-size:14px;cursor:pointer;word-break:break-word}
.todo-card.status-done .tc-title{text-decoration:line-through}
.tc-stbadge{font-size:11px;font-weight:700;padding:1px 7px;border-radius:8px;margin-left:4px;vertical-align:middle}
.tc-stbadge.hold{background:var(--muted);color:#fff}
.tc-stbadge.done{background:var(--accent);color:#fff}
.tc-meta{font-size:12px;color:var(--muted);margin-top:3px}
.todo-card.urgent .tc-due{color:#e1473d;font-weight:700}
.tc-actions{display:flex;align-items:center;gap:6px;flex-shrink:0;flex-wrap:wrap;justify-content:flex-end}
.tc-toggle{background:var(--accent);color:#fff;border:none;border-radius:10px;padding:7px 12px;font-size:12px;font-weight:700;cursor:pointer;white-space:nowrap}
/* 保留：グレーの反転（塗りつぶしグレー） */
.tc-hold{background:var(--muted);color:#fff;border:none;border-radius:10px;padding:7px 12px;font-size:12px;font-weight:700;cursor:pointer;white-space:nowrap}
.tc-reopen{background:transparent;color:var(--muted);border:1.5px solid var(--line);border-radius:10px;padding:6px 11px;font-size:12px;font-weight:700;cursor:pointer;white-space:nowrap}
/* 押した時の視覚効果（反転・くぼみ） */
.tc-toggle:active{background:#03894a;transform:scale(.94)}
.tc-hold:active{background:#5a616b;transform:scale(.94)}
.tc-reopen:active{background:var(--bg);transform:scale(.94)}
.tc-toggle,.tc-hold,.tc-reopen{transition:transform .08s,background .08s}
/* 作成シート */
.todo-quote{background:rgba(0,0,0,.045);border-left:3px solid var(--accent);border-radius:10px;padding:8px 11px;margin-bottom:12px}
html.dark .todo-quote{background:rgba(255,255,255,.07)}
.todo-title-input{width:100%;min-height:96px;font-size:16px;line-height:1.6;padding:12px;border:1.5px solid var(--line);border-radius:12px;font-family:inherit}
/* 担当者の@検索入力＋候補ポップアップ */
.todo-ac{position:relative;margin-top:4px}
.todo-ac input{width:100%;padding:11px 12px;border:1.5px solid var(--line);border-radius:10px;font-size:15px;font-family:inherit}
.ac-menu{position:absolute;left:0;right:0;top:calc(100% + 4px);z-index:10;background:#fff;border:1px solid var(--line);border-radius:14px;box-shadow:0 12px 36px rgba(0,0,0,.2);max-height:56vh;overflow-y:auto}
html.dark .ac-menu{background:#23272e;border-color:#3a4048}
/* サイドバーのメンバー一覧と同じサイズ感（アバター46px・名前16px） */
.ac-item{display:flex;align-items:center;gap:12px;width:100%;text-align:left;background:transparent;border:none;padding:12px 12px;font-size:16px;font-weight:700;color:var(--text);cursor:pointer;border-bottom:1px solid var(--line)}
.ac-item:last-child{border-bottom:none}
.ac-item:active{background:var(--bg)}
/* 候補名はメンバー一覧と同じ見やすさに統一（.field span の小さい灰色文字に上書きされるのを防ぐ） */
.ac-item .ac-name{font-size:16px;font-weight:700;color:var(--text);display:inline;margin-bottom:0}
.ac-menu .ac-ava{display:grid;font-size:18px;color:var(--text);margin-bottom:0}
.ac-ava{width:46px;height:46px;border-radius:50%;overflow:hidden;flex-shrink:0;display:grid;place-items:center;background:#dfe3e8;font-size:18px}
.ac-ava img{width:100%;height:100%;object-fit:cover}
.todo-chips{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:6px}
.todo-chip-sel{display:inline-flex;align-items:center;gap:6px;background:color-mix(in srgb,var(--accent) 12%,#fff);color:var(--accent);border:1px solid color-mix(in srgb,var(--accent) 40%,#fff);border-radius:16px;padding:6px 8px 6px 13px;font-size:14px;font-weight:700}
html.dark .todo-chip-sel{background:#1f2a24}
.tcs-x{background:transparent;border:none;color:inherit;font-size:12px;cursor:pointer;padding:0 4px}
/* 期日：日時入力＋右下に小さく薄い「期日なし」 */
.todo-due-wrap{display:flex;flex-direction:column;gap:6px;margin-top:4px}
.todo-due-wrap input[type=datetime-local]{width:100%;padding:11px 12px;border:1.5px solid var(--line);border-radius:10px;font-size:15px;font-family:inherit}
.todo-nodue{align-self:flex-end;display:inline-flex;align-items:center;gap:7px;font-size:14px;color:var(--muted)}
.todo-nodue input{width:20px;height:20px}
/* 一覧 */
.todo-list{display:flex;flex-direction:column;gap:8px}
.todo-add-btn{width:100%;padding:13px;background:var(--accent);color:#fff;font-size:15px;font-weight:800;border:none;border-radius:12px;margin-bottom:6px;cursor:pointer}
.todo-add-btn:active{opacity:.85}
/* To Do系モーダルの重なり順（閉じたら一覧→チャットの順で戻る） */
#todoListModal.open{z-index:52}
#tagMergeModal.open{z-index:62}/* To Do一覧(52)より前面に。裏に隠れて見えない問題の対策 */
#todoMenu.open{z-index:60}
#todoSheet.open{z-index:64}
#todoHistoryModal.open{z-index:64}
#todoMemoSheet.open{z-index:64}
#copySheet.open{z-index:70}
.todo-sec-h{font-size:13px;font-weight:800;color:var(--muted);margin-top:8px}
.todo-empty{font-size:13px;color:var(--muted);padding:6px 2px}
/* 変更履歴 */
.th-title{font-weight:700;font-size:15px;margin-bottom:10px}
.th-list{display:flex;flex-direction:column;gap:8px}
.th-item{border-left:3px solid var(--accent);background:var(--bg);border-radius:8px;padding:8px 11px}
.th-when{font-size:12px;color:var(--muted)}
.th-body{font-size:14px;font-weight:600;margin-top:2px}
.th-empty{font-size:13px;color:var(--muted);padding:8px 2px}
.tmemo-meta{font-size:12px;color:var(--muted);margin-bottom:8px}
/* リンクプレビュー（OGPカード） */
.link-preview{display:flex;align-items:stretch;gap:0;margin-top:4px;max-width:300px;background:#fff;border:1px solid var(--line);border-radius:12px;overflow:hidden;text-decoration:none;color:var(--text)}
html.dark .link-preview{background:#1f242b;border-color:#3a4048}
.link-preview:active{opacity:.85}
.link-preview .lp-img{width:84px;flex-shrink:0;background:var(--bg);display:block;overflow:hidden}
.link-preview .lp-img img{width:100%;height:100%;min-height:64px;object-fit:cover;display:block}
.link-preview .lp-text{display:flex;flex-direction:column;justify-content:center;gap:3px;padding:9px 11px;min-width:0}
.link-preview .lp-title{font-size:13px;font-weight:700;line-height:1.35;overflow:hidden;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical}
.link-preview .lp-desc{font-size:11.5px;color:var(--muted);line-height:1.35;overflow:hidden;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical}
.link-preview .lp-site{font-size:11px;color:var(--muted);display:flex;align-items:center;gap:5px}
.link-preview .lp-fav{width:14px;height:14px;border-radius:3px;flex-shrink:0}
.msg.me .link-preview{margin-left:auto}
/* YouTube/Vimeo 埋め込みプレーヤー（クリックで再生） */
.video-embed{position:relative;margin-top:4px;max-width:320px;width:100%;aspect-ratio:16/9;border-radius:12px;overflow:hidden;background:#000;cursor:pointer}
.video-embed .ve-thumb{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;display:block}
.video-embed .ve-play{position:absolute;inset:0;margin:auto;width:54px;height:54px;display:flex;align-items:center;justify-content:center;font-size:22px;color:#fff;background:rgba(0,0,0,.55);border-radius:50%;padding-left:4px;box-shadow:0 2px 10px rgba(0,0,0,.4);transition:background .15s;z-index:1}
.video-embed:hover .ve-play{background:rgba(204,0,0,.85)}
.video-embed.ve-playing{cursor:default}
.video-embed iframe{position:absolute;inset:0;width:100%;height:100%;border:0;display:block}
.video-title{font-size:14px;font-weight:800;line-height:1.4;margin:6px 0 12px}
.video-title:empty{display:none}
.msg.me .video-embed{margin-left:auto}
/* プロフィールのSNSリンク編集 */
.plink-edit{display:flex;flex-direction:column;gap:7px;margin-top:6px}
.plink-row{display:flex;align-items:center;gap:7px;background:var(--bg);border:1px solid var(--line);border-radius:10px;padding:6px 8px}
.plink-row.dragging{box-shadow:0 10px 28px rgba(0,0,0,.22);background:#fff;position:relative;z-index:5}
.plink-row .grip{font-size:20px;color:var(--muted);cursor:grab;touch-action:none;flex-shrink:0;width:24px;text-align:center;user-select:none}
.plink-ico{width:34px;height:34px;border-radius:9px;flex-shrink:0;display:grid;place-items:center;color:#fff;font-weight:800;font-size:12px;line-height:1;overflow:hidden;border:1px solid var(--line)}
.plink-ico img{width:64%;height:64%;object-fit:contain;display:block}
.plink-name{font-size:13px;font-weight:700;width:88px;flex-shrink:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
/* .field input(width:100%) に負けないよう、行内入力はクラス＋要素で上書き */
.plink-row input.plink-flabel{width:90px;flex-shrink:0;padding:8px;border:1.5px solid var(--line);border-radius:8px;font-size:13px;font-family:inherit;background:#fff}
.plink-row input.plink-url{width:auto;flex:1;min-width:0;padding:8px;border:1.5px solid var(--line);border-radius:8px;font-size:13px;font-family:inherit;background:#fff}
.plink-vis{flex-shrink:0;border:1.5px solid var(--line);border-radius:8px;background:#fff;font-size:11px;font-weight:700;padding:6px 8px;color:var(--muted)}
.plink-vis.on{color:var(--accent);border-color:var(--accent)}
.plink-vis.off{color:#e1473d;border-color:#f0b6b1}
.plink-del{flex-shrink:0;background:transparent;border:none;font-size:15px;padding:2px}
/* プロフィール項目の編集 */
.pf-edit{display:flex;flex-direction:column;gap:6px;margin-top:6px}
.pf-erow{display:flex;align-items:center;gap:8px;background:var(--bg);border:1px solid var(--line);border-radius:10px;padding:6px 8px}
.pf-erow.dragging{box-shadow:0 10px 28px rgba(0,0,0,.22);background:#fff;position:relative;z-index:5}
.pf-erow .grip{font-size:20px;color:var(--muted);cursor:grab;touch-action:none;flex-shrink:0;width:22px;text-align:center;user-select:none}
.pf-elabel{font-size:12.5px;font-weight:700;width:110px;flex-shrink:0;line-height:1.25}
.pf-erow input.pf-einput{width:auto;flex:1;min-width:0;padding:8px 10px;border:1.5px solid var(--line);border-radius:8px;font-size:14px;font-family:inherit;background:#fff}
/* プロフィール表示：項目 */
.pf-list{display:flex;flex-direction:column;gap:0;margin-top:14px;text-align:left;width:100%;border:1px solid var(--line);border-radius:12px;overflow:hidden}
.pf-row{display:flex;gap:0;border-bottom:1px solid var(--line)}
.pf-row:last-child{border-bottom:none}
.pf-label{width:118px;flex-shrink:0;background:var(--bg);padding:10px 12px;font-size:12.5px;font-weight:700;color:var(--muted);line-height:1.35}
.pf-value{flex:1;min-width:0;padding:10px 12px;font-size:14px;word-break:break-word}
/* プロフィール表示：2列のリンクアイコン */
.plink-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-top:16px}
.plink-cell{display:flex;align-items:center;gap:10px;background:#fff;border:1.5px solid var(--line);border-radius:12px;padding:11px 12px;text-decoration:none;color:var(--text)}
html.dark .plink-cell{background:#1f242b}
.plink-cell:active{background:var(--bg)}
.plink-cell-name{font-size:14px;font-weight:700;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.time{font-size:10px;color:var(--muted);flex-shrink:0;white-space:nowrap}
.sys{align-self:center;font-size:12px;color:var(--muted);background:rgba(0,0,0,.04);padding:4px 12px;border-radius:12px}

.composer{display:flex;align-items:flex-end;gap:8px;padding:10px 12px;background:#fff;border-top:1px solid var(--line);padding-bottom:calc(10px + env(safe-area-inset-bottom))}
.attach{font-size:24px;color:var(--accent);width:40px;height:40px;display:grid;place-items:center;cursor:pointer;flex-shrink:0}
#msgInput{flex:1;padding:11px 14px;border:1.5px solid var(--line);border-radius:18px;font-size:15px;outline:none;font-family:inherit;line-height:1.4;resize:none;max-height:120px;overflow-y:auto;-webkit-appearance:none}
#msgInput:focus{border-color:var(--accent)}
.send{background:var(--accent);color:#fff;padding:10px 18px;border-radius:22px;font-weight:700;flex-shrink:0}
.readonly-bar{padding:14px 16px;background:#fff;border-top:1px solid var(--line);color:var(--muted);font-size:13px;line-height:1.6;text-align:center;padding-bottom:calc(14px + env(safe-area-inset-bottom))}

/* ===== 右下フローティングボタン（管理者に連絡） ===== */
#contactAdminFab{
  position:fixed;
  right:18px;
  bottom:calc(96px + env(safe-area-inset-bottom));
  z-index:30;
  display:flex;align-items:center;gap:8px;
  background:var(--accent);color:#fff;
  padding:13px 20px;border-radius:30px;
  font-size:15px;font-weight:700;
  box-shadow:0 6px 20px rgba(0,0,0,.22);
  cursor:pointer;
}
#contactAdminFab:active{transform:scale(.96)}
#contactAdminFab .fab-icon{font-size:18px}
.fab-badge{
  position:absolute;top:-6px;right:-4px;
  background:#ff3b30;color:#fff;
  min-width:20px;height:20px;padding:0 5px;border-radius:10px;
  font-size:12px;font-weight:700;
  display:grid;place-items:center;
  border:2px solid #fff;
}

/* ===== サイドバー：自分のプロフィール欄 ===== */
.side-me{display:flex;align-items:center;gap:10px;width:100%;text-align:left;background:var(--bg);border-radius:12px;padding:8px 10px}
.side-me:active{opacity:.85}
.side-me-ava{width:38px;height:38px;border-radius:50%;overflow:hidden;flex-shrink:0;background:#dfe3e8}
.side-me-text{display:flex;flex-direction:column;min-width:0}
.side-me-text #myName{font-weight:700;font-size:14px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.side-me-text small{font-size:11px;color:var(--muted)}

/* ===== メンバー一覧 ===== */
.members-list{display:flex;flex-direction:column;gap:2px}
.member-row{display:flex;align-items:center;gap:12px;padding:10px 8px;border-radius:12px;cursor:pointer}
.member-row:hover{background:var(--bg)}
.member-row .ava{width:46px;height:46px}
.member-info{min-width:0;flex:1}
.member-name{font-weight:700;font-size:15px;display:flex;align-items:center;gap:6px}
/* メンバーの公開/非公開 */
.vis-badge{font-size:10px;font-weight:700;color:#fff;background:#9aa3af;border-radius:6px;padding:1px 6px;letter-spacing:.3px}
.admin-badge{font-size:10px;font-weight:700;color:#fff;background:#99CC00;border-radius:6px;padding:1px 6px;letter-spacing:.3px}
.member-chevron{flex-shrink:0;color:var(--muted);font-size:22px;line-height:1;opacity:.6}
/* プロフィール内：管理者用スイッチ（管理者ON/OFF・表示ON/OFF） */
.profile-admin-ctrls{margin:14px 0 4px;padding:12px 14px;background:var(--bg);border-radius:12px;text-align:left}
.switch-row{display:flex;align-items:center;justify-content:space-between;gap:10px;padding:6px 0;font-size:14px;font-weight:700}
.switch-note{font-size:11.5px;color:var(--muted);line-height:1.5;margin-top:6px}
.switch{position:relative;width:48px;height:28px;border-radius:999px;background:#cfd5db;border:none;flex-shrink:0;transition:background .18s;cursor:pointer}
.switch::after{content:"";position:absolute;top:3px;left:3px;width:22px;height:22px;border-radius:50%;background:#fff;box-shadow:0 1px 3px rgba(0,0,0,.3);transition:transform .18s}
.switch.on{background:#99CC00}
.switch.on::after{transform:translateX(20px)}
html.dark .switch{background:#3a4048}
html.dark .profile-admin-ctrls{background:#1f242b}
.vis-toggle{display:flex;gap:8px}
.vis-opt{flex:1;display:flex;flex-direction:column;gap:2px;align-items:center;padding:9px 8px;border:1.5px solid var(--line);border-radius:10px;background:#fff;font-weight:700;font-size:13px;color:var(--text)}
.vis-opt small{font-weight:400;font-size:10.5px;color:var(--muted)}
.vis-opt.on{border-color:var(--accent);background:color-mix(in srgb,#99CC00 14%,#fff)}
html.dark .vis-opt{background:#1f242b;color:#e8eaed;border-color:#3a4048}
html.dark .vis-opt.on{background:color-mix(in srgb,#99CC00 22%,#1a1d22)}
.vis-note{font-size:11.5px;color:var(--muted);line-height:1.5;margin:8px 0 0}
.composer-notice{padding:12px 14px;text-align:center;font-size:12.5px;color:var(--muted);line-height:1.5;background:var(--bg)}
.member-intro{font-size:12px;color:var(--muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:60vw}
.dot-online{width:8px;height:8px;border-radius:50%;background:var(--accent);display:inline-block}
.empty{color:var(--muted);font-size:14px;text-align:center;padding:20px}

/* ===== ファイル一覧 / リンク一覧 ===== */
.list-search{width:100%;box-sizing:border-box;padding:10px 12px;font-size:16px;border:1px solid #d7dbe0;border-radius:10px;margin:4px 0 12px;background:#fff}
html.dark .list-search{background:#1f242b;color:#e8eaed;border-color:#3a4048}

/* 並べ替えセレクト（写真/PDF/リンク/ピン） */
.list-sort-row{display:flex;justify-content:flex-end;margin:0 0 10px}
.list-sort{font-size:13px;font-weight:700;color:var(--text);background:var(--bg);border:1px solid var(--line);border-radius:9px;padding:7px 28px 7px 12px;appearance:none;-webkit-appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6' viewBox='0 0 10 6'%3E%3Cpath fill='%237a8290' d='M0 0h10L5 6z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 10px center}
html.dark .list-sort{background-color:#1f242b;color:#e8eaed;border-color:#3a4048}
/* 検索(2/3)＋ソート(1/3)を1列に */
.list-top-row{display:flex;gap:8px;align-items:stretch;margin:4px 0 12px}
.list-top-row .list-search{flex:2 1 0;min-width:0;margin:0}
.list-top-row .list-sort{flex:1 1 0;min-width:0;margin:0;font-size:12px;padding:7px 24px 7px 10px}

/* PDF/リンク一覧：#タグチップ＋正方形グリッド */
.list-tags{display:flex;gap:7px;overflow-x:auto;padding:0 0 10px;-webkit-overflow-scrolling:touch}
.list-tag{flex:0 0 auto;font-size:12px;font-weight:700;padding:6px 12px;border-radius:999px;background:var(--bg);color:#5a6472;border:1px solid var(--line);white-space:nowrap}
.list-tag.on{background:var(--accent);color:#fff;border-color:var(--accent)}
html.dark .list-tag{background:#1f242b;color:#aeb6c0;border-color:#3a4048}
/* ToDo作成フォームの#タグ候補（よく使う順・回数バッジ） */
.ac-item .ac-count{margin-left:auto;font-size:12px;font-weight:700;color:#fff;background:#9aa3af;border-radius:999px;padding:1px 8px;min-width:20px;text-align:center}
/* #おまとめ */
.merge-open-btn{width:100%;margin:0 0 12px;padding:10px;border-radius:10px;background:var(--bg);color:var(--accent);font-size:13px;font-weight:700;border:1px solid var(--line)}
.merge-lead{font-size:12.5px;color:var(--muted);line-height:1.6;margin:0 0 12px}
.merge-list{display:flex;flex-direction:column;gap:2px;max-height:40vh;overflow-y:auto;margin-bottom:12px}
.merge-item{display:flex;align-items:center;gap:10px;padding:10px 8px;border-radius:9px;font-size:14px;font-weight:600}
.merge-item:active{background:var(--bg)}
.merge-item input{width:20px;height:20px;flex-shrink:0}
.merge-empty{color:var(--muted);font-size:13px;text-align:center;padding:16px}
/* 日程調整（楽々調整くん） */
.poll-list{display:flex;flex-direction:column;gap:12px}
.poll-card{border:1px solid var(--line);border-radius:14px;padding:12px;background:#fff}
.poll-card.decided{border-color:var(--accent);background:color-mix(in srgb,#99CC00 7%,#fff)}
html.dark .poll-card{background:#1f242b;border-color:#3a4048}
html.dark .poll-card.decided{background:color-mix(in srgb,#99CC00 14%,#1a1d22)}
.poll-head{margin-bottom:8px}
.poll-title{font-weight:800;font-size:15px}
.poll-status{font-size:11px;font-weight:700;color:#fff;background:#9aa3af;border-radius:6px;padding:1px 7px;margin-left:4px;vertical-align:middle}
.poll-card.decided .poll-status{background:var(--accent)}
.poll-sub{font-size:11.5px;color:var(--muted);margin-top:3px}
.poll-cands{display:flex;flex-direction:column;gap:6px;margin-top:4px}
.poll-cand{display:flex;align-items:center;gap:8px;flex-wrap:wrap;padding:7px 8px;border-radius:10px;background:var(--bg)}
.poll-cand.is-decided{outline:2px solid var(--accent)}
.pc-date{font-weight:700;font-size:13px;flex:1;min-width:90px}
.pc-decided{font-size:10px;font-weight:700;color:#fff;background:var(--accent);border-radius:5px;padding:1px 5px}
.pc-vote{display:flex;gap:4px}
.pc-btn{width:34px;height:34px;border-radius:9px;border:1.5px solid var(--line);background:#fff;font-size:16px;font-weight:800;color:#9aa3af}
.pc-btn.pc-yes.on{border-color:#2f9e44;color:#fff;background:#2f9e44}
.pc-btn.pc-maybe.on{border-color:#f08c00;color:#fff;background:#f08c00}
.pc-btn.pc-no.on{border-color:#e03131;color:#fff;background:#e03131}
.pc-btn:disabled{opacity:.5}
html.dark .pc-btn{background:#23272e;border-color:#3a4048}
.pc-count{font-size:11px;color:var(--muted);white-space:nowrap}
.pc-decide{font-size:11px;font-weight:700;color:var(--accent);background:#fff;border:1px solid var(--accent);border-radius:8px;padding:5px 10px;white-space:nowrap}
html.dark .pc-decide{background:#1f242b}
.pc-del-cand{font-size:13px;background:#fff;border:1px solid var(--line);border-radius:8px;padding:5px 8px;color:#c0392b;white-space:nowrap}
html.dark .pc-del-cand{background:#1f242b}
/* 日程調整 一覧のまとめカード */
.poll-sum{display:block;width:100%;text-align:left;background:#fff;border:1px solid var(--line);border-radius:12px;padding:12px 14px;margin-bottom:10px;cursor:pointer}
.poll-sum:active{background:var(--bg)}
html.dark .poll-sum{background:#1f242b}
.poll-sum.decided{border-color:var(--accent)}
.ps-top{display:flex;align-items:center;justify-content:space-between;gap:8px}
.ps-title{font-weight:800;font-size:15px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.ps-status{font-size:11px;font-weight:700;color:#fff;background:#9aa3af;border-radius:6px;padding:2px 8px;flex:none}
.ps-status.open{background:#3e92a8}
.ps-status.decided{background:var(--accent)}
.ps-meta{display:flex;flex-wrap:wrap;gap:4px 12px;font-size:12px;color:var(--muted);margin-top:6px}
#pollDetailModal.open{z-index:62}
#pollDetailBody .poll-card{padding:0;border:none}
.poll-actions{display:flex;gap:8px;margin-top:10px}
.poll-reopen,.poll-del,.poll-share{font-size:12px;font-weight:700;background:var(--bg);border:1px solid var(--line);border-radius:8px;padding:7px 12px;color:var(--muted)}
.poll-del{color:#c0392b}
.poll-share{color:var(--accent);border-color:var(--accent);margin-right:auto}
/* 楽々調整くん：Googleカレンダー空き時間取得 */
.poll-cand-actions{display:flex;gap:8px;flex-wrap:wrap;margin-top:6px}
.gcal-open{color:var(--accent);border-color:var(--accent)}
.gcal-panel{margin-top:10px;padding:12px;border:1px solid var(--line);border-radius:12px;background:var(--bg)}
.gcal-lead{font-size:12px;color:var(--muted);line-height:1.6;margin-bottom:8px}
.gcal-opts{display:flex;flex-direction:column;gap:8px}
.gcal-opt{display:flex;align-items:center;gap:6px;font-size:13px;font-weight:700;flex-wrap:wrap}
.gcal-opt input[type=date]{flex:1;min-width:120px}
.gcal-opt input[type=number]{width:62px}
.gcal-opt.gcal-wd input{width:18px;height:18px;flex:none}
.gcal-run{margin-top:10px;width:auto;padding:0 16px;background:var(--accent);color:#fff;border:none}
.gcal-result{margin-top:10px}
.gcal-loading,.gcal-empty{font-size:13px;color:var(--muted);padding:8px 2px;line-height:1.6}
.gcal-rhead{font-size:13px;font-weight:700;margin-bottom:6px}
.gcal-slotlist{max-height:220px;overflow-y:auto;border:1px solid var(--line);border-radius:10px;padding:4px 8px;background:#fff}
html.dark .gcal-slotlist{background:#1f242b}
.gcal-slot{display:flex;align-items:center;gap:8px;padding:7px 2px;font-size:14px;border-bottom:1px solid var(--line)}
.gcal-slot:last-child{border-bottom:none}
.gcal-slot input{width:18px;height:18px;flex:none}
.gcal-add{margin-top:10px}
/* 着せ替え（テーマカラー） */
.skin-lead{font-size:12.5px;color:var(--muted);line-height:1.6;margin:0 0 12px}
.skin-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:10px}
.skin-card{background:transparent;border:2px solid var(--line);border-radius:12px;padding:6px;cursor:pointer;text-align:center}
.skin-card.on{border-color:var(--accent)}
.skin-mini{border-radius:8px;overflow:hidden;height:62px;display:flex;flex-direction:column;border:1px solid rgba(0,0,0,.06)}
.skin-hd{height:18px}
.skin-bubs{flex:1;display:flex;flex-direction:column;justify-content:center;gap:4px;padding:5px}
.skin-b{height:9px;border-radius:5px}
.skin-b.other{width:60%;background:#fff;box-shadow:0 0 0 1px rgba(0,0,0,.05)}
.skin-b.me{width:55%;align-self:flex-end}
.skin-name{font-size:11px;font-weight:700;margin-top:5px;color:var(--text);line-height:1.3}
@media (max-width:380px){.skin-grid{grid-template-columns:repeat(2,1fr)}}
/* コミュニティ削除（厳重確認） */
.side-danger{color:#c0392b !important}
.delcomm-warn{background:color-mix(in srgb,#e03131 7%,#fff);border:1px solid color-mix(in srgb,#e03131 25%,#fff);border-radius:12px;padding:12px 14px;margin-bottom:14px}
html.dark .delcomm-warn{background:#2a1a1a;border-color:#5a2a2a}
.delcomm-target{font-size:14px;margin:0 0 8px}
.delcomm-lead{font-size:13.5px;font-weight:700;margin:0 0 6px}
.delcomm-list{margin:0 0 10px;padding-left:20px;font-size:13px;line-height:1.8;color:var(--text)}
.delcomm-grace{font-size:13px;line-height:1.7;margin:0;color:var(--text);background:var(--bg);border-radius:8px;padding:8px 10px}
.delcomm-chk{display:flex;gap:9px;align-items:flex-start;font-size:13px;line-height:1.6;margin:10px 0;color:var(--text)}
.delcomm-chk input{width:20px;height:20px;flex:none;margin-top:1px}
.delcomm-btn{width:100%;margin-top:8px;padding:14px;border:none;border-radius:12px;font-size:15px;font-weight:800;background:#cfd5db;color:#fff}
.delcomm-btn.ready{background:#e03131}
.delcomm-btn:disabled{opacity:1;cursor:not-allowed}
.delcomm-cancel{width:100%;margin-top:8px;padding:11px;border:none;border-radius:12px;background:transparent;color:var(--muted);font-weight:700}
/* 選択画面：削除予定（復元可） */
.ci-archived-head{font-size:12.5px;font-weight:700;color:var(--muted);margin:18px 2px 8px}
.community-item.ci-archived{opacity:.85;border:1px dashed var(--line)}
.community-item.ci-archived .emoji{filter:grayscale(.2)}
.ci-archived-meta{color:#c0392b !important}
.ci-restore{flex-shrink:0;background:var(--accent);color:#fff;border:none;border-radius:9px;font-size:12.5px;font-weight:700;padding:8px 12px;white-space:nowrap}
/* 作成フォームの候補日 */
.poll-cand-list{display:flex;flex-direction:column;gap:8px}
.poll-cand-row{display:flex;align-items:center;gap:6px;flex-wrap:wrap}
.poll-cand-row input[type=date]{flex:1;min-width:130px;padding:8px;border:1px solid var(--line);border-radius:8px;font-size:14px}
.poll-cand-row input[type=time]{width:96px;padding:8px;border:1px solid var(--line);border-radius:8px;font-size:14px}
.pcr-allday{font-size:12px;display:flex;align-items:center;gap:3px;white-space:nowrap}
.pcr-x{background:transparent;border:none;font-size:15px;color:var(--muted);padding:6px}
.media-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:9px;overflow-y:auto}
.media-grid .empty{grid-column:1/-1}
.grid-cell{position:relative;aspect-ratio:1/1;display:flex;flex-direction:column;border:1px solid var(--line);border-radius:13px;overflow:hidden;background:#fff;text-decoration:none;color:inherit}
.grid-cell:active{opacity:.85}
.gc-thumb{position:relative;aspect-ratio:16/9;width:100%;flex:0 0 auto;display:flex;align-items:center;justify-content:center;overflow:hidden;background:#0b0b0b}
.gc-thumb.pdf,.gc-thumb.noimg{background:#eef1f4}
.gc-thumb img{width:100%;height:100%;object-fit:cover;display:block}
.gc-web{font-size:26px}
.pdfbadge-lg{width:40px;height:40px;border-radius:10px;background:#e23b3b;color:#fff;font-weight:800;font-size:13px;display:flex;align-items:center;justify-content:center;letter-spacing:.5px}
.gc-ov{position:absolute;right:4px;bottom:4px;max-width:calc(100% - 8px);background:rgba(0,0,0,.6);color:#fff;font-size:9px;font-weight:600;padding:1px 5px;border-radius:6px;line-height:1.5;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.gc-cap{flex:1 1 auto;min-height:0;padding:6px 8px;display:flex;align-items:center}
.gc-title{font-size:11px;font-weight:600;line-height:1.3;color:#5b6470;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.gc-edit{position:absolute;top:5px;right:5px;background:rgba(255,255,255,.92);border:1px solid var(--line);border-radius:8px;font-size:12px;padding:3px 6px;line-height:1;z-index:2}
html.dark .grid-cell{background:#1f242b;border-color:#3a4048}
html.dark .gc-thumb.pdf,html.dark .gc-thumb.noimg{background:#2a313a}
html.dark .gc-title{color:#aeb6c0}
html.dark .gc-edit{background:#262c34;border-color:#3a4048}

/* ===== プロフィール表示（自己紹介ページ） ===== */
.profile-card{position:relative;text-align:center;padding-top:34px}
.profile-x{position:absolute;top:12px;right:12px}
.profile-ava{width:104px;height:104px;border-radius:50%;overflow:hidden;margin:4px auto 14px;background:#dfe3e8}
.profile-ava .ava-init{font-size:42px}
.profile-name{font-size:21px;font-weight:800}
.profile-realname{font-size:12px;color:var(--muted);margin-top:2px}
.profile-intro{font-size:15px;line-height:1.8;color:#333;text-align:left;white-space:pre-wrap;word-break:break-word;background:var(--bg);border-radius:12px;padding:14px;margin:16px 0}
.profile-link{display:inline-block;padding:11px 22px;background:var(--accent);color:#fff;border-radius:24px;font-weight:700;text-decoration:none}

/* ===== プロフィール編集 ===== */
.pedit{display:flex;flex-direction:column;gap:6px}
.pedit-ava-row{display:flex;align-items:center;gap:14px;margin-bottom:8px}
.pedit-ava{width:72px;height:72px;border-radius:50%;overflow:hidden;flex-shrink:0;background:#dfe3e8}
.pedit-ava .ava-init{font-size:30px}
.pedit-ava-btn{background:var(--bg);border:1.5px solid var(--line);border-radius:10px;padding:9px 14px;font-size:14px;font-weight:600;color:var(--text)}
.pedit-ava-side{display:flex;flex-direction:column;gap:8px;align-items:flex-start;min-width:0}
.pedit-name-tap{display:inline-flex;align-items:center;gap:6px;max-width:100%;background:var(--bg);border:1.5px solid var(--line);border-radius:10px;padding:9px 14px;font-size:15px;font-weight:700;color:var(--text);cursor:pointer}
.pedit-name-tap b{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.pedit-name-tap .pn-edit{font-size:12px;font-weight:600;color:var(--accent);flex-shrink:0}
.pedit-name-tap:active{background:color-mix(in srgb,var(--accent) 10%,#fff)}
.pedit .field{margin-bottom:8px}
.pedit textarea{width:100%;padding:10px;border:1.5px solid var(--line);border-radius:10px;font-size:14px;font-family:inherit;resize:vertical}
.counter{text-align:right;font-size:12px;color:var(--muted);margin-top:2px}

/* ===== モーダル ===== */
/* モーダル全体をスクロール可能に。margin:auto で中身が短いときは中央、
   長いとき（＝スマホでキーボードが出たとき）は上下にスクロールして
   「保存」ボタンまで必ず届くようにする。 */
.modal{position:fixed;inset:0;background:rgba(0,0,0,.5);display:none;align-items:flex-start;justify-content:center;padding:16px 16px 120px;z-index:50;overflow-x:hidden;overflow-y:auto;-webkit-overflow-scrolling:touch}
.modal.open{display:flex}
.modal-card{background:#fff;border-radius:16px;width:100%;max-width:520px;padding:18px;margin:auto}
.modal-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px}
.modal-head h2{font-size:17px;margin:0}
.modal-close{background:var(--bg);width:32px;height:32px;border-radius:8px;font-size:15px}
.admin-post{background:var(--bg);border-radius:12px;padding:12px;margin-bottom:16px;display:grid;gap:8px}
.admin-post input,.admin-post textarea{width:100%;padding:10px;border:1.5px solid var(--line);border-radius:10px;font-size:14px;font-family:inherit}
.article{border:1px solid var(--line);border-radius:12px;padding:14px;margin-bottom:10px}
.article h3{margin:0 0 4px;font-size:16px}
.article .meta{font-size:12px;color:var(--muted);margin-bottom:8px}
.article .body{font-size:14px;line-height:1.7;white-space:pre-wrap;color:#333}
.article .body.clamp{white-space:nowrap;overflow:hidden;text-overflow:ellipsis;color:var(--muted)}
.article.pinned{border-color:var(--accent);background:color-mix(in srgb,var(--accent) 6%,#fff)}
.art-actions{display:flex;gap:16px;align-items:center;flex-wrap:wrap;margin-top:8px}
.art-toggle{background:transparent;color:var(--accent);font-size:13px;font-weight:700;padding:4px 0}
.art-pin{background:transparent;color:var(--muted);font-size:13px;font-weight:600;padding:4px 0}
.art-edit{background:transparent;color:var(--accent);font-size:13px;font-weight:600;padding:4px 0}
.art-share{background:transparent;color:var(--accent);font-size:13px;font-weight:700;padding:4px 0}
.share-lead{font-size:13px;color:var(--muted);margin:0 0 12px}
.share-list{display:flex;flex-direction:column;gap:8px}
.share-ch{display:flex;align-items:center;gap:6px;width:100%;text-align:left;background:var(--bg);border:1.5px solid var(--line);border-radius:12px;padding:13px 14px;font-size:15px;font-weight:700;color:var(--text);cursor:pointer}
.share-ch:active{background:color-mix(in srgb,var(--accent) 12%,#fff)}
.share-ch .hash{color:var(--accent)}
/* チャット内の「お知らせ共有」カード */
.bubble.share-card{display:flex;flex-direction:column;gap:4px;cursor:pointer;border:1.5px solid color-mix(in srgb,var(--accent) 45%,#fff);background:color-mix(in srgb,var(--accent) 8%,#fff)}
html.dark .bubble.share-card{background:#1f2a24;border-color:#2e5a44}
.share-card .sc-title{font-weight:700;font-size:14.5px;line-height:1.4}
.share-card .sc-go{font-size:12px;font-weight:700;color:var(--accent)}
.bubble.todo-jump{cursor:pointer}
.todo-jump-go{display:block;margin-top:6px;font-size:12px;font-weight:700;color:var(--accent)}
.todo-card.flash{animation:flashborder 1.2s ease 3}
.bubble.share-card:active{background:color-mix(in srgb,var(--accent) 16%,#fff)}
/* 共有から飛んだ記事をふわっと強調 */
@keyframes artHl{0%{background:color-mix(in srgb,var(--accent) 24%,#fff)}100%{background:transparent}}
.article.art-hl{animation:artHl 1.6s ease}
.art-del{background:transparent;color:#e1473d;font-size:13px;font-weight:600;padding:4px 0}
.head-actions{display:flex;align-items:center;gap:8px}
.art-post-row{display:flex;align-items:center;gap:10px}
#boardLockBtn{padding:0 12px;font-size:13px;font-weight:700;width:auto;color:var(--accent)}
#boardLockBtn.locked{color:#e1473d;border-color:#f0b6b1}
#imgModal img{max-width:92vw;max-height:88vh;border-radius:12px;margin:auto}

/* ===== モバイル ===== */
@media(max-width:720px){
  #sidebar{position:fixed;left:0;top:0;bottom:0;z-index:45;transform:translateX(-100%);transition:transform .25s;box-shadow:4px 0 24px rgba(0,0,0,.12)}
  #sidebar.open{transform:translateX(0)}
  #menuBtn{display:grid;place-items:center}
  .side-close{display:grid;place-items:center}
  /* メニューを開いたときの黒い背景：タップで閉じる */
  #sideOverlay.show{display:block;position:fixed;inset:0;background:rgba(0,0,0,.4);z-index:44}
  .msg{max-width:84%}
}

/* ===== 🌙 ダークモード ===== */
html.dark{
  --bg:#0f1217;
  --text:#e8eaed;
  --muted:#9aa1ab;
  --line:#2c313a;
  --bubble-other:#23272f;
}
html.dark body{background:var(--bg)}
html.dark #login{background:#0f1217}
/* 白背景の面 → 暗い面 */
html.dark .login-card,
html.dark #sidebar,
html.dark .main-head,
html.dark .composer,
html.dark .readonly-bar,
html.dark .modal-card,
html.dark .react-picker,
html.dark .community-item,
html.dark .channel.dragging{background:#191d24}
/* 入力欄・小ボタン */
html.dark input,
html.dark textarea,
html.dark select,
html.dark .mini-btn,
html.dark .move-btn,
html.dark .rchip,
html.dark .install-banner,
html.dark .pedit-ava-btn{background:#23272f;color:var(--text);border-color:var(--line)}
html.dark input::placeholder,html.dark textarea::placeholder{color:#6b7280}
/* テキスト色のハードコード分 */
html.dark .profile-intro,html.dark .article .body{color:var(--text)}
/* 自分の吹き出し（緑）の文字は暗く保つ */
html.dark .msg.me .bubble{color:#10130f}
/* リンク色（暗い吹き出し用に明るく） */
html.dark .bubble a{color:#7fb8ff}
html.dark .msg.me .bubble a{color:#0a4a9e}
/* アバターのプレースホルダ */
html.dark .ava,html.dark .side-me-ava,html.dark .profile-ava,html.dark .pedit-ava{background:#2c313a}
html.dark .side-emoji{background:color-mix(in srgb,var(--accent) 20%,#191d24)}
html.dark .community-item .emoji{background:color-mix(in srgb,var(--c) 20%,#191d24)}
/* アクセント系のうす色（白混ぜ→暗い面混ぜに） */
html.dark .channel.active{background:color-mix(in srgb,var(--accent) 26%,#191d24)}
html.dark .community-item.selected{background:color-mix(in srgb,var(--c) 22%,#191d24)}
html.dark .article.pinned{background:color-mix(in srgb,var(--accent) 14%,#191d24)}
html.dark .role-note,html.dark .drag-hint{background:color-mix(in srgb,var(--accent) 16%,#191d24)}
html.dark .rchip.mine{background:color-mix(in srgb,var(--accent) 24%,#191d24)}
/* 状態バッジ */
html.dark .dm-badge.new{background:color-mix(in srgb,var(--accent) 24%,#191d24)}
html.dark .dm-badge.read{background:#23272f;color:var(--muted)}
html.dark .dm-badge.flag{background:#3a1f27;color:#ff7a9c}
html.dark .dm-badge.unread{background:#3a2e1a;color:#f0b454}
/* ホバー・システムメッセージ */
html.dark .channel:hover,html.dark .side-add:hover,html.dark .side-nav:hover,html.dark .member-row:hover,html.dark .channel-toggle:hover{background:#23272f}
html.dark .sys{background:rgba(255,255,255,.08);color:var(--muted)}

/* ===== 検索 ===== */
#searchInput{width:100%;padding:12px 14px;border:1.5px solid var(--line);border-radius:12px;font-size:15px;background:var(--bg);color:var(--text);margin-bottom:12px}
#searchInput:focus{outline:none;border-color:var(--accent)}
.search-results{display:flex;flex-direction:column;gap:2px}
.search-head{font-size:12px;font-weight:700;color:var(--muted);margin:12px 4px 4px}
.search-item{padding:10px 10px;border-radius:10px;cursor:pointer;border:1px solid var(--line);margin-bottom:4px}
.search-item:hover{background:var(--bg)}
.si-meta{font-size:11px;color:var(--muted);margin-bottom:3px}
.si-text{font-size:14px;line-height:1.5;color:var(--text);word-break:break-word}
.search-item mark{background:color-mix(in srgb,var(--accent) 35%,transparent);color:inherit;border-radius:3px;padding:0 2px}
.search-item.member-row{display:flex;align-items:center;gap:12px}
.msg.flash .bubble{animation:flashbg 1s ease 3}/* 3秒間（1秒×3回）点滅して見落とし防止 */
@keyframes flashbg{0%,100%{box-shadow:0 1px 1px rgba(0,0,0,.04)}30%{box-shadow:0 0 0 3px var(--accent)}}
.article.flash{animation:flashborder 1.5s ease}
@keyframes flashborder{0%,100%{border-color:var(--line)}30%{border-color:var(--accent);box-shadow:0 0 0 2px color-mix(in srgb,var(--accent) 40%,transparent)}}

/* ===== 複数画像（アルバム） ===== */
.bubble.album{padding:3px;display:grid;gap:3px;background:transparent;box-shadow:none}
.album-img{width:100%;object-fit:cover;cursor:pointer;display:block;border-radius:10px;background:#dfe3e8}
.album.one .album-img{max-width:230px;max-height:280px;width:auto;border-radius:12px}
.album.two{grid-template-columns:1fr 1fr}
.album.two .album-img{width:112px;height:112px}
.album.grid{grid-template-columns:1fr 1fr}
.album.grid .album-img{width:112px;height:112px}
.album.many{grid-template-columns:1fr 1fr 1fr}
.album.many .album-img{width:74px;height:74px}
/* アップロード中 */
.attach.uploading{opacity:.4;pointer-events:none}
/* 画像ビューアの前後ナビ */
.img-nav{position:fixed;top:50%;transform:translateY(-50%);width:46px;height:46px;border-radius:50%;background:rgba(0,0,0,.55);color:#fff;font-size:30px;line-height:1;display:grid;place-items:center;z-index:60;border:none}
#imgPrev{left:12px}
#imgNext{right:12px}
.img-count{position:fixed;bottom:calc(24px + env(safe-area-inset-bottom));left:50%;transform:translateX(-50%);color:#fff;background:rgba(0,0,0,.55);padding:5px 14px;border-radius:14px;font-size:13px;z-index:60}

/* ===== 写真フォルダ（自動アルバム） ===== */
.photos-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:4px}
.photo-cell{aspect-ratio:1;border-radius:8px;overflow:hidden;cursor:pointer;background:#dfe3e8}
.photo-cell img{width:100%;height:100%;object-fit:cover;display:block}
.photo-cell:active{opacity:.85}
html.dark .photo-cell{background:#2c313a}

/* ===== 4枚以上：重ねて表示（タップで開く） ===== */
.bubble.album.stack{display:block;position:relative;width:152px;height:132px;padding:0;cursor:pointer}
.stack-card{position:absolute;top:6px;width:118px;height:118px;object-fit:cover;border-radius:12px;border:3px solid #fff;box-shadow:0 2px 9px rgba(0,0,0,.22);background:#dfe3e8}
.stack-card.c2{left:24px;transform:rotate(7deg);z-index:1}
.stack-card.c1{left:13px;transform:rotate(3.5deg);z-index:2}
.stack-card.c0{left:4px;transform:rotate(0);z-index:3}
.stack-count{position:absolute;right:2px;bottom:2px;background:rgba(0,0,0,.62);color:#fff;font-size:12px;font-weight:700;padding:3px 10px;border-radius:13px;z-index:4}
html.dark .stack-card{border-color:#23272f}
/* キャプション付きメディア（写真フォルダ追加など） */
.media-wrap{display:flex;flex-direction:column;gap:4px;align-items:flex-start;max-width:100%}
.msg.me .media-wrap{align-items:flex-end}
.bubble.caption{font-size:14px;line-height:1.5}

/* ===== 押した感（タップ・クリックのフィードバック） =====
   モバイルでは標準のタップ色を消しているため、全ボタン・押せる要素に
   「少し沈む＋色が濃くなる」反応を付けて、押したことが分かるようにする。 */
button{transition:transform .08s ease, filter .12s ease, background-color .12s ease, opacity .12s ease}
button:active{transform:scale(.95)}
/* 塗りつぶし系ボタン（緑など）は色をはっきり濃く＋少し沈める */
.primary:active,.send:active{filter:brightness(.8);transform:scale(.96)}
/* 白・透明・薄色のボタンは背景をはっきり濃く */
.google-btn:active,.ghost:active,.side-add:active,.side-install:active,.side-leave:active,
.icon-btn:active,.channel-toggle:active,.react-add:active,.rchip:active,.mini-btn:active,
.mini-btn.vis:active,.dm-star:active,.remoji:active,.attach:active{background:rgba(0,0,0,.14)}
/* 押せるリスト項目・行 */
.channel:active,.community-item:active,.member-row:active,.search-item:active,.side-me:active{
  background:rgba(0,0,0,.12);transition:background-color .04s ease}
/* 画像・アバターは軽く沈める */
.ava:active,.album-img:active,.photo-cell:active,.bubble.img img:active,
.bubble.album.stack:active,.msg .who:active{opacity:.75}
/* ダークモードは白系で濃淡 */
html.dark .google-btn:active,html.dark .ghost:active,html.dark .side-add:active,
html.dark .side-install:active,html.dark .side-leave:active,html.dark .icon-btn:active,
html.dark .channel-toggle:active,html.dark .react-add:active,html.dark .rchip:active,
html.dark .mini-btn:active,html.dark .mini-btn.vis:active,html.dark .attach:active,html.dark .channel:active,
html.dark .community-item:active,html.dark .member-row:active,html.dark .search-item:active,
html.dark .side-me:active{background:rgba(255,255,255,.18)}

/* 入力プロンプト（グループ名などを入れる小窓） */
.prompt-body{padding:2px}
.prompt-label{display:block;font-size:13px;color:var(--muted);margin:2px 0 7px;font-weight:600}
.prompt-input{width:100%;padding:14px;border:2px solid var(--accent);border-radius:12px;font-size:16px;background:#fff;color:var(--text);outline:none}
.prompt-input::placeholder{color:#b8bec6}
html.dark .prompt-input{background:#1b1f25;color:#e8eaed}
.prompt-actions{display:flex;gap:10px;justify-content:flex-end;margin-top:16px}
.prompt-actions .primary{width:auto;padding:11px 20px}
.prompt-actions .ghost{width:auto;padding:11px 16px}

/* お知らせ記事内の動画埋め込み（YouTube / Vimeo）。チャットの .video-embed と競合しないよう記事内に限定 */
.article .video-embed{max-width:560px;margin:10px 0 4px}
.article .video-embed iframe{position:absolute;inset:0;width:100%;height:100%;border:0}

/* ===== ピン留め ===== */
.pin-btn{background:transparent;border:none;font-size:13px;opacity:.4;cursor:pointer;padding:2px 4px;line-height:1}
.pin-btn.on{opacity:1;filter:saturate(1.4)}
/* 選択シート */
.modal-card.sheet{max-width:380px}
.pin-sheet-body{display:flex;flex-direction:column;gap:10px;padding:4px 2px}
.sheet-btn{display:flex;align-items:center;gap:12px;width:100%;text-align:left;background:#fff;border:1.5px solid var(--line);border-radius:14px;padding:14px;color:var(--text)}
.sheet-btn .se{font-size:24px;flex-shrink:0}
.sheet-btn .st{display:flex;flex-direction:column;gap:2px;min-width:0}
.sheet-btn .st b{font-size:15px}
.sheet-btn .st small{font-size:12px;color:var(--muted)}
.sheet-btn:active{background:rgba(0,0,0,.06)}
html.dark .sheet-btn{background:#1b1f25}
html.dark .sheet-btn:active{background:rgba(255,255,255,.1)}
/* ピン一覧 */
.pins-list{display:flex;flex-direction:column;gap:8px}
.pins-section-label{font-size:12px;font-weight:700;color:var(--muted);margin:8px 4px 2px;display:flex;align-items:center;gap:6px}
.pin-item{display:flex;gap:10px;align-items:flex-start;background:var(--bg);border-radius:12px;padding:10px 12px;cursor:pointer}
.pin-item .pin-main{flex:1;min-width:0}
.pin-item .pin-text{font-size:14px;line-height:1.5;white-space:pre-wrap;word-break:break-word;display:-webkit-box;-webkit-line-clamp:4;-webkit-box-orient:vertical;overflow:hidden}
.pin-item .pin-meta{font-size:11px;color:var(--muted);margin-top:3px}
.pin-item .pin-thumb{width:46px;height:46px;border-radius:8px;object-fit:cover;flex-shrink:0;background:#dfe3e8}
.pin-item .pin-x{background:transparent;border:none;color:var(--muted);font-size:15px;flex-shrink:0;padding:2px 4px;align-self:center}
.pins-empty{font-size:13px;color:var(--muted);text-align:center;padding:16px}

/* ===== メッセージ削除・取消履歴 ===== */
.danger{background:#e0245e;color:#fff;border:none;border-radius:12px;padding:11px 20px;font-size:15px;font-weight:700}
.danger:active{filter:brightness(.85);transform:scale(.97)}
.del-body{padding:2px}
.del-preview{background:var(--bg);border-radius:12px;padding:12px;margin-bottom:12px;max-height:160px;overflow:auto}
.del-preview .dp-who{font-size:12px;color:var(--muted);font-weight:700;margin-bottom:4px}
.del-preview .dp-text{font-size:14px;line-height:1.5;white-space:pre-wrap;word-break:break-word}
.del-note{font-size:13px;color:var(--muted);margin:0 0 16px}
.del-actions{display:flex;gap:10px;justify-content:flex-end}
.del-actions .ghost{width:auto;padding:11px 16px;margin:0}
/* 取消履歴 */
.deleted-log{display:flex;flex-direction:column;gap:8px}
.dlog-item{background:var(--bg);border-radius:12px;padding:10px 12px}
.dlog-body{font-size:14px;line-height:1.5;white-space:pre-wrap;word-break:break-word}
.dlog-meta{font-size:11px;color:var(--muted);margin-top:5px;line-height:1.5}

/* ===== 長押し削除時にiOSのテキスト選択メニュー（コピー等）が出ないようにする =====
   -webkit-touch-callout は継承されないため、子孫すべて(*)に明示的に効かせる。 */
#messages, #messages *, #sidebar, #sidebar *, .modal-card, .modal-card *{
  -webkit-user-select:none;user-select:none;-webkit-touch-callout:none}
/* リンクは押せるが長押しメニューは出さない */
#messages a, .modal-card a{-webkit-touch-callout:none}
/* 入力欄・検索は通常どおり選択／コピー可 */
input, textarea, #messages input, #messages textarea, .modal-card input, .modal-card textarea{
  -webkit-user-select:text;user-select:text;-webkit-touch-callout:default}
.dlog-note{font-size:12px;color:var(--muted);background:var(--bg);border-radius:10px;padding:9px 11px;margin-bottom:8px}

/* ===== @メンション ===== */
#main{position:relative}
.mention-box{position:absolute;left:8px;right:8px;bottom:62px;max-height:230px;overflow-y:auto;background:#fff;border:1px solid var(--line);border-radius:14px;box-shadow:0 -8px 28px rgba(0,0,0,.14);z-index:30}
html.dark .mention-box{background:#1b1f25;border-color:#3a4048}
.mention-item{display:flex;align-items:center;gap:10px;padding:11px 13px;cursor:pointer}
/* スラッシュコマンド候補 */
.cmd-item{display:flex;align-items:center;gap:12px;width:100%;text-align:left;background:transparent;border:none;padding:13px 14px;cursor:pointer;border-bottom:1px solid var(--line)}
.cmd-item:last-child{border-bottom:none}
.cmd-item:active{background:var(--bg)}
.cmd-item .cmd-name{font-size:16px;font-weight:800;color:var(--accent);flex-shrink:0}
.cmd-item .cmd-text{display:flex;flex-direction:column;min-width:0}
.cmd-item .cmd-text b{font-size:15px;font-weight:700;color:var(--text)}
.cmd-item .cmd-text small{font-size:12px;color:var(--muted)}
.cmd-item.soon{opacity:.6}
.mention-item.sel,.mention-item:active{background:rgba(0,0,0,.06)}
html.dark .mention-item.sel,html.dark .mention-item:active{background:rgba(255,255,255,.1)}
.mention-item .ava{width:30px;height:30px;border-radius:50%;overflow:hidden;flex-shrink:0;background:#dfe3e8}
.mention-item .mi-all{font-size:16px;width:30px;height:30px;display:grid;place-items:center;background:color-mix(in srgb,var(--accent) 16%,#fff);border-radius:50%;flex-shrink:0}
.mention-item .mi-name{font-weight:600;font-size:14px}
.mention-item .mi-sub{font-size:11px;color:var(--muted)}
/* メッセージ内の@強調 */
.mention{color:var(--accent);font-weight:700}
.hashtag{color:#1d72d2;font-weight:700;cursor:pointer}
html.dark .hashtag{color:#5aa9ff}
.mention.me{background:color-mix(in srgb,var(--accent) 20%,#fff);border-radius:6px;padding:0 3px}
html.dark .mention.me{background:color-mix(in srgb,var(--accent) 32%,#000)}
/* ヘッダーのメンション件数バッジ */
#notifyBtn{position:relative}
.hdr-badge{position:absolute;top:3px;right:3px;background:#ff3b30;color:#fff;font-size:10px;font-weight:700;min-width:16px;height:16px;padding:0 4px;border-radius:8px;display:grid;place-items:center;line-height:1;border:1.5px solid #fff;pointer-events:none}
html.dark .hdr-badge{border-color:#15181d}
/* お知らせ一覧 */
.notif-list{display:flex;flex-direction:column;gap:8px}
.notif-settings{background:var(--bg);border:1px solid var(--line);border-radius:12px;padding:2px 14px;margin-bottom:8px}
.notif-settings .switch-row{border-bottom:1px solid var(--line)}
.notif-settings .switch-row:last-of-type{border-bottom:none}
/* トースト（ミュート送信など短い通知） */
#toast{position:fixed;left:50%;bottom:96px;transform:translateX(-50%) translateY(8px);background:rgba(30,34,40,.94);color:#fff;font-size:13.5px;font-weight:700;padding:10px 16px;border-radius:20px;z-index:200;opacity:0;pointer-events:none;transition:opacity .2s,transform .2s;max-width:86%;text-align:center}
#toast.show{opacity:1;transform:translateX(-50%) translateY(0)}
.notif-item{display:flex;gap:10px;align-items:flex-start;background:var(--bg);border-radius:12px;padding:10px 12px;cursor:pointer}
.notif-ico{flex-shrink:0;width:28px;height:28px;display:grid;place-items:center;border-radius:50%;background:color-mix(in srgb,var(--accent) 16%,#fff);color:var(--accent);font-weight:800;font-size:14px}
.notif-main{flex:1;min-width:0}
.notif-head{font-size:13px;color:var(--muted)}
.notif-role{display:inline-block;margin-left:6px;font-size:11px;font-weight:700;color:var(--accent);background:color-mix(in srgb,var(--accent) 14%,#fff);border-radius:8px;padding:1px 7px}
html.dark .notif-role{background:#1f2a24}
.notif-head b{color:var(--text)}
.notif-text{font-size:14px;line-height:1.5;word-break:break-word;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;margin-top:1px}
.notif-time{font-size:11px;color:var(--muted);margin-top:3px}

/* ===== リプライ ===== */
.reply-btn,.quote-btn{background:transparent;border:none;color:var(--accent);font-size:12px;font-weight:700;cursor:pointer;padding:2px 8px;line-height:1.6;border-radius:8px}
.quote-btn{color:var(--muted)}
.reply-btn:active,.quote-btn:active{background:rgba(0,0,0,.06)}
/* 返信は誰でも左揃い。自分の返信は緑で区別（右に飛ばさない） */
.msg.in-reply{align-self:flex-start;align-items:flex-start;max-width:100%}
.msg.in-reply .row{flex-direction:row}
.msg.in-reply.reply-mine .bubble{background:var(--bubble-me)}
html.dark .msg.in-reply.reply-mine .bubble{color:#10130f}
.msg.in-reply.reply-mine .bubble a{color:#0a4a9e}
/* 返信見出し（親の真下・親が自分なら右寄せで橋渡し） */
.reply-header{align-self:flex-start;font-size:12px;font-weight:700;color:var(--muted);margin:3px 6px 0 44px;cursor:pointer;display:inline-flex;align-items:center;gap:4px;user-select:none}
.reply-header.me{align-self:flex-end;margin:3px 14px 0 6px;color:var(--accent)}
.reply-header .rh-arrow{font-size:15px;line-height:1}
.reply-header:active{opacity:.6}
.replies{margin:2px 0 9px 40px;padding-left:14px;border-left:2px solid #ccd2da;border-bottom-left-radius:12px;display:flex;flex-direction:column;gap:1px}
html.dark .replies{border-left-color:#3a4048}
/* 返信への返信：どの投稿宛てかをうっすら表示（タップで該当箇所へ） */
/* リプライ引用（LINE風：相手のアイコン＋名前＋本文2行） */
.reply-quote{display:block;background:rgba(0,0,0,.045);border-radius:10px;padding:7px 10px 14px;margin-bottom:-10px;cursor:pointer;max-width:100%;border-left:3px solid var(--accent)}
/* 引用元に返信の吹き出しを少し被せて隙間を消す（吹き出しを前面に） */
.msg-body>.row{position:relative;z-index:1}
.reply-quote{position:relative;z-index:0}
html.dark .reply-quote{background:rgba(255,255,255,.08)}
.reply-quote:active{background:rgba(0,0,0,.1)}
.rq-head{display:flex;align-items:center;gap:6px;margin-bottom:3px}
.rq-ava{width:22px;height:22px;border-radius:50%;overflow:hidden;flex-shrink:0;background:#dfe3e8}
.rq-ava .ava-init{font-size:11px}
.rq-name{font-size:12px;font-weight:700;color:var(--text);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.rq-text{font-size:12.5px;color:var(--muted);line-height:1.45;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;white-space:normal;word-break:break-word}
/* ぽよよん（該当箇所へジャンプした時の強調） */
@keyframes poyo{0%{transform:scale(1)}30%{transform:scale(1.06)}55%{transform:scale(.98)}80%{transform:scale(1.02)}100%{transform:scale(1)}}
.msg.bounce .bubble{animation:poyo .7s ease}
.replies .msg{margin:2px 0}
.replies .bubble{font-size:14px;padding:7px 11px}
.replies-more{align-self:flex-start;background:transparent;border:none;color:var(--accent);font-size:13px;font-weight:700;padding:4px 2px;cursor:pointer}
/* 返信中バー */
.reply-bar{display:flex;align-items:center;gap:8px;padding:8px 14px;background:color-mix(in srgb,var(--accent) 10%,#fff);border-top:1px solid var(--line);font-size:13px}
html.dark .reply-bar{background:#1f242b}
.reply-bar .rb-text{flex:1;color:var(--muted);min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.reply-bar .rb-text b{color:var(--text)}
.reply-bar .rb-x{background:transparent;border:none;color:var(--muted);font-size:14px;padding:2px 8px;flex-shrink:0}
/* 送信前の写真・ファイルのプレビュー */
.attach-preview{display:flex;gap:8px;flex-wrap:wrap;padding:10px 12px 4px;background:var(--bg);border-top:1px solid var(--line)}
.ap-item{position:relative;width:64px;height:64px;border-radius:10px;overflow:hidden;background:#fff;border:1px solid var(--line);flex-shrink:0}
html.dark .ap-item{background:#23272f}
.ap-item img{width:100%;height:100%;object-fit:cover;display:block}
.ap-file{width:100%;height:100%;display:flex;align-items:center;justify-content:center;font-size:11px;padding:4px;text-align:center;color:var(--muted);word-break:break-all;overflow:hidden}
.ap-x{position:absolute;top:2px;right:2px;width:20px;height:20px;border:none;border-radius:50%;background:rgba(0,0,0,.6);color:#fff;font-size:11px;line-height:1;display:grid;place-items:center;cursor:pointer}

/* 他コミュニティのプロフィール反映：選択リスト */
.pcopy-list { display: flex; flex-direction: column; gap: 8px; }
.pcopy-item {
  display: flex; align-items: center; gap: 10px;
  width: 100%; padding: 10px 12px; border: 1px solid #e3e6ea; border-radius: 12px;
  background: #fff; cursor: pointer; text-align: left; font: inherit; color: inherit;
}
.pcopy-item:hover { background: #f6f8fa; }
.pcopy-ico {
  width: 36px; height: 36px; border-radius: 10px; flex: none;
  display: flex; align-items: center; justify-content: center;
  background: var(--c, #06c755); color: #fff; font-size: 18px; overflow: hidden;
}
.pcopy-ico img { width: 100%; height: 100%; object-fit: cover; }
.pcopy-name { flex: 1; font-weight: 600; }
.pcopy-go { color: #06c755; font-weight: 600; font-size: 14px; }

/* 過去メッセージを読み込むボタン（メッセージ一覧の最上部） */
.load-older{display:block;margin:6px auto 12px;padding:8px 16px;border:1px solid var(--line);border-radius:999px;background:#fff;color:var(--muted);font-size:13px;font-weight:700;cursor:pointer}
.load-older:active{background:var(--bg)}
.load-older:disabled{opacity:.6;cursor:default}
html.dark .load-older{background:#23272e;color:#aab2bd;border-color:#3a4048}

/* ===== イベントカレンダー ===== */
/* カレンダー部は固定し、下のスケジュールだけスクロールさせる（縦を画面内に収める） */
#calendarModal{padding-bottom:24px;align-items:center}
.cal-card{max-width:520px;display:flex;flex-direction:column;max-height:calc(100dvh - 48px);overflow:hidden}
.cal-card > .modal-head,.cal-card > .cal-nav,.cal-card > .cal-grid-head,.cal-card > .cal-grid{flex:none}
.cal-nav{display:flex;align-items:center;justify-content:center;gap:10px;margin:4px 0 10px}
.cal-navbtn{width:36px;height:36px;border:1px solid var(--line);border-radius:10px;background:#fff;font-size:20px;line-height:1;cursor:pointer;color:var(--text)}
.cal-navbtn:active{background:var(--bg)}
.cal-monthlabel{font-size:17px;font-weight:800;min-width:130px;text-align:center}
.cal-today{margin-left:6px;border:1px solid var(--accent);color:var(--accent);background:#fff;border-radius:999px;font-size:12px;font-weight:700;padding:5px 12px;cursor:pointer}
.cal-grid-head{display:grid;grid-template-columns:repeat(7,1fr);text-align:center;font-size:12px;color:var(--muted);font-weight:700;margin-bottom:4px}
.cal-grid-head span:first-child{color:#e1473d}
.cal-grid-head span:last-child{color:#2f6fed}
.cal-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:3px}
.cal-cell{position:relative;aspect-ratio:1/1;border:none;background:var(--bg);border-radius:9px;cursor:pointer;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2px;font-family:inherit}
.cal-cell.empty{background:transparent;cursor:default}
.cal-daynum{font-size:14px;font-weight:700;color:var(--text)}
.cal-cell.sun .cal-daynum{color:#e1473d}
.cal-cell.sat .cal-daynum{color:#2f6fed}
.cal-cell.today{outline:2px solid var(--accent);outline-offset:-2px}
.cal-cell.selected{background:var(--accent)}
.cal-cell.selected .cal-daynum{color:#fff}
.cal-dot{width:6px;height:6px;border-radius:50%;background:var(--accent)}
.cal-cell.selected .cal-dot{background:#fff}
html.dark .cal-navbtn,html.dark .cal-today{background:#23272e}
/* 下のスケジュール部：ここだけ縦スクロール（カレンダーは固定のまま） */
.cal-daypanel{flex:1 1 auto;min-height:80px;overflow-y:auto;-webkit-overflow-scrolling:touch;margin-top:10px;border-top:1px solid var(--line);padding-top:10px;display:flex;flex-direction:column;gap:8px}
.cal-day-empty{font-size:13px;color:var(--muted);padding:4px 2px}
.cal-add-btn{width:100%;padding:11px;background:var(--accent);color:#fff;font-size:14px;font-weight:800;border:none;border-radius:12px;cursor:pointer;flex:none}
.ev-cat{font-size:11px;font-weight:700;color:var(--accent);background:color-mix(in srgb,var(--accent) 12%,#fff);border:1px solid color-mix(in srgb,var(--accent) 35%,#fff);border-radius:6px;padding:1px 7px}
/* 予定一覧（アジェンダ） */
.agenda-month{font-size:12px;font-weight:800;color:var(--muted);margin:6px 0 2px;position:sticky;top:0;background:var(--card,#fff);padding:2px 0}
html.dark .agenda-month{background:#23272e}
.agenda-row{display:flex;gap:12px;align-items:flex-start;text-align:left;width:100%;border:none;background:transparent;border-bottom:1px solid var(--line);padding:10px 2px;cursor:pointer;font-family:inherit}
.agenda-row:active{background:var(--bg)}
.agenda-date{flex:none;width:38px;text-align:center;line-height:1.1}
.agenda-date .ad-day{display:block;font-size:20px;font-weight:800;color:var(--text)}
.agenda-date .ad-wd{display:block;font-size:11px;color:var(--muted)}
.agenda-date.today .ad-day{color:#fff;background:var(--accent);border-radius:50%;width:30px;height:30px;line-height:30px;margin:0 auto}
.agenda-main{flex:1;min-width:0}
.agenda-title{font-size:15px;font-weight:700;color:var(--text);display:flex;align-items:center;gap:6px;flex-wrap:wrap}
.agenda-sub{font-size:12px;color:var(--muted);margin-top:3px;display:flex;gap:12px;flex-wrap:wrap}
/* イベント フォーム */
/* 入力欄は16px以上＝iOSのフォーカス時ズーム（横揺れ）を防ぐ */
#eventFormModal input,#eventFormModal select,#eventFormModal textarea{font-size:16px}
.ev-allday{display:inline-flex;align-items:center;gap:5px;font-size:13px;color:var(--text);margin-bottom:6px}
.ev-time-row{display:flex;align-items:center;gap:8px}
.ev-time-row input{flex:1;min-width:0}
/* フォームの横はみ出しを完全に抑える（横揺れ防止） */
#eventFormModal .modal-card{overflow-x:hidden}
#eventFormModal input,#eventFormModal select,#eventFormModal textarea{max-width:100%}
.ev-locmode{display:flex;flex-direction:column;gap:6px;margin-bottom:8px;font-size:14px}
.ev-locmode label{display:inline-flex;align-items:center;gap:6px}
.ev-fee-grid{display:flex;flex-direction:column;gap:6px}
.ev-fee-grid input{width:100%;box-sizing:border-box;padding:10px;border:1px solid var(--line);border-radius:9px;font-size:14px}
.ev-cancel-row{display:flex;gap:14px;margin-bottom:6px;font-size:14px}
.ev-cancel-row label{display:inline-flex;align-items:center;gap:5px}
/* イベント出欠（RSVP） */
.evv-rsvp{margin-top:14px;padding-top:12px;border-top:2px solid var(--line)}
.evv-rsvp-head{font-size:13px;font-weight:800;margin-bottom:8px}
.evv-rsvp-btns{display:flex;gap:8px}
.evv-rsvp-btns button{flex:1;padding:12px;border-radius:12px;border:1.5px solid var(--line);background:#fff;font-size:15px;font-weight:800;color:#7a8290}
.rsvp-yes.on{border-color:#2f9e44;background:#2f9e44;color:#fff}
.rsvp-no.on{border-color:#e03131;background:#e03131;color:#fff}
html.dark .evv-rsvp-btns button{background:#23272e}
.evv-rsvp-list{font-size:12px;color:var(--text);margin-top:8px;line-height:1.5}
.evv-rsvp-list.muted{color:var(--muted)}
/* イベント詳細 */
.evv-row{display:flex;gap:10px;padding:9px 2px;border-bottom:1px solid var(--line);font-size:14px}
.evv-row:last-child{border-bottom:none}
.evv-k{flex:none;width:70px;color:var(--muted);font-weight:700}
.evv-v{flex:1;min-width:0;word-break:break-word}
.ev-view-actions{display:flex;flex-wrap:wrap;gap:8px;margin-top:14px}
.ev-act{flex:1;min-width:120px;padding:11px;border:1px solid var(--line);border-radius:12px;background:#fff;font-size:14px;font-weight:700;color:var(--text);cursor:pointer}
.ev-act:active{background:var(--bg)}
.ev-act.ev-del{color:#e1473d;border-color:#f0b6b1}
html.dark .ev-act{background:#23272e}

/* イベント：繰り返し設定 */
.ev-repeat-opts{margin-top:8px;padding:10px;border:1px dashed var(--line);border-radius:10px;display:flex;flex-direction:column;gap:8px;background:var(--bg)}
.ev-rep-row{display:flex;align-items:center;gap:8px;font-size:13px;color:var(--text);flex-wrap:wrap}
.ev-rep-row span{flex:none}
.ev-rep-row input[type=number]{width:64px;flex:none}
.ev-rep-row input[type=date]{flex:1;min-width:120px}
.ev-rep-mark{font-size:12px}
.cal-add-bday{background:#ff7eb6}
html.dark .cal-add-bday{background:#c64d86}

/* 長文：続きを読む */
.read-more{display:inline;background:none;border:none;padding:0;margin-left:2px;color:var(--accent);font-weight:700;font-size:inherit;cursor:pointer;font-family:inherit}
.read-more span{text-decoration:underline}
.msg.me .read-more{color:#0a5}

/* 長文ノート（全画面ポップアップ） */
.note-modal{align-items:stretch;justify-content:stretch;padding:0;overflow:hidden}
.note-card{background:var(--card,#fff);width:100%;height:100dvh;margin:0;display:flex;flex-direction:column;border-radius:0}
html.dark .note-card{background:#1a1d22}
.note-head{display:flex;align-items:center;justify-content:space-between;gap:10px;padding:14px 16px;border-bottom:1px solid var(--line);flex:none;padding-top:max(14px,env(safe-area-inset-top))}
.note-title{font-size:15px;font-weight:800;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.note-close{flex:none;background:var(--bg);border:1px solid var(--line);border-radius:10px;padding:8px 14px;font-size:14px;font-weight:700;color:var(--text);cursor:pointer}
.note-close:active{background:var(--line)}
.note-body{flex:1 1 auto;overflow-y:auto;-webkit-overflow-scrolling:touch;padding:16px;font-size:16px;line-height:1.85;word-break:break-word;display:flex;flex-direction:column;gap:12px}
.note-text{white-space:pre-wrap}
.note-actions{flex:none;display:flex;flex-wrap:wrap;gap:8px;padding:12px 16px;border-top:1px solid var(--line);padding-bottom:max(12px,env(safe-area-inset-bottom))}
.note-act{flex:1;min-width:96px;padding:13px;border:1px solid var(--line);border-radius:12px;background:#fff;font-size:14px;font-weight:700;color:var(--text);cursor:pointer}
.note-act:active{background:var(--bg)}
html.dark .note-act{background:#23272e}
.note-act.note-del{color:#e1473d;border-color:#f0b6b1}
.note-act.note-save{background:var(--accent);color:#fff;border-color:var(--accent)}
.note-edit-area{flex:1 1 auto;display:flex;padding:16px;min-height:0}
.note-edit-area textarea{width:100%;height:100%;min-height:240px;resize:none;border:1.5px solid var(--line);border-radius:12px;padding:12px;font-size:16px;line-height:1.8;font-family:inherit;background:#fff}
html.dark .note-edit-area textarea{background:#23272e;color:#e8eaed}
/* ノート内リンクサムネイル＋× */
.note-preview-wrap{position:relative}
.note-preview-x{position:absolute;top:8px;right:8px;width:30px;height:30px;border-radius:50%;border:none;background:rgba(0,0,0,.6);color:#fff;font-size:14px;cursor:pointer;display:none;place-items:center;z-index:2}
.note-preview-wrap .link-preview:not([hidden]) + .note-preview-x{display:grid}

/* 部分コピーシートは長文ノートより前面に */
#copySheet{z-index:70}

/* コミュニティ選択カード：未読通知バッジ */
.community-item{position:relative}
.community-item.ci-in{animation:ci-in .4s ease both}
@keyframes ci-in{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:none}}
@media (prefers-reduced-motion:reduce){.community-item.ci-in{animation:none}}
.ci-badge{position:absolute;top:6px;left:44px;min-width:20px;height:20px;padding:0 6px;border-radius:999px;background:#e1473d;color:#fff;font-size:11px;font-weight:800;display:grid;place-items:center;line-height:1;box-shadow:0 1px 3px rgba(0,0,0,.25);border:2px solid #fff}
html.dark .ci-badge{border-color:#1a1d22}

/* ベル：他コミュニティ通知（色・表記を変えて区別） */
.notif-other-head{font-size:12px;font-weight:800;color:var(--muted);margin:14px 2px 6px;padding-top:10px;border-top:1px dashed var(--line)}
.notif-item.notif-other{background:color-mix(in srgb,#99CC00 9%,#fff);border-radius:12px}
html.dark .notif-item.notif-other{background:color-mix(in srgb,#99CC00 16%,#1a1d22)}
.notif-item.notif-other.unread{background:color-mix(in srgb,#99CC00 18%,#fff)}
.notif-comm{color:#5f7d00}
html.dark .notif-comm{color:#b7e000}
.notif-new{display:inline-block;margin-left:6px;font-size:10px;font-weight:800;color:#fff;background:#e1473d;border-radius:4px;padding:0 5px;vertical-align:middle}

/* メールでログイン（6桁コード） */
.email-login{margin-top:14px}
.email-or{display:flex;align-items:center;gap:10px;color:var(--muted);font-size:12px;margin:6px 0 12px}
.email-or::before,.email-or::after{content:"";flex:1;height:1px;background:var(--line)}
#emailLogin input{width:100%;padding:13px;border:1.5px solid var(--line);border-radius:12px;font-size:16px;background:#fff;margin-bottom:10px}
html.dark #emailLogin input{background:#23272e;color:#e8eaed}
#emailLogin .primary{margin-top:0}
.email-sent{font-size:13px;color:var(--muted);margin-bottom:10px;line-height:1.6}
.email-link{flex:1;background:none;border:none;color:var(--muted);text-decoration:underline;font-size:13px;padding:10px 0;margin-top:4px;cursor:pointer}
.email-link:disabled{color:var(--line);text-decoration:none;cursor:default}
.email-sub-actions{display:flex;gap:8px;align-items:center}

/* アプリ内ログイン誘導の注意書き */
.app-login-notice{background:color-mix(in srgb,#99CC00 14%,#fff);border:1.5px solid #99CC00;border-radius:12px;padding:12px 14px;font-size:14px;font-weight:700;color:#3d5400;line-height:1.6;margin:6px 0 2px;text-align:center}
.app-login-notice small{font-weight:500;color:var(--muted);font-size:12px}
html.dark .app-login-notice{background:color-mix(in srgb,#99CC00 20%,#1a1d22);color:#cde85a}

/* イベント：リマインド選択 */
.ev-remind-opts{display:flex;flex-direction:column;gap:7px;margin-top:4px;font-size:14px}
.ev-remind-opts label{display:inline-flex;align-items:center;gap:7px}
