/* ===========================
   Catalog modal (overlay)
   =========================== */
:root{
  --header-h: 72px;
  --brand: #FF9412;
  --brand-weak: rgba(255,148,18,.15);
  --border: rgba(0,0,0,.06);
  --shadow: 0 20px 60px rgba(0,0,0,.12);
  --shadow-soft: 0 6px 18px rgba(0,0,0,.07);
}

.hidden { display: none !important; }

#catalogPanel{
  position: fixed;
  inset: 0;
  z-index: 9999;
  display: none;                  /* включается скриптом через aria */
  align-items: center;
  justify-content: center;
  background: rgba(0,0,0,.35);
}
#catalogPanel[aria-hidden="false"]{ display: flex; }

/* ===========================
   Sheet
   =========================== */
.catalog-sheet{
  width: min(1360px, 96%);        /* чуть шире, чтобы влезали крупные кнопки */
  max-height: calc(100vh - var(--header-h) - 24px);
  overflow-y: auto;
  overflow-x: hidden;
  background: #fffefd;
  
  border-radius: 12px;
  box-shadow: var(--shadow);
  padding: 24px;
  position: relative;
  box-sizing: border-box;
}
@media (min-width: 1600px){
  .catalog-sheet{ width: min(1480px, 96%); }
}

/* ===========================
   Header
   =========================== */
.catalog-header{
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 8px;
  margin-bottom: 12px;
  padding-inline: 4rem;
}
#catTitle{
  font-size: 18px;
  font-weight: 700;
  margin: 0;
}
#catalogBack,
#catalogClose{
  border: none;
  background: transparent;
  cursor: pointer;
  font-size: 20px;
  line-height: 1;
  padding: 3px 9px 6px 9px;
  color: #000000;
  border-radius: 8px;
}
#catalogClose{ font-size: 22px; }
#catalogBack{ display: none; }
#catalogBack.show{ display: inline-flex; }
#catalogBack:hover,
#catalogClose:hover{
  color: var(--brand);
  background: rgba(255, 197, 110, 0.05);
}
#catalogBack:focus-visible,
#catalogClose:focus-visible{
  outline: 2px solid var(--brand);
  outline-offset: 2px;
}

/* ===========================
   Type chooser (главные кнопки)
   Базовая сетка — не используется в 3|2|2, но пусть остаётся.
   =========================== */
.type-chooser{
  display: grid;
  grid-template-columns: repeat(3, minmax(280px, 1fr));
  gap: 24px 24px;
  padding: 8px 8px 16px;
  width: 100%;
  max-width: 100%;
  box-sizing: border-box;
  margin: 0 auto;
}

.type-card{
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 10px;
  padding: 20px 18px;
  min-height: 140px;
  border-radius: 16px;
  background: #fff;
  border: 1px solid var(--border);
  cursor: pointer;
  text-align: left;
  transition: box-shadow .15s ease, border-color .15s ease, transform .02s ease-in;
  box-sizing: border-box;
}
.type-card:hover{
  border-color: rgba(255,153,0,.35);
  box-shadow: var(--shadow-soft);
}
.type-card:active{ transform: translateY(1px); }
.type-card:focus-visible{
  outline: 2px solid var(--brand);
  outline-offset: 2px;
}
.type-card img{
  width: 48px;
  height: 48px;
  object-fit: contain;
}
.type-title{ display: none !important; }
.type-sub{
  font-size: 16px;
  font-weight: 600;
  color: #111;
}

/* ===========================
   Alpha groups (категории/подкатегории)
   =========================== */
#catalogPanel .alpha-grid{
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 18px 24px;
  align-items: start;
  padding: 6px 2px 2px;
  box-sizing: border-box;
}
#catalogPanel .alpha-col{ display: flex; flex-direction: column; }
#catalogPanel .alpha-group{
  background: #fff;
  border: 1px solid transparent;
  border-radius: 12px;
  padding: 10px 12px;
}
#catalogPanel .alpha-title{
  font-size: 13px;
  font-family: 'Inter', sans-serif;
  font-weight: 600;
  letter-spacing: .4px;
  color: #b3b3b3;
  margin: 2px 2px 8px;
}
#catalogPanel .alpha-list{ display: flex; flex-direction: column; gap: 8px; }

