/* =================================================================
   TERRAKANA TEC — Styles du formulaire
   Isolation totale pour éviter les conflits avec les thèmes WordPress.
   Tous les sélecteurs sont préfixés .tk-app.
   ================================================================= */

/* Reset ciblé — n'affecte que les éléments du widget */
.tk-app *, .tk-app *::before, .tk-app *::after {
  box-sizing: border-box;
}
.tk-app h1, .tk-app h2, .tk-app h3, .tk-app p, .tk-app ul, .tk-app li {
  margin: 0;
  padding: 0;
}
.tk-app ul { list-style: none; }

:root {
  --tk-green:       #1a3a2a;
  --tk-green-mid:   #2d5a3d;
  --tk-yellow:      #F5C000;
  --tk-yellow-light:#FDE97A;
  --tk-orange:      #E8650A;
  --tk-white:       #ffffff;
  --tk-off:         #f7f5f0;
  --tk-text:        #1a1a1a;
  --tk-muted:       #5a6a5e;
  --tk-border:      #d4ddd7;
  --tk-err:         #c0392b;
  --tk-err-bg:      #fdf2f2;
  --tk-ok:          #27ae60;
  --tk-ok-bg:       #f2fdf5;
}

/* ── App wrapper ── */
.tk-app {
  max-width: 740px;
  margin: 0 auto;
  padding: .5rem 0;
  font-family: ui-sans-serif, system-ui, -apple-system, Arial, sans-serif;
  color: #1a1a1a;
}

/* ── Header ── */
.tk-header {
  background: var(--tk-green);
  border-radius: 16px;
  padding: 20px 24px;
  margin-bottom: 16px;
  display: flex;
  align-items: center;
  gap: 16px;
}
.tk-brand {
  color: var(--tk-yellow);
  font-size: 18px;
  font-weight: 700;
  letter-spacing: .5px;
}
.tk-brand-sub {
  color: rgba(255,255,255,.6);
  font-size: 11px;
  letter-spacing: 1px;
  margin-top: 1px;
}

/* ── Progress ── */
.tk-prog-wrap {
  background: #e8ede9;
  border-radius: 999px;
  height: 5px;
  margin-bottom: 6px;
  overflow: hidden;
}
.tk-prog-bar {
  height: 5px;
  background: var(--tk-yellow);
  border-radius: 999px;
  transition: width .4s ease;
}
.tk-prog-meta {
  display: flex;
  justify-content: space-between;
  font-size: 11px;
  color: var(--tk-muted);
  margin-bottom: 16px;
}

/* ── Steps ── */
.tk-step         { display: none; }
.tk-step.active  { display: block; }

/* ── Hero tag ── */
.tk-hero-tag {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  background: var(--tk-green);
  color: var(--tk-yellow);
  font-size: 11px;
  font-weight: 600;
  letter-spacing: .8px;
  padding: 5px 12px;
  border-radius: 999px;
  margin-bottom: 14px;
}
.tk-hero-tag span {
  width: 6px;
  height: 6px;
  background: var(--tk-yellow);
  border-radius: 50%;
  flex-shrink: 0;
}

/* ── Typography ── */
.tk-title {
  font-size: 22px;
  font-weight: 700;
  color: var(--tk-green);
  margin-bottom: 8px;
  line-height: 1.3;
}
.tk-subtitle {
  font-size: 14px;
  color: var(--tk-muted);
  margin-bottom: 18px;
  line-height: 1.6;
  max-width: 60ch;
}

/* ── Cards intro ── */
.tk-grid2 {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 10px;
  margin-bottom: 20px;
}
.tk-card {
  background: #fff;
  border: 1px solid var(--tk-border);
  border-radius: 14px;
  padding: 14px;
}
.tk-card-head {
  font-size: 12px;
  font-weight: 700;
  color: var(--tk-green);
  letter-spacing: .5px;
  margin-bottom: 8px;
  display: flex;
  align-items: center;
  gap: 6px;
}
.tk-card-head::before {
  content: '';
  width: 10px;
  height: 3px;
  background: var(--tk-yellow);
  border-radius: 2px;
  flex-shrink: 0;
}
.tk-card ul {
  padding-left: 14px;
  font-size: 13px;
  color: var(--tk-muted);
  line-height: 2;
  margin: 0;
}
.tk-note {
  font-size: 12px;
  color: var(--tk-muted);
  margin-top: 12px;
  padding: 10px 12px;
  background: var(--tk-off);
  border-radius: 8px;
  border-left: 3px solid var(--tk-yellow);
}

