    /* TOPページのみ gs-topbar を sticky 維持 */
    .gs-topbar {
      position: sticky;
      top: 0;
      backdrop-filter: blur(18px);
      z-index: 20;
    }
    :root {
      --text-xs: .75rem;
      --text-sm: .875rem;
      --text-base: 1rem;
      --text-lg: 1.125rem;
      --text-xl: clamp(1.45rem, 1.18rem + 1vw, 2rem);
      --color-bg: #f6f8fc;
      --color-surface: #ffffff;
      --color-surface-2: #f8fafd;
      --color-surface-3: #eef3fd;
      --color-border: rgba(60,64,67,.14);
      --color-divider: rgba(60,64,67,.10);
      --color-text: #202124;
      --color-text-muted: #5f6368;
      --color-text-faint: #80868b;
      --color-primary: #1a73e8;
      --color-primary-soft: rgba(26,115,232,.10);
      --color-green: #188038;
      --color-amber: #f29900;
      --shadow-1: 0 1px 2px rgba(60,64,67,.12), 0 1px 3px 1px rgba(60,64,67,.08);
      --shadow-2: 0 2px 6px rgba(60,64,67,.15), 0 8px 24px rgba(60,64,67,.10);
      --tr: 180ms cubic-bezier(.2,0,0,1);
    }
    [data-theme="dark"] {
      --color-bg: #0b1220;
      --color-surface: #111827;
      --color-surface-2: #172033;
      --color-surface-3: #1b2740;
      --color-border: rgba(255,255,255,.10);
      --color-divider: rgba(255,255,255,.08);
      --color-text: #edf2fb;
      --color-text-muted: #c0c9d6;
      --color-text-faint: #8ea0bb;
      --color-primary: #8ab4f8;
      --color-primary-soft: rgba(138,180,248,.14);
      --shadow-1: 0 1px 2px rgba(0,0,0,.35);
      --shadow-2: 0 12px 30px rgba(0,0,0,.30);
    }

    /* ログイン画面（Material Design 風） */
    body.page-bg {
      min-height: 100vh;
      background:
        radial-gradient(circle at 0% 0%, rgba(26,115,232,.10), transparent 26%),
        radial-gradient(circle at 100% 0%, rgba(52,168,83,.08), transparent 18%),
        #f6f8fc;
      /* v6.156.10: ページ高さに依らず背景を一定にする（radial-gradient のページ高依存解消・gs-body と同手法） */
      background-attachment: fixed;
      font-family: 'Google Sans', 'Noto Sans JP', Arial, sans-serif;
    }
    .login-section {
      display: flex; flex-direction: column;
      align-items: center; justify-content: center;
      min-height: 100vh; padding: 40px 20px;
    }
    .login-container { width: 100%; max-width: 400px; }
    .login-card {
      background: #ffffff !important;
      border: 1px solid rgba(60,64,67,.14) !important;
      box-shadow: 0 2px 6px rgba(60,64,67,.15), 0 8px 24px rgba(60,64,67,.10) !important;
      border-radius: 28px !important;
      padding: 40px 40px 36px !important;
    }
    .login-header { text-align: center; margin-bottom: 28px !important; }
    .login-logo {
      width: 220px; height: auto;
      display: block;
      margin: 0 auto -2px !important;
      background: transparent;
      box-shadow: none;
      padding: 0;
    }
    .login-logo img { display: block; width: 100%; height: auto; }
    .login-header .login-title { margin-top: 0 !important; }
    .login-title {
      font-size: 20px !important; font-weight: 500 !important;
      color: #202124 !important; margin-bottom: 6px !important;
      letter-spacing: 0 !important;
    }
    .login-subtitle {
      font-size: 13px !important; color: #5f6368 !important;
      font-weight: 400 !important;
    }
    .login-card .form-group { margin-bottom: 16px; }
    .login-card label {
      display: block; font-size: 12px; font-weight: 500;
      color: #5f6368 !important; margin-bottom: 6px !important;
    }
    .login-card input[type="text"],
    .login-card input[type="password"] {
      width: 100% !important;
      height: 44px !important;
      border-radius: 9999px !important;
      border: 1px solid rgba(60,64,67,.14) !important;
      background: #ffffff !important;
      color: #202124 !important;
      font-size: 14px !important;
      padding: 0 18px !important;
      outline: none !important;
      box-shadow: 0 1px 2px rgba(60,64,67,.12), 0 1px 3px 1px rgba(60,64,67,.08) !important;
      transition: border-color 180ms, box-shadow 180ms !important;
    }
    .login-card input[type="text"]:focus,
    .login-card input[type="password"]:focus {
      border-color: #1a73e8 !important;
      box-shadow: 0 0 0 3px rgba(26,115,232,.10) !important;
    }
    .login-card .error-message {
      display: none;
      background: rgba(197,34,31,.08) !important;
      border: 1px solid rgba(197,34,31,.2) !important;
      border-radius: 10px !important;
      padding: 10px 14px !important;
      font-size: 12px !important;
      color: #c5221f !important;
      margin-bottom: 14px !important;
      text-align: center;
    }
    #loginBtn {
      width: 100% !important;
      height: 48px !important;
      border-radius: 9999px !important;
      border: none !important;
      background: #1a73e8 !important;
      color: #fff !important;
      font-size: 15px !important;
      font-weight: 500 !important;
      cursor: pointer !important;
      margin-top: 8px !important;
      box-shadow: 0 2px 6px rgba(60,64,67,.15), 0 8px 24px rgba(60,64,67,.10) !important;
      transition: background 180ms !important;
      padding: 0 !important;
    }
    #loginBtn:hover:not(:disabled) { background: #1558b0 !important; }
    #loginBtn:disabled { opacity: .6; cursor: not-allowed; }
    .login-footer {
      margin-top: 32px !important;
      font-size: 11px !important;
      color: #80868b !important;
      text-align: center;
    }

    /* ポータル本体 */
    .portal-section { display: none; }
    body.portal-on {
      background:
        radial-gradient(circle at 0% 0%, rgba(26,115,232,.10), transparent 26%),
        radial-gradient(circle at 100% 0%, rgba(52,168,83,.08), transparent 18%),
        var(--color-bg);
      /* v6.156.10: ページ高さに依らず背景を一定にする（radial-gradient のページ高依存解消・gs-body と同手法） */
      background-attachment: fixed;
      color: var(--color-text);
      font-family: 'Google Sans', 'Noto Sans JP', Arial, sans-serif;
      min-height: 100vh;
    }

    .portal-wrap {
      max-width: 1200px;
      margin: 0 auto;
      padding: 14px 18px 40px;
    }

    /* トップバー */
    .topbar {
      position: sticky; top: 0; z-index: 20;
      display: flex; align-items: center; justify-content: space-between;
      gap: 10px; padding: 10px 6px;
      margin-bottom: 14px;
      background: transparent;
    }
    /* スクロール時のみうっすら境界を出す（トップ位置では無し） */
    .topbar.scrolled {
      backdrop-filter: blur(18px) saturate(1.2);
      -webkit-backdrop-filter: blur(18px) saturate(1.2);
      background: color-mix(in srgb, var(--color-bg) 40%, transparent);
    }
    .brand { display: flex; align-items: center; gap: 12px; }
    .logo {
      width: 44px; height: 44px;
      border-radius: 16px;
      background: conic-gradient(from 210deg, #1a73e8, #34a853, #fbbc04, #ea4335, #1a73e8);
      padding: 2px;
      box-shadow: var(--shadow-1);
      display: grid; place-items: center;
    }
    .logo svg {
      width: 100%; height: 100%;
      background: var(--color-surface);
      border-radius: 14px;
      padding: 9px;
      color: var(--color-primary);
    }
    .brand-text {
      display: flex; flex-direction: column; line-height: 1.2;
    }
    .brand-text strong { font-size: var(--text-base); font-weight: 700; color: var(--color-text); }
    .brand-text span { font-size: var(--text-xs); color: var(--color-text-muted); }

    .topbar-right { display: flex; align-items: center; gap: 8px; }

    .k-icon-btn {
      width: 44px !important; height: 44px !important;
      border-radius: 9999px !important;
      display: inline-flex !important; align-items: center !important; justify-content: center !important;
      background: var(--color-surface) !important;
      border: 1px solid var(--color-border) !important;
      box-shadow: var(--shadow-1) !important;
      color: var(--color-text) !important;
      padding: 0 !important;
      cursor: pointer;
      transition: transform var(--tr), box-shadow var(--tr);
      text-decoration: none;
    }
    .k-icon-btn:hover { transform: translateY(-1px); box-shadow: var(--shadow-2) !important; }
    .k-icon-btn svg { width: 20px; height: 20px; }

    .k-pill-btn {
      height: 44px !important;
      border-radius: 9999px !important;
      padding: 0 18px !important;
      display: inline-flex !important; align-items: center !important; justify-content: center !important;
      background: var(--color-surface) !important;
      border: 1px solid var(--color-border) !important;
      box-shadow: var(--shadow-1) !important;
      color: var(--color-text) !important;
      font-size: var(--text-sm) !important;
      cursor: pointer;
      font-family: inherit;
      font-weight: 500;
      text-decoration: none;
      gap: 6px;
      transition: transform var(--tr), box-shadow var(--tr);
    }
    .k-pill-btn:hover { transform: translateY(-1px); box-shadow: var(--shadow-2) !important; }

    /* v6.17.0 D7.1: .k-pill-btn の display:inline-flex !important を上書きする is-hidden ユーティリティ。
       設計知見 #96「!important クラスを着た要素の表示制御は .is-hidden で」。
       詳細度を上げる + ソース順序で .k-pill-btn の後に配置の二重防御。 */
    .k-pill-btn.is-hidden,
    .k-primary-btn.is-hidden,
    .k-icon-btn.is-hidden {
      display: none !important;
    }

    .k-primary-btn {
      height: 44px !important;
      border-radius: 9999px !important;
      padding: 0 20px !important;
      display: inline-flex !important; align-items: center !important; justify-content: center !important;
      background: var(--color-primary) !important;
      border: none !important;
      color: #fff !important;
      font-size: var(--text-sm) !important;
      font-weight: 500 !important;
      box-shadow: var(--shadow-2) !important;
      cursor: pointer;
      font-family: inherit;
      text-decoration: none;
      gap: 6px;
      transition: transform var(--tr), filter var(--tr);
    }
    .k-primary-btn:hover { transform: translateY(-1px); filter: brightness(1.05); }

    /* ヒーロー */
    .hero {
      display: grid;
      grid-template-columns: 1.15fr .85fr;
      gap: 14px;
      margin-bottom: 14px;
    }
    .hero-card {
      position: relative; overflow: hidden;
      background: var(--color-surface);
      border: 1px solid var(--color-border);
      border-radius: 32px;
      padding: clamp(1.25rem, 2.6vw, 2rem);
      box-shadow: var(--shadow-1);
    }
    .hero-card::after {
      content: '';
      position: absolute; right: -60px; bottom: -80px;
      width: 300px; height: 300px;
      background: radial-gradient(circle, rgba(26,115,232,.18), transparent 70%);
      pointer-events: none;
    }
    .hello-badge {
      display: inline-flex; align-items: center; gap: 6px;
      padding: 4px 12px;
      background: var(--color-primary-soft);
      color: var(--color-primary);
      border-radius: 9999px;
      font-size: var(--text-xs);
      font-weight: 500;
      margin-bottom: 14px;
    }
    .hero-card h1 {
      font-size: var(--text-xl);
      font-weight: 700;
      line-height: 1.35;
      color: var(--color-text);
      margin: 0 0 10px;
    }
    .hero-lead {
      font-size: var(--text-sm);
      color: var(--color-text-muted);
      margin-bottom: 18px;
      line-height: 1.6;
    }
    .search-bar {
      display: flex; align-items: center; gap: 10px;
      height: 44px;
      padding: 0 18px;
      background: var(--color-surface-2);
      border: 1px solid var(--color-border);
      border-radius: 9999px !important;
      margin-bottom: 14px;
    }
    .search-bar input {
      flex: 1; border: none; background: none; outline: none;
      font-size: var(--text-sm); font-family: inherit;
      color: var(--color-text);
    }
    .search-bar svg { width: 18px; height: 18px; color: var(--color-text-muted); }
    .hero-actions { display: flex; gap: 10px; flex-wrap: wrap; }

    .summary-col { display: flex; flex-direction: column; gap: 10px; }
    .summary-card {
      background: var(--color-surface);
      border: 1px solid var(--color-border);
      border-radius: 20px;
      padding: 14px 18px;
      box-shadow: var(--shadow-1);
      display: flex; align-items: center; gap: 14px;
    }
    .summary-icon {
      width: 44px; height: 44px; border-radius: 14px;
      display: grid; place-items: center;
      background: var(--color-primary-soft);
      color: var(--color-primary);
      flex-shrink: 0;
    }
    .summary-icon.green { background: rgba(24,128,56,.10); color: var(--color-green); }
    .summary-icon.amber { background: rgba(242,153,0,.12); color: #b06000; }
    .summary-icon svg { width: 22px; height: 22px; }
    .summary-text { display: flex; flex-direction: column; line-height: 1.3; }
    .summary-label { font-size: var(--text-xs); color: var(--color-text-muted); }
    .summary-value { font-size: var(--text-lg); font-weight: 700; color: var(--color-text); }

    /* メニューパネル */
    .panel {
      background: var(--color-surface);
      border: 1px solid var(--color-border);
      border-radius: 28px;
      padding: 20px;
      box-shadow: var(--shadow-1);
      margin-bottom: 14px;
    }
    .panel-head {
      display: flex; align-items: center; justify-content: space-between;
      margin-bottom: 12px;
    }
    .panel-title {
      font-size: var(--text-lg); font-weight: 700; color: var(--color-text);
    }
    .section-label {
      font-size: var(--text-xs);
      color: var(--color-text-faint);
      font-weight: 700;
      letter-spacing: .08em;
      margin: 18px 0 10px;
      text-transform: uppercase;
    }
    .section-label:first-child { margin-top: 0; }

    .apps-grid {
      display: grid;
      grid-template-columns: repeat(4, 1fr);
      gap: 12px;
    }

    /* v6.22.0-hotfix.1: FOUC 防止のため data-feature 持ちタイルを初期非表示。
       JS（index.js / settings.js の applyFeaturePermissions）が featuresCache 取得後に
       権限なしカードを remove() し、最後に body.classList.add('features-loaded') を呼ぶ。
       これにより本セレクタが無効化され、残った権限ありカードが一斉に表示される。
       セレクタを .app-tile に限定して feature-permissions.js が動的生成する
       td.fp-cell[data-feature] への影響を防ぐ（v6.19.0 hotfix.1 CSS グローバル罠回避）。
       設計知見 #96「CSS 詳細度の罠」: el.style.display='' は外部 CSS に勝てないため
       body クラス方式で CSS 自体を条件付き化（v6.22.0-hotfix.1 試行版で再演した罠の回避）。 */
    body:not(.features-loaded) .app-tile[data-feature] { display: none; }

    /* v6.22.0-hotfix.2: セクション見出し（.section-label）と空グリッド（.apps-grid）の FOUC 防止。
       v6.22.0 本体 applyFeaturePermissions の第 2 ループが、カード 0 個セクションの
       .section-label と .apps-grid を JS 実行後に remove() するため、それまでに一瞬見える。
       hotfix.1 と同じ body:not(.features-loaded) パターンで初期非表示にし、
       JS 完了後（document.body.classList.add('features-loaded') 後）に表示される空セクションを
       remove() で除去 → 結果として「適切なものだけ」表示される。
       メタ教訓: FOUC 対応時は JS で削除/変更される全 UI 要素を網羅的に洗い出す必要あり
       （hotfix.1 で .app-tile のみカバーし、.section-label / .apps-grid を漏らした反省）。 */
    body:not(.features-loaded) .section-label,
    body:not(.features-loaded) .apps-grid {
      display: none;
    }

    .app-tile {
      background: var(--color-surface);
      border: 1px solid var(--color-border);
      border-radius: 24px;
      padding: 16px 18px;
      display: flex; flex-direction: column; gap: 14px;
      box-shadow: var(--shadow-1);
      text-decoration: none;
      color: inherit;
      transition: transform var(--tr), box-shadow var(--tr), border-color var(--tr);
      position: relative; /* v6.39.0: .badge-pending を絶対配置するため */
    }

    /* v6.39.0: 配置確認未確認件数バッジ（タイル右上に赤丸+白文字）。
       「報告」タイル（id="tileAttendance"）右上に飛び出る位置で表示。
       JS が pending_count > 0 のとき display:flex に切替、0 で display:none。
       2 桁対応のため min-width で円〜カプセル形状に自然に変化。 */
    .app-tile .badge-pending {
      position: absolute;
      top: -8px;
      right: -8px;
      min-width: 24px;
      height: 24px;
      /* v6.42.10: 数字が円内でやや下寄りに見える光学ズレの補正。box-sizing:border-box +
         align-items:center のため、下パディングを足すと中央計算が上にずれ、数字だけが約1px
         上へ寄る（円の直径 24px は border-box のため不変）。flex 中央揃えは既に効いており、
         残るのはフォント数字グリフの baseline 起因の光学ズレ。微調整は信介氏が実機で可能。 */
      padding: 0 7px 2px;
      background: #e53935;
      color: #fff;
      font-size: 12px;
      font-weight: 700;
      border-radius: 12px;
      display: flex;
      align-items: center;
      justify-content: center;
      border: 2px solid #fff;
      box-shadow: 0 2px 6px rgba(0, 0, 0, 0.25);
      z-index: 2;
      line-height: 1;
      letter-spacing: 0.02em;
    }
    .app-tile:hover {
      transform: translateY(-2px);
      box-shadow: var(--shadow-2);
      border-color: color-mix(in srgb, var(--color-primary) 28%, var(--color-border));
    }
    .app-top { display: flex; align-items: flex-start; justify-content: space-between; }
    .app-icon {
      width: 44px; height: 44px; border-radius: 14px;
      display: grid; place-items: center;
      background: var(--color-primary-soft);
      color: var(--color-primary);
    }
    .app-icon.green { background: rgba(24,128,56,.10); color: var(--color-green); }
    .app-icon.amber { background: rgba(242,153,0,.12); color: #b06000; }
    .app-icon svg { width: 22px; height: 22px; }
    .mini-badge {
      font-size: var(--text-xs);
      padding: 3px 10px;
      border-radius: 9999px;
      background: var(--color-primary-soft);
      color: var(--color-primary);
      font-weight: 500;
    }
    .mini-badge.green { background: rgba(24,128,56,.10); color: var(--color-green); }
    .mini-badge.amber { background: rgba(242,153,0,.12); color: #b06000; }

    .app-bottom .app-title {
      font-size: var(--text-lg);
      font-weight: 700;
      color: var(--color-text);
      margin-bottom: 4px;
    }
    .app-desc {
      font-size: var(--text-xs);
      color: var(--color-text-muted);
      line-height: 1.5;
    }

    /* 下部2カラム */
    .content-grid {
      display: grid;
      grid-template-columns: 1.1fr .9fr;
      gap: 14px;
    }
    .task-list { display: flex; flex-direction: column; gap: 8px; }
    .task-row {
      display: flex; align-items: center; gap: 12px;
      padding: 12px 14px;
      background: var(--color-surface-2);
      border-radius: 16px;
      border: 1px solid var(--color-border);
    }
    .status-dot {
      width: 10px; height: 10px; border-radius: 50%;
      background: var(--color-green); flex-shrink: 0;
    }
    .status-dot.alert { background: #ea4335; }
    .status-dot.warn  { background: var(--color-amber); }
    .task-body { flex: 1; line-height: 1.4; }
    .task-title { font-size: var(--text-sm); color: var(--color-text); font-weight: 500; }
    .task-meta  { font-size: var(--text-xs); color: var(--color-text-muted); margin-top: 2px; }

    .info-list { display: flex; flex-direction: column; gap: 10px; }
    .info-row {
      display: flex; justify-content: space-between; align-items: center;
      padding: 10px 14px;
      background: var(--color-surface-2);
      border-radius: 12px;
      font-size: var(--text-sm);
    }
    .info-label { color: var(--color-text-muted); }
    .info-value { color: var(--color-text); font-weight: 500; }

    .portal-footer {
      text-align: center; padding: 24px 0 8px;
      color: var(--color-text-faint);
      font-size: var(--text-xs);
    }

    @media (max-width: 1000px) {
      .hero, .content-grid { grid-template-columns: 1fr; }
      .apps-grid { grid-template-columns: repeat(3, 1fr); }
    }
    @media (max-width: 700px) {
      .apps-grid { grid-template-columns: repeat(2, 1fr); }
    }
    @media (max-width: 600px) {
      .brand-text span { display: none; }
      .apps-grid { grid-template-columns: repeat(2, 1fr); }
      .portal-wrap { padding: 10px 12px 30px; }
      .k-pill-btn { padding: 0 14px !important; }
    }

    /* ============================================================
       v6.8.28: 応援依頼 summary-card（4 枚目）
       ============================================================ */
    .summary-card.is-support {
      transition: background 0.15s ease;
    }
    .summary-card.is-support:hover {
      background: rgba(245, 158, 11, 0.06);
    }
    .summary-icon.amber {
      background: rgba(245, 158, 11, 0.12);
      color: #d97706;
    }
    @media (prefers-color-scheme: dark) {
      .summary-icon.amber {
        background: rgba(245, 158, 11, 0.18);
        color: #fbbf24;
      }
      .summary-card.is-support:hover {
        background: rgba(245, 158, 11, 0.1);
      }
    }
