/* Look « iOS » (style app Réglages) : fond gris groupé, cartes/listes encadrées
   arrondies, en-têtes de section en petites majuscules, bouton plein arrondi.

   Chargé par info.html (page autonome, body.ios-page) ET par index.html, où la
   modale d'information réutilise le même balisage #info-content (classes ios-*
   communes). Les règles scopées body.ios-page ne touchent que la page autonome ;
   le bloc #infoModal (en bas) habille la « coque » de la modale du sommaire. */

:root {
    --ios-bg: #f2f2f7; /* systemGroupedBackground */
    --ios-card: #ffffff; /* secondarySystemGroupedBackground */
    --ios-label: #1c1c1e; /* label */
    --ios-secondary: rgba(60, 60, 67, .6); /* secondaryLabel */
    --ios-separator: rgba(60, 60, 67, .29); /* separator (hairline) */
    --ios-tint: #007aff; /* systemBlue */
    --ios-radius: 12px;
}

body.ios-page {
    background-color: var(--ios-bg);
    color: var(--ios-label);
    font-family: -apple-system, BlinkMacSystemFont, "SF Pro Text",
    "Helvetica Neue", Helvetica, Arial, sans-serif;
    -webkit-font-smoothing: antialiased;
    padding-bottom: env(safe-area-inset-bottom);
}

/* Grand titre façon iOS (« Large Title »). */
body.ios-page h1 {
    font-size: 2.125rem; /* ~34 px */
    font-weight: 700;
    letter-spacing: -0.02em;
    margin-bottom: 1.25rem;
}

/* Liens en bleu système (hors bouton) — page autonome ET modale du sommaire. */
body.ios-page a:not(.btn),
#infoModal .modal-body a:not(.btn) {
    color: var(--ios-tint);
    text-decoration: none;
}

/* Carte d'introduction. */
.ios-intro {
    background: var(--ios-card);
    border-radius: var(--ios-radius);
    padding: 1rem 1.125rem;
    line-height: 1.45;
}

.ios-intro img {
    vertical-align: middle;
    border-radius: 6px;
}

/* En-tête de groupe (« Réglages » : petites majuscules grises, en retrait). */
.ios-group-header {
    font-size: 0.8125rem !important; /* ~13 px */
    font-weight: 400 !important;
    text-transform: uppercase;
    letter-spacing: 0.02em;
    color: var(--ios-secondary);
    margin: 1.5rem 0 0.5rem !important;
    padding: 0 1.125rem;
}

/* Liste groupée encadrée (cellules à séparateurs en hairline). */
.ios-list {
    list-style: none;
    margin: 0 !important;
    padding: 0;
    background: var(--ios-card);
    border-radius: var(--ios-radius);
}

.ios-list > li {
    position: relative;
    padding: 0.7rem 1.125rem;
    line-height: 1.4;
}

/* Séparateur fin, en retrait à gauche, entre les cellules (jamais en bordure). */
.ios-list > li + li::before {
    content: "";
    position: absolute;
    top: 0;
    left: 1.125rem;
    right: 0;
    border-top: 0.5px solid var(--ios-separator);
}

/* Sous-liste (ex. actions de « Créer ma page »). */
.ios-sublist {
    list-style: none;
    margin: 0.4rem 0 0;
    padding: 0;
}

.ios-sublist > li {
    padding: 0.3rem 0;
}

/* Note d'avertissement : encart ambre doux et arrondi. */
.ios-note {
    border: 0 !important;
    border-radius: var(--ios-radius) !important;
    background: rgba(255, 204, 0, 0.18) !important; /* systemYellow ~18% : remplissage translucide façon iOS */
    color: #7a5b00 !important;
    padding: 0.875rem 1.125rem !important;
    margin-top: 1.5rem !important;
    line-height: 1.4;
}

.ios-note .bi {
    color: #ff9500; /* systemOrange */
}

/* Pied de page : version + contact, en petit gris centré (façon écran « À propos »
   d'iOS). Présent dans #info-content : apparaît donc en bas de la page ET de la modale. */
.ios-footer {
    margin-top: 1.5rem;
    text-align: center;
    font-size: 0.8125rem; /* ~13 px */
    line-height: 1.6;
    color: var(--ios-secondary);
}

/* Bouton « Retour à l'accueil » : plein bleu, pleine largeur, gros et arrondi
   (mobile-first, large zone tactile). */
body.ios-page .btn.btn-outline-secondary {
    display: block;
    width: 100%;
    margin-top: 2rem !important;
    padding: 0.85rem 1rem;
    border: 0;
    border-radius: var(--ios-radius);
    background: var(--ios-tint);
    color: #fff;
    font-weight: 600;
    font-size: 1.0625rem;
}

body.ios-page .btn.btn-outline-secondary:active {
    background: #0062cc;
}