/* Category line item */
#catalogPanel .catline{
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  width: 100%;
  padding: 12px 14px;
  background: #fff;
  box-shadow: 0 2px 3px 0 rgba(136, 136, 136, 0.138);
  border-radius: 10px;
  cursor: pointer;
  text-align: left;
  transition: all .2s;
}
#catalogPanel .catline:hover{
  border-color: rgba(255,153,0,.35);
  color:#FF9412;
  box-shadow: var(--shadow-soft);
}
#catalogPanel .catline:active{ transform: translateY(1px); }
#catalogPanel .catline:focus-visible{
  outline: 2px solid var(--brand);
  outline-offset: 2px;
}
#catalogPanel .catline-title{
  font-size: 16px;
  font-family: 'Inter', sans-serif;
  font-weight: 600;
  letter-spacing: .2px;
}
#catalogPanel .catline-badge{
  font-family: 'Inter', sans-serif;
  min-width: 26px;
  height: 22px;
  border-radius: 999px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-size: 12px;
  font-weight: 700;
  color: #fff;
  background: #ff9900;
}

/* ===========================
   Responsive
   =========================== */
@media (max-width: 1200px){
  .type-chooser{ grid-template-columns: repeat(2, minmax(300px, 1fr)); }
  #catalogPanel .alpha-grid{ grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .catalog-header {
  padding-inline: 0;}
}
@media (max-width: 760px){
  .type-chooser{ grid-template-columns: 1fr; }
  #catalogPanel .alpha-grid{ grid-template-columns: 1fr; }
}

.catalog-back { display:inline-flex; align-items:center; }
.catalog-header-left{ display:flex; align-items:center; gap:10px; }
#catTitle{ line-height: 1; }
.catalog-header-left{ display:flex; align-items:center; gap:8px; }

#catalogPanel .catline--disabled{
  color:#9aa0a6;
  background:#f7f7f7;
  box-shadow:none;
  cursor:default;
  pointer-events:none;
  border:1px solid var(--border);
}
#catalogPanel .catline--disabled .catline-title{ color:#9aa0a6; }
#catalogPanel .catline--disabled:hover{ box-shadow:none; }

#catalogBody { display:flex; justify-content:center; }

/* ==== Override для макета 3|2|2: крупные карточки вида ==== */
#typeChooser.type-chooser--rows{
  display:grid;
  grid-template-columns: 1fr !important; /* перекрывает базовую сетку */
  row-gap: 40px;                          /* больше межрядье */
  justify-items: center;
}

#typeChooser.type-chooser--rows .type-row{
  display:grid;
  gap:32px;
  justify-content:center;
  width:100%;
}

#typeChooser.type-chooser--rows .type-row.three{
  grid-template-columns: repeat(3, minmax(240px, 360px));
}
#typeChooser.type-chooser--rows .type-row.two{
  grid-template-columns: repeat(2, minmax(280px, 380px));
}

#typeChooser.type-chooser--rows .type-card{
  box-shadow: 0 3px 5px 0 rgba(136, 136, 136, 0.08);
  align-items:center;
  text-align:center;
  padding: 28px 24px;
  border-radius: 18px;
}
#typeChooser.type-chooser--rows .type-card img,
#typeChooser.type-chooser--rows .type-card svg{
  width: 64px;
  height: 64px;
}
#typeChooser.type-chooser--rows .type-sub{
  font-size: 18px;
  margin-top: 6px;
}

/* адаптив */
@media (max-width:1200px){
  #typeChooser.type-chooser--rows .type-row.three{ grid-template-columns:repeat(3, minmax(200px,1fr)); }
  #typeChooser.type-chooser--rows .type-row.two{   grid-template-columns:repeat(2, minmax(220px,1fr)); }
}
@media (max-width:760px){
  #typeChooser.type-chooser--rows .type-row.three{ grid-template-columns:1fr;}
  #typeChooser.type-chooser--rows .type-row.two{   grid-template-columns:1fr;}
  #catalogPanel .alpha-group{
    padding: 0;
  }
}
/* === Категории/подкатегории: длиннее карточки === */
#catalogPanel .alpha-grid{
  /* три широкие колонки на десктопе */
  grid-template-columns: repeat(3, minmax(380px, 1fr));
  column-gap: 28px;     /* можно 24–32 */
  row-gap: 18px;
}

/* адаптив: на средних экранах две широкие колонки */
@media (max-width: 1200px){
  #catalogPanel .alpha-grid{
    grid-template-columns: repeat(2, minmax(380px, 1fr));
  }
}

/* ещё уже — две поуже; на мобилке остаётся одна (у тебя уже задано) */
@media (max-width: 900px){
  #catalogPanel .alpha-grid{
    grid-template-columns: repeat(2, minmax(300px, 1fr));
  }
}

.alpha-grid--single {
  display: block;
}

.alpha-grid--single .alpha-group {
  width: 100%;
}

@media (max-width: 749px) {
  .alpha-grid {
    display: block;
  }

  .alpha-col {
    width: 100%;
  }
}