/* =========================================================
   IDD Tool Kit — design kit partagé pour les outils WeddingPart
   ----------------------------------------------------------
   Source de vérité visuelle extraite de idd-plan-de-table.
   Tokens consommés depuis themes/WeddingPart/assets/css/base.css
   (variables --wp-*).

   Classes exposées (toutes en .idd-tool-*) :

     .idd-tool                       wrapper racine d'un outil (reset + padding)
     .idd-tool-page-header           hero (eyebrow + titre + lead + KPIs)
       .idd-tool-page-header__intro
       .idd-tool-page-header__title
       .idd-tool-page-header__lead
     .idd-tool-eyebrow [--gold|--sage]
     .idd-tool-kpis                  grille de KPIs (2×2 desktop ou 4×1)
     .idd-tool-kpi [--brand|--gold|--sage|--neutral]
       .idd-tool-kpi__icon
       .idd-tool-kpi__body
       .idd-tool-kpi__label
       .idd-tool-kpi__value
     .idd-tool-layout                grid 320px + 1fr → 1 col @980px
     .idd-tool-sidebar               sticky, surface blanche, radius xl
       .idd-tool-sidebar-head
       .idd-tool-sidebar-title
       .idd-tool-sidebar-sub
       .idd-tool-sidebar-toggle
     .idd-tool-search                input pilule 40px + loupe + clear
     .idd-tool-search-clear
     .idd-tool-filters               container selects pilules
     .idd-tool-filter-select         select pilule (--active possible)
     .idd-tool-filters-reset         bouton reset dashed brand
     .idd-tool-counter               compteur ("X éléments à placer")
     .idd-tool-list                  conteneur scrollable
     .idd-tool-card [--draggable|--selected|--dragging]
     .idd-tool-badge [--brand|--gold|--sage|--neutral|--alert]
     .idd-tool-empty                 empty state visuel
       .idd-tool-empty__visual
       .idd-tool-empty__title
       .idd-tool-empty__lead
       .idd-tool-empty__actions
     .idd-tool-toolbar               toolbar horizontale d'actions
       .idd-tool-toolbar__group
       .idd-tool-toolbar__sep

   Mobile : collapse à 980px (sidebar → 1 col, plus de sticky)
            puis ajustements à 640px (header 1 col, paddings réduits).
   ========================================================= */


/* =========================================================
   Fallbacks pour tokens qui ne sont pas dans base.css
   (déclarés une seule fois — spécificité minimale)
   ========================================================= */
:where(:root){
  --wp-gold-soft: rgba(201,168,124,.10);
  --wp-sage-soft: rgba(122,157,128,.10);
}


/* =========================================================
   Wrapper racine
   ========================================================= */
.idd-tool{
  position: relative;
  padding: clamp(16px, 3vw, 32px) 0 calc(120px + env(safe-area-inset-bottom, 0));
  font-family: var(--font-sans);
  color: var(--wp-ink);
  background: transparent;
}

.idd-tool *,
.idd-tool *::before,
.idd-tool *::after{ box-sizing: border-box; }

@media print{
  .idd-tool .no-print{ display: none !important; }
}


/* =========================================================
   PAGE HEADER
   ========================================================= */
.idd-tool-page-header{
  display: grid;
  grid-template-columns: minmax(0, 1.4fr) minmax(0, 1fr);
  gap: clamp(18px, 3vw, 36px);
  align-items: end;
  padding: clamp(18px, 2.4vw, 28px) clamp(18px, 2.4vw, 32px);
  margin-bottom: clamp(16px, 2.4vw, 24px);
  background: var(--wp-surface);
  border: 1px solid var(--wp-line);
  border-radius: var(--radius-xl);
  box-shadow: var(--shadow-xs);
  overflow: hidden;
  position: relative;
}
.idd-tool-page-header::before{
  content: "";
  position: absolute;
  inset: 0 0 auto 0;
  height: 2px;
  background: linear-gradient(90deg, var(--wp-brand) 0%, var(--wp-gold) 60%, transparent 100%);
}

.idd-tool-page-header__intro{ min-width: 0; }

.idd-tool-page-header__title{
  margin: 12px 0 8px;
  font-family: var(--font-serif);
  font-weight: 500;
  font-size: clamp(1.6rem, 3vw, 2.4rem);
  line-height: 1.08;
  letter-spacing: -.005em;
  color: var(--wp-ink);
}
.idd-tool-page-header__title em{
  font-style: italic;
  color: var(--wp-brand);
  font-weight: 500;
}

