/* Thiqa — système de design partagé (app + fiche publique) */
:root{
  --cream:oklch(96.8% 0.016 84);--cream-2:oklch(99.3% 0.006 86);--cream-3:oklch(94.6% 0.02 82);
  --ink:oklch(26% 0.026 138);--ink-2:oklch(42% 0.024 134);--ink-3:oklch(56% 0.02 126);
  --green:oklch(53% 0.108 150);--green-d:oklch(41% 0.092 152);--green-dd:oklch(33% 0.07 154);--green-soft:oklch(93.5% 0.045 150);
  --honey:oklch(81% 0.13 80);--honey-d:oklch(66% 0.12 70);--honey-soft:oklch(94% 0.06 82);
  --terra:oklch(63% 0.14 44);
  --ok:oklch(56% 0.12 150);--warn:oklch(76% 0.13 75);--bad:oklch(58% 0.16 28);
  --line:oklch(88.5% 0.018 86);--line-2:oklch(82% 0.024 82);
  --r:14px;--r-lg:20px;--r-xl:28px;
  --sh-s:0 1px 2px oklch(40% 0.04 120/.06),0 4px 10px oklch(40% 0.04 120/.05);
  --sh:0 3px 8px oklch(40% 0.04 120/.06),0 18px 40px oklch(40% 0.05 120/.09);
  --sh-lg:0 8px 20px oklch(40% 0.05 120/.09),0 40px 80px oklch(36% 0.06 120/.16);
  --t-xs:clamp(.72rem,.7rem+.1vw,.8rem);--t-sm:clamp(.85rem,.82rem+.16vw,.94rem);
  --t-base:clamp(.97rem,.93rem+.2vw,1.05rem);--t-md:clamp(1.1rem,1rem+.4vw,1.3rem);
  --t-lg:clamp(1.4rem,1.1rem+1vw,1.9rem);--t-xl:clamp(1.7rem,1.3rem+1.8vw,2.4rem);
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{background:var(--cream);color:var(--ink);font-family:"Plus Jakarta Sans",system-ui,sans-serif;font-size:var(--t-base);line-height:1.6;-webkit-font-smoothing:antialiased;overflow-x:hidden}
body::before{content:"";position:fixed;inset:0;z-index:0;pointer-events:none;opacity:.55;mix-blend-mode:multiply;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='220' height='220'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.8' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.03'/%3E%3C/svg%3E")}
h1,h2,h3,h4{font-family:"Bricolage Grotesque",system-ui,sans-serif;font-weight:600;line-height:1.06;letter-spacing:-.02em;color:var(--ink)}
a{color:inherit;text-decoration:none}
.mono{font-family:ui-monospace,"SF Mono",Menlo,monospace;font-size:.92em;font-variant-numeric:tabular-nums}
.app-main{position:relative;z-index:1}

/* buttons */
.btn{font-family:inherit;font-size:var(--t-sm);font-weight:700;cursor:pointer;border:none;padding:.8rem 1.3rem;border-radius:999px;display:inline-flex;align-items:center;justify-content:center;gap:.5rem;white-space:nowrap;transition:transform .18s cubic-bezier(.34,1.4,.5,1),background .2s,color .2s,border-color .2s,box-shadow .2s;line-height:1}
.btn:active{transform:scale(.97)}
.btn svg{width:16px;height:16px}
.btn-pri{background:var(--green);color:var(--cream-2);box-shadow:0 6px 16px oklch(53% 0.1 150/.3)}
.btn-pri:hover{background:var(--green-d);transform:translateY(-1px)}
.btn-soft{background:var(--cream-2);color:var(--ink);border:1.5px solid var(--line-2)}
.btn-soft:hover{border-color:var(--green);color:var(--green-d)}
.btn-block{width:100%}
.btn-lg{padding:1rem 1.6rem;font-size:var(--t-base)}

/* header */
.hdr{position:sticky;top:0;z-index:50;background:oklch(96.8% 0.016 84/.85);backdrop-filter:blur(14px);border-bottom:1px solid var(--line)}
.hdr-in{display:flex;align-items:center;justify-content:space-between;height:64px;width:min(100% - 2rem,72rem);margin-inline:auto}
.brand{display:flex;align-items:center;gap:.55rem;cursor:pointer}
.brand b{font-family:"Bricolage Grotesque";font-weight:800;font-size:1.3rem;letter-spacing:-.03em}
.hdr a{font-size:var(--t-sm);font-weight:600;color:var(--ink-2)}
.hdr a:hover{color:var(--green-d)}
.hdr .row{display:flex;align-items:center;gap:1rem}

/* layout */
.shell{width:min(100% - 2rem,72rem);margin:2rem auto;display:grid;grid-template-columns:1.05fr .95fr;gap:1.6rem;align-items:start;position:relative;z-index:1}
@media(max-width:880px){.shell{grid-template-columns:1fr}}
.sticky{position:sticky;top:84px}
@media(max-width:880px){.sticky{position:static}}

/* card / panel */
.card{background:var(--cream-2);border:1px solid var(--line);border-radius:var(--r-lg);padding:1.6rem;box-shadow:var(--sh-s);margin-bottom:1.2rem}
.card h3{font-size:var(--t-md);margin-bottom:.3rem}
.card .hint{color:var(--ink-3);font-size:var(--t-sm);margin-bottom:1.1rem}
.steplabel{display:inline-flex;align-items:center;gap:.5rem;font-size:.66rem;font-weight:800;letter-spacing:.1em;text-transform:uppercase;color:var(--green-d);margin-bottom:.6rem}
.steplabel .n{width:22px;height:22px;border-radius:50%;background:var(--green-soft);display:grid;place-items:center;color:var(--green-d)}

/* fields */
.field{display:grid;gap:.4rem;margin-bottom:1rem}
.field label{font-size:.66rem;font-weight:700;letter-spacing:.07em;text-transform:uppercase;color:var(--ink-3)}
.field input,.field select{font-family:inherit;font-size:var(--t-sm);padding:.78rem .9rem;border:1px solid var(--line-2);border-radius:10px;background:var(--cream);color:var(--ink);width:100%}
.field input:focus,.field select:focus{outline:2px solid var(--green);outline-offset:1px;border-color:var(--green)}
.grid2{display:grid;grid-template-columns:1fr 1fr;gap:.9rem}
@media(max-width:520px){.grid2{grid-template-columns:1fr}}
.check{display:flex;align-items:center;gap:.6rem;font-size:var(--t-sm);font-weight:600;cursor:pointer;color:var(--ink-2)}
.check input{width:20px;height:20px;accent-color:var(--green)}
.prodrow{display:grid;grid-template-columns:1fr 1fr auto;gap:.6rem;margin-bottom:.6rem;align-items:center}
@media(max-width:520px){.prodrow{grid-template-columns:1fr 1fr}}
.prodrow button{background:none;border:none;color:var(--ink-3);cursor:pointer;font-size:1.2rem;padding:.3rem}
.addrow{font-size:var(--t-sm);font-weight:700;color:var(--green-d);background:var(--green-soft);border:none;padding:.55rem .9rem;border-radius:999px;cursor:pointer;display:inline-flex;align-items:center;gap:.4rem}

/* certificate / fiche */
.cert{background:var(--cream-2);border-radius:var(--r-xl);overflow:hidden;box-shadow:var(--sh-lg);border:1px solid var(--line)}
.cert-top{position:relative;padding:1.8rem 1.5rem 1.4rem;text-align:center;color:var(--cream-2);overflow:hidden}
.cert-top.ok{background:linear-gradient(160deg,var(--green),var(--green-dd))}
.cert-top.bad{background:linear-gradient(160deg,oklch(54% 0.15 30),oklch(40% 0.12 30))}
.sealwrap{width:84px;margin:.2rem auto .8rem}
.verdict{display:inline-flex;align-items:center;gap:.4rem;background:oklch(100% 0 0/.2);padding:.4rem .9rem;border-radius:999px;font-size:.68rem;font-weight:800;letter-spacing:.04em;text-transform:uppercase;margin-bottom:.3rem}
.verdict svg{width:14px;height:14px}
.cert-top h2{color:var(--cream-2);font-size:var(--t-lg)}.cert-top .loc{font-size:var(--t-sm);opacity:.86}
.chainbar{display:flex;align-items:center;justify-content:center;gap:.45rem;background:var(--cream);padding:.7rem;border-bottom:1px solid var(--line);font-size:.7rem;font-weight:700;color:var(--ink-2);flex-wrap:wrap}
.chainbar svg{width:14px;height:14px;color:var(--green)}.chainbar .c{display:inline-flex;align-items:center;gap:.3rem}
.cert-body{padding:.4rem 1.5rem 1rem}
.dl{display:grid;grid-template-columns:auto 1fr;gap:1rem;align-items:baseline;padding:.85rem 0;border-bottom:1px solid var(--line)}
.dl:last-child{border-bottom:none}
.dl .k{font-size:.62rem;text-transform:uppercase;letter-spacing:.08em;color:var(--ink-3);font-weight:700;white-space:nowrap}
.dl .v{text-align:right;font-size:var(--t-sm);font-weight:700;color:var(--ink)}
.dl .v small{display:block;font-weight:500;color:var(--ink-3);font-size:.7rem;margin-top:1px}
.dl .v .reg{font-weight:500;color:var(--ink-2)}
.local{display:inline-flex;align-items:center;gap:.3rem;font-size:.64rem;font-weight:700;color:var(--green-d);background:var(--green-soft);padding:.2rem .55rem;border-radius:999px;margin-top:.35rem}
.local svg{width:12px;height:12px}
.cert-foot{padding:1rem 1.5rem;background:var(--cream);text-align:center;border-top:1px solid var(--line)}
.cert-foot small{font-size:.64rem;color:var(--ink-3)}

.stampin{animation:stampin .7s cubic-bezier(.2,1.5,.4,1) both}
@keyframes stampin{0%{opacity:0;transform:scale(1.4) rotate(-12deg)}60%{opacity:1}100%{opacity:1;transform:scale(1) rotate(-4deg)}}
@media(prefers-reduced-motion:reduce){.stampin{animation:none}}

/* qr */
.qrwrap{text-align:center}
#qrbox{width:188px;height:188px;margin:1rem auto;display:grid;place-items:center;background:#fff;border-radius:12px;padding:11px;border:1px solid var(--line)}
#qrbox img,#qrbox canvas{display:block;border-radius:4px}
.linkrow{display:flex;gap:.5rem;align-items:center;background:var(--cream);border:1px solid var(--line-2);border-radius:10px;padding:.5rem .7rem;margin-top:.8rem}
.linkrow input{flex:1;border:none;background:none;font-size:.78rem;color:var(--ink-2);font-family:ui-monospace,monospace;outline:none}

/* status pill */
.pill{display:inline-flex;align-items:center;gap:.4rem;font-size:.66rem;font-weight:800;padding:.32rem .7rem;border-radius:999px}
.pill.ok{background:var(--green-soft);color:var(--green-d)}
.pill.warn{background:var(--honey-soft);color:var(--honey-d)}
.pill.bad{background:oklch(93% 0.05 28);color:var(--bad)}
.pill .d{width:7px;height:7px;border-radius:50%;background:currentColor}

/* tabs (mobile toggle) */
.seg{display:inline-flex;background:var(--cream-2);border:1px solid var(--line-2);border-radius:999px;padding:3px;gap:2px;margin-bottom:1rem}
.seg button{font-family:inherit;font-size:var(--t-xs);font-weight:700;border:none;background:none;padding:.5rem .9rem;border-radius:999px;cursor:pointer;color:var(--ink-3)}
.seg button.on{background:var(--green);color:var(--cream-2)}

/* public page */
.pub{width:min(100% - 2rem,430px);margin:2.5rem auto;position:relative;z-index:1}
.pub .foot-note{text-align:center;font-size:var(--t-xs);color:var(--ink-3);margin-top:1.3rem;line-height:1.5}
.pub .cta-mini{text-align:center;margin-top:1.4rem}

.toast{position:fixed;bottom:24px;left:50%;transform:translateX(-50%) translateY(16px);background:var(--ink);color:var(--cream);padding:.8rem 1.3rem;border-radius:999px;font-size:var(--t-sm);font-weight:600;opacity:0;transition:.3s;z-index:99;box-shadow:var(--sh-lg)}
.toast.show{opacity:1;transform:translateX(-50%)}

@media print{
  .hdr,.editor-col,.seg,.no-print,.toast,body::before{display:none!important}
  .shell{display:block;margin:0}
  body{background:#fff}
  .print-card{box-shadow:none}
}

/* =====================================================================
   COUCHE PREMIUM — composants ajoutés pour app.html & me.html (v2)
   Toutes les classes ci-dessous sont NOUVELLES (préfixe app-/me-/x-)
   ou des enrichissements non destructifs. Ne pas écraser l'existant.
   ===================================================================== */

/* aura douce de fond, partagée avec la landing */
.x-aura{position:fixed;inset:0;z-index:0;pointer-events:none;background:
  radial-gradient(38% 32% at 82% 6%,var(--honey-soft),transparent 70%),
  radial-gradient(42% 38% at 4% 18%,var(--green-soft),transparent 72%),
  radial-gradient(48% 42% at 96% 94%,oklch(93% 0.04 80/.6),transparent 76%)}

/* ----- En-tête enrichi (espace commerçant) ----- */
.hdr .row .plan,.hdr .row .saveind{transition:.2s}
.plan-dot{width:7px;height:7px;border-radius:50%;background:currentColor;box-shadow:0 0 0 3px oklch(56% 0.12 150/.18)}
.saveind{display:inline-flex;align-items:center;gap:.35rem}
.saveind::before{content:"";width:6px;height:6px;border-radius:50%;background:var(--ink-3);opacity:.5}
.saveind[data-state="saving"]::before{background:var(--honey-d);opacity:1;animation:savepulse 1s ease-in-out infinite}
.saveind[data-state="saved"]::before{background:var(--ok);opacity:1}
.saveind[data-state="error"]::before{background:var(--bad);opacity:1}
@keyframes savepulse{50%{opacity:.35;transform:scale(.7)}}
@media(prefers-reduced-motion:reduce){.saveind[data-state="saving"]::before{animation:none}}

/* ----- Bandeau de page (titre + sous-titre) ----- */
.app-head{width:min(100% - 2rem,72rem);margin:1.6rem auto .2rem;position:relative;z-index:1}
.app-head .eyebrow{display:inline-flex;align-items:center;gap:.45rem;font-size:var(--t-xs);font-weight:800;letter-spacing:.08em;text-transform:uppercase;color:var(--green-d);background:oklch(95% 0.03 150/.6);border:1px solid oklch(82% 0.05 150);border-radius:999px;padding:.32rem .8rem}
.app-head .eyebrow .d{width:7px;height:7px;border-radius:50%;background:var(--ok);box-shadow:0 0 0 3px oklch(56% 0.12 150/.2)}
.app-head h1{font-size:var(--t-lg);margin-top:.7rem;letter-spacing:-.03em}
.app-head p{color:var(--ink-2);font-size:var(--t-sm);margin-top:.25rem;max-width:54ch;font-weight:500}

/* ----- Carte d'étape enrichie ----- */
.card.step-card{position:relative;transition:border-color .25s,box-shadow .25s,transform .25s}
.card.step-card:focus-within{border-color:oklch(80% 0.05 150);box-shadow:var(--sh-s),0 0 0 3px oklch(56% 0.12 150/.1)}
.steplabel .n{font-size:.72rem}
/* étape "remplie" : la pastille passe au vert plein */
.step-card.done .steplabel .n{background:var(--green);color:var(--cream-2)}
.step-card .substep{font-size:var(--t-sm);color:var(--ink-2);font-weight:500;margin:-.1rem 0 1rem}

/* ----- Barre de progression de la fiche ----- */
.fill-track{width:min(100% - 2rem,72rem);margin:.2rem auto 0;position:relative;z-index:1}
.fill-bar{height:8px;border-radius:999px;background:var(--cream-3);overflow:hidden;border:1px solid var(--line)}
.fill-bar > i{display:block;height:100%;border-radius:999px;background:linear-gradient(90deg,var(--green),var(--green-d));transition:width .5s cubic-bezier(.16,1,.3,1)}

/* ----- Aperçu / badge mis en valeur ----- */
.preview-col .sticky{display:grid;gap:1rem}
.qrwrap{border-radius:var(--r-xl);background:linear-gradient(168deg,var(--cream-2),oklch(97% 0.012 84));border:1px solid var(--line)}
.qrwrap .steplabel{margin-bottom:.4rem}
#qrbox{box-shadow:var(--sh-s)}
.qr-note{display:inline-flex;align-items:center;gap:.4rem;justify-content:center}

/* ----- Boutons compacts d'en-tête ----- */
.btn-sm{padding:.5rem .9rem;font-size:var(--t-xs)}
.btn-ghost{background:transparent;border:1.5px solid transparent;color:var(--ink-2)}
.btn-ghost:hover{border-color:var(--line-2);color:var(--green-d)}

/* =====================================================================
   ESPACE CLIENT (me.html) — enrichissements
   ===================================================================== */
/* la carte commerce (générée par JS, classe .scard) */
.scard{transition:transform .22s cubic-bezier(.16,1,.3,1),box-shadow .22s,border-color .22s}
.scard:hover{transform:translateY(-3px);box-shadow:var(--sh);border-color:oklch(85% 0.03 120)}
.scard .acts .see{transition:background .2s,transform .15s;box-shadow:0 4px 12px oklch(53% 0.1 150/.22)}
.scard .acts .see:hover{background:var(--green-d);transform:translateY(-1px)}
.scard .acts .fav{transition:.18s;line-height:1}
.scard .acts .fav:hover{border-color:var(--green);color:var(--green-d);background:var(--green-soft)}

/* barre de recherche premium */
.searchwrap{position:relative}
.searchwrap .ic{position:absolute;left:1rem;top:50%;transform:translateY(-50%);color:var(--ink-3);pointer-events:none;display:grid;place-items:center}
.searchwrap .ic svg{width:18px;height:18px}
.searchbar input{transition:border-color .2s,box-shadow .2s,background .2s}
.searchbar.has-ic input{padding-left:2.6rem}
.searchbar input:focus{box-shadow:0 0 0 4px oklch(56% 0.12 150/.12)}

/* en-tête de section enrichi */
.sect .h h2{display:flex;align-items:center;gap:.5rem;letter-spacing:-.02em}
.sect .h h2 .sicon{color:var(--green-d);display:grid;place-items:center}
.sect .h h2 .sicon svg{width:20px;height:20px}

/* alerte certificat — plus présente */
.alert{box-shadow:var(--sh-s);align-items:center;line-height:1.4}
.alert .aicon{flex:none;width:26px;height:26px;border-radius:8px;background:oklch(88% 0.1 75);color:var(--honey-d);display:grid;place-items:center}
.alert .aicon svg{width:15px;height:15px}
.alert.bad{background:oklch(95% 0.04 28);border-color:oklch(86% 0.06 28);color:var(--bad)}
.alert.bad .aicon{background:oklch(90% 0.07 28);color:var(--bad)}

/* états vides plus soignés */
.empty{display:grid;gap:.55rem;justify-items:center;line-height:1.5}
.empty .eicon{width:46px;height:46px;border-radius:14px;background:var(--cream-3);color:var(--green-d);display:grid;place-items:center;margin-bottom:.1rem}
.empty .eicon svg{width:22px;height:22px}

/* chips d'historique */
.chip{display:inline-flex;align-items:center;gap:.4rem;transition:.18s;box-shadow:var(--sh-s)}
.chip::before{content:"";width:5px;height:5px;border-radius:50%;background:var(--honey);flex:none}
.chip:hover{transform:translateY(-1px)}

/* apparition douce des cartes */
.x-rise{animation:xrise .5s cubic-bezier(.16,1,.3,1) both}
@keyframes xrise{0%{opacity:0;transform:translateY(10px)}100%{opacity:1;transform:none}}
@media(prefers-reduced-motion:reduce){.x-rise{animation:none}}
