/* === DAKAR LAVE PRESSE — DESIGN SYSTEM === */
:root{
  --navy: #1E4B8C;
  --navy-700: #163a6e;
  --navy-50: #eaf0f9;
  --sky: #5BB8D6;
  --sky-50: #e6f4f9;
  --green: #6FBA3F;
  --green-700: #57932f;
  --green-50: #eef7e6;
  --yellow: #F5C518;
  --red: #E03A3A;
  --ink: #0F1B2E;
  --ink-2: #3a4658;
  --ink-3: #6b7689;
  --line: #e3e8ef;
  --line-2: #eef1f6;
  --bg: #f6f8fb;
  --paper: #ffffff;
  --shadow-sm: 0 1px 2px rgba(15,27,46,.06);
  --shadow: 0 6px 20px -8px rgba(15,27,46,.18), 0 2px 6px rgba(15,27,46,.05);
  --shadow-lg: 0 24px 60px -20px rgba(15,27,46,.25);
  --r-sm: 8px;
  --r: 12px;
  --r-lg: 18px;
  --r-xl: 24px;
}

*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{
  font-family: 'Inter', system-ui, sans-serif;
  color: var(--ink);
  background: var(--bg);
  font-size: 15px;
  line-height: 1.55;
  -webkit-font-smoothing: antialiased;
}
h1,h2,h3,h4{font-family:'Poppins',sans-serif; margin:0; color:var(--ink); letter-spacing:-0.01em}
h1{font-weight:800; font-size:56px; line-height:1.05; letter-spacing:-0.025em}
h2{font-weight:700; font-size:34px; line-height:1.15; letter-spacing:-0.02em}
h3{font-weight:600; font-size:20px}
p{margin:0}
a{color:inherit; text-decoration:none}
button{font-family:inherit; cursor:pointer; border:0; background:none; color:inherit}
input, select, textarea{font-family:inherit; font-size:15px; color:inherit}
img{max-width:100%; display:block}

.container{max-width:1240px; margin:0 auto; padding: 0 24px}

/* === HEADER === */
.header{
  position:sticky; top:0; z-index:50;
  background: rgba(255,255,255,0.92);
  backdrop-filter: blur(12px);
  border-bottom: 1px solid var(--line);
}
.header-inner{
  display:flex; align-items:center; justify-content:space-between;
  height: 76px;
}
.brand{display:flex; align-items:center; gap:12px}
.brand-logo{
  width:48px; height:48px; border-radius:50%;
  background:#fff; padding:2px;
  border:1px solid var(--line);
  overflow:hidden; flex:none;
}
.brand-logo img{width:100%; height:100%; object-fit:cover; border-radius:50%}
.brand-name{
  font-family:'Poppins'; font-weight:700; font-size:17px;
  letter-spacing:-0.01em; line-height:1.05;
}
.brand-name .a{color:var(--navy)}
.brand-name .b{color:var(--green)}
.brand-tag{font-size:11px; color:var(--ink-3); font-weight:500; letter-spacing:0.04em; text-transform:uppercase}
.nav{display:flex; gap:6px; align-items:center}
.nav-link{
  padding: 9px 14px; border-radius: 999px;
  font-size:14px; font-weight:500; color: var(--ink-2);
  transition:.15s; cursor:pointer;
}
.nav-link:hover{background: var(--line-2); color:var(--ink)}
.nav-link.active{background: var(--navy-50); color: var(--navy); font-weight:600}
.header-cta{display:flex; gap:10px; align-items:center}

/* === BUTTONS === */
.btn{
  display:inline-flex; align-items:center; gap:8px;
  padding:12px 20px; border-radius:999px;
  font-weight:600; font-size:14px;
  transition: .18s ease;
  white-space:nowrap;
}
.btn-primary{
  background: var(--navy); color:#fff;
}
.btn-primary:hover{background:var(--navy-700); transform:translateY(-1px); box-shadow: 0 8px 20px -6px rgba(30,75,140,.5)}
.btn-green{
  background: var(--green); color:#fff;
}
.btn-green:hover{background:var(--green-700); transform:translateY(-1px); box-shadow: 0 8px 20px -6px rgba(111,186,63,.5)}
.btn-ghost{
  background: transparent; color:var(--ink); border:1px solid var(--line);
}
.btn-ghost:hover{background:var(--paper); border-color:var(--ink-3)}
.btn-sm{padding:8px 14px; font-size:13px}
.btn-lg{padding:15px 26px; font-size:15px}
.btn-block{width:100%; justify-content:center}

