/* generateur-image.ai — thème studio sombre (néon violet) */
:root{
  --bg:#0a0a0f; --bg-2:#0e0e16; --panel:#15151f; --panel-2:#1c1c28;
  --border:#262633; --border-2:#33334a;
  --text:#ecebf5; --muted:#9a9ab0; --muted-2:#6f6f86;
  --accent:#a855f7; --accent-2:#7c5cff; --accent-3:#22d3ee;
  --danger:#f43f5e; --ok:#22c55e;
  --radius:16px; --radius-sm:10px;
  --glow:0 0 0 1px rgba(168,85,247,.35), 0 8px 30px rgba(124,92,255,.35);
  --font:'Inter',-apple-system,BlinkMacSystemFont,'Segoe UI',Roboto,sans-serif;
}
*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{
  background:var(--bg); color:var(--text); font-family:var(--font);
  -webkit-font-smoothing:antialiased; line-height:1.55;
  background-image:radial-gradient(900px 500px at 80% -10%,rgba(124,92,255,.18),transparent 60%),
                   radial-gradient(700px 400px at 0% 0%,rgba(34,211,238,.10),transparent 55%);
  background-attachment:fixed;
}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
.container{max-width:1200px;margin:0 auto;padding:0 24px}
.muted{color:var(--muted)}

/* Boutons */
.btn{display:inline-flex;align-items:center;gap:8px;border:0;cursor:pointer;
  font-weight:600;font-size:15px;padding:12px 22px;border-radius:999px;
  font-family:var(--font);transition:.18s ease;text-align:center;justify-content:center}
