/* ============================================================
   LEEF Bestelportaal — shiny stylesheet
   Officiële LEEF huisstijl: zwart/espresso + koper-gradient
   Palet: #D9B7A0 (zand) · #B3613B (koper) · #824631 (donkerbruin) · #80462E
   ============================================================ */
:root{
  /* merkkleuren */
  --sand:#D9B7A0;
  --copper:#B3613B;
  --brown:#824631;
  --brown-deep:#80462E;

  /* espresso / zwart-tinten */
  --espresso-900:#160f0a;
  --espresso-800:#1f150d;
  --espresso-700:#2a1b11;
  --ink:#2a1b11;
  --muted:#9c8676;
  --line:rgba(130,70,49,.14);

  /* neutralen */
  --cream:#faf5ee;
  --cream-2:#f3e9dd;
  --white:#ffffff;

  /* aliassen (compat met bestaande class-namen) */
  --green-900:var(--espresso-900);
  --green-800:#3a2417;
  --green-700:var(--brown);
  --green-600:var(--copper);
  --green-500:var(--copper);
  --green-400:var(--sand);
  --gold:var(--copper);
  --gold-dark:var(--brown);

  --shadow-sm:0 2px 10px rgba(70,35,20,.07);
  --shadow:0 14px 44px rgba(70,35,20,.14);
  --shadow-lg:0 30px 70px rgba(40,20,10,.30);
  --radius:20px;
  --radius-sm:14px;

  /* gradients */
  --grad-copper:linear-gradient(120deg,#e7ccb6 0%,#D9B7A0 14%,#B3613B 58%,#824631 100%);
  --grad-copper-strong:linear-gradient(120deg,#D9B7A0 0%,#B3613B 50%,#80462E 100%);
  --grad-espresso:linear-gradient(150deg,#2a1b11 0%,#1c130c 55%,#140d08 100%);
  --grad-portal:linear-gradient(125deg,#2a1b11 0%,#3a2417 40%,#7a3f25 100%);

  /* compat met oude tokens */
  --grad-green:var(--grad-espresso);
  --grad-gold:var(--grad-copper);

  --font:'Poppins','Segoe UI',system-ui,sans-serif;
  --font-display:'Fraunces','Georgia',serif;
}

/* Verfijnde display-koppen */
.auth-hero h1, .portal-hero h1, .page-head h1, .sec-title,
.journey-hello h1, .auth-card h2, .drawer-head h2, .modal-head h2,
.empty-state h3, .stat .v{
  font-family:var(--font-display);
  letter-spacing:-.01em;
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  font-family:var(--font);
  color:var(--ink);
  background:var(--cream);
  -webkit-font-smoothing:antialiased;
  min-height:100vh;
}
[x-cloak]{display:none!important}
a{color:inherit;text-decoration:none}
button{font-family:inherit;cursor:pointer;border:none;background:none}
img{max-width:100%}

/* ---------- Ambient background blobs ---------- */
.bg-fx{position:fixed;inset:0;z-index:-1;overflow:hidden}
.blob{position:absolute;border-radius:50%;filter:blur(80px);opacity:.5}
.blob.b1{width:480px;height:480px;background:radial-gradient(circle,#D9B7A0,transparent 70%);top:-140px;right:-120px;opacity:.55}
.blob.b2{width:520px;height:520px;background:radial-gradient(circle,#B3613B,transparent 70%);bottom:-180px;left:-160px;opacity:.30}
.blob.b3{width:360px;height:360px;background:radial-gradient(circle,#824631,transparent 70%);top:40%;left:55%;opacity:.14}

/* ============================================================
   AUTH SCREEN
   ============================================================ */
.auth-wrap{min-height:100vh;display:grid;grid-template-columns:1.05fr .95fr}
@media(max-width:900px){.auth-wrap{grid-template-columns:1fr}}

.auth-hero{
  position:relative;overflow:hidden;
  background:var(--grad-espresso);
  color:#f3e6da;padding:64px 56px;
  display:flex;flex-direction:column;justify-content:space-between;
}
.auth-hero::after{
  content:"";position:absolute;inset:0;
  background:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='40' height='40'%3E%3Cpath d='M0 39h40M39 0v40' stroke='%23ffffff08' stroke-width='1'/%3E%3C/svg%3E");
  opacity:.6;pointer-events:none;
}
.auth-hero .hero-shine{
  position:absolute;width:620px;height:620px;border-radius:50%;
  background:radial-gradient(circle at 30% 30%,rgba(217,183,160,.28),transparent 62%);
  top:-220px;right:-200px;pointer-events:none;
}
.auth-hero-inner{position:relative;z-index:1}
.auth-hero .logo-mark{filter:drop-shadow(0 10px 28px rgba(0,0,0,.45))}
.hero-eyebrow{letter-spacing:5px;font-size:12px;font-weight:600;color:var(--sand);text-transform:uppercase;margin-top:40px}
.auth-hero h1{font-size:46px;line-height:1.06;font-weight:800;margin:14px 0 18px;max-width:13ch;color:#fbf3ea}
.auth-hero p.lede{font-size:17px;line-height:1.6;color:#cbb4a3;max-width:42ch}
.hero-feats{display:flex;flex-direction:column;gap:16px;margin-top:38px}
.hero-feat{display:flex;align-items:center;gap:14px;font-size:15px;color:#ecdccf}
.hero-feat .ico{width:42px;height:42px;border-radius:12px;display:grid;place-items:center;font-size:20px;
  background:rgba(217,183,160,.12);backdrop-filter:blur(6px);border:1px solid rgba(217,183,160,.22)}
.hero-foot{position:relative;z-index:1;font-size:13px;color:#9c8676;margin-top:40px;letter-spacing:.5px}

.auth-panel{display:flex;align-items:center;justify-content:center;padding:48px 28px;background:var(--cream)}
.auth-card{
  width:100%;max-width:430px;background:var(--white);border-radius:26px;
  padding:44px 40px;box-shadow:var(--shadow-lg);border:1px solid var(--line);
  position:relative;
}
.auth-card h2{font-size:26px;font-weight:800;color:var(--green-800)}
.auth-card .sub{color:var(--muted);margin:8px 0 26px;font-size:14.5px}

.tabs{display:flex;background:var(--cream-2);border-radius:14px;padding:5px;margin-bottom:26px}
.tabs button{flex:1;padding:11px;border-radius:10px;font-weight:600;font-size:14px;color:var(--muted);transition:.25s}
.tabs button.active{background:var(--white);color:var(--brown);box-shadow:var(--shadow-sm)}

.field{margin-bottom:16px}
.field label{display:block;font-size:13px;font-weight:600;color:var(--green-800);margin-bottom:7px}
.field input,.field textarea,.field select{
  width:100%;padding:13px 15px;border:1.6px solid var(--line);border-radius:12px;
  font-size:14.5px;font-family:inherit;color:var(--ink);background:#fdfaf6;transition:.2s;
}
.field input:focus,.field textarea:focus,.field select:focus{
  outline:none;border-color:var(--copper);background:#fff;
  box-shadow:0 0 0 4px rgba(179,97,59,.14);
}
.row2{display:grid;grid-template-columns:1fr 1fr;gap:14px}

/* ---------- Buttons ---------- */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:9px;
  padding:13px 22px;border-radius:13px;font-weight:700;font-size:14.5px;
  transition:transform .18s ease,box-shadow .18s ease,filter .18s ease;
}
.btn:active{transform:translateY(1px) scale(.99)}
.btn-primary{
  color:#2a1b11;background:var(--grad-copper);background-size:140% 140%;
  box-shadow:0 12px 28px rgba(130,70,49,.38);
  position:relative;overflow:hidden;
}
.btn-primary::after{
  content:"";position:absolute;top:0;left:-120%;width:60%;height:100%;
  background:linear-gradient(120deg,transparent,rgba(255,255,255,.55),transparent);
  transform:skewX(-20deg);transition:left .6s;
}
.btn-primary:hover::after{left:130%}
.btn-primary:hover{transform:translateY(-2px);box-shadow:0 18px 36px rgba(130,70,49,.48)}
.btn-green{color:#f5e7da;background:var(--grad-espresso);box-shadow:0 10px 24px rgba(40,20,10,.30)}
.btn-green:hover{transform:translateY(-2px);filter:brightness(1.18)}
.btn-block{width:100%}
.btn-ghost{background:var(--cream-2);color:var(--brown)}
.btn-ghost:hover{background:#ead9c9}
.btn-sm{padding:8px 14px;font-size:13px;border-radius:10px}
.btn[disabled]{opacity:.55;cursor:not-allowed}

.demo-hint{margin-top:22px;padding:14px 16px;background:#faf2e9;border:1px dashed var(--copper);
  border-radius:12px;font-size:12.5px;color:var(--brown);line-height:1.7}
.demo-hint b{color:var(--green-800)}
.auth-note{margin-top:22px;padding-top:18px;border-top:1px solid var(--line);
  font-size:13px;color:var(--muted);line-height:1.6;text-align:center}
.form-error{background:#fdecea;color:#a3261c;padding:11px 14px;border-radius:11px;font-size:13.5px;margin-bottom:16px;border:1px solid #f3c7c1}

/* ============================================================
   APP SHELL
   ============================================================ */
.topbar{
  position:sticky;top:0;z-index:50;background:rgba(250,245,238,.82);
  backdrop-filter:blur(16px);border-bottom:1px solid var(--line);
  display:flex;align-items:center;justify-content:space-between;
  padding:12px 30px;
}
.topbar .brand{display:flex;align-items:center;gap:12px}
.topbar .brand .badge{font-size:11px;font-weight:700;letter-spacing:1.5px;color:var(--brown);
  background:#f0e2d4;padding:4px 10px;border-radius:20px}
.topbar-right{display:flex;align-items:center;gap:18px}
.whoami{text-align:right;line-height:1.25}
.whoami .nm{font-weight:700;font-size:14px;color:var(--green-800)}
.whoami .rl{font-size:12px;color:var(--muted)}
.avatar{width:42px;height:42px;border-radius:50%;display:grid;place-items:center;font-weight:800;color:#fff;
  background:var(--grad-copper-strong);box-shadow:var(--shadow-sm)}
.cart-btn{position:relative;width:46px;height:46px;border-radius:14px;background:var(--espresso-800);color:#f5e7da;
  display:grid;place-items:center;font-size:20px;transition:.2s;box-shadow:var(--shadow-sm)}
.cart-btn:hover{transform:translateY(-2px);filter:brightness(1.2)}
.cart-count{position:absolute;top:-6px;right:-6px;min-width:22px;height:22px;padding:0 6px;border-radius:11px;
  background:var(--copper);color:#fff;font-size:12px;font-weight:800;display:grid;place-items:center;
  box-shadow:0 4px 10px rgba(179,97,59,.5)}

.container{max-width:1240px;margin:0 auto;padding:28px 30px 80px}

/* ---------- Portal hero strip ---------- */
.portal-hero{
  background:var(--grad-portal);color:#f5e7da;border-radius:24px;padding:34px 38px;margin-bottom:26px;
  position:relative;overflow:hidden;box-shadow:var(--shadow)
}
.portal-hero::after{content:"";position:absolute;width:440px;height:440px;border-radius:50%;
  background:radial-gradient(circle at 30% 30%,rgba(217,183,160,.22),transparent 60%);top:-170px;right:-120px}
.portal-hero h1{font-size:30px;font-weight:800;position:relative;color:#fbf3ea}
.portal-hero p{color:#d8c2b1;margin-top:8px;font-size:15px;max-width:60ch;position:relative}
.portal-hero .chips{display:flex;gap:10px;flex-wrap:wrap;margin-top:18px;position:relative}
.portal-hero .chip{background:rgba(217,183,160,.14);border:1px solid rgba(217,183,160,.26);
  padding:7px 14px;border-radius:20px;font-size:13px;font-weight:600;color:#f0ddcd}

/* ---------- Category filter ---------- */
.catbar{display:flex;gap:10px;flex-wrap:wrap;margin-bottom:22px}
.catbar button{padding:9px 18px;border-radius:30px;font-size:13.5px;font-weight:600;color:var(--brown);
  background:#fff;border:1.5px solid var(--line);transition:.2s;box-shadow:var(--shadow-sm)}
.catbar button:hover{border-color:var(--copper)}
.catbar button.active{background:var(--espresso-800);color:#f5e7da;border-color:var(--espresso-800)}

/* ---------- Product grid ---------- */
.grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(258px,1fr));gap:22px}
.card{
  background:#fff;border-radius:var(--radius);overflow:hidden;border:1px solid var(--line);
  box-shadow:var(--shadow-sm);transition:transform .25s ease,box-shadow .25s ease;
  display:flex;flex-direction:column;position:relative;
}
.card:hover{transform:translateY(-6px);box-shadow:var(--shadow)}
.card .thumb{height:140px;display:grid;place-items:center;font-size:62px;position:relative;
  background:linear-gradient(135deg,#f3e7d9,#e7d2bf)}
.card:nth-child(3n) .thumb{background:linear-gradient(135deg,#f6ece0,#e9c9ad)}
.card:nth-child(3n+1) .thumb{background:linear-gradient(135deg,#f4ebe1,#e4cdb6)}
.card:nth-child(3n+2) .thumb{background:linear-gradient(135deg,#f1e6da,#dcc0a6)}
.card .thumb .pop{position:absolute;top:12px;left:12px;background:var(--grad-copper-strong);color:#fff;
  font-size:11px;font-weight:800;padding:5px 11px;border-radius:20px;box-shadow:0 6px 14px rgba(130,70,49,.45)}
.card .body{padding:18px 18px 20px;display:flex;flex-direction:column;gap:8px;flex:1}
.card .cat{font-size:11px;font-weight:700;letter-spacing:1px;text-transform:uppercase;color:var(--copper)}
.card h3{font-size:16.5px;font-weight:700;color:var(--green-800);line-height:1.25}
.card .desc{font-size:13px;color:var(--muted);line-height:1.55;flex:1}
.card .price-row{display:flex;align-items:center;justify-content:space-between;margin-top:6px}
.card .price{font-size:20px;font-weight:800;color:var(--brown)}
.card .price small{font-size:12px;font-weight:600;color:var(--muted)}

.qty{display:flex;align-items:center;gap:0;background:var(--cream-2);border-radius:11px;overflow:hidden}
.qty button{width:34px;height:38px;font-size:18px;font-weight:700;color:var(--brown)}
.qty button:hover{background:#ead9c9}
.qty input{width:42px;text-align:center;border:none;background:transparent;font-weight:700;font-size:15px;color:var(--green-800)}
.add-row{display:flex;gap:10px;margin-top:12px}
.add-row .btn{flex:1}
.minq{font-size:11.5px;color:var(--muted);margin-top:2px}

/* ---------- Cart drawer ---------- */
.drawer-overlay{position:fixed;inset:0;background:rgba(40,20,10,.5);backdrop-filter:blur(3px);z-index:60}
.drawer{position:fixed;top:0;right:0;height:100vh;width:430px;max-width:92vw;background:var(--cream);
  z-index:61;box-shadow:var(--shadow-lg);display:flex;flex-direction:column}
.drawer-head{padding:24px 26px;background:var(--grad-portal);color:#f5e7da}
.drawer-head h2{font-size:21px;font-weight:800;color:#fbf3ea}
.drawer-head p{color:#d8c2b1;font-size:13px;margin-top:4px}
.drawer-body{flex:1;overflow-y:auto;padding:22px 24px;display:flex;flex-direction:column;gap:14px}
.cart-line{display:flex;gap:12px;background:#fff;border-radius:14px;padding:13px 14px;box-shadow:var(--shadow-sm);align-items:center}
.cart-line .ci{width:46px;height:46px;border-radius:11px;display:grid;place-items:center;font-size:26px;background:#f3e7d9;flex-shrink:0}
.cart-line .info{flex:1;min-width:0}
.cart-line .info .n{font-weight:700;font-size:14px;color:var(--green-800);line-height:1.2}
.cart-line .info .p{font-size:12.5px;color:var(--muted);margin-top:2px}
.cart-line .lineqty{display:flex;align-items:center;gap:8px}
.cart-line .lineqty button{width:26px;height:26px;border-radius:8px;background:var(--cream-2);font-weight:800;color:var(--brown)}
.cart-line .rm{color:#b3493b;font-size:18px;padding:2px 4px}
.empty-cart{text-align:center;color:var(--muted);padding:50px 20px}
.empty-cart .big{font-size:54px;margin-bottom:10px}

.delivery-box{background:#fff;border-radius:16px;padding:18px;box-shadow:var(--shadow-sm);margin-top:6px}
.delivery-box h4{font-size:14px;font-weight:700;color:var(--green-800);margin-bottom:14px;display:flex;align-items:center;gap:8px}

.drawer-foot{padding:20px 24px;background:#fff;border-top:1px solid var(--line)}
.tot-row{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:14px}
.tot-row .lbl{color:var(--muted);font-size:14px}
.tot-row .amt{font-size:26px;font-weight:800;color:var(--brown)}

/* ---------- Orders / admin ---------- */
.page-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:22px;flex-wrap:wrap;gap:14px}
.page-head h1{font-size:26px;font-weight:800;color:var(--green-800)}
.page-head .sub{color:var(--muted);font-size:14px;margin-top:3px}

.stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:18px;margin-bottom:26px}
.stat{background:#fff;border-radius:18px;padding:22px;box-shadow:var(--shadow-sm);border:1px solid var(--line);position:relative;overflow:hidden}
.stat .ic{width:46px;height:46px;border-radius:13px;display:grid;place-items:center;font-size:22px;background:#f3e7d9;margin-bottom:14px}
.stat .v{font-size:30px;font-weight:800;color:var(--green-800)}
.stat .l{font-size:13px;color:var(--muted);margin-top:2px}

.order-card{background:#fff;border-radius:18px;padding:20px 22px;box-shadow:var(--shadow-sm);border:1px solid var(--line);margin-bottom:16px}
.order-top{display:flex;justify-content:space-between;align-items:flex-start;gap:14px;flex-wrap:wrap}
.order-top .oid{font-size:13px;color:var(--muted)}
.order-top .comp{font-size:17px;font-weight:800;color:var(--green-800)}
.order-meta{display:flex;gap:18px;flex-wrap:wrap;margin:12px 0;font-size:13.5px;color:var(--ink)}
.order-meta .m{display:flex;align-items:center;gap:7px}
.order-meta .m b{color:var(--brown)}
.order-items{border-top:1px dashed var(--line);padding-top:12px;margin-top:4px}
.order-items .it{display:flex;justify-content:space-between;font-size:13.5px;padding:3px 0;color:var(--ink)}
.order-items .it .q{color:var(--muted)}
.order-foot{display:flex;justify-content:space-between;align-items:center;margin-top:14px;padding-top:14px;border-top:1px solid var(--line)}
.order-foot .ot{font-size:20px;font-weight:800;color:var(--brown)}

.badge-status{padding:6px 13px;border-radius:20px;font-size:12px;font-weight:700;text-transform:capitalize}
.s-nieuw{background:#f7e7cf;color:#9a6313}
.s-bevestigd{background:#eaddcf;color:#7a4a2c}
.s-onderweg{background:#e6dcc2;color:#7d6a23}
.s-geleverd{background:#dceadd;color:#3c7a4e}
.s-geannuleerd{background:#f6ddd8;color:#a3261c}
select.status-select{padding:8px 12px;border-radius:10px;border:1.5px solid var(--line);font-weight:600;font-size:13px;color:var(--green-800);background:#fdfaf6}

.empty-state{text-align:center;padding:70px 20px;color:var(--muted)}
.empty-state .big{font-size:60px;margin-bottom:14px}
.empty-state h3{color:var(--green-800);font-size:20px;margin-bottom:8px}

/* ============================================================
   CUSTOMER JOURNEY (stappen)
   ============================================================ */
.btn-lg{padding:15px 28px;font-size:15.5px;border-radius:14px}

.journey-head{margin-bottom:26px}
.journey-hello h1{font-size:32px;font-weight:700;color:var(--green-800)}
.journey-hello h1 span{color:var(--copper)}
.journey-hello p{color:var(--muted);margin-top:6px;font-size:15px}

.stepper{display:flex;align-items:center;gap:6px;margin-top:24px;background:#fff;border:1px solid var(--line);
  border-radius:18px;padding:16px 20px;box-shadow:var(--shadow-sm);overflow-x:auto}
.step{display:flex;align-items:center;gap:12px;flex-shrink:0;cursor:pointer}
.step-no{width:38px;height:38px;border-radius:50%;display:grid;place-items:center;font-weight:800;font-size:15px;
  background:var(--cream-2);color:var(--muted);transition:.25s;flex-shrink:0;border:2px solid transparent}
.step.active .step-no{background:var(--grad-copper-strong);color:#fff;box-shadow:0 6px 16px rgba(130,70,49,.4)}
.step.done .step-no{background:#e7f0e7;color:#3c7a4e;border-color:#bcdcc3}
.step-lbl{display:flex;flex-direction:column;line-height:1.2}
.step-lbl b{font-size:14px;color:var(--green-800);font-weight:700}
.step-lbl span{font-size:11.5px;color:var(--muted)}
.step.active .step-lbl b{color:var(--copper)}
.step-line{flex:1;min-width:24px;height:2px;background:var(--line);border-radius:2px;transition:.3s}
.step-line.done{background:var(--green-400)}
@media(max-width:680px){.step-lbl span{display:none}.step-lbl b{font-size:12.5px}}

.journey-panel{animation:fadeUp .35s ease}
@keyframes fadeUp{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}

.panel-card{background:#fff;border:1px solid var(--line);border-radius:20px;padding:26px 28px;
  box-shadow:var(--shadow-sm);margin-bottom:20px}
.sec-title{font-size:20px;font-weight:700;color:var(--green-800);margin-bottom:6px}
.sec-sub{color:var(--muted);font-size:14px;margin-bottom:18px}
.muted-note{font-size:13px;color:var(--muted);padding-top:13px}

.journey-actions{display:flex;justify-content:space-between;align-items:center;gap:14px;margin-top:8px}

/* Gelegenheid-keuze */
.occasion-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:12px}
.occ{padding:16px 14px;border-radius:14px;border:1.6px solid var(--line);background:#fdfaf6;
  font-weight:600;font-size:14px;color:var(--green-800);transition:.18s;text-align:center}
.occ:hover{border-color:var(--copper);transform:translateY(-2px)}
.occ.sel{background:var(--grad-copper);color:#2a1b11;border-color:transparent;box-shadow:0 10px 22px rgba(130,70,49,.32)}

/* Menu-kaarten */
.menu-section .sec-title{margin-top:4px}
.thumb-menu{background:linear-gradient(135deg,#2a1b11,#7a3f25)!important;color:#fff}
.ribbon{position:absolute;top:12px;left:12px;background:var(--grad-copper-strong);color:#fff;
  font-size:11px;font-weight:800;letter-spacing:1.5px;padding:5px 12px;border-radius:20px;box-shadow:0 6px 14px rgba(40,20,10,.35)}
.menu-card{border:1.5px solid #ecd9c6}
.menu-list{list-style:none;display:flex;flex-direction:column;gap:5px;margin:4px 0 6px;padding:12px 0;
  border-top:1px dashed var(--line);border-bottom:1px dashed var(--line)}
.menu-list li{position:relative;padding-left:20px;font-size:13px;color:var(--ink)}
.menu-list li::before{content:"✓";position:absolute;left:0;color:var(--copper);font-weight:800}

/* Sticky samenvattingsbalk */
.summary-bar{position:fixed;left:50%;bottom:22px;transform:translateX(-50%);z-index:55;
  width:min(760px,92vw);background:var(--espresso-800);color:#f5e7da;border-radius:18px;
  padding:14px 20px;display:flex;align-items:center;justify-content:space-between;gap:16px;
  box-shadow:0 22px 50px rgba(20,10,5,.4)}
.sb-info{display:flex;align-items:center;gap:12px;font-size:14px;color:#e7d3c2}
.sb-count{min-width:32px;height:32px;padding:0 10px;border-radius:16px;background:var(--grad-copper-strong);
  color:#fff;font-weight:800;display:grid;place-items:center}
.sb-info b{color:#fff}
.sb-actions{display:flex;gap:10px;align-items:center}
.sb-actions .btn-ghost{background:rgba(255,255,255,.12);color:#f5e7da}
.sb-actions .btn-ghost:hover{background:rgba(255,255,255,.2)}
@media(max-width:560px){.sb-text{display:none}.summary-bar{padding:12px 14px}}

/* Overzicht (stap 3) */
.overview-back{margin-bottom:16px}
.overview-grid{display:grid;grid-template-columns:1.5fr 1fr;gap:20px;align-items:start}
@media(max-width:880px){.overview-grid{grid-template-columns:1fr}}
.ov-side{display:flex;flex-direction:column;gap:20px}
.ov-side .panel-card{margin-bottom:0}
.ov-line{display:grid;grid-template-columns:42px 1fr auto auto auto;gap:12px;align-items:center;
  padding:12px 0;border-bottom:1px solid var(--line)}
.ov-line:last-of-type{border-bottom:none}
.ov-line .ci{width:42px;height:42px;border-radius:11px;display:grid;place-items:center;font-size:24px;background:#f3e7d9}
.ov-line .info .n{font-weight:700;font-size:14px;color:var(--green-800)}
.ov-line .info .p{font-size:12px;color:var(--muted);margin-top:2px}
.ov-line .lineqty{display:flex;align-items:center;gap:8px}
.ov-line .lineqty button{width:26px;height:26px;border-radius:8px;background:var(--cream-2);font-weight:800;color:var(--brown)}
.ov-line .lineqty span{font-weight:700;min-width:18px;text-align:center}
.ov-sub{font-weight:700;color:var(--brown);font-size:14px;min-width:64px;text-align:right}
.ov-line .rm{color:#b3493b;font-size:16px;padding:2px}
.ov-h{font-size:15px;font-weight:700;color:var(--green-800);margin-bottom:12px;font-family:var(--font-display)}
.ov-detail{display:flex;justify-content:space-between;gap:12px;padding:6px 0;font-size:13.5px;color:var(--muted)}
.ov-detail b{color:var(--green-800);text-align:right;font-weight:600}
.invoice-note{margin-top:12px;background:#faf2e9;border:1px solid #ecd9c6;border-radius:12px;
  padding:12px 14px;font-size:12.5px;color:var(--brown);line-height:1.6}
.total-card{background:var(--grad-espresso);border:none}
.total-card .tot-row .lbl{color:#cbb4a3}
.total-card .tot-row .amt{color:#fff}
.total-card .btn-ghost{background:rgba(255,255,255,.12);color:#f5e7da}

/* Menu-samensteller in productformulier */
.menu-toggle{margin-top:18px;border:1.6px solid var(--line);border-radius:14px;padding:16px;background:#fdfaf6;transition:.2s}
.menu-toggle.on{border-color:var(--copper);background:#faf2e9}
.mt-head{display:flex;align-items:center;gap:12px;cursor:pointer}
.mt-head input{width:auto;accent-color:var(--copper);transform:scale(1.2)}
.mt-head b{display:block;font-size:14px;color:var(--green-800)}
.mt-head span{display:block;font-size:12px;color:var(--muted)}
.mt-body{margin-top:16px}
.mt-label{display:block;font-size:13px;font-weight:600;color:var(--green-800);margin-bottom:10px}
.comp-row{display:flex;gap:8px;margin-bottom:8px}
.comp-qty{width:62px;flex-shrink:0;text-align:center}
.comp-label{flex:1}
.comp-row input{padding:10px 12px;border:1.5px solid var(--line);border-radius:10px;font-family:inherit;font-size:14px;background:#fff}
.comp-row input:focus{outline:none;border-color:var(--copper)}
.comp-del{width:40px;flex-shrink:0;border-radius:10px;background:#f6ddd8;color:#a3261c;font-size:15px}

/* Foto's op productkaarten */
.thumb.has-img{background-size:cover!important;background-position:center;font-size:0}
.thumb.has-img span:not(.ribbon):not(.pop):not(.inactive-tag){display:none}
.card.clickable{cursor:pointer}
.card.clickable .body h3{transition:color .15s}
.card.clickable:hover .body h3{color:var(--copper)}

/* Foto-upload in productformulier */
.img-upload{display:flex;gap:16px;align-items:flex-start}
.img-preview{width:110px;height:88px;border-radius:14px;flex-shrink:0;display:grid;place-items:center;
  font-size:40px;background:#f3e7d9 center/cover no-repeat;border:1px solid var(--line)}
.img-preview.empty{background:linear-gradient(135deg,#f3e7d9,#e7d2bf)}
.img-actions{display:flex;flex-direction:column;gap:8px;align-items:flex-start;padding-top:2px}
.img-actions .btn{cursor:pointer}
.img-hint{font-size:11.5px;color:var(--muted);line-height:1.5;margin-top:2px}

/* Productdetail-popup (klant) */
.detail-modal{max-width:540px;overflow:hidden;position:relative;padding:0}
.detail-x{position:absolute;top:14px;right:14px;z-index:3;width:36px;height:36px;border-radius:50%;
  background:rgba(20,12,8,.45);color:#fff;font-size:24px;line-height:1;backdrop-filter:blur(4px)}
.detail-x:hover{background:rgba(20,12,8,.7)}
.detail-media{height:240px;display:grid;place-items:center;font-size:96px;position:relative;
  background:linear-gradient(135deg,#f3e7d9,#e7d2bf)}
.detail-media.is-menu{background:linear-gradient(135deg,#2a1b11,#7a3f25);color:#fff}
.detail-media.has-img{background-size:cover;background-position:center;font-size:0}
.detail-media .ribbon{top:16px;left:16px}
.detail-media .pop{position:absolute;top:16px;left:16px;background:var(--grad-copper-strong);color:#fff;
  font-size:12px;font-weight:800;padding:6px 13px;border-radius:20px;box-shadow:0 6px 14px rgba(130,70,49,.45)}
.detail-body{padding:24px 28px 26px}
.detail-body .cat{font-size:11px;font-weight:700;letter-spacing:1px;text-transform:uppercase;color:var(--copper)}
.detail-body h2{font-size:25px;font-weight:700;color:var(--green-800);margin:6px 0 10px}
.detail-desc{color:var(--ink);font-size:14.5px;line-height:1.6;margin-bottom:8px}
.detail-h{font-size:14px;font-weight:700;color:var(--green-800);margin:16px 0 8px;font-family:var(--font-display)}
.detail-list{margin-top:0}
.detail-list li{font-size:14px;padding:3px 0 3px 22px}
.detail-foot{display:flex;align-items:center;justify-content:space-between;gap:16px;margin-top:22px;
  padding-top:20px;border-top:1px solid var(--line)}
.detail-price{font-size:28px;font-weight:800;color:var(--brown);font-family:var(--font-display)}
.detail-unit{font-size:12.5px;color:var(--muted);margin-top:2px}
@media(max-width:520px){.detail-media{height:180px;font-size:72px}.img-upload{flex-direction:column}}

/* ---------- Admin product-acties + modal ---------- */
.card-admin-actions{display:flex;gap:8px;margin-top:12px}
.card-admin-actions .btn{flex:1}
.inactive-tag{position:absolute;top:12px;right:12px;background:#7a4a2c;color:#fff;font-size:10px;font-weight:700;
  letter-spacing:.5px;padding:4px 9px;border-radius:20px;box-shadow:var(--shadow-sm)}

.modal-overlay{position:fixed;inset:0;background:rgba(40,20,10,.5);backdrop-filter:blur(4px);z-index:70;
  display:grid;place-items:center;padding:24px}
.modal{background:var(--cream);border-radius:22px;width:100%;max-width:560px;max-height:90vh;overflow-y:auto;
  box-shadow:var(--shadow-lg);border:1px solid var(--line)}
.modal-head{padding:20px 26px;background:var(--grad-portal);color:#f5e7da;
  display:flex;justify-content:space-between;align-items:center;position:sticky;top:0;z-index:2}
.modal-head h2{font-size:20px;font-weight:800;color:#fbf3ea}
.modal-head .x{color:#f5e7da;font-size:26px;line-height:1;opacity:.8;width:32px;height:32px;border-radius:9px}
.modal-head .x:hover{opacity:1;background:rgba(255,255,255,.12)}
.modal-body{padding:24px 26px 8px}
.modal-foot{padding:8px 26px 24px;display:flex;gap:12px;justify-content:flex-end}
.emoji-pick{display:flex;flex-wrap:wrap;gap:6px;margin-top:10px}
.emoji-pick button{width:38px;height:38px;border-radius:10px;font-size:20px;background:#fff;border:1.5px solid var(--line);transition:.15s}
.emoji-pick button:hover{border-color:var(--copper)}
.emoji-pick button.sel{border-color:var(--copper);background:#faf2e9;transform:scale(1.08)}
.check-row{display:flex;gap:24px;align-items:center;flex-wrap:wrap;margin-top:10px}
.check-row label{display:flex;align-items:center;gap:8px;font-size:14px;font-weight:600;color:var(--green-800);cursor:pointer}
.check-row input{width:auto;accent-color:var(--copper)}

/* ---------- Klanttabel (admin) ---------- */
.cust-table{background:#fff;border-radius:18px;box-shadow:var(--shadow-sm);border:1px solid var(--line);overflow:hidden}
.cust-row{display:grid;grid-template-columns:2.4fr 1.4fr 1.2fr .9fr 1fr .9fr;gap:14px;align-items:center;
  padding:16px 22px;border-bottom:1px solid var(--line);font-size:14px}
.cust-row:last-child{border-bottom:none}
.cust-head{background:#f6ede2;font-size:12px;font-weight:700;letter-spacing:.5px;text-transform:uppercase;color:var(--brown)}
.cust-row:not(.cust-head):hover{background:#fdfaf6}
.cust-name{font-weight:700;color:var(--green-800);font-size:15px}
.cust-sub{font-size:12.5px;color:var(--muted);margin-top:2px}
.ta-c{text-align:center}
.ta-r{text-align:right}
.pill{display:inline-grid;place-items:center;min-width:30px;height:26px;padding:0 9px;border-radius:13px;
  background:#f0e2d4;color:var(--brown);font-weight:700;font-size:13px}
.cust-actions{display:flex;gap:6px;justify-content:flex-end}
.cust-actions .btn{padding:7px 11px}
@media(max-width:820px){
  .cust-head{display:none}
  .cust-row{grid-template-columns:1fr 1fr;gap:6px 14px;padding:16px}
  .cust-actions{justify-content:flex-start;grid-column:1/-1;margin-top:6px}
}

/* ---------- Toast ---------- */
.toast{position:fixed;bottom:26px;left:50%;transform:translateX(-50%);z-index:200;
  background:var(--espresso-800);color:#f5e7da;padding:14px 24px;border-radius:14px;font-weight:600;font-size:14px;
  box-shadow:var(--shadow-lg);display:flex;align-items:center;gap:10px}
.toast.err{background:#a3261c}

/* ---------- View nav (admin/portal toggle) ---------- */
.viewnav{display:flex;gap:8px;background:var(--cream-2);border-radius:12px;padding:5px}
.viewnav button{padding:9px 18px;border-radius:9px;font-size:13.5px;font-weight:600;color:var(--muted)}
.viewnav button.active{background:#fff;color:var(--brown);box-shadow:var(--shadow-sm)}

/* ============================================================
   MOBIEL & TABLET
   ============================================================ */
@media(max-width:720px){
  /* Topbar: compact, navigatie naar een eigen rij */
  .topbar{flex-wrap:wrap;padding:9px 13px;gap:8px 10px}
  .topbar .brand .badge{display:none}
  .topbar .brand img{height:36px}
  .whoami{display:none}
  .topbar-right{flex:1;flex-wrap:wrap;gap:8px;justify-content:flex-end}
  .viewnav{order:5;width:100%;justify-content:stretch}
  .viewnav button{flex:1;padding:10px 6px;font-size:12.5px;white-space:nowrap}
  .cart-btn{width:42px;height:42px;font-size:18px}
  .avatar{width:38px;height:38px}
}

@media(max-width:600px){
  .container{padding:18px 14px 96px}
  .auth-hero{padding:42px 26px}
  .auth-hero h1{font-size:34px}
  .auth-hero p.lede{font-size:15.5px}
  .auth-card{padding:30px 22px}
  .journey-hello h1{font-size:26px}
  .portal-hero{padding:26px 22px}
  .portal-hero h1{font-size:24px}
  .panel-card{padding:20px 17px}
  .sec-title{font-size:18px}
  .row2{grid-template-columns:1fr}                 /* dubbele velden onder elkaar */
  .journey-actions .btn-lg{padding:13px 16px;font-size:13.5px}
  .occasion-grid{grid-template-columns:1fr 1fr}
  .detail-foot{flex-direction:column;align-items:stretch;gap:14px}
  .detail-foot .btn,.detail-foot>div{width:100%;text-align:center}
  .modal-foot{flex-direction:column-reverse;gap:10px}
  .modal-foot .btn{width:100%}
  .summary-bar{left:12px;right:12px;transform:none;width:auto}
  .img-upload{flex-direction:column}
  /* Stepper: alleen de actieve stap toont tekst, zo passen alle stappen */
  .stepper{padding:14px 12px;gap:6px}
  .step{gap:8px}
  .step-no{width:34px;height:34px;font-size:14px}
  .step:not(.active) .step-lbl{display:none}
  .step-lbl b{font-size:13px}
}
