/* CyberFlash Partner Styles (no Tailwind) */
:root{
  --primary:#007BFF;
  --primary-hover:#006AE6;
  --accent:#FF7B00;
  --accent-hover:#E66F00;
  --bg:#FFFFFF;
  --panel:#FFFFFF;
  --text:#111827;
  --muted:#6B7280;
  --border:#E5E7EB;
  --gray-50:#F9FAFB;
  --gray-100:#F3F4F6;
  --gray-700:#374151;
  --success-bg:#D1FAE5; --success-border:#10B981; --success-text:#065F46;
  --warn-bg:#FEF3C7; --warn-border:#F59E0B; --warn-text:#92400E;
  --danger-bg:#FEE2E2; --danger-text:#991B1B;
}

*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{font-family:system-ui,-apple-system,Segoe UI,Roboto,Ubuntu,Cantarell,Noto Sans,sans-serif;background:#F8FAFC;color:var(--text)}
a{color:var(--primary);text-decoration:none}
a:hover{color:var(--primary-hover)}

/* Top nav (modern) */
.pf-nav{position:sticky;top:0;z-index:50;background:rgba(255,255,255,0.85);backdrop-filter:saturate(160%) blur(12px);border-bottom:1px solid var(--border)}
.pf-nav::after{content:"";position:absolute;left:0;right:0;bottom:-1px;height:2px;background:linear-gradient(90deg,var(--primary),var(--accent));opacity:.9}
.pf-nav .inner{max-width:1120px;margin:0 auto;padding:10px 16px;display:flex;align-items:center;justify-content:space-between;gap:12px;position:relative}
.pf-brand{display:flex;gap:6px;align-items:center;font-weight:900;font-size:18px;letter-spacing:.2px}
.pf-brand .cyber{color:var(--primary)}
.pf-brand .flash{color:var(--accent)}
.pf-menu{display:flex;gap:8px;flex-wrap:wrap}
.pf-menu a{position:relative;color:var(--text);padding:10px 12px;border-radius:8px;transition:background .2s ease, color .2s ease}
.pf-menu a::after{content:"";position:absolute;left:12px;right:12px;bottom:6px;height:2px;background:linear-gradient(90deg,var(--primary),var(--accent));transform:scaleX(0);transform-origin:left;transition:transform .18s ease}
.pf-menu a:hover{background:var(--gray-100)}
.pf-menu a:hover::after,.pf-menu a.active::after{transform:scaleX(1)}
.pf-actions{display:flex;align-items:center;gap:8px}
.pf-cta{display:inline-flex;align-items:center;gap:8px;padding:8px 14px;border-radius:999px;background:linear-gradient(90deg,var(--primary),var(--accent));color:#fff;border:0;box-shadow:0 4px 16px rgba(0,123,255,.2);text-decoration:none}
.pf-cta:hover{filter:saturate(110%) brightness(1.02)}
.pf-user{display:flex;gap:8px;align-items:center}
.pf-user .logout{background:#111827;color:#fff;border:1px solid #374151;border-radius:6px;padding:6px 10px}
.pf-burger{display:none;flex-direction:column;gap:4px;width:40px;height:36px;align-items:center;justify-content:center;border:1px solid var(--border);border-radius:8px;background:#fff}
.pf-burger span{display:block;width:20px;height:2px;background:var(--text);transition:transform .2s ease, opacity .2s ease}
.pf-burger.open span:nth-child(1){transform:translateY(6px) rotate(45deg)}
.pf-burger.open span:nth-child(2){opacity:0}
.pf-burger.open span:nth-child(3){transform:translateY(-6px) rotate(-45deg)}
@media(max-width:768px){
  .pf-burger{display:flex}
  .pf-menu{display:none;position:absolute;top:54px;left:0;right:0;background:#fff;border-bottom:1px solid var(--border);padding:12px 16px;box-shadow:0 8px 20px rgba(0,0,0,.06)}
  .pf-menu.open{display:flex;flex-direction:column}
  .pf-actions{display:flex}
  /* Layout mobile: 2 colonnes (bouton à gauche | burger à droite), marque cachée */
  .pf-nav .inner{display:grid;grid-template-columns:1fr 40px;align-items:center;grid-auto-flow:column}
  .pf-actions{grid-column:1;justify-self:start}
  .pf-burger{grid-column:2;justify-self:end}
  /* Cacher totalement la marque (logo + texte) sur mobile */
  .pf-brand{display:none}
  .pf-brand .cyber,.pf-brand .flash{display:none}
  /* Compacter le CTA en mobile */
  .pf-cta{padding:6px 10px;font-size:14px;white-space:nowrap}
}

/* Sidebar layout */
.pf-topbar{position:sticky;top:0;z-index:60;display:flex;align-items:center;justify-content:space-between;padding:10px 16px;background:rgba(255,255,255,.9);border-bottom:1px solid var(--border);backdrop-filter:saturate(160%) blur(10px)}
.pf-topbar .right{display:flex;align-items:center;gap:8px}
@media(min-width:1024px){.pf-topbar{display:none}}

.pf-shell{display:grid;grid-template-columns:260px 1fr;min-height:100vh}
@media(max-width:1023px){.pf-shell{grid-template-columns:1fr}}

.pf-sidebar{background:#fff;border-right:1px solid var(--border);padding:12px}
@media(min-width:1024px){.pf-sidebar{position:sticky;top:0;height:100vh}}
@media(max-width:1023px){
  .pf-sidebar{position:fixed;top:0;left:0;bottom:0;width:260px;transform:translateX(-100%);transition:transform .2s ease;z-index:70}
  .pf-sidebar.open{transform:translateX(0)}
  .pf-overlay{display:none;position:fixed;inset:0;background:rgba(17,24,39,.45);z-index:65}
  .pf-overlay.open{display:block}
}
.pf-side{display:flex;flex-direction:column;height:100%;gap:12px}
.pf-side .pf-brand{padding:4px 6px}
.pf-navlist{display:flex;flex-direction:column;gap:4px}
.pf-item{display:flex;align-items:center;gap:10px;padding:10px 12px;border-radius:8px;color:var(--text);text-decoration:none;transition:background .15s ease}
.pf-item i{width:18px;text-align:center;color:var(--muted)}
.pf-item:hover{background:var(--gray-100)}
.pf-item.active{background:linear-gradient(90deg, rgba(0,123,255,.08), rgba(255,123,0,.08));border:1px solid var(--border)}
.pf-side-footer{margin-top:auto}
.pf-content{min-width:0}

/* Header */
.pf-header{background:#fff;border-bottom:1px solid var(--border)}
.pf-header .inner{max-width:1120px;margin:0 auto;padding:16px}
.pf-title{margin:0;font-size:22px;font-weight:700;color:var(--text)}

/* Common containers */
.cf-container{max-width:960px;margin:16px auto;padding:0 16px}
.cf-wrap{max-width:720px;margin:16px auto;padding:0 16px}
.cf-panel{background:var(--panel);border:1px solid var(--border);border-radius:8px;box-shadow:0 1px 2px rgba(0,0,0,.05)}
.cf-panel-body,.cf-body{padding:16px}
.cf-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.cf-grid-4{display:grid;grid-template-columns:repeat(1,1fr);gap:16px}
@media(min-width:768px){.cf-grid-4{grid-template-columns:repeat(4,1fr)}}
.cf-stat{background:var(--gray-100);border-radius:8px;padding:12px}
.cf-value{font-size:22px;font-weight:700}

/* Section titles */
.section-title{margin:0 0 8px 0;font-size:18px;font-weight:800;color:var(--text)}
.section-sub{margin:0 0 12px 0;font-size:13px;color:var(--muted)}

/* KPI row (mobile: scrollable, desktop: grid) */
.kpi-row{display:flex;gap:12px;overflow-x:auto;padding-bottom:6px;scroll-snap-type:x mandatory}
.kpi-card{flex:0 0 auto;min-width:200px;background:#fff;border:1px solid var(--border);border-radius:10px;padding:12px;scroll-snap-align:start;box-shadow:0 1px 2px rgba(0,0,0,.04)}
.kpi-card .label{color:var(--muted);font-size:13px}
.kpi-card .value{font-size:22px;font-weight:800;color:var(--text)}
.kpi-card.primary{border-color:rgba(0,123,255,.25);box-shadow:0 6px 18px rgba(0,123,255,.08)}
.kpi-card.accent{border-color:rgba(255,123,0,.25);box-shadow:0 6px 18px rgba(255,123,0,.08)}
@media(min-width:768px){
  .kpi-row{display:grid;grid-template-columns:repeat(4,1fr);overflow:visible}
  .kpi-card{min-width:auto}
}

/* Chart card (placeholder friendly) */
.chart-card{position:relative;min-height:220px;background:linear-gradient(135deg,rgba(0,123,255,.08),rgba(255,123,0,.08));border:1px solid var(--border);border-radius:12px;overflow:hidden}
.chart-card .inner{position:absolute;inset:0;padding:16px}
.chart-card .header{display:flex;align-items:center;justify-content:space-between;margin-bottom:8px}
.chart-card .title{font-weight:800;color:var(--text)}
.chart-placeholder{position:absolute;left:0;right:0;bottom:0;height:60%;background:repeating-linear-gradient(90deg,rgba(0,123,255,.14) 0 12px, transparent 12px 24px)}

/* Pie/Donut card using CSS only */
.pie-card{display:flex;gap:16px;align-items:center}
.donut{--p1:40;--p2:40;width:120px;height:120px;border-radius:50%;background:conic-gradient(var(--primary) 0 calc(var(--p1)*1%), var(--accent) 0 calc((var(--p1)+var(--p2))*1%), #e5e7eb 0 100%);position:relative}
.donut::after{content:"";position:absolute;inset:18px;border-radius:50%;background:#fff}
.legend{display:flex;flex-direction:column;gap:8px}
.legend .item{display:flex;align-items:center;gap:8px;color:var(--text)}
.legend .dot{width:10px;height:10px;border-radius:50%}
.legend .dot.p1{background:var(--primary)}
.legend .dot.p2{background:var(--accent)}
.legend .dot.p3{background:#e5e7eb}

/* Progress bars */
.progress-group{display:grid;gap:8px}
.progress{background:var(--gray-100);border-radius:999px;overflow:hidden;height:8px;border:1px solid var(--border)}
.progress .bar{height:100%;background:linear-gradient(90deg,var(--primary),var(--accent))}

/* Mini bars (sparklines) */
.mini-bars{position:absolute;left:16px;right:16px;bottom:16px;height:120px;display:flex;align-items:flex-end;gap:6px;overflow-x:auto;padding-bottom:6px}
.mini-bars .bar{width:10px;border-radius:6px 6px 0 0;background:linear-gradient(180deg,var(--accent),var(--primary));box-shadow:0 2px 6px rgba(0,0,0,.06)}
.mini-bars .bar.weak{opacity:.55}
.mini-bars .bar.strong{filter:saturate(115%)}

/* Forms */
.cf-label{font-size:13px;color:var(--muted);margin-bottom:4px}
.cf-input,.cf-select{width:100%;padding:10px 12px;border:1px solid #d1d5db;border-radius:6px;background:#fff;color:var(--text)}

/* Tables */
.cf-table-wrap{width:100%;overflow-x:auto}
.cf-table{width:100%;border-collapse:collapse;background:#fff;border:1px solid var(--border)}
.cf-table th,.cf-table td{padding:10px 12px;border-bottom:1px solid var(--border);text-align:left;white-space:nowrap}
.cf-table thead th{font-weight:700;color:var(--gray-700);background:var(--gray-50)}
.cf-table tbody tr:hover{background:var(--gray-100)}

/* Buttons */
.cf-actions{display:flex;gap:8px;flex-wrap:wrap}
.cf-btn{display:inline-flex;align-items:center;gap:8px;padding:10px 14px;border-radius:6px;border:1px solid var(--primary-hover);background:var(--primary);color:#fff;text-decoration:none;cursor:pointer}
.cf-btn:hover{background:var(--primary-hover)}
.cf-btn.accent{border-color:var(--accent-hover);background:var(--accent)}
.cf-btn.accent:hover{background:var(--accent-hover)}
.cf-btn.gray{border-color:#4b5563;background:#6b7280}
.cf-btn.gray:hover{background:#4b5563}

/* Alerts & badges */
.cf-muted{color:var(--muted);font-size:13px}
.cf-alert{padding:10px;border-radius:6px;border:1px solid var(--warn-border);background:var(--warn-bg);color:var(--warn-text);margin-bottom:12px}
.cf-alert.success{border-color:var(--success-border);background:var(--success-bg);color:var(--success-text)}
.cf-badge{display:inline-block;padding:6px 10px;border-radius:9999px;font-weight:700;font-size:13px}
.cf-badge.success{background:var(--success-bg);color:var(--success-text)}
.cf-badge.pending{background:var(--warn-bg);color:var(--warn-text)}
.cf-badge.failed{background:var(--danger-bg);color:var(--danger-text)}

/* Cards */
.cf-cards{display:grid;grid-template-columns:repeat(1,1fr);gap:12px}
@media(min-width:768px){.cf-cards{grid-template-columns:repeat(3,1fr)}}
.cf-card{border:1px solid var(--border);border-radius:10px;padding:12px;display:flex;flex-direction:column;gap:8px;background:#fff}
.cf-card h3{margin:0;font-size:16px;font-weight:700}
.cf-card .muted{color:var(--muted);font-size:13px}
.cf-card .row{display:flex;justify-content:space-between;align-items:center}
.price{font-weight:700}
.stock{font-weight:700}

/* Selectable cards + availability */
.cf-card .meta{color:var(--muted);font-size:13px}
.stock .dot{display:inline-block;width:10px;height:10px;border-radius:50%;margin-right:6px;background:var(--gray-100);border:1px solid var(--border)}
.stock .dot.ok{background:var(--primary);border-color:var(--primary)}
.stock .dot.none{background:#e5e7eb;border-color:#e5e7eb}
.cf-card.selectable{cursor:pointer;transition:box-shadow .15s ease, border-color .15s ease, transform .05s ease}
.cf-card.selectable:active{transform:scale(.995)}
.cf-card.selectable.selected{border-color:var(--primary);box-shadow:0 0 0 3px rgba(0,123,255,.12), 0 6px 16px rgba(0,0,0,.06)}
.cf-card.selectable.disabled{opacity:.6;filter:saturate(.7);cursor:not-allowed}

/* Misc */
.mono{font-family: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace;}
.right{text-align:right}
.cf-box{background:var(--gray-50);border:1px solid var(--border);border-radius:8px;padding:12px;font-size:14px}
.cf-note{color:var(--muted);font-size:13px;margin-bottom:8px}
.cf-field{margin-bottom:14px}

/* Page spacing */
main{padding-bottom:24px}

/* Footer */
.pf-footer{margin-top:24px;background:#fff;border-top:1px solid var(--border)}
.pf-footer .inner{max-width:1120px;margin:0 auto;padding:16px;display:grid;gap:16px}
@media(min-width:768px){.pf-footer .inner{grid-template-columns:2fr 1fr 1fr 2fr}}
.pf-footer .col .title{font-weight:800;color:var(--text);margin-bottom:8px}
.pf-footer .brand .muted{color:var(--muted)}
.pf-footer .links a{display:block;color:var(--text);text-decoration:none;padding:6px 0}
.pf-footer .links a:hover{color:var(--primary)}
.pf-footer .socials{display:flex;gap:10px;margin-top:10px}
.pf-footer .socials a{width:34px;height:34px;border:1px solid var(--border);border-radius:999px;display:inline-flex;align-items:center;justify-content:center;color:var(--text)}
.pf-footer .socials a:hover{background:var(--gray-100)}
.pf-footer .nl-form{display:flex;gap:8px;flex-wrap:wrap}
.pf-footer .nl-form input{flex:1 1 180px;padding:10px 12px;border:1px solid var(--border);border-radius:8px}
.pf-footer .bottom{border-top:1px solid var(--border);background:var(--gray-50);margin-top:8px}
.pf-footer .bottom{display:flex;align-items:center;justify-content:space-between;gap:12px;max-width:1120px;margin:0 auto;padding:10px 16px;color:var(--muted);font-size:13px}
.pf-footer .bottom a{color:inherit;text-decoration:none;margin-left:10px}
.pf-footer .bottom a:hover{color:var(--text)}
.pf-logo{width:28px;height:28px;border-radius:6px;border:1px solid var(--border);background:#fff;box-shadow:0 1px 2px rgba(0,0,0,.04)}
@media(min-width:768px){.pf-logo{width:32px;height:32px}}
