    /* ========== リセット & ベース ========== */
    *,
    *::before,
    *::after {
      box-sizing: border-box;
      margin: 0;
      padding: 0;
    }

    :root {
      --c-bg: #f4f3ef;
      --c-surface: #ffffff;
      --c-border: #e2e0d8;
      --c-text: #1c1c1a;
      --c-muted: #555552;
      --c-accent: #1a3a7c;
      --c-accent-light: #e8edf8;
      --c-accent2: #b8341b;
      --c-success: #0f6e56;
      --c-success-bg: #e1f5ee;
      --c-warn: #92600a;
      --c-warn-bg: #fef3e2;
      --radius-sm: 8px;
      --radius-md: 12px;
      --radius-lg: 18px;
      --shadow-sm: 0 1px 4px rgba(0, 0, 0, 0.07);
      --shadow-md: 0 2px 12px rgba(0, 0, 0, 0.10);
      --font: 'Hiragino Kaku Gothic ProN', 'Hiragino Sans', 'Noto Sans JP', 'Yu Gothic', sans-serif;
      --font-serif: 'Hiragino Mincho ProN', 'Yu Mincho', serif;
      --max-width: 860px;
      --header-h: 60px;
    }

    html {
      font-size: 16px;
      scroll-behavior: smooth;
    }

    body {
      font-family: var(--font);
      background: var(--c-bg);
      color: var(--c-text);
      line-height: 1.7;
      min-height: 100vh;
    }

    a {
      color: var(--c-accent);
      text-decoration: none;
    }

    a:hover {
      text-decoration: underline;
    }

    img {
      max-width: 100%;
      height: auto;
      display: block;
    }

    /* ========== サイトヘッダー ========== */
    .site-header {
      position: sticky;
      top: 0;
      z-index: 100;
      background: var(--c-accent);
      height: var(--header-h);
      display: flex;
      align-items: center;
      box-shadow: 0 2px 8px rgba(0, 0, 0, 0.18);
    }

    .site-header .inner {
      max-width: var(--max-width);
      margin: 0 auto;
      padding: 0 20px;
      width: 100%;
      display: flex;
      align-items: center;
      justify-content: space-between;
    }

    .site-logo {
      font-family: var(--font-serif);
      font-size: 18px;
      font-weight: 700;
      color: #fff;
      letter-spacing: 0.03em;
      text-decoration: none;
    }

    .site-logo:hover {
      text-decoration: none;
      opacity: 0.88;
    }

    .site-nav {
      display: flex;
      gap: 4px;
    }

    .site-nav a {
      color: rgba(255, 255, 255, 0.85);
      font-size: 13px;
      font-weight: 500;
      padding: 6px 12px;
      border-radius: var(--radius-sm);
      text-decoration: none;
      transition: background 0.15s;
    }

    .site-nav a:hover {
      background: rgba(255, 255, 255, 0.15);
      color: #fff;
    }

    /* ========== パンくず ========== */
    .breadcrumb {
      max-width: var(--max-width);
      margin: 0 auto;
      padding: 10px 20px 0;
      font-size: 12px;
      color: var(--c-muted);
      display: flex;
      gap: 6px;
      align-items: center;
      flex-wrap: wrap;
    }

    .breadcrumb a {
      color: var(--c-muted);
      text-decoration: none;
    }

    .breadcrumb a:hover {
      color: var(--c-accent);
    }

    .breadcrumb .sep {
      opacity: 0.5;
    }

    /* ========== メインラッパー ========== */
    .main-wrap {
      max-width: var(--max-width);
      margin: 0 auto;
      padding: 24px 20px 80px;
    }

    /* ========== カード ========== */
    .card {
      background: var(--c-surface);
      border: 1px solid var(--c-border);
      border-radius: var(--radius-lg);
      padding: 24px 28px;
      box-shadow: var(--shadow-sm);
    }

    .card+.card {
      margin-top: 16px;
    }

    /* ========== ボタン ========== */
    .btn {
      display: inline-flex;
      align-items: center;
      justify-content: center;
      gap: 6px;
      padding: 12px 24px;
      border-radius: var(--radius-md);
      font-family: var(--font);
      font-size: 15px;
      font-weight: 700;
      cursor: pointer;
      border: none;
      transition: opacity 0.15s, transform 0.1s;
      text-decoration: none;
    }

    .btn:hover {
      opacity: 0.88;
      transform: translateY(-1px);
    }

    .btn:active {
      transform: translateY(0);
    }

    .btn-primary {
      background: var(--c-accent);
      color: #fff;
    }

    .btn-red {
      background: var(--c-accent2);
      color: #fff;
    }

    .btn-success {
      background: var(--c-success);
      color: #fff;
    }

    .btn-outline {
      background: transparent;
      background-color: var(--c-surface);
      border: 2px solid var(--c-border);
      color: var(--c-text);
      box-shadow: 1px 1px 2px rgba(0, 0, 0, 0.18);
    }

    .btn-full {
      width: 100%;
    }

    .btn:disabled {
      opacity: 0.4;
      cursor: not-allowed;
      transform: none;
    }

    /* ========== バッジ ========== */
    .badge {
      display: inline-block;
      font-size: 11px;
      font-weight: 700;
      padding: 3px 9px;
      border-radius: 999px;
      vertical-align: middle;
    }

    .badge-daily {
      background: #e8edf8;
      color: var(--c-accent);
    }

    .badge-weekly {
      background: #fef3e2;
      color: var(--c-warn);
    }

    .badge-active {
      background: var(--c-success-bg);
      color: var(--c-success);
    }

    /* ========== 回答者数サマリー ========== */
    .stats-row {
      display: grid;
      grid-template-columns: repeat(3, 1fr);
      gap: 10px;
      margin-bottom: 20px;
    }

    .stat-card {
      background: var(--c-bg);
      border: 1px solid var(--c-border);
      border-radius: var(--radius-md);
      padding: 14px 12px;
      text-align: center;
    }

    .stat-card .num {
      font-size: 24px;
      font-weight: 700;
      color: var(--c-accent);
    }

    .stat-card .lbl {
      font-size: 11px;
      color: var(--c-muted);
      margin-top: 2px;
    }

    /* ========== セクション見出し ========== */
    .section-title {
      font-size: 17px;
      font-weight: 700;
      margin-bottom: 16px;
      padding-bottom: 10px;
      border-bottom: 2px solid var(--c-accent);
      display: flex;
      align-items: center;
      gap: 8px;
    }

    /* ========== フォーム共通 ========== */
    .form-group {
      margin-bottom: 20px;
    }

    .form-label {
      display: block;
      font-size: 13px;
      font-weight: 700;
      margin-bottom: 8px;
      color: var(--c-muted);
    }

    .form-label .req {
      display: inline-block;
      background: #fce8e8;
      color: #c0392b;
      font-size: 10px;
      font-weight: 700;
      padding: 2px 6px;
      border-radius: 4px;
      margin-left: 5px;
    }

    input[type="text"],
    input[type="email"],
    input[type="password"],
    select,
    textarea {
      width: 100%;
      padding: 10px 14px;
      border: 1.5px solid var(--c-border);
      border-radius: var(--radius-sm);
      font-family: var(--font);
      font-size: 15px;
      color: var(--c-text);
      background: #fff;
      transition: border-color 0.15s;
    }

    input:focus,
    select:focus,
    textarea:focus {
      outline: none;
      border-color: var(--c-accent);
      box-shadow: 0 0 0 3px rgba(26, 58, 124, 0.1);
    }

    /* ========== ラジオ・チェックボックス（選択肢カード） ========== */
    .option-list {
      display: flex;
      flex-direction: column;
      gap: 8px;
    }

    .option-item {
      display: flex;
      align-items: center;
      gap: 12px;
      padding: 12px 16px;
      border: 1.5px solid var(--c-border);
      border-radius: var(--radius-md);
      cursor: pointer;
      transition: border-color 0.12s, background 0.12s;
      user-select: none;
    }

    .option-item:hover {
      border-color: var(--c-accent);
      background: var(--c-accent-light);
    }

    .option-item.checked {
      border-color: var(--c-accent);
      background: var(--c-accent-light);
    }

    .option-item input {
      width: 18px;
      height: 18px;
      accent-color: var(--c-accent);
      flex-shrink: 0;
    }

    .option-item .opt-label {
      font-size: 15px;
      font-weight: 500;
    }

    /* ========== Yes/No ボタン ========== */
    .yesno-grid {
      display: grid;
      grid-template-columns: 1fr 1fr;
      gap: 12px;
    }

    .yesno-btn {
      padding: 20px;
      border: 1.5px solid var(--c-border);
      border-radius: var(--radius-md);
      font-family: var(--font);
      font-size: 18px;
      font-weight: 700;
      text-align: center;
      cursor: pointer;
      background: var(--c-surface);
      color: var(--c-text);
      transition: all 0.15s;
    }

    .yesno-btn .yn-sub {
      font-size: 11px;
      font-weight: 400;
      color: var(--c-muted);
      margin-top: 4px;
    }

    .yesno-btn[data-val="yes"]:hover,
    .yesno-btn[data-val="yes"].selected {
      border-color: var(--c-success);
      background: var(--c-success-bg);
      color: var(--c-success);
    }

    .yesno-btn[data-val="no"]:hover,
    .yesno-btn[data-val="no"].selected {
      border-color: #c0392b;
      background: #fce8e8;
      color: #c0392b;
    }

    /* ========== 投票済みメッセージ ========== */
    .voted-box {
      background: var(--c-success-bg);
      border: 1px solid #5dcaa5;
      border-radius: var(--radius-lg);
      padding: 28px 24px;
      text-align: center;
    }

    .voted-box .icon {
      font-size: 40px;
      margin-bottom: 10px;
    }

    .voted-box h3 {
      font-size: 17px;
      font-weight: 700;
      color: var(--c-success);
      margin-bottom: 6px;
    }

    .voted-box .next-msg {
      font-size: 13px;
      color: var(--c-muted);
      line-height: 1.8;
    }

    /* ========== アラート ========== */
    .alert {
      padding: 12px 16px;
      border-radius: var(--radius-sm);
      font-size: 14px;
      margin-bottom: 16px;
    }

    .alert-error {
      background: #fce8e8;
      border: 1px solid #e74c3c;
      color: #c0392b;
    }

    .alert-success {
      background: var(--c-success-bg);
      border: 1px solid var(--c-success);
      color: var(--c-success);
    }

    .alert-warn {
      background: var(--c-warn-bg);
      border: 1px solid var(--c-warn);
      color: var(--c-warn);
    }

    /* ========== レスポンシブ ========== */
    @media (max-width: 600px) {
      .site-logo {
        font-size: 15px;
      }

      .site-nav a {
        font-size: 12px;
        padding: 5px 8px;
      }

      .main-wrap {
        padding: 16px 14px 60px;
      }

      .card {
        padding: 18px 16px;
      }

      .stats-row {
        grid-template-columns: repeat(3, 1fr);
        gap: 6px;
      }

      .stat-card .num {
        font-size: 20px;
      }
    }


@media (max-width: 500px) {
  .site-header .inner {
    flex-direction: column;
padding: 12px 0 8px;
  }
}
