/* =========================================================
   HyperDAF Core — Component Styles
   Location: /wp-content/themes/hyperdaf-core/assets/css/components.css
   Purpose:
   - Shared UI components for buttons, forms, cards, chips,
   - badges, tags, tables, marketplace toolbar, pagination,
   - and universal marketplace loop cards.
   -
   - Important:
   - Card shadow usage is allowed here because loop/product/post
   - cards are the only approved place for shadow effects.
========================================================= */

button,
input[type="submit"],
input[type="button"],
input[type="reset"]{
    font-family:var(--hdaf-font-base);
}

.hdaf-btn,
button.hdaf-btn,
a.hdaf-btn{
    display:inline-flex;
    align-items:center;
    justify-content:center;
    gap:8px;
    min-height:40px;
    padding:0 16px;
    border:1px solid transparent;
    border-radius:10px;
    background:var(--hdaf-color-primary);
    color:#ffffff;
    font-size:13px;
    font-weight:700;
    line-height:1;
    cursor:pointer;
    text-decoration:none;
    white-space:nowrap;
    transition:
        background var(--hdaf-transition-fast),
        border-color var(--hdaf-transition-fast),
        color var(--hdaf-transition-fast),
        transform var(--hdaf-transition-fast);
}

.hdaf-btn:hover,
button.hdaf-btn:hover,
a.hdaf-btn:hover{
    background:var(--hdaf-color-primary-hover);
    color:#ffffff;
    text-decoration:none;
}

.hdaf-btn:focus,
button.hdaf-btn:focus,
a.hdaf-btn:focus{
    outline:none;
    color:#ffffff;
}

.hdaf-btn:active,
button.hdaf-btn:active,
a.hdaf-btn:active{
    transform:translateY(1px);
}

.hdaf-btn[disabled],
.hdaf-btn.is-disabled,
button.hdaf-btn[disabled]{
    opacity:.6;
    cursor:not-allowed;
    pointer-events:none;
}

.hdaf-btn--primary{
    background:var(--hdaf-color-primary);
    color:#ffffff;
}

.hdaf-btn--primary:hover{
    background:var(--hdaf-color-primary-hover);
    color:#ffffff;
}

.hdaf-btn--accent{
    background:var(--hdaf-color-accent);
    color:#ffffff;
}

.hdaf-btn--accent:hover{
    background:var(--hdaf-color-accent-hover);
    color:#ffffff;
}

.hdaf-btn--soft{
    background:#ffffff;
    border-color:var(--hdaf-color-border);
    color:var(--hdaf-color-heading);
}

.hdaf-btn--soft:hover{
    background:var(--hdaf-color-surface-soft);
    border-color:#cbd5e1;
    color:var(--hdaf-color-heading);
}

.hdaf-btn--success{
    background:var(--hdaf-color-success);
    color:#ffffff;
}

.hdaf-btn--success:hover{
    background:#15803d;
    color:#ffffff;
}

.hdaf-btn--pill{
    border-radius:999px;
}

.hdaf-btn--block{
    width:100%;
}

.hdaf-btn--sm{
    min-height:34px;
    padding:0 12px;
    font-size:12px;
    border-radius:9px;
}

.hdaf-btn--lg{
    min-height:44px;
    padding:0 20px;
    font-size:14px;
    border-radius:11px;
}

/* =========================================================
   Form Fields
========================================================= */

input[type="text"],
input[type="email"],
input[type="url"],
input[type="password"],
input[type="search"],
input[type="number"],
input[type="tel"],
input[type="date"],
textarea,
select{
    width:100%;
    min-height:46px;
    padding:0 14px;
    border:1px solid var(--hdaf-color-border);
    border-radius:12px;
    background:var(--hdaf-color-surface);
    color:var(--hdaf-color-text);
    font-family:var(--hdaf-font-base);
    font-size:14px;
    transition:
        border-color var(--hdaf-transition-fast),
        background-color var(--hdaf-transition-fast);
}

textarea{
    min-height:120px;
    padding-top:12px;
    padding-bottom:12px;
    resize:vertical;
}

select{
    padding-right:40px;
}

input::placeholder,
textarea::placeholder{
    color:#94a3b8;
    opacity:1;
}

input:hover,
textarea:hover,
select:hover{
    border-color:#cbd5e1;
}

input:focus,
textarea:focus,
select:focus{
    border-color:#93c5fd;
    background:#fcfdff;
    outline:0;
}

