/* 山形まちづくり大学 事務局ボード — 共通デザインシステム
 * Figma（まち大HP）準拠：白基調＋深緑アクセント、英語ラベル＋日本語サブ、角丸カード、広い余白。
 * 絵文字は使わない。アイコンはインラインSVG（.ic）で統一。 */
:root{
  --green:#1F5B43; --green-d:#163D2D; --green-dd:#0E2B1C; --green-soft:#EAF1EC; --green-tint:#F2F7F3;
  --gold:#B8924F; --gold-d:#8A6A33;
  --bg:#F6F8F5; --surface:#FFFFFF; --line:#E5E9E1; --line-2:#EEF1EA;
  --ink:#1D2B22; --ink-2:#46544B; --muted:#7A867D; --faint:#9AA59D;
  --todo:#D6D9CE; --doing:#C8820E; --done:#1F5B43; --na:#8E978B;
  --danger:#B23B2E; --info:#2C6E8F;
  --shadow-s:0 1px 2px rgba(16,43,28,.05);
  --shadow:0 2px 10px rgba(16,43,28,.06), 0 1px 3px rgba(16,43,28,.05);
  --shadow-l:0 16px 48px rgba(16,43,28,.18);
  --radius:16px; --radius-s:11px;
  --font-head:'Zen Kaku Gothic New',sans-serif;
  --font-body:'Noto Sans JP',sans-serif;
  --font-en:'Quicksand','Zen Kaku Gothic New',sans-serif;
}
*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{font-family:var(--font-body);color:var(--ink);line-height:1.7;background:var(--bg);-webkit-font-smoothing:antialiased;-webkit-text-size-adjust:100%}
a{color:var(--green)}
h1,h2,h3,h4{font-family:var(--font-head);font-weight:700;margin:0}
img{max-width:100%}

/* ---- 英語マイクロラベル（Figmaの "Course Fee" 等の見出しパターン） ---- */
.eyebrow{font-family:var(--font-en);font-weight:700;font-size:11px;letter-spacing:.16em;color:var(--gold-d);text-transform:uppercase}

/* ---- アイコン（インラインSVG共通サイズ） ---- */
.ic{width:1em;height:1em;display:inline-block;vertical-align:-.125em;flex:none;fill:none;stroke:currentColor;stroke-width:1.9;stroke-linecap:round;stroke-linejoin:round}

/* ---- ボタン ---- */
.btn{font-family:var(--font-head);font-weight:700;font-size:13.5px;cursor:pointer;border:1px solid var(--line);
  background:var(--surface);color:var(--ink);padding:9px 18px;border-radius:99px;transition:.15s;display:inline-flex;align-items:center;gap:8px;text-decoration:none;line-height:1}