/* ── Section (bloc questions) ── */
.tk-section {
  background: #fff;
  border: 1px solid var(--tk-border);
  border-radius: 16px;
  padding: 16px;
  margin-bottom: 12px;
}
.tk-section-head  { margin-bottom: 14px; }
.tk-section-title { font-size: 15px; font-weight: 700; color: var(--tk-green); margin-bottom: 3px; }
.tk-section-sub   { font-size: 12px; color: var(--tk-muted); }
.tk-source        { font-size: 10px; color: var(--tk-orange); font-style: italic; margin-top: 2px; }

/* ── Likert question ── */
.tk-q              { padding: 12px 0; border-top: 1px solid #eef1ee; }
.tk-q:first-of-type{ border-top: none; padding-top: 0; }
.tk-q-txt          { font-size: 13px; color: var(--tk-text); margin-bottom: 10px; line-height: 1.5; font-weight: 500; }
.tk-scale          { display: flex; gap: 6px; align-items: center; flex-wrap: wrap; }
.tk-scale-label    { font-size: 10px; color: var(--tk-muted); white-space: nowrap; }
.tk-chips          { display: flex; gap: 6px; }
.tk-chip {
  width: 40px;
  height: 40px;
  border: 1.5px solid var(--tk-border);
  border-radius: 10px;
  cursor: pointer;
  font-size: 14px;
  font-weight: 700;
  color: var(--tk-muted);
  display: flex;
  align-items: center;
  justify-content: center;
  transition: all .15s;
  background: #fff;
  flex-shrink: 0;
}
.tk-chip:hover { border-color: var(--tk-yellow); color: var(--tk-green); }
.tk-chip.sel   { background: var(--tk-green); border-color: var(--tk-green); color: var(--tk-yellow); }

/* ── DISC ── */
.tk-fc-block  { margin-bottom: 14px; }
.tk-fc-title  { font-size: 13px; font-weight: 700; color: var(--tk-green); margin-bottom: 8px; }
.tk-fc-grid   { display: grid; grid-template-columns: 1fr 1fr; gap: 8px; }
.tk-fc-item   { border: 1.5px solid var(--tk-border); border-radius: 12px; padding: 10px; background: #fff; transition: border-color .15s; }
.tk-fc-item.has-most  { border-color: var(--tk-green); }
.tk-fc-item.has-least { border-color: var(--tk-orange); }
.tk-fc-item.has-both  { border-color: var(--tk-yellow); }
.tk-fc-letter {
  width: 22px;
  height: 22px;
  background: var(--tk-green);
  color: var(--tk-yellow);
  border-radius: 6px;
  font-size: 11px;
  font-weight: 800;
  display: flex;
  align-items: center;
  justify-content: center;
  margin-bottom: 6px;
}
.tk-fc-text    { font-size: 12px; color: var(--tk-muted); margin-bottom: 8px; line-height: 1.5; }
.tk-fc-picks   { display: flex; flex-direction: column; gap: 4px; }
.tk-fc-picks label { font-size: 11px; color: var(--tk-muted); display: flex; align-items: center; gap: 5px; cursor: pointer; }
.tk-fc-picks input[type=radio] { accent-color: var(--tk-orange); }
.tk-fc-hint    { font-size: 11px; color: var(--tk-muted); margin-top: 8px; font-style: italic; }

/* ── Lead form ── */
.tk-field { margin-bottom: 12px; }
.tk-field label {
  font-size: 12px;
  font-weight: 700;
  color: var(--tk-green);
  display: flex;
  align-items: center;
  gap: 4px;
  margin-bottom: 5px;
  letter-spacing: .3px;
}
.tk-field label .req { color: var(--tk-orange); font-size: 14px; line-height: 1; }
.tk-input-wrap { position: relative; }
.tk-input-wrap input,
.tk-input-wrap select {
  width: 100%;
  border: 1.5px solid var(--tk-border);
  border-radius: 10px;
  padding: 10px 36px 10px 12px;
  font-size: 13px;
  color: var(--tk-text);
  background: #fff;
  outline: none;
  transition: border-color .2s;
  appearance: none;
  box-sizing: border-box;
}
.tk-input-wrap input:focus,
.tk-input-wrap select:focus { border-color: var(--tk-green); }
.tk-input-wrap.is-valid input,
.tk-input-wrap.is-valid select { border-color: var(--tk-ok); background: #f9fefb; }
.tk-input-wrap.is-error input,
.tk-input-wrap.is-error select { border-color: var(--tk-err); background: var(--tk-err-bg); }
.tk-icon         { position: absolute; right: 10px; top: 50%; transform: translateY(-50%); font-size: 14px; pointer-events: none; display: none; }
.is-valid .tk-icon-ok  { display: block; color: var(--tk-ok); }
.is-error .tk-icon-err { display: block; color: var(--tk-err); }
.tk-field-msg    { font-size: 11px; margin-top: 4px; min-height: 16px; }
.tk-field-msg.err{ color: var(--tk-err); }
.tk-field-msg.ok { color: var(--tk-ok); }
.tk-field-row    { display: grid; grid-template-columns: 1fr 1fr; gap: 10px; }

/* ── Navigation ── */
.tk-nav {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-top: 16px;
  gap: 10px;
}
.tk-btn {
  padding: 11px 20px;
  border-radius: 12px;
  font-size: 14px;
  font-weight: 700;
  cursor: pointer;
  border: none;
  transition: all .15s;
  letter-spacing: .3px;
}
.tk-btn-primary { background: var(--tk-green); color: var(--tk-yellow); }
.tk-btn-primary:hover { background: var(--tk-green-mid); }
.tk-btn-ghost   { background: transparent; color: var(--tk-muted); border: 1.5px solid var(--tk-border); }
.tk-btn-ghost:hover { border-color: var(--tk-green); color: var(--tk-green); }
.tk-btn-xl      { width: 100%; padding: 14px; font-size: 15px; }
.tk-btn:disabled{ opacity: .55; cursor: not-allowed; }

/* ── Erreur globale ── */
.tk-err {
  color: var(--tk-err);
  font-size: 12px;
  margin-bottom: 12px;
  font-weight: 600;
  padding: 8px 10px;
  background: var(--tk-err-bg);
  border-radius: 8px;
  border-left: 3px solid var(--tk-err);
  display: none;
}
.tk-err.show { display: block; }

/* ── Résultats ── */
.tk-results-header {
  background: var(--tk-green);
  border-radius: 16px;
  padding: 20px 24px;
  margin-bottom: 14px;
  color: #fff;
}
.tk-score-row { display: flex; align-items: baseline; gap: 10px; margin: 8px 0 4px; }
.tk-score-num { font-size: 56px; font-weight: 800; line-height: 1; }
.tk-score-denom { font-size: 20px; opacity: .5; }
.tk-score-tag { font-size: 13px; opacity: .8; margin-top: 4px; line-height: 1.5; }
.tk-score-tagline {
  display: inline-block;
  background: var(--tk-yellow);
  color: var(--tk-green);
  font-size: 13px;
  font-weight: 700;
  padding: 4px 14px;
  border-radius: 999px;
  margin-top: 8px;
}

/* ── KPIs (4 axes) ── */
.tk-kpis { display: grid; grid-template-columns: repeat(4,1fr); gap: 8px; margin-bottom: 14px; }
.tk-kpi { background: #fff; border: 1px solid var(--tk-border); border-radius: 12px; padding: 10px; text-align: center; }
.tk-kpi-lbl { font-size: 10px; color: var(--tk-muted); font-weight: 600; letter-spacing: .3px; margin-bottom: 4px; }
.tk-kpi-val { font-size: 24px; font-weight: 800; }
.tk-kpi-bar { height: 3px; border-radius: 2px; margin-top: 6px; background: #eee; }
.tk-kpi-fill{ height: 3px; border-radius: 2px; }

/* ── Panels résultats ── */
.tk-panel { background: #fff; border: 1px solid var(--tk-border); border-radius: 16px; padding: 14px; }
.tk-panel-title { font-size: 12px; font-weight: 700; color: var(--tk-green); letter-spacing: .5px; margin-bottom: 10px; }

/* ── DISC résultats ── */
.tk-disc-bars { display: flex; flex-direction: column; gap: 8px; }
.tk-disc-row  { display: flex; align-items: center; gap: 8px; }
.tk-disc-ltr  {
  width: 28px;
  height: 28px;
  background: var(--tk-green);
  color: var(--tk-yellow);
  border-radius: 8px;
  font-size: 12px;
  font-weight: 800;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}
.tk-disc-ltr.dominant { background: var(--tk-yellow); color: var(--tk-green); }
.tk-disc-track { flex: 1; background: #eee; border-radius: 4px; height: 8px; }
.tk-disc-fill  { height: 8px; border-radius: 4px; background: var(--tk-green); transition: width .6s ease; }
.tk-disc-fill.dominant { background: var(--tk-yellow); }
.tk-disc-pct   { font-size: 11px; font-weight: 700; color: var(--tk-muted); width: 32px; text-align: right; }

/* ── Analyse section ── */
.tk-analysis { background: #fff; border: 1px solid var(--tk-border); border-radius: 16px; padding: 16px; margin-bottom: 12px; }
.tk-analysis-title {
  font-size: 13px;
  font-weight: 700;
  color: var(--tk-green);
  margin-bottom: 10px;
  display: flex;
  align-items: center;
  gap: 8px;
}
.tk-analysis-title::after { content: ''; flex: 1; height: 1px; background: var(--tk-border); }

/* ── Risques ── */
.tk-risk        { border-radius: 10px; padding: 12px; margin-bottom: 8px; }
.tk-risk-crit   { background: #fdf2f2; border-left: 3px solid #e74c3c; }
.tk-risk-warn   { background: #fdfaf2; border-left: 3px solid var(--tk-yellow); }
.tk-risk-ok     { background: var(--tk-ok-bg); border-left: 3px solid var(--tk-ok); }
.tk-risk-title  { font-size: 13px; font-weight: 700; color: var(--tk-text); margin-bottom: 4px; }
.tk-risk-txt    { font-size: 12px; color: var(--tk-muted); line-height: 1.6; }
.tk-risk-src    { font-size: 10px; color: var(--tk-orange); margin-top: 4px; font-style: italic; }

/* ── Actions ── */
.tk-action       { background: var(--tk-off); border-radius: 10px; padding: 12px; margin-bottom: 8px; border-left: 3px solid var(--tk-green); }
.tk-action-title { font-size: 13px; font-weight: 700; color: var(--tk-green); margin-bottom: 4px; display: flex; align-items: center; gap: 6px; }
.tk-action-num   {
  width: 20px;
  height: 20px;
  background: var(--tk-green);
  color: var(--tk-yellow);
  border-radius: 50%;
  font-size: 11px;
  font-weight: 800;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}
.tk-action-txt { font-size: 12px; color: var(--tk-muted); line-height: 1.6; }
.tk-action-src { font-size: 10px; color: var(--tk-orange); margin-top: 4px; font-style: italic; }

/* ── CTA final ── */
.tk-cta          { background: var(--tk-green); border-radius: 16px; padding: 20px 24px; margin-bottom: 14px; color: #fff; }
.tk-cta-head     { font-size: 11px; color: var(--tk-yellow); font-weight: 700; letter-spacing: 1px; margin-bottom: 8px; }
.tk-cta-title    { font-size: 18px; font-weight: 800; color: #fff; margin-bottom: 8px; line-height: 1.3; }
.tk-cta-txt      { font-size: 13px; color: rgba(255,255,255,.75); margin-bottom: 14px; line-height: 1.6; }
.tk-cta-items    { display: grid; grid-template-columns: 1fr 1fr; gap: 8px; margin-bottom: 16px; }
.tk-cta-item     { background: rgba(255,255,255,.1); border-radius: 10px; padding: 10px 12px; font-size: 12px; color: #fff; }
.tk-cta-item strong { color: var(--tk-yellow); display: block; font-size: 14px; margin-bottom: 2px; }
.tk-cta-btn {
  background: var(--tk-yellow);
  color: var(--tk-green);
  border: none;
  border-radius: 12px;
  padding: 13px 24px;
  font-size: 14px;
  font-weight: 800;
  cursor: pointer;
  letter-spacing: .3px;
  text-decoration: none;
  display: inline-block;
  transition: background .15s;
}
.tk-cta-btn:hover { background: var(--tk-yellow-light); }

/* ── Loader ── */
.tk-loader {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  padding: 48px 24px;
  text-align: center;
}
.tk-spinner {
  width: 40px;
  height: 40px;
  border: 3px solid #e8ede9;
  border-top-color: var(--tk-yellow);
  border-radius: 50%;
  animation: tec-spin .8s linear infinite;
  margin-bottom: 16px;
}
@keyframes tec-spin { to { transform: rotate(360deg); } }

/* ── Select dropdown arrow custom ── */
.tk-input-wrap {
  position: relative;
}
.tk-input-wrap select {
  padding-right: 36px;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%235a6a5e' stroke-width='1.5' fill='none' stroke-linecap='round'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: right 12px center;
  cursor: pointer;
}

/* ── Header — logo icon ── */
.tk-header-logo {
  width: 42px;
  height: 42px;
  background: rgba(255,255,255,.1);
  border: 1.5px solid rgba(245,192,0,.4);
  border-radius: 10px;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  font-size: 12px;
  font-weight: 900;
  color: var(--tk-yellow);
  letter-spacing: .5px;
}

/* ── Step 5 lead — badge dédicacé ── */
.tk-lead-badge {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  background: rgba(245,192,0,.12);
  border: 1px solid rgba(245,192,0,.35);
  color: var(--tk-yellow);
  font-size: 11px;
  font-weight: 700;
  letter-spacing: .8px;
  padding: 5px 12px;
  border-radius: 999px;
  margin-bottom: 14px;
}

/* ── Results — section de contexte global ── */
.tk-context-bar {
  background: var(--tk-off);
  border: 1px solid var(--tk-border);
  border-radius: 12px;
  padding: 12px 16px;
  display: flex;
  align-items: center;
  gap: 12px;
  margin-bottom: 14px;
  font-size: 12px;
  color: var(--tk-muted);
  line-height: 1.6;
}
.tk-context-bar strong { color: var(--tk-green); }

/* ── CTA — accroches personnalisées ── */
.tk-score-cta {
  display: flex;
  align-items: baseline;
  gap: 6px;
  margin: 6px 0 20px;
}
.tk-cta-accroches {
  display: flex;
  flex-direction: column;
  gap: 10px;
  margin-bottom: 20px;
}
.tk-cta-accroche {
  display: flex;
  align-items: flex-start;
  gap: 10px;
  font-size: 15px;
  font-weight: 700;
  color: #fff;
  line-height: 1.4;
}
.tk-cta-dash {
  color: var(--tk-yellow);
  font-size: 18px;
  line-height: 1.2;
  flex-shrink: 0;
}
.tk-cta-transition {
  font-size: 13px;
  color: rgba(255,255,255,.7);
  margin-bottom: 20px;
  line-height: 1.6;
  font-style: italic;
}
.tk-cta-reassurance {
  font-size: 11px;
  color: rgba(255,255,255,.4);
  margin-top: 12px;
  letter-spacing: .3px;
}

/* ── Responsive ── */
@media (max-width: 600px) {
  .tk-grid2        { grid-template-columns: 1fr; }
  .tk-kpis         { grid-template-columns: repeat(2, 1fr); }
  .tk-fc-grid      { grid-template-columns: 1fr; }
  .tk-field-row    { grid-template-columns: 1fr; }
  .tk-cta-items    { grid-template-columns: 1fr; }
  .tk-cta-items-8  { grid-template-columns: 1fr; }
  .tk-score-num    { font-size: 44px; }
  .tk-title        { font-size: 19px; }
  .tk-chips        { flex-wrap: wrap; }
}