.idd-tool-page-header__lead{
  margin: 0;
  max-width: 56ch;
  color: var(--wp-soft);
  font-size: .94rem;
  line-height: 1.55;
}


/* =========================================================
   EYEBROW (petite pilule majuscule)
   ========================================================= */
.idd-tool-eyebrow{
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 6px 14px;
  border-radius: var(--radius-full);
  background: var(--wp-brand-soft);
  color: var(--wp-brand-dark);
  font-family: var(--font-sans);
  font-size: .72rem;
  font-weight: 700;
  letter-spacing: .14em;
  text-transform: uppercase;
}
.idd-tool-eyebrow svg{ flex: 0 0 auto; color: var(--wp-brand); }
.idd-tool-eyebrow--gold{ background: var(--wp-gold-soft); color: var(--wp-gold-dark); }
.idd-tool-eyebrow--gold svg{ color: var(--wp-gold); }
.idd-tool-eyebrow--sage{ background: var(--wp-sage-soft); color: var(--wp-sage-dark); }
.idd-tool-eyebrow--sage svg{ color: var(--wp-sage); }


/* =========================================================
   KPIs (tuiles)
   ========================================================= */
.idd-tool-kpis{
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 10px;
  align-self: stretch;
}
.idd-tool-kpi{
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 10px 12px;
  background: var(--wp-bg);
  border: 1px solid var(--wp-line);
  border-radius: var(--radius-md);
  transition: border-color var(--duration) var(--ease),
              background var(--duration) var(--ease);
}
.idd-tool-kpi:hover{
  border-color: var(--wp-brand-border);
  background: var(--wp-surface);
}
.idd-tool-kpi__icon{
  flex: 0 0 auto;
  width: 32px;
  height: 32px;
  display: grid;
  place-items: center;
  border-radius: var(--radius-sm);
  background: var(--wp-brand-soft);
  color: var(--wp-brand);
}
.idd-tool-kpi__body{
  display: flex;
  flex-direction: column;
  min-width: 0;
}
.idd-tool-kpi__label{
  font-size: .68rem;
  font-weight: 600;
  letter-spacing: .08em;
  text-transform: uppercase;
  color: var(--wp-muted);
}
.idd-tool-kpi__value{
  font-family: var(--font-serif);
  font-size: 1.45rem;
  font-weight: 600;
  line-height: 1.05;
  color: var(--wp-ink);
}
.idd-tool-kpi--brand   .idd-tool-kpi__icon{ background: var(--wp-brand-soft); color: var(--wp-brand-dark); }
.idd-tool-kpi--sage    .idd-tool-kpi__icon{ background: var(--wp-sage-soft);  color: var(--wp-sage-dark);  }
.idd-tool-kpi--gold    .idd-tool-kpi__icon{ background: var(--wp-gold-soft);  color: var(--wp-gold-dark);  }
.idd-tool-kpi--neutral .idd-tool-kpi__icon{ background: var(--wp-surface-2);  color: var(--wp-soft); }


/* =========================================================
   LAYOUT (sidebar 320px + main 1fr → 1 col @980px)
   ========================================================= */
.idd-tool-layout{
  display: grid;
  grid-template-columns: minmax(0, 320px) minmax(0, 1fr);
  gap: 18px;
  align-items: start;
}
@media (max-width: 980px){
  .idd-tool-layout{ grid-template-columns: 1fr; }
}


/* =========================================================
   SIDEBAR
   ========================================================= */
.idd-tool-sidebar{
  position: sticky;
  top: calc(var(--header-h, 68px) + 12px);
  background: var(--wp-surface);
  border: 1px solid var(--wp-line);
  border-radius: var(--radius-xl);
  box-shadow: var(--shadow-sm);
  padding: 16px;
  display: flex;
  flex-direction: column;
  gap: 12px;
  max-height: calc(100vh - 100px);
  overflow: hidden;
}
@media (max-width: 980px){
  .idd-tool-sidebar{
    position: relative;
    top: 0;
    max-height: none;
  }
}

.idd-tool-sidebar.is-collapsed{
  max-height: 78px;
  overflow: hidden;
}
.idd-tool-sidebar.is-collapsed > *:not(.idd-tool-sidebar-head){
  display: none;
}
.idd-tool-sidebar.is-collapsed .idd-tool-sidebar-toggle svg{
  transform: rotate(180deg);
}

