/* =============================================================================
   出欠管理アプリ  style.css
   設計方針: スマホファースト / 最小限 / CSS 変数で配色を集約
   ========================================================================== */

/* -----------------------------------------------------------------------------
   1. CSS 変数
   ----------------------------------------------------------------------------- */
:root {
    /* ブランドカラー（青系） */
    --color-primary:        #1976d2;
    --color-primary-dark:   #0d47a1;
    --color-primary-light:  #e3f2fd;

    /* セカンダリ・グレースケール */
    --color-text:           #1a1a1a;
    --color-text-muted:     #666666;
    --color-text-light:     #999999;
    --color-bg:             #fafafa;
    --color-bg-card:        #ffffff;
    --color-border:         #e0e0e0;
    --color-border-light:   #efefef;

    /* ステータスカラー */
    --color-success:        #1976d2;
    --color-success-bg:     #e3f2fd;
    --color-warning:        #d97706;
    --color-warning-bg:     #fef3c7;
    --color-danger:         #d32f2f;
    --color-danger-bg:      #fee;
    --color-info:           #1976d2;
    --color-info-bg:        #e3f2fd;

    /* 出欠ステータス */
    --color-attend:         #1976d2;  /* 出席：青 */
    --color-attend-late:    #1976d2;  /* 出席（遅刻）：青 */
    --color-attend-early:   #1976d2;  /* 出席（早退）：青 */
    --color-maybe:          #f5c000;  /* 未定：山吹色 */
    --color-absent:         #d32f2f;  /* 欠席：赤 */
    --color-no-response:    #999999;  /* 未回答：グレー */

    /* レイアウト */
    --max-width:            720px;
    --radius:               6px;
    --radius-lg:            10px;

    /* タイポグラフィ */
    --font-base:            16px;
    --font-sm:              14px;
    --font-lg:              18px;
    --font-xl:              22px;

    /* タップターゲット */
    --tap-min:              44px;

    /* シャドウ */
    --shadow-sm:            0 1px 2px rgba(0,0,0,0.05);
    --shadow:               0 2px 4px rgba(0,0,0,0.08);
}

/* -----------------------------------------------------------------------------
   2. リセット
   ----------------------------------------------------------------------------- */
*,
*::before,
*::after {
    box-sizing: border-box;
}

html {
    -webkit-text-size-adjust: 100%;
    text-size-adjust: 100%;
}

body {
    margin: 0;
    font-family:
        -apple-system, BlinkMacSystemFont, "Helvetica Neue",
        "Hiragino Sans", "Hiragino Kaku Gothic ProN",
        "Yu Gothic Medium", "Meiryo", sans-serif;
    font-size: var(--font-base);
    line-height: 1.6;
    color: var(--color-text);
    background: var(--color-bg);
}

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

button,
input,
textarea,
select {
    font-family: inherit;
    font-size: inherit;
}

a {
    color: var(--color-primary);
    text-decoration: none;
}
a:hover {
    text-decoration: underline;
}

h1, h2, h3, h4 {
    margin: 0 0 0.6em;
    line-height: 1.3;
    font-weight: 600;
}
h1 { font-size: 1.5rem; }
h2 { font-size: 1.25rem; }
h3 { font-size: 1.1rem; }
h4 { font-size: 1rem; }

p {
    margin: 0 0 1em;
}

/* -----------------------------------------------------------------------------
   3. レイアウト
   ----------------------------------------------------------------------------- */

.site-header {
    background: var(--color-bg-card);
    border-bottom: 1px solid var(--color-border);
    box-shadow: var(--shadow-sm);
}

.site-header__inner {
    max-width: var(--max-width);
    margin: 0 auto;
    padding: 12px 16px;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
}

.site-header__title {
    margin: 0;
    font-size: 1.1rem;
    font-weight: 600;
}
.site-header__title a {
    color: var(--color-text);
}

.site-header__user {
    font-size: var(--font-sm);
    color: var(--color-text-muted);
    display: flex;
    align-items: center;
    gap: 12px;
    flex-wrap: wrap;
}

.site-main {
    max-width: var(--max-width);
    margin: 0 auto;
    padding: 16px;
}

.site-footer {
    max-width: var(--max-width);
    margin: 32px auto 16px;
    padding: 0 16px;
    text-align: center;
    color: var(--color-text-light);
    font-size: var(--font-sm);
}

/* ナビゲーション（ヘッダー直下のリンク群） */
.nav {
    background: var(--color-bg-card);
    border-bottom: 1px solid var(--color-border-light);
}
.nav__inner {
    max-width: var(--max-width);
    margin: 0 auto;
    padding: 0 8px;
    display: flex;
    overflow-x: auto;
}
.nav__link {
    display: inline-flex;
    align-items: center;
    min-height: var(--tap-min);
    padding: 0 16px;
    font-size: var(--font-sm);
    color: var(--color-text-muted);
    white-space: nowrap;
    border-bottom: 2px solid transparent;
}
.nav__link:hover {
    text-decoration: none;
    color: var(--color-text);
}
.nav__link.is-active {
    color: var(--color-primary);
    border-bottom-color: var(--color-primary);
    font-weight: 600;
}

