:root {
  --mm-bg: #ffffff;
  --mm-fg: #111111;
  --mm-muted: #6b7280;
  --mm-border: #e5e7eb;
  --mm-primary: #E30613; /* default HEXIS red */
  --mm-radius: 16px;
  --mm-pad: 16px;
}
.matmak-card {
  background: var(--mm-bg);
  color: var(--mm-fg);
  border: 0px solid var(--mm-border);
  border-radius: var(--mm-radius);
  padding: calc(var(--mm-pad) * 1.25);
  max-width: 1100px;
  margin-inline: auto;
}
.matmak-card h3 { margin-top: 0; letter-spacing: -0.02em; font-weight: 700; }
.muted { color: var(--mm-muted); font-size: 13px; }
.grid-2 { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; }
.grid-3 { display: grid; grid-template-columns: repeat(3,1fr); gap: 12px; }
.button { background: #f3f4f6; border:1px solid var(--mm-border); color:#111; padding:10px 14px; border-radius: 12px; cursor: pointer; }
.button.small { padding: 6px 10px; border-radius: 999px; }
.button.button-primary { background: var(--mm-primary); color:#fff; border:0; }
.button-link { background: transparent; border: 0; color: var(--mm-primary); cursor: pointer; font-size: 18px; }
.button.is-loading {
    position: relative;
    pointer-events: none;
    color: transparent !important; /* Masque le texte */
}
.button.is-loading .button-text {
    visibility: hidden; /* Cache le texte mais garde l'espace */
}
.button.is-loading .button-loader {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    width: 24px;
    height: 24px;
    animation: mm-pulse-drive 1.4s ease-in-out infinite;
}
.check { font-weight: 600; }
.matmak-form label { display:block; margin-bottom: 12px; font-weight: 600; }
.matmak-form input, .matmak-form select {
  width: 100%;
  padding: 12px 14px;
  border-radius: 12px;
  border: 1px solid var(--mm-border);
  outline: none;
}
.matmak-form input:focus, .matmak-form select:focus { border-color: var(--mm-primary); box-shadow: 0 0 0 3px rgba(227,6,19,0.18); }

/* tabs */
.tabs { display:flex; gap:8px; margin: 8px 0 16px; flex-wrap: wrap; }
.tab { padding:8px 12px; border:1px solid var(--mm-border); border-radius: 999px; background:#fff; cursor:pointer; }
.tab.active { background: var(--mm-primary); color:#fff; border-color: var(--mm-primary); }
.tabpanes .tabpane {}

/* messages */
.matmak-feedback { display:none; margin-top: 10px; font-weight:600; }
.matmak-feedback.ok { color: #0a7a33; }
.matmak-feedback.err { color: #b00020; }

/* cards and lists */
.cards { display:grid; grid-template-columns: repeat(auto-fill,minmax(220px,1fr)); gap: 12px; }
.card { border:1px solid var(--mm-border); border-radius:14px; padding:12px; background:#fff; }
.card .title { font-weight:700; }
.card .price { font-weight:700; margin-top:6px; }
.list .row { border:1px solid var(--mm-border); border-radius:12px; padding:12px; margin-bottom:10px; background:#fff; }

/* lookup */
.matmak-results { display: grid; grid-template-columns: repeat(auto-fill, minmax(220px,1fr)); gap: 12px; margin-top: 16px; }
.mm-card { border:1px solid var(--mm-border); border-radius: 14px; overflow: hidden; background:#fff; cursor:pointer; }
.mm-thumb { aspect-ratio: 4/3; overflow:hidden; display:flex; align-items:center; justify-content:center; background:#f7f7f7; }
.mm-thumb img { max-width:100%; height:auto; display:block; }
.mm-title { font-weight:700; padding:10px 12px 0; }
.mm-meta { color:var(--mm-muted); padding: 0 12px 12px; font-size: 12px; }
.mm-badges { padding: 0 12px 12px; display:flex; gap:8px; flex-wrap: wrap; }
.mm-badges span { font-size: 11px; background:#f1f5f9; border-radius:999px; padding:4px 8px; border:1px solid #e5e7eb; }
.mm-spinner { padding: 24px; color: var(--mm-muted); }

/* modal */
dialog#mm-pattern-modal { border:0; border-radius: 18px; padding:0; width:min(100%, 980px); }
dialog#mm-flow-modal { border:0; border-radius: 18px; padding:0; width:min(100%, 500px); }
.mm-modal { padding: 12px; }
.mm-modal-header { display:flex; justify-content: space-between; align-items:center; gap:10px; border-bottom:1px solid var(--mm-border); padding-bottom:8px; }
.mm-modal-body { padding-top: 12px; }
.mm-modal-grid { display:grid; grid-template-columns: 1.2fr 1fr; gap: 16px; }
.mm-thumb.lg { aspect-ratio: 4/3; margin-bottom: 8px; }
.mm-details div { margin-bottom: 6px; }
.mm-type-filters label {
  font-weight: 600;
  display: block;
  margin-bottom: 8px;
}
.chip { display:inline-flex; align-items:center; gap:8px; border:1px solid var(--mm-border); padding: 6px 10px; border-radius: 999px; }
.chip.muted { color: var(--mm-muted); }

/* Styles pour le bouton d'abonnement personnalisé */
.mm-subscribe-btn-styled {
    background-color: var(--mm-primary);
    color: #ffffff;
    border: 2px solid var(--mm-primary);
    border-radius: 100px;
    box-shadow: none;
    cursor: pointer;
    display: inline-block;
    font-family: 'Inter', sans-serif;
    font-size: 16px;
    font-weight: 300;
    height: 48px;
    line-height: 24px;
    padding: 10px 40px;
    text-align: center;
    text-decoration: none;
    text-shadow: none;
    transition: background-color 0.3s, color 0.3s;
}

/* header */
.app-header { display:flex; align-items:center; justify-content:space-between; margin-bottom:12px; }
.brand { font-weight:800; letter-spacing:-0.02em; display:flex; align-items:center; gap:10px; }
.brand-logo { height: 28px; }

@keyframes mm-pulse-drive {
    0%, 100% {
        transform: translate(-50%, -50%) translateX(0) scale(1);
    }
    25% {
        transform: translate(-50%, -50%) translateX(-3px) scale(1.05);
    }
    75% {
        transform: translate(-50%, -50%) translateX(3px) scale(1.05);
    }
}

@media (max-width: 920px) {
  .grid-2, .grid-3 { grid-template-columns: 1fr; }
  .mm-modal-grid { grid-template-columns: 1fr; }
}
