/* =============================================================================
   TestKav · pages/catalog.css — LUXE catalog v3
   White background · two-column (main + sticky sidebar) · editorial rows.
   No aura/lines, no card covers, no logos. Tight, scannable, striking.
   Shared by exams_home + exams_root_category + exams_category.
   ========================================================================== */
.cat{padding-bottom:46px}

/* breadcrumb */
.cat-crumbs{display:flex;align-items:center;flex-wrap:wrap;gap:8px;font-size:.82rem;color:var(--ink-3);padding:22px 0 20px}
.cat-crumbs a{color:var(--ink-3);transition:color .3s var(--ease)}
.cat-crumbs a:hover{color:var(--gold-deep)}
.cat-crumbs .sep{color:var(--line-2)}
.cat-crumbs .cur{color:var(--ink);font-weight:600}

/* ---------- two-column ---------- */
.cat-layout{display:grid;grid-template-columns:1fr 286px;gap:46px;align-items:start}
.cat-main{min-width:0}

/* header (compact) */
.cat-eyebrow{display:inline-flex;align-items:center;gap:9px;font-size:.73rem;font-weight:700;color:var(--ink-2)}
.cat-eyebrow .dot{width:7px;height:7px;border-radius:50%;background:var(--gold)}
.cat-title{font-family:var(--ff-d);font-weight:900;color:var(--ink);font-size:clamp(1.6rem,2.7vw,2.15rem);line-height:1.62;margin-top:11px}
.cat-title .accent{color:var(--gold-text)}
.cat-sub{font-size:.91rem;color:var(--ink-2);line-height:1.95;max-width:62ch;margin-top:9px}

/* toolbar / list header with strong divider */
.cat-toolbar{display:flex;align-items:baseline;justify-content:space-between;gap:12px;margin:24px 0 0;padding-bottom:12px;border-bottom:2px solid var(--ink)}
.cat-toolbar__count{font-family:var(--ff-d);font-weight:800;font-size:.95rem;color:var(--ink)}
.cat-toolbar__count b{color:var(--gold-deep)}
.cat-toolbar__hint{font-size:.79rem;color:var(--ink-3)}

/* ---------- editorial rows ---------- */
.cat-list{display:flex;flex-direction:column;gap:14px;margin-top:18px}
.cat-row{position:relative;display:flex;align-items:center;gap:18px;padding:20px 20px 20px 16px;
  border:1px solid var(--line);border-radius:18px;background:#fff;overflow:hidden;box-shadow:0 1px 0 rgba(20,17,13,.02);
  transition:border-color .35s var(--ease),box-shadow .35s var(--ease),transform .35s var(--ease),background .35s var(--ease)}
