/* cf-korea filter styles (ported from block_05_korea_prototype) */
:root{
  /* === Carfinance brand tokens (from design-map) === */
  --cf-primary:#1A3A5C;
  --cf-primary-light:#2A5A8C;
  --cf-primary-dark:#0F2640;
  --cf-brand:rgba(42,90,140,.92);
  --cf-cyan:#009EE3;
  --cf-cyan-dark:#0077B2;
  --cf-accent:#F5A623;
  --cf-green:#4CAF50;
  --cf-red:#E24B4A;
  --cf-bg:#FFFFFF;
  --cf-bg-alt:#F7F8FA;
  --cf-bg-dark:#0B1B2B;
  --cf-text:#222222;
  --cf-text-muted:#5A6472;
  --cf-text-light:#8E96A0;
  --cf-border:#E2E6EB;
  --cf-border-light:#F0F2F5;

  --cf-font:'Manrope',-apple-system,BlinkMacSystemFont,'Segoe UI',sans-serif;
  --cf-font-display:'Bebas Neue','Manrope',sans-serif;
  --cf-font-mono:'JetBrains Mono',monospace;

  --cf-radius:14px;
  --cf-radius-sm:8px;
  --cf-shadow-sm:0 1px 2px rgba(15,38,64,.04),0 2px 8px rgba(15,38,64,.04);
  --cf-shadow-md:0 4px 16px rgba(15,38,64,.06),0 2px 4px rgba(15,38,64,.04);
  --cf-shadow-lg:0 12px 40px rgba(15,38,64,.10),0 4px 12px rgba(15,38,64,.06);
}

/* Mobile overflow fix applied globally via cf-korea.php wp_head */
.cfk-page-wrap { overflow-x: hidden; max-width: 100%; }

.cfk-filter-root, .cfk-filter-root *, .cfk-filter-root *::before, .cfk-filter-root *::after {
  box-sizing: border-box;
}
.cfk-filter-root {
  font-family: var(--cf-font);
  background: var(--cf-bg-alt);
  color: var(--cf-text);
  line-height: 1.6;
  font-size: 15px;
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
}
.cfk-filter-root button,
.cfk-filter-root input,
.cfk-filter-root select { font: inherit; color: inherit; }
.cfk-filter-root button { cursor: pointer; border: none; background: none; }
.cfk-filter-root a { color: inherit; text-decoration: none; }
.cfk-filter-root img { display: block; max-width: 100%; }

