/* static/app.css */
:root{
  --brand:#0ea5e9; --ink:#0f172a; --muted:#6a7a96; --bg:#fafafa; --card:#fff; --line:#e5e7eb;
  --wrap:clamp(1100px,94vw,1440px); --shadow:0 10px 28px rgba(2,132,199,.10);
}

/* Base */
*{box-sizing:border-box}
html,body{min-height:100%}
body{
  margin:0; background:var(--bg); color:var(--ink);
  font:14.5px/1.55 Inter,system-ui,Segoe UI,Roboto,sans-serif;
  -webkit-text-size-adjust:100%;
}
img,svg,video{max-width:100%;height:auto}

/* Focus accessibility */
:is(a,button,.btn,input,select,textarea,.item .del):focus-visible{
  outline:2px solid var(--brand); outline-offset:2px;
}

/* Header */
.brandbar{background:#fff;border-bottom:1px solid var(--line)}
.brandwrap{max-width:var(--wrap);margin:0 auto;display:flex;align-items:center;gap:12px;padding:10px 14px}
.brand-logo{width:48px;height:48px}
.brand-titles{display:flex;flex-direction:column}
.brand-title{margin:0;font-size:32px;line-height:1.2}
.brand-sub{margin:4px 0 0;color:var(--muted);font-size:13px}

/* Slot title */
#slot{display:inline-flex;gap:3px;line-height:36px;height:36px;overflow:hidden;cursor:pointer}
.reel{display:inline-block;width:0.74em;height:36px;overflow:hidden}
.strip{display:block;will-change:transform}
.cell{display:block;height:36px;font-weight:800;font-size:32px}

/* Layout */
.wrap{max-width:var(--wrap);margin:12px auto;padding:0 12px}
.card{background:var(--card);border:1px solid var(--line);border-radius:12px;box-shadow:var(--shadow);padding:12px;margin-bottom:12px}
.h{margin:4px 0 8px;font-size:15px;position:relative;padding-left:9px}
.h::before{content:"";position:absolute;left:0;top:2px;bottom:2px;width:3px;background:var(--brand);border-radius:2px}
.row{display:block;margin-bottom:12px}
.grid-1{display:grid;gap:8px;grid-template-columns:1fr}
.grid-2{display:grid;gap:8px;grid-template-columns:1fr 1fr}
.grid-3{display:grid;gap:8px;grid-template-columns:repeat(3,1fr)}
.grid-ref .input-with-btn{display:grid;grid-template-columns:1fr auto;gap:6px}

/* Controls */
label{display:flex;flex-direction:column;gap:4px;font-size:13.5px}
input,select,textarea{
  width:100%;border:1px solid var(--line);border-radius:8px;background:#fff;
  padding:8px 10px;font-size:14px;min-height:34px
}
textarea{min-height:108px;resize:vertical}
.mini-color{width:52px;height:32px;padding:0;border-radius:6px}

/* Logo */
.logo-inline{display:flex;align-items:center;gap:8px}
.logo-mini{max-height:44px;max-width:160px;object-fit:contain;border:1px dashed #cbd5e1;border-radius:6px;padding:2px;background:#f8fafc}

/* Zones */
.zone{border:1px solid var(--line);border-radius:10px;overflow:hidden;background:#fff}
.zone-head{padding:8px 10px;font-weight:600;background:#f6f8fc;border-bottom:1px solid var(--line);font-size:13.5px}
.zone-body{padding:10px}

/* Lignes */
.rows-wrap{display:grid;grid-template-columns:1fr 320px;gap:10px;align-items:start}
.items{border:1px solid var(--line);border-radius:10px;padding:8px;background:#fff}
.items-head,.item{display:grid;gap:6px;align-items:center;grid-template-columns:3fr 1fr 1fr .9fr .9fr .9fr 1fr 34px}
.items-head{font-weight:600;color:var(--muted);padding:4px 2px;border-bottom:1px dashed var(--line);position:sticky;top:0;background:#fff;z-index:1}
#rows{display:flex;flex-direction:column;gap:8px;padding-top:6px}
.item input{height:32px}
.item .del{display:inline-flex;align-items:center;justify-content:center;height:32px;width:32px;border:1px solid var(--line);border-radius:8px;background:#fff;cursor:pointer}
.item .del:hover{border-color:#cbd5e1}
.btn-row{display:flex;gap:8px;align-items:center;margin-top:8px}
.hint{color:var(--muted);font-size:12px}

/* Totaux */
.totals{display:flex;flex-direction:column;gap:8px}
.totals>div{display:grid;grid-template-columns:auto 1fr;align-items:center;border:1px solid var(--line);border-radius:10px;padding:8px 12px;background:#fff}
.totals>div b{padding-right:12px}
.totals>div span{text-align:right;font-variant-numeric:tabular-nums}
.totals .ttc{border-color:var(--brand);box-shadow:0 4px 14px rgba(2,132,199,.12)}

/* Buttons */
.btn{appearance:none;cursor:pointer;background:#fff;color:var(--ink);border:1px solid var(--line);border-radius:8px;padding:8px 12px;min-height:36px;font-weight:600}
.btn:hover{border-color:#cbd5e1}
.btn.ghost{background:#fff}
.btn.primary{background:var(--brand);border-color:var(--brand);color:#fff}
.actions{display:flex;gap:10px;justify-content:flex-end;padding-top:6px;border-top:1px solid var(--line);margin-top:12px}

/* Modal */
.modal{display:none;position:fixed;inset:0;background:rgba(0,0,0,.5);z-index:50;align-items:center;justify-content:center;padding:18px}
.modal.open{display:flex}
.modal-content{background:#fff;border-radius:12px;max-width:1100px;width:min(94vw,1100px);height:82vh;display:flex;flex-direction:column;position:relative;box-shadow:0 10px 30px rgba(0,0,0,.2)}
.modal-close{position:absolute;top:8px;right:8px;width:34px;height:34px;border:0;border-radius:50%;background:#eee;cursor:pointer;font-size:20px}
.modal-content iframe{flex:1;border:0;border-top-left-radius:12px;border-top-right-radius:12px;width:100%}
.modal-actions{padding:8px;display:flex;justify-content:flex-end;gap:8px;border-top:1px solid #e2e8f0}

/* Footer */
.site-footer{max-width:var(--wrap);margin:8px auto 18px;text-align:center;color:#475569;font-size:12.5px}
.site-footer a{color:#0ea5e9;text-decoration:none}

/* Horizontal pillsets (optional classes if present) */
.pillset,.pills,.tabs,.chiplist{display:flex;gap:8px}
.pill,.chip{scroll-snap-align:start}

/* Consent popup (single, patched) */
#consent-popup{
  position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);
  background:#333;color:#fff;padding:20px 30px;border-radius:10px;
  font-size:16px;text-align:center;opacity:0;pointer-events:none;
  transition:opacity .35s ease;z-index:9999
}
#consent-popup.show{opacity:1;pointer-events:auto}
#consent-popup[hidden]{display:none !important}
#consent-popup button{display:inline-block;margin-top:12px;padding:8px 16px;background:#4a6cf7;color:#fff;border:0;border-radius:6px;cursor:pointer}

/* Reduce motion */
@media (prefers-reduced-motion:reduce){
  *{animation:none!important;transition:none!important;scroll-behavior:auto!important}
}

/* ====== Mobile (≤980px) ====== */
@media (max-width:980px){
  /* Safe areas */
  body{
    padding-left:max(0px, env(safe-area-inset-left));
    padding-right:max(0px, env(safe-area-inset-right));
    padding-bottom:max(0px, env(safe-area-inset-bottom));
  }
  .brandbar{padding-top:env(safe-area-inset-top)}

  /* Typography and spacing */
  body{font-size:clamp(15px,1.6vw + .2rem,17px)}
  .brandwrap{padding:12px 16px}
  .brand-logo{width:40px;height:40px}
  .brand-title{font-size:clamp(22px,6vw,28px)}
  .brand-sub{font-size:clamp(12px,3.4vw,14px)}
  .wrap{padding:0 16px;margin:14px auto}
  .card{padding:14px;margin-bottom:14px}
  .h{font-size:clamp(14px,3.6vw,16px)}

  /* Forms: avoid iOS zoom, comfortable touch targets */
  input,select,textarea{
    font-size:16px; /* iOS no-zoom */
    min-height:44px;padding:10px 12px;border-radius:10px
  }
  .mini-color{width:56px;height:40px}
  .btn{min-height:44px;padding:10px 14px;border-radius:10px}
  .item .del{width:44px;height:44px;border-radius:10px}

  /* Layout: stack vertically, reorder for better reading */
  .grid-2,.grid-3{grid-template-columns:1fr}
  .grid-ref .input-with-btn{grid-template-columns:1fr auto}

  .rows-wrap{
    grid-template-columns:1fr;
    grid-template-areas:
      "totals"
      "items";
    gap:12px
  }
  .items{grid-area:items}
  .totals{grid-area:totals}

  /* Items table → compact cards */
  .items-head{display:none}
  .item{
    grid-template-columns:1fr 1fr;
    gap:8px;
    /* helper to place the TVA badge as a grid item */
  }
  .item>*:nth-child(1){grid-column:1/-1}
  .item>.del{grid-column:2;justify-self:end}

  /* Badge TVA % collé à la cellule TVA sur mobile.
     Hypothèse: ordre des colonnes: 1 Libellé, 2 PU HT, 3 PU TTC, 4 Qté, 5 Unité, 6 TVA%, 7 Total HT, 8 Suppr.
     En grille 2 colonnes, TVA% arrive en ligne 4, colonne 1. */
  .item::after{
    content:"TVA %";
    display:inline-block;
    grid-column:1; /* colonne de la cellule TVA% */
    grid-row:4;    /* ligne de la cellule TVA% */
    justify-self:end; align-self:center;
    font-size:12px; line-height:1;
    color:#64748b; background:#f8fafc;
    border:1px solid var(--line);
    border-radius:999px; padding:3px 8px;
    pointer-events:none; white-space:nowrap;
    margin-right:6px;
  }

  /* Actions */
  .actions{justify-content:center;gap:12px;padding-top:10px;margin-top:14px}

  /* Modal full-viewport on mobile */
  .modal{padding:0}
  .modal-content{
    width:100vw;height:100vh;border-radius:0;
    max-width:none;box-shadow:none
  }
  .modal-content iframe{border-radius:0}
  .modal-actions{position:sticky;bottom:0;background:#fff}

  /* Horizontal pillsets */
  .pillset,.pills,.tabs,.chiplist{
    overflow-x:auto;-webkit-overflow-scrolling:touch;scroll-snap-type:x mandatory;
    padding-bottom:6px;margin:0 -6px 6px;padding-left:6px;padding-right:6px
  }

  /* Images */
  .logo-mini{max-height:40px}

  /* Slot title sizing */
  #slot{line-height:40px;height:40px}
  .reel{height:40px}
  .cell{height:40px;font-size:clamp(22px,7.2vw,30px)}
}
