/* ============================================================================
   VLEENO — Application shell (dashboard)
   Loaded after style.css
   ========================================================================== */
body.app { background: var(--canvas); overflow: hidden; }
.shell { display: grid; grid-template-columns: 264px 1fr; height: 100vh; }

/* ---- Sidebar ---- */
.side { background: var(--slate-900); color: rgba(255,255,255,.66); display: flex; flex-direction: column; padding: 18px 14px; overflow-y: auto; }
.side__brand { display: flex; align-items: center; gap: 11px; padding: 8px 10px 18px; }
.side__brand .logo__mark { width: 36px; height: 36px; border-radius: 10px; }
.side__brand .logo__name { color: #fff; font-weight: 800; font-size: 1.12rem; }
.side__brand small { display:block; font-size:.62rem; letter-spacing:.18em; color: rgba(255,255,255,.4); font-weight:600; }
.side__co { display:flex; align-items:center; gap:10px; padding:10px 12px; margin-bottom:14px; background: rgba(255,255,255,.05); border:1px solid rgba(255,255,255,.08); border-radius: var(--r-md); }
.side__co-logo { width:34px; height:34px; border-radius:9px; background: var(--grad); display:grid; place-items:center; color:#fff; font-weight:800; font-size:.9rem; overflow:hidden; flex:none; }
.side__co-logo img { width:100%; height:100%; object-fit:cover; }
.side__co-name { font-size:.86rem; font-weight:700; color:#fff; line-height:1.2; }
.side__co-name span { display:block; font-size:.7rem; font-weight:500; color: rgba(255,255,255,.45); }
.side__group { font-size:.68rem; text-transform:uppercase; letter-spacing:.14em; color: rgba(255,255,255,.32); margin:16px 12px 8px; font-weight:700; }
.side__link { display:flex; align-items:center; gap:12px; padding:10px 12px; border-radius:11px; font-weight:600; font-size:.92rem; color: rgba(255,255,255,.7); transition: background .18s, color .18s; position:relative; }
.side__link svg { width:20px; height:20px; flex:none; opacity:.9; }
.side__link:hover { background: rgba(255,255,255,.06); color:#fff; }
.side__link.active { background: var(--grad); color:#fff; box-shadow: 0 8px 20px -10px rgba(124,92,255,.8); }
.side__link .pill { margin-left:auto; background: rgba(255,255,255,.16); color:#fff; font-size:.66rem; padding:2px 7px; border-radius:999px; font-weight:800; }
.side__foot { margin-top:auto; padding:12px; }

/* ---- Topbar ---- */
.main { display:flex; flex-direction:column; overflow:hidden; }
.topbar { height:66px; background: var(--paper); border-bottom:1px solid var(--line); display:flex; align-items:center; gap:16px; padding:0 clamp(16px,3vw,30px); flex:none; }
.topbar__menu { display:none; width:42px; height:42px; border-radius:11px; border:1px solid var(--line); background:#fff; }
.topbar__title { font-size:1.18rem; font-weight:800; letter-spacing:-.01em; }
.topbar__title span { display:block; font-size:.78rem; font-weight:500; color: var(--muted); }
.topbar__search { margin-left:auto; position:relative; }
.topbar__search input { width:240px; padding:10px 14px 10px 38px; border:1px solid var(--line); border-radius:999px; background: var(--canvas); }
.topbar__search svg { position:absolute; left:13px; top:50%; transform:translateY(-50%); width:17px; height:17px; color: var(--muted); }
.topbar__icon { width:42px; height:42px; border-radius:12px; border:1px solid var(--line); background:#fff; display:grid; place-items:center; position:relative; color: var(--text-soft); }
.topbar__icon svg { width:20px; height:20px; }
.topbar__icon .dot { position:absolute; top:9px; right:10px; width:8px; height:8px; border-radius:50%; background: var(--danger); border:2px solid #fff; }
.topbar__user { display:flex; align-items:center; gap:10px; }
.avatar { width:40px; height:40px; border-radius:12px; background: var(--grad); color:#fff; display:grid; place-items:center; font-weight:800; font-size:.85rem; flex:none; }

.demo-bar { flex:none; display:flex; align-items:center; gap:10px; justify-content:center; flex-wrap:wrap; padding:9px 16px; background:linear-gradient(90deg, rgba(245,158,11,.16), rgba(245,158,11,.08)); color:#92500e; font-size:.9rem; font-weight:600; border-bottom:1px solid rgba(245,158,11,.3); }
.demo-bar button { border:none; background:var(--slate-900); color:#fff; font-weight:700; font-size:.84rem; padding:7px 14px; border-radius:999px; cursor:pointer; }
.demo-bar button:hover { background:var(--slate-800); }
.view { flex:1; overflow-y:auto; padding: clamp(18px,3vw,30px); }
.view__head { display:flex; align-items:flex-end; justify-content:space-between; gap:16px; flex-wrap:wrap; margin-bottom:22px; }
.view__head h1 { font-size:1.6rem; }
.view__head p { color: var(--muted); font-size:.95rem; }
.view__actions { display:flex; gap:10px; flex-wrap:wrap; }

/* ---- Cards / grid ---- */
.cards { display:grid; gap:18px; }
.cards--4 { grid-template-columns: repeat(4,1fr); }
.cards--3 { grid-template-columns: repeat(3,1fr); }
.cards--2 { grid-template-columns: repeat(2,1fr); }
.card { background: var(--paper); border:1px solid var(--line); border-radius: var(--r-lg); padding:22px; box-shadow: var(--sh-sm); }
.card__head { display:flex; align-items:center; justify-content:space-between; margin-bottom:16px; gap:12px; }
.card__head h3 { font-size:1.05rem; }
.card__head a { font-size:.85rem; font-weight:700; color: var(--brand); }

.kpi { display:flex; flex-direction:column; gap:10px; }
.kpi__top { display:flex; align-items:center; justify-content:space-between; }
.kpi__ic { width:44px; height:44px; border-radius:13px; display:grid; place-items:center; }
.kpi__ic svg { width:22px; height:22px; }
.kpi__ic.v { background: rgba(124,92,255,.12); color: var(--brand); }
.kpi__ic.g { background: rgba(16,185,129,.12); color: var(--success); }
.kpi__ic.b { background: rgba(56,189,248,.14); color: #0369a1; }
.kpi__ic.o { background: rgba(245,158,11,.14); color: #b45309; }
.kpi__val { font-size:2rem; font-weight:800; letter-spacing:-.02em; line-height:1; }
.kpi__lbl { color: var(--muted); font-size:.9rem; }
.kpi__trend { font-size:.82rem; font-weight:700; }
.kpi__trend.up { color: var(--success); } .kpi__trend.down { color: var(--danger); }

/* ---- Tables ---- */
.tbl-wrap { overflow-x:auto; }
table.tbl { width:100%; border-collapse: collapse; font-size:.92rem; }
.tbl th { text-align:left; padding:12px 14px; color: var(--muted); font-weight:700; font-size:.78rem; text-transform:uppercase; letter-spacing:.04em; border-bottom:1px solid var(--line); white-space:nowrap; }
.tbl td { padding:13px 14px; border-bottom:1px solid var(--line-2); vertical-align:middle; }
.tbl tr:last-child td { border-bottom:0; }
.tbl tbody tr { transition: background .15s; }
.tbl tbody tr:hover { background: var(--canvas); }
.tbl .who { display:flex; align-items:center; gap:10px; }
.tbl .who .avatar { width:34px; height:34px; border-radius:10px; font-size:.72rem; }
.tbl strong { font-weight:700; }
.cell-sub { color: var(--muted); font-size:.82rem; }
.row-actions { display:flex; gap:6px; }
.icon-btn { width:32px; height:32px; border-radius:9px; border:1px solid var(--line); background:#fff; display:grid; place-items:center; color: var(--text-soft); transition: .15s; }
.icon-btn:hover { border-color: var(--brand); color: var(--brand); }
.icon-btn svg { width:16px; height:16px; }

/* ---- Progress / meters ---- */
.meter { height:8px; border-radius:999px; background: var(--line); overflow:hidden; }
.meter > i { display:block; height:100%; border-radius:999px; background: var(--grad); }
.ring { --p:0; width:120px; height:120px; border-radius:50%; display:grid; place-items:center; background: conic-gradient(var(--brand) calc(var(--p)*1%), var(--line) 0); }
.ring__in { width:90px; height:90px; border-radius:50%; background:#fff; display:grid; place-items:center; text-align:center; }
.ring__in b { font-size:1.6rem; }

/* ---- Planning ---- */
.plan { display:grid; grid-template-columns: 64px repeat(6,1fr); border:1px solid var(--line); border-radius: var(--r-lg); overflow:hidden; background:#fff; }
.plan__h { background: var(--canvas); padding:12px 10px; font-weight:700; font-size:.82rem; text-align:center; border-bottom:1px solid var(--line); }
.plan__time { padding:10px; font-size:.74rem; color: var(--muted); text-align:right; border-right:1px solid var(--line-2); border-bottom:1px solid var(--line-2); }
.plan__cell { min-height:64px; border-right:1px solid var(--line-2); border-bottom:1px solid var(--line-2); padding:5px; }
.plan__ev { background: linear-gradient(135deg, rgba(124,92,255,.14), rgba(34,211,238,.12)); border-left:3px solid var(--brand); border-radius:8px; padding:7px 9px; font-size:.78rem; margin-bottom:4px; cursor:pointer; transition: .15s; }
.plan__ev:hover { transform: translateX(2px); box-shadow: var(--sh-sm); }
.plan__ev b { display:block; font-weight:700; }
.plan__ev span { color: var(--text-soft); }
.plan__ev.g { background: linear-gradient(135deg, rgba(16,185,129,.16), rgba(16,185,129,.05)); border-left-color: var(--success); }
.plan__ev.o { background: linear-gradient(135deg, rgba(245,158,11,.18), rgba(245,158,11,.05)); border-left-color: var(--warning); }

/* ---- QR / pointage ---- */
.qr-card { text-align:center; }
.qr-card img, .qr-box { width:200px; height:200px; margin:0 auto 14px; border-radius: var(--r-md); border:1px solid var(--line); background:#fff; padding:10px; }
.live-feed li { display:flex; align-items:center; gap:12px; padding:12px 0; border-bottom:1px solid var(--line-2); }
.live-feed .dot { width:9px; height:9px; border-radius:50%; flex:none; }
.dot--in { background: var(--success); } .dot--out { background: var(--muted); }
.pulse { position:relative; }
.pulse::after { content:""; position:absolute; inset:-4px; border-radius:50%; border:2px solid var(--success); animation: pulse 1.6s ease-out infinite; }
@keyframes pulse { 0%{opacity:.7;transform:scale(.8)} 100%{opacity:0;transform:scale(1.8)} }

/* ---- Quality checklist ---- */
.check li { display:flex; align-items:center; gap:14px; padding:14px; border:1px solid var(--line); border-radius: var(--r-md); margin-bottom:10px; transition: .15s; }
.check li.done { background: rgba(16,185,129,.05); border-color: rgba(16,185,129,.3); }
.check input { width:22px; height:22px; accent-color: var(--success); flex:none; }
.check .lbl { flex:1; font-weight:600; }
.check li.done .lbl { color: var(--success); }

/* ---- Pipeline (CRM) ---- */
.pipe { display:grid; grid-template-columns: repeat(4,1fr); gap:14px; }
.pipe__col { background: var(--canvas); border-radius: var(--r-md); padding:12px; }
.pipe__col h4 { font-size:.82rem; text-transform:uppercase; letter-spacing:.04em; color: var(--muted); margin-bottom:12px; display:flex; justify-content:space-between; }
.pipe__card { background:#fff; border:1px solid var(--line); border-radius:11px; padding:12px; margin-bottom:10px; box-shadow: var(--sh-sm); cursor:grab; }
.pipe__card b { font-size:.92rem; } .pipe__card .amt { color: var(--brand); font-weight:800; margin-top:6px; }
.pipe__card .cell-sub { margin-top:3px; }

/* ---- Invoice ---- */
.doc { background:#fff; border:1px solid var(--line); border-radius: var(--r-lg); padding: clamp(20px,4vw,40px); max-width:760px; box-shadow: var(--sh-sm); }
.doc__head { display:flex; justify-content:space-between; gap:20px; flex-wrap:wrap; padding-bottom:22px; border-bottom:2px solid var(--line); }
.doc__logo { width:54px; height:54px; border-radius:13px; background: var(--grad); display:grid; place-items:center; color:#fff; font-weight:800; overflow:hidden; }
.doc__logo img{width:100%;height:100%;object-fit:cover}
.doc table { width:100%; border-collapse:collapse; margin:22px 0; font-size:.92rem; }
.doc th { text-align:left; padding:10px; background: var(--canvas); font-size:.76rem; text-transform:uppercase; color: var(--muted); }
.doc td { padding:11px 10px; border-bottom:1px solid var(--line-2); }
.doc__tot { margin-left:auto; width:260px; }
.doc__tot div { display:flex; justify-content:space-between; padding:7px 0; }
.doc__tot .grand { border-top:2px solid var(--line); margin-top:6px; padding-top:12px; font-size:1.2rem; font-weight:800; }

/* ---- Charts (inline SVG) ---- */
.chart { width:100%; height:200px; }
.bar-chart { display:flex; align-items:flex-end; gap:10px; height:180px; padding-top:10px; }
.bar-chart .bar { flex:1; border-radius:7px 7px 0 0; background: var(--grad); position:relative; min-height:4px; transition: height .6s ease; }
.bar-chart .bar span { position:absolute; top:-22px; left:0; right:0; text-align:center; font-size:.72rem; font-weight:700; color: var(--text-soft); }
.bar-chart .bar small { position:absolute; bottom:-22px; left:0; right:0; text-align:center; font-size:.72rem; color: var(--muted); }

/* ---- Modal ---- */
.modal-bg { position:fixed; inset:0; background: rgba(11,16,32,.5); backdrop-filter: blur(4px); display:grid; place-items:center; z-index:200; padding:20px; opacity:0; pointer-events:none; transition: opacity .2s; }
.modal-bg.open { opacity:1; pointer-events:auto; }
.modal { background:#fff; border-radius: var(--r-xl); width: min(560px,100%); max-height: 90vh; overflow-y:auto; box-shadow: var(--sh-lg); transform: translateY(12px) scale(.98); transition: transform .25s; }
.modal-bg.open .modal { transform:none; }
.modal__head { display:flex; align-items:center; justify-content:space-between; padding:22px 24px; border-bottom:1px solid var(--line); }
.modal__head h3 { font-size:1.2rem; }
.modal__body { padding:24px; }
.modal__foot { padding:18px 24px; border-top:1px solid var(--line); display:flex; justify-content:flex-end; gap:10px; }

.field { margin-bottom:16px; }
.field label { display:block; font-weight:700; font-size:.86rem; margin-bottom:7px; }
.field input, .field select, .field textarea { width:100%; padding:11px 13px; border:1.5px solid var(--line); border-radius: var(--r-sm); background:#fff; transition: border-color .15s, box-shadow .15s; }
.field input:focus, .field select:focus, .field textarea:focus { border-color: var(--brand); box-shadow: 0 0 0 3px rgba(124,92,255,.14); }
.field-row { display:grid; grid-template-columns:1fr 1fr; gap:14px; }
.help { color: var(--muted); font-size:.82rem; margin-top:5px; }

.empty { text-align:center; padding:50px 20px; color: var(--muted); }
.empty svg { width:48px; height:48px; margin:0 auto 14px; opacity:.4; }

.swatch { width:34px; height:34px; border-radius:9px; border:2px solid #fff; box-shadow: var(--sh-sm); cursor:pointer; }
.swatch.sel { outline:2px solid var(--brand); outline-offset:2px; }

.toast { position:fixed; bottom:24px; left:50%; transform:translateX(-50%) translateY(20px); background: var(--slate-900); color:#fff; padding:13px 22px; border-radius:999px; box-shadow: var(--sh-lg); font-weight:600; font-size:.9rem; opacity:0; pointer-events:none; transition: .3s; z-index:300; display:flex; align-items:center; gap:10px; }
.toast.show { opacity:1; transform:translateX(-50%) translateY(0); }
.toast svg { width:18px; height:18px; color: var(--success); }

@media (max-width: 1100px){ .cards--4{grid-template-columns:1fr 1fr} .pipe{grid-template-columns:1fr 1fr} }
@media (max-width: 860px){
  .shell{grid-template-columns:1fr}
  .side{position:fixed; inset:0 auto 0 0; width:264px; z-index:150; transform:translateX(-100%); transition:transform .3s; box-shadow: var(--sh-lg);}
  body.nav-open .side{transform:none}
  body.nav-open::after{content:"";position:fixed;inset:0;background:rgba(11,16,32,.5);z-index:140}
  .topbar__menu{display:grid; place-items:center}
  .topbar__search{display:none}
  .cards--4,.cards--3,.cards--2{grid-template-columns:1fr}
  .plan{grid-template-columns:48px repeat(6,minmax(90px,1fr)); overflow-x:auto}
  .field-row{grid-template-columns:1fr}
}
