/* Sprint 2-C C.3.2 / Bookings RWD(2026-05-17) — 三個畫面共用的卡片 / 摘要 / RWD table。
   Goals:
   - Desktop:寬鬆 grid / table 展示
   - Mobile:每筆 reg / 訂單變一張卡片(label-value 直排),不再橫向溢出
   - 不動 _PersonLayout 既有 .section-title / .cta 等 class
*/

/* ============================================================
   1. 摘要卡片(Booking / Order / Result 通用 label-value 卡片)
   ============================================================ */
.mhfa-card {
    background: #fff;
    border: 1px solid #e5e5e5;
    border-radius: 12px;
    padding: 1.2em 1.4em;
    margin-bottom: 1em;
    box-shadow: 0 1px 3px rgba(0,0,0,0.04);
}
.mhfa-card.--accent {
    border-left: 4px solid #0d803b;
}
.mhfa-card.--success {
    border-left: 4px solid #0d803b;
    background: #f1faf3;
}
.mhfa-card.--fail {
    border-left: 4px solid #b91c1c;
    background: #fdf3f3;
}
.mhfa-card.--warn {
    border-left: 4px solid #d8a700;
    background: #fff8e0;
}

/* label-value pair row(取代 <table><tr><td>) */
.mhfa-card dl,
.mhfa-summary dl {
    margin: 0;
    display: grid;
    grid-template-columns: max-content 1fr;
    gap: 0.5em 1.5em;
    align-items: baseline;
}
.mhfa-card dt,
.mhfa-summary dt {
    font-size: 0.9rem;
    color: #666;
    font-weight: normal;
    grid-column: 1;
}
.mhfa-card dd,
.mhfa-summary dd {
    margin: 0;
    grid-column: 2;
    font-size: 0.95rem;
    color: #0e0e0e;
}
/* Mobile:label-value 換成 stacked,label 在上 */
@media (max-width: 600px) {
    .mhfa-card dl,
    .mhfa-summary dl {
        grid-template-columns: 1fr;
        gap: 0.2em 0;
    }
    .mhfa-card dt,
    .mhfa-summary dt {
        margin-top: 0.6em;
        font-size: 0.85rem;
    }
    .mhfa-card dt:first-of-type,
    .mhfa-summary dt:first-of-type {
        margin-top: 0;
    }
}

/* ============================================================
   2. 金額大字 callout(PayConfirm 用)
   ============================================================ */