/* --- Modale d'information du sommaire (index.html) --- */
/* index.html charge aussi info.css et injecte le balisage #info-content (qui porte
   déjà les classes ios-* communes : cartes, listes groupées, en-têtes, note). Il
   reste à habiller la « coque » de la modale : fond gris groupé derrière les cartes
   blanches + barre de titre épurée, pour le même rendu que la page autonome. */
#infoModal .modal-content {
    background-color: var(--ios-bg);
    border: 0;
    border-radius: 16px;
}

#infoModal .modal-header {
    background-color: var(--ios-bg);
    border-bottom: 0;
}

#infoModal .modal-title {
    font-style: normal !important; /* annule le fst-italic (!important) du balisage */
    font-weight: 700;
    color: var(--ios-label);
}

#infoModal .modal-body {
    background-color: var(--ios-bg);
    color: var(--ios-label);
    font-family: -apple-system, BlinkMacSystemFont, "SF Pro Text",
    "Helvetica Neue", Helvetica, Arial, sans-serif;
    -webkit-font-smoothing: antialiased;
}

/* --- Sommaire / page d'accueil (index.html, body.ios-home) --- */
/* Même univers iOS : fond gris groupé, cartes blanches arrondies sans ombre,
   typographie système. On réhabille seulement les .card existantes — SortableJS
   continue de réordonner #regions, et le balisage reste inchangé (juste body.ios-home). */
body.ios-home {
    background-color: var(--ios-bg);
    color: var(--ios-label);
    font-family: -apple-system, BlinkMacSystemFont, "SF Pro Text",
    "Helvetica Neue", Helvetica, Arial, sans-serif;
    -webkit-font-smoothing: antialiased;
    padding-bottom: env(safe-area-inset-bottom);
}

/* Titre façon iOS : grand, gras, foncé. */
body.ios-home h4 {
    font-size: 1.75rem;
    font-weight: 700;
    letter-spacing: -0.02em;
    color: var(--ios-label);
    padding-top: 0.5rem;
}

/* Icône d'information de l'en-tête en bleu système. */
body.ios-home h4 a {
    color: var(--ios-tint);
}

/* Cartes du sommaire : cellules blanches arrondies, sans l'ombre Bootstrap,
   avec une hauteur tactile confortable. */
body.ios-home .card {
    border: 0;
    border-radius: var(--ios-radius);
    box-shadow: none !important; /* annule .shadow (!important de Bootstrap) */
    background: var(--ios-card);
    min-height: 56px;
}

/* Libellés des cartes en couleur « label » iOS (et non le gris secondaire).
   Cible les libellés (.fw-bold) sans toucher à la poignée de tri (gris discret). */
body.ios-home .card .fw-bold {
    color: var(--ios-label) !important;
}

/* Retour visuel au toucher : la cellule se grise légèrement. */
body.ios-home .card:active {
    background: #e9e9ec;
}

/* Chevron de navigation (« disclosure indicator ») à droite de chaque carte.
   Tracé en CSS (deux bordures d'un carré pivoté à 45°) : aucune dépendance à la
   police d'icônes, et positionné en absolu => n'affecte ni la mise en page centrée
   des cartes ni le glisser-déposer (SortableJS). */
body.ios-home .card {
    position: relative;
}

body.ios-home .card::after {
    content: "";
    position: absolute;
    right: 1rem;
    top: 50%;
    width: 0.5rem;
    height: 0.5rem;
    border-top: 2px solid rgba(60, 60, 67, .3); /* gris tertiaire iOS */
    border-right: 2px solid rgba(60, 60, 67, .3);
    transform: translateY(-50%) rotate(45deg);
    pointer-events: none; /* le clic passe à la carte/lien */
}

/* Toute la carte cliquable, pas seulement le libellé. */
/* Cartes fixes (Autour de moi / Créer ma page) : le lien enveloppe déjà la carte ;
   on le passe en bloc pour que sa zone cliquable en épouse exactement les contours. */
body.ios-home .container > a {
    display: block;
}

/* Cartes de zones : le lien du libellé ne couvrait que sa ligne de texte (la
   min-height de 56px laissait des bandes haut/bas mortes). On le fait remplir toute
   la cellule ; la poignée de tri reste le seul élément non-navigant (pour le glisser). */
body.ios-home #regions .card {
    padding-top: 0 !important;
    padding-bottom: 0 !important;
}

body.ios-home #regions .card > a {
    align-self: stretch; /* remplit la hauteur de la cellule */
    display: flex; /* recentre le libellé (avec le pe-5 d'origine) */
    align-items: center;
    justify-content: center;
}

/* --- Pages de balises (luchon.html & co, body.ios-balises) --- */
/* Même univers iOS : fond gris groupé, barre d'onglets façon « segmented control »,
   chaque balise dans une carte blanche arrondie. La barre #balisesTabs est injectée
   par app.js : on l'habille uniquement en CSS (aucune modif de app.js, partagée par
   toutes les pages de balises). Ajouter body.ios-balises à une autre page suffit. */