/* -----------------------------------------------------------------------------
   4. カード
   ----------------------------------------------------------------------------- */

.card {
    background: var(--color-bg-card);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-lg);
    padding: 16px;
    margin-bottom: 12px;
    box-shadow: var(--shadow-sm);
}
.card__title {
    margin: 0 0 8px;
    font-size: var(--font-lg);
    font-weight: 600;
}
.card__meta {
    color: var(--color-text-muted);
    font-size: var(--font-sm);
}

/* -----------------------------------------------------------------------------
   5. フォーム
   ----------------------------------------------------------------------------- */

.form {
    display: block;
}
.form__group {
    margin-bottom: 16px;
}
.form__label {
    display: block;
    margin-bottom: 6px;
    font-weight: 600;
    font-size: var(--font-sm);
}
.form__label .required {
    color: var(--color-danger);
    margin-left: 2px;
}

.form__control {
    display: block;
    width: 100%;
    min-height: var(--tap-min);
    padding: 10px 12px;
    border: 1px solid var(--color-border);
    border-radius: var(--radius);
    background: var(--color-bg-card);
    color: var(--color-text);
    line-height: 1.5;
    -webkit-appearance: none;
    appearance: none;
}
.form__control:focus {
    outline: none;
    border-color: var(--color-primary);
    box-shadow: 0 0 0 3px var(--color-primary-light);
}
.form__control[disabled] {
    background: var(--color-border-light);
    color: var(--color-text-light);
    cursor: not-allowed;
}

textarea.form__control {
    min-height: 96px;
    resize: vertical;
}

.form__help {
    margin-top: 4px;
    font-size: var(--font-sm);
    color: var(--color-text-muted);
}
.form__error {
    margin-top: 4px;
    font-size: var(--font-sm);
    color: var(--color-danger);
}

.form__actions {
    margin-top: 24px;
    display: flex;
    gap: 12px;
    flex-wrap: wrap;
}

/* -----------------------------------------------------------------------------
   6. ボタン
   ----------------------------------------------------------------------------- */

.btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: var(--tap-min);
    padding: 10px 20px;
    font-size: var(--font-base);
    font-weight: 600;
    line-height: 1.4;
    text-align: center;
    text-decoration: none;
    border: 1px solid transparent;
    border-radius: var(--radius);
    cursor: pointer;
    transition: background 0.1s, border-color 0.1s;
    -webkit-appearance: none;
    appearance: none;
}
.btn:hover {
    text-decoration: none;
}
.btn:disabled,
.btn.is-disabled {
    opacity: 0.5;
    cursor: not-allowed;
}

.btn--primary {
    background: var(--color-primary);
    border-color: var(--color-primary);
    color: #fff;
}
.btn--primary:hover {
    background: var(--color-primary-dark);
    border-color: var(--color-primary-dark);
    color: #fff;
}

.btn--secondary {
    background: var(--color-bg-card);
    border-color: var(--color-border);
    color: var(--color-text);
}
.btn--secondary:hover {
    background: var(--color-bg);
}

.btn--danger {
    background: var(--color-bg-card);
    border-color: var(--color-danger);
    color: var(--color-danger);
}
.btn--danger:hover {
    background: var(--color-danger-bg);
}

.btn--sm {
    min-height: 36px;
    padding: 6px 12px;
    font-size: var(--font-sm);
}

.btn--block {
    width: 100%;
}

/* -----------------------------------------------------------------------------
   7. アラート（フラッシュメッセージ）
   ----------------------------------------------------------------------------- */

.alert {
    margin-bottom: 16px;
    padding: 12px 16px;
    border-radius: var(--radius);
    border: 1px solid transparent;
    font-size: var(--font-sm);
}
.alert--success {
    background: var(--color-success-bg);
    border-color: var(--color-success);
    color: var(--color-primary-dark);
}
.alert--warning {
    background: var(--color-warning-bg);
    border-color: var(--color-warning);
    color: var(--color-warning);
}
.alert--danger {
    background: var(--color-danger-bg);
    border-color: var(--color-danger);
    color: var(--color-danger);
}
.alert--info {
    background: var(--color-info-bg);
    border-color: var(--color-info);
    color: var(--color-info);
}

/* -----------------------------------------------------------------------------
   8. リスト・テーブル
   ----------------------------------------------------------------------------- */