.hdaf-form-group{
    display:flex;
    flex-direction:column;
    gap:8px;
}

.hdaf-form-label{
    color:var(--hdaf-color-heading);
    font-size:13px;
    font-weight:700;
    line-height:1.4;
}

.hdaf-form-help{
    color:var(--hdaf-color-muted);
    font-size:12px;
    line-height:1.6;
}

.hdaf-form-row{
    display:grid;
    grid-template-columns:repeat(2, minmax(0, 1fr));
    gap:16px;
}

/* =========================================================
   Shared Card
========================================================= */

.hdaf-card{
    background:var(--hdaf-color-surface);
    border:1px solid var(--hdaf-color-border);
    border-radius:16px;
}

.hdaf-card__body{
    padding:20px;
}

.hdaf-card__title{
    margin:0 0 8px;
    color:var(--hdaf-color-heading);
    font-size:1.125rem;
    font-weight:800;
    line-height:1.35;
}

.hdaf-card__meta{
    color:var(--hdaf-color-muted);
    font-size:.9375rem;
    line-height:1.6;
}

/* =========================================================
   Marketplace Toolbar
========================================================= */

.hdaf-toolbar{
    display:flex;
    align-items:center;
    justify-content:space-between;
    gap:14px;
    padding:14px 16px;
    margin-bottom:20px;
    background:var(--hdaf-color-surface);
    border:1px solid var(--hdaf-color-border);
    border-radius:16px;
}

.hdaf-toolbar__group{
    display:flex;
    align-items:center;
    flex-wrap:wrap;
    gap:10px;
    min-width:0;
}

.hdaf-toolbar__label{
    color:var(--hdaf-color-heading);
    font-size:12px;
    font-weight:800;
    letter-spacing:.04em;
    text-transform:uppercase;
    line-height:1.4;
    white-space:nowrap;
}

.hdaf-toolbar__count{
    display:inline-flex;
    align-items:center;
    min-height:36px;
    padding:0 12px;
    border:1px solid var(--hdaf-color-border);
    border-radius:999px;
    background:var(--hdaf-color-surface-soft);
    color:var(--hdaf-color-text);
    font-size:13px;
    font-weight:700;
    line-height:1;
    white-space:nowrap;
}

.hdaf-toolbar__search{
    position:relative;
    width:min(100%, 320px);
}

.hdaf-toolbar__search input[type="search"],
.hdaf-toolbar__search input[type="text"]{
    min-height:40px;
    padding-right:14px;
    padding-left:14px;
    border-radius:10px;
    background:#ffffff;
    font-size:13px;
}

.hdaf-toolbar__select{
    min-width:180px;
    max-width:100%;
}

.hdaf-toolbar__select select{
    min-height:40px;
    padding-right:40px;
    border-radius:10px;
    background:#ffffff;
    font-size:13px;
    font-weight:600;
}

.hdaf-toolbar__actions{
    display:flex;
    align-items:center;
    flex-wrap:wrap;
    gap:10px;
}

.hdaf-toolbar__view{
    display:inline-flex;
    align-items:center;
    gap:6px;
    padding:4px;
    border:1px solid var(--hdaf-color-border);
    border-radius:999px;
    background:var(--hdaf-color-surface-soft);
}

.hdaf-toolbar__view-btn{
    display:inline-flex;
    align-items:center;
    justify-content:center;
    min-width:34px;
    min-height:34px;
    padding:0 10px;
    border:0;
    border-radius:999px;
    background:transparent;
    color:var(--hdaf-color-muted);
    font-size:12px;
    font-weight:800;
    line-height:1;
    text-decoration:none;
    cursor:pointer;
    transition:
        background var(--hdaf-transition-fast),
        color var(--hdaf-transition-fast);
}

.hdaf-toolbar__view-btn:hover,
.hdaf-toolbar__view-btn.is-active{
    background:var(--hdaf-color-primary);
    color:#ffffff;
}

.hdaf-toolbar__result{
    color:var(--hdaf-color-muted);
    font-size:13px;
    font-weight:600;
    line-height:1.5;
}

/* =========================================================
   Shared Post / Marketplace Loop Card
========================================================= */

.hdaf-market-card{
    display:flex;
    flex-direction:column;
    height:100%;
    overflow:hidden;
    background:var(--hdaf-color-surface);
    border:1px solid var(--hdaf-color-border);
    border-radius:16px;
    box-shadow:var(--hdaf-shadow-sm);
    transition:
        transform var(--hdaf-transition-fast),
        box-shadow var(--hdaf-transition-fast),
        border-color var(--hdaf-transition-fast);
}