/* === Page header (mini, just to frame the prototype) === */
.page-head{
  background:linear-gradient(180deg,var(--cf-primary-dark) 0%,var(--cf-primary) 100%);
  color:#fff;
  padding:28px 0;
  position:relative;
  overflow:hidden;
}
.page-head::after{
  content:'';position:absolute;inset:0;
  background:radial-gradient(circle at 85% 40%,rgba(0,158,227,.22),transparent 55%);
  pointer-events:none;
}
.page-head .wrap{max-width:1440px;margin:0 auto;padding:0 24px;display:flex;align-items:center;justify-content:space-between;gap:24px;flex-wrap:wrap;position:relative}
.page-head .logo{font-weight:800;font-size:22px;letter-spacing:-.5px;display:flex;align-items:center;gap:2px}
.page-head .logo .car{color:#fff}
.page-head .logo .fin{color:var(--cf-cyan)}
.crumbs{font-size:12px;color:rgba(255,255,255,.65);letter-spacing:.3px;text-transform:uppercase;font-weight:500}
.crumbs b{color:#fff;font-weight:600}

/* === Section hero for the block === */
.block-hero{
  max-width:1440px;margin:0 auto;padding:40px 24px 16px;
}
.eyebrow{
  display:inline-flex;align-items:center;gap:8px;
  font-size:11px;font-weight:700;letter-spacing:1.4px;text-transform:uppercase;
  color:var(--cf-cyan);
  padding:6px 12px;border-radius:999px;
  background:rgba(0,158,227,.08);
  border:1px solid rgba(0,158,227,.22);
}
.eyebrow::before{content:'';width:6px;height:6px;border-radius:50%;background:var(--cf-cyan);box-shadow:0 0 0 3px rgba(0,158,227,.2)}
.block-hero h1{
  font-size:clamp(28px,3.4vw,44px);
  font-weight:800;
  letter-spacing:-1px;
  line-height:1.1;
  margin:14px 0 10px;
  color:var(--cf-text);
}
.block-hero h1 em{font-style:normal;color:var(--cf-cyan);background:linear-gradient(180deg,transparent 65%,rgba(0,158,227,.18) 65%)}
.block-hero .lede{color:var(--cf-text-muted);font-size:16px;max-width:760px;line-height:1.55}

/* === Layout: sidebar + catalog === */
.layout{
  max-width:1440px;margin:0 auto;padding:24px 24px 80px;
  display:grid;
  grid-template-columns:320px minmax(0,1fr);
  gap:28px;
  align-items:start;
}
@media(max-width:1100px){.layout{grid-template-columns:280px minmax(0,1fr);gap:20px}}
@media(max-width:900px){.layout{grid-template-columns:1fr;padding:16px}}

/* === Sidebar === */
.sidebar{
  position:sticky;top:16px;
  background:#fff;
  border:1px solid var(--cf-border);
  border-radius:6px;
  max-height:calc(100vh - 32px);
  overflow:hidden;
  display:flex;flex-direction:column;
}
@media(max-width:900px){
  .sidebar{
    position:fixed;inset:auto 0 0 0;top:auto;
    max-height:85vh;z-index:100;border-radius:16px 16px 0 0;
    transform:translateY(100%);transition:transform .35s cubic-bezier(.4,.0,.2,1);
    box-shadow:0 -8px 40px rgba(0,0,0,.18);
  }
  .sidebar.open{transform:translateY(0)}
}
.sidebar-head{
  padding:16px 18px 12px;
  border-bottom:1px solid var(--cf-border-light);
  display:flex;align-items:center;justify-content:space-between;gap:12px;
  flex-shrink:0;
}
.sidebar-head h2{font-size:14px;font-weight:800;letter-spacing:.03em;text-transform:uppercase;color:var(--cf-text)}
.sidebar-head .count-pill{
  font-family:var(--cf-font-mono);
  font-size:10px;font-weight:600;
  padding:3px 8px;border-radius:4px;
  background:var(--cf-bg-alt);color:var(--cf-text-muted);
}
.sidebar-close{display:none;width:28px;height:28px;border-radius:4px;background:var(--cf-bg-alt);color:var(--cf-text-muted);font-size:16px}
@media(max-width:900px){.sidebar-close{display:flex;align-items:center;justify-content:center}}

.sidebar-scroll{
  overflow-y:auto;
  padding:0 18px 110px;
  flex:1;
  scrollbar-width:thin;scrollbar-color:var(--cf-border) transparent;
}
.sidebar-scroll::-webkit-scrollbar{width:5px}
.sidebar-scroll::-webkit-scrollbar-thumb{background:var(--cf-border);border-radius:3px}

/* ---- Type tabs ---- */
.type-tabs{
  display:flex;gap:4px;
  padding:12px 0 14px;
  border-bottom:1px solid var(--cf-border-light);
  overflow-x:auto;
  scrollbar-width:none;
}
.type-tabs::-webkit-scrollbar{display:none}
.type-tab{
  flex:0 0 auto;
  padding:8px 12px;font-size:11px;font-weight:700;
  border-radius:4px;
  background:transparent;
  color:var(--cf-text-muted);
  border:1px solid var(--cf-border);
  transition:all .12s;
  text-align:center;line-height:1.2;
  white-space:nowrap;
}
.type-tab br{display:none}
.type-tab span{display:none}
.type-tab .emoji{display:none}
.type-tab:hover{color:var(--cf-text);border-color:var(--cf-text-light)}
.type-tab.active{
  background:var(--cf-primary);color:#fff;
  border-color:var(--cf-primary);
}

/* ---- Photo toggle ---- */
.fgroup--photo{padding:0;margin:0}
.photo-toggle{display:flex;gap:2px;padding:8px 0 12px;border-bottom:1px solid var(--cf-border-light)}
.photo-btn{
  flex:1;padding:6px 4px;font-size:11px;font-weight:700;
  border-radius:4px;background:transparent;color:var(--cf-text-light);
  border:1px solid transparent;transition:all .12s;text-align:center;
}
.photo-btn .emoji{display:none}
.photo-btn:hover{color:var(--cf-text)}
.photo-btn.active{background:var(--cf-bg-alt);color:var(--cf-text);border-color:var(--cf-border)}

/* ---- Filter groups ---- */
.fgroup{padding:14px 0;border-bottom:1px solid var(--cf-border-light)}
.fgroup:last-child{border-bottom:none}
.fgroup-title{
  font-size:10px;font-weight:800;letter-spacing:.1em;text-transform:uppercase;
  color:var(--cf-text-light);
  margin-bottom:10px;
  display:flex;align-items:center;justify-content:space-between;gap:8px;
}
.fgroup-title .hint{text-transform:none;letter-spacing:normal;font-weight:500;font-size:10px;color:var(--cf-text-light);opacity:.6}

/* ---- Dropdown cascade ---- */
.cascade{display:flex;flex-direction:column;gap:6px}
.sel-wrap{position:relative}
.sel-wrap select{
  width:100%;appearance:none;-webkit-appearance:none;
  padding:10px 32px 10px 12px;
  background:var(--cf-bg-alt);
  border:1px solid var(--cf-border);
  border-radius:4px;
  font-size:12px;font-weight:600;
  color:var(--cf-text);
  transition:border-color .12s;
}
.sel-wrap::after{
  content:'';position:absolute;right:12px;top:50%;width:6px;height:6px;
  border-right:1.5px solid var(--cf-text-muted);border-bottom:1.5px solid var(--cf-text-muted);
  transform:translateY(-70%) rotate(45deg);pointer-events:none;
}
.sel-wrap select:hover{border-color:var(--cf-text-light)}
.sel-wrap select:focus{outline:none;border-color:var(--cf-primary);box-shadow:0 0 0 2px rgba(26,58,92,.08)}
.sel-wrap select:disabled{opacity:.4;cursor:not-allowed}

/* ---- Checkbox options ---- */
.chk-grid{display:grid;grid-template-columns:1fr 1fr;gap:4px}
.chk-grid.one{grid-template-columns:1fr}
.chk{
  display:flex;align-items:center;gap:7px;
  padding:7px 8px;
  font-size:12px;font-weight:600;
  background:transparent;
  border:1px solid var(--cf-border-light);
  border-radius:4px;
  cursor:pointer;
  transition:all .1s;
  user-select:none;
  line-height:1.2;
}
.chk:hover{background:var(--cf-bg-alt);border-color:var(--cf-border)}
.chk input{display:none}
.chk .box{
  width:14px;height:14px;border-radius:3px;
  border:1.5px solid var(--cf-border);
  background:#fff;flex-shrink:0;
  position:relative;transition:all .1s;
}
.chk input:checked + .box{background:var(--cf-primary);border-color:var(--cf-primary)}
.chk input:checked + .box::after{
  content:'';position:absolute;left:3px;top:0px;
  width:5px;height:8px;border:solid #fff;border-width:0 1.5px 1.5px 0;transform:rotate(45deg);
}
.chk input:checked ~ .lbl{color:var(--cf-primary)}
.chk:has(input:checked){background:rgba(26,58,92,.04);border-color:var(--cf-primary)}
.chk .lbl{flex:1;min-width:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.chk .ic{font-size:13px;line-height:1;display:flex;align-items:center}
.chk .ic .emoji{width:13px!important;height:13px!important}

/* ---- Range slider ---- */
.range{padding-top:4px}
.range .nums{
  display:grid;grid-template-columns:1fr 1fr;gap:6px;margin-bottom:12px;
}
.range .nums input{
  width:100%;padding:8px 8px;
  background:#fff;
  border:1px solid var(--cf-border);
  border-radius:4px;
  font-size:11px;font-weight:700;font-family:var(--cf-font-mono);
  color:var(--cf-text);
  text-align:center;
}
.range .nums input:focus{outline:none;border-color:var(--cf-primary);box-shadow:0 0 0 2px rgba(26,58,92,.08)}
.range .nums label{position:relative;display:block}
.range .nums label::before{
  content:attr(data-prefix);position:absolute;left:8px;top:50%;transform:translateY(-50%);
  font-size:9px;font-weight:800;color:var(--cf-text-light);text-transform:uppercase;letter-spacing:.04em;
}
.range .nums label input{padding-left:26px;text-align:left}

.dual-slider{position:relative;height:20px}
.dual-slider .track{
  position:absolute;left:0;right:0;top:50%;transform:translateY(-50%);
  height:3px;background:var(--cf-border);border-radius:2px;
}
.dual-slider .fill{
  position:absolute;top:50%;transform:translateY(-50%);
  height:3px;background:var(--cf-primary);border-radius:2px;
}
.dual-slider input[type=range]{
  position:absolute;left:0;right:0;top:0;width:100%;height:20px;
  background:none;appearance:none;-webkit-appearance:none;pointer-events:none;
}
.dual-slider input[type=range]::-webkit-slider-thumb{
  -webkit-appearance:none;appearance:none;
  width:16px;height:16px;border-radius:50%;
  background:#fff;border:2px solid var(--cf-primary);
  box-shadow:0 1px 4px rgba(0,0,0,.15);
  pointer-events:auto;cursor:grab;
  transition:box-shadow .1s;
}
.dual-slider input[type=range]::-webkit-slider-thumb:hover{box-shadow:0 2px 8px rgba(26,58,92,.3)}
.dual-slider input[type=range]::-moz-range-thumb{
  width:16px;height:16px;border-radius:50%;
  background:#fff;border:2px solid var(--cf-primary);
  box-shadow:0 1px 4px rgba(0,0,0,.15);
  pointer-events:auto;cursor:grab;
}
.dual-slider input[type=range]:nth-child(3){z-index:2}
.dual-slider input[type=range]:nth-child(4){z-index:3}

.quick-pill{
  display:inline-flex;align-items:center;gap:4px;
  margin-top:8px;
  padding:6px 10px;
  font-size:10px;font-weight:800;letter-spacing:.03em;text-transform:uppercase;
  border-radius:4px;
  background:rgba(245,166,35,.08);
  color:var(--cf-accent-dark, #A1660A);
  border:1px solid rgba(245,166,35,.2);
  transition:all .12s;
}
.quick-pill .emoji{display:none}
.quick-pill:hover{background:rgba(245,166,35,.15)}
.quick-pill.active{background:var(--cf-accent);color:#fff;border-color:var(--cf-accent)}

.drive-warn{
  display:flex;gap:6px;padding:8px 10px;margin-top:8px;
  background:var(--cf-bg-alt);border:1px solid var(--cf-border);border-radius:4px;
  font-size:10px;line-height:1.45;color:var(--cf-text-muted);
}
.drive-warn::before{content:'i';font-weight:800;flex-shrink:0;font-size:9px;width:16px;height:16px;border-radius:50%;background:var(--cf-border);color:#fff;display:flex;align-items:center;justify-content:center}

.year-grid{display:grid;grid-template-columns:1fr 1fr;gap:6px}

/* ---- Sticky apply bar ---- */
.apply-bar{
  position:absolute;left:0;right:0;bottom:0;
  padding:12px 18px 14px;
  background:linear-gradient(180deg,rgba(255,255,255,0) 0%,#fff 25%);
  display:flex;flex-direction:column;gap:6px;
  pointer-events:none;
}
.apply-bar > *{pointer-events:auto}
.btn-apply{
  width:100%;padding:12px 16px;
  background:var(--cf-primary);
  color:#fff;
  border-radius:4px;
  font-size:13px;font-weight:800;letter-spacing:.03em;text-transform:uppercase;
  display:flex;align-items:center;justify-content:center;gap:6px;
  transition:background .12s;
}
.btn-apply:hover{background:var(--cf-primary-dark)}
.btn-apply.zero{background:var(--cf-border);cursor:not-allowed}
.btn-apply.zero:hover{background:var(--cf-border)}
.btn-apply .n{font-family:var(--cf-font-mono);font-weight:800}
.btn-reset{
  width:100%;padding:8px;
  font-size:11px;font-weight:700;
  color:var(--cf-text-muted);
  border-radius:4px;
  background:transparent;
  transition:color .12s;
}
.btn-reset:hover{color:var(--cf-red)}
.btn-reset.hidden{display:none}

/* === Catalog area === */
.catalog{min-width:0}
.cat-top{
  background:#fff;
  border:1px solid var(--cf-border);
  border-radius:6px;
  padding:12px 16px;
  display:flex;align-items:center;justify-content:space-between;gap:12px;
  margin-bottom:16px;
  flex-wrap:wrap;
}
.cat-top .found{
  font-size:13px;color:var(--cf-text-muted);
}
.cat-top .found b{
  font-family:var(--cf-font-display);
  font-size:28px;font-weight:400;letter-spacing:.5px;
  color:var(--cf-primary);display:inline-block;line-height:1;vertical-align:-2px;margin-right:6px;
}
.cat-top .right{display:flex;gap:10px;align-items:center;flex-wrap:wrap}
.view-toggle{display:flex;background:var(--cf-bg-alt);border-radius:4px;padding:2px;gap:1px;border:1px solid var(--cf-border)}
.view-toggle button{
  width:32px;height:28px;border-radius:3px;
  display:flex;align-items:center;justify-content:center;
  color:var(--cf-text-light);transition:all .1s;
}
.view-toggle button:hover{color:var(--cf-text)}
.view-toggle button.active{background:#fff;color:var(--cf-primary);box-shadow:0 1px 2px rgba(0,0,0,.06)}
.view-toggle svg{width:14px;height:14px}

.sort-sel{position:relative}
.sort-sel select{
  appearance:none;-webkit-appearance:none;
  padding:8px 30px 8px 12px;
  background:#fff;border:1px solid var(--cf-border);
  border-radius:4px;font-size:12px;font-weight:600;color:var(--cf-text);
}
.sort-sel::after{
  content:'';position:absolute;right:12px;top:50%;width:5px;height:5px;
  border-right:1.5px solid var(--cf-text-muted);border-bottom:1.5px solid var(--cf-text-muted);
  transform:translateY(-70%) rotate(45deg);pointer-events:none;
}

.mobile-filter-btn{
  display:none;
  padding:10px 16px;background:var(--cf-primary);color:#fff;border-radius:4px;
  font-weight:700;font-size:12px;gap:6px;align-items:center;
  text-transform:uppercase;letter-spacing:.03em;
}
@media(max-width:900px){.mobile-filter-btn{display:inline-flex}}

/* === Grid === */
.grid{
  display:grid;gap:14px;
  grid-template-columns:repeat(3,minmax(0,1fr));
}
.grid.cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}
.grid.cols-4{grid-template-columns:repeat(4,minmax(0,1fr))}
.grid.list{grid-template-columns:1fr}
@media(max-width:1200px){.grid,.grid.cols-4{grid-template-columns:repeat(2,minmax(0,1fr))}}
@media(max-width:700px){.grid,.grid.cols-2,.grid.cols-4{grid-template-columns:1fr}}

/* === Car card === */
.card{
  background:#fff;
  border:1px solid var(--cf-border);
  border-radius:6px;
  overflow:hidden;
  display:flex;flex-direction:column;
  transition:transform .15s,box-shadow .15s,border-color .15s;
  position:relative;
}
.card:hover{transform:translateY(-2px);box-shadow:var(--cf-shadow-md);border-color:#D1D9E2}
.card-link{display:flex;flex-direction:column;flex:1;text-decoration:none;color:inherit}
.card-link:hover{color:inherit;text-decoration:none}
.card .fav{position:absolute;top:8px;right:8px;z-index:2}

.card-photo{
  position:relative;
  aspect-ratio:4/3;
  background:#EEF2F6;
  overflow:hidden;
}
.card-photo img{
  width:100%;height:100%;object-fit:cover;
  transition:transform .5s cubic-bezier(.4,0,.2,1);
}
.card:hover .card-photo img{transform:scale(1.05)}
.card-photo .placeholder{
  position:absolute;inset:0;display:flex;align-items:center;justify-content:center;
  background:linear-gradient(135deg,#EEF1F5,#F7F8FA);
  color:var(--cf-text-light);font-size:11px;font-weight:600;
  flex-direction:column;gap:4px;text-align:center;
}
.card-photo .placeholder svg{color:var(--cf-border);margin-bottom:2px}
.card-photo .placeholder span{color:var(--cf-text-light)}

.badges{
  position:absolute;top:12px;left:12px;right:52px;
  display:flex;flex-wrap:wrap;gap:6px;
  z-index:2;
}
.badge{
  display:inline-flex;align-items:center;gap:4px;
  padding:5px 9px;
  font-size:10.5px;font-weight:700;letter-spacing:.3px;
  border-radius:999px;
  background:rgba(255,255,255,.92);
  color:var(--cf-text);
  backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);
  box-shadow:0 2px 8px rgba(0,0,0,.08);
  line-height:1.2;
}
.badge.pass{background:rgba(76,175,80,.95);color:#fff}
.badge.elec{background:rgba(0,158,227,.95);color:#fff}
.badge.top{background:rgba(245,166,35,.95);color:#fff}
.badge.new-badge{background:rgba(16,185,129,.95);color:#fff}

/* China price in CNY */
.card-price-cny{font-size:12px;color:var(--cf-text-muted,#8e96a0);margin-top:-2px;font-weight:500}
/* Auction price (small line under turnkey) */
.card-price-auction{font-size:11px;color:var(--cf-text-light,#8E96A0);margin-top:-2px;font-weight:400;text-decoration:line-through;text-decoration-color:rgba(142,150,160,.4)}

.fav{
  position:absolute;top:8px;right:8px;z-index:2;
  width:32px;height:32px;border-radius:4px;
  background:rgba(255,255,255,.85);
  display:flex;align-items:center;justify-content:center;
  font-size:16px;
  color:var(--cf-text-light);
  transition:all .12s;
}
.fav:hover{color:var(--cf-red);background:#fff}
.fav.on{color:var(--cf-red);background:#fff}

.card-body{
  padding:12px 14px 14px;
  display:flex;flex-direction:column;gap:6px;
  flex:1;
}
.card-title{
  font-size:14px;font-weight:700;letter-spacing:-.2px;
  line-height:1.3;
  color:var(--cf-text);
  display:-webkit-box;-webkit-line-clamp:1;-webkit-box-orient:vertical;overflow:hidden;
  min-height:auto;
}
.card-price{
  font-family:var(--cf-font-display);
  font-size:24px;font-weight:400;letter-spacing:.3px;
  color:var(--cf-primary);
  line-height:1;
  display:flex;align-items:baseline;gap:4px;
}
.card-price .cur{font-size:14px;color:var(--cf-text-muted)}
.card-meta{
  display:flex;flex-wrap:wrap;gap:4px 0;
  font-size:11px;color:var(--cf-text-muted);
  font-weight:500;
  align-items:center;
}
.card-meta .dot{width:3px;height:3px;border-radius:50%;background:#C9D0D8;margin:0 6px;flex-shrink:0}
.card-meta .hl{color:var(--cf-text);font-weight:600}
.card-specs{
  display:grid;grid-template-columns:1fr;gap:3px;
  padding-top:8px;border-top:1px dashed var(--cf-border);
  font-size:11px;
}
.card-specs .sp{display:flex;justify-content:space-between;gap:6px;color:var(--cf-text-muted)}
.card-specs .sp b{color:var(--cf-text);font-weight:600;font-family:var(--cf-font-mono);font-size:10.5px}
.card-cta{
  margin-top:auto;padding-top:6px;
  display:flex;
  gap:6px;
}
.card-cta .more{
  flex:1;padding:8px;
  background:var(--cf-primary);
  color:#fff;
  border-radius:6px;
  font-size:11.5px;font-weight:700;letter-spacing:.02em;
  text-align:center;
  transition:all .12s;
  border:none;
}
.card-cta .more:hover{background:var(--cf-primary-light);color:#fff}

/* List view */
.grid.list .card{flex-direction:column}
.grid.list .card-link{flex-direction:row}
.grid.list .card-photo{width:240px;flex-shrink:0;aspect-ratio:4/3}
.grid.list .card-body{flex:1;padding:12px 16px}
.grid.list .card-title{font-size:15px;-webkit-line-clamp:1;min-height:auto}
.grid.list .card-specs{grid-template-columns:repeat(3,auto);gap:3px 14px}
.grid.list .card-price{font-size:22px}
.grid.list .card-cta{margin-top:auto}
@media(max-width:900px){
  .grid.list .card-link{flex-direction:column}
  .grid.list .card-photo{width:100%;aspect-ratio:16/10}
}

/* Load more */
.load-more-wrap{display:flex;justify-content:center;margin-top:32px;padding:8px 0 16px}
.btn-load-more{
  padding:16px 48px;
  background:var(--cf-primary);color:#fff;
  border:none;border-radius:6px;
  font-size:14px;font-weight:700;letter-spacing:.02em;
  cursor:pointer;transition:all .15s;
  box-shadow:0 4px 12px rgba(26,58,92,.2);
}
.btn-load-more:hover{background:var(--cf-primary-light);transform:translateY(-1px);box-shadow:0 6px 16px rgba(26,58,92,.25)}
.btn-load-more:disabled{opacity:.4;cursor:not-allowed;transform:none;box-shadow:none}

/* Loading / empty */
.state{
  grid-column:1/-1;
  padding:60px 20px;
  text-align:center;
  background:#fff;border:1px solid var(--cf-border);border-radius:6px;
}
.state h3{font-size:18px;font-weight:700;margin-bottom:8px;color:var(--cf-text)}
.state p{font-size:13px;color:var(--cf-text-muted);max-width:380px;margin:0 auto}
.state .spinner{
  width:36px;height:36px;margin:0 auto 16px;
  border:3px solid var(--cf-border);
  border-top-color:var(--cf-primary);
  border-radius:50%;
  animation:spin .8s linear infinite;
}
@keyframes spin{to{transform:rotate(360deg)}}
.state .progress{font-family:var(--cf-font-mono);font-size:11px;color:var(--cf-text-light);margin-top:6px}

/* Animated loader */
.cfk-loader{padding:48px 24px 40px;background:linear-gradient(135deg,#f8fafc 0%,#eef2f7 100%);border:1px solid var(--cf-border);border-radius:10px}
.cfk-loader__pulse{width:48px;height:48px;margin:0 auto 24px;border-radius:50%;background:var(--cf-primary,#1A3A5C);opacity:.15;animation:cfk-pulse 1.4s ease-in-out infinite}
@keyframes cfk-pulse{0%,100%{transform:scale(.8);opacity:.12}50%{transform:scale(1.1);opacity:.25}}

.cfk-loader__steps{display:flex;flex-direction:column;gap:12px;max-width:320px;margin:0 auto}
.cfk-loader__step{display:flex;align-items:center;gap:12px;padding:10px 16px;border-radius:8px;background:rgba(255,255,255,.5);border:1px solid transparent;opacity:.35;transform:translateX(-8px);transition:all .4s cubic-bezier(.4,0,.2,1)}
.cfk-loader__step.active{opacity:1;transform:translateX(0);background:#fff;border-color:var(--cf-border);box-shadow:0 2px 8px rgba(0,0,0,.04)}
.cfk-loader__icon{font-size:20px;flex-shrink:0;width:28px;text-align:center}
.cfk-loader__text{font-size:14px;font-weight:600;color:var(--cf-text,#1A1D22)}
.cfk-loader__step:not(.active) .cfk-loader__text{color:var(--cf-text-muted,#8E96A0);font-weight:500}

.cfk-loader__hint{margin:20px 0 0;font-size:12px;color:var(--cf-text-light,#8E96A0);font-style:italic}

/* Backdrop for mobile sheet */
.backdrop{
  display:none;position:fixed;inset:0;background:rgba(11,27,43,.5);z-index:90;backdrop-filter:blur(3px);
  opacity:0;transition:opacity .3s;
}
.backdrop.show{display:block;opacity:1}

/* Searchable select popup */
.cascade .sel-search{
  padding:9px 12px;font-size:12px;
  background:#fff;border:1px solid var(--cf-border);border-radius:8px;
  margin-bottom:6px;width:100%;
}
.cascade .sel-search:focus{outline:none;border-color:var(--cf-cyan)}
</style>