.event-list {
    list-style: none;
    margin: 0;
    padding: 0;
}
.event-list__item {
    background: var(--color-bg-card);
    border: 1px solid var(--color-border);
    border-radius: var(--radius);
    padding: 12px 16px;
    margin-bottom: 8px;
    display: block;
    color: var(--color-text);
}
.event-list__item:hover {
    text-decoration: none;
    border-color: var(--color-primary);
}
.event-list__date {
    font-size: var(--font-sm);
    color: var(--color-text-muted);
    margin-bottom: 4px;
}
.event-list__title {
    font-weight: 600;
    margin-bottom: 4px;
}
.event-list__meta {
    font-size: var(--font-sm);
    color: var(--color-text-muted);
}

/* 出欠表 */
.attendance-table {
    width: 100%;
    border-collapse: collapse;
    font-size: var(--font-sm);
}
.attendance-table th,
.attendance-table td {
    padding: 10px 8px;
    border-bottom: 1px solid var(--color-border-light);
    text-align: left;
    vertical-align: top;
}
.attendance-table th {
    background: var(--color-bg);
    font-weight: 600;
    color: var(--color-text-muted);
    font-size: var(--font-sm);
}

/* 出欠ステータスのバッジ */
.status-badge {
    display: inline-block;
    padding: 2px 8px;
    border-radius: 999px;
    font-size: 12px;
    font-weight: 600;
    line-height: 1.5;
    color: #fff;
    white-space: nowrap;
}
.status-badge--attend       { background: var(--color-attend); }
.status-badge--attend-late  { background: var(--color-attend-late); }
.status-badge--attend-early { background: var(--color-attend-early); }
.status-badge--maybe        { background: var(--color-maybe); }
.status-badge--absent       { background: var(--color-absent); }
.status-badge--no-response  { background: var(--color-no-response); }

/* -----------------------------------------------------------------------------
   9. ページネーション
   ----------------------------------------------------------------------------- */
.pagination {
    display: flex;
    justify-content: space-between;
    gap: 8px;
    margin-top: 16px;
}
.pagination .btn {
    flex: 1;
}

/* -----------------------------------------------------------------------------
   10. プロフィール完成度プログレス
   ----------------------------------------------------------------------------- */
.progress {
    background: var(--color-border-light);
    border-radius: 999px;
    height: 8px;
    overflow: hidden;
    margin: 8px 0;
}
.progress__bar {
    background: var(--color-primary);
    height: 100%;
    transition: width 0.3s;
}

/* -----------------------------------------------------------------------------
   11. ユーティリティ
   ----------------------------------------------------------------------------- */
.text-center  { text-align: center; }
.text-right   { text-align: right; }
.text-muted   { color: var(--color-text-muted); }
.text-danger  { color: var(--color-danger); }
.text-sm      { font-size: var(--font-sm); }

.mt-0         { margin-top: 0; }
.mt-1         { margin-top: 8px; }
.mt-2         { margin-top: 16px; }
.mt-3         { margin-top: 24px; }
.mb-0         { margin-bottom: 0; }
.mb-1         { margin-bottom: 8px; }
.mb-2         { margin-bottom: 16px; }
.mb-3         { margin-bottom: 24px; }

.hidden       { display: none !important; }

.flex         { display: flex; }
.flex-between { display: flex; justify-content: space-between; align-items: center; }
.gap-1        { gap: 8px; }
.gap-2        { gap: 16px; }

/* -----------------------------------------------------------------------------
   12. レスポンシブ調整（タブレット以上）
   ----------------------------------------------------------------------------- */
@media (min-width: 600px) {
    .site-main {
        padding: 24px 16px;
    }
    .form__actions {
        flex-wrap: nowrap;
    }
}


/* -----------------------------------------------------------------------------
   LINE 連携ボタン専用カラー（公式ブランドカラー #06C755）
   ----------------------------------------------------------------------------- */
.btn--line,
a.btn--line,
a.btn--line:link,
a.btn--line:visited {
    background: #06C755 !important;
    border-color: #06C755 !important;
    color: #ffffff !important;
}
.btn--line:hover,
a.btn--line:hover,
a.btn--line:active {
    background: #05a847 !important;
    border-color: #05a847 !important;
    color: #ffffff !important;
    text-decoration: none !important;
}
.btn--line img,
.btn--line svg {
    height: 20px;
    width: 20px;
    margin-right: 8px;
    vertical-align: middle;
}

.text-line {
    color: #06C755;
    font-weight: 600;
}

/* -----------------------------------------------------------------------------
   曜日カラー（祝日 / 日曜 / 土曜）
   ----------------------------------------------------------------------------- */
.date-sunday   { color: #d32f2f; font-weight: 600; } /* 日曜：赤 */
.date-saturday { color: #2196f3; font-weight: 600; } /* 土曜：水色 */
.date-holiday  { color: #f57c00; font-weight: 600; } /* 祝日：オレンジ */