.btn-primary{background:linear-gradient(135deg,var(--accent-2),var(--accent));color:#fff;box-shadow:var(--glow)}
.btn-primary:hover{transform:translateY(-1px);filter:brightness(1.08)}
.btn-ghost{background:rgba(255,255,255,.04);color:var(--text);border:1px solid var(--border-2)}
.btn-ghost:hover{background:rgba(255,255,255,.08)}
.btn-lg{padding:15px 30px;font-size:16px}
.btn:disabled{opacity:.5;cursor:not-allowed}

/* Header */
.nav{position:sticky;top:0;z-index:40;backdrop-filter:blur(12px);
  background:rgba(10,10,15,.7);border-bottom:1px solid var(--border)}
.nav .container{display:flex;align-items:center;justify-content:space-between;height:68px}
.logo{display:flex;align-items:center;gap:10px;font-weight:800;font-size:19px;letter-spacing:-.3px}
.logo .dot{width:26px;height:26px;border-radius:8px;background:linear-gradient(135deg,var(--accent-2),var(--accent));
  box-shadow:var(--glow);display:grid;place-items:center;font-size:15px}
.logo b{background:linear-gradient(90deg,#fff,#cbb6ff);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}
.nav-actions{display:flex;gap:10px;align-items:center}
.logo-mini{display:none;overflow:visible}
.nav-actions .t-short{display:none}
/* Header compact sur mobile : logo court « GIAI » + boutons réduits, libellés courts */
@media(max-width:760px){
  .nav .container{height:58px;padding:0 12px}
  .logo{gap:7px;font-size:17px}
  .logo-name{display:none}
  .logo-mini{display:block}
  .nav-actions{gap:4px}
  .nav-actions .btn{padding:7px 10px;font-size:12.5px}
  .nav-actions .t-full{display:none}
  .nav-actions .t-short{display:inline-flex;align-items:center}
  .btn-logout{padding:7px 9px}
}
@media(max-width:360px){
  .nav .container{padding:0 8px}
  .nav-actions .btn{padding:7px 8px;font-size:12px}
}

/* Hero */
.hero{padding:90px 0 60px;text-align:center}
.badge{display:inline-flex;align-items:center;gap:8px;padding:6px 14px;border-radius:999px;
  background:rgba(168,85,247,.12);border:1px solid rgba(168,85,247,.3);color:#d6c2ff;font-size:13px;font-weight:600;margin-bottom:22px}
.hero h1{font-size:clamp(34px,6vw,64px);line-height:1.05;margin:0 0 18px;font-weight:800;letter-spacing:-1.5px}
.hero h1 .grad{background:linear-gradient(120deg,var(--accent),var(--accent-3));-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}
.hero p{font-size:clamp(16px,2.2vw,20px);color:var(--muted);max-width:620px;margin:0 auto 30px}
.hero-cta{display:flex;gap:14px;justify-content:center;flex-wrap:wrap}

/* Galerie showcase */
.showcase{padding:30px 0 70px}
.masonry{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}
.masonry .card{border-radius:var(--radius);overflow:hidden;border:1px solid var(--border);
  position:relative;background:var(--panel);aspect-ratio:3/2}
.masonry .card img{width:100%;height:100%;object-fit:cover;display:block;transition:.4s ease}
.masonry .card:hover img{transform:scale(1.05)}
@media(max-width:1000px){.masonry{grid-template-columns:repeat(3,1fr)}}
@media(max-width:680px){.masonry{grid-template-columns:repeat(2,1fr)}}

/* Sections */
.section{padding:70px 0}
.section h2{font-size:clamp(26px,4vw,40px);text-align:center;margin:0 0 12px;font-weight:800;letter-spacing:-.8px}
.section .sub{text-align:center;color:var(--muted);max-width:560px;margin:0 auto 44px}
.grid{display:grid;gap:20px}
.grid-3{grid-template-columns:repeat(3,1fr)}
.grid-6{grid-template-columns:repeat(6,1fr)}
@media(max-width:900px){.grid-3{grid-template-columns:1fr}.grid-6{grid-template-columns:repeat(3,1fr)}}
@media(max-width:520px){.grid-6{grid-template-columns:repeat(2,1fr)}}

.tile{background:var(--panel);border:1px solid var(--border);border-radius:var(--radius);padding:22px;transition:.2s}
.tile:hover{border-color:var(--border-2);transform:translateY(-3px)}
.model-chip{text-align:center}
.model-chip .ic{width:46px;height:46px;border-radius:12px;margin:0 auto 12px;display:grid;place-items:center;
  background:rgba(124,92,255,.14);border:1px solid rgba(124,92,255,.3);font-size:22px}
.model-chip h4{margin:0 0 4px;font-size:15px}
.model-chip span{font-size:12px;color:var(--muted-2)}

/* Pricing */
.price-card{display:flex;flex-direction:column;position:relative}
.price-card.featured{border-color:var(--accent);box-shadow:var(--glow)}
.price-card .tag{position:absolute;top:-12px;left:50%;transform:translateX(-50%);background:linear-gradient(135deg,var(--accent-2),var(--accent));
  color:#fff;font-size:12px;font-weight:700;padding:5px 14px;border-radius:999px}
.price-card h3{margin:0 0 6px;font-size:20px}
.price-card .price{font-size:40px;font-weight:800;margin:8px 0}
.price-card .price small{font-size:15px;color:var(--muted);font-weight:500}
.price-card ul{list-style:none;padding:0;margin:18px 0;display:grid;gap:10px}
.price-card li{display:flex;gap:10px;align-items:flex-start;color:var(--muted);font-size:14px}
.price-card li::before{content:'✓';color:var(--accent);font-weight:800}

/* Footer */
.footer{border-top:1px solid var(--border);padding:40px 0;color:var(--muted-2);font-size:14px;text-align:center;margin-top:40px}

/* ===== STUDIO ===== */
.studio{display:grid;grid-template-columns:380px 1fr;min-height:calc(100vh - 68px)}
.composer{border-right:1px solid var(--border);padding:24px;display:flex;flex-direction:column;gap:18px;background:var(--bg-2)}
.field label{display:block;font-size:13px;font-weight:600;color:var(--muted);margin-bottom:8px}
textarea.prompt{width:100%;min-height:120px;resize:vertical;background:var(--panel);border:1px solid var(--border-2);
  color:var(--text);border-radius:var(--radius-sm);padding:14px;font-family:var(--font);font-size:15px}
textarea.prompt:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px rgba(168,85,247,.15)}
.models{display:grid;grid-template-columns:1fr 1fr;gap:8px}
.model-opt{border:1px solid var(--border-2);border-radius:var(--radius-sm);padding:10px;cursor:pointer;transition:.15s;background:var(--panel)}
.model-opt:hover{border-color:var(--accent)}
.model-opt.sel{border-color:var(--accent);background:rgba(168,85,247,.12);box-shadow:0 0 0 1px var(--accent) inset}
.model-opt b{display:block;font-size:13px}
.model-opt span{font-size:11px;color:var(--muted-2)}
.model-opt.locked{opacity:.45;cursor:not-allowed}
.formats{display:flex;gap:8px}
.fmt{flex:1;border:1px solid var(--border-2);border-radius:var(--radius-sm);padding:10px;text-align:center;cursor:pointer;font-size:13px;background:var(--panel)}
.fmt.sel{border-color:var(--accent);background:rgba(168,85,247,.12)}
.fmt .box{margin:0 auto 6px;background:var(--muted-2);border-radius:3px}
.fmt[data-f=square] .box{width:22px;height:22px}
.fmt[data-f=landscape] .box{width:28px;height:18px}
.fmt[data-f=portrait] .box{width:18px;height:26px}
.credits-pill{display:inline-flex;align-items:center;gap:6px;background:rgba(34,211,238,.1);border:1px solid rgba(34,211,238,.3);
  color:#7fe7f5;padding:6px 12px;border-radius:999px;font-size:13px;font-weight:600}
.canvas{padding:24px;overflow:auto}
.result{display:grid;place-items:center;min-height:300px;max-height:52vh;border:1px dashed var(--border-2);border-radius:var(--radius);
  background:var(--panel);position:relative;overflow:hidden;margin-bottom:18px}
.result img{max-height:50vh;border-radius:var(--radius)}
.result .dlimg{position:absolute;bottom:12px;right:12px;background:rgba(0,0,0,.6);color:#fff;padding:8px 14px;border-radius:999px;font-size:13px;font-weight:600;backdrop-filter:blur(6px)}
/* plusieurs images générées : vignettes sur une même ligne */
.result-grid{display:flex;flex-wrap:wrap;gap:10px;justify-content:center;align-content:flex-start;width:100%;height:100%;overflow:auto;padding:10px}
.result-grid .rg-item{flex:0 0 auto}
.result-grid .rg-item img{max-height:20vh;border-radius:10px;display:block;transition:.15s}
.result-grid .rg-item img:hover{transform:scale(1.03)}
.result .placeholder{color:var(--muted-2);text-align:center;padding:40px}
.spinner{width:46px;height:46px;border:3px solid rgba(168,85,247,.2);border-top-color:var(--accent);border-radius:50%;animation:spin 1s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}
.gallery-title{margin:34px 0 16px;font-size:18px;font-weight:700}
.gallery{columns:4;column-gap:14px}
.gallery .g{break-inside:avoid;margin-bottom:14px;border-radius:12px;overflow:hidden;border:1px solid var(--border)}
@media(max-width:1200px){.gallery{columns:3}}
@media(max-width:700px){.studio{grid-template-columns:1fr}.composer{border-right:0;border-bottom:1px solid var(--border)}.gallery{columns:2}}
.err{background:rgba(244,63,94,.12);border:1px solid rgba(244,63,94,.4);color:#fda4b4;padding:12px 14px;border-radius:10px;font-size:14px;display:none}
.topbar{display:flex;align-items:center;justify-content:space-between;gap:12px}
.alert-info{background:rgba(124,92,255,.1);border:1px solid rgba(124,92,255,.3);color:#cbb6ff;padding:10px 14px;border-radius:10px;font-size:13px}
/* Pastille « aucune saisie » / « saisie optionnelle » (studio) */
.studio-noinput{display:none;align-items:center;gap:8px;margin-top:2px;padding:11px 14px;border-radius:10px;background:rgba(124,92,255,.12);border:1px solid rgba(124,92,255,.35);color:#cbb6ff;font-size:13.5px;font-weight:600}
.studio-noinput svg{flex:0 0 auto}
.studio-noinput strong{color:#fff;font-weight:700}
.studio-noinput.is-optional{background:rgba(255,255,255,.04);border-color:var(--border-2);color:var(--muted)}
.studio-noinput.is-optional strong{color:var(--text)}

/* Auth */
.auth-wrap{min-height:calc(100vh - 68px);display:grid;place-items:center;padding:40px 20px}
.auth-card{width:100%;max-width:420px;background:var(--panel);border:1px solid var(--border);border-radius:var(--radius);padding:34px}
.auth-card h1{font-size:24px;margin:0 0 6px}
.auth-card .field{margin-bottom:16px}
.auth-card input{width:100%;background:var(--bg-2);border:1px solid var(--border-2);color:var(--text);border-radius:10px;padding:13px;font-size:15px;font-family:var(--font)}
.auth-card input:focus{outline:none;border-color:var(--accent)}
.auth-card .btn{width:100%}

/* ===== Studio v2 : contrôles à droite sous l'image ===== */
.actions-grid{grid-template-columns:1fr 1fr}
.genform{background:var(--bg-2);border:1px solid var(--border);border-radius:var(--radius);padding:18px;display:flex;flex-direction:column;gap:16px}
.genform .field{margin:0}
.genform textarea.prompt{min-height:84px}
.opts-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:14px}
/* menus déroulants sombres harmonisés */
.sel-input{appearance:none;-webkit-appearance:none;-moz-appearance:none;width:100%;height:46px;padding:0 36px 0 13px;
  background-color:var(--panel);
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' fill='none'%3E%3Cpath d='M1 1.5L6 6.5L11 1.5' stroke='%239a9ab0' stroke-width='1.6' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");
  background-repeat:no-repeat;background-position:right 13px center;
  border:1px solid var(--border-2);border-radius:var(--radius-sm);color:var(--text);
  font-family:var(--font);font-size:14px;cursor:pointer;transition:.15s}
.sel-input:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px rgba(168,85,247,.15)}
.sel-input option{background:#15151f;color:var(--text)}

/* ===== Page Galerie ===== */
.gallery-head{display:flex;align-items:center;justify-content:space-between;gap:16px;margin-bottom:18px}
.gallery-search{display:flex;gap:10px;margin-bottom:18px;flex-wrap:wrap}
.gallery-search input{flex:1;min-width:240px;background:var(--panel);border:1px solid var(--border-2);color:var(--text);
  border-radius:999px;padding:13px 20px;font-size:15px;font-family:var(--font)}
.gallery-search input:focus{outline:none;border-color:var(--accent)}
.gal-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:18px}
@media(max-width:1000px){.gal-grid{grid-template-columns:repeat(3,1fr)}}
@media(max-width:680px){.gal-grid{grid-template-columns:repeat(2,1fr)}}
.gal-item{margin:0;background:var(--panel);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;display:flex;flex-direction:column}
.gal-item>a{display:block;aspect-ratio:1;overflow:hidden}
.gal-item img{width:100%;height:100%;object-fit:cover;transition:.3s}
.gal-item:hover img{transform:scale(1.05)}
.gal-item figcaption{padding:12px}
.gal-prompt{margin:0 0 8px;font-size:13px;color:var(--text);display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden;line-height:1.4}
.gal-meta{display:flex;justify-content:space-between;align-items:center;font-size:11px;color:var(--muted-2)}
.gal-meta a{background:rgba(168,85,247,.15);color:var(--accent);width:28px;height:28px;border-radius:8px;display:grid;place-items:center;text-decoration:none}
/* boutons d'action galerie — harmonisés avec le studio (violet, arrondis) */
.gal-actions{display:flex;gap:8px;align-items:center}
.gal-btn{display:inline-flex;align-items:center;justify-content:center;gap:7px;height:40px;
  border-radius:var(--radius-sm);font-size:13px;font-weight:600;font-family:var(--font);
  cursor:pointer;text-decoration:none;transition:.15s;border:1px solid var(--border-2)}
.gal-btn svg{display:block}
/* Partager = bouton principal dégradé violet (comme « Générer ») */
.gal-share{flex:1;padding:0 14px;border:0;color:#fff;
  background:linear-gradient(135deg,var(--accent-2),var(--accent));box-shadow:0 4px 14px rgba(124,92,255,.30)}
.gal-share:hover{filter:brightness(1.08);transform:translateY(-1px)}
.gal-share.ok{background:linear-gradient(135deg,#16a34a,#22c55e)}
/* icônes carrées = cartes violettes (comme model-opt) */
.gal-icon{width:40px;flex:0 0 40px;background:var(--panel);color:var(--muted)}
.gal-icon:hover{border-color:var(--accent);color:#fff;background:rgba(168,85,247,.14)}
.gal-icon.danger:hover{border-color:var(--danger);color:#fda4b4;background:rgba(244,63,94,.14)}
.gal-btn:disabled{opacity:.6;cursor:default}
/* bouton danger (modale suppression) */
.btn-danger{background:linear-gradient(135deg,#e11d48,#f43f5e);color:#fff}
.btn-danger:hover{filter:brightness(1.08)}
/* modales galerie */
.gmodal-overlay{position:fixed;inset:0;background:rgba(5,5,10,.72);backdrop-filter:blur(4px);
  display:none;align-items:center;justify-content:center;z-index:100;padding:20px}
.gmodal-overlay.open{display:flex}
.gmodal{background:var(--panel);border:1px solid var(--border-2);border-radius:var(--radius);
  padding:28px;max-width:460px;width:100%;box-shadow:0 24px 70px rgba(0,0,0,.55)}
.gmodal h3{margin:0 0 12px;font-size:20px}
.gmodal-warn{color:var(--muted);font-size:14px;line-height:1.55;margin:0 0 20px}
.gmodal-copy{display:flex;gap:8px;margin-bottom:18px}
.gmodal-copy input{flex:1;min-width:0;background:var(--bg-2);border:1px solid var(--border-2);
  color:var(--text);border-radius:var(--radius-sm);padding:11px 13px;font-size:13px;font-family:var(--font)}
.gmodal-actions{display:flex;gap:10px;justify-content:flex-end;flex-wrap:wrap}
/* gros CTA abonnement dans la sidebar studio */
.cta-sub{display:block;text-decoration:none;margin-top:6px;padding:16px 18px;border-radius:var(--radius);
  background:linear-gradient(135deg,var(--accent-2),var(--accent));color:#fff;box-shadow:var(--glow);
  text-align:center;transition:.18s}
.cta-sub:hover{filter:brightness(1.08);transform:translateY(-1px)}
.cta-sub-title{display:block;font-weight:700;font-size:15px}
.cta-sub-sub{display:block;font-size:12px;color:rgba(255,255,255,.85);margin-top:3px}
.cost-badge{font-size:13px;font-weight:600;opacity:.85;margin-left:4px}
/* ===== Admin ===== */
.adm{display:grid;grid-template-columns:240px 1fr;min-height:100vh}
.adm-side{background:var(--bg-2);border-right:1px solid var(--border);padding:18px 14px;display:flex;flex-direction:column;position:sticky;top:0;height:100vh;align-self:start;overflow-y:auto}
.adm-nav{display:grid;gap:4px;margin-top:8px}
.adm-nav a{display:block;padding:11px 14px;border-radius:10px;color:var(--muted);text-decoration:none;font-weight:600;font-size:14px}
.adm-nav a:hover{background:rgba(255,255,255,.05);color:var(--text)}
.adm-nav a.on{background:rgba(168,85,247,.15);color:#cbb6ff;border:1px solid rgba(168,85,247,.3)}
.adm-main{padding:26px 30px;overflow:auto;max-width:1100px}
.adm-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(170px,1fr));gap:13px}
.adm-card{background:var(--panel);border:1px solid var(--border);border-radius:var(--radius);padding:14px 16px}
.adm-card span{display:block;font-size:11.5px;text-transform:uppercase;letter-spacing:.05em;color:var(--muted-2)}
.adm-card b{display:block;font-size:23px;font-weight:800;margin:4px 0 1px}
.adm-card small{color:var(--muted)}
.adm-table{width:100%;border-collapse:collapse;font-size:14px}
.adm-table th{text-align:left;padding:12px 14px;color:var(--muted);font-size:11px;text-transform:uppercase;letter-spacing:.04em;border-bottom:1px solid var(--border)}
.adm-table td{padding:12px 14px;border-bottom:1px solid var(--border)}
.adm-table tr:last-child td{border-bottom:0}
@media(max-width:760px){.adm{grid-template-columns:1fr}.adm-side{flex-direction:row;flex-wrap:wrap;align-items:center;gap:8px;position:static;height:auto;overflow:visible}.adm-nav{grid-auto-flow:column;overflow-x:auto}}
/* badges statut tickets */
.ticket-badge{display:inline-block;padding:5px 12px;border-radius:999px;font-size:12px;font-weight:600;text-transform:capitalize;
  background:rgba(255,255,255,.07);border:1px solid var(--border-2);color:var(--muted);white-space:nowrap}
.ticket-open,.ticket-awaiting_admin{background:rgba(124,92,255,.15);border-color:rgba(124,92,255,.4);color:#cbb6ff}
.ticket-awaiting_user,.ticket-in_progress{background:rgba(34,211,238,.12);border-color:rgba(34,211,238,.35);color:#7fe7f5}
.ticket-resolved,.ticket-closed{background:rgba(34,197,94,.12);border-color:rgba(34,197,94,.35);color:#86efac}
/* pagination FR */
.pager{display:flex;align-items:center;justify-content:center;gap:14px;margin-top:34px}
.pg{display:inline-flex;align-items:center;background:var(--panel);border:1px solid var(--border-2);color:var(--text);
  border-radius:999px;padding:10px 20px;font-size:14px;font-weight:600;text-decoration:none;transition:.15s}
.pg:hover{border-color:var(--accent);background:rgba(168,85,247,.12)}
.pg.disabled{opacity:.4;pointer-events:none}
.pg-info{font-size:13px;color:var(--muted)}
/* FAQ (landing, SEO) */
.faq{display:grid;gap:12px;margin-top:26px;text-align:left}
.faq-item{background:var(--panel);border:1px solid var(--border);border-radius:var(--radius);
  padding:0 20px;transition:border-color .18s ease,box-shadow .18s ease}
.faq-item[open]{border-color:rgba(124,92,255,.45);box-shadow:0 8px 30px rgba(124,92,255,.12)}
.faq-item summary{list-style:none;cursor:pointer;font-weight:600;font-size:16px;color:var(--text);
  padding:18px 0;display:flex;align-items:center;justify-content:space-between;gap:14px}
.faq-item summary::-webkit-details-marker{display:none}
.faq-item summary::after{content:"+";font-size:22px;font-weight:400;color:var(--accent);
  line-height:1;transition:transform .2s ease;flex:0 0 auto}
.faq-item[open] summary::after{transform:rotate(45deg)}
.faq-item summary:hover{color:#cbb6ff}
.faq-a{color:var(--muted);font-size:15px;line-height:1.7;padding:0 0 20px}
.faq-a strong{color:var(--text);font-weight:600}
/* ===== Animation d'attente génération d'image ===== */
.gi-loader{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:16px;width:100%;padding:34px 24px;text-align:center}
.gi-orb{position:relative;width:108px;height:108px;display:grid;place-items:center}
.gi-orb::before{content:"";position:absolute;inset:0;border-radius:50%;
  background:conic-gradient(from 0deg,var(--accent-2),var(--accent-3),var(--accent),var(--accent-2));
  animation:giSpin 2.4s linear infinite;
  -webkit-mask:radial-gradient(farthest-side,transparent calc(100% - 10px),#000 calc(100% - 9px));
  mask:radial-gradient(farthest-side,transparent calc(100% - 10px),#000 calc(100% - 9px))}
.gi-orb::after{content:"";position:absolute;inset:8px;border-radius:50%;box-shadow:0 0 50px 8px rgba(124,92,255,.45);animation:giPulse 1.8s ease-in-out infinite}
.gi-orb-core{position:relative;width:56px;height:56px;border-radius:50%;
  background:radial-gradient(circle at 34% 30%,#fff,var(--accent) 52%,var(--accent-2) 100%);
  box-shadow:0 0 26px rgba(168,85,247,.8),inset 0 0 16px rgba(255,255,255,.35);animation:giCore 1.8s ease-in-out infinite}
.gi-orb-core::after{content:"\2726";position:absolute;inset:0;display:grid;place-items:center;font-size:24px;color:#fff;text-shadow:0 0 10px rgba(255,255,255,.85);animation:giSpin 3.6s linear infinite reverse}
@keyframes giSpin{to{transform:rotate(360deg)}}
@keyframes giPulse{0%,100%{opacity:.45;transform:scale(.9)}50%{opacity:1;transform:scale(1.05)}}
@keyframes giCore{0%,100%{transform:scale(.93)}50%{transform:scale(1.07)}}
.gi-status{font-size:15px;font-weight:600;color:var(--text);min-height:20px}
.gi-dots::after{content:"";animation:giDots 1.4s steps(1,end) infinite}
@keyframes giDots{0%{content:""}25%{content:"."}50%{content:".."}75%{content:"..."}}
.gi-progress{position:relative;width:min(440px,86%);height:10px;border-radius:999px;background:rgba(255,255,255,.07);border:1px solid var(--border-2);overflow:hidden}
.gi-progress-bar{position:relative;height:100%;width:0;border-radius:999px;
  background:linear-gradient(90deg,var(--accent-2),var(--accent),var(--accent-3));background-size:200% 100%;
  box-shadow:0 0 16px rgba(124,92,255,.7);transition:width .25s ease;animation:giFlow 2s linear infinite}
@keyframes giFlow{to{background-position:200% 0}}
.gi-progress-bar::after{content:"";position:absolute;top:0;left:0;height:100%;width:46px;
  background:linear-gradient(90deg,transparent,rgba(255,255,255,.55),transparent);animation:giShine 1.3s ease-in-out infinite}
@keyframes giShine{0%{transform:translateX(-46px)}100%{transform:translateX(460px)}}
.gi-pct{font-size:13px;font-weight:700;color:#cbb6ff;font-variant-numeric:tabular-nums}
.gi-sub{font-size:12px;color:var(--muted-2);min-height:14px}
/* résultat : image + barre d'actions (télécharger/partager/supprimer) */
.result-single{display:flex;flex-direction:column;align-items:center;gap:12px;padding:14px;width:100%}
.result-single img{max-height:44vh;border-radius:var(--radius)}
.result-actions{display:flex;gap:8px;align-items:center;flex-wrap:wrap;justify-content:center}
.result-grid .rg-item{display:flex;flex-direction:column;gap:8px}
.result-grid .result-actions .lbl{display:none}
.result-grid .gal-btn{height:34px}
.result-grid .gal-dl,.result-grid .gal-out{width:34px;flex:0 0 34px;padding:0}
.gal-dl{border:0;color:#fff;padding:0 16px;background:linear-gradient(135deg,var(--accent-2),var(--accent));box-shadow:0 4px 14px rgba(124,92,255,.30)}
.gal-dl:hover{filter:brightness(1.08);transform:translateY(-1px)}
.gal-out{padding:0 16px;background:var(--panel);color:var(--text)}
.gal-out:hover{border-color:var(--accent);color:#fff;background:rgba(168,85,247,.14)}
/* ===== Pages documentaires (légales + contact) — charte sombre ===== */
.legal{max-width:880px;margin:0 auto;padding:46px 24px 72px}
.legal .page-hero{margin-bottom:28px;padding-bottom:22px;border-bottom:1px solid var(--border)}
.legal .eyebrow{display:inline-block;font-size:12px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;
  color:var(--accent);background:rgba(168,85,247,.12);border:1px solid rgba(168,85,247,.3);padding:5px 12px;border-radius:999px;margin-bottom:14px}
.legal h1{font-size:32px;font-weight:800;margin:0 0 10px;letter-spacing:-.02em}
.legal .subtitle{color:var(--muted);font-size:16px;margin:0 0 6px;line-height:1.5}
.legal .updated{color:var(--muted-2);font-size:13px;margin:0}
.legal .page-content h2{font-size:19px;font-weight:700;margin:30px 0 12px;color:var(--text)}
.legal .page-content h3{font-size:16px;font-weight:700;margin:22px 0 8px;color:var(--text)}
.legal .page-content p,.legal .page-content li{color:var(--muted);font-size:15px;line-height:1.75}
.legal .page-content ul,.legal .page-content ol{padding-left:20px;margin:10px 0}
.legal .page-content li{margin-bottom:6px}
.legal a{color:var(--accent);text-decoration:none}
.legal a:hover{text-decoration:underline}
.legal strong{color:var(--text)}
.legal .info-box{background:var(--panel);border:1px solid var(--border-2);border-radius:var(--radius);
  padding:18px 20px;margin:14px 0 6px;font-size:14.5px;line-height:1.7;color:var(--text)}
.legal .info-box a{color:var(--accent)}
/* Contact : 2 colonnes (infos + formulaire) */
.contact-grid{display:grid;grid-template-columns:1fr 1.4fr;gap:36px;margin-top:6px}
@media(max-width:760px){.contact-grid{grid-template-columns:1fr;gap:28px}}
.contact-info h3{font-size:16px;margin:0 0 8px;color:var(--text)}
.contact-info>p{color:var(--muted);font-size:14.5px;line-height:1.6;margin:0 0 18px}
.contact-info .ci-item{margin-bottom:20px}
.contact-info .ci-label{font-size:11px;color:var(--muted-2);text-transform:uppercase;letter-spacing:.06em;font-weight:700;margin-bottom:4px}
.contact-info .ci-val{font-size:14.5px;color:var(--muted);line-height:1.6}
.contact-info .ci-val a{color:var(--accent)}
.contact-form .fg{margin-bottom:16px}
.contact-form label{display:block;font-size:13px;font-weight:600;margin-bottom:6px;color:var(--text)}
.contact-form .help{font-size:12px;color:var(--muted-2);margin-top:4px}
.contact-form .err-msg{font-size:12px;color:#fda4b4;margin-top:4px}
.contact-form .fg.error .sel-input,.contact-form .fg.error .prompt{border-color:var(--danger)}
.flash-ok{padding:14px 18px;background:rgba(34,197,94,.1);border:1px solid rgba(34,197,94,.35);border-radius:12px;color:#86efac;font-size:14px;margin-bottom:20px}
.flash-err{padding:14px 18px;background:rgba(244,63,94,.1);border:1px solid rgba(244,63,94,.35);border-radius:12px;color:#fda4b4;font-size:14px;margin-bottom:20px}
.ctx-box{background:var(--panel);border:1px solid var(--accent-2);border-radius:12px;padding:14px 18px;margin-bottom:20px;font-size:13px;color:var(--muted)}
.ctx-box strong{color:var(--text)}
.legal .page-content table{width:100%;border-collapse:collapse;margin:14px 0;font-size:14px}
.legal .page-content th{text-align:left;padding:10px 12px;color:var(--muted-2);font-size:11px;text-transform:uppercase;letter-spacing:.04em;border-bottom:1px solid var(--border-2);background:rgba(255,255,255,.03)}
.legal .page-content td{padding:10px 12px;border-bottom:1px solid var(--border);color:var(--muted)}
.legal .page-content tr:last-child td{border-bottom:0}
/* ===== Mobile : barres d'actions sous les images ===== */
@media(max-width:760px){
  /* Galerie média : icônes seules sous chaque image (pas de texte) */
  .gal-actions{justify-content:center;gap:6px}
  .gal-actions .lbl{display:none}
  .gal-share{flex:0 0 40px;width:40px;padding:0}
  /* Studio : barre d'actions du résultat un peu plus compacte (texte conservé) */
  .result-actions .gal-btn{height:36px;font-size:12.5px}
  .result-actions .gal-dl,.result-actions .gal-out{padding:0 12px}
}
/* Champ fichier stylé : bouton « Parcourir » harmonisé (input natif masqué) */
.file-hidden{position:absolute!important;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0 0 0 0);white-space:nowrap;border:0}
.file-row{display:flex;align-items:center;gap:10px;flex-wrap:wrap;margin-top:2px}
.file-btn{cursor:pointer;font-size:14px;padding:10px 18px}
.file-name{font-size:13px;color:var(--muted);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:100%}
