/* ── Free Samples Page ─────────────────────────────── */
.smp-title-area { text-align: center; padding: 10px 0 4px; }
.smp-title-area h1 { color: #d74352; margin-bottom: 4px; }
@media(max-width:576px){ .smp-title-area h1 { margin: 0; } }
.smp-title-area .smp-subtitle { color: #666; font-size: 15px; margin: 0 0 6px; }

/* Step wrapper spacing */
.smp-step { margin-bottom: 10px; }
.smp-step .title-band-wrapper { margin-bottom: 12px; }
.smp-step .smp-step-body { padding: 0 15px 20px; }

/* ── Step 1: Product Cards ─────── */
.smp-product-grid { display: flex; flex-wrap: wrap; gap: 10px; padding: 4px 0 8px; }
.smp-step-1 .sel-button.product {
    display: inline-flex; flex-direction: column; align-items: center;
    width: 155px; padding: 14px 10px 10px;
    border: 2px solid #e8e8e8; border-radius: 10px;
    background: #fff; color: #555; font-size: 13px;
    line-height: 1.3; text-align: center; cursor: pointer;
    transition: border-color 0.2s, background 0.2s, box-shadow 0.2s;
    margin: 0;
}
.smp-step-1 .sel-button.product img.smp-card-img {
    width: 105px; height: 105px; object-fit: contain;
    margin-bottom: 8px; border-radius: 6px;
    background: #f9f9f9;
}
.smp-step-1 .sel-button.product .fa {
    font-size: 11px; margin-bottom: 4px; color: #ccc; display: block;
}
.smp-step-1 .sel-button.product.active,
.smp-step-1 .sel-button.product:hover {
    border-color: #f2b71c; background: #fffbf0;
    box-shadow: 0 2px 8px rgba(242,183,28,0.25); color: #6a4e00;
}
.smp-step-1 .sel-button.product.active .fa { color: #f2b71c; }

/* ── Step 2: Shipping Cards ────── */
.smp-ship-grid { display: flex; flex-wrap: wrap; gap: 14px; padding: 4px 0 8px; }
.smp-step-2 .sel-button.shipType {
    display: flex; align-items: center; gap: 14px;
    min-width: 240px; padding: 18px 22px;
    border: 2px solid #e8e8e8; border-radius: 12px;
    background: #fff; color: #444; font-size: 15px;
    cursor: pointer; margin: 0;
    transition: border-color 0.2s, background 0.2s, box-shadow 0.2s;
}
.smp-step-2 .sel-button.shipType .smp-ship-icon {
    font-size: 30px; color: #ccc; flex-shrink: 0;
    transition: color 0.2s;
}
.smp-step-2 .sel-button.shipType .smp-ship-info { text-align: left; }
.smp-step-2 .sel-button.shipType .smp-ship-name {
    font-size: 15px; font-weight: 600; display: block; margin-bottom: 3px;
}
.smp-step-2 .sel-button.shipType .smp-ship-price {
    font-size: 20px; font-weight: 700; color: #333; display: block;
}
.smp-step-2 .sel-button.shipType .smp-ship-eta {
    font-size: 11px; color: #888; display: block; margin-top: 2px;
}
.smp-step-2 .sel-button.shipType .fa.smp-check {
    margin-left: auto; font-size: 20px; color: transparent;
    transition: color 0.2s; flex-shrink: 0;
}
.smp-step-2 .sel-button.shipType.active,
.smp-step-2 .sel-button.shipType:hover {
    border-color: #8ab445; background: #f4f9ed;
    box-shadow: 0 2px 10px rgba(138,180,69,0.2);
}
.smp-step-2 .sel-button.shipType.active .smp-ship-icon,
.smp-step-2 .sel-button.shipType:hover .smp-ship-icon { color: #8ab445; }
.smp-step-2 .sel-button.shipType.active .smp-check { color: #8ab445; }

/* ── Step 3: Comments & Review ── */
.smp-step-3 .smp-comments-label {
    font-size: 13px; font-weight: 600; color: #555; margin-bottom: 6px; display: block;
}
.smp-step-3 .smp-textarea {
    width: 100%; height: 130px; padding: 12px 14px;
    border: 2px solid #e0e0e0; border-radius: 8px;
    font-size: 14px; color: #333; resize: vertical;
    transition: border-color 0.2s;
    font-family: inherit;
}
.smp-step-3 .smp-textarea:focus {
    outline: none; border-color: #D74352;
}
.smp-review-panel { border: 2px solid #e0e7ef; border-radius: 10px; overflow: hidden; }
.smp-review-header {
    background: #D74352; color: #fff;
    padding: 12px 18px; font-size: 15px; font-weight: 700;
    text-align: center; line-height: 1.4; display: block;
}
.smp-review-header .fa { display: inline; vertical-align: middle; margin-right: 6px; }
.smp-review-body { padding: 16px 18px; background: #fff; }
.smp-review-row {
    display: flex; justify-content: space-between; align-items: center;
    padding: 7px 0; border-bottom: 1px solid #f0f0f0; font-size: 14px; color: #555;
}
.smp-review-row:last-child { border-bottom: none; }
.smp-review-row .smp-label { font-weight: 500; }
.smp-review-row .smp-val { font-weight: 700; color: #222; }
.smp-review-total {
    background: #fff8f8; border-top: 2px solid #D74352;
    padding: 12px 18px; text-align: center;
}
.smp-review-total .smp-total-label { font-size: 12px; color: #888; }
.smp-review-total .smp-total-price {
    font-size: 26px; font-weight: 800; color: #D74352; line-height: 1.1;
}
.smp-review-total .smp-total-note { font-size: 11px; color: #999; }
.smp-add-to-cart-wrap { padding: 14px 18px 16px; text-align: center; }
.smp-btn-cart {
    display: inline-block; background: #D74352; color: #fff !important;
    border: none; border-radius: 8px; font-size: 18px; font-weight: 600;
    padding: 13px 36px; cursor: pointer; width: 100%;
    transition: background 0.2s, transform 0.1s;
    text-align: center;
}
.smp-btn-cart:hover { background: #b5303e; transform: translateY(-1px); }
.smp-btn-cart:active { transform: translateY(0); }
.smp-note-box {
    margin-top: 18px; padding: 12px 16px;
    border-left: 4px solid #D74352; background: #fff5f5;
    border-radius: 0 6px 6px 0; font-size: 12px; color: #c0392b;
    line-height: 1.6;
}
.smp-note-box strong { color: #D74352; }
@media(max-width:767px){
    .smp-step-2 .sel-button.shipType { min-width: 100%; }
    .smp-product-grid { gap: 7px; }
    .smp-step-1 .sel-button.product { width: calc(50% - 5px); }
}