.hdaf-market-card:hover{
    transform:translateY(-2px);
    border-color:#cbd5e1;
    box-shadow:var(--hdaf-shadow-md);
}

.hdaf-market-card__media{
    position:relative;
    overflow:hidden;
    background:var(--hdaf-color-surface-soft);
    border-bottom:1px solid var(--hdaf-color-border);
}

.hdaf-market-card__thumb{
    display:block;
    width:100%;
    aspect-ratio:16 / 10;
    object-fit:cover;
}

.hdaf-market-card__badge{
    position:absolute;
    top:12px;
    left:12px;
    z-index:2;
}

.hdaf-market-card__body{
    display:flex;
    flex:1 1 auto;
    flex-direction:column;
    padding:18px;
}

.hdaf-market-card__top{
    display:flex;
    align-items:flex-start;
    justify-content:space-between;
    gap:12px;
    margin-bottom:10px;
}

.hdaf-market-card__category{
    color:var(--hdaf-color-primary);
    font-size:12px;
    font-weight:800;
    letter-spacing:.06em;
    text-transform:uppercase;
    line-height:1.4;
}

.hdaf-market-card__title{
    margin:0 0 8px;
    color:var(--hdaf-color-heading);
    font-size:1.0625rem;
    font-weight:800;
    line-height:1.35;
}

.hdaf-market-card__title a{
    color:inherit;
    text-decoration:none;
}

.hdaf-market-card__title a:hover{
    color:var(--hdaf-color-primary);
}

.hdaf-market-card__meta{
    display:flex;
    flex-wrap:wrap;
    gap:10px 14px;
    margin-bottom:12px;
    color:var(--hdaf-color-muted);
    font-size:13px;
    line-height:1.5;
}

.hdaf-market-card__meta-item{
    display:inline-flex;
    align-items:center;
    gap:6px;
}

.hdaf-market-card__excerpt{
    margin:0 0 16px;
    color:var(--hdaf-color-text);
    font-size:14px;
    line-height:1.6;
}

.hdaf-market-card__rating{
    display:inline-flex;
    align-items:center;
    gap:6px;
    color:var(--hdaf-color-heading);
    font-size:13px;
    font-weight:700;
}

.hdaf-market-card__author{
    color:var(--hdaf-color-muted);
    font-size:13px;
    font-weight:600;
    line-height:1.5;
}

.hdaf-market-card__footer{
    display:flex;
    align-items:center;
    justify-content:space-between;
    gap:12px;
    margin-top:auto;
    padding-top:14px;
    border-top:1px solid var(--hdaf-color-border);
}

.hdaf-market-card__price{
    display:flex;
    flex-wrap:wrap;
    align-items:baseline;
    gap:6px;
    color:var(--hdaf-color-heading);
    font-size:1.125rem;
    font-weight:800;
    line-height:1.2;
}

.hdaf-market-card__price-old{
    color:var(--hdaf-color-muted);
    font-size:13px;
    font-weight:600;
    text-decoration:line-through;
}

.hdaf-market-card__actions{
    display:flex;
    align-items:center;
    gap:8px;
    flex-shrink:0;
}

/* =========================================================
   Chips / Tags / Badges
========================================================= */

.hdaf-chip,
.hdaf-tag,
.hdaf-badge{
    display:inline-flex;
    align-items:center;
    justify-content:center;
    gap:6px;
    min-height:32px;
    padding:0 10px;
    border:1px solid var(--hdaf-color-border);
    border-radius:999px;
    background:var(--hdaf-color-surface-soft);
    color:var(--hdaf-color-text);
    font-size:12px;
    font-weight:700;
    line-height:1;
    white-space:nowrap;
}

.hdaf-chip--primary,
.hdaf-tag--primary,
.hdaf-badge--primary{
    background:#eff6ff;
    border-color:#bfdbfe;
    color:var(--hdaf-color-primary);
}

.hdaf-chip--accent,
.hdaf-tag--accent,
.hdaf-badge--accent{
    background:#fff7ed;
    border-color:#fed7aa;
    color:var(--hdaf-color-accent);
}

.hdaf-chip--success,
.hdaf-tag--success,
.hdaf-badge--success{
    background:var(--hdaf-color-success-soft);
    border-color:#86efac;
    color:var(--hdaf-color-success);
}

