  :root{
    --wall:#0c0c0c;
    --wall-2:#171717;
    --wall-3:#242424;
    --paper:#faf9f5;
    --ink:#1b1b17;
    --ink-2:#827f76;
    --t1:var(--t1);
    --t2:#c4c3ba;
    --t3:var(--t3);
    --line:rgba(255,255,255,.10);
    --line-strong:var(--line-strong);
    --line-d:rgba(0,0,0,.10);
    --header-bg:rgba(12,12,12,.82);
    --chip-bg:var(--chip-bg);
    --ico-fg:var(--ico-fg);
    --accent:#2d5bff;
    --accent-press:#1e45d8;
    --ok:#1fa971;
    --radius:7px;
    --maxw:1320px;
    --narrow:1020px;
  }
  :root[data-theme="light"]{
    --wall:#f6f5f1;
    --wall-2:#ffffff;
    --wall-3:#e9e7e0;
    --paper:#1b1b17;
    --ink:#faf9f5;
    --ink-2:#76756b;
    --t1:#26261f;
    --t2:#55544c;
    --t3:#9a998f;
    --line:rgba(0,0,0,.12);
    --line-strong:rgba(0,0,0,.30);
    --header-bg:rgba(246,245,241,.86);
    --chip-bg:rgba(0,0,0,.06);
    --ico-fg:#2d5bff;
  }
  *{box-sizing:border-box}
  html{-webkit-text-size-adjust:100%}
  body{
    margin:0;
    background:var(--wall);
    color:var(--paper);
    font-family:"Inter",system-ui,sans-serif;
    font-size:15px;
    line-height:1.5;
    -webkit-font-smoothing:antialiased;
  }
  a{color:inherit;text-decoration:none}
  button{font-family:inherit;cursor:pointer}
  ::selection{background:var(--accent);color:#fff}

  .wrap{max-width:var(--maxw);margin:0 auto;padding:0 22px}
  .bleed{padding:0 28px}
  .narrow{max-width:var(--narrow);margin:0 auto;padding:0 28px}
  @media(max-width:760px){.bleed,.narrow{padding:0 16px}}

  /* ---------- header ---------- */
  header{
    position:sticky;top:0;z-index:40;
    background:var(--header-bg);
    backdrop-filter:saturate(140%) blur(10px);
    border-bottom:1px solid var(--line);
  }
  .bar{display:flex;align-items:center;gap:18px;height:62px}
  .mark{
    font-family:"Inter",system-ui,sans-serif;
    font-weight:800;font-size:21px;letter-spacing:-.02em;
    display:flex;align-items:center;gap:9px;white-space:nowrap;
  }
  .mark .dot{width:11px;height:11px;border-radius:2px;background:var(--accent);display:inline-block;transform:rotate(45deg)}
  .count{
    font-family:"Inter",system-ui,sans-serif;font-size:12px;
    color:var(--ink-2);border-left:1px solid var(--line);padding-left:18px;white-space:nowrap;
  }
  .count b{color:var(--paper);font-weight:500}
  .search{margin-left:auto;position:relative;flex:0 1 320px;min-width:0}
  .search input{
    width:100%;height:38px;border-radius:var(--radius);
    background:var(--wall-2);border:1px solid var(--line);
    color:var(--paper);padding:0 14px 0 36px;font-size:14px;outline:none;
  }
  .search input::placeholder{color:var(--t3)}
  .search input:focus{border-color:var(--accent)}
  .search svg{position:absolute;left:12px;top:50%;transform:translateY(-50%);opacity:.5}

  /* ---------- hero ---------- */
  .hero{padding:54px 0 30px;text-align:center}
  .hero h1{
    font-family:"Inter",system-ui,sans-serif;
    font-weight:700;letter-spacing:-.035em;line-height:.98;
    font-size:clamp(34px,7vw,60px);margin:0 auto 16px;max-width:18ch;
  }
  .hero h1 em{font-style:normal;color:var(--accent)}
  .hero p{
    color:var(--t2);font-size:clamp(15px,1.6vw,18px);max-width:56ch;margin:0 auto 30px;
  }
  /* hero main search — full container width */
  .hero-search{position:relative;width:100%}
  .hero-search svg{position:absolute;left:22px;top:50%;transform:translateY(-50%);opacity:.55}
  .hero-search input{
    width:100%;height:64px;border-radius:12px;text-align:left;
    background:var(--wall-2);border:1px solid var(--line);
    color:var(--paper);padding:0 120px 0 56px;font-size:17px;outline:none;
    font-family:"Inter",system-ui,sans-serif;transition:border-color .15s,box-shadow .15s;
  }
  .hero-search input::placeholder{color:var(--t3)}
  .hero-search input:focus{border-color:var(--accent);box-shadow:0 0 0 4px rgba(45,91,255,.18)}
  .hero-search .kbd{
    position:absolute;right:18px;top:50%;transform:translateY(-50%);
    font-size:11px;letter-spacing:.04em;color:var(--ink-2);
    border:1px solid var(--line);border-radius:6px;padding:5px 9px;background:var(--wall);
  }
  .hero-hits{
    margin-top:12px;font-size:12.5px;color:var(--ink-2);min-height:18px;letter-spacing:.02em;
  }
  .hero-hits b{color:var(--paper);font-weight:500}

  /* ---------- categories ---------- */
  .cats{padding:6px 0 28px;border-bottom:1px solid var(--line);margin-bottom:30px}
  .cat-head{display:flex;align-items:center;gap:14px;margin-bottom:16px;flex-wrap:wrap}
  .cat-tabs{display:inline-flex;gap:2px;background:var(--wall-2);border:1px solid var(--line);border-radius:10px;padding:3px}
  .cat-tab{
    background:transparent;border:0;color:var(--t2);border-radius:7px;
    padding:8px 16px;font-family:"Inter",system-ui,sans-serif;font-size:13px;letter-spacing:.01em;
    transition:background .15s,color .15s;
  }
  .cat-tab:hover{color:var(--paper)}
  .cat-tab[aria-selected="true"]{background:var(--paper);color:var(--ink)}
  .cat-reset{
    background:transparent;border:0;color:var(--accent);font-family:"Inter",system-ui,sans-serif;
    font-size:12px;letter-spacing:.02em;padding:6px 4px;
  }
  .cat-reset:hover{text-decoration:underline}
  .cat-axis-label{
    font-family:"Inter",system-ui,sans-serif;font-size:11px;letter-spacing:.1em;text-transform:uppercase;
    color:var(--ink-2);margin-left:auto;
  }
  .cat-strip{
    display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));
    gap:12px;padding:4px 2px 2px;
  }
  /* Respecte hidden pose par le JS des onglets (sinon display:grid reaffiche) */
  .cat-strip[hidden]{display:none;}
  .cat-tile{
    position:relative;width:100%;height:104px;border-radius:10px;overflow:hidden;
    border:0;padding:0;cursor:pointer;
    background:var(--wall-3);box-shadow:inset 0 0 0 1px var(--line);
    transition:transform .18s ease,box-shadow .18s ease;
  }
  .cat-tile img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;opacity:.62;transition:opacity .2s,transform .3s}
  .cat-tile::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(15,15,12,.1),rgba(15,15,12,.78))}
  .cat-tile:hover{transform:translateY(-2px)}
  .cat-tile:hover img{opacity:.8;transform:scale(1.05)}
  .cat-tile:focus-visible{outline:3px solid var(--accent);outline-offset:2px}
  .cat-tile .cn{
    position:absolute;left:13px;bottom:11px;z-index:2;color:#fff;
    font-family:"Inter",system-ui,sans-serif;font-size:14px;font-weight:500;letter-spacing:-.01em;
  }
  .cat-tile .cc{
    position:absolute;right:11px;top:10px;z-index:2;
    font-family:"Inter",system-ui,sans-serif;font-size:11px;color:#fff;
    background:rgba(15,15,12,.55);border-radius:100px;padding:3px 8px;backdrop-filter:blur(3px);
  }
  .cat-tile[aria-pressed="true"]{box-shadow:0 0 0 2px var(--accent),0 0 0 5px rgba(45,91,255,.25)}
  .cat-tile[aria-pressed="true"] img{opacity:.9}
  .cat-tile[aria-pressed="true"] .cn{color:#fff}

  /* ---------- gallery ---------- */
  .gallery{
    display:grid;
    grid-template-columns:repeat(6,1fr);
    gap:0;padding-bottom:0;
  }
  .card{
    position:relative;display:block;width:100%;aspect-ratio:3/4;overflow:hidden;
    background:var(--wall-3);border:0;padding:0;margin:0;text-align:left;color:var(--ink);
    cursor:pointer;
  }
  .card:focus-visible{outline:3px solid var(--accent);outline-offset:-3px;z-index:2}
  .thumb{position:absolute;inset:0;display:block;overflow:hidden}
  .thumb img{display:block;width:100%;height:100%;object-fit:cover;transition:transform .4s ease}
  .card:hover .thumb img{transform:scale(1.04)}
  .reveal{
    position:absolute;inset:0;padding:14px;display:flex;flex-direction:column;justify-content:flex-end;gap:8px;
    background:linear-gradient(180deg,rgba(15,15,12,0) 35%,rgba(15,15,12,.92) 100%);
    opacity:0;transition:opacity .2s ease;
  }
  .card:hover .reveal,.card:focus-visible .reveal{opacity:1}
  .reveal-model{
    align-self:flex-start;font-family:"Inter",system-ui,sans-serif;font-size:10.5px;letter-spacing:.04em;
    color:#fff;background:var(--accent);border-radius:100px;padding:4px 9px;line-height:1;
  }
  .reveal-txt{
    font-family:"Inter",system-ui,sans-serif;font-size:12px;line-height:1.45;color:#f2f1ec;
    display:-webkit-box;-webkit-line-clamp:5;-webkit-box-orient:vertical;overflow:hidden;
  }
  .more{display:flex;justify-content:center;padding:14px 0 64px}
  .more button{
    background:var(--wall-2);border:1px solid var(--line);color:var(--paper);
    border-radius:var(--radius);padding:12px 26px;font-size:14px;font-weight:500;
    transition:background .15s,border-color .15s;
  }
  .more button:hover{background:var(--wall-3);border-color:var(--line-strong)}
  .empty{text-align:center;color:var(--ink-2);padding:60px 0 80px;font-family:"Inter",system-ui,sans-serif;font-size:13px}

  /* ---------- dedicated prompt page ---------- */
  #promptView{padding-top:30px;padding-bottom:60px}
  .pp-back{
    display:inline-flex;align-items:center;gap:7px;color:var(--ink-2);font-size:13px;
    margin-bottom:22px;transition:color .15s;
  }
  .pp-back:hover{color:var(--paper)}
  .pp-grid{display:grid;grid-template-columns:minmax(0,1fr) minmax(0,1.05fr);gap:32px;align-items:start}
  .pp-media{border-radius:12px;overflow:hidden;background:var(--wall-3);position:sticky;top:84px}
  .pp-media img{display:block;width:100%;height:auto}
  .pp-info{min-width:0}
  .pp-bread{font-size:12px;color:var(--ink-2);margin-bottom:12px}
  .pp-bread a{color:var(--ink-2)}
  .pp-bread a:hover{color:var(--paper)}
  .pp-info h1{
    font-size:clamp(22px,3vw,30px);font-weight:700;letter-spacing:-.02em;line-height:1.18;margin:0 0 16px;
  }
  .pp-tags{display:flex;flex-wrap:wrap;gap:7px;margin:0}
  .tag{
    font-size:12px;letter-spacing:.01em;border:1px solid var(--line);border-radius:100px;
    padding:5px 11px;color:var(--t2);background:var(--wall-2);transition:border-color .15s,color .15s;cursor:pointer;
  }
  .tag:hover{border-color:var(--accent);color:#fff}
  .pp-prompt-h{
    font-size:11px;letter-spacing:.09em;text-transform:uppercase;color:var(--ink-2);
    display:flex;align-items:center;justify-content:space-between;margin-bottom:9px;
  }
  .pp-prompt{
    background:var(--wall-2);border:1px solid var(--line);border-radius:10px;
    font-size:15px;line-height:1.65;color:var(--t1);
    padding:18px;white-space:pre-wrap;word-break:break-word;
  }
  .copy{
    margin-top:16px;background:var(--accent);color:#fff;border:0;border-radius:10px;
    height:50px;font-size:15px;font-weight:600;display:flex;align-items:center;justify-content:center;gap:9px;
    transition:background .15s;width:100%;cursor:pointer;
  }
  .copy:hover{background:var(--accent-press)}
  .copy.done{background:var(--ok)}
  .pp-model{font-size:13px;color:var(--ink-2);margin-top:18px}
  .pp-model b{color:var(--paper);font-weight:600}
  .pp-related{margin-top:54px;border-top:1px solid var(--line);padding-top:34px}
  .pp-related h2{font-size:26px;font-weight:700;letter-spacing:-.03em;margin:0 0 20px}
  @media(max-width:720px){
    .pp-grid{grid-template-columns:1fr;gap:22px}
    .pp-media{position:static}
  }

  footer{border-top:1px solid var(--line);margin-top:46px;padding:46px 0 34px;color:var(--ink-2);font-size:13px}
  .foot-grid{display:grid;grid-template-columns:1.7fr 1fr 1fr;gap:40px;margin-bottom:32px}
  .foot-brand .mark{font-size:18px;color:var(--paper)}
  .foot-tag{margin:12px 0 0;max-width:44ch;line-height:1.65;color:var(--ink-2)}
  .foot-col h4{font-size:11px;text-transform:uppercase;letter-spacing:.08em;color:var(--t3);margin:0 0 13px;font-weight:600}
  .foot-col ul{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:10px}
  .foot-col a{color:var(--t2);transition:color .15s}
  .foot-col a:hover{color:var(--paper)}
  .foot-bottom{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:14px;border-top:1px solid var(--line);padding-top:22px}
  .foot-bottom .note{font-size:12px}
  .foot-top{background:var(--wall-2);border:1px solid var(--line);color:var(--paper);border-radius:8px;padding:8px 15px;font-size:13px;cursor:pointer;transition:border-color .15s}
  .foot-top:hover{border-color:var(--accent)}
  @media(max-width:760px){.foot-grid{grid-template-columns:1fr 1fr;gap:26px}.foot-brand{grid-column:1/-1}}
  @media(max-width:460px){.foot-grid{grid-template-columns:1fr}}

  @media(max-width:1100px){
    .gallery{grid-template-columns:repeat(4,1fr)}
  }
  @media(max-width:760px){
    .gallery{grid-template-columns:repeat(2,1fr)}
    .search{flex-basis:150px}
  }
  @media(prefers-reduced-motion:reduce){
    *{transition:none!important;animation:none!important}
  }

  /* ---------- pagination ---------- */
  .pager{display:flex;align-items:center;justify-content:center;gap:18px;padding:30px 0 64px}
  .pager a{
    color:var(--paper);border:1px solid var(--line);background:var(--wall-2);
    border-radius:8px;padding:9px 16px;font-size:14px;transition:background .15s,border-color .15s;
  }
  .pager a:hover{background:var(--wall-3);border-color:var(--line-strong)}
  .pager-info{font-size:13px;color:var(--ink-2)}
  .hero-cat{text-align:center}
  .hero-cat .pp-bread{justify-content:center}
  .noimg{position:absolute;inset:0;background:var(--wall-3)}

  /* ---------- back-office ---------- */
  body.admin{background:var(--wall)}
  .admin-nav{margin-left:auto;display:flex;gap:18px;font-size:14px}
  .admin-nav a{color:var(--t2)}
  .admin-nav a:hover{color:var(--paper)}
  .admin-wrap{padding:34px 0 80px}
  .admin-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:24px;gap:16px}
  .admin-head h1{font-size:24px;font-weight:700;letter-spacing:-.02em;margin:0}
  .admin-count{font-size:14px;color:var(--ink-2);font-weight:400;margin-left:6px}
  .admin-muted{color:var(--ink-2)}
  .admin-muted.small,.small{font-size:12px}
  .btn-primary{
    background:var(--accent);color:#fff;border:0;border-radius:8px;
    padding:11px 18px;font-size:14px;font-weight:600;cursor:pointer;display:inline-block;
  }
  .btn-primary:hover{background:var(--accent-press)}
  .admin-error{background:rgba(255,90,80,.12);border:1px solid rgba(255,90,80,.4);color:#ffb3ad;
    border-radius:8px;padding:12px 14px;margin-bottom:18px;font-size:14px}
  .admin-error ul{margin:0;padding-left:18px}

  .admin-table{width:100%;border-collapse:collapse;font-size:14px}
  .admin-table th{text-align:left;color:var(--ink-2);font-weight:500;font-size:12px;
    text-transform:uppercase;letter-spacing:.05em;padding:0 12px 10px;border-bottom:1px solid var(--line)}
  .admin-table td{padding:12px;border-bottom:1px solid var(--line);vertical-align:top}
  .admin-thumb img{width:54px;height:54px;object-fit:cover;border-radius:6px;display:block}
  .admin-actions{white-space:nowrap;display:flex;gap:12px;align-items:center}
  .admin-actions a{color:var(--accent)}
  .admin-actions form{display:inline}
  .link-danger{background:none;border:0;color:#ff6a5e;cursor:pointer;font-size:14px;padding:0}
  .link-danger:hover{text-decoration:underline}
  .badge{font-size:11px;padding:3px 8px;border-radius:100px;letter-spacing:.02em}
  .badge-published{background:rgba(31,169,113,.15);color:#5fd6a6}
  .badge-draft{background:var(--chip-bg);color:var(--ink-2)}

  .admin-login{max-width:340px;margin:60px auto}
  .admin-login h1{font-size:22px;margin:0 0 18px}
  .admin-login label,.admin-form label{display:block;font-size:13px;color:var(--t2);margin-bottom:14px}
  .admin-login input,.admin-form input[type=text],.admin-form input[type=password],
  .admin-form textarea,.admin-form select,.admin-form input[type=file]{
    width:100%;margin-top:6px;background:var(--wall-2);border:1px solid var(--line);
    color:var(--paper);border-radius:8px;padding:11px 12px;font-size:14px;font-family:inherit;outline:none;
  }
  .admin-form input:focus,.admin-form textarea:focus,.admin-form select:focus{border-color:var(--accent)}
  .admin-form textarea{resize:vertical;line-height:1.55}
  .form-grid{display:grid;grid-template-columns:1fr 280px;gap:26px;align-items:start}
  .form-row{display:grid;grid-template-columns:1fr 1fr;gap:14px}
  .tags-field{border:1px solid var(--line);border-radius:10px;padding:14px 16px;margin-bottom:4px}
  .tags-field legend{font-size:12px;color:var(--ink-2);text-transform:uppercase;letter-spacing:.06em;padding:0 6px}
  .tags-axis{margin-bottom:12px}
  .tags-axis-label{font-size:11px;color:var(--ink-2);text-transform:uppercase;letter-spacing:.08em}
  .tags-checks{display:flex;flex-wrap:wrap;gap:8px;margin-top:8px}
  .chk{display:inline-flex;align-items:center;gap:6px;background:var(--wall-2);border:1px solid var(--line);
    border-radius:100px;padding:6px 12px;margin:0;cursor:pointer;font-size:13px;color:var(--t2)}
  .chk input{width:auto;margin:0}
  .chk input:checked + span{color:var(--paper)}
  .form-preview img{width:100%;border-radius:8px;margin-top:6px}
  .form-actions{display:flex;align-items:center;gap:18px;margin-top:24px}
  @media(max-width:760px){.form-grid{grid-template-columns:1fr}}

  /* ---------- back-office : enrichissements ---------- */
  .admin-nav a.on{color:var(--paper);font-weight:600}
  .admin-nav a.sep{margin-left:6px;padding-left:18px;border-left:1px solid var(--line)}
  .admin-h2{font-size:16px;font-weight:600;margin:0;letter-spacing:-.01em}

  /* Cartes de statistiques */
  .stat-grid{display:grid;grid-template-columns:repeat(6,1fr);gap:12px}
  .stat{display:flex;flex-direction:column;gap:4px;background:var(--wall-2);border:1px solid var(--line);
    border-radius:12px;padding:16px 16px 14px;text-decoration:none;transition:border-color .15s,transform .15s}
  a.stat:hover{border-color:var(--accent);transform:translateY(-2px)}
  .stat-n{font-size:26px;font-weight:700;letter-spacing:-.02em;color:var(--paper)}
  .stat-l{font-size:12px;color:var(--ink-2);text-transform:uppercase;letter-spacing:.05em}
  @media(max-width:860px){.stat-grid{grid-template-columns:repeat(3,1fr)}}
  @media(max-width:460px){.stat-grid{grid-template-columns:repeat(2,1fr)}}

  /* Barre de filtres */
  .filters{display:flex;flex-wrap:wrap;gap:10px;align-items:center;margin-bottom:22px}
  .filters input[type=search],.filters select{
    background:var(--wall-2);border:1px solid var(--line);color:var(--paper);
    border-radius:8px;padding:9px 11px;font-size:14px;font-family:inherit;outline:none}
  .filters input[type=search]{flex:1;min-width:200px}
  .filters input:focus,.filters select:focus{border-color:var(--accent)}
  .btn-ghost{background:var(--wall-2);border:1px solid var(--line);color:var(--paper);
    border-radius:8px;padding:9px 16px;font-size:14px;font-weight:500;cursor:pointer;font-family:inherit}
  .btn-ghost:hover{border-color:var(--accent)}

  /* Ajout en ligne (catégories / tags) */
  .inline-add{display:flex;gap:10px;margin-bottom:22px;max-width:520px}
  .inline-add input[type=text]{flex:1;background:var(--wall-2);border:1px solid var(--line);color:var(--paper);
    border-radius:8px;padding:10px 12px;font-size:14px;font-family:inherit;outline:none}
  .inline-add input:focus{border-color:var(--accent)}

  /* Tables de gestion + renommage en ligne */
  .manage-table td{vertical-align:middle}
  .rename{display:flex;gap:8px;align-items:center;margin:0}
  .rename input[type=text]{background:var(--wall-2);border:1px solid var(--line);color:var(--paper);
    border-radius:8px;padding:8px 10px;font-size:14px;font-family:inherit;outline:none;min-width:180px}
  .rename input:focus{border-color:var(--accent)}
  .rename .btn-ghost{padding:7px 12px;font-size:13px}

  /* Titre section catégories (home) */
  .cat-title{font-size:15px;font-weight:600;margin:0}

  /* Catégories sur la page prompt */
  .pp-cats{display:flex;flex-wrap:wrap;gap:8px;margin:0 0 18px}
  .cat-pill{display:inline-block;background:var(--accent);color:#fff;border-radius:100px;
    padding:4px 12px;font-size:12px;font-weight:600;text-decoration:none}
  .cat-pill:hover{background:var(--accent-press)}

  /* ---------- "How to use" : étapes visuelles ---------- */
  .pp-hint{margin:0 0 12px;font-size:12.5px;color:var(--ink-2);letter-spacing:.01em}
  .howto{margin-top:46px;border-top:1px solid var(--line);padding-top:30px}
  .howto-head h2{font-size:26px;font-weight:700;letter-spacing:-.03em;margin:0 0 6px}
  .howto-head p{margin:0 0 20px;color:var(--ink-2);font-size:14px}
  .howto-steps{list-style:none;margin:0;padding:0;display:grid;grid-template-columns:repeat(3,1fr);gap:14px;counter-reset:howto}
  .howto-step{
    position:relative;background:linear-gradient(180deg,var(--wall-2),var(--wall-2));
    border:1px solid var(--line);border-radius:16px;padding:20px 18px;overflow:hidden;
    transition:border-color .18s ease,transform .18s ease,box-shadow .18s ease;
  }
  .howto-step::before{
    content:"";position:absolute;inset:0 0 auto 0;height:2px;
    background:linear-gradient(90deg,var(--accent),transparent);opacity:.5;
  }
  .howto-step:hover{border-color:var(--accent);transform:translateY(-4px);
    box-shadow:0 12px 30px -16px rgba(45,91,255,.55)}
  .howto-ico{
    width:46px;height:46px;border-radius:13px;display:flex;align-items:center;justify-content:center;
    background:rgba(45,91,255,.16);color:var(--ico-fg);margin-bottom:14px;
  }
  .howto-ico svg{width:23px;height:23px}
  .howto-step-no{font-size:11px;font-weight:600;letter-spacing:.09em;text-transform:uppercase;color:var(--accent)}
  .howto-step h3{font-size:16px;font-weight:600;letter-spacing:-.01em;margin:4px 0 6px}
  .howto-step p{margin:0;font-size:13.5px;line-height:1.55;color:var(--t2)}
  .howto-step p b{color:var(--paper);font-weight:600}
  @media(max-width:720px){.howto-steps{grid-template-columns:1fr}}

  html{background:var(--wall)}

  /* ---------- bascule thème clair / sombre ---------- */
  .theme-toggle{
    display:inline-flex;align-items:center;justify-content:center;flex:none;
    width:38px;height:38px;border-radius:var(--radius);padding:0;
    background:var(--wall-2);border:1px solid var(--line);color:var(--paper);cursor:pointer;
    transition:border-color .15s,color .15s;
  }
  .theme-toggle:hover{border-color:var(--accent)}
  .theme-toggle svg{width:18px;height:18px}
  .theme-toggle .ic-sun{display:inline}
  .theme-toggle .ic-moon{display:none}
  :root[data-theme="light"] .theme-toggle .ic-sun{display:none}
  :root[data-theme="light"] .theme-toggle .ic-moon{display:inline}
  .bar-actions{margin-left:auto;display:flex;align-items:center;gap:18px}
  .bar-actions .admin-nav{margin-left:0}

  /* Bloc meta (free to use + tags) sous le bouton copier */
  .pp-meta{margin-top:20px;padding-top:16px;border-top:1px solid var(--line)}
  .pp-tagrow{display:flex;align-items:flex-start;gap:14px}
  .pp-taxo-label{flex:none;width:46px;padding-top:6px;font-size:11px;font-weight:600;letter-spacing:.09em;text-transform:uppercase;color:var(--ink-2)}
  @media(max-width:520px){.pp-tagrow{flex-direction:column;gap:6px}.pp-taxo-label{padding-top:0}}

  /* ---------- favoris (header) ---------- */
  .fav-link{position:relative;display:inline-flex;align-items:center;justify-content:center;flex:none;
    width:38px;height:38px;border-radius:var(--radius);background:var(--wall-2);border:1px solid var(--line);
    color:var(--paper);transition:border-color .15s}
  .fav-link:hover{border-color:var(--accent)}
  .fav-link svg{width:18px;height:18px}
  .fav-count{position:absolute;top:-6px;right:-6px;min-width:17px;height:17px;padding:0 4px;border-radius:100px;
    background:var(--accent);color:#fff;font-size:10px;font-weight:600;display:flex;align-items:center;justify-content:center;line-height:1}

  /* ---------- actions page prompt (save / partage) ---------- */
  .pp-actions{display:flex;gap:10px;margin-top:12px}
  .pp-act{flex:1;display:inline-flex;align-items:center;justify-content:center;gap:8px;height:44px;
    border-radius:10px;background:var(--wall-2);border:1px solid var(--line);color:var(--paper);
    font-size:14px;font-weight:500;cursor:pointer;text-decoration:none;transition:border-color .15s,color .15s}
  .pp-act:hover{border-color:var(--accent)}
  .pp-act svg{width:17px;height:17px}
  .fav-toggle.on{border-color:#e2554a;color:#ff6a5e}
  .fav-toggle.on svg{fill:#ff6a5e;stroke:#ff6a5e}
  @media(max-width:520px){.pp-act span{display:none}.pp-act{flex:1}}

  /* ---------- toast ---------- */
  .toast{position:fixed;left:50%;bottom:26px;transform:translateX(-50%) translateY(12px);
    background:var(--paper);color:var(--wall);font-size:13.5px;font-weight:500;
    padding:11px 18px;border-radius:10px;box-shadow:0 12px 32px -12px rgba(0,0,0,.6);
    opacity:0;transition:opacity .25s ease,transform .25s ease;z-index:100;pointer-events:none}
  .toast.show{opacity:1;transform:translateX(-50%) translateY(0)}

  /* ---------- page About ---------- */
  .about-body{padding-bottom:64px;max-width:64ch}
  .about-body p{color:var(--t2);line-height:1.75;margin:0 0 16px;font-size:15px}
  .about-body p b{color:var(--paper);font-weight:600}
  .about-body h2{font-size:18px;font-weight:600;margin:28px 0 10px;letter-spacing:-.01em}

  /* ---------- page Favorites ---------- */
  .fav-actions{display:flex;justify-content:center;gap:12px;padding:26px 0 60px}

  /* ---------- soumission publique ---------- */
  .hp{position:absolute !important;left:-9999px;width:1px;height:1px;overflow:hidden}
  .submit-wrap{padding-bottom:64px}
  .cap-field b{color:var(--paper)}
  .hero-cta{margin-top:14px}
  .hero-cta a{color:var(--accent);font-size:14px;font-weight:500}
  .hero-cta a:hover{text-decoration:underline}

  .submit-done{max-width:560px;margin:64px auto;text-align:center;background:var(--wall-2);
    border:1px solid var(--line);border-radius:16px;padding:42px 28px}
  .submit-check{width:60px;height:60px;border-radius:50%;background:rgba(31,169,113,.16);color:#5fd6a6;
    display:flex;align-items:center;justify-content:center;margin:0 auto 18px}
  .submit-done h1{font-size:24px;margin:0 0 10px}
  .submit-done p{color:var(--t2);line-height:1.6;margin:0 auto 22px;max-width:44ch}
  .submit-done-actions{display:flex;gap:12px;justify-content:center;flex-wrap:wrap}

  /* statut "à valider" + actions admin */
  .badge-pending{background:rgba(239,159,39,.16);color:#f0b34b}
  .link-ok{background:none;border:0;color:#3ec98a;cursor:pointer;font-size:14px;padding:0;font-family:inherit}
  .link-ok:hover{text-decoration:underline}
  .stat-alert{border-color:rgba(239,159,39,.5)}
  .stat-alert .stat-n{color:#f0b34b}
  .nav-pending{display:inline-flex;align-items:center;gap:6px}
  .nav-badge{background:#ef9f27;color:#1b1b17;border-radius:100px;font-size:11px;font-weight:700;padding:1px 7px;line-height:1.4}

  /* ---------- zone de dépôt d'image (dropzone) ---------- */
  .dz-label{display:block;font-size:13px;color:var(--t2);margin-bottom:8px}
  .dropzone{position:relative;border:1.5px dashed var(--line);border-radius:14px;background:var(--wall-2);
    min-height:172px;display:flex;align-items:center;justify-content:center;overflow:hidden;
    transition:border-color .15s,background .15s}
  .dropzone:hover{border-color:var(--accent)}
  .dropzone.drag{border-color:var(--accent);background:rgba(45,91,255,.10)}
  .dz-input{position:absolute;inset:0;width:100%;height:100%;opacity:0;cursor:pointer;z-index:1}
  .dz-cta{position:relative;z-index:0;display:flex;flex-direction:column;align-items:center;gap:5px;
    text-align:center;padding:28px 18px;pointer-events:none}
  .dz-icon{width:48px;height:48px;border-radius:13px;display:flex;align-items:center;justify-content:center;
    background:rgba(45,91,255,.14);color:var(--ico-fg);margin-bottom:6px}
  .dz-icon svg{width:25px;height:25px}
  .dz-title{font-size:15px;font-weight:600;color:var(--paper)}
  .dz-sub{font-size:12.5px;color:var(--ink-2)}
  .dz-sub u{color:var(--accent);text-decoration:none}
  .dz-preview{position:relative;z-index:2;width:100%}
  .dz-img{display:block;width:100%;max-height:300px;object-fit:cover;background:var(--wall-3)}
  .dz-overlay{position:absolute;left:0;right:0;bottom:0;display:flex;align-items:center;justify-content:space-between;
    gap:10px;padding:10px 12px;background:linear-gradient(180deg,rgba(0,0,0,0),rgba(0,0,0,.72))}
  .dz-name{font-size:12px;color:#fff;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:60%}
  .dz-remove{background:rgba(255,255,255,.16);border:1px solid rgba(255,255,255,.28);color:#fff;border-radius:7px;
    padding:6px 13px;font-size:12.5px;font-weight:500;cursor:pointer}
  .dz-remove:hover{background:rgba(255,255,255,.28)}
  .dz-detect{position:absolute;top:10px;left:10px;z-index:3;display:inline-flex;align-items:center;gap:7px;
    background:var(--ok);color:#fff;border-radius:100px;padding:6px 12px;font-size:12px;font-weight:500;
    box-shadow:0 6px 18px -8px rgba(0,0,0,.6)}
  .dz-detect svg{width:15px;height:15px}
  .dz-detect.loading{background:rgba(20,20,20,.85)}
  .dz-detect.loading svg{animation:dzspin 1s linear infinite}
  @keyframes dzspin{to{transform:rotate(360deg)}}

  /* ---------- formulaire "upload-first" ---------- */
  .upload-form{max-width:760px}
  .upload-form .dropzone{min-height:200px;margin-bottom:6px}
  .upload-form .dz-hint{margin:0 0 22px}
  .upload-form > label,.upload-form > .tags-field,.upload-form > .cap-field{display:block;margin-bottom:16px}

  .dz-detect.empty{background:rgba(20,20,20,.85)}

  /* page submit : formulaire pleine largeur du conteneur */
  .submit-wrap .upload-form{max-width:none}

  /* ---------- sections accueil (populaires / récents) ---------- */
  .sec-title{font-size:18px;font-weight:700;letter-spacing:-.02em;margin:8px 0 14px}
  .sec-title-mt{margin-top:36px}

  /* case à cocher en ligne (NSFW) */
  .admin-form label.chk-line{display:flex;align-items:center;gap:10px;font-size:14px;color:var(--t2);margin-bottom:16px;cursor:pointer}
  .admin-form .chk-line input{width:auto;margin:0}

  /* badge 18+ */
  .badge-nsfw{background:rgba(226,85,74,.18);color:#ff8a7e}

  /* ---------- age-gate 18+ ---------- */
  .agegate{display:flex;justify-content:center;padding:60px 0 90px}
  .agegate-box{max-width:480px;text-align:center;background:var(--wall-2);border:1px solid var(--line);border-radius:16px;padding:42px 30px}
  .agegate-ico{width:58px;height:58px;border-radius:50%;display:flex;align-items:center;justify-content:center;margin:0 auto 18px;background:rgba(239,159,39,.16);color:#f0b34b}
  .agegate-ico svg{width:30px;height:30px}
  .agegate-box h1{font-size:24px;margin:0 0 12px}
  .agegate-box p{color:var(--t2);line-height:1.6;margin:0 auto 22px;max-width:42ch}
  .agegate-actions{display:flex;gap:12px;justify-content:center;flex-wrap:wrap;margin-bottom:14px}

  /* ---------- header admin compact ---------- */
  .mark-admin{font-size:17px}
  .admin-nav{margin-left:auto;display:flex;align-items:center;gap:16px;font-size:13.5px;flex-wrap:wrap}
  .admin-nav + .bar-actions{margin-left:16px}
  .btn-sm{padding:8px 13px;font-size:13px}
  .icon-link{display:inline-flex;align-items:center;justify-content:center;width:34px;height:34px;border-radius:8px;
    color:var(--t2);border:1px solid transparent;transition:color .15s,border-color .15s,background .15s;text-decoration:none}
  .icon-link:hover{color:var(--paper);border-color:var(--line);background:var(--wall-2)}
  .icon-link svg{width:17px;height:17px}

  /* ---------- liste des prompts (admin) ---------- */
  .prompt-list{display:flex;flex-direction:column;gap:8px;margin-top:4px}
  .prow{display:grid;grid-template-columns:60px minmax(0,1fr) auto;gap:16px;align-items:center;
    background:var(--wall-2);border:1px solid var(--line);border-radius:12px;padding:10px 14px;transition:border-color .15s}
  .prow:hover{border-color:var(--line-strong)}
  .prow-thumb{width:60px;height:60px;border-radius:9px;object-fit:cover;background:var(--wall-3);display:block}
  .prow-noimg{display:flex;align-items:center;justify-content:center;color:var(--ink-2)}
  .prow-noimg svg{width:24px;height:24px}
  .prow-main{min-width:0}
  .prow-title{font-size:14.5px;font-weight:600;line-height:1.3}
  .prow-title a{color:var(--paper)}
  .prow-title a:hover{color:var(--accent)}
  .prow-ex{color:var(--ink-2);font-size:12.5px;margin-top:2px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
  .prow-sub{display:flex;align-items:center;gap:10px;margin-top:7px;flex-wrap:wrap}
  .prow-date{font-size:12px;color:var(--ink-2)}
  .prow-actions{display:flex;align-items:center;gap:6px;white-space:nowrap}
  .prow-actions form{display:inline;margin:0}
  .pact{font-size:13px;padding:6px 11px;border-radius:7px;border:1px solid var(--line);background:transparent;
    color:var(--t2);cursor:pointer;font-family:inherit;text-decoration:none;transition:border-color .15s,color .15s,background .15s}
  .pact:hover{border-color:var(--line-strong);color:var(--paper)}
  .pact-muted{color:var(--ink-2)}
  .pact-ok{border-color:rgba(31,169,113,.5);color:#3ec98a}
  .pact-ok:hover{background:rgba(31,169,113,.12);color:#5fd6a6}
  .pact-danger{color:#ff8a7e}
  .pact-danger:hover{border-color:rgba(226,85,74,.5);color:#ff6a5e}
  @media(max-width:680px){
    .prow{grid-template-columns:52px minmax(0,1fr);row-gap:10px}
    .prow-thumb{width:52px;height:52px}
    .prow-actions{grid-column:1/-1;justify-content:flex-start;flex-wrap:wrap}
  }

  .pact{display:inline-flex;align-items:center;gap:6px}
  .pact svg{width:14px;height:14px}
  .pact-danger{color:#ff6a5e;border-color:rgba(226,85,74,.35)}
  .pact-danger:hover{background:rgba(226,85,74,.14);border-color:rgba(226,85,74,.6);color:#ff8a7e}

  /* ---------- like + tri + lien auteur ---------- */
  .pp-like.on{border-color:#e2554a;color:#ff6a5e}
  .pp-like.on svg{fill:#ff6a5e;stroke:#ff6a5e}
  .pp-like-n{font-variant-numeric:tabular-nums;font-weight:600;min-width:14px;text-align:center}
  .pp-author{color:var(--paper);text-decoration:underline;text-decoration-color:var(--line);text-underline-offset:2px}
  .pp-author:hover{color:var(--accent)}
  .sortbar{display:flex;gap:4px;margin:4px 0 18px;border-bottom:1px solid var(--line)}
  .sorttab{font-size:14px;color:var(--ink-2);padding:9px 15px;border-bottom:2px solid transparent;margin-bottom:-1px;transition:color .15s,border-color .15s}
  .sorttab:hover{color:var(--paper)}
  .sorttab.on{color:var(--paper);font-weight:600;border-bottom-color:var(--accent)}
