/* Модалка — 100% экрана */
.search-modal{position:fixed;inset:0;z-index:100000;background:var(--bg,#FDF8F0);display:flex;flex-direction:column;height:100vh;height:100dvh;transform:translateY(100%);transition:transform .35s cubic-bezier(.32,.72,0,1);will-change:transform}
.search-overlay.active .search-modal{transform:translateY(0)}
.search-overlay{position:fixed;inset:0;z-index:99999;display:none}
.search-overlay.active{display:block}

/* Шапка — sticky */
.search-modal__header{position:sticky;top:0;z-index:10;background:var(--bg,#FDF8F0);padding:10px 12px;display:flex;align-items:center;gap:10px;border-bottom:1px solid rgba(128,128,128,.12);flex-shrink:0;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);background:color-mix(in srgb, var(--bg,#FDF8F0) 85%, transparent)}

.search-modal__back,.search-modal__clear{flex-shrink:0;width:44px;height:44px;display:flex;align-items:center;justify-content:center;border:none;background:transparent;color:var(--text,#1E293B);cursor:pointer;border-radius:12px;transition:background .15s}
.search-modal__back:hover,.search-modal__clear:hover{background:rgba(128,128,128,.1)}
.search-modal__back svg,.search-modal__clear svg{pointer-events:none}

.search-modal__input{flex:1;min-height:44px;padding:10px 14px;border:2px solid rgba(128,128,128,.15);border-radius:12px;background:rgba(128,128,128,.04);color:var(--text,#1E293B);font-size:16px;font-family:'Inter',system-ui,sans-serif;-webkit-appearance:none;appearance:none}
.search-modal__input:focus{outline:none;border-color:#FF6B35;background:rgba(255,107,53,.04)}
.search-modal__input::placeholder{color:rgba(128,128,128,.5)}

/* Тело — скролл */
.search-modal__body{flex:1;overflow-y:auto;-webkit-overflow-scrolling:touch;padding:16px 16px 32px;max-width:800px;margin:0 auto;width:100%}

/* Секции */
.search-section{margin-bottom:28px}
.search-section__title{font-family:'Manrope',system-ui,sans-serif;font-weight:700;text-transform:uppercase;letter-spacing:.06em;font-size:11px;opacity:.55;margin-bottom:10px;color:var(--text,#1E293B)}

/* Посёлки — чипы */
.search-towns{display:flex;flex-wrap:wrap;gap:8px}
.town-chip{display:inline-flex;align-items:center;padding:9px 16px;border-radius:24px;background:rgba(128,128,128,.06);border:1.5px solid rgba(128,128,128,.12);cursor:pointer;font-size:14px;color:var(--text,#1E293B);transition:all .15s;min-height:40px;user-select:none;font-family:'Inter',system-ui,sans-serif;white-space:nowrap}
.town-chip:has(input:checked){background:#FF6B35;color:#fff;border-color:#FF6B35}
.town-chip input{position:absolute;opacity:0;pointer-events:none}
.town-chip--all{font-weight:600}

/* Часто ищут */
.search-popular{display:flex;flex-direction:column;gap:6px}
.search-popular__item{display:flex;align-items:center;gap:12px;width:100%;padding:14px 16px;border-radius:14px;background:rgba(128,128,128,.05);border:1px solid transparent;font-size:15px;color:var(--text,#1E293B);cursor:pointer;transition:background .15s,border-color .15s;min-height:52px;font-family:'Inter',system-ui,sans-serif;text-align:left}
.search-popular__item:hover{background:rgba(128,128,128,.1);border-color:rgba(128,128,128,.12)}
.search-popular__item:active{background:rgba(128,128,128,.15)}
.search-popular__icon{font-size:22px;flex-shrink:0;width:36px;height:36px;display:flex;align-items:center;justify-content:center;background:rgba(128,128,128,.07);border-radius:10px}
.search-popular__label{line-height:1.3}

/* Результаты */
.search-results__group{margin-bottom:24px}
.search-results__group-header{display:flex;align-items:center;gap:8px;margin-bottom:10px}
.search-results__group-icon{font-size:18px}
.search-results__group-title{font-weight:700;font-size:15px;color:var(--text,#1E293B)}
.search-results__count{font-weight:400;font-size:13px;color:rgba(128,128,128,.5);margin-left:auto}

.search-results__item{display:flex;align-items:center;gap:12px;padding:13px 14px;border-radius:14px;background:rgba(128,128,128,.05);margin-bottom:6px;transition:background .15s;min-height:56px;text-decoration:none;color:var(--text,#1E293B)}
.search-results__item:hover{background:rgba(128,128,128,.1)}
.search-results__item:active{background:rgba(128,128,128,.14)}
.search-results__item-icon{font-size:22px;flex-shrink:0;width:36px;height:36px;display:flex;align-items:center;justify-content:center;background:rgba(128,128,128,.07);border-radius:10px}
.search-results__item-info{flex:1;min-width:0}
.search-results__item-title{font-weight:600;font-size:14px;margin-bottom:2px;line-height:1.3;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.search-results__item-town{font-size:12px;color:rgba(128,128,128,.5);line-height:1.3}

/* Пустое состояние */
.search-empty{text-align:center;padding:72px 16px;color:rgba(128,128,128,.5)}
.search-empty__icon{font-size:52px;margin-bottom:14px;opacity:.45}
.search-empty__title{font-weight:700;font-size:17px;margin-bottom:6px;color:var(--text,#1E293B)}
.search-empty__desc{font-size:14px;line-height:1.5}

/* Загрузка */
.search-loading{text-align:center;padding:72px 16px;color:rgba(128,128,128,.5)}
.search-loading__spinner{width:32px;height:32px;border:3px solid rgba(128,128,128,.12);border-top-color:#FF6B35;border-radius:50%;animation:search-spin .7s linear infinite;margin:0 auto 14px}
@keyframes search-spin{to{transform:rotate(360deg)}}
.search-loading__text{font-size:14px}

/* ===== ТЁМНАЯ ТЕМА ===== */
.dark .search-modal{background:#0F172A}
.dark .search-modal__header{border-bottom-color:rgba(255,255,255,.06);background:color-mix(in srgb, #0F172A 85%, transparent)}
.dark .search-modal__back,.dark .search-modal__clear{color:#F1F5F9}
.dark .search-modal__input{background:rgba(30,41,59,.5);color:#F1F5F9;border-color:rgba(255,255,255,.08)}
.dark .search-modal__input:focus{border-color:#FF6B35;background:rgba(255,107,53,.06)}
.dark .search-modal__input::placeholder{color:rgba(241,245,249,.3)}
.dark .search-section__title{color:rgba(241,245,249,.4)}
.dark .town-chip{background:rgba(30,41,59,.35);border-color:rgba(255,255,255,.06);color:#F1F5F9}
.dark .search-popular__item{background:rgba(30,41,59,.35);border-color:rgba(255,255,255,.04);color:#F1F5F9}
.dark .search-popular__item:hover{background:rgba(30,41,59,.6)}
.dark .search-popular__item:active{background:rgba(30,41,59,.75)}
.dark .search-popular__icon{background:rgba(30,41,59,.5)}
.dark .search-results__item{background:rgba(30,41,59,.35)}
.dark .search-results__item:hover{background:rgba(30,41,59,.55)}
.dark .search-results__item-icon{background:rgba(30,41,59,.5)}
.dark .search-results__item-town{color:rgba(241,245,249,.35)}
.dark .search-empty__title{color:#F1F5F9}

/* Подсказки (autocomplete) */
.search-modal__suggestions{margin-bottom:16px;border-radius:14px;background:rgba(0,0,0,.03);border:1px solid rgba(0,0,0,.06);overflow:hidden}
.search-modal__suggestion{display:flex;align-items:center;gap:10px;padding:12px 14px;font-size:15px;color:#1E293B;cursor:pointer;transition:background .1s;min-height:46px;border-bottom:1px solid rgba(0,0,0,.04)}
.search-modal__suggestion:last-child{border-bottom:none}
.search-modal__suggestion:hover{background:rgba(0,0,0,.06)}
.search-modal__suggestion:active{background:rgba(0,0,0,.1)}
.search-modal__suggestion-icon{font-size:16px;opacity:.5;flex-shrink:0}
.search-modal__suggestion-text{flex:1}
.search-modal__suggestion-text mark{background:transparent;color:#FF6B35;font-weight:600}

/* Тёмная тема подсказок */
.dark .search-modal__suggestions{background:rgba(255,255,255,.04);border-color:rgba(255,255,255,.08)}
.dark .search-modal__suggestion{color:#F1F5F9;border-bottom-color:rgba(255,255,255,.04)}
.dark .search-modal__suggestion:hover{background:rgba(255,255,255,.08)}
.dark .search-modal__suggestion mark{color:#FF6B35}