/* =========================================================
   Pagination
========================================================= */

.hdaf-pagination{
    display:flex;
    align-items:center;
    justify-content:center;
    gap:10px;
    flex-wrap:wrap;
    margin-top:24px;
}

.hdaf-pagination__btn,
.hdaf-pagination a,
.hdaf-pagination button{
    display:inline-flex;
    align-items:center;
    justify-content:center;
    min-width:42px;
    min-height:42px;
    padding:0 14px;
    border:1px solid var(--hdaf-color-border);
    border-radius:12px;
    background:#ffffff;
    color:var(--hdaf-color-heading);
    font-size:13px;
    font-weight:800;
    line-height:1;
    text-decoration:none;
    transition:
        background var(--hdaf-transition-fast),
        border-color var(--hdaf-transition-fast),
        color var(--hdaf-transition-fast);
}

.hdaf-pagination__btn:hover,
.hdaf-pagination a:hover,
.hdaf-pagination button:hover{
    border-color:#cbd5e1;
    background:var(--hdaf-color-surface-soft);
    color:var(--hdaf-color-heading);
}

.hdaf-pagination__btn.is-current,
.hdaf-pagination .current{
    border-color:var(--hdaf-color-primary);
    background:var(--hdaf-color-primary);
    color:#ffffff;
}

.hdaf-pagination__back,
.hdaf-pagination__next{
    min-width:96px;
}

.hdaf-pagination__jump{
    display:inline-flex;
    align-items:center;
    gap:8px;
    padding:8px 10px;
    border:1px solid var(--hdaf-color-border);
    border-radius:14px;
    background:var(--hdaf-color-surface);
}

.hdaf-pagination__jump-label{
    color:var(--hdaf-color-muted);
    font-size:12px;
    font-weight:700;
    line-height:1;
    white-space:nowrap;
}

.hdaf-pagination__input{
    width:64px;
    min-width:64px;
}

.hdaf-pagination__input input[type="number"],
.hdaf-pagination__input input[type="text"]{
    min-height:40px;
    padding:0 10px;
    border-radius:10px;
    text-align:center;
    font-size:13px;
    font-weight:700;
}

.hdaf-pagination__total{
    color:var(--hdaf-color-muted);
    font-size:13px;
    font-weight:700;
    line-height:1.5;
}

/* =========================================================
   Table
========================================================= */

.hdaf-table-wrap{
    width:100%;
    overflow-x:auto;
    -webkit-overflow-scrolling:touch;
}

table{
    width:100%;
    border-collapse:collapse;
    border-spacing:0;
}

th,
td{
    padding:14px 16px;
    border-bottom:1px solid var(--hdaf-color-border);
    text-align:left;
    vertical-align:top;
}

th{
    color:var(--hdaf-color-heading);
    font-size:13px;
    font-weight:800;
    letter-spacing:.02em;
    text-transform:uppercase;
    background:var(--hdaf-color-surface-soft);
}

td{
    color:var(--hdaf-color-text);
    line-height:1.6;
}

/* =========================================================
   Responsive
========================================================= */

@media (max-width: 991px){
    .hdaf-toolbar{
        flex-direction:column;
        align-items:stretch;
    }

    .hdaf-toolbar__group,
    .hdaf-toolbar__actions{
        width:100%;
    }

    .hdaf-toolbar__select,
    .hdaf-toolbar__search{
        width:100%;
    }

    .hdaf-pagination{
        gap:8px;
    }
}

@media (max-width: 767px){
    .hdaf-form-row{
        grid-template-columns:minmax(0, 1fr);
    }

    .hdaf-market-card__body{
        padding:16px;
    }

    .hdaf-market-card__top,
    .hdaf-market-card__footer{
        flex-direction:column;
        align-items:flex-start;
    }

    .hdaf-market-card__actions{
        width:100%;
    }

    .hdaf-market-card__actions .hdaf-btn{
        flex:1 1 auto;
    }

    .hdaf-toolbar{
        padding:12px;
        margin-bottom:16px;
    }

    .hdaf-toolbar__view{
        width:100%;
        justify-content:flex-start;
    }

    .hdaf-pagination__back,
    .hdaf-pagination__next{
        min-width:84px;
    }

    .hdaf-pagination__jump{
        width:100%;
        justify-content:center;
    }

    th,
    td{
        padding:12px 14px;
    }
}