/* Dark theme / WRAP BAZA */
:root{
  --bg:#0b0e13;
  --panel:#12161e;
  --text:#e8eef6;
  --muted:#9aa7b2;
  --brand:#8bd0ff;
  --brand-2:#c6f06b;
  --stroke:#202735;
  --btn:#1e2633;
  --btn-primary:#2b80ff;
  --danger:#ff4d4f;
  --success:#22c55e;
  /* Sticky layout metrics */
  --topbar-h:60px;
  --tabs-h:60px;
}
*{box-sizing:border-box}
html,body{height:100%}
html{-webkit-text-size-adjust:100%;text-size-adjust:100%}
body{
  margin:0;
  font:16px/1.45 -apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Ubuntu,Inter,system-ui;
  background:radial-gradient(1200px 600px at 80% -20%,rgba(43,128,255,.2),transparent 60%),var(--bg);
  color:var(--text);
}

.topbar{
  position:sticky;top:0;z-index:10;
  display:flex;align-items:center;gap:14px;
  padding:14px 16px;border-bottom:1px solid var(--stroke);min-height:var(--topbar-h);
  background:linear-gradient(180deg,rgba(11,14,19,.9),rgba(11,14,19,.75));
  backdrop-filter:saturate(140%) blur(6px);
}
.brand{display:flex;align-items:center;gap:12px}
.logo{width:32px;height:32px;filter:drop-shadow(0 2px 6px rgba(0,0,0,.4))}
.titles .title{font-weight:800;letter-spacing:.5px}
.titles .subtitle{font-size:12px;color:var(--muted)}

