/*
 * ============================================================
 *  KWMS v2 — base.css
 *  Styles communs à TOUTES les pages (mobile + desktop).
 *  Chargé par templates/base/base.html, après tokens.css.
 *  Contient : reset, body, accessibilité, bandeau offline,
 *  bouton d'installation PWA + modal iOS, utilitaires.
 * ============================================================ */

/* ================================================================
   RESET
================================================================ */
*, *::before, *::after { box-sizing: border-box; }

html {
  -webkit-text-size-adjust: 100%;
  text-size-adjust: 100%;
}

body {
  margin: 0;
  padding: 0;
  min-height: 100vh;
  font-family: var(--font-family);
  font-size: var(--text-base);
  line-height: var(--leading-normal);
  color: var(--color-text);
  background: var(--color-surface);
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  overscroll-behavior-y: none;
  text-rendering: optimizeLegibility;
}

h1, h2, h3, h4, h5, h6, p, figure { margin: 0; }

a { color: var(--color-primary); text-decoration: none; }

button {
  font-family: inherit;
  -webkit-appearance: none;
  appearance: none;
}

img, svg { display: block; max-width: 100%; }

/* Sélection */
::selection { background: var(--color-primary-light); color: var(--color-primary-darker); }

/* ================================================================
   ACCESSIBILITÉ — focus visible cohérent
================================================================ */
:focus-visible {
  outline: none;
  box-shadow: var(--shadow-focus);
  border-radius: var(--radius-sm);
}

.visually-hidden {
  position: absolute !important;
  width: 1px; height: 1px;
  padding: 0; margin: -1px;
  overflow: hidden; clip: rect(0 0 0 0);
  white-space: nowrap; border: 0;
}

@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after {
    animation-duration: 0.01ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: 0.01ms !important;
  }
}

/* ================================================================
   BANDEAU OFFLINE GLOBAL
   Affiché par connectivity.js quand la connexion est perdue.
================================================================ */
.offline-banner {
  position: fixed;
  top: 0; left: 0; right: 0;
  z-index: var(--z-toast);
  display: none;
  align-items: center;
  justify-content: center;
  gap: var(--space-2);
  padding: var(--space-2) var(--space-4);
  background: var(--color-warning);
  color: #fff;
  font-size: var(--text-sm);
  font-weight: var(--font-semibold);
  direction: rtl;
  box-shadow: var(--shadow-md);
}

body.is-offline .offline-banner { display: flex; }

.offline-banner svg { width: 16px; height: 16px; flex-shrink: 0; }

@keyframes kwms-slide-down {
  from { transform: translateY(-100%); }
  to   { transform: translateY(0); }
}
body.is-offline .offline-banner { animation: kwms-slide-down var(--transition-base); }

/* Décale légèrement le contenu quand offline (les layouts gèrent le détail) */
body.is-offline { --offline-banner-height: 34px; }

/* ================================================================
   BOUTON D'INSTALLATION PWA
================================================================ */
.pwa-install-btn {
  position: fixed;
  bottom: calc(var(--nav-height) + var(--space-4));
  inset-inline-start: var(--space-4);
  z-index: var(--z-overlay);
  display: none;
  align-items: center;
  gap: var(--space-2);
  padding: var(--space-3) var(--space-5);
  background: var(--color-primary);
  color: var(--color-text-on-primary);
  border: none;
  border-radius: var(--radius-full);
  font-size: var(--text-sm);
  font-weight: var(--font-bold);
  cursor: pointer;
  box-shadow: var(--shadow-lg);
  transition: transform var(--transition-fast), background var(--transition-fast);
}
.pwa-install-btn.is-visible { display: inline-flex; }
.pwa-install-btn:hover { background: var(--color-primary-dark); transform: translateY(-2px); }
.pwa-install-btn:active { transform: translateY(0); }
.pwa-install-btn svg { width: 18px; height: 18px; }

/* ================================================================
   MODAL iOS — instructions « Sur l'écran d'accueil »
================================================================ */
.pwa-ios-modal {
  position: fixed;
  inset: 0;
  z-index: var(--z-modal);
  display: none;
  align-items: center;
  justify-content: center;
  padding: var(--space-4);
}
.pwa-ios-modal.is-open { display: flex; }

.pwa-ios-modal__overlay {
  position: absolute;
  inset: 0;
  background: var(--color-overlay);
  backdrop-filter: blur(2px);
}

.pwa-ios-modal__box {
  position: relative;
  width: 100%;
  max-width: 360px;
  background: var(--color-white);
  border-radius: var(--radius-2xl);
  padding: var(--space-8) var(--space-6) var(--space-6);
  text-align: center;
  box-shadow: var(--shadow-2xl);
}

.pwa-ios-modal__close {
  position: absolute;
  top: var(--space-3);
  inset-inline-end: var(--space-3);
  width: 32px; height: 32px;
  border: none;
  background: var(--color-surface);
  border-radius: var(--radius-full);
  color: var(--color-text-secondary);
  font-size: var(--text-lg);
  line-height: 1;
  cursor: pointer;
}
.pwa-ios-modal__close:hover { background: var(--color-border); }

.pwa-ios-modal__icon {
  width: 56px; height: 56px;
  margin: 0 auto var(--space-4);
  display: flex; align-items: center; justify-content: center;
  background: var(--color-primary-light);
  color: var(--color-primary);
  border-radius: var(--radius-xl);
}
.pwa-ios-modal__icon svg { width: 28px; height: 28px; }

.pwa-ios-modal__title {
  font-size: var(--text-xl);
  font-weight: var(--font-bold);
  color: var(--color-text);
  margin-bottom: var(--space-2);
}

.pwa-ios-modal__text {
  font-size: var(--text-sm);
  color: var(--color-text-secondary);
  line-height: var(--leading-relaxed);
}
.pwa-ios-modal__text strong { color: var(--color-text); }

/* ================================================================
   UTILITAIRES PARTAGÉS
================================================================ */
.kwms-store-icon,
.kwms-logo-icon { display: flex; align-items: center; }