/* === HERO === */
.hero{
  position:relative;
  background: linear-gradient(135deg, #f7faff 0%, #eaf3f8 100%);
  padding: 70px 0 90px;
  overflow:hidden;
}
.hero::before{
  content:""; position:absolute; right:-200px; top:-100px;
  width:600px; height:600px; border-radius:50%;
  background: radial-gradient(circle, rgba(91,184,214,.18), transparent 70%);
  pointer-events:none;
}
.hero::after{
  content:""; position:absolute; left:-150px; bottom:-200px;
  width:500px; height:500px; border-radius:50%;
  background: radial-gradient(circle, rgba(111,186,63,.12), transparent 70%);
  pointer-events:none;
}
.hero-grid{
  display:grid; grid-template-columns: 1.1fr 1fr; gap:60px;
  align-items:center; position:relative; z-index:1;
}
.hero-eyebrow{
  display:inline-flex; align-items:center; gap:8px;
  padding: 7px 14px; border-radius:999px;
  background: var(--paper); border:1px solid var(--line);
  font-size:13px; font-weight:600; color:var(--navy);
  box-shadow: var(--shadow-sm);
  margin-bottom: 24px;
}
.hero-eyebrow .dot{width:8px; height:8px; border-radius:50%; background:var(--green); animation: pulse 1.8s infinite}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.4}}
.hero h1 .accent{color: var(--navy)}
.hero h1 .accent-2{color: var(--green)}
.hero-sub{font-size:18px; color:var(--ink-2); margin-top:22px; max-width:520px}
.hero-actions{display:flex; gap:14px; margin-top:34px; flex-wrap:wrap}
.hero-trust{
  display:flex; gap:28px; margin-top:42px; padding-top:28px;
  border-top:1px solid rgba(15,27,46,.08);
}
.trust-item{display:flex; flex-direction:column; gap:2px}
.trust-num{font-family:'Poppins'; font-weight:700; font-size:24px; color:var(--navy)}
.trust-label{font-size:13px; color:var(--ink-3)}