.tabs{
  display:flex;flex-wrap:wrap;gap:6px;
  padding:12px 16px;border-bottom:1px solid var(--stroke);
}
.tab{
  padding:8px 12px;border:1px solid var(--stroke);border-radius:999px;
  background:var(--btn);color:var(--text);cursor:pointer
}
.tab.active{background:var(--btn-primary);border-color:#2b80ff}

.view{display:none;padding:16px}
.view.active{display:block}

.card{
  background:linear-gradient(180deg,#0e131b,#0b0f15);
  border:1px solid var(--stroke);border-radius:16px;padding:16px;
  box-shadow:0 6px 30px rgba(0,0,0,.25)
}
.card-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:10px}
.qr{display:flex;justify-content:center;padding:8px 0 12px}
.qr img{width:160px;height:160px;background:#000;border-radius:8px;border:1px solid var(--stroke)}

.quick{display:flex;gap:8px;margin-top:8px}
.btn{border:1px solid var(--stroke);background:var(--btn);color:var(--text);padding:10px 14px;border-radius:12px;cursor:pointer}
.btn.primary{background:var(--btn-primary);border-color:#2b80ff}
.btn.danger{background:transparent;border-color:var(--danger);color:var(--danger)}

.tiles{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-top:14px}
.tile{border:1px solid var(--stroke);background:var(--panel);border-radius:12px;padding:12px}
.tile-title{font-weight:600}
.tile-text{font-size:13px;color:var(--muted)}

.panel{border:1px solid var(--stroke);background:var(--panel);border-radius:16px;padding:16px}
.panel h2{margin:0 0 8px}
details.spoiler{border:1px dashed var(--stroke);border-radius:12px;padding:8px 12px;background:#0e1420}
details.spoiler summary{cursor:pointer;list-style:none;font-weight:600}
details.spoiler summary::-webkit-details-marker{display:none}

.grid2{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:12px;
}
.grid2 .line{display:flex;flex-direction:column;gap:6px;min-width:0}
.grid2 .line.full{grid-column:1 / -1}

input, select{
  background:#0e1420;border:1px solid var(--stroke);color:var(--text);
  padding:10px 12px;border-radius:10px;width:100%
}

.plans{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.plan{border:1px solid var(--stroke);background:linear-gradient(180deg,#0e131b,#0b0f15);border-radius:16px;padding:16px}
.plan-title{font-weight:700}
.plan-desc{color:var(--muted);margin:6px 0 10px;font-size:14px;line-height:1.4}
.plan-desc:empty{display:none}
.plan-desc p{margin:0 0 6px}
.plan-desc ul{padding-left:18px;margin:6px 0}
.plan-price{font-size:20px;margin:4px 0 8px}
.plan ul{padding-left:18px;margin:8px 0;color:var(--muted)}

/* Segmented control for subscription durations */
.segmented{display:flex;gap:8px;flex-wrap:wrap;margin:10px 0}
.seg-btn{
  border:1px solid var(--stroke);
  background:#0e1420;color:var(--text);
  padding:8px 12px;border-radius:999px;cursor:pointer;font-size:14px
}
.seg-btn.active{background:var(--btn-primary);border-color:#2b80ff}

.feed{display:grid;gap:8px}
.feed-item{border:1px dashed var(--stroke);border-radius:12px;padding:10px;background:#0e1420}

.wlist{display:grid;gap:10px}
.witem{display:flex;justify-content:space-between;border:1px solid var(--stroke);border-radius:12px;padding:10px;background:#0e1420}
.muted{color:var(--muted)}

.form .line{display:flex;gap:10px;align-items:center;margin:10px 0}
.form input{flex:1}

.check{display:block;margin:8px 0;color:var(--muted)}

/* Profile info cards */
.profile-info{display:grid;gap:10px;margin:12px 0}
.profile-field{display:flex;justify-content:space-between;align-items:center;border:1px solid var(--stroke);border-radius:10px;padding:10px 12px;background:#0e1420}
.profile-label{font-size:13px;color:var(--muted)}
.profile-value{font-weight:600;color:var(--text)}

/* Checkbox rows aligned */
.checks{display:grid;gap:10px;margin-top:12px}
.check-row{display:grid;grid-template-columns:16px 1fr;align-items:center;gap:10px}
.check-row input[type="checkbox"]{
  appearance:auto;width:16px;height:16px;line-height:1;
  accent-color: var(--btn-primary);
  cursor:pointer; margin:0;
}
.check-row span{font-size:13px;color:var(--muted);line-height:1.4}

.toolbar{display:flex;gap:10px;margin-top:8px}

.status{margin:6px 0 10px;font-size:13px;color:var(--muted)}
.status.error{color:var(--danger)}
.status.ok{color:var(--success)}

.list{display:grid;gap:10px}
.record{
  display:grid;gap:6px;border:1px solid var(--stroke);border-radius:12px;padding:12px;background:#0e1420
}
.record-head{display:flex;justify-content:space-between;align-items:center}
.record-tags{display:flex;flex-wrap:wrap;gap:6px}
.tag{font-size:12px;border:1px solid var(--stroke);border-radius:999px;padding:4px 8px;color:var(--muted)}
.tag.ok{border-color:#2b80ff;color:#cfe1ff}
.tag.warn{border-color:#d4a72c;color:#ffefc3}
.tag.bad{border-color:var(--danger);color:#ffd2d2}

.footer{opacity:.6;font-size:12px;padding:16px;text-align:center}

@media (max-width:560px){
  /* Убираем sticky у табов на мобильных, чтобы не раздвигали контент */
  .tabs{position:static;top:auto;min-height:auto;background:transparent;backdrop-filter:none}
  .grid2{grid-template-columns:1fr}
  /* Скрываем повтор KPI на компактной карточке, чтобы не было дублей */
  .kpis{display:none}
}

/* Loyalty card compact */
.loyalty{display:flex;flex-direction:column;gap:12px}
.loyalty-head{display:flex;justify-content:space-between;align-items:center}
.loyalty-title{font-weight:700;letter-spacing:.2px}
.loyalty-badges{display:flex;gap:8px;flex-wrap:wrap}
.badge{
  display:inline-flex;align-items:center;gap:6px;
  padding:6px 10px;border:1px solid var(--stroke);
  border-radius:999px;background:#0e1420;color:var(--text);
  font-size:12px
}
.badge.soft{color:var(--muted)}
.kpis{display:grid;grid-template-columns:repeat(2,1fr);gap:10px}
.kpi{border:1px solid var(--stroke);border-radius:12px;padding:10px;background:#0e1420}
.kpi-label{font-size:12px;color:var(--muted)}
.kpi-value{font-size:18px;font-weight:700}

/* Спрятать блок KPI, чтобы не дублировать значения с бейджами */
.kpis{display:none}

/* Tighten panel headings a bit */
.panel h2{font-size:18px;margin-bottom:10px}

/* --- UI tweaks: typography and density refinements --- */
/* Labels above inputs */
.line > span{font-size:13px;color:var(--muted)}

/* Tighter form controls in booking grid */
.grid2 select,.grid2 input{padding:8px 10px;font-size:14px}
select option{font-size:14px}

/* Categories/services list readability on mobile */
.grid2 .line{gap:4px}

/* Showcase (Витрина) spacing when open */
details.spoiler[open] > summary{margin-bottom:16px}
#subsCatalog{margin-top:4px}

/* Mobile adjustments */
@media (max-width:560px){
  body{font-size:15px}
  .tab{padding:7px 10px;font-size:14px}
  .btn{padding:9px 12px;font-size:14px}
  .plans{grid-template-columns:1fr}
  #view-booking .grid2 select,#view-booking .grid2 input{padding:8px 10px;font-size:14px}
}

/* Android-specific tuning for big native pickers */
.is-android select,.is-android option{font-size:14px;line-height:1.3}

/* === Smart Select (custom dropdown with search) === */
.smart-select{position:relative;min-width:0;width:100%}
.smart-hidden{display:none!important;pointer-events:none!important;position:absolute!important;opacity:0!important}
.smart-trigger{
  display:flex;align-items:center;justify-content:space-between;min-width:0;
  width:100%;background:#0e1420;border:1px solid var(--stroke);color:var(--text);
  padding:10px 12px;border-radius:10px;cursor:pointer
}
.smart-trigger .value{flex:1;min-width:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.smart-trigger .chev{margin-left:8px;opacity:.7;flex-shrink:0}

.smart-overlay{position:fixed;inset:0;z-index:1000;display:flex;align-items:flex-end;justify-content:center;background:rgba(0,0,0,.5)}
.smart-panel{
  width:min(640px,96vw);max-height:80vh;overflow:hidden;display:flex;flex-direction:column;
  background:var(--panel);border:1px solid var(--stroke);
  border-top-left-radius:16px;border-top-right-radius:16px;border-bottom-left-radius:16px;border-bottom-right-radius:16px;
  box-shadow:0 10px 40px rgba(0,0,0,.5)
}
.smart-head{display:flex;gap:8px;align-items:center;padding:12px;border-bottom:1px solid var(--stroke)}
.smart-title{font-weight:700}
.smart-close{border:1px solid var(--stroke);background:var(--btn);color:var(--text);border-radius:8px;padding:8px 10px;cursor:pointer}
.smart-search{flex:1;background:#0e1420;border:1px solid var(--stroke);color:var(--text);padding:10px 12px;border-radius:10px}
.smart-list{max-height:calc(80vh - 56px - 24px);overflow:auto;padding:12px;display:grid;gap:8px}
.smart-item{display:grid;grid-template-columns:1fr auto;gap:10px;align-items:flex-start;border:1px solid var(--stroke);border-radius:10px;padding:10px;background:#0e1420;cursor:pointer}
.smart-item:hover{border-color:#2b80ff}
.smart-item.selected{border-color:#2b80ff;background:linear-gradient(180deg,#0e131b,#0b0f15)}
.smart-item.active{border-color:#2b80ff;box-shadow:0 0 0 2px rgba(43,128,255,.2) inset}
.smart-item .smart-item-title{min-width:0;font-size:14px;line-height:1.35;hyphens:auto;overflow-wrap:anywhere}
.smart-item .smart-item-details{font-size:12px;color:var(--muted);margin-top:4px;hyphens:auto;overflow-wrap:anywhere}
.smart-item .smart-item-price{white-space:nowrap;font-weight:700;margin-left:6px}
.smart-item mark{background:transparent;color:var(--brand)}

@media (min-width:900px){
  .smart-overlay{align-items:center;background:rgba(0,0,0,.35)}
}

/* Lock scroll when smart overlay open */
body.smart-open{overflow:hidden}

/* Скрытие всего контента для несинхронизированных пользователей */
body.not-mapped .tabs{display:none}
body.not-mapped #profileInfoPanel{display:none}
body.not-mapped .tiles{display:none}
body.not-mapped #view-booking{display:none!important}
body.not-mapped #view-subs{display:none!important}
body.not-mapped #view-history{display:none!important}
body.not-mapped #view-warranty{display:none!important}

/* Показываем только панель привязки */
body.not-mapped #linkPhonePanel{display:block}
body:not(.not-mapped) #linkPhonePanel{display:none}

/* Chips of selected services */
.chips{display:flex;gap:6px;flex-wrap:wrap;margin-top:6px}
.chip{border:1px solid var(--stroke);border-radius:999px;padding:4px 8px;font-size:12px;color:var(--text);background:#0e1420}
.chip .x{opacity:.7;margin-left:6px;cursor:pointer}

/* --- History (friendly) --- */
.history-day{display:grid;gap:8px}
.history-date{
  position:sticky; top:var(--topbar-h); /* только под бар, табы нестикнуты на мобиле */
  background:rgba(14,20,32,.7); backdrop-filter:blur(4px);
  border:1px solid var(--stroke); border-radius:8px;
  padding:4px 8px; font-size:12px; color:var(--muted); z-index:1
}
.h-card{padding:12px}
.h-head{display:flex;align-items:flex-start;justify-content:space-between;gap:8px}
.h-left{display:flex;gap:8px;align-items:center}
.h-time{font-weight:700}
.h-staff{opacity:.9}
.h-right{text-align:right}
.h-amount{font-weight:700}
.h-id{font-size:12px;color:var(--muted)}
.h-services{margin:6px 0 8px;color:var(--text);opacity:.9;word-break:break-word}
.h-tags{display:flex;gap:6px;flex-wrap:wrap}

/* --- Warranty block --- */
.h-warranty{
  border:1px solid var(--stroke);
  background:#0e1420;
  border-radius:10px;
  padding:10px 12px;
  margin-top:6px;
}
.h-warranty .h-w-title{
  font-size:13px;
  color:var(--muted);
  font-weight:700;
  margin-bottom:6px;
}
.h-warranty .h-w-grid{
  display:grid;
  grid-template-columns: auto 1fr;
  gap:6px 10px;
}
.h-warranty .h-w-label{
  font-size:12px;
  color:var(--muted);
}
.h-warranty .h-w-value{
  font-size:13px;
  color:var(--text);
  font-weight:600;
}

/* --- Acts UI --- */
.acts-toolbar{display:flex;gap:8px;margin-top:6px}
.otp-modal{position:fixed;inset:0;z-index:2000;display:flex;align-items:center;justify-content:center;background:rgba(0,0,0,.55)}
.otp-panel{width:min(520px,96vw);background:var(--panel);border:1px solid var(--stroke);border-radius:16px;padding:16px}
.otp-title{font-weight:700;margin-bottom:8px}
.otp-grid{display:grid;gap:10px;margin:8px 0}
.otp-grid label{display:grid;gap:6px}
.otp-grid input{background:#0e1420;border:1px solid var(--stroke);color:var(--text);padding:10px 12px;border-radius:10px}

/* Доп. подсказка в OTP модалке */
.otp-hint{margin:6px 0 0;color:var(--muted);font-size:13px;line-height:1.4}

/* --- OFF overlay (maintenance) --- */
#offOverlay{position:fixed;inset:0;z-index:3000;display:flex;align-items:center;justify-content:center;background:linear-gradient(180deg,rgba(0,0,0,.8),rgba(0,0,0,.85));backdrop-filter:blur(2px)}
#offOverlay .off-panel{max-width:720px;margin:0 16px;text-align:center}
#offOverlay .off-title{
  color:#ff5252;
  text-shadow:0 0 18px rgba(255,0,0,.25), 0 0 2px rgba(0,0,0,.35);
  font-weight:900;letter-spacing:1px;line-height:1.1;
  font-size: clamp(22px, 5vw, 40px);
}
#offOverlay .off-sub{
  margin-top:12px;color:#eaeaea;opacity:.9;
  font-size: clamp(12px, 2.6vw, 16px);
}

/* --- Consent overlay (PDn gate) --- */
#consentOverlay{
  position:fixed;top:0;left:0;right:0;bottom:0;
  width:100vw;height:100vh;
  z-index:3500;display:flex;align-items:center;justify-content:center;
  background:linear-gradient(180deg,rgba(0,0,0,.8),rgba(0,0,0,.85));
  backdrop-filter:blur(2px)
}
#consentOverlay .consent-panel{width:min(640px,96vw);background:var(--panel);border:1px solid var(--stroke);border-radius:16px;padding:16px;margin:0 12px}
.consent-title{font-weight:800;letter-spacing:.2px}
.consent-text{margin-top:8px;color:var(--text);opacity:.9}
.consent-panel .toolbar{justify-content:flex-end}

/* When consent is not given, lock app UI */
body.consent-required .topbar{filter:blur(2px);pointer-events:none!important;user-select:none!important}
body.consent-required .tabs{filter:blur(2px);pointer-events:none!important;user-select:none!important}
body.consent-required main{filter:blur(2px);pointer-events:none!important;user-select:none!important}
body.consent-required .footer{filter:blur(2px);pointer-events:none!important;user-select:none!important}

/* --- Skeleton loader (shimmer) --- */
.skeleton{
  position:relative;
  color:transparent!important;
  background:#0e1420;
  border-radius:8px;
  overflow:hidden
}
.skeleton::after{
  content:"";
  position:absolute;inset:0;
  background:linear-gradient(90deg, rgba(255,255,255,0), rgba(255,255,255,.06), rgba(255,255,255,0));
  transform:translateX(-100%);
  animation:wb-shimmer 1.2s infinite
}
@keyframes wb-shimmer{to{transform:translateX(100%)}}

/* Skeleton helpers: lines and cards */
.sk-line{height:14px;border-radius:6px;background:#0e1420}
.sk-line.lg{height:18px}
.sk-line.sm{height:10px}
.sk-card{border:1px solid var(--stroke);border-radius:12px;padding:12px;background:#0e1420}
.sk-gap{height:8px}

/* --- Button loading spinner --- */
.btn.loading{position:relative;pointer-events:none;opacity:.8}
.btn.loading::after{
  content:"";
  position:absolute;right:10px;top:50%;transform:translateY(-50%);
  width:16px;height:16px;border:2px solid rgba(255,255,255,.35);border-top-color:#fff;border-radius:50%;
  animation:wb-spin .8s linear infinite
}
@keyframes wb-spin{to{transform:translateY(-50%) rotate(360deg)}}