.cat-row::before{content:"";position:absolute;inset-inline-start:0;top:50%;transform:translateY(-50%) scaleY(0);height:62%;width:4px;background:linear-gradient(180deg,var(--gold),var(--gold-deep));border-radius:0 4px 4px 0;transition:transform .35s var(--ease)}
.cat-row:hover{border-color:var(--gold-soft);box-shadow:0 26px 52px -30px rgba(20,17,13,.28);transform:translateY(-3px);background:linear-gradient(180deg,#fffdf8,#fff)}
.cat-row:hover::before{transform:translateY(-50%) scaleY(1)}
.cat-row__idx{flex:none;min-width:42px;width:42px;height:42px;display:grid;place-items:center;border-radius:50%;
  font-family:var(--ff-d);font-weight:800;font-size:.95rem;font-variant-numeric:tabular-nums;color:var(--gold-deep);
  background:linear-gradient(160deg,#fffdf4,#fff4d4);border:1px solid var(--gold-soft);
  box-shadow:inset 0 1px 0 rgba(255,255,255,.9),0 6px 14px -10px rgba(207,154,12,.5)}
.cat-row:hover .cat-row__idx{background:var(--gold);border-color:var(--gold);color:#1c1402;box-shadow:0 8px 18px -8px var(--gold-soft)}
.cat-row__main{flex:1;min-width:0}
.cat-row__name{display:block;font-family:var(--ff-d);font-weight:700;font-size:1.1rem;color:var(--ink);line-height:1.55;transition:color .3s}
.cat-row:hover .cat-row__name{color:var(--gold-deep)}
.cat-row__meta{display:flex;flex-wrap:wrap;align-items:center;gap:6px 14px;margin-top:5px;font-size:.82rem;color:var(--ink-3);line-height:1.6}
.cat-row__meta .m{display:inline-flex;align-items:center;gap:6px}
.cat-row__meta .m i{color:var(--gold-deep);font-size:.85rem}
.cat-row__meta b{font-family:var(--ff-d);font-weight:700;color:var(--ink-2)}
.cat-row__stat{flex:none;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding-inline:6px;min-width:58px}
.cat-row__stat .n{font-family:var(--ff-d);font-weight:900;font-size:1.24rem;color:var(--gold-deep);line-height:1}
.cat-row__stat .l{font-size:.69rem;color:var(--ink-3);margin-top:3px}
.cat-row__go{flex:none;width:40px;height:40px;display:grid;place-items:center;border:1px solid var(--gold-soft);border-radius:50%;color:var(--gold-deep);transition:.35s var(--ease)}
.cat-row:hover .cat-row__go{border-color:transparent;background:var(--gold);color:#1c1402;box-shadow:0 8px 18px -8px var(--gold-soft)}
.cat-row__go i{transition:transform .35s var(--ease)}
.cat-row:hover .cat-row__go i{transform:translateX(-3px)}

/* exam rows (brief + specs + buy/free) */
.cat-row--exam{align-items:flex-start}
.cat-row--exam .cat-row__idx{margin-top:2px}
.cat-row__brief{font-size:.83rem;color:var(--ink-2);line-height:1.7;margin-top:6px;max-width:60ch}
.cat-row__specs{display:flex;flex-wrap:wrap;gap:7px;margin-top:11px}
.cat-spec{display:inline-flex;align-items:center;gap:5px;font-size:.72rem;color:var(--ink-2);border:1px solid var(--line);border-radius:999px;padding:4px 10px}
.cat-spec i{color:var(--gold-deep)}
.cat-spec b{font-family:var(--ff-d);font-weight:800;color:var(--ink)}
.cat-spec--code{color:var(--gold-deep);border-color:var(--gold-soft);background:var(--gold-faint);direction:ltr}
.cat-row__actions{flex:none;display:flex;flex-direction:column;gap:8px;width:126px}
.cat-btn{display:inline-flex;align-items:center;justify-content:center;gap:7px;font-weight:700;font-size:.8rem;border-radius:11px;padding:10px 12px;transition:.3s var(--ease);white-space:nowrap}
.cat-btn--buy{font-family:var(--ff-d);font-weight:800;color:var(--btn-ink);background:var(--btn-grad);box-shadow:var(--btn-shadow)}
.cat-btn--buy:hover{background:var(--btn-grad-hover);transform:translateY(-2px);box-shadow:var(--btn-shadow-hover)}
.cat-btn--buy:active{transform:translateY(0);box-shadow:var(--btn-shadow-active)}
.cat-btn--buy:focus-visible{outline:0;box-shadow:var(--ring),var(--btn-shadow)}
.cat-btn--free{color:var(--ink);background:#fff;border:1px solid var(--line-2);box-shadow:var(--shadow-sm)}
.cat-btn--free i{color:var(--gold-deep)}
.cat-btn--free:hover{border-color:var(--gold);color:var(--gold-deep);background:var(--paper-2);transform:translateY(-2px);box-shadow:0 10px 22px -12px var(--gold-soft)}
.cat-btn--free:active{transform:translateY(0);box-shadow:var(--shadow-sm)}
.cat-btn--free:focus-visible{outline:0;border-color:var(--gold);box-shadow:var(--ring)}

/* pagination */
.cat-pager{display:flex;align-items:center;justify-content:center;gap:16px;margin-top:28px}
.cat-page{display:inline-flex;align-items:center;gap:7px;font-size:.86rem;font-weight:600;color:var(--ink);background:#fff;border:1px solid var(--line-2);border-radius:11px;padding:9px 16px;box-shadow:var(--shadow-sm);transition:transform .3s var(--ease),box-shadow .3s var(--ease),border-color .3s var(--ease),color .3s var(--ease),background .3s var(--ease)}
.cat-page:hover{border-color:var(--gold);color:var(--gold-deep);background:var(--paper-2);transform:translateY(-2px);box-shadow:0 10px 22px -12px var(--gold-soft)}
.cat-page:active{transform:translateY(0);box-shadow:var(--shadow-sm)}
.cat-page:focus-visible{outline:0;border-color:var(--gold);box-shadow:var(--ring)}
.cat-page-info{font-size:.84rem;color:var(--ink-3)}

/* empty */
.cat-empty{text-align:center;padding:44px 20px;border:1px dashed var(--line-2);border-radius:14px;color:var(--ink-3);margin-top:18px}

/* ---------- sidebar ---------- */
.cat-side{position:sticky;top:18px;display:flex;flex-direction:column;gap:16px}
.cat-searchbar{display:flex;gap:10px;align-items:center;flex-wrap:wrap;margin:18px 0 2px}
.cat-field{flex:1;min-width:220px;display:flex;align-items:center;gap:10px;background:#fff;border:1px solid var(--line-2);border-radius:13px;padding:0 16px;transition:border-color .3s var(--ease),box-shadow .3s var(--ease)}
.cat-field:focus-within{border-color:var(--gold);box-shadow:0 0 0 4px var(--gold-faint)}
.cat-field i{color:var(--gold-deep)}
.cat-field input{flex:1;border:0;background:transparent;outline:none;padding:14px 0;font-family:inherit;font-size:.93rem;color:var(--ink)}
.cat-searchbar button{border:0;cursor:pointer;font-family:var(--ff-d);font-weight:800;font-size:.9rem;color:var(--btn-ink);background:var(--btn-grad);border-radius:13px;padding:14px 26px;box-shadow:var(--btn-shadow);transition:transform .25s var(--ease),box-shadow .25s var(--ease),background .25s var(--ease)}
.cat-searchbar button:hover{background:var(--btn-grad-hover);transform:translateY(-2px);box-shadow:var(--btn-shadow-hover)}
.cat-searchbar button:active{transform:translateY(0);box-shadow:var(--btn-shadow-active)}
.cat-searchbar button:focus-visible{outline:0;box-shadow:var(--ring),var(--btn-shadow)}
.cat-clear{font-size:.83rem;color:var(--ink-3);transition:color .3s}
.cat-clear:hover{color:var(--gold-deep)}

.cat-panel{position:relative;border:1px solid var(--line);border-radius:18px;padding:19px 17px;background:#fff;overflow:hidden;box-shadow:0 24px 48px -36px rgba(20,17,13,.2)}
.cat-panel::before{content:"";position:absolute;inset-inline:0;top:0;height:3px;background:linear-gradient(90deg,transparent,var(--gold),transparent)}
.cat-panel__title{display:flex;align-items:center;gap:8px;font-size:.74rem;font-weight:700;color:var(--ink-3);margin-bottom:13px}
.cat-panel__title i{color:var(--gold-deep)}
.cat-step{display:flex;align-items:center;gap:11px;padding:9px 0}
.cat-step+.cat-step{border-top:1px solid var(--line)}
.cat-step__ico{width:30px;height:30px;flex:none;border-radius:9px;display:grid;place-items:center;color:var(--gold-deep);background:var(--gold-faint);font-size:.9rem}
.cat-step__label{font-size:.84rem;color:var(--ink-2)}
.cat-step__num{margin-inline-start:auto;font-family:var(--ff-d);font-weight:900;font-size:1.12rem;color:var(--gold-deep)}
.cat-step__num--sm{font-size:.8rem;font-weight:700;max-width:120px;text-align:end;line-height:1.3;color:var(--ink-2)}
.cat-prov{display:flex;flex-direction:column;gap:3px;margin-bottom:13px}
.cat-prov__eyebrow{font-size:.71rem;color:var(--ink-3)}
.cat-prov__name{font-family:var(--ff-d);font-weight:800;font-size:1.05rem;color:var(--ink);line-height:1.35}
.cat-stats{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.cat-stat{display:flex;flex-direction:column;align-items:center;justify-content:center;border:1px solid var(--line);border-radius:14px;padding:14px 8px;text-align:center;background:linear-gradient(180deg,#fffdf7,#fff)}
.cat-stat .n{font-family:var(--ff-d);font-weight:900;font-size:1.34rem;color:var(--gold-deep);line-height:1}
.cat-stat .l{font-size:.71rem;color:var(--ink-3);margin-top:5px}

.cat-adv{display:flex;align-items:center;justify-content:center;gap:9px;font-family:var(--ff-d);font-weight:800;font-size:.88rem;color:var(--btn-ink);background:var(--btn-grad);border-radius:13px;padding:13px;box-shadow:var(--btn-shadow);transition:transform .25s var(--ease),box-shadow .25s var(--ease),background .25s var(--ease)}
.cat-adv:hover{background:var(--btn-grad-hover);transform:translateY(-2px);box-shadow:var(--btn-shadow-hover)}
.cat-adv:active{transform:translateY(0);box-shadow:var(--btn-shadow-active)}
.cat-adv:focus-visible{outline:0;box-shadow:var(--ring),var(--btn-shadow)}
.cat-note{font-size:.8rem;color:var(--ink-3);line-height:1.75;padding:2px}
.cat-note b{color:var(--ink-2);font-weight:700}

/* ---------- responsive ---------- */
@media (max-width:900px){
  .cat-layout{grid-template-columns:1fr;gap:24px}
  .cat-side{position:static}
}
@media (max-width:560px){
  .cat-row--exam{flex-wrap:wrap}
  .cat-row--exam .cat-row__actions{flex-direction:row;width:100%;margin-top:10px}
  .cat-btn{flex:1}
  .cat-row__stat{min-width:48px}
}

/* =============================================================================
   exams_home (catalog HUB) — distinct "landing" treatment so the main /exams/
   page reads differently from the deeper category/listing pages, which share
   this same stylesheet. Scoped to .cat-page--hub (only exams_home carries it).
   ========================================================================== */
/* hub: just a slightly richer eyebrow dot — cards/badges now live in the shared base */
.cat-page--hub .cat-eyebrow .dot{box-shadow:0 0 0 4px var(--gold-faint)}
