/* FWS Shopify Analytics — frontend.css v1.1.2 */

.fsa-wrap * { box-sizing: border-box; }

/* ── Header ─────────────────────────────────────────────────────────── */
.fsa-header {
    display: flex; justify-content: space-between; align-items: center;
    background: #185FA5; color: #fff;
    padding: 14px 20px; border-radius: 8px; margin-bottom: .75rem;
}
.fsa-header__title { font-size: 1rem; font-weight: 600; display: flex; align-items: center; gap: 8px; }
.fsa-header__right  { display: flex; align-items: center; gap: 14px; font-size: .82rem; }
.fsa-user  { opacity: .85; display: flex; align-items: center; gap: 5px; }
.fsa-logout { color: #fff; text-decoration: underline; opacity: .75; }
.fsa-logout:hover { opacity: 1; }
.fsa-data-range { font-size: .78rem; color: #888; margin: 0 0 .6rem; }

/* ── Filter bar ─────────────────────────────────────────────────────── */
.fsa-filter-bar {
    display: flex; align-items: center; gap: 8px; flex-wrap: wrap;
    background: #f6f7f7; border: 1px solid #e0e0e0; border-radius: 6px;
    padding: 10px 14px; margin-bottom: 1rem;
}
.fsa-filter-bar select { min-width: 200px; padding: 5px 8px; border: 1px solid #ccc; border-radius: 4px; }
.fsa-filter-bar input[type=date] { padding: 5px 8px; border: 1px solid #ccc; border-radius: 4px; }
.fsa-range-label { font-size: .8rem; color: #777; }

/* ── Tabs ───────────────────────────────────────────────────────────── */
.fsa-tabs { display: flex; border-bottom: 2px solid #e0e0e0; margin-bottom: 1.25rem; flex-wrap: wrap; }
.fsa-tab { padding: 9px 16px; text-decoration: none; color: #555; font-size: .88rem; border-bottom: 2px solid transparent; margin-bottom: -2px; }
.fsa-tab:hover      { color: #185FA5; text-decoration: none; }
.fsa-tab--active    { color: #185FA5; font-weight: 600; border-bottom-color: #185FA5; }

/* ── KPI grid ───────────────────────────────────────────────────────── */
.fsa-kpi-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(150px, 1fr)); gap: 12px; margin-bottom: 1.25rem; }
.fsa-kpi      { background: #f6f7f7; border-radius: 6px; padding: 14px 16px; }
.fsa-kpi__lbl { font-size: .7rem; color: #666; text-transform: uppercase; letter-spacing: .04em; margin-bottom: 6px; }
.fsa-kpi__val { font-size: 1.4rem; font-weight: 700; color: #1d2327; line-height: 1; }
.fsa-kpi__sub { font-size: .7rem; color: #999; margin-top: 5px; }
.fsa-kpi--blue   { background: #e6f1fb; } .fsa-kpi--blue .fsa-kpi__val   { color: #185FA5; }
.fsa-kpi--green  { background: #eaf3de; } .fsa-kpi--green .fsa-kpi__val  { color: #3B6D11; }
.fsa-kpi--purple { background: #eeedfe; } .fsa-kpi--purple .fsa-kpi__val { color: #534AB7; }
.fsa-kpi--warn   { background: #fff8e5; } .fsa-kpi--warn .fsa-kpi__val   { color: #854F0B; }

/* ── Sections ───────────────────────────────────────────────────────── */
.fsa-section { background: #fff; border: 1px solid #e5e5e5; border-radius: 6px; padding: 20px 22px; margin-bottom: 1.25rem; }
.fsa-section h2 { font-size: 1rem; font-weight: 600; margin: 0 0 1rem; }

/* ── Table ──────────────────────────────────────────────────────────── */
.fsa-table-wrap { overflow-x: auto; }
.fsa-table { width: 100%; border-collapse: collapse; font-size: .84rem; }
.fsa-table th { background: #185FA5; color: #fff; text-align: left; padding: 8px 10px; font-weight: 500; font-size: .78rem; }
.fsa-table td { padding: 7px 10px; border-bottom: 1px solid #f0f0f0; color: #333; }
.fsa-table tr:last-child td { border-bottom: none; }
.fsa-table tr:nth-child(even) td { background: #fafafa; }

/* ── Callouts ───────────────────────────────────────────────────────── */
.fsa-callout { border-radius: 5px; padding: 11px 14px; font-size: .85rem; line-height: 1.55; }
.fsa-callout--warn   { background: #fff8e5; border-left: 4px solid #EF9F27; color: #633806; }
.fsa-callout--info   { background: #e6f1fb; border-left: 4px solid #185FA5; color: #0C447C; }
.fsa-callout--purple { background: #eeedfe; border-left: 4px solid #534AB7; color: #26215C; }

/* ── Buttons ────────────────────────────────────────────────────────── */
.fsa-btn { display: inline-block; padding: 9px 20px; border-radius: 5px; font-size: .88rem; font-weight: 500; cursor: pointer; border: 1.5px solid transparent; transition: all .15s; text-decoration: none; }
.fsa-btn--primary { background: #185FA5; color: #fff; border-color: #185FA5; width: 100%; text-align: center; padding: 12px 20px; font-size: .95rem; }
.fsa-btn--primary:hover { background: #0C447C; }
.fsa-btn--primary:disabled { opacity: .6; cursor: default; }
.fsa-btn--sm { padding: 6px 14px; font-size: .82rem; background: #fff; border-color: #ccc; color: #333; }
.fsa-btn--sm:hover { border-color: #185FA5; color: #185FA5; }
.fsa-btn--link { background: none; border: none; color: #185FA5; padding: 0; font-size: .85rem; cursor: pointer; text-decoration: underline; display: block; margin: 10px auto 0; }

/* ── Auth form ──────────────────────────────────────────────────────── */
.fsa-auth-wrap { max-width: 440px; margin: 3rem auto; }
.fsa-auth-card { background: #fff; border: 1px solid #e0e0e0; border-radius: 10px; padding: 2.25rem 2rem; text-align: center; }
.fsa-auth-icon { margin-bottom: 1.25rem; }
.fsa-auth-card h2 { font-size: 1.25rem; font-weight: 700; color: #1d2327; margin: 0 0 .6rem; }
.fsa-auth-card p  { font-size: .9rem; color: #555; margin: 0 0 1.5rem; line-height: 1.55; }
.fsa-field { text-align: left; margin-bottom: 1rem; }
.fsa-field label { display: block; font-size: .82rem; font-weight: 600; color: #444; margin-bottom: 5px; }
.fsa-field input { width: 100%; padding: 10px 12px; border: 1.5px solid #ccc; border-radius: 5px; font-size: .95rem; transition: border-color .15s; }
.fsa-field input:focus { outline: none; border-color: #185FA5; }
.fsa-code-input { font-size: 1.6rem !important; letter-spacing: .25em; text-align: center; }
.fsa-msg { font-size: .85rem; padding: 10px 12px; border-radius: 5px; margin-top: 12px; text-align: left; }
.fsa-msg--ok  { background: #eaf3de; color: #27500A; }
.fsa-msg--err { background: #fcebeb; color: #791F1F; }

.fsa-notice { border-radius: 5px; padding: 14px 18px; font-size: .9rem; }
.fsa-notice--info { background: #e6f1fb; border-left: 4px solid #185FA5; color: #0C447C; }

@media (max-width: 680px) {
    .fsa-kpi-grid { grid-template-columns: repeat(2, 1fr); }
    .fsa-header { flex-direction: column; gap: 8px; }
    .fsa-tabs .fsa-tab { padding: 7px 10px; font-size: .82rem; }
}
