/* ============================================================
   Plateforme de parrainage Ouioweb — design system
   Charte : Nunito, primaire #003F63, accent #f2b138
   ============================================================ */
@import url('https://fonts.googleapis.com/css2?family=Nunito:wght@400;600;700;800;900&display=swap');

:root{
  --ow-primary:#003F63; --ow-primary-light:#005580;
  --ow-accent:#f2b138; --ow-accent-dark:#e09f1f;
  --ow-dark:#0f172a; --ow-text:#334155; --ow-muted:#64748b;
  --ow-bg:#f4f7fa; --ow-white:#fff; --ow-border:rgba(0,63,99,.10);
  --ow-shadow:0 10px 30px rgba(2,32,53,.08);
  --ow-radius:16px; --ow-radius-sm:10px;
  --ok:#16a34a; --okbg:#dcfce7; --warn:#b45309; --warnbg:#fef3c7;
  --err:#dc2626; --errbg:#fee2e2; --info:#0369a1; --infobg:#e0f2fe;
}

*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{
  font-family:'Nunito',system-ui,-apple-system,Segoe UI,Roboto,sans-serif;
  background:var(--ow-bg); color:var(--ow-text); font-size:15px; line-height:1.55;
  -webkit-font-smoothing:antialiased;
}
a{color:var(--ow-primary-light);text-decoration:none}
a:hover{text-decoration:underline}
h1,h2,h3,h4{color:var(--ow-dark);font-weight:800;margin:.2em 0 .5em}
h1{font-size:1.55rem} h2{font-size:1.2rem} h3{font-size:1.02rem}
small,.muted{color:var(--ow-muted)}

