/* ── Hikari Loyalty – Frontend CSS v1.0.0 ── */
:root {
    --hikari-dark:   #1a1a2e;
    --hikari-gold:   #e6c87a;
    --hikari-accent: #c9a227;
    --hikari-light:  #f9f6ef;
    --hikari-text:   #2c2c2c;
    --hikari-muted:  #888;
    --hikari-border: #ddd;
    --hikari-radius: 10px;
    --hikari-shadow: 0 4px 20px rgba(0,0,0,.12);
}

/* ── Shared ── */
.hikari-input {
    width: 100%;
    padding: 10px 14px;
    border: 1px solid var(--hikari-border);
    border-radius: var(--hikari-radius);
    font-size: 15px;
    transition: border-color .2s;
    box-sizing: border-box;
}
.hikari-input:focus { border-color: var(--hikari-gold); outline: none; }

.hikari-field { margin-bottom: 16px; }
.hikari-field label { display: block; font-size: 13px; font-weight: 600; margin-bottom: 5px; color: var(--hikari-text); }
.hikari-field small { display: block; color: var(--hikari-muted); font-size: 12px; margin-top: 4px; }
.req { color: #e74c3c; }

.hikari-btn-primary {
    background: var(--hikari-dark);
    color: var(--hikari-gold);
    border: none;
    padding: 11px 22px;
    border-radius: var(--hikari-radius);
    font-size: 14px;
    font-weight: 700;
    cursor: pointer;
    letter-spacing: .5px;
    transition: background .2s, transform .1s;
}
.hikari-btn-primary:hover { background: #25254a; transform: translateY(-1px); }

.hikari-btn-secondary {
    background: transparent;
    color: var(--hikari-dark);
    border: 2px solid var(--hikari-dark);
    padding: 9px 18px;
    border-radius: var(--hikari-radius);
    font-size: 14px;
    font-weight: 600;
    cursor: pointer;
    transition: background .2s;
}
.hikari-btn-secondary:hover { background: var(--hikari-light); }

.hikari-msg {
    padding: 12px 16px;
    border-radius: var(--hikari-radius);
    font-size: 14px;
    margin-top: 12px;
}
.hikari-msg.success { background: #d4edda; color: #155724; border: 1px solid #c3e6cb; }
.hikari-msg.error   { background: #f8d7da; color: #721c24; border: 1px solid #f5c6cb; }
.hikari-form-title  { color: var(--hikari-dark); font-size: 20px; font-weight: 700; margin-bottom: 20px; }

/* ── Register widget ── */
.hikari-register-widget {
    background: #fff;
    padding: 28px;
    border-radius: var(--hikari-radius);
    box-shadow: var(--hikari-shadow);
    max-width: 480px;
}

/* ── Query widget ── */
.hikari-query-widget {
    max-width: 480px;
}
.hikari-query-row {
    display: flex;
    gap: 10px;
    align-items: center;
}
.hikari-query-row .hikari-input { flex: 1; }
.hikari-result-card {
    background: var(--hikari-dark);
    color: #fff;
    border-radius: var(--hikari-radius);
    padding: 24px;
    margin-top: 16px;
    text-align: center;
    box-shadow: var(--hikari-shadow);
}
.hikari-result-name { font-size: 20px; font-weight: 700; }
.hikari-result-key  { font-size: 13px; color: #aaa; margin: 4px 0 12px; }
.hikari-result-pts  { font-size: 42px; font-weight: 800; color: var(--hikari-gold); }
.hikari-result-pts span { font-size: 15px; color: #ccc; vertical-align: middle; }
.hikari-q-error { color: #e74c3c; font-size: 14px; margin-top: 10px; }

/* ── Panel widget ── */
.hikari-panel-widget { font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif; }
.hikari-panel-header { display: flex; align-items: center; gap: 16px; margin-bottom: 18px; }
.hikari-logo { font-size: 16px; font-weight: 800; color: var(--hikari-dark); white-space: nowrap; }
.hikari-panel-header input { flex: 1; }

.hikari-w-table { width: 100%; border-collapse: collapse; font-size: 14px; }
.hikari-w-table th { background: var(--hikari-dark); color: var(--hikari-gold); padding: 10px 12px; text-align: left; }
.hikari-w-table td { padding: 9px 12px; border-bottom: 1px solid var(--hikari-border); }
.hikari-w-table tr:hover td { background: var(--hikari-light); }

.hikari-back-btn { background: none; border: none; color: var(--hikari-dark); font-size: 14px; cursor: pointer; padding: 0 0 14px; font-weight: 600; }
.hikari-member-card { background: var(--hikari-dark); color: #fff; border-radius: var(--hikari-radius); padding: 20px 24px; margin-bottom: 18px; display: flex; align-items: center; gap: 20px; }
.hikari-member-card-name { font-size: 18px; font-weight: 700; flex: 1; }
.hikari-member-card-key  { font-size: 12px; color: #aaa; }
.hikari-member-card-pts  { font-size: 36px; font-weight: 800; color: var(--hikari-gold); text-align: right; }
.hikari-member-card-pts small { display: block; font-size: 12px; color: #aaa; }

.hikari-w-tabs { display: flex; gap: 4px; border-bottom: 2px solid var(--hikari-border); margin-bottom: 16px; }
.hikari-w-tab  { background: none; border: none; padding: 9px 16px; cursor: pointer; font-size: 14px; font-weight: 600; color: var(--hikari-muted); border-bottom: 2px solid transparent; margin-bottom: -2px; }
.hikari-w-tab.active { color: var(--hikari-dark); border-bottom-color: var(--hikari-gold); }

.hikari-w-pages { display: flex; gap: 6px; margin-top: 12px; }
.hikari-w-pages button { padding: 5px 10px; border: 1px solid var(--hikari-border); border-radius: 6px; cursor: pointer; background: #fff; }
.hikari-w-pages button.active { background: var(--hikari-dark); color: var(--hikari-gold); border-color: var(--hikari-dark); }

/* ── v1.2.0 additions ── */

/* Panel widget – header layout */
.hkp-header {
    display: flex;
    align-items: center;
    gap: 12px;
    margin-bottom: 16px;
    flex-wrap: wrap;
}
.hkp-header .hkp-search { flex: 1; min-width: 160px; }

/* Panel table */
.hkp-table { width: 100%; border-collapse: collapse; font-size: 14px; }
.hkp-table th { padding: 10px 12px; text-align: left; }
.hkp-table td { padding: 9px 12px; border-bottom: 1px solid #eee; }

/* Panel card */
.hkp-card {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 16px;
    padding: 20px 24px;
    border-radius: 10px;
    margin-bottom: 18px;
}
.hkp-card-name { font-size: 17px; font-weight: 700; }
.hkp-card-key  { font-size: 12px; margin-top: 2px; font-family: monospace; }
.hkp-card-pts  { font-size: 36px; font-weight: 800; line-height: 1; text-align: right; }
.hkp-card-pts-wrap { text-align: right; }

/* Panel tabs */
.hkp-tabs { display: flex; gap: 4px; border-bottom: 2px solid #eee; margin-bottom: 14px; }
.hkp-tab  {
    background: none; border: none; padding: 8px 16px; cursor: pointer;
    font-size: 14px; font-weight: 600; color: #888;
    border-bottom: 2px solid transparent; margin-bottom: -2px;
    transition: color .15s;
}
.hkp-tab.active { color: #1a1a2e; border-bottom-color: #e6c87a; }
.hkp-tab-body { margin-top: 4px; }

/* Back button */
.hkp-back-btn {
    background: none; border: none; cursor: pointer;
    font-size: 14px; font-weight: 600; color: #1a1a2e;
    padding: 0 0 12px; display: inline-block;
}
.hkp-back-btn:hover { text-decoration: underline; }

/* Pagination */
.hkp-pages { display: flex; gap: 4px; margin-top: 10px; flex-wrap: wrap; }

/* Field label asterisk */
.hikari-field label .req { color: #e74c3c; }

/* Fix query row on mobile */
@media (max-width: 480px) {
    .hikari-query-row, .hkq-row { flex-direction: column; }
    .hikari-query-row .hikari-input,
    .hkq-row .hkq-key { width: 100%; }
    .hkq-submit, .hikari-q-submit { width: 100%; }
}