.mhfa-amount-callout {
    display: flex;
    align-items: baseline;
    justify-content: center;
    gap: 0.8em;
    padding: 0.7em 1.2em;
    background: linear-gradient(135deg, #0d803b 0%, #15a04b 100%);
    color: #fff;
    border-radius: 10px;
    margin-bottom: 1em;
}
.mhfa-amount-callout .label {
    font-size: 0.9rem;
    opacity: 0.92;
}
.mhfa-amount-callout .amount {
    font-size: 1.5rem;
    font-weight: bold;
    letter-spacing: 0.02em;
    line-height: 1;
}
.mhfa-amount-callout .currency {
    font-size: 0.82rem;
    opacity: 0.85;
    margin-right: 0.2em;
}
/* Mobile:仍維持 inline 但 size 微縮 */
@media (max-width: 500px) {
    .mhfa-amount-callout {
        flex-wrap: wrap;
        gap: 0.4em;
        padding: 0.6em 1em;
    }
    .mhfa-amount-callout .amount {
        font-size: 1.3rem;
    }
}

/* ============================================================
   3. PayConfirm form 區塊(每個 form section 一張卡)
   ============================================================ */
.mhfa-form-section {
    background: #fff;
    border: 1px solid #e5e5e5;
    border-radius: 12px;
    padding: 1.2em 1.4em;
    margin-bottom: 1em;
}
.mhfa-form-section h6 {
    margin: 0 0 0.8em;
    padding-bottom: 0.5em;
    border-bottom: 2px solid #f2f2f2;
    font-size: 0.95rem;
    color: #0d803b;
    font-weight: bold;
}

/* Radio option as card */
.mhfa-radio-card {
    display: block;
    padding: 0.8em 1em;
    border: 2px solid #e5e5e5;
    border-radius: 8px;
    margin-bottom: 0.6em;
    cursor: pointer;
    transition: all 0.15s ease;
    background: #fafafa;
}
.mhfa-radio-card:hover {
    border-color: #0d803b;
    background: #f1faf3;
}
.mhfa-radio-card input[type="radio"] {
    margin-right: 0.5em;
}
.mhfa-radio-card .desc {
    display: block;
    font-size: 0.85rem;
    color: #666;
    margin-top: 0.2em;
    margin-left: 1.5em;
}

/* Input field common */
.mhfa-field {
    display: block;
    margin: 0.5em 0;
}
.mhfa-field label {
    display: block;
    font-size: 0.9rem;
    color: #555;
    margin-bottom: 0.3em;
}
.mhfa-field input[type="text"],
.mhfa-field input[type="email"] {
    width: 100%;
    max-width: 380px;
    padding: 0.5em 0.7em;
    border: 1px solid #ccc;
    border-radius: 6px;
    font-size: 0.95rem;
}
.mhfa-field input:focus {
    outline: none;
    border-color: #0d803b;
    box-shadow: 0 0 0 2px rgba(13,128,59,0.1);
}

/* Secondary action button — outline 風格(取消 / 返回 等次要 CTA) */
.mhfa-btn-outline {
    display: inline-flex;
    align-items: center;
    gap: 0.4em;
    padding: 0.55em 1.3em;
    background: #fff;
    color: #0d803b;
    border: 2px solid #0d803b;
    border-radius: 30px;       /* 對齊 .cta 的 pill 形狀 */
    text-decoration: none;
    font-weight: bold;
    font-size: 0.95rem;
    cursor: pointer;
    transition: all 0.15s ease;
}
.mhfa-btn-outline:hover {
    background: #f1faf3;
    border-color: #0a6b30;
    color: #0a6b30;
}
.mhfa-btn-outline:focus {
    outline: none;
    box-shadow: 0 0 0 3px rgba(13,128,59,0.18);
}

/* Hint box */
.mhfa-hint {
    background: #fff3cd;
    border-left: 4px solid #d8a700;
    padding: 0.8em 1em;
    border-radius: 6px;
    margin: 1em 0;
    color: #856404;
    font-size: 0.92rem;
}
.mhfa-error {
    background: #f8d7da;
    border-left: 4px solid #b91c1c;
    padding: 0.8em 1em;
    border-radius: 6px;
    margin: 1em 0;
    color: #721c24;
    font-size: 0.92rem;
}
.mhfa-error ul {
    margin: 0.3em 0 0 1em;
    padding-left: 0.5em;
}

/* ============================================================
   4. Booking list — RWD card-style(replaces <table>)
   ============================================================ */
.mhfa-booking-list {
    display: grid;
    grid-template-columns: 1fr;
    gap: 0.8em;
}
.mhfa-booking-card {
    background: #fff;
    border: 1px solid #e5e5e5;
    border-radius: 10px;
    padding: 1em 1.2em;
    display: grid;
    grid-template-columns: 1.4fr 1fr 0.8fr 1.2fr 0.6fr auto;  /* 含繳費截止 + 操作 */
    gap: 0.8em;
    align-items: center;
    font-size: 0.9rem;
}
.mhfa-booking-card.--no-paydue {
    grid-template-columns: 1.4fr 1fr 0.8fr 1.2fr 0.6fr;        /* 已完成,沒繳費截止 + 操作 */
}
.mhfa-booking-card .label {
    display: none;     /* desktop:不顯示 label */
    font-size: 0.78rem;
    color: #888;
    margin-bottom: 0.15em;
}
.mhfa-booking-card .field strong {
    color: #0e0e0e;
}
.mhfa-booking-card .field.--course {
    font-weight: 500;
}
.mhfa-booking-card .field.--paydue.overdue {
    color: #b91c1c;
    font-weight: bold;
}
.mhfa-booking-card .action-btn {
    display: inline-block;
    padding: 0.45em 1em;
    background: #0d803b;
    color: #fff;
    text-decoration: none;
    border-radius: 6px;
    font-size: 0.88rem;
    white-space: nowrap;
}
.mhfa-booking-card .action-btn:hover {
    background: #0a6b30;
}
.mhfa-booking-card .action-btn.--secondary {
    background: #f0f0f0;
    color: #444;
    border: 1px solid #ccc;
}
.mhfa-booking-card .action-btn.--secondary:hover {
    background: #e0e0e0;
}
.mhfa-booking-card .action-btn.--danger {
    background: none;
    color: #b91c1c;
    border: 1px solid #fca5a5;
    cursor: pointer;
    font-family: inherit;
}
.mhfa-booking-card .action-btn.--danger:hover {
    background: #fef2f2;
}

/* Header row(desktop only) */
.mhfa-booking-header {
    display: grid;
    grid-template-columns: 1.4fr 1fr 0.8fr 1.2fr 0.6fr auto;
    gap: 0.8em;
    padding: 0.5em 1.2em;
    color: #666;
    font-size: 0.82rem;
    font-weight: bold;
    border-bottom: 2px solid #e5e5e5;
    margin-bottom: 0.4em;
}
.mhfa-booking-header.--no-paydue {
    grid-template-columns: 1.4fr 1fr 0.8fr 1.2fr 0.6fr;
}

/* Mobile:每張 booking 變直排,label 出現。
   用屬性 selector + !important 避免將來再有 inline style override 踩坑。 */
@media (max-width: 768px) {
    .mhfa-booking-header,
    .mhfa-booking-header.--no-paydue { display: none; }

    .mhfa-booking-card,
    .mhfa-booking-card.--no-paydue {
        grid-template-columns: 1fr !important;
        gap: 0.4em;
        padding: 1em;
    }
    .mhfa-booking-card .label { display: block; }
    .mhfa-booking-card .action-btn {
        margin-top: 0.4em;
        text-align: center;
    }
}

/* ============================================================
   5. 大狀態頭(Result 用)
   ============================================================ */
.mhfa-status-header {
    text-align: center;
    padding: 2em 1.5em 1.5em;
    border-radius: 12px 12px 0 0;
    color: #fff;
}
.mhfa-status-header.--success { background: linear-gradient(135deg, #0d803b 0%, #15a04b 100%); }
.mhfa-status-header.--fail    { background: linear-gradient(135deg, #b91c1c 0%, #d72e2e 100%); }
.mhfa-status-header.--process { background: linear-gradient(135deg, #5a5a5a 0%, #777 100%); }
.mhfa-status-header .icon {
    font-size: 3rem;
    line-height: 1;
    margin-bottom: 0.3em;
}
.mhfa-status-header .title {
    font-size: 1.5rem;
    font-weight: bold;
    margin: 0;
}