/* ---------- Layout dashboard ---------- */
.app{display:flex;min-height:100vh}
.sidebar{
  width:248px;background:linear-gradient(180deg,var(--ow-primary),#012c46);
  color:#cfe2ee;display:flex;flex-direction:column;flex-shrink:0;position:sticky;top:0;height:100vh
}
.sidebar .brand{display:flex;align-items:center;gap:10px;padding:20px 22px;border-bottom:1px solid rgba(255,255,255,.08)}
.sidebar .brand img{height:30px}
.sidebar .brand b{color:#fff;font-weight:900;font-size:1.05rem}
.sidebar .role{font-size:.7rem;letter-spacing:.08em;text-transform:uppercase;color:var(--ow-accent);padding:14px 22px 6px;font-weight:800}
.sidebar nav a{
  display:flex;align-items:center;gap:11px;padding:11px 22px;color:#cfe2ee;
  font-weight:600;border-left:3px solid transparent;transition:.15s
}
.sidebar nav a:hover{background:rgba(255,255,255,.06);text-decoration:none;color:#fff}
.sidebar nav a.active{background:rgba(242,177,56,.14);border-left-color:var(--ow-accent);color:#fff}
.sidebar nav a svg{width:18px;height:18px;flex-shrink:0;opacity:.85}
.sidebar .foot{margin-top:auto;padding:16px 22px;font-size:.8rem;border-top:1px solid rgba(255,255,255,.08)}
.sidebar .foot a{display:inline-flex;align-items:center;gap:9px}
.sidebar .foot svg{width:18px;height:18px;flex-shrink:0}

.sidebar-backdrop{display:none}

.main{flex:1;min-width:0;display:flex;flex-direction:column}
.topbar{
  background:var(--ow-white);border-bottom:1px solid var(--ow-border);
  padding:14px 28px;display:flex;align-items:center;justify-content:space-between;gap:16px
}
.topbar .who{font-weight:700;color:var(--ow-dark)}
.content{padding:26px 28px;max-width:1180px;width:100%}

/* ---------- Cards / KPI ----------
   Gouttière unique partout : --gap (vertical = horizontal). */
:root{--gap:20px}
.card{background:var(--ow-white);border:1px solid var(--ow-border);border-radius:var(--ow-radius);box-shadow:var(--ow-shadow);padding:22px;margin-bottom:var(--gap)}
.card h2{margin-top:0}
/* Une carte dans une grille ne gère pas sa propre marge : c'est le conteneur qui sépare. */
.grid>.card,.form-grid>.card{margin-bottom:0}
.grid{display:grid;gap:var(--gap);margin-bottom:var(--gap)}
.grid.kpi{grid-template-columns:repeat(auto-fit,minmax(190px,1fr))}
.kpi-card{background:var(--ow-white);border:1px solid var(--ow-border);border-radius:var(--ow-radius);padding:18px 20px;box-shadow:var(--ow-shadow)}
.kpi-card .label{font-size:.78rem;text-transform:uppercase;letter-spacing:.05em;color:var(--ow-muted);font-weight:800}
.kpi-card .val{font-size:1.7rem;font-weight:900;color:var(--ow-dark);margin-top:4px}
.kpi-card.accent{background:linear-gradient(135deg,var(--ow-primary),var(--ow-primary-light));border:0}
.kpi-card.accent .label{color:#bfe0f0} .kpi-card.accent .val{color:#fff}
.kpi-card.gold{background:linear-gradient(135deg,var(--ow-accent),var(--ow-accent-dark));border:0}
.kpi-card.gold .label{color:#5a3d05} .kpi-card.gold .val{color:#3d2900}

/* ---------- Tables ---------- */
.table-wrap{overflow-x:auto;border-radius:var(--ow-radius-sm)}
table{width:100%;border-collapse:collapse;font-size:.92rem}
th,td{text-align:left;padding:11px 13px;border-bottom:1px solid var(--ow-border);vertical-align:middle}
th{font-size:.74rem;text-transform:uppercase;letter-spacing:.04em;color:var(--ow-muted);font-weight:800;background:#fafcfe}
tbody tr:hover{background:#f7fbfe}
td.num,th.num{text-align:right;font-variant-numeric:tabular-nums}
.empty{padding:34px;text-align:center;color:var(--ow-muted)}

/* ---------- Badges ---------- */
.badge{display:inline-block;padding:3px 10px;border-radius:999px;font-size:.72rem;font-weight:800;text-transform:uppercase;letter-spacing:.03em}
.badge.ok{background:var(--okbg);color:var(--ok)}
.badge.pending{background:var(--warnbg);color:var(--warn)}
.badge.paid{background:var(--infobg);color:var(--info)}
.badge.err{background:var(--errbg);color:var(--err)}
.badge.muted{background:#e2e8f0;color:#475569}

/* ---------- Buttons ---------- */
.btn{display:inline-flex;align-items:center;gap:8px;border:0;cursor:pointer;font-family:inherit;
  font-weight:800;font-size:.9rem;padding:10px 18px;border-radius:var(--ow-radius-sm);transition:.15s;text-decoration:none}
.btn:hover{text-decoration:none;transform:translateY(-1px)}
.btn-primary{background:var(--ow-primary);color:#fff}
.btn-primary:hover{background:var(--ow-primary-light);color:#fff}
.btn-accent{background:var(--ow-accent);color:#3d2900}
.btn-accent:hover{background:var(--ow-accent-dark)}
.btn-ghost{background:#eef4f8;color:var(--ow-primary)}
.btn-danger{background:var(--errbg);color:var(--err)}
.btn-sm{padding:6px 12px;font-size:.8rem}
.btn[disabled]{opacity:.5;cursor:not-allowed;transform:none}
.btn svg{width:16px;height:16px;flex-shrink:0}
.btn-sm svg{width:14px;height:14px}
/* Icônes dans les titres de section */
h1 svg,h2 svg,h3 svg{width:20px;height:20px;vertical-align:-3px;color:var(--ow-primary);flex-shrink:0}

/* ---------- Forms ---------- */
.form-row{margin-bottom:16px}
.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:var(--gap)}
/* Grille de CARTES (et non de champs) : sépare du bloc suivant, quelle que soit la hauteur des colonnes. */
.form-grid[style*="align-items"]{margin-bottom:var(--gap)}
label{display:block;font-weight:700;color:var(--ow-dark);margin-bottom:6px;font-size:.88rem}
input,select,textarea{
  width:100%;padding:10px 13px;border:1px solid #cdd9e3;border-radius:var(--ow-radius-sm);
  font-family:inherit;font-size:.95rem;background:#fff;color:var(--ow-text)
}
input:focus,select:focus,textarea:focus{outline:0;border-color:var(--ow-primary-light);box-shadow:0 0 0 3px rgba(0,85,128,.12)}
.hint{font-size:.8rem;color:var(--ow-muted);margin-top:5px}

/* ---------- Alerts ---------- */
.alert{padding:13px 16px;border-radius:var(--ow-radius-sm);margin-bottom:16px;font-weight:600;border:1px solid transparent}
.alert.success{background:var(--okbg);color:#14532d;border-color:#bbf7d0}
.alert.error{background:var(--errbg);color:#7f1d1d;border-color:#fecaca}
.alert.info{background:var(--infobg);color:#075985;border-color:#bae6fd}
.alert.warn{background:var(--warnbg);color:#78350f;border-color:#fde68a}

/* ---------- Auth pages ---------- */
.auth{min-height:100vh;display:flex;align-items:center;justify-content:center;
  background:radial-gradient(1200px 600px at 70% -10%,rgba(0,85,128,.25),transparent),
             linear-gradient(135deg,var(--ow-primary),#012c46);padding:20px}
.auth-card{background:#fff;border-radius:22px;box-shadow:0 30px 70px rgba(0,0,0,.3);
  width:100%;max-width:410px;padding:34px 32px}
.auth-card .logo{text-align:center;margin-bottom:8px}
.auth-card .logo img{height:40px}
.auth-card h1{text-align:center;font-size:1.3rem;margin-bottom:4px}
.auth-card .sub{text-align:center;color:var(--ow-muted);margin-bottom:22px;font-size:.9rem}
.section-title{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:16px}
.section-title h1{margin:0}
.flex{display:flex;gap:10px;align-items:center}
.flex.wrap{flex-wrap:wrap}
.right{margin-left:auto}
.pill-rate{font-weight:800;color:var(--ow-primary)}

/* ---------- Lead / intro ---------- */
.lead{font-size:1.04rem;color:var(--ow-text);max-width:780px;margin:.3em 0 26px;line-height:1.6}

/* ---------- Code rows (codes promo) ---------- */
.code-row{display:flex;align-items:center;justify-content:space-between;gap:14px;
  padding:14px 16px;border:1px dashed var(--ow-border);border-radius:var(--ow-radius-sm);margin-bottom:12px;background:#fbfdff}
.code-row.is-off{opacity:.55}
.code-word{font-size:1.25rem;letter-spacing:.06em;color:var(--ow-primary);font-weight:900}
.code-main .hint{margin-top:3px}

/* Encart remise dans le formulaire de création */
.discount-callout{display:flex;align-items:center;justify-content:space-between;gap:14px;
  background:linear-gradient(135deg,var(--ow-accent),var(--ow-accent-dark));color:#3d2900;
  border-radius:var(--ow-radius-sm);padding:16px 20px;margin:14px 0 6px;font-weight:800}
.discount-callout strong{font-size:1.6rem;color:#3d2900;line-height:1}

/* ---------- Étapes "comment ça marche" ---------- */
.steps{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:var(--gap)}
.step{display:flex;gap:14px;align-items:flex-start;line-height:1.5}
.step-num{flex-shrink:0;width:32px;height:32px;border-radius:50%;display:flex;align-items:center;justify-content:center;
  background:var(--ow-primary);color:#fff;font-weight:900;font-size:.95rem}

/* ============================================================
   Kit de communication
   ============================================================ */
.kit-hero{display:flex;align-items:center;gap:26px;flex-wrap:wrap;
  background:radial-gradient(900px 400px at 85% -60%,rgba(242,177,56,.28),transparent),
             linear-gradient(135deg,var(--ow-primary),#012c46);
  border-radius:var(--ow-radius);padding:32px 34px;margin-bottom:26px;box-shadow:var(--ow-shadow)}
.kit-hero-logo{background:#fff;border-radius:14px;padding:16px 22px;display:flex;align-items:center;box-shadow:0 8px 24px rgba(0,0,0,.18)}
.kit-hero-logo img{height:40px;display:block}
.kit-hero h1{font-size:1.5rem}
.kit-hero p{font-size:1rem;line-height:1.55;max-width:560px}

/* En-tête de section numérotée */
.kit-section-head{display:flex;align-items:center;gap:14px;margin:34px 0 16px}
.kit-section-head .n{flex-shrink:0;width:38px;height:38px;border-radius:50%;display:flex;align-items:center;justify-content:center;
  background:var(--ow-accent);color:#3d2900;font-weight:900;font-size:1.1rem}
.kit-section-head h2{margin:0;font-size:1.22rem}
.kit-section-head p{margin:2px 0 0;font-size:.85rem;color:var(--ow-muted)}

/* Logos */
.asset-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:var(--gap)}
.asset-card{border:1px solid var(--ow-border);border-radius:var(--ow-radius);overflow:hidden;background:#fff;box-shadow:var(--ow-shadow);display:flex;flex-direction:column}
.asset-preview{display:flex;align-items:center;justify-content:center;padding:34px 22px;min-height:120px}
.asset-preview img{max-height:54px;max-width:80%}
.asset-preview.light{background:#f4f7fa}
.asset-preview.dark{background:linear-gradient(135deg,var(--ow-primary),#012c46)}
.asset-card .asset-label{padding:12px 16px 0;font-weight:800;color:var(--ow-dark);font-size:.92rem}
.asset-card .btn{margin:12px 16px 16px;justify-content:center}

/* Couleurs */
.swatches{display:grid;grid-template-columns:repeat(auto-fit,minmax(170px,1fr));gap:var(--gap)}
.swatch{display:flex;align-items:center;gap:14px;padding:12px;border:1px solid var(--ow-border);
  border-radius:var(--ow-radius);background:#fff;cursor:pointer;text-align:left;transition:.15s;box-shadow:var(--ow-shadow)}
.swatch:hover{transform:translateY(-2px)}
.swatch .swatch-color{width:46px;height:46px;border-radius:10px;background:var(--c);flex-shrink:0;border:1px solid rgba(0,0,0,.08)}
.swatch-meta b{display:block;font-size:.9rem;color:var(--ow-dark)}
.swatch-meta small{color:var(--ow-muted);font-size:.76rem}
.swatch.copied{outline:2px solid var(--ow-accent);outline-offset:1px}
.swatch.copied .swatch-meta b::after{content:' ✓';color:var(--ok)}

/* Textes prêts à l'emploi */
.snippet{border:1px solid var(--ow-border);border-radius:var(--ow-radius);margin-bottom:var(--gap);overflow:hidden;box-shadow:var(--ow-shadow)}
.snippet:last-child{margin-bottom:0}
.snippet-head{display:flex;align-items:center;justify-content:space-between;gap:12px;
  padding:13px 18px;background:#f7fbfe;border-bottom:1px solid var(--ow-border)}
.snippet-head b{color:var(--ow-dark);font-size:.95rem}
.snippet pre{margin:0;padding:18px;white-space:pre-wrap;word-break:break-word;
  font-family:inherit;font-size:.92rem;color:var(--ow-text);background:#fff;line-height:1.65}

/* Arguments */
.feature-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:var(--gap)}
.feature{display:flex;gap:14px;align-items:flex-start;padding:18px;border:1px solid var(--ow-border);
  border-radius:var(--ow-radius);background:#fff;box-shadow:var(--ow-shadow);line-height:1.5}
.feature .chk{flex-shrink:0;width:30px;height:30px;border-radius:50%;display:flex;align-items:center;justify-content:center;
  background:var(--okbg);color:var(--ok);font-weight:900}
.feature b{display:block;color:var(--ow-dark);margin-bottom:3px}
.feature small{color:var(--ow-muted)}

@media(max-width:860px){
  .kit-hero{padding:24px;text-align:center;justify-content:center}
  .sidebar{position:fixed;left:-260px;z-index:50;transition:.2s}
  .sidebar.open{left:0;box-shadow:0 0 40px rgba(0,0,0,.35)}
  .sidebar.open ~ .sidebar-backdrop{display:block;position:fixed;inset:0;background:rgba(2,32,53,.45);z-index:40}
  .form-grid{grid-template-columns:1fr}
  .menu-toggle{display:inline-flex!important}
}
.menu-toggle{display:none}