body.ios-balises {
    background-color: var(--ios-bg);
    color: var(--ios-label);
    font-family: -apple-system, BlinkMacSystemFont, "SF Pro Text",
    "Helvetica Neue", Helvetica, Arial, sans-serif;
    -webkit-font-smoothing: antialiased;
}

/* Actions Accueil / Rafraîchir : icônes bleu système, sans fond. */
body.ios-balises #balisesTabs .nav-link:not([data-bs-toggle]) {
    color: var(--ios-tint);
    background: transparent;
}

/* Onglets Déco / Atterro façon segments : inactif gris transparent,
   actif = petite carte blanche surélevée. */
body.ios-balises #balisesTabs [data-bs-toggle="tab"] {
    color: var(--ios-secondary);
    background: transparent;
    border-radius: 8px;
    margin: 0 4px;
    padding: 0.4rem 0.5rem;
}

body.ios-balises #balisesTabs [data-bs-toggle="tab"].active {
    color: var(--ios-label);
    background: var(--ios-card);
    box-shadow: 0 1px 4px rgba(0, 0, 0, .12);
}

body.ios-balises #balisesTabs [data-bs-toggle="tab"].disabled {
    color: #c7c7cc;
    background: transparent;
    box-shadow: none;
}

/* Chaque balise dans une carte blanche arrondie « inset » (au lieu du trait
   séparateur d'origine border-bottom/rounded-0). Cible aussi les cartes générées
   par mes-balises.js (hors .tab-pane). */
body.ios-balises .card {
    border: 0 !important; /* annule border-0/border-bottom */
    border-radius: var(--ios-radius) !important; /* annule rounded-0 */
    background: var(--ios-card);
    margin: 0.625rem 1rem !important; /* annule mx-2 + espacement vertical */
    overflow: hidden; /* coins nets autour du widget */
}

/* --- Pages « secondaires » : around.html, creer.html, mes-balises.html --- */
/* Surface iOS commune (mes-balises l'obtient déjà via body.ios-balises). */
body.ios-surface,
body.ios-creer {
    background-color: var(--ios-bg);
    color: var(--ios-label);
    font-family: -apple-system, BlinkMacSystemFont, "SF Pro Text",
    "Helvetica Neue", Helvetica, Arial, sans-serif;
    -webkit-font-smoothing: antialiased;
}

/* Barre de titre commune (flèche Accueil + titre + actions) façon « navigation bar » iOS :
   icônes d'action en bleu système, titre foncé et gras. Classe .ios-topbar posée sur la
   première ligne d'en-tête de chaque page. */
.ios-topbar a,
.ios-topbar .btn-link {
    color: var(--ios-tint) !important; /* annule text-secondary */
}

.ios-topbar h1 {
    color: var(--ios-label) !important;
    font-weight: 700;
}

/* Boutons d'action principaux (« Voir ma page », « Créer ma page ») façon iOS. */
body.ios-creer .btn-primary,
body.ios-balises .btn-primary {
    border: 0;
    border-radius: 10px;
    background: var(--ios-tint);
    font-weight: 600;
}

/* creer.html : champs de recherche/filtre façon iOS (arrondis, sans bordure dure). */
body.ios-creer .form-control,
body.ios-creer .form-select {
    border: 0;
    border-radius: 10px;
    background-color: var(--ios-card); /* pas « background » : préserve la flèche du select */
}

/* Pied de page épinglé en bas : la colonne flex doit avoir une hauteur DÉFINIE (pas
   seulement min-height, qui n'est qu'un plancher). Sans cela, le conteneur grandit avec
   la liste et c'est toute la page qui défile, emportant le pied de page hors de l'écran. */
body.ios-creer .container {
    height: 100vh; /* repli pour les navigateurs sans dvh */
}

/* dvh : suit la zone réellement visible sur mobile (barre d'adresse dynamique).
   Dans un @supports séparé pour ne pas redéclarer height (avertissement IDE). */
@supports (height: 100dvh) {
    body.ios-creer .container {
        height: 100dvh;
    }
}

/* creer.html : la liste filtrable devient un panneau blanc arrondi (liste groupée).
   Couplée à la hauteur définie ci-dessus, min-height:0 (qui lève le blocage flexbox
   min-height:auto par défaut) lui permet de défiler EN INTERNE : le pied de page
   « x sélectionnée(s) + Voir ma page » reste épinglé en bas, en-tête + filtres visibles. */
body.ios-creer #balise-list {
    background: var(--ios-card);
    border-radius: var(--ios-radius);
    margin: 0 0.5rem 0.5rem;
    min-height: 0;
}

body.ios-creer .list-group-item {
    background: transparent;
    border-color: var(--ios-separator);
}
