
body {
  background: #f6f7fb;
}
.stat-card {
  border: 0;
  box-shadow: 0 6px 16px rgba(0,0,0,.06);
}
.stat-label {
  color: #6c757d;
  font-size: .9rem;
}
.stat-value {
  font-size: 1.8rem;
  font-weight: 700;
}
.card {
  border: 0;
  box-shadow: 0 6px 16px rgba(0,0,0,.06);
}
.table td, .table th {
  white-space: nowrap;
}

.table td, .table th { vertical-align: middle; }
.card-header { font-weight: 600; }

.main-navbar { margin-bottom: 0 !important; }
.subnav { background:#fff; border-bottom:1px solid #e6e8ef; padding:10px 0; margin-bottom: 1rem; }
.subnav-link { text-decoration:none; color:#3d4657; background:#f1f3f8; padding:8px 12px; border-radius:999px; font-size:.92rem; }
.subnav-link:hover { background:#e4e8f2; color:#111827; }
.navbar .nav-link.active { color:#fff !important; font-weight:600; }
.section-hero { border-radius:18px; padding:24px; background:linear-gradient(135deg,#111827,#2b3445); color:#fff; box-shadow:0 10px 22px rgba(0,0,0,.12); }
.quick-card { text-decoration:none; color:inherit; display:block; height:100%; }
.quick-card .card { transition:.15s transform,.15s box-shadow; }
.quick-card:hover .card { transform:translateY(-2px); box-shadow:0 12px 28px rgba(0,0,0,.10); }
.client-page { max-width:1180px; margin:0 auto; }
.client-hero { border-radius:22px; background:linear-gradient(135deg,#151923,#3c2b52); color:#fff; padding:38px; }
.client-card { border-radius:18px; }

/* Club visual calendar */
.club-calendar-card { overflow:hidden; }
.club-calendar { min-width: 980px; background:#fff; }
.club-calendar th { position: sticky; top: 0; background:#f8fafc; z-index: 2; text-align:center; font-size:.9rem; }
.club-calendar .time-col { width: 86px; }
.calendar-time { background:#f8fafc; color:#64748b; font-weight:600; text-align:center; width:86px; }
.calendar-cell { width: 230px; height: 58px; padding: 5px !important; vertical-align: top; background:#fff; }
.calendar-cell:hover { background:#fbfdff; }
.empty-slot { display:flex; align-items:center; justify-content:center; width:100%; min-height:44px; border:1px dashed #cbd5e1; border-radius:10px; color:#94a3b8; text-decoration:none; font-weight:700; font-size:1.1rem; }
.empty-slot:hover { border-color:#111827; color:#111827; background:#f8fafc; }
.booking-chip { display:block; padding:6px 8px; border-radius:10px; text-decoration:none; margin-bottom:4px; border:1px solid transparent; line-height:1.15; }
.booking-chip:hover { filter:brightness(.98); transform:translateY(-1px); }
.booking-time { display:block; font-size:.75rem; font-weight:700; opacity:.85; }
.booking-name { display:block; font-size:.85rem; font-weight:700; white-space:normal; }
.booking-phone { display:block; font-size:.72rem; opacity:.8; }
.booking-active { background:#e8f7ef; color:#0f5132; border-color:#badbcc; }
.booking-pending { background:#fff3cd; color:#664d03; border-color:#ffecb5; }
.booking-cancelled { background:#f8d7da; color:#842029; border-color:#f5c2c7; text-decoration:line-through; }
.booking-neutral { background:#eef2ff; color:#3730a3; border-color:#c7d2fe; }
.calendar-legend { display:flex; flex-wrap:wrap; gap:8px; }
.legend-pill { display:inline-flex; align-items:center; padding:7px 11px; border-radius:999px; font-size:.85rem; font-weight:600; }
.legend-active { background:#e8f7ef; color:#0f5132; }
.legend-pending { background:#fff3cd; color:#664d03; }
.legend-cancelled { background:#f8d7da; color:#842029; }
.legend-empty { background:#f1f5f9; color:#475569; }


/* === SNP CRM v39 theme: purple / orange / black === */
:root {
  --snp-black: #09070f;
  --snp-black-2: #11101a;
  --snp-panel: #181622;
  --snp-panel-soft: #211d2f;
  --snp-purple: #7c3aed;
  --snp-purple-2: #a855f7;
  --snp-orange: #ff8a00;
  --snp-orange-2: #ffb347;
  --snp-text: #f8f5ff;
  --snp-muted: #9ca3af;
  --snp-border: rgba(168, 85, 247, .22);
}
body { background: #f7f4fb; color:#171322; }
.main-navbar.navbar { background: linear-gradient(90deg, #09070f 0%, #171022 54%, #2a1207 100%) !important; border-bottom:1px solid rgba(255,138,0,.22); box-shadow:0 8px 28px rgba(9,7,15,.18); }
.navbar-brand { letter-spacing:.02em; }
.navbar .nav-link { color:rgba(255,255,255,.74)!important; border-radius:999px; padding:.45rem .72rem!important; margin:0 .05rem; }
.navbar .nav-link:hover { color:#fff!important; background:rgba(124,58,237,.18); }
.navbar .nav-link.active { color:#fff!important; background:linear-gradient(135deg, var(--snp-purple), #5b21b6); box-shadow:0 0 0 1px rgba(255,255,255,.08) inset; }
.subnav { background:#fff; border-bottom:1px solid rgba(124,58,237,.12); box-shadow:0 4px 16px rgba(17,16,26,.04); }
.subnav-link { color:#33254a; background:#f3ecff; border:1px solid rgba(124,58,237,.12); font-weight:600; }
.subnav-link:hover { color:#fff; background:linear-gradient(135deg,var(--snp-purple),var(--snp-orange)); border-color:transparent; }
.card, .stat-card { border:1px solid rgba(124,58,237,.08); border-radius:18px; box-shadow:0 10px 28px rgba(30, 15, 55, .07); }
.card-header { background:#fbf8ff; border-bottom:1px solid rgba(124,58,237,.10); }
.table-hover tbody tr:hover { background:#fbf5ff; }
.form-control:focus, .form-select:focus { border-color:var(--snp-purple); box-shadow:0 0 0 .22rem rgba(124,58,237,.16); }
.btn { border-radius:12px; font-weight:700; }
.btn-dark, .btn-primary { background:linear-gradient(135deg, var(--snp-purple), #5b21b6)!important; border-color:transparent!important; color:#fff!important; box-shadow:0 8px 18px rgba(124,58,237,.20); }
.btn-dark:hover, .btn-primary:hover { background:linear-gradient(135deg, #6d28d9, var(--snp-orange))!important; transform:translateY(-1px); }
.btn-outline-dark, .btn-outline-primary, .btn-outline-secondary { border-color:rgba(124,58,237,.35)!important; color:#5b21b6!important; background:#fff; }
.btn-outline-dark:hover, .btn-outline-primary:hover, .btn-outline-secondary:hover { background:linear-gradient(135deg, var(--snp-purple), #5b21b6)!important; color:#fff!important; border-color:transparent!important; }
.btn-outline-warning, .btn-warning { border-color:var(--snp-orange)!important; color:#fff!important; background:linear-gradient(135deg, var(--snp-orange), #f97316)!important; }
.btn-outline-light:hover { color:#111!important; }
.badge.text-bg-secondary { background:rgba(255,138,0,.18)!important; color:#ffd7a3!important; border:1px solid rgba(255,138,0,.25); }
.section-hero { background:radial-gradient(circle at 16% 10%, rgba(124,58,237,.5), transparent 30%), radial-gradient(circle at 88% 20%, rgba(255,138,0,.4), transparent 28%), linear-gradient(135deg,#09070f,#1b1029 58%,#271006); }
.empty-slot:hover { border-color:var(--snp-purple); color:var(--snp-purple); background:#fbf5ff; }
.booking-active { background:#f1eaff; color:#4c1d95; border-color:#ddd0ff; }
.booking-pending { background:#fff3e0; color:#7c2d12; border-color:#fed7aa; }
.booking-neutral { background:#f4e8ff; color:#581c87; border-color:#e9d5ff; }
.legend-active { background:#f1eaff; color:#4c1d95; }
.legend-pending { background:#fff3e0; color:#7c2d12; }
@media(max-width: 768px){
  .navbar .nav-link { padding:.6rem .75rem!important; }
  main.container-fluid { padding-left:12px!important; padding-right:12px!important; }
  .card { border-radius:16px; }
}


.snp-public-navbar { background: linear-gradient(90deg,#09070f,#1b1029 65%,#2a1207)!important; border-bottom:1px solid rgba(255,138,0,.25)!important; }
.public-navbar .navbar-brand { color:#fff!important; }
.public-navbar .nav-link { color:rgba(255,255,255,.72)!important; font-weight:700; }
.public-navbar .nav-link:hover { color:#ffb347!important; }
.public-body .alert-success { background:#f3e8ff; color:#4c1d95; border-color:#d8b4fe; }
.public-body .alert-danger, .public-body .alert-warning { background:#fff7ed; color:#7c2d12; border-color:#fed7aa; }


/* === SNP CRM MOBILE RESPONSIVE LAYER ===
   Цель: удобно пользоваться CRM и публичным сайтом с телефона.
   Логика приложения не меняется, только адаптивность интерфейса. */
:root {
  --mobile-safe-x: 12px;
}

/* Базовая защита от горизонтального развала */
html, body {
  max-width: 100%;
  overflow-x: hidden;
}
img, svg, video, canvas {
  max-width: 100%;
  height: auto;
}
textarea {
  min-height: 96px;
}

/* Навигация сотрудников */
.main-navbar .navbar-toggler,
.public-navbar .navbar-toggler {
  border-radius: 12px;
  border-color: rgba(255,255,255,.25);
}
.main-navbar .navbar-collapse,
.public-navbar .navbar-collapse {
  padding-top: .7rem;
}
.main-navbar .navbar-nav,
.public-navbar .navbar-nav {
  gap: 4px;
}
.subnav {
  position: sticky;
  top: 0;
  z-index: 1010;
}
.subnav > .container-fluid {
  overflow-x: auto;
  flex-wrap: nowrap !important;
  -webkit-overflow-scrolling: touch;
  scrollbar-width: none;
}
.subnav > .container-fluid::-webkit-scrollbar {
  display: none;
}
.subnav-link {
  white-space: nowrap;
  flex: 0 0 auto;
}

/* Таблицы: на телефоне горизонтальная прокрутка вместо сломанной верстки */
.table-responsive {
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
}
.table {
  margin-bottom: 0;
}
.table td,
.table th {
  vertical-align: middle;
}
.table td .btn,
.table th .btn {
  white-space: nowrap;
}

/* Универсальные элементы */
.card {
  overflow: hidden;
}
.card-body {
  min-width: 0;
}
.btn,
.form-control,
.form-select {
  min-height: 42px;
}
.btn-sm {
  min-height: 34px;
}
.form-control[type="datetime-local"],
.form-control[type="date"],
.form-control[type="time"] {
  min-width: 0;
}
.input-group {
  min-width: 0;
}
.d-flex {
  min-width: 0;
}

/* Мобильный public-сайт */
.public-body {
  overflow-x: hidden;
}
.lux-wrap,
.lux-page-hero,
.lux-card,
.lux-form,
.club-widget,
.client-hero {
  max-width: 100%;
}
.lux-title {
  overflow-wrap: anywhere;
}
.lux-links {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}
.lux-links a {
  margin: 0 !important;
}
.direction-grid,
.cert-grid,
.store-grid,
.mini-grid {
  min-width: 0;
}
.lux-btn {
  text-align: center;
}

/* Карточка клиента */
.client2-layout,
.client2-grid,
.client2-two {
  min-width: 0;
}
.client2-main,
.client2-section,
.client2-card {
  min-width: 0;
}
.client2-section {
  scroll-margin-top: 110px;
}

/* Календарь клуба */
.club-calendar-card,
.calendar-scroll,
.calendar-table-wrap {
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
}
.club-calendar {
  min-width: 980px;
}
.calendar-control-panel {
  max-width: 100%;
}
.calendar-day-switcher,
.calendar-actions,
.calendar-filter-row {
  min-width: 0;
}

/* Школьное расписание */
.week-board {
  max-width: 100%;
  -webkit-overflow-scrolling: touch;
}
.student-panel {
  min-width: 0;
}

/* Активная сессия */
.product-card-wrap {
  min-width: 0;
}
.product-card {
  touch-action: manipulation;
}
#cartList,
#productResults {
  min-width: 0;
}

/* Боковые drawer/modal окна */
.drawer,
.payment-modal {
  max-width: 100vw;
}

/* Большие экраны */
@media (min-width: 992px) {
  .main-navbar .navbar-collapse,
  .public-navbar .navbar-collapse {
    padding-top: 0;
  }
}

/* Планшет */
@media (max-width: 991.98px) {
  .main-navbar .navbar-collapse {
    max-height: calc(100vh - 72px);
    overflow-y: auto;
  }
  .main-navbar .navbar-nav {
    padding: 8px 0;
  }
  .main-navbar .nav-link {
    width: 100%;
    margin: 2px 0 !important;
  }
  .main-navbar .d-flex.gap-2,
  .public-navbar .d-flex.gap-2 {
    flex-wrap: wrap;
    align-items: stretch !important;
  }
  .main-navbar .d-flex.gap-2 .btn,
  .public-navbar .d-flex.gap-2 .btn {
    flex: 1 1 auto;
  }

  .booking-admin-layout,
  .board-layout,
  .client2-layout {
    grid-template-columns: 1fr !important;
  }
  .booking-summary-card,
  .student-panel,
  .client2-side {
    position: static !important;
  }

  .calendar-main-row,
  .calendar-date-nav,
  .calendar-actions,
  .calendar-filter-row {
    align-items: stretch !important;
  }
}

/* Телефон */
@media (max-width: 767.98px) {
  body {
    font-size: 15px;
  }
  main.container-fluid,
  .public-main .container {
    padding-left: var(--mobile-safe-x) !important;
    padding-right: var(--mobile-safe-x) !important;
    padding-top: 14px !important;
  }
  .container,
  .container-fluid {
    max-width: 100%;
  }

  h1, .h1 { font-size: 1.55rem !important; }
  h2, .h2 { font-size: 1.32rem !important; }
  h3, .h3 { font-size: 1.16rem !important; }

  .card,
  .booking-section-card,
  .booking-summary-card,
  .board-hero,
  .student-panel,
  .week-board,
  .client2-section,
  .client2-hero,
  .lux-card,
  .lux-form,
  .lux-page-hero,
  .club-widget,
  .client-hero {
    border-radius: 18px !important;
  }

  .card-body,
  .card-header,
  .booking-section-body,
  .booking-section-head,
  .booking-summary-body,
  .booking-summary-top,
  .booking-summary-actions,
  .lux-card,
  .lux-form,
  .lux-page-hero,
  .client-hero {
    padding: 14px !important;
  }

  .subnav {
    margin-bottom: .65rem;
    padding: 8px 0;
  }
  .subnav > .container-fluid {
    padding-left: var(--mobile-safe-x) !important;
    padding-right: var(--mobile-safe-x) !important;
  }
  .subnav-link {
    padding: 9px 12px;
    font-size: .86rem;
  }

  .btn {
    width: auto;
  }
  .d-grid .btn,
  .booking-summary-actions .btn,
  .lux-btn,
  .direction-actions .btn,
  .direction-actions .lux-btn {
    width: 100%;
  }

  .row.g-3 {
    --bs-gutter-y: .75rem;
  }

  /* Таблицы читаются свайпом */
  .table-responsive {
    border-radius: 14px;
  }
  .table {
    min-width: 720px;
    font-size: .9rem;
  }
  .table.table-sm {
    min-width: 680px;
  }

  /* Формы */
  label.form-label {
    font-weight: 750;
  }
  .form-control,
  .form-select {
    font-size: 16px; /* iOS не зумит форму */
  }

  /* Public pages */
  .lux-nav {
    display: grid !important;
    grid-template-columns: 1fr;
    gap: 12px;
    padding: 14px 0 !important;
  }
  .lux-logo {
    font-size: 1rem;
  }
  .lux-links {
    display: flex !important;
    overflow-x: auto;
    flex-wrap: nowrap;
    -webkit-overflow-scrolling: touch;
    padding-bottom: 2px;
  }
  .lux-links a {
    flex: 0 0 auto;
    border: 1px solid rgba(255,255,255,.14);
    border-radius: 999px;
    padding: 8px 12px;
    background: rgba(255,255,255,.055);
  }
  .lux-title {
    font-size: clamp(2rem, 12vw, 3rem) !important;
    line-height: 1 !important;
    letter-spacing: -.055em !important;
  }
  .lux-sub {
    font-size: 1rem !important;
  }
  .lux-page-hero {
    padding: 20px !important;
  }
  .direction-grid,
  .cert-grid,
  .store-grid,
  .mini-grid {
    display: grid !important;
    grid-template-columns: 1fr !important;
    gap: 12px !important;
  }
  .direction-card,
  .cert-card {
    min-height: auto !important;
    border-radius: 22px !important;
    padding: 18px !important;
  }
  .request-type {
    grid-template-columns: 1fr !important;
    border-radius: 18px !important;
  }
  .request-type span {
    border-radius: 14px !important;
  }

  /* Public club map */
  .club-map-wrap {
    padding: 10px !important;
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
  }
  .club-map {
    min-width: 720px;
    height: 460px !important;
  }

  /* Manager calendar */
  .calendar-control-panel {
    padding: 12px !important;
  }
  .calendar-main-row,
  .calendar-date-nav,
  .calendar-day-switcher,
  .calendar-actions,
  .calendar-filter-row {
    display: grid !important;
    grid-template-columns: 1fr !important;
    gap: 8px !important;
  }
  .calendar-date-input,
  .calendar-day-switcher .btn,
  .calendar-actions .btn,
  .calendar-filter-pill {
    width: 100%;
  }
  .club-calendar {
    min-width: 920px;
  }
  .calendar-cell {
    width: 190px;
  }

  /* School board */
  .board-actions {
    display: grid !important;
    grid-template-columns: 1fr !important;
  }
  .week-board {
    padding: 10px !important;
  }
  .week-grid {
    min-width: 0 !important;
    display: flex !important;
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
    scroll-snap-type: x mandatory;
    gap: 10px !important;
  }
  .day-col {
    flex: 0 0 86vw;
    min-height: 460px !important;
    scroll-snap-align: start;
  }
  .student-panel {
    padding: 12px !important;
  }
  .drawer {
    width: 100vw !important;
  }

  /* Booking form */
  .booking-mode-choice {
    grid-template-columns: 1fr !important;
  }
  .booking-mode-card {
    min-height: auto !important;
  }
  .booking-admin-header {
    display: grid !important;
    grid-template-columns: 1fr !important;
  }

  /* Active session */
  #productResults {
    max-height: 520px;
    overflow-y: auto;
    padding-right: 2px;
  }
  .product-card {
    min-height: auto !important;
  }
  #cartList .cart-row,
  .cart-row {
    border-radius: 14px;
  }

  /* Client profile */
  .client2-side {
    overflow-x: auto;
    display: flex !important;
    gap: 8px;
    padding-bottom: 4px;
  }
  .client2-side a {
    flex: 0 0 auto;
    white-space: nowrap;
  }
}

/* Маленькие телефоны */
@media (max-width: 430px) {
  :root {
    --mobile-safe-x: 10px;
  }
  body {
    font-size: 14px;
  }
  .navbar-brand {
    font-size: 1rem;
  }
  .badge {
    white-space: normal;
  }
  .btn,
  .form-control,
  .form-select {
    min-height: 44px;
  }
  .table {
    font-size: .84rem;
  }
  .lux-title {
    font-size: 2rem !important;
  }
  .club-map {
    min-width: 640px;
  }
  .day-col {
    flex-basis: 90vw;
  }
  .display-4,
  .display-5,
  .display-6 {
    font-size: 1.65rem !important;
  }
}



/* Mobile patch for public home hero and generic action rows */
.lux-hero {
  max-width: 100%;
}
@media (max-width: 767.98px) {
  .lux-hero {
    padding: 20px !important;
    border-radius: 22px !important;
  }
  .booking-admin-header .btn,
  .d-flex.justify-content-between.align-items-center.mb-4.flex-wrap.gap-2 .btn,
  .d-flex.justify-content-between.align-items-start.mb-4.flex-wrap.gap-2 .btn {
    width: 100%;
  }
  .navbar .navbar-collapse .btn {
    width: 100%;
  }
  .public-navbar .navbar-collapse .btn {
    width: 100%;
  }
}


/* === SNP CRM PWA APP LAYER === */
@media (display-mode: standalone) {
  body.crm-body .main-navbar {
    padding-top: max(.5rem, env(safe-area-inset-top));
  }
  body.crm-body main.container-fluid,
  body.public-body .public-main .container {
    padding-bottom: max(24px, env(safe-area-inset-bottom));
  }
}
#pwaInstallBtn {
  border-color: rgba(255,255,255,.35)!important;
  background: rgba(255,255,255,.08)!important;
}
#pwaInstallBtn:not(.d-none) {
  display: inline-flex !important;
  align-items: center;
  justify-content: center;
}


/* === HOTFIX: visible mobile + calls + install === */
@media (max-width: 767.98px) {
  body.crm-body main.container-fluid {
    padding-left: 10px !important;
    padding-right: 10px !important;
  }
  .install-page .section-hero {
    padding: 16px !important;
  }
  .install-page .card-body {
    padding: 14px !important;
  }
  .install-page ol {
    padding-left: 1.1rem;
  }
  .install-page .btn {
    width: 100%;
  }
  .crm-body .navbar .btn {
    min-height: 40px;
  }
  .crm-body .subnav-link[href="/crm/calls"] {
    background: linear-gradient(135deg, #7c3aed, #ff8a00);
    color: #fff;
  }
}


/* === STORE MOBILE CATALOG PATCH ===
   Compact mobile navigation/buttons + marketplace-like product cards. */
@media (max-width: 767.98px) {
  .crm-body .subnav {
    padding: 6px 0 !important;
    margin-bottom: .55rem !important;
  }
  .crm-body .subnav > .container-fluid {
    flex-wrap: nowrap !important;
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
    gap: 6px !important;
    padding-bottom: 2px;
  }
  .crm-body .subnav-link {
    flex: 0 0 auto;
    white-space: nowrap;
    padding: 7px 10px !important;
    font-size: .82rem !important;
    line-height: 1.05;
    border-radius: 999px;
  }
  .store-products-page .btn {
    box-shadow: none;
  }
  .store-products-page .btn,
  .store-products-page .form-control,
  .store-products-page .form-select {
    min-height: 38px;
  }
  .store-products-page .table {
    min-width: 980px;
  }
}


/* === STORE MOBILE SALES/REPAIRS PATCH === */
@media (max-width: 767.98px) {
  .store-list-page .btn,
  .store-list-page .form-control,
  .store-list-page .form-select,
  .store-sale-form .btn,
  .store-sale-form .form-control,
  .store-sale-form .form-select {
    min-height: 38px;
  }
  .store-list-page .table {
    min-width: 880px;
  }
  .store-list-page .card {
    border-radius: 18px;
  }
}