.idd-tool-sidebar-head{ position: relative; }
.idd-tool-sidebar-title{
  margin: 8px 0 4px;
  font-family: var(--font-serif);
  font-weight: 500;
  font-size: 1.2rem;
  color: var(--wp-ink);
}
.idd-tool-sidebar-sub{
  margin: 0;
  color: var(--wp-muted);
  font-size: .82rem;
  line-height: 1.5;
}

.idd-tool-sidebar-toggle{
  position: absolute;
  top: 0;
  right: 0;
  width: 30px; height: 30px;
  display: grid;
  place-items: center;
  border: 1px solid var(--wp-line);
  background: var(--wp-surface);
  color: var(--wp-soft);
  border-radius: var(--radius-full);
  cursor: pointer;
  transition: background var(--duration) var(--ease),
              color var(--duration) var(--ease),
              border-color var(--duration) var(--ease);
}
.idd-tool-sidebar-toggle:hover{
  background: var(--wp-brand-soft);
  color: var(--wp-brand-dark);
  border-color: var(--wp-brand-border);
}
.idd-tool-sidebar-toggle svg{
  transition: transform var(--duration) var(--ease);
}


/* =========================================================
   SEARCH (input pilule)
   ========================================================= */
.idd-tool-search{
  position: relative;
  display: flex;
  align-items: center;
  height: 40px;
  padding: 0 12px 0 38px;
  background: var(--wp-bg);
  border: 1px solid var(--wp-line);
  border-radius: var(--radius-full);
  transition: border-color var(--duration) var(--ease),
              box-shadow var(--duration) var(--ease),
              background var(--duration) var(--ease);
}
.idd-tool-search:focus-within{
  background: var(--wp-surface);
  border-color: var(--wp-brand);
  box-shadow: 0 0 0 4px var(--wp-brand-soft);
}
.idd-tool-search > svg{
  position: absolute;
  left: 14px;
  top: 50%;
  transform: translateY(-50%);
  color: var(--wp-muted);
  flex: 0 0 auto;
  pointer-events: none;
}
.idd-tool-search input{
  flex: 1 1 auto;
  min-width: 0;
  border: 0;
  background: transparent;
  font: inherit;
  font-size: .88rem;
  color: var(--wp-ink);
  padding: 0;
  outline: none;
}
.idd-tool-search input::placeholder{ color: var(--wp-muted); }
.idd-tool-search input::-webkit-search-cancel-button{ display: none; }

.idd-tool-search-clear{
  flex: 0 0 auto;
  width: 22px; height: 22px;
  display: grid;
  place-items: center;
  border: 0;
  background: var(--wp-surface-2);
  color: var(--wp-soft);
  border-radius: var(--radius-full);
  cursor: pointer;
  font-size: 14px;
  line-height: 1;
}
.idd-tool-search-clear[hidden]{ display: none !important; }
.idd-tool-search-clear:hover{
  background: var(--wp-brand-soft);
  color: var(--wp-brand-dark);
}


/* =========================================================
   FILTERS (selects pilules + reset)
   ========================================================= */
.idd-tool-filters{
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
}
.idd-tool-filter-select{
  appearance: none;
  -webkit-appearance: none;
  -moz-appearance: none;
  flex: 1 1 calc(50% - 3px);
  min-width: 0;
  height: 34px;
  padding: 0 32px 0 12px;
  background-color: var(--wp-surface);
  background-image:
    linear-gradient(45deg, transparent 50%, var(--wp-soft) 50%),
    linear-gradient(135deg, var(--wp-soft) 50%, transparent 50%);
  background-position:
    calc(100% - 16px) 50%,
    calc(100% - 11px) 50%;
  background-size: 4px 4px, 4px 4px;
  background-repeat: no-repeat;
  border: 1px solid var(--wp-line);
  border-radius: var(--radius-full);
  color: var(--wp-ink);
  font: inherit;
  font-size: .8rem;
  cursor: pointer;
  transition: border-color var(--duration) var(--ease),
              box-shadow var(--duration) var(--ease),
              background-color var(--duration) var(--ease);
}
.idd-tool-filter-select:hover{ border-color: var(--wp-brand-border); }
.idd-tool-filter-select:focus{
  outline: none;
  border-color: var(--wp-brand);
  box-shadow: 0 0 0 4px var(--wp-brand-soft);
}
.idd-tool-filter-select.is-active{
  background-color: var(--wp-brand-soft);
  border-color: var(--wp-brand);
  color: var(--wp-brand-dark);
  font-weight: 600;
}