.btn:hover{border-color:var(--green);color:var(--green)}
.btn:disabled{opacity:.5;cursor:not-allowed}
.btn-primary{background:var(--green);color:#fff;border-color:var(--green)}
.btn-primary:hover{background:var(--green-d);color:#fff}
.btn-ghost{background:transparent;border-color:transparent;color:var(--ink-2)}
.btn-ghost:hover{background:var(--green-soft);color:var(--green);border-color:transparent}
.btn-sm{padding:6px 13px;font-size:12.5px}
.btn-danger{color:var(--danger);border-color:#E7CFCB}
.btn-danger:hover{background:#FBEEEC;border-color:var(--danger);color:var(--danger)}

/* ---- カード ---- */
.card{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow)}

/* ---- フォーム ---- */
.field{margin-bottom:14px}
.field label{display:block;font-family:var(--font-head);font-weight:700;font-size:13px;margin-bottom:6px;color:var(--ink)}
.field .hint{font-size:12px;color:var(--muted);margin-top:5px;line-height:1.5}
.input,textarea.input,select.input{width:100%;font-family:var(--font-body);font-size:15px;color:var(--ink);
  border:1.5px solid var(--line);background:#fff;border-radius:11px;padding:11px 13px;transition:.15s}
.input:focus,textarea.input:focus,select.input:focus{outline:none;border-color:var(--green);box-shadow:0 0 0 3px rgba(31,91,67,.12)}
textarea.input{resize:vertical;line-height:1.6}

/* ---- バッジ / チップ ---- */
.badge{font-family:var(--font-head);font-weight:700;font-size:11px;padding:2px 9px;border-radius:99px;display:inline-flex;align-items:center;gap:5px;line-height:1.5;white-space:nowrap}
.badge-green{background:var(--green-soft);color:var(--green-d)}
.badge-gold{background:#FBF3E4;color:var(--gold-d);border:1px solid #EBDCC0}
.badge-line{background:#fff;color:var(--ink-2);border:1px solid var(--line)}
.role-admin{background:var(--green);color:#fff}
.role-editor{background:var(--green-soft);color:var(--green-d)}
.role-viewer{background:#EEF1EA;color:var(--muted)}

/* ---- 認証/中央寄せレイアウト ---- */
.auth-wrap{min-height:100vh;display:grid;place-items:center;padding:24px;
  background:radial-gradient(1100px 460px at 50% -8%, var(--green-soft) 0%, rgba(234,241,236,0) 62%), var(--bg)}
.auth-card{width:100%;max-width:430px;background:var(--surface);border:1px solid var(--line);border-radius:22px;box-shadow:var(--shadow-l);padding:34px 32px}
.brand-mark{width:54px;height:54px;border-radius:15px;display:grid;place-items:center;color:#fff;
  background:linear-gradient(150deg,var(--green),var(--green-d));font-family:var(--font-head);font-weight:700;font-size:24px;margin:0 auto 14px}
.auth-card h1{font-size:20px;text-align:center;color:var(--green-d);margin-bottom:4px}
.auth-card .sub{text-align:center;font-size:13px;color:var(--muted);margin-bottom:22px}
.msg{font-size:13px;border-radius:10px;padding:10px 13px;margin:12px 0;line-height:1.6;display:none}
.msg.show{display:block}
.msg-err{background:#FBEEEC;color:var(--danger);border:1px solid #E7CFCB}
.msg-ok{background:var(--green-soft);color:var(--green-d);border:1px solid #CFE0D5}
.msg-info{background:#EAF2F6;color:var(--info);border:1px solid #CFE2EB}
.divider{display:flex;align-items:center;gap:12px;color:var(--faint);font-size:12px;margin:18px 0}
.divider::before,.divider::after{content:"";height:1px;background:var(--line);flex:1}

/* ---- ローディング ---- */
.spin{width:16px;height:16px;border:2px solid rgba(255,255,255,.4);border-top-color:#fff;border-radius:50%;animation:spin .7s linear infinite;display:inline-block}
@keyframes spin{to{transform:rotate(360deg)}}

/* ---- アプリ共通ヘッダ ---- */
.appbar{background:linear-gradient(155deg,var(--green) 0%,var(--green-d) 100%);color:#fff;
  position:sticky;top:0;z-index:40;box-shadow:0 3px 16px rgba(14,43,28,.22)}
.appbar .row{max-width:1300px;margin:0 auto;padding:13px 22px;display:flex;align-items:center;gap:16px;flex-wrap:wrap}
.appbar .logo{display:flex;align-items:center;gap:11px;min-width:0;text-decoration:none;color:#fff}
.appbar .logo .m{width:38px;height:38px;border-radius:11px;flex:none;display:grid;place-items:center;
  background:rgba(255,255,255,.14);border:1px solid rgba(255,255,255,.2);font-family:var(--font-head);font-weight:700;font-size:18px}
.appbar h1{font-size:16px;line-height:1.25;letter-spacing:.01em}
.appbar .logo .s{font-size:10.5px;opacity:.82;font-family:var(--font-en);letter-spacing:.08em}
.appbar .spacer{flex:1}
.appbar .navlinks{display:flex;gap:4px;flex-wrap:wrap}
.appbar .navlinks a{color:rgba(255,255,255,.86);text-decoration:none;font-family:var(--font-head);font-weight:700;font-size:13px;padding:7px 13px;border-radius:99px}
.appbar .navlinks a:hover,.appbar .navlinks a.active{background:rgba(255,255,255,.16);color:#fff}

/* アカウントメニュー */
.acct-btn{display:flex;align-items:center;gap:9px;background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.18);
  border-radius:99px;padding:5px 6px 5px 13px;cursor:pointer;color:#fff;font-family:var(--font-body)}
.acct-btn:hover{background:rgba(255,255,255,.2)}
.acct-btn .nm{font-size:13px;font-weight:700;max-width:140px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.acct-btn .av{width:28px;height:28px;border-radius:99px;background:#fff;color:var(--green-d);display:grid;place-items:center;font-family:var(--font-head);font-weight:700;font-size:13px;flex:none}
.menu{position:absolute;right:22px;top:60px;background:#fff;color:var(--ink);border:1px solid var(--line);border-radius:14px;
  box-shadow:var(--shadow-l);min-width:240px;padding:8px;z-index:60;display:none}
.menu.show{display:block}
.menu .who{padding:10px 12px 12px;border-bottom:1px solid var(--line-2);margin-bottom:6px}
.menu .who .n{font-family:var(--font-head);font-weight:700;font-size:14px}
.menu .who .e{font-size:11.5px;color:var(--muted);word-break:break-all}
.menu button,.menu a{display:flex;align-items:center;gap:9px;width:100%;text-align:left;background:none;border:0;
  font-family:var(--font-body);font-size:13.5px;color:var(--ink);padding:9px 12px;border-radius:9px;cursor:pointer;text-decoration:none}
.menu button:hover,.menu a:hover{background:var(--green-tint)}

/* ---- モーダル ---- */
.overlay{position:fixed;inset:0;background:rgba(14,43,28,.5);backdrop-filter:blur(3px);z-index:90;display:none;place-items:center;padding:20px}
.overlay.show{display:grid}
.modal{background:var(--surface);border-radius:18px;max-width:560px;width:100%;box-shadow:var(--shadow-l);max-height:88vh;display:flex;flex-direction:column}
.modal .mhead{padding:18px 22px;border-bottom:1px solid var(--line-2);display:flex;align-items:center;gap:12px}
.modal .mhead h3{font-size:16px;color:var(--green-d)}
.modal .mhead .x{margin-left:auto;background:none;border:0;cursor:pointer;color:var(--muted);font-size:20px;line-height:1;padding:4px}
.modal .mbody{padding:20px 22px;overflow:auto}
.modal .mfoot{padding:14px 22px;border-top:1px solid var(--line-2);display:flex;gap:10px;justify-content:flex-end}

/* ---- テーブル ---- */
.tbl{width:100%;border-collapse:collapse;font-size:13.5px}
.tbl th{text-align:left;font-family:var(--font-head);font-weight:700;font-size:12px;color:var(--muted);padding:10px 12px;border-bottom:2px solid var(--line)}
.tbl td{padding:11px 12px;border-bottom:1px solid var(--line-2);vertical-align:middle}
.tbl tr:hover td{background:var(--green-tint)}

/* ---- セクション見出し（英語ラベル＋日本語） ---- */
.sec-head{display:flex;align-items:baseline;gap:11px;margin:0 0 10px}
.sec-head h2{font-size:18px;color:var(--green-d)}

.toast{position:fixed;left:50%;bottom:26px;transform:translateX(-50%) translateY(20px);background:var(--green-d);color:#fff;
  padding:11px 20px;border-radius:99px;font-size:13px;font-weight:700;box-shadow:var(--shadow-l);opacity:0;pointer-events:none;transition:.25s;z-index:120}
.toast.show{opacity:1;transform:translateX(-50%) translateY(0)}

.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);border:0}
@media(max-width:640px){
  .appbar h1{font-size:14px}
  .appbar .navlinks a{font-size:12px;padding:6px 10px}
  .menu{right:12px}
  .auth-card{padding:26px 20px}
}

/* キーボード操作のフォーカス可視化（a11y） */
:focus-visible{outline:2px solid var(--green);outline-offset:2px;border-radius:6px}
.appbar a:focus-visible,.acct-btn:focus-visible,.appbar button:focus-visible{outline:2px solid #fff;outline-offset:2px}

/* 印刷／PDF配布用：操作系を隠し、全カードを展開して読めるようにする */
@media print{
  .appbar,.menu,.toolbar,.toast,.overlay,.imeta .hist,.seg,.foot .nolink{display:none !important}
  body{background:#fff}
  .ev{break-inside:avoid;box-shadow:none;border:1px solid #bbb}
  .ev-body{display:block !important}
  .detail{border:0;background:#fff}
  a[href]:after{content:""}
}