/* HERO VISUAL — order card mockup */
.hero-visual{position:relative; min-height:480px}
.order-card{
  background: var(--paper);
  border-radius: var(--r-xl);
  padding: 24px;
  box-shadow: var(--shadow-lg);
  position:relative; z-index:2;
  border: 1px solid var(--line);
  transform: rotate(-1.5deg);
}
.oc-head{
  display:flex; justify-content:space-between; align-items:flex-start;
  padding-bottom:18px; border-bottom:1px solid var(--line-2);
}
.oc-id{font-size:12px; color:var(--ink-3); letter-spacing:0.05em; text-transform:uppercase; font-weight:500}
.oc-name{font-family:'Poppins'; font-weight:600; font-size:18px; margin-top:2px}
.oc-status{
  padding:6px 12px; border-radius:999px; font-size:12px; font-weight:600;
  background: var(--green-50); color:var(--green-700);
  display:inline-flex; align-items:center; gap:6px;
}
.oc-status .dot{width:6px;height:6px;border-radius:50%; background:var(--green); animation:pulse 1.8s infinite}
.oc-timeline{padding:18px 0; display:flex; flex-direction:column; gap:14px}
.oc-step{display:flex; gap:12px; align-items:center}
.oc-step .ico{
  width:36px; height:36px; border-radius:50%;
  display:flex; align-items:center; justify-content:center;
  background: var(--line-2); color: var(--ink-3);
  flex:none; font-size:16px;
}
.oc-step.done .ico{background:var(--green); color:#fff}
.oc-step.active .ico{background:var(--navy); color:#fff; box-shadow: 0 0 0 4px rgba(30,75,140,.15)}
.oc-step .label{font-weight:500; font-size:14px}
.oc-step .time{font-size:12px; color:var(--ink-3)}
.oc-step.done .label, .oc-step.active .label{color:var(--ink)}
.oc-step:not(.done):not(.active) .label{color:var(--ink-3)}
.oc-foot{
  padding-top:18px; border-top:1px solid var(--line-2);
  display:flex; justify-content:space-between; align-items:center;
}
.oc-total{font-family:'Poppins'; font-weight:700; font-size:18px; color:var(--navy)}
.oc-pay{font-size:12px; color:var(--ink-3)}

.float-card{
  position:absolute; background:var(--paper); border-radius: var(--r-lg);
  padding:14px 16px; box-shadow: var(--shadow-lg); border:1px solid var(--line);
  display:flex; gap:12px; align-items:center;
}
.float-card .ic{
  width:40px; height:40px; border-radius:12px;
  display:flex; align-items:center; justify-content:center;
  font-size:20px; flex:none;
}
.float-card .t{font-size:13px; font-weight:600; line-height:1.2}
.float-card .s{font-size:11px; color:var(--ink-3); margin-top:2px}

.float-1{top:20px; left:-30px; transform:rotate(-3deg); animation: float1 4s ease-in-out infinite}
.float-1 .ic{background: var(--sky-50); color: var(--sky)}
.float-2{bottom:30px; right:-30px; transform:rotate(2deg); animation: float2 5s ease-in-out infinite}
.float-2 .ic{background: var(--green-50); color: var(--green)}
@keyframes float1{0%,100%{transform:translateY(0) rotate(-3deg)}50%{transform:translateY(-10px) rotate(-3deg)}}
@keyframes float2{0%,100%{transform:translateY(0) rotate(2deg)}50%{transform:translateY(-12px) rotate(2deg)}}

/* === SECTIONS === */
.section{padding: 80px 0}
.section-tight{padding:60px 0}
.section-head{text-align:center; max-width:680px; margin:0 auto 50px}
.section-eyebrow{
  display:inline-block; font-size:12px; font-weight:700; letter-spacing:0.12em;
  text-transform:uppercase; color: var(--green); margin-bottom:14px;
}
.section-head p{color:var(--ink-2); font-size:17px; margin-top:14px}

/* === SERVICES === */
.services-grid{
  display:grid; grid-template-columns: repeat(3, 1fr); gap:20px;
}
.service-card{
  background: var(--paper); border-radius: var(--r-lg);
  padding: 28px; border:1px solid var(--line);
  transition: .2s; position:relative; overflow:hidden;
}
.service-card:hover{
  transform: translateY(-4px);
  box-shadow: var(--shadow);
  border-color: var(--sky);
}
.service-card::before{
  content:""; position:absolute; top:0; left:0; right:0; height:3px;
  background: linear-gradient(90deg, var(--navy), var(--sky), var(--green));
  transform: scaleX(0); transform-origin:left; transition:.3s;
}
.service-card:hover::before{transform:scaleX(1)}
.service-icon{
  width:54px; height:54px; border-radius:14px;
  background: var(--navy-50); color: var(--navy);
  display:flex; align-items:center; justify-content:center;
  font-size:26px; margin-bottom:18px;
}
.service-card:nth-child(3n+2) .service-icon{background:var(--sky-50); color:var(--sky)}
.service-card:nth-child(3n) .service-icon{background:var(--green-50); color:var(--green)}
.service-card h3{font-size:18px; margin-bottom:8px}
.service-desc{font-size:14px; color:var(--ink-2); margin-bottom:18px; min-height:40px}
.service-price{
  font-family:'Poppins'; font-weight:700; font-size:22px;
  color: var(--navy);
}
.service-price .from{font-family:'Inter'; font-weight:500; font-size:12px; color:var(--ink-3); margin-right:6px}
.service-price .unit{font-family:'Inter'; font-size:13px; font-weight:500; color:var(--ink-3); margin-left:2px}

/* === HOW IT WORKS === */
.how-bg{background: linear-gradient(180deg, #fff 0%, var(--bg) 100%)}
.steps{
  display:grid; grid-template-columns: repeat(4, 1fr); gap:0;
  position:relative;
}
.steps::before{
  content:""; position:absolute; top:30px; left:12.5%; right:12.5%;
  height:2px; background: repeating-linear-gradient(90deg, var(--sky) 0 8px, transparent 8px 16px);
  z-index:0;
}
.step{
  text-align:center; padding:0 16px; position:relative; z-index:1;
}
.step-num{
  width:60px; height:60px; border-radius:50%;
  background: var(--paper); border:2px solid var(--navy);
  color:var(--navy); font-family:'Poppins'; font-weight:700; font-size:22px;
  display:flex; align-items:center; justify-content:center;
  margin:0 auto 18px;
  box-shadow: 0 0 0 6px rgba(255,255,255,1), var(--shadow-sm);
}
.step:nth-child(2) .step-num{border-color:var(--sky); color:var(--sky)}
.step:nth-child(3) .step-num{border-color:var(--green); color:var(--green)}
.step:nth-child(4) .step-num{background:var(--green); color:#fff; border-color:var(--green)}
.step h3{font-size:17px; margin-bottom:6px}
.step p{font-size:14px; color:var(--ink-2)}

/* === ZONE / DOMICILE === */
.domicile{
  background: linear-gradient(135deg, var(--navy) 0%, var(--navy-700) 100%);
  color:#fff; border-radius: var(--r-xl);
  padding: 50px 60px;
  display:grid; grid-template-columns: 1fr 1fr; gap:50px; align-items:center;
  position:relative; overflow:hidden;
}
.domicile::after{
  content:""; position:absolute; right:-100px; top:-100px;
  width:400px; height:400px; border-radius:50%;
  background: radial-gradient(circle, rgba(91,184,214,.3), transparent 70%);
}
.domicile-content{position:relative; z-index:1}
.domicile h2{color:#fff}
.domicile p{margin-top:14px; font-size:16px; color:rgba(255,255,255,.85)}
.domicile-features{
  display:flex; flex-direction:column; gap:14px; margin-top:30px;
}
.dom-feat{display:flex; gap:14px; align-items:flex-start}
.dom-feat .dot{
  width:24px; height:24px; border-radius:50%;
  background: var(--green); color:#fff; flex:none;
  display:flex; align-items:center; justify-content:center;
  font-size:13px; margin-top:2px;
}
.dom-feat .t{font-weight:600}
.dom-feat .s{font-size:14px; color:rgba(255,255,255,.7)}
.domicile-card{
  background: rgba(255,255,255,.08); border:1px solid rgba(255,255,255,.18);
  border-radius: var(--r-lg); padding: 28px; backdrop-filter: blur(8px);
  position:relative; z-index:1;
}
.domicile-card h3{color:#fff; font-size:18px; margin-bottom:18px; display:flex; align-items:center; gap:10px}
.zone-list{display:grid; grid-template-columns:1fr 1fr; gap:10px 20px; font-size:14px}
.zone-item{display:flex; align-items:center; gap:8px; color:rgba(255,255,255,.9)}
.zone-item::before{content:"•"; color:var(--sky); font-size:18px; line-height:1}

/* === FORMS (collecte etc) === */
.page{padding: 60px 0 100px}
.page-head{margin-bottom:40px; max-width:720px}
.page-head h1{font-size:42px}
.page-head p{color:var(--ink-2); font-size:17px; margin-top:12px}
.crumbs{display:flex; gap:8px; align-items:center; font-size:13px; color:var(--ink-3); margin-bottom:18px}
.crumbs .here{color:var(--navy); font-weight:600}

.form-card{
  background: var(--paper); border-radius: var(--r-xl);
  padding: 36px; border:1px solid var(--line);
  box-shadow: var(--shadow-sm);
}
.form-grid{display:grid; grid-template-columns: 1fr 1fr; gap:18px}
.field{display:flex; flex-direction:column; gap:6px}
.field-full{grid-column: span 2}
.label{font-size:13px; font-weight:600; color:var(--ink-2)}
.label .req{color:var(--red); margin-left:2px}
.input, .select, .textarea{
  background: var(--bg); border:1px solid var(--line);
  border-radius: var(--r); padding: 12px 14px;
  font-size:15px; transition:.15s;
  width:100%;
}
.input:focus, .select:focus, .textarea:focus{
  outline:none; border-color: var(--navy);
  background:#fff; box-shadow: 0 0 0 4px rgba(30,75,140,.1);
}
.textarea{min-height:90px; resize:vertical; font-family:inherit}
.hint{font-size:12px; color:var(--ink-3)}

.choice-grid{
  display:grid; grid-template-columns: repeat(3, 1fr); gap:10px;
}
.choice{
  border:1.5px solid var(--line); border-radius: var(--r);
  padding: 14px; cursor:pointer; transition:.15s;
  background: var(--paper); display:flex; gap:10px; align-items:center;
}
.choice:hover{border-color:var(--sky)}
.choice.selected{border-color: var(--navy); background: var(--navy-50)}
.choice-ic{
  width:34px; height:34px; border-radius:8px;
  background: var(--line-2); color:var(--ink-2);
  display:flex; align-items:center; justify-content:center; flex:none;
}
.choice.selected .choice-ic{background:var(--navy); color:#fff}
.choice .t{font-weight:600; font-size:14px}
.choice .s{font-size:11px; color:var(--ink-3); margin-top:2px}

.summary-card{
  background: var(--navy-50); border-radius: var(--r-lg);
  padding: 22px; border:1px solid rgba(30,75,140,.15);
  position:sticky; top:100px;
}
.summary-card h3{font-size:16px; margin-bottom:14px; color:var(--navy)}
.summary-row{display:flex; justify-content:space-between; padding:8px 0; font-size:14px}
.summary-row .lbl{color:var(--ink-2)}
.summary-row .val{font-weight:600}
.summary-total{
  border-top:1.5px dashed rgba(30,75,140,.2); margin-top:8px; padding-top:14px;
  display:flex; justify-content:space-between; align-items:baseline;
}
.summary-total .lbl{font-size:14px; font-weight:600}
.summary-total .val{font-family:'Poppins'; font-weight:700; font-size:24px; color:var(--navy)}
.summary-note{
  margin-top:16px; padding: 12px; border-radius:10px;
  background: rgba(255,255,255,.7); font-size:12px; color:var(--ink-2);
  display:flex; gap:10px; align-items:flex-start;
}

/* === SUIVI === */
.tracker-search{
  display:flex; gap:10px; max-width:520px; margin-bottom: 30px;
}
.tracker-search .input{flex:1}

.tracker-card{
  background: var(--paper); border-radius: var(--r-xl);
  padding: 36px; border:1px solid var(--line);
}
.tracker-head{
  display:flex; justify-content:space-between; align-items:flex-start;
  padding-bottom:24px; border-bottom:1px solid var(--line-2); flex-wrap:wrap; gap:16px;
}
.tracker-head .id{font-size:13px; color:var(--ink-3); letter-spacing:0.05em; text-transform:uppercase}
.tracker-head h2{font-size:26px; margin-top:4px}
.tracker-status{
  padding:8px 16px; border-radius:999px; font-weight:600; font-size:13px;
  background: var(--sky-50); color: var(--navy);
  display:inline-flex; gap:8px; align-items:center;
}
.tracker-status .dot{width:8px;height:8px;border-radius:50%; background:var(--sky); animation:pulse 1.8s infinite}

.timeline{padding: 30px 0; position:relative}
.timeline::before{
  content:""; position:absolute; left:23px; top:50px; bottom:50px;
  width:2px; background: var(--line);
}
.tl-item{display:flex; gap:18px; padding: 18px 0; position:relative; z-index:1}
.tl-dot{
  width:48px; height:48px; border-radius:50%;
  background: var(--paper); border:2px solid var(--line);
  display:flex; align-items:center; justify-content:center;
  flex:none; color:var(--ink-3); font-size:20px;
}
.tl-item.done .tl-dot{background: var(--green); color:#fff; border-color:var(--green)}
.tl-item.active .tl-dot{
  background: var(--navy); color:#fff; border-color:var(--navy);
  box-shadow: 0 0 0 6px rgba(30,75,140,.12);
  animation: pulseRing 2s infinite;
}
@keyframes pulseRing{0%,100%{box-shadow: 0 0 0 4px rgba(30,75,140,.12)}50%{box-shadow: 0 0 0 10px rgba(30,75,140,.05)}}
.tl-content{flex:1; padding-top:6px}
.tl-content h3{font-size:16px}
.tl-content .desc{font-size:14px; color:var(--ink-2); margin-top:4px}
.tl-content .time{font-size:13px; color:var(--ink-3); margin-top:6px; font-weight:500}
.tl-item:not(.done):not(.active) .tl-content h3{color:var(--ink-3); font-weight:500}

.tracker-detail{
  display:grid; grid-template-columns: 1fr 1fr; gap: 0;
  padding-top:20px; border-top:1px solid var(--line-2);
}
.detail-block{padding: 18px 24px}
.detail-block + .detail-block{border-left:1px solid var(--line-2)}
.detail-block .lbl{font-size:12px; text-transform:uppercase; letter-spacing:0.05em; color:var(--ink-3); font-weight:600}
.detail-block .val{font-weight:600; margin-top:4px}
.detail-block .sub{font-size:13px; color:var(--ink-2); margin-top:2px}

/* === CLIENT DASHBOARD === */
.dash-grid{
  display:grid; grid-template-columns: 280px 1fr; gap:30px;
}
.side-card{
  background: var(--paper); border-radius: var(--r-lg);
  padding: 24px; border:1px solid var(--line);
}
.profile{display:flex; flex-direction:column; align-items:center; text-align:center}
.profile .avatar{
  width:72px; height:72px; border-radius:50%;
  background: linear-gradient(135deg, var(--navy), var(--sky));
  color:#fff; font-family:'Poppins'; font-weight:700; font-size:26px;
  display:flex; align-items:center; justify-content:center;
  margin-bottom:14px;
}
.profile .name{font-family:'Poppins'; font-weight:600; font-size:17px}
.profile .phone{font-size:13px; color:var(--ink-3); margin-top:2px}
.profile .pts{
  margin-top:14px; padding:10px 14px; border-radius:10px;
  background: var(--green-50); font-size:12px; color:var(--green-700); font-weight:600;
  display:flex; gap:6px; align-items:center;
}
.side-menu{margin-top:24px; display:flex; flex-direction:column; gap:2px}
.side-menu .mi{
  display:flex; align-items:center; gap:12px; padding:11px 14px;
  border-radius:10px; font-size:14px; color:var(--ink-2); cursor:pointer; font-weight:500;
}
.side-menu .mi:hover{background: var(--bg)}
.side-menu .mi.active{background: var(--navy-50); color:var(--navy); font-weight:600}
.side-menu .mi .ic{width:18px; opacity:.7}
.side-menu .mi.active .ic{opacity:1}

.kpi-row{display:grid; grid-template-columns: repeat(3,1fr); gap:14px; margin-bottom: 24px}
.kpi{
  background:var(--paper); border-radius: var(--r);
  padding:18px 20px; border:1px solid var(--line);
}
.kpi .lbl{font-size:12px; color:var(--ink-3); text-transform:uppercase; letter-spacing:0.05em; font-weight:600}
.kpi .val{font-family:'Poppins'; font-weight:700; font-size:28px; color:var(--ink); margin-top:6px}
.kpi .delta{font-size:12px; color:var(--green); margin-top:2px; font-weight:600}

.orders-list{
  background: var(--paper); border-radius: var(--r-lg);
  border:1px solid var(--line); overflow:hidden;
}
.orders-head{
  padding:18px 24px; border-bottom:1px solid var(--line-2);
  display:flex; justify-content:space-between; align-items:center;
}
.orders-head h3{font-size:17px}
.tabs{display:flex; gap:4px; background:var(--bg); padding:4px; border-radius:10px}
.tab{padding:7px 14px; border-radius:7px; font-size:13px; font-weight:500; color:var(--ink-2); cursor:pointer}
.tab.active{background:#fff; color:var(--ink); box-shadow: var(--shadow-sm)}

.order-row{
  display:grid; grid-template-columns: 1.4fr 1.4fr 1fr 1fr 0.8fr;
  gap:18px; padding: 18px 24px; align-items:center;
  border-bottom: 1px solid var(--line-2);
  transition:.15s;
}
.order-row:hover{background: var(--bg)}
.order-row:last-child{border-bottom:0}
.order-row .id{font-family:'Poppins'; font-weight:600; font-size:14px; color:var(--navy)}
.order-row .id .sub{display:block; font-family:'Inter'; font-weight:400; font-size:12px; color:var(--ink-3); margin-top:2px}
.order-row .info{font-size:13px}
.order-row .info .main{font-weight:500}
.order-row .info .sub{color:var(--ink-3); margin-top:2px; font-size:12px}
.order-row .price{font-family:'Poppins'; font-weight:600; color:var(--navy)}

.badge{
  display:inline-flex; align-items:center; gap:6px;
  padding:5px 10px; border-radius:999px;
  font-size:11px; font-weight:600; letter-spacing:0.02em;
}
.badge .b-dot{width:6px;height:6px;border-radius:50%}
.b-collected{background: var(--sky-50); color: var(--navy)} .b-collected .b-dot{background:var(--sky)}
.b-washing{background: #FFF4D6; color: #9C7400} .b-washing .b-dot{background: var(--yellow)}
.b-ready{background: var(--green-50); color: var(--green-700)} .b-ready .b-dot{background:var(--green)}
.b-delivered{background: var(--line-2); color:var(--ink-2)} .b-delivered .b-dot{background:var(--ink-3)}
.b-pending{background: #FCE8E8; color: var(--red)} .b-pending .b-dot{background:var(--red)}

/* === ADMIN === */
.admin-shell{
  display:grid; grid-template-columns: 240px 1fr;
  min-height: 700px;
  background: var(--paper); border-radius: var(--r-xl);
  border:1px solid var(--line); overflow:hidden;
  box-shadow: var(--shadow-sm);
}
.admin-side{
  background: var(--ink); color:#fff;
  padding: 22px;
  display:flex; flex-direction:column;
}
.admin-brand{
  display:flex; gap:10px; align-items:center; padding-bottom:22px;
  border-bottom:1px solid rgba(255,255,255,.1);
}
.admin-brand .lg{
  width:36px; height:36px; border-radius:50%;
  background:#fff; padding:1px; overflow:hidden; flex:none;
}
.admin-brand .lg img{width:100%;height:100%;object-fit:cover; border-radius:50%}
.admin-brand .name{font-family:'Poppins'; font-weight:600; font-size:14px; line-height:1.1}
.admin-brand .name span{display:block; color: rgba(255,255,255,.5); font-weight:400; font-size:11px; margin-top:2px}
.admin-menu{display:flex; flex-direction:column; gap:2px; margin-top:18px; flex:1}
.admin-mi{
  display:flex; align-items:center; gap:12px; padding:11px 12px;
  border-radius:8px; font-size:14px; color:rgba(255,255,255,.65); cursor:pointer; font-weight:500;
  transition:.15s;
}
.admin-mi:hover{color:#fff; background: rgba(255,255,255,.06)}
.admin-mi.active{background: var(--navy); color:#fff}
.admin-mi .badge-n{
  margin-left:auto; background: var(--green); color:#fff;
  font-size:10px; font-weight:700; padding:2px 7px; border-radius:999px;
}
.admin-bottom{
  margin-top:auto; padding-top:18px; border-top:1px solid rgba(255,255,255,.1);
  font-size:12px; color: rgba(255,255,255,.45);
}

.admin-main{padding: 28px 32px; background: var(--bg); overflow:auto}
.admin-top{
  display:flex; justify-content:space-between; align-items:center;
  margin-bottom: 26px;
}
.admin-top h2{font-size:22px}
.admin-top .sub{font-size:13px; color:var(--ink-3); margin-top:2px}
.admin-actions{display:flex; gap:10px}
.admin-search{
  width:280px; position:relative;
}
.admin-search .input{padding-left:38px; background:#fff}
.admin-search .ic{
  position:absolute; left:12px; top:50%; transform:translateY(-50%);
  color:var(--ink-3);
}

.admin-kpis{display:grid; grid-template-columns: repeat(4,1fr); gap:14px; margin-bottom:24px}
.admin-kpi{
  background:#fff; border-radius:var(--r); padding:18px 20px;
  border:1px solid var(--line); position:relative; overflow:hidden;
}
.admin-kpi .lbl{font-size:12px; color:var(--ink-3); text-transform:uppercase; letter-spacing:0.05em; font-weight:600}
.admin-kpi .val{font-family:'Poppins'; font-weight:700; font-size:28px; color:var(--ink); margin-top:6px}
.admin-kpi .delta{font-size:12px; margin-top:4px; font-weight:600; display:flex; align-items:center; gap:4px}
.admin-kpi .delta.up{color:var(--green-700)}
.admin-kpi .delta.down{color:var(--red)}
.admin-kpi .strip{position:absolute; bottom:0; left:0; right:0; height:3px}
.admin-kpi:nth-child(1) .strip{background: var(--navy)}
.admin-kpi:nth-child(2) .strip{background: var(--sky)}
.admin-kpi:nth-child(3) .strip{background: var(--green)}
.admin-kpi:nth-child(4) .strip{background: var(--yellow)}

.panel{
  background:#fff; border-radius: var(--r-lg);
  border:1px solid var(--line); overflow:hidden; margin-bottom: 18px;
}
.panel-head{
  padding:16px 22px; border-bottom:1px solid var(--line-2);
  display:flex; justify-content:space-between; align-items:center; flex-wrap:wrap; gap:10px;
}
.panel-head h3{font-size:16px}

.table{width:100%; border-collapse:collapse; font-size:13px}
.table th{
  text-align:left; font-weight:600; color:var(--ink-3); font-size:11px;
  letter-spacing:0.06em; text-transform:uppercase;
  padding:12px 22px; background: var(--bg); border-bottom:1px solid var(--line-2);
}
.table td{padding: 14px 22px; border-bottom:1px solid var(--line-2); vertical-align:middle}
.table tr:last-child td{border-bottom:0}
.table tr:hover td{background: var(--bg)}
.table .td-id{font-family:'Poppins'; font-weight:600; color:var(--navy)}
.table .td-customer .n{font-weight:600}
.table .td-customer .p{font-size:12px; color:var(--ink-3); margin-top:2px}
.table .td-actions{text-align:right; white-space:nowrap}
.icbtn{
  width:30px; height:30px; border-radius:7px;
  display:inline-flex; align-items:center; justify-content:center;
  background: var(--line-2); color:var(--ink-2); margin-left:4px; cursor:pointer;
  transition:.15s;
}
.icbtn:hover{background: var(--navy); color:#fff}

.split-2{display:grid; grid-template-columns: 1.4fr 1fr; gap:18px}
.chart-card{background:#fff; border-radius:var(--r-lg); border:1px solid var(--line); padding:22px}
.chart-card h3{font-size:16px; margin-bottom:18px}

.chart{height:200px; display:flex; align-items:flex-end; gap:8px; padding-top:20px}
.bar{
  flex:1; background: linear-gradient(180deg, var(--sky) 0%, var(--navy) 100%);
  border-radius: 6px 6px 0 0; min-height:8px; position:relative; transition:.2s;
  cursor:pointer;
}
.bar:hover{opacity:.85}
.bar.hl{background: linear-gradient(180deg, #93d3a8 0%, var(--green) 100%)}
.chart-x{display:flex; gap:8px; margin-top:8px}
.chart-x span{flex:1; text-align:center; font-size:11px; color:var(--ink-3)}

.donut-wrap{display:flex; gap:20px; align-items:center}
.donut{
  width:140px; height:140px; border-radius:50%; flex:none;
  background:
    conic-gradient(
      var(--navy) 0% 38%,
      var(--sky) 38% 62%,
      var(--green) 62% 84%,
      var(--yellow) 84% 100%
    );
  display:flex; align-items:center; justify-content:center;
  position:relative;
}
.donut::after{
  content:""; position:absolute; inset:18px;
  background:#fff; border-radius:50%;
}
.donut .donut-c{position:relative; z-index:1; text-align:center}
.donut .donut-c .n{font-family:'Poppins'; font-weight:700; font-size:22px}
.donut .donut-c .l{font-size:10px; color:var(--ink-3); text-transform:uppercase; letter-spacing:0.05em}
.legend{display:flex; flex-direction:column; gap:10px; flex:1}
.lg-item{display:flex; align-items:center; gap:10px; font-size:13px}
.lg-item .sw{width:10px; height:10px; border-radius:3px}
.lg-item .v{margin-left:auto; font-weight:600}

/* collecte panel small */
.collecte-list{display:flex; flex-direction:column}
.coll-row{
  display:grid; grid-template-columns: auto 1fr auto auto; gap:14px;
  align-items:center; padding: 14px 22px; border-bottom:1px solid var(--line-2);
}
.coll-row:last-child{border-bottom:0}
.coll-time{
  background: var(--navy-50); color:var(--navy); border-radius:8px;
  width:54px; height:54px; display:flex; flex-direction:column;
  align-items:center; justify-content:center; flex:none;
  font-family:'Poppins';
}
.coll-time .h{font-weight:700; font-size:16px; line-height:1}
.coll-time .m{font-size:11px; margin-top:2px}
.coll-info .n{font-weight:600; font-size:14px}
.coll-info .a{font-size:12px; color:var(--ink-3); margin-top:2px}
.coll-driver{font-size:12px; color:var(--ink-2); display:flex; gap:6px; align-items:center}
.coll-driver .d-av{
  width:24px; height:24px; border-radius:50%; background:var(--green);
  color:#fff; font-size:10px; font-weight:700;
  display:flex; align-items:center; justify-content:center;
}

/* === FOOTER === */
.footer{
  background: var(--ink); color: rgba(255,255,255,.7);
  padding: 60px 0 30px; margin-top: 60px;
}
.footer-grid{
  display:grid; grid-template-columns: 1.4fr 1fr 1fr 1fr; gap:40px;
}
.footer h4{color:#fff; font-size:14px; font-family:'Poppins'; margin-bottom:16px}
.footer .brand-name{color:#fff}
.footer .brand-name .b{color:var(--green)}
.footer-sub{font-size:14px; line-height:1.6; margin-top:14px; max-width:300px}
.footer-list{display:flex; flex-direction:column; gap:8px; font-size:14px}
.footer-list a:hover{color:#fff}
.footer-contact{display:flex; flex-direction:column; gap:10px; font-size:14px}
.footer-contact div{display:flex; gap:10px; align-items:flex-start}
.footer-bottom{
  margin-top:50px; padding-top:24px; border-top:1px solid rgba(255,255,255,.08);
  display:flex; justify-content:space-between; align-items:center;
  font-size:12px; color: rgba(255,255,255,.4);
}

/* === UTILS / ANIM === */
.fadein{animation: fadein .4s ease}
@keyframes fadein{from{opacity:0; transform:translateY(8px)}to{opacity:1; transform:translateY(0)}}

/* Scroll reveal */
.reveal{
  opacity:0; transform: translateY(28px);
  transition: opacity .7s cubic-bezier(.2,.7,.2,1), transform .7s cubic-bezier(.2,.7,.2,1);
  will-change: opacity, transform;
}
.reveal.in{opacity:1; transform: translateY(0)}
.reveal.delay-1{transition-delay:.08s}
.reveal.delay-2{transition-delay:.16s}
.reveal.delay-3{transition-delay:.24s}
.reveal.delay-4{transition-delay:.32s}
.reveal.delay-5{transition-delay:.40s}
.reveal.delay-6{transition-delay:.48s}
.reveal-left{opacity:0; transform: translateX(-30px); transition: opacity .7s cubic-bezier(.2,.7,.2,1), transform .7s cubic-bezier(.2,.7,.2,1)}
.reveal-left.in{opacity:1; transform: translateX(0)}
.reveal-right{opacity:0; transform: translateX(30px); transition: opacity .7s cubic-bezier(.2,.7,.2,1), transform .7s cubic-bezier(.2,.7,.2,1)}
.reveal-right.in{opacity:1; transform: translateX(0)}
.reveal-scale{opacity:0; transform: scale(.92); transition: opacity .6s ease, transform .6s cubic-bezier(.2,.8,.2,1.2)}
.reveal-scale.in{opacity:1; transform: scale(1)}

/* Hero entrance */
.hero h1 .accent, .hero h1 .accent-2{
  display:inline-block;
  animation: slideUp .8s cubic-bezier(.2,.7,.2,1) both;
}
.hero h1 .accent{animation-delay:.1s}
.hero h1 .accent-2{animation-delay:.25s}
@keyframes slideUp{from{opacity:0; transform:translateY(40px)}to{opacity:1; transform:translateY(0)}}

.hero-eyebrow{animation: fadeDown .6s ease both}
.hero-sub{animation: fadeUp .7s ease .35s both}
.hero-actions{animation: fadeUp .7s ease .5s both}
.hero-trust{animation: fadeUp .7s ease .65s both}
@keyframes fadeDown{from{opacity:0; transform:translateY(-12px)}to{opacity:1; transform:translateY(0)}}
@keyframes fadeUp{from{opacity:0; transform:translateY(20px)}to{opacity:1; transform:translateY(0)}}

.order-card{
  animation: cardIn 1s cubic-bezier(.2,.7,.2,1) .3s both;
}
@keyframes cardIn{from{opacity:0; transform: rotate(-1.5deg) translateY(40px) scale(.92)}to{opacity:1; transform: rotate(-1.5deg) translateY(0) scale(1)}}

/* Washer spin in service icon */
.service-card:hover .service-icon{
  animation: bump .5s cubic-bezier(.2,.8,.2,1.4);
}
@keyframes bump{0%{transform:scale(1)}50%{transform:scale(1.15) rotate(-6deg)}100%{transform:scale(1) rotate(0)}}

/* Step number progressive fill */
.step-num{transition: transform .3s, box-shadow .3s}
.step:hover .step-num{transform: translateY(-4px); box-shadow: 0 0 0 6px #fff, 0 12px 24px -8px rgba(30,75,140,.4)}

/* Order row pop on hover */
.order-row{transition: background .15s, transform .15s}
.order-row:hover{transform: translateX(4px)}

/* KPI counter animation hint */
.kpi, .admin-kpi{transition: transform .25s ease, box-shadow .25s ease}
.kpi:hover, .admin-kpi:hover{transform: translateY(-3px); box-shadow: var(--shadow)}

/* Bar chart grow */
.bar{
  animation: barGrow 1s cubic-bezier(.2,.8,.2,1) both;
  transform-origin: bottom;
}
.bar:nth-child(1){animation-delay:.05s}
.bar:nth-child(2){animation-delay:.12s}
.bar:nth-child(3){animation-delay:.19s}
.bar:nth-child(4){animation-delay:.26s}
.bar:nth-child(5){animation-delay:.33s}
.bar:nth-child(6){animation-delay:.40s}
.bar:nth-child(7){animation-delay:.47s}
@keyframes barGrow{from{transform: scaleY(0)}to{transform: scaleY(1)}}

/* Donut spin in */
.donut{animation: donutIn 1.2s cubic-bezier(.2,.7,.2,1) both}
@keyframes donutIn{from{transform: rotate(-90deg) scale(.7); opacity:0}to{transform: rotate(0) scale(1); opacity:1}}

/* Timeline reveal */
.tl-item{animation: tlIn .6s ease both}
.tl-item:nth-child(1){animation-delay:.05s}
.tl-item:nth-child(2){animation-delay:.18s}
.tl-item:nth-child(3){animation-delay:.31s}
.tl-item:nth-child(4){animation-delay:.44s}
@keyframes tlIn{from{opacity:0; transform: translateX(-20px)}to{opacity:1; transform: translateX(0)}}

/* Choice / button micro-press */
.choice{transition: border-color .15s, background .15s, transform .1s}
.choice:active{transform: scale(.98)}
.btn:active{transform: scale(.97)}

/* Nav link slide indicator */
.nav-link{position:relative; overflow:hidden}
.nav-link::after{
  content:""; position:absolute; bottom:6px; left:50%; transform: translateX(-50%);
  width:0; height:2px; background: var(--navy); transition: width .25s;
  border-radius:2px;
}
.nav-link:hover::after{width: 50%}
.nav-link.active::after{width: 0}

/* Float bubbles in hero */
.hero::before{animation: blob 14s ease-in-out infinite}
.hero::after{animation: blob 18s ease-in-out infinite reverse}
@keyframes blob{
  0%,100%{transform: translate(0,0) scale(1)}
  33%{transform: translate(-30px, 20px) scale(1.1)}
  66%{transform: translate(20px, -20px) scale(.95)}
}

/* Status dot pulse already exists; add washer drum spin */
.oc-step.active .ic{animation: drumSpin 2.5s linear infinite}
@keyframes drumSpin{from{transform: rotate(0)}to{transform: rotate(360deg)}}

/* Page transitions */
.fadein{animation: pageIn .45s cubic-bezier(.2,.7,.2,1)}
@keyframes pageIn{from{opacity:0; transform:translateY(14px)}to{opacity:1; transform:translateY(0)}}

@media (prefers-reduced-motion: reduce){
  *, *::before, *::after{animation: none !important; transition: none !important}
}

@media (max-width: 980px){
  h1{font-size:40px}
  h2{font-size:28px}
  .hero{padding:50px 0}
  .hero-grid{grid-template-columns: 1fr; gap:40px}
  .services-grid{grid-template-columns: 1fr 1fr}
  .steps{grid-template-columns: 1fr 1fr; gap:30px}
  .steps::before{display:none}
  .domicile{grid-template-columns:1fr; padding:36px}
  .form-grid{grid-template-columns:1fr}
  .field-full{grid-column: span 1}
  .dash-grid{grid-template-columns: 1fr}
  .admin-shell{grid-template-columns:1fr}
  .admin-side{display:none}
  .footer-grid{grid-template-columns:1fr 1fr; gap:30px}
  .nav{display:none}
  .order-row{grid-template-columns: 1fr 1fr; gap:8px}
  .tracker-detail{grid-template-columns:1fr}
  .detail-block + .detail-block{border-left:0; border-top:1px solid var(--line-2)}
  .admin-kpis{grid-template-columns:1fr 1fr}
  .split-2{grid-template-columns:1fr}
}