.idd-tool-filters-reset{
  flex: 1 1 100%;
  height: 30px;
  padding: 0 14px;
  border: 1px dashed var(--wp-brand-border);
  background: transparent;
  color: var(--wp-brand-dark);
  border-radius: var(--radius-full);
  font: inherit;
  font-size: .78rem;
  font-weight: 600;
  cursor: pointer;
  transition: background var(--duration) var(--ease),
              border-style var(--duration) var(--ease);
}
.idd-tool-filters-reset[hidden]{ display: none !important; }
.idd-tool-filters-reset:hover{
  background: var(--wp-brand-soft);
  border-style: solid;
}


/* =========================================================
   COUNTER (en-tête de liste)
   ========================================================= */
.idd-tool-counter{
  font-size: .76rem;
  font-weight: 600;
  color: var(--wp-muted);
  letter-spacing: .04em;
  text-align: right;
  padding: 0 4px;
}
.idd-tool-counter:empty{ display: none; }
.idd-tool-counter strong{
  color: var(--wp-brand-dark);
  font-weight: 700;
}


/* =========================================================
   LIST (conteneur scrollable)
   ========================================================= */
.idd-tool-list{
  overflow-y: auto;
  flex: 1 1 auto;
  min-height: 0;
  padding-right: 4px;
  display: flex;
  flex-direction: column;
  gap: 8px;
  scrollbar-width: thin;
  scrollbar-color: var(--wp-brand-border) transparent;
}
.idd-tool-list::-webkit-scrollbar{ width: 6px; }
.idd-tool-list::-webkit-scrollbar-track{ background: transparent; }
.idd-tool-list::-webkit-scrollbar-thumb{
  background: var(--wp-brand-border);
  border-radius: var(--radius-full);
}
@media (max-width: 980px){
  .idd-tool-list{ max-height: 50vh; }
}


/* =========================================================
   CARD (élément de liste / carte standard)
   ========================================================= */
.idd-tool-card{
  background: var(--wp-surface);
  border: 1px solid var(--wp-line);
  border-radius: var(--radius-md);
  padding: 10px 12px;
  transition: transform var(--duration) var(--ease),
              border-color var(--duration) var(--ease),
              box-shadow var(--duration) var(--ease);
}
.idd-tool-card:hover{
  border-color: var(--wp-brand-border);
  box-shadow: var(--shadow-sm);
  transform: translateY(-1px);
}
.idd-tool-card--draggable{ cursor: grab; }
.idd-tool-card--draggable:active{ cursor: grabbing; }
.idd-tool-card--selected{
  border-color: var(--wp-brand);
  box-shadow: 0 0 0 3px var(--wp-brand-soft), var(--shadow-sm);
}
.idd-tool-card--dragging{
  opacity: .55;
  border-color: var(--wp-brand);
  box-shadow: var(--shadow-md);
}


/* =========================================================
   BADGE (pilule)
   ========================================================= */
.idd-tool-badge{
  display: inline-flex;
  align-items: center;
  gap: 5px;
  padding: 3px 9px;
  border-radius: var(--radius-full);
  font-size: .72rem;
  font-weight: 600;
  letter-spacing: .02em;
  white-space: nowrap;
  border: 1px solid transparent;
  background: var(--wp-surface-2);
  color: var(--wp-soft);
  line-height: 1.2;
}
.idd-tool-badge--brand{   background: var(--wp-brand-soft); color: var(--wp-brand-dark); border-color: var(--wp-brand-border); }
.idd-tool-badge--gold{    background: var(--wp-gold-soft);  color: var(--wp-gold-dark);  border-color: var(--wp-gold-border); }
.idd-tool-badge--sage{    background: var(--wp-sage-soft);  color: var(--wp-sage-dark);  border-color: var(--wp-sage-border); }
.idd-tool-badge--neutral{ background: var(--wp-surface-2);  color: var(--wp-soft);       border-color: var(--wp-line); }
.idd-tool-badge--alert{
  background: var(--wp-brand-soft);
  color: var(--wp-brand-dark);
  border-color: var(--wp-brand-border);
}
.idd-tool-badge--alert::before{
  content: "";
  width: 5px; height: 5px;
  border-radius: var(--radius-full);
  background: var(--wp-brand);
  box-shadow: 0 0 0 3px rgba(181,99,122,.18);
}


/* =========================================================
   EMPTY STATE
   ========================================================= */
.idd-tool-empty{
  padding: clamp(28px, 5vw, 56px) 24px;
  text-align: center;
  color: var(--wp-soft);
  background: var(--wp-surface);
  border: 1px dashed var(--wp-line-strong);
  border-radius: var(--radius-xl);
}
.idd-tool-empty[hidden]{ display: none !important; }

.idd-tool-empty__visual{
  width: 96px;
  height: 96px;
  margin: 0 auto 18px;
  display: grid;
  place-items: center;
  border-radius: var(--radius-full);
  background:
    radial-gradient(circle at 50% 50%, var(--wp-brand-soft) 0%, transparent 70%),
    var(--wp-surface);
  color: var(--wp-brand);
  border: 1px solid var(--wp-brand-border);
}
.idd-tool-empty__title{
  margin: 0 0 8px;
  font-family: var(--font-serif);
  font-size: 1.5rem;
  font-weight: 500;
  color: var(--wp-ink);
}
.idd-tool-empty__lead{
  margin: 0 auto 22px;
  max-width: 48ch;
  color: var(--wp-soft);
  font-size: .95rem;
  line-height: 1.55;
}
.idd-tool-empty__actions{
  display: flex;
  gap: 10px;
  flex-wrap: wrap;
  justify-content: center;
}


/* =========================================================
   TOOLBAR (barre d'actions horizontale)
   ========================================================= */
.idd-tool-toolbar{
  display: flex;
  flex-wrap: nowrap;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  padding: 10px 14px;
  background: var(--wp-surface);
  border: 1px solid var(--wp-line);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-xs);
  margin-bottom: clamp(12px, 2vw, 18px);
  width: 100%;
  max-width: 100%;
  overflow-x: auto;
  overflow-y: hidden;
  scrollbar-width: thin;
  -ms-overflow-style: none;
  scroll-behavior: smooth;
  -webkit-overflow-scrolling: touch;
}
/* Scrollbar discrète (Chrome/Safari) */
.idd-tool-toolbar::-webkit-scrollbar { height: 6px; }
.idd-tool-toolbar::-webkit-scrollbar-track { background: transparent; }
.idd-tool-toolbar::-webkit-scrollbar-thumb {
  background: var(--wp-line);
  border-radius: 999px;
}
.idd-tool-toolbar::-webkit-scrollbar-thumb:hover { background: var(--wp-muted, #a08d93); }

/* Les 3 zones — toutes en flex row, ne se rétrécissent pas, ne wrappent pas */
.idd-tool-toolbar__left,
.idd-tool-toolbar__center,
.idd-tool-toolbar__right{
  display: flex;
  align-items: center;
  gap: 6px;
  flex-wrap: nowrap;
  flex-shrink: 0;
}
.idd-tool-toolbar__center{
  flex: 1 1 auto;
  min-width: 0;
  justify-content: center;
  text-align: center;
}
.idd-tool-toolbar__center > .idd-tool-toolbar__title{
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  min-width: 0;
  max-width: 100%;
}
.idd-tool-toolbar__right{ margin-left: auto; }

.idd-tool-toolbar__group{
  display: inline-flex;
  align-items: center;
  gap: 6px;
  flex-shrink: 0;
}
.idd-tool-toolbar__sep{
  width: 1px;
  height: 22px;
  background: var(--wp-line);
  margin: 0 4px;
  flex-shrink: 0;
}
/* Tous les boutons : pas de wrap, pas de shrink */
.idd-tool-toolbar__btn,
.idd-tool-toolbar__back,
.idd-tool-toolbar__primary,
.idd-tool-toolbar__burger{
  flex-shrink: 0;
  white-space: nowrap;
}

/* =========================================================
   TOOLBAR — BOTTOM-FIXED (source unique de vérité)
   La toolbar est posée en bas de viewport pour TOUS les outils.
   Chaque outil doit appliquer un padding-bottom à son layout
   pour ne pas être recouvert (cf .idd-tool { padding-bottom })
   ========================================================= */
.idd-tool-toolbar{
  position: fixed;
  left: 0;
  right: 0;
  bottom: env(safe-area-inset-bottom, 0px);
  z-index: 40;
  margin: 0;
  border-radius: 0;
  border-left: 0;
  border-right: 0;
  border-bottom: 0;
  box-shadow: 0 -6px 24px -10px rgba(29, 24, 25, .12);
  padding: 10px 16px;
  height: 64px;
  background: var(--wp-surface, #fff);
  border-top: 1px solid var(--wp-line, #EDE0E4);
}

/* =========================================================
   TITRE & STATUS (zone __center)
   ========================================================= */
.idd-tool-toolbar__title{
  font-family: var(--font-serif, 'Cormorant Garamond', serif);
  font-weight: 600;
  font-size: 1.05rem;
  color: var(--wp-ink, #1D1819);
  letter-spacing: -.005em;
  line-height: 1.15;
}
.idd-tool-toolbar__status{
  display: inline-flex;
  align-items: center;
  font-size: .78rem;
  color: var(--wp-soft, #6E5A60);
  margin-left: 10px;
  font-weight: 500;
  min-height: 20px;
}
.idd-tool-toolbar__status[data-status="saved"]   { color: var(--wp-sage-dark, #4F7256); }
.idd-tool-toolbar__status[data-status="saving"]  { color: var(--wp-gold-dark, #B0926A); }
.idd-tool-toolbar__status[data-status="error"]   { color: var(--wp-brand, #B5637A); }

/* =========================================================
   BOUTON __primary — CTA principal (filled brand)
   ========================================================= */
.idd-tool-toolbar__primary{
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 7px;
  min-height: 40px;
  padding: 0 16px;
  border-radius: 999px;
  border: 0;
  background: var(--wp-brand, #B5637A);
  color: #fff;
  font-family: inherit;
  font-size: .9rem;
  font-weight: 600;
  cursor: pointer;
  text-decoration: none;
  box-shadow: 0 4px 12px -4px rgba(181, 99, 122, .35);
  transition: background-color .15s ease, transform .12s ease, box-shadow .15s ease;
}
.idd-tool-toolbar__primary:hover,
.idd-tool-toolbar__primary:focus-visible{
  background: var(--wp-brand-dark, #9A4F65);
  transform: translateY(-1px);
  box-shadow: 0 6px 16px -4px rgba(181, 99, 122, .45);
  outline: none;
  color: #fff;
}
.idd-tool-toolbar__primary:active{ transform: scale(.97); }
.idd-tool-toolbar__primary svg{
  width: 18px;
  height: 18px;
  stroke-width: 2;
  flex-shrink: 0;
}
.idd-tool-toolbar__primary-label{
  font-size: .88rem;
  font-weight: 600;
  line-height: 1;
}

/* =========================================================
   BOUTON __btn — action secondaire (outline neutre)
   ========================================================= */
.idd-tool-toolbar__btn{
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 6px;
  min-width: 40px;
  min-height: 40px;
  padding: 0 12px;
  border-radius: 12px;
  border: 1px solid var(--wp-line, #EDE0E4);
  background: var(--wp-surface, #fff);
  color: var(--wp-ink, #1D1819);
  font-family: inherit;
  font-size: .85rem;
  font-weight: 600;
  cursor: pointer;
  text-decoration: none;
  transition: background-color .15s ease, border-color .15s ease, color .15s ease;
}
.idd-tool-toolbar__btn:hover,
.idd-tool-toolbar__btn:focus-visible{
  background: var(--wp-brand-soft, rgba(181, 99, 122, .08));
  border-color: var(--wp-brand-border, rgba(181, 99, 122, .22));
  color: var(--wp-brand-dark, #9A4F65);
  outline: none;
}
.idd-tool-toolbar__btn:active{ transform: scale(.97); }
.idd-tool-toolbar__btn svg{
  width: 18px;
  height: 18px;
  stroke-width: 2;
  flex-shrink: 0;
}
.idd-tool-toolbar__label{
  font-size: .82rem;
  font-weight: 500;
  line-height: 1;
}

/* =========================================================
   BOUTON __back — retour (icône seule, neutre)
   ========================================================= */
.idd-tool-toolbar__back{
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 40px;
  height: 40px;
  border-radius: 12px;
  border: 1px solid var(--wp-line, #EDE0E4);
  background: var(--wp-surface, #fff);
  color: var(--wp-soft, #6E5A60);
  cursor: pointer;
  transition: background-color .15s ease, color .15s ease, border-color .15s ease;
}
.idd-tool-toolbar__back:hover,
.idd-tool-toolbar__back:focus-visible{
  background: var(--wp-brand-soft, rgba(181, 99, 122, .08));
  border-color: var(--wp-brand-border, rgba(181, 99, 122, .22));
  color: var(--wp-brand-dark, #9A4F65);
  outline: none;
}
.idd-tool-toolbar__back svg{
  width: 18px;
  height: 18px;
  stroke-width: 2;
}

/* =========================================================
   BOUTON __burger — ouvre le panel (icône 3 lignes)
   ========================================================= */
.idd-tool-toolbar__burger{
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 40px;
  height: 40px;
  border-radius: 12px;
  border: 1px solid var(--wp-line, #EDE0E4);
  background: var(--wp-surface, #fff);
  color: var(--wp-ink, #1D1819);
  cursor: pointer;
  transition: background-color .15s ease, border-color .15s ease;
}
.idd-tool-toolbar__burger:hover,
.idd-tool-toolbar__burger:focus-visible{
  background: var(--wp-brand-soft, rgba(181, 99, 122, .08));
  border-color: var(--wp-brand-border, rgba(181, 99, 122, .22));
  outline: none;
}
.idd-tool-toolbar__burger[aria-expanded="true"]{
  background: var(--wp-brand-soft, rgba(181, 99, 122, .08));
  border-color: var(--wp-brand-border, rgba(181, 99, 122, .22));
}
.idd-tool-toolbar__burger-lines{
  width: 18px;
  height: 14px;
  position: relative;
  display: inline-block;
}
.idd-tool-toolbar__burger-lines span{
  position: absolute;
  left: 0;
  right: 0;
  height: 2px;
  background: currentColor;
  border-radius: 2px;
}
.idd-tool-toolbar__burger-lines span:nth-child(1){ top: 1px; }
.idd-tool-toolbar__burger-lines span:nth-child(2){ top: 6px; }
.idd-tool-toolbar__burger-lines span:nth-child(3){ top: 11px; }

/* =========================================================
   RESPONSIVE — masquer les labels en-dessous de 640px
   pour garder la toolbar lisible avec icônes seules.
   ========================================================= */
@media (max-width: 640px){
  .idd-tool-toolbar{ padding: 8px 10px; height: 60px; }
  .idd-tool-toolbar__btn{ padding: 0 10px; min-width: 40px; }
  .idd-tool-toolbar__btn .idd-tool-toolbar__label{ display: none; }
  .idd-tool-toolbar__primary{ padding: 0 14px; }
  .idd-tool-toolbar__primary-label{ display: none; }
  .idd-tool-toolbar__title{ font-size: .95rem; }
  .idd-tool-toolbar__status{ display: none; }
}
@media (max-width: 380px){
  .idd-tool-toolbar{ padding: 6px 8px; gap: 6px; }
  .idd-tool-toolbar__btn,
  .idd-tool-toolbar__primary,
  .idd-tool-toolbar__back,
  .idd-tool-toolbar__burger{ min-width: 38px; min-height: 38px; width: 38px; height: 38px; padding: 0; }
}

/* Print : masquer la toolbar */
@media print{
  .idd-tool-toolbar,
  .idd-tool-toolbar.no-print{ display: none !important; }
}


/* =========================================================
   RESPONSIVE — ajustements <640px
   ========================================================= */
@media (max-width: 720px){
  .idd-tool-page-header{
    grid-template-columns: 1fr;
    align-items: start;
    padding: 18px;
  }
}
@media (max-width: 640px){
  .idd-tool-kpis{ grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .idd-tool-toolbar{ padding: 10px 12px; }
}
@media (max-width: 380px){
  .idd-tool-kpi__value{ font-size: 1.25rem; }
}


/* =========================================================
   MODAL (premium upsell + confirm) + SPINNER + EMPTY
   Pilotés par idd-tool-kit.js — utilisable depuis n'importe
   quel outil via window.IddToolKit.
   ========================================================= */
.idd-tool-modal{
  position: fixed; inset: 0;
  z-index: 999999;
  display: grid; place-items: center;
  padding: 16px;
  animation: idd-tk-fade .15s ease;
}
@keyframes idd-tk-fade { from { opacity: 0; } to { opacity: 1; } }

.idd-tool-modal__backdrop{
  position: absolute; inset: 0;
  background: rgba(29,24,25,.55);
  backdrop-filter: blur(2px);
}
.idd-tool-modal__panel{
  position: relative;
  z-index: 1;
  max-width: 480px;
  width: 100%;
  background: var(--wp-surface, #fff);
  color: var(--wp-ink, #1d1819);
  border-radius: 24px;
  padding: 36px 28px 28px;
  box-shadow: 0 32px 80px -16px rgba(29,24,25,.32);
  text-align: center;
  animation: idd-tk-pop .25s cubic-bezier(.34,1.56,.64,1);
}
.idd-tool-modal__panel--sm{ max-width: 420px; padding: 28px 24px 24px; }
@keyframes idd-tk-pop {
  from { opacity: 0; transform: translateY(8px) scale(.97); }
  to   { opacity: 1; transform: translateY(0) scale(1); }
}
.idd-tool-modal__close{
  position: absolute; top: 14px; right: 14px;
  width: 36px; height: 36px;
  border: 0; background: transparent;
  color: var(--wp-soft, #6e5a60);
  border-radius: 50%; cursor: pointer;
  display: grid; place-items: center;
  transition: background .15s;
}
.idd-tool-modal__close:hover,
.idd-tool-modal__close:focus-visible{
  background: var(--wp-line, #f0e8e9);
  outline: none;
}
.idd-tool-modal__icon{
  width: 56px; height: 56px;
  margin: 0 auto 18px;
  display: grid; place-items: center;
  border-radius: 16px;
  background: linear-gradient(135deg, rgba(181,99,122,.10), rgba(201,168,124,.18));
  color: var(--wp-gold, #C9A87C);
}
.idd-tool-modal__icon svg{ width: 32px; height: 32px; }
.idd-tool-modal__title{
  font-family: var(--wp-font-serif, 'Cormorant Garamond', serif);
  font-weight: 600;
  font-size: clamp(1.45rem, 3vw, 1.85rem);
  line-height: 1.15;
  margin: 0 0 10px;
  color: var(--wp-ink, #1d1819);
}
.idd-tool-modal__lead{
  font-size: .95rem;
  line-height: 1.5;
  color: var(--wp-soft, #6e5a60);
  margin: 0 0 22px;
}
.idd-tool-modal__bullets{
  list-style: none;
  padding: 0;
  margin: 0 auto 24px;
  max-width: 320px;
  text-align: left;
  display: grid; gap: 8px;
}
.idd-tool-modal__bullets li{
  padding-left: 26px;
  position: relative;
  font-size: .9rem;
  color: var(--wp-ink, #1d1819);
}
.idd-tool-modal__bullets li::before{
  content: '✓';
  position: absolute; left: 0; top: 0;
  width: 18px; height: 18px;
  background: var(--wp-brand-soft, rgba(181,99,122,.12));
  color: var(--wp-brand, #B5637A);
  border-radius: 50%;
  display: grid; place-items: center;
  font-size: .7rem; font-weight: 700;
}
.idd-tool-modal__actions{
  display: flex;
  gap: 10px;
  justify-content: center;
  flex-wrap: wrap;
}
.idd-tool-modal__btn{
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 44px;
  padding: 11px 22px;
  border-radius: 999px;
  font-size: .92rem;
  font-weight: 600;
  text-decoration: none;
  border: 0;
  cursor: pointer;
  font-family: inherit;
  transition: background .15s, transform .15s, box-shadow .15s;
}
.idd-tool-modal__btn--primary{
  background: var(--wp-brand, #B5637A);
  color: #fff;
  box-shadow: 0 6px 16px -6px rgba(181,99,122,.45);
}
.idd-tool-modal__btn--primary:hover,
.idd-tool-modal__btn--primary:focus-visible{
  background: var(--wp-brand-dark, #9A4F65);
  transform: translateY(-1px);
  color: #fff; outline: none;
}
.idd-tool-modal__btn--ghost{
  background: transparent;
  color: var(--wp-ink, #1d1819);
  border: 1px solid var(--wp-line, #e0d3d6);
}
.idd-tool-modal__btn--ghost:hover,
.idd-tool-modal__btn--ghost:focus-visible{
  background: var(--wp-surface-2, #faf5f3);
  outline: none;
}
.idd-tool-modal__btn--danger{
  background: #C0392B;
  color: #fff;
  box-shadow: 0 6px 16px -6px rgba(192,57,43,.45);
}
.idd-tool-modal__btn--danger:hover,
.idd-tool-modal__btn--danger:focus-visible{
  background: #A03224;
  transform: translateY(-1px);
  outline: none;
}

/* Spinner pour iddBusy() */
.idd-tool-spinner{
  display: inline-block;
  width: 14px; height: 14px;
  margin-left: 8px;
  border: 2px solid currentColor;
  border-top-color: transparent;
  border-radius: 50%;
  vertical-align: middle;
  animation: idd-tk-spin .8s linear infinite;
}
@keyframes idd-tk-spin { to { transform: rotate(360deg); } }
[aria-busy="true"]{ cursor: progress; }
button[aria-busy="true"], a[aria-busy="true"]{ opacity: .75; }

/* Reduced motion */
@media (prefers-reduced-motion: reduce){
  .idd-tool-modal,
  .idd-tool-modal__panel,
  .idd-tool-spinner{ animation: none !important; }
}

@media (max-width: 480px){
  .idd-tool-modal__panel{ padding: 28px 20px 22px; border-radius: 20px; }
  .idd-tool-modal__title{ font-size: 1.35rem; }
}
