/* ===== Order Manager — modern utility theme (blue / yellow) ===== */
:root{
  --blue:        #1d4ed8;
  --blue-600:    #2563eb;
  --blue-700:    #1e40af;
  --blue-50:     #eff5ff;
  --yellow:      #facc15;
  --yellow-600:  #eab308;
  --yellow-50:   #fefce8;
  --ink:         #0f172a;
  --slate:       #475569;
  --slate-400:   #94a3b8;
  --line:        #e2e8f0;
  --bg:          #f4f6fb;
  --card:        #ffffff;
  --green:       #16a34a;
  --green-50:    #ecfdf5;
  --red:         #dc2626;
  --red-50:      #fef2f2;
  --radius:      14px;
  --shadow:      0 1px 2px rgba(15,23,42,.06), 0 8px 24px rgba(15,23,42,.06);
  --shadow-sm:   0 1px 2px rgba(15,23,42,.08);

  /* Themeable colours (overridable from Settings → Branding → Styles) */
  --topbar-bg:   #0f172a;   /* header background       */
  --drawer-bg:   #0f172a;   /* mobile slide-out menu   */
  --nav-link:    #cbd5e1;   /* menu link colour        */
  --accent:      #ffd507;   /* highlight / yellow CTA  */
  --btn-primary: #2563eb;   /* primary (blue) buttons  */
  --text:        #0f172a;   /* body text               */
  --page-bg:     #f4f6fb;   /* page background         */
}

*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{
  font-family:'Manrope',system-ui,sans-serif;
  background:
    radial-gradient(1200px 500px at 100% -10%, var(--blue-50), transparent 60%),
    var(--page-bg);
  color:var(--text);
  min-height:100vh;
  -webkit-font-smoothing:antialiased;
}
h1,h2,h3,.brand-text{font-family:'Sora',sans-serif;letter-spacing:-.01em}
a{color:var(--blue-600);text-decoration:none}
a:hover{text-decoration:underline}

/* ---- Top bar ---- */
.topbar{
  display:flex;align-items:center;gap:24px;
  padding:14px 28px;background:var(--topbar-bg);color:#fff;
  position:sticky;top:0;z-index:20;
}
.brand{display:flex;align-items:center;gap:11px;color:#fff;font-weight:700}
.brand:hover{text-decoration:none}
.brand-logo{display:block;height:30px;width:auto;
  border-radius:9px;box-shadow:var(--shadow-sm)}
.nav{display:flex;flex-wrap:wrap;gap:6px;margin-left:8px}
.nav a{
  color:var(--nav-link);padding:7px 13px;border-radius:8px;font-weight:600;font-size:14px;
  transition:background .15s ease, color .15s ease;
}
.nav a:hover{color:#fff;background:rgba(255,255,255,.14);text-decoration:none}
.nav a.active{color:#fff;background:rgba(255,255,255,.12)}
.topbar-right{margin-left:auto;display:flex;align-items:center;gap:14px}
.who{color:var(--slate-400);font-size:13px;font-weight:600}

/* ---- Layout ---- */
.container{max-width:1080px;margin:0 auto;padding:32px 24px 60px}
.section-head{display:flex;align-items:center;gap:12px;margin:34px 0 16px}
.section-head:first-child{margin-top:8px}
.section-head h2{margin:0;font-size:20px}
.section-head .count{
  font-size:12px;font-weight:700;color:var(--slate);
  background:#fff;border:1px solid var(--line);border-radius:999px;padding:3px 10px;
}
.section-head .see-all{margin-left:auto;font-size:13px;font-weight:700}

/* ---- Toolbar: status tabs + search ---- */
.filterbar{background:var(--card);border:1px solid var(--line);border-radius:14px;
  padding:14px;margin:20px 0 18px}
.tabs{display:flex;gap:6px;flex-wrap:wrap}
.tab{font-size:13px;font-weight:700;color:var(--slate);background:#fff;border:1px solid var(--line);
  border-radius:999px;padding:7px 14px}
.tab:hover{border-color:#c9d6f5;text-decoration:none}
.tab.active{background:var(--blue-600);border-color:var(--blue-600);color:#fff}
.filters{display:flex;align-items:center;gap:8px;flex-wrap:wrap;
  margin-top:12px;padding-top:12px;border-top:1px solid var(--line)}
.filter-select{flex:0 0 auto;width:150px;padding:8px 12px;border:1px solid var(--line);
  border-radius:9px;font:inherit;font-size:14px;background:#fff;cursor:pointer}
.search-group{display:flex;align-items:center;gap:8px;flex:1 1 320px;min-width:220px}
.search-group .btn{flex:none}
.filter-search{flex:1 1 auto;min-width:0;padding:8px 12px;border:1px solid var(--line);
  border-radius:9px;font:inherit;font-size:14px;background:#fff}
.filter-search:focus,.filter-select:focus{outline:none;border-color:var(--blue);box-shadow:0 0 0 3px var(--blue-50)}
.btn svg{width:15px;height:15px;flex:none}

/* ---- Pagination ---- */
.pager{display:flex;flex-wrap:wrap;justify-content:center;gap:6px;margin-top:22px}
.pg{min-width:38px;text-align:center;font-size:14px;font-weight:700;color:var(--ink);
  background:#fff;border:1px solid var(--line);border-radius:9px;padding:8px 12px}
.pg:hover{border-color:var(--blue-600);color:var(--blue-700);text-decoration:none}
.pg.active{background:var(--blue-600);border-color:var(--blue-600);color:#fff}
.pg.disabled{color:var(--slate-400);background:#f8fafc;pointer-events:none;border-color:var(--line)}
.pg-gap{align-self:center;color:var(--slate-400);padding:0 4px}
.page-title{font-size:28px;margin:4px 0 2px}
.muted{color:var(--slate);font-size:14px}

/* ---- Buttons ---- */
.btn{
  display:inline-flex;align-items:center;gap:8px;justify-content:center;
  font-family:'Manrope';font-weight:700;font-size:14px;cursor:pointer;
  padding:10px 16px;border-radius:10px;border:1px solid transparent;
  transition:transform .04s ease, box-shadow .15s ease, background .15s ease;
}
.btn:hover{text-decoration:none}
.btn:active{transform:translateY(1px)}
.btn-sm{padding:7px 12px;font-size:13px;border-radius:9px}
.btn-blue{background:var(--btn-primary);color:#fff;box-shadow:var(--shadow-sm)}
.btn-blue:hover{background:var(--blue-700)}
.btn-yellow{background:var(--accent);color:var(--ink);box-shadow:var(--shadow-sm)}
.btn-yellow:hover{background:var(--yellow-600)}
.btn-green{background:#16a34a;color:#fff;box-shadow:var(--shadow-sm)}
.btn-green:hover{background:#15803d}
.btn-sky{background:#0284c7;color:#fff;box-shadow:var(--shadow-sm)}
.btn-sky:hover{background:#0369a1}
.btn-ghost{background:transparent;border-color:rgba(255,255,255,.25);color:#fff}
.btn-ghost:hover{background:rgba(255,255,255,.1)}
.btn-outline{background:#fff;border-color:var(--line);color:var(--ink)}
.btn-outline:hover{border-color:var(--blue-600);color:var(--blue-700)}
.btn-danger{background:#fff;border-color:var(--line);color:var(--red)}
.btn-danger:hover{background:var(--red-50);border-color:var(--red)}
.btn-row{display:flex;flex-wrap:wrap;gap:10px}

/* ---- Status badges ---- */
.badge{
  display:inline-flex;align-items:center;gap:6px;font-size:12px;font-weight:700;
  padding:4px 10px;border-radius:999px;border:1px solid transparent;line-height:1;
}
.badge::before{content:"";width:7px;height:7px;border-radius:50%}
.badge.in_production  {background:var(--yellow-50);color:#8a6d00;border-color:#f7e08a}
.badge.in_production::before{background:var(--yellow-600)}
.badge.on_hold {background:#fff4e6;color:#9a3412;border-color:#fed7aa}
.badge.on_hold::before{background:#f97316}
.badge.completed{background:var(--green-50);color:#0f7a3d;border-color:#bbf7d0}
.badge.completed::before{background:var(--green)}
.badge.canceled {background:var(--red-50);color:#b91c1c;border-color:#fecaca}
.badge.canceled::before{background:var(--red)}
.badge.overdue  {background:#fff1f2;color:#be123c;border-color:#fecdd3}
.badge.overdue::before{background:#e11d48}

.cat-tag{
  display:inline-flex;align-items:center;font-size:11px;font-weight:700;color:var(--blue-700);
  background:var(--blue-50);border:1px solid #d3e1fb;border-radius:6px;padding:2px 8px;line-height:1.4;
}
.cat-logo{width:14px;height:14px;object-fit:contain;margin-right:5px;border-radius:3px;background:#fff}
/* Order priority pills */
.prio{display:inline-flex;align-items:center;gap:3px;font-size:11px;font-weight:800;border-radius:6px;
  padding:2px 8px;line-height:1.4;border:1px solid transparent;text-transform:uppercase;letter-spacing:.02em}
.prio-ico{flex:none}
.prio-normal{color:var(--slate);background:#eef1f6;border-color:#dde3ec}
.prio-high{color:#9a3412;background:#fff4e6;border-color:#fed7aa}
.prio-urgent{color:var(--red);background:var(--red-50);border-color:#fecaca}
.prio-line{margin:8px 0 0}
/* DTF printed-roll length badge */
.dtf-roll{display:inline-flex;align-items:center;gap:4px;font-size:11px;font-weight:700;
  color:#0e7490;background:#ecfeff;border:1px solid #a5f3fc;border-radius:6px;padding:2px 8px;
  line-height:1.4;white-space:nowrap}
.dtf-roll .roll-ico{flex:none}
.input-unit{display:flex;align-items:center;gap:8px}
.input-unit input{width:110px;flex:none}
.input-unit .unit{color:var(--slate);font-weight:600;font-size:14px}
.tag-list{display:flex;flex-wrap:wrap;gap:6px}
/* category (order type) logo shown on orders + lists */
.cat-type-logo{height:18px;width:18px;object-fit:contain;border-radius:50%;vertical-align:middle;margin-right:7px;flex:none;background:#fff}
.detail-body .v .cat-type-logo{height:24px;width:24px;margin-right:9px}
.card-media{position:relative}
.card-media .card-cat{position:absolute;top:10px;right:10px;height:34px;width:34px;border-radius:50%;
  background:#fff;padding:2px;box-shadow:var(--shadow-sm);object-fit:contain;margin:0}

/* ---- Categories page ---- */
.cat-layout{display:grid;grid-template-columns:340px 1fr;gap:18px;align-items:start;margin-top:20px}
.cat-thumb{width:38px;height:38px;border-radius:50%;object-fit:contain;background:#fff;
  border:1px solid var(--line);flex:none}
.cat-thumb.placeholder{display:grid;place-items:center;font-family:'Sora';font-weight:700;
  font-size:15px;color:var(--blue-700);background:var(--blue-50)}
.logo-current{display:flex;align-items:center;gap:10px;margin-bottom:10px}
.logo-preview{display:flex;align-items:center;gap:12px;background:var(--ink);border-radius:10px;
  padding:10px 14px;margin-bottom:10px}
.logo-preview img{height:30px;width:auto;background:transparent;padding:0;border-radius:0}
.logo-preview.foot{background:var(--bg);border:1px solid var(--line)}
.logo-preview.foot img{background:transparent;padding:0;border-radius:0;height:30px}
.logo-preview.pdf{background:#fff;border:1px solid var(--line)}
.logo-preview.pdf img{background:transparent;padding:0;border-radius:0;height:34px}

/* ---- Translation editor ---- */
.tr-filter{width:100%;padding:9px 12px;border:1px solid var(--line);border-radius:9px;
  margin:6px 0 14px;font:inherit}
.tr-head{display:grid;grid-template-columns:minmax(0,1fr) minmax(0,1.2fr);gap:12px;
  font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.04em;
  color:var(--slate-400);padding-bottom:6px;border-bottom:1px solid var(--line)}
.tr-section h4{margin:16px 0 6px;font-family:'Sora';font-size:12px;color:var(--slate-400);
  text-transform:uppercase;letter-spacing:.05em}
.tr-row{display:grid;grid-template-columns:minmax(0,1fr) minmax(0,1.2fr);gap:12px;
  align-items:center;padding:5px 0;border-bottom:1px solid var(--bg)}
.tr-src{font-size:13px;color:#475569;word-break:break-word}
.tr-row input{width:100%;padding:7px 10px;border:1px solid var(--line);border-radius:8px;
  font:inherit;font-size:13px}
.tr-row input:focus{outline:none;border-color:var(--blue);box-shadow:0 0 0 3px var(--blue-50)}
@media(max-width:640px){
  .tr-head{display:none}
  .tr-row{grid-template-columns:1fr;gap:3px;padding:8px 0}
}
.cat-item-main{flex:1;min-width:0}
.cat-item{flex-wrap:wrap;row-gap:8px}
.cat-item form{margin:0}
.cat-default-badge{display:inline-block;margin-left:8px;font-size:10px;font-weight:700;color:#0f7a3d;
  background:var(--green-50);border:1px solid #bbf7d0;border-radius:5px;padding:1px 7px;
  vertical-align:middle;text-transform:uppercase;letter-spacing:.03em}
.cat-move{display:flex;flex-direction:column;gap:3px}
.cat-move .mv{border:1px solid var(--line);background:#fff;border-radius:6px;width:26px;height:18px;
  font-size:9px;line-height:1;cursor:pointer;color:var(--slate);padding:0;display:grid;place-items:center}
.cat-move .mv:hover:not(:disabled){border-color:var(--blue);color:var(--blue)}
.cat-move .mv:disabled{opacity:.35;cursor:default}
@media(max-width:640px){.cat-layout{grid-template-columns:1fr}}

/* ---- Shop pickup panel ---- */
.pickup-contact{display:flex;flex-wrap:wrap;gap:14px;margin-top:16px}
.pickup-contact a{display:flex;flex-direction:column;gap:3px;text-decoration:none;min-width:210px;
  background:var(--yellow-50);border:1px solid #f0e0a0;border-radius:12px;padding:12px 16px;
  transition:border-color .15s,box-shadow .15s}
.pickup-contact a:hover{border-color:#e6c84d;box-shadow:var(--shadow-sm)}
.pickup-contact .pc-label{font-size:11px;text-transform:uppercase;letter-spacing:.05em;color:#9a7b06;font-weight:700}
.pickup-contact .pc-value{font-size:18px;font-weight:700;color:var(--ink);font-family:'Sora',sans-serif;word-break:break-word}

/* ---- List view ---- */
.order-list{display:flex;flex-direction:column;gap:10px}
.list-row{
  display:flex;align-items:center;gap:16px;background:var(--card);
  border:1px solid var(--line);border-radius:var(--radius);padding:12px 16px;
  box-shadow:var(--shadow-sm);transition:border-color .15s, box-shadow .15s;
}
.list-row:hover{border-color:#c9d6f5;box-shadow:var(--shadow)}
.thumb{
  width:54px;height:54px;border-radius:10px;object-fit:cover;flex:none;
  background:var(--blue-50);border:1px solid var(--line);
}
.list-main{min-width:0;flex:1}
.list-main .num{font-size:12px;font-weight:700;color:var(--slate-400);letter-spacing:.02em}
.list-main .title{font-weight:700;font-size:15px;margin:1px 0 4px;color:var(--ink)}
.list-main .tags{display:flex;flex-wrap:wrap;gap:5px}
.list-side{display:flex;flex-direction:column;align-items:flex-end;gap:8px;flex:none}
.list-side .due{font-size:12px;color:var(--slate);font-weight:600;white-space:nowrap}
.file-pill{display:inline-flex;align-items:center;gap:4px;font-size:12px;font-weight:700;color:#4338ca;
  background:#eef2ff;border-radius:999px;padding:2px 9px 2px 7px;white-space:nowrap}
.file-pill svg{width:13px;height:13px}

/* ---- Grid view ---- */
.grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:16px}
.card{
  background:var(--card);border:1px solid var(--line);border-radius:var(--radius);
  overflow:hidden;box-shadow:var(--shadow-sm);transition:transform .12s, box-shadow .15s;
  display:flex;flex-direction:column;
}
.card:hover{transform:translateY(-3px);box-shadow:var(--shadow)}
.card-media{height:130px;background:var(--blue-50);position:relative}
.card-media img{width:100%;height:100%;object-fit:cover;display:block}
.card-media .badge{position:absolute;top:10px;left:10px}
.card-body{padding:13px 15px 16px;display:flex;flex-direction:column;gap:7px;flex:1}
.card-body .num{font-size:11px;font-weight:700;color:var(--slate-400)}
.card-body .title{font-weight:700;font-size:15px;line-height:1.25;color:var(--ink)}
.card-body .desc{font-size:13px;color:var(--slate);line-height:1.45;
  display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.card-body .tags{display:flex;flex-wrap:wrap;gap:5px;margin-top:auto}
.card-foot{display:flex;align-items:center;justify-content:space-between;
  padding:11px 15px;border-top:1px solid var(--line);font-size:12px;color:var(--slate);font-weight:600}

.empty{padding:26px;text-align:center;color:var(--slate);background:var(--card);
  border:1px dashed var(--line);border-radius:var(--radius)}

/* ---- Cards / panels ---- */
.panel{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);
  box-shadow:var(--shadow-sm);padding:22px}
.panel h3{margin:0 0 14px;font-size:16px}

/* ---- Forms ---- */
.field{margin-bottom:16px}
.field label{display:block;font-weight:700;font-size:13px;margin-bottom:6px;color:var(--ink)}
.field .hint{font-weight:500;color:var(--slate-400);font-size:12px}
input[type=text],input[type=email],input[type=password],input[type=date],input[type=datetime-local],input[type=number],textarea,select{
  width:100%;font-family:'Manrope',system-ui,sans-serif;font-size:14px;color:var(--ink);
  padding:10px 12px;border:1px solid var(--line);border-radius:10px;background:#fff;
}
select,option{font-family:'Manrope',system-ui,sans-serif}
input:focus,textarea:focus,select:focus{
  outline:none;border-color:var(--blue-600);box-shadow:0 0 0 3px rgba(37,99,235,.15)}
textarea{min-height:90px;resize:vertical}
.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.checks{display:flex;flex-wrap:wrap;gap:8px}
.check{
  display:inline-flex;align-items:center;gap:7px;border:1px solid var(--line);
  border-radius:9px;padding:8px 12px;font-size:13px;font-weight:600;cursor:pointer;background:#fff}
.check input{accent-color:var(--blue-600)}
.check:has(input:checked){border-color:var(--blue-600);background:var(--blue-50);color:var(--blue-700)}

/* ---- File rows ---- */
.file-row{display:flex;align-items:center;gap:12px;padding:11px 14px;border:1px solid var(--line);
  border-radius:11px;background:#fff;margin-bottom:9px}
.file-ico{width:38px;height:38px;border-radius:9px;display:grid;place-items:center;flex:none;
  background:var(--blue-50);color:var(--blue-700);font-weight:700;font-size:11px;text-transform:uppercase}
.file-meta{flex:1;min-width:0}
.file-meta .fn{font-weight:600;font-size:14px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.file-meta .fs{font-size:12px;color:var(--slate-400);font-weight:600}
.file-ico-link{background:#eef2ff;color:#4338ca}
.file-ico-link svg{width:20px;height:20px}
.file-meta .file-url{font-weight:500;color:var(--slate-400);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:100%}
.link-box{margin-top:12px}
.link-form{display:flex;gap:8px;align-items:center;flex-wrap:wrap;margin-top:8px}
.link-input{flex:1 1 280px;min-width:0;padding:9px 11px;border:1px solid #c7d2e8;border-radius:9px;font-family:inherit;font-size:13px;background:#fff}
.link-input::placeholder{font-size:13px}
.link-input:focus{outline:none;border-color:var(--btn-primary);box-shadow:0 0 0 3px rgba(37,99,235,.15)}
.link-hint{margin:8px 0 0;font-size:12px}
.upload-box{border:1px dashed #c7d2e8;border-radius:12px;padding:16px;background:var(--blue-50)}
.upload-box.alt{background:var(--yellow-50);border-color:#f0e0a0}
.upload-box h4{margin:0 0 4px;font-size:14px;font-family:'Sora'}
.file-input{display:block;margin:10px 0;font-size:13px}

/* Pretty native file-picker buttons (everything except the hidden dropzone inputs) */
input[type=file]:not(.dz-input){font-size:13px;color:var(--slate-400);max-width:100%}
input[type=file]:not(.dz-input)::file-selector-button{
  margin-right:12px;padding:8px 15px;border:0;border-radius:9px;cursor:pointer;
  background:var(--blue);color:#fff;font-weight:700;font-size:13px;font-family:inherit;transition:background .15s}
input[type=file]:not(.dz-input):hover::file-selector-button{background:var(--blue-700)}
input[type=file]:not(.dz-input)::-webkit-file-upload-button{
  margin-right:12px;padding:8px 15px;border:0;border-radius:9px;cursor:pointer;
  background:var(--blue);color:#fff;font-weight:700;font-size:13px;font-family:inherit;transition:background .15s}
input[type=file]:not(.dz-input):hover::-webkit-file-upload-button{background:var(--blue-700)}

/* ---- Drag & drop upload ---- */
.dz-form{margin-top:10px}
.dropzone{display:block;position:relative;border:2px dashed #c7d2e8;border-radius:12px;
  padding:22px 18px;background:#fff;cursor:pointer;transition:border-color .15s,background .15s}
.dropzone:hover{border-color:var(--blue)}
.dropzone.drag{border-color:var(--blue);background:var(--blue-50)}
.dz-input{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0 0 0 0);border:0}
.dz-inner{display:flex;flex-direction:column;align-items:center;gap:3px;pointer-events:none}
.dz-icon{font-size:22px;line-height:1;color:var(--blue-700)}
.dz-text{font-weight:600;font-size:14px}
.dz-hint{font-size:12px;color:var(--slate-400)}
.dz-list{list-style:none;margin:12px 0 0;padding:0;display:flex;flex-direction:column;gap:5px;text-align:left;pointer-events:none}
.dz-list li{font-size:13px;background:var(--bg);border:1px solid var(--line);border-radius:8px;
  padding:6px 10px;display:flex;justify-content:space-between;gap:10px}
.dz-list li .sz{color:var(--slate-400);font-size:12px;flex:none}
.dz-form .btn{margin-top:16px}

/* ---- Detail header ---- */
.detail-panel{padding:0;overflow:hidden}
.detail-hero{position:relative;display:block;width:100%;padding:0;border:0;cursor:zoom-in;
  background:var(--blue-50);border-bottom:1px solid var(--line);max-height:420px;overflow:hidden}
.detail-hero img{display:block;width:100%;height:auto;max-height:420px;object-fit:cover}
.detail-hero .badge{position:absolute;top:16px;left:16px;box-shadow:var(--shadow-sm)}
.hero-zoom{position:absolute;bottom:14px;right:14px;display:inline-flex;align-items:center;gap:6px;
  font-size:12px;font-weight:700;color:#fff;background:rgba(15,23,42,.62);
  border-radius:999px;padding:6px 12px;backdrop-filter:blur(2px);transition:background .15s}
.detail-hero:hover .hero-zoom{background:var(--blue-700)}
.detail-body{padding:34px 28px 28px}
.detail-body .num{font-size:13px;font-weight:700;color:var(--slate-400)}
.detail-body h1{margin:5px 0 0;font-size:26px}
.meta-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:18px;margin-top:22px}
.meta-grid .k{font-size:11px;text-transform:uppercase;letter-spacing:.05em;color:var(--slate-400);font-weight:700}
.meta-grid .v{font-size:14px;font-weight:600;margin-top:3px;word-break:break-word}

/* ---- Panel header row (title + action) ---- */
.panel-head{display:flex;align-items:center;justify-content:space-between;gap:12px;
  flex-wrap:wrap;margin-bottom:14px}

/* ---- Lightbox (full-size, uncropped image) ---- */
.lightbox{position:fixed;inset:0;z-index:100;display:none;align-items:center;justify-content:center;
  padding:28px;background:rgba(15,23,42,.86);backdrop-filter:blur(3px);cursor:zoom-out}
.lightbox.open{display:flex}
.lightbox img{max-width:96vw;max-height:92vh;width:auto;height:auto;object-fit:contain;
  border-radius:10px;box-shadow:0 20px 60px rgba(0,0,0,.5);cursor:default}
.lightbox-close{position:absolute;top:18px;right:22px;width:42px;height:42px;border:0;border-radius:50%;
  background:rgba(255,255,255,.14);color:#fff;font-size:26px;line-height:1;cursor:pointer;
  display:grid;place-items:center;transition:background .15s}
.lightbox-close:hover{background:rgba(255,255,255,.28)}

/* ---- Form divider ---- */
.form-divider{display:flex;align-items:center;gap:12px;margin:26px 0 18px;
  color:var(--slate-400);font-family:'Sora';font-weight:600;font-size:13px;
  text-transform:uppercase;letter-spacing:.06em}
.form-divider::before,.form-divider::after{content:"";height:1px;background:var(--line);flex:1}

/* ---- Auth ---- */
.auth-wrap{min-height:100vh;display:grid;place-items:center;padding:24px}
.auth-card{width:100%;max-width:380px;background:var(--card);border:1px solid var(--line);
  border-radius:18px;box-shadow:var(--shadow);padding:30px}
.auth-card .brand-mark{width:46px;height:46px;font-size:19px;border-radius:12px;margin-bottom:14px}
.auth-card h1{font-size:22px;margin:0 0 4px}
.auth-card .creds{margin-top:16px;font-size:12px;color:var(--slate);text-align:center}
.error{background:var(--red-50);color:#b91c1c;border:1px solid #fecaca;border-radius:10px;
  padding:10px 13px;font-size:13px;font-weight:600;margin-bottom:14px}
.flash{background:var(--green-50);color:#0f7a3d;border:1px solid #bbf7d0;border-radius:10px;
  padding:10px 14px;font-size:14px;font-weight:600;margin-bottom:16px}

/* ---- Modal (notifications) ---- */
.modal-overlay{position:fixed;inset:0;background:rgba(15,23,42,.5);display:flex;align-items:center;
  justify-content:center;z-index:1000;padding:20px;animation:modal-fade .15s ease}
@keyframes modal-fade{from{opacity:0}to{opacity:1}}
.modal{background:var(--card);border-radius:16px;max-width:420px;width:100%;position:relative;
  padding:26px 24px 22px;box-shadow:0 24px 70px rgba(15,23,42,.32);animation:modal-pop .16s ease}
@keyframes modal-pop{from{transform:translateY(10px) scale(.98);opacity:0}to{transform:none;opacity:1}}
.modal-x{position:absolute;top:12px;right:14px;background:none;border:0;font-size:24px;line-height:1;
  color:var(--slate-400);cursor:pointer}
.modal-x:hover{color:var(--ink)}
.modal-icon{width:46px;height:46px;border-radius:50%;background:var(--green-50);color:#0f7a3d;
  display:grid;place-items:center;font-size:24px;margin-bottom:14px}
.modal-icon.danger{background:var(--red-50);color:var(--red)}
.modal-body p{margin:0 0 6px;font-size:15px;font-weight:600;color:var(--ink);line-height:1.45}
.modal-body p:last-child{margin-bottom:0}
.modal-foot{margin-top:20px;display:flex;justify-content:flex-end;gap:10px}

/* ---- Misc ---- */
.cat-list{display:flex;flex-direction:column;gap:8px}
.cat-item{display:flex;align-items:center;gap:12px;
  border:1px solid var(--line);border-radius:10px;padding:10px 14px;background:#fff}
.cat-item .nm{font-weight:700}
.cat-item .cn{font-size:12px;color:var(--slate-400);font-weight:600}
.site-foot{display:flex;flex-direction:column;align-items:center;gap:10px;
  color:var(--slate-400);font-size:12px;padding:30px 24px}
.foot-logo{height:30px;width:auto}
.auth-logo{display:block;width:100%;max-width:260px;height:auto;margin:0 auto 18px;
  background:var(--ink);padding:14px 20px;border-radius:14px;box-sizing:border-box}
.back-link{display:inline-flex;align-items:center;gap:6px;font-weight:600;font-size:13px;margin-bottom:14px}

@media(max-width:820px){
  .topbar{gap:12px;padding:12px 18px}
  .nav{gap:4px;margin-left:0}
  .nav a{padding:6px 10px;font-size:13px}
  .topbar-right{gap:10px}
}
@media(max-width:560px){
  .topbar{gap:10px;padding:11px 14px}
  .brand-logo{height:26px}
  .topbar-right{margin-left:auto}
  .who{display:none}
  .grid-2{grid-template-columns:1fr}
  .container{padding:22px 16px 50px}
}

/* ----- Activity log table + per-order logs modal ----- */
.log-table{width:100%;border-collapse:collapse;font-size:13px}
.log-table th{text-align:left;font-size:11px;text-transform:uppercase;letter-spacing:.04em;color:var(--slate-400);padding:11px 14px;border-bottom:1px solid var(--line);white-space:nowrap;background:var(--bg)}
.log-table td{padding:10px 14px;border-bottom:1px solid var(--line);vertical-align:top;color:var(--ink)}
.log-table tbody tr:last-child td{border-bottom:0}
.log-table tbody tr:hover{background:var(--bg)}
.log-table .nowrap{white-space:nowrap;color:var(--slate)}
.log-table .log-details{color:var(--slate);word-break:break-word}
.logs-modal-body{max-height:55vh;overflow:auto;border:1px solid var(--line);border-radius:var(--radius)}
.logs-modal-body .log-table th{position:sticky;top:0}

/* ----- Email settings panel ----- */
.settings-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:0 18px}
.tpl-block{border:1px solid var(--line);border-radius:var(--radius);padding:14px 16px;margin-bottom:14px;background:#fff}
.tpl-head{font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.04em;color:var(--slate-400);margin-bottom:10px}
.tpl-vars{border:1px dashed var(--line);border-radius:var(--radius);padding:12px 16px;background:var(--bg);margin-top:6px}
.tpl-vars ul{margin:6px 0 0;padding-left:18px;columns:2;font-size:13px;line-height:1.7}
.tpl-vars li{break-inside:avoid}
.tpl-vars code{background:#fff;border:1px solid var(--line);border-radius:5px;padding:1px 6px;font-size:12px;color:var(--blue-700)}
@media(max-width:560px){.tpl-vars ul{columns:1}}

/* ----- Inline warning banner (e.g. blocked email send) ----- */
.warn-banner{background:var(--red-50);border:1px solid #fecaca;color:#b91c1c;
  padding:12px 14px;border-radius:10px;font-size:14px;line-height:1.5;margin-bottom:16px}

/* ----- Storage cleanup / export ----- */
.danger-box{background:var(--red-50);border:1px solid #fecaca;color:#b91c1c;
  padding:14px 16px;border-radius:12px;font-size:14px;line-height:1.55;margin:8px 0 14px}
.progress{height:12px;background:var(--bg);border:1px solid var(--line);border-radius:999px;overflow:hidden}
.progress-bar{height:100%;width:0;background:var(--blue-600);transition:width .35s ease}

/* Disabled buttons should read as disabled */
.btn:disabled,.btn[disabled]{opacity:.5;cursor:not-allowed;box-shadow:none}

/* ----- Retention form + server environment table ----- */
.retention-row{display:flex;gap:8px;align-items:center;flex-wrap:wrap;margin-top:4px}
.retention-row input[type=number]{width:100px}
.retention-row select{width:auto}
.env-table{width:100%;border-collapse:collapse;font-size:13px;margin-bottom:4px}
.env-table th{text-align:left;font-weight:600;color:var(--slate);padding:6px 10px;border-bottom:1px solid var(--line);white-space:nowrap;width:42%;vertical-align:top}
.env-table td{padding:6px 10px;border-bottom:1px solid var(--line);color:var(--ink);word-break:break-word;font-family:monospace;font-size:12px}
.env-table tr:last-child th,.env-table tr:last-child td{border-bottom:0}

/* Discreet disk-usage indicator in the header */
.topbar-right .disk{font-size:12px;color:var(--slate-400);white-space:nowrap;
  padding-right:10px;margin-right:2px;border-right:1px solid var(--line)}
@media(max-width:720px){.topbar-right .disk{display:none}}

/* Clients page: import + search rows */
.import-row{display:flex;flex-wrap:wrap;align-items:center;gap:10px}
.search-row{display:flex;flex-wrap:wrap;align-items:center;gap:10px}
.search-row .form-control{flex:1;min-width:200px;max-width:420px}

/* Client autocomplete on the order form */
.client-find{position:relative}
.ac-list{position:absolute;z-index:40;left:0;right:0;top:100%;margin-top:6px;background:var(--card);
  border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow);max-height:300px;overflow:auto}
.ac-item{padding:9px 13px;cursor:pointer;border-bottom:1px solid var(--line)}
.ac-item:last-child{border-bottom:0}
.ac-item:hover,.ac-item.active{background:var(--bg)}
.ac-item .nm{font-weight:600;color:var(--ink)}
.ac-item .sub{font-size:12px;color:var(--slate);margin-top:1px}
.ac-empty{padding:11px 13px;color:var(--slate);font-size:13px}

/* "Update saved client" offer on the order form */
.client-offer{display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap;
  margin:4px 0 16px;padding:11px 14px;border:1px solid var(--blue);background:var(--blue-50);
  border-radius:var(--radius);font-size:14px;color:var(--ink)}
.client-offer[hidden]{display:none}
.client-offer.ok{border-color:var(--green);background:var(--green-50)}
.client-offer.err{border-color:var(--red);background:var(--red-50)}
.client-offer-text{flex:1;min-width:180px}
.client-offer-actions{display:flex;gap:8px;flex:none}

/* Header nav link icons */
.nav a{display:inline-flex;align-items:center;gap:7px}
.nav-ico{flex:none;display:block}
.btn-icon{display:inline-flex;align-items:center;gap:6px}

/* Featured-image thumbnail preview inside its dropzone */
.dz-thumb{display:block;margin:12px auto 0;width:50px;height:50px;border-radius:8px;
  border:1px solid var(--line);object-fit:cover;pointer-events:none}
.dz-thumb[hidden]{display:none}

/* Settings tabs */
.settings-tabs{display:flex;flex-wrap:wrap;gap:8px;margin-top:18px}
.stab{display:inline-flex;align-items:center;gap:7px;background:var(--card);border:1px solid var(--line);
  padding:9px 14px;border-radius:10px;font:inherit;font-weight:600;font-size:14px;color:var(--slate);cursor:pointer}
.stab:hover{border-color:var(--blue-600);color:var(--blue-700)}
.stab.active{background:var(--blue-600);border-color:var(--blue-600);color:#fff}
.stab svg{width:17px;height:17px;flex:none}
.tab-pane[hidden]{display:none}

/* Focusable featured dropzone (for paste) */
.dropzone:focus{outline:none;border-color:var(--blue);box-shadow:0 0 0 3px var(--blue-50)}
.dropzone:focus-visible{outline:none;border-color:var(--blue);box-shadow:0 0 0 3px var(--blue-50)}

/* On-hold disclaimer banner (order detail) */
.hold-banner{display:flex;gap:12px;align-items:flex-start;margin:14px 0 18px;padding:14px 16px;
  background:#fff4e6;border:1px solid #fed7aa;border-left:4px solid #f97316;border-radius:12px;
  color:#9a3412;font-weight:600;line-height:1.5}
.hold-banner-icon{font-size:20px;line-height:1.25;flex:none}
/* Conflict / heads-up banner (e.g. both a DPD label and a manual sticker) */
.warn-banner{display:flex;gap:12px;align-items:flex-start;margin:0 0 14px;padding:12px 14px;
  background:#fef2f2;border:1px solid #fecaca;border-left:4px solid var(--red);border-radius:12px;
  color:#991b1b;font-weight:600;line-height:1.5}
.warn-banner-icon{font-size:18px;line-height:1.25;flex:none}
/* Neutral info badge */
.badge.info{background:var(--blue-50);color:var(--blue-700);border-color:#d3e1fb}
.badge.info::before{background:var(--blue-700)}
/* Cross-reference note linking the DPD / sticker sections */
.ship-note{display:flex;gap:8px;align-items:flex-start;margin:0 0 14px;font-size:13px;color:var(--slate);
  background:#f4f6fb;border:1px solid var(--line);border-radius:10px;padding:10px 12px;font-weight:600}

/* Live search loading state */
#ordersResults.is-loading{opacity:.5;transition:opacity .12s ease}

/* ---- Mobile hamburger + left slide-in drawer ---- */
.nav-toggle{display:none;flex-direction:column;align-items:center;justify-content:center;width:40px;height:40px;
  padding:0;border:0;border-radius:9px;background:transparent;cursor:pointer;flex:none}
.nav-toggle:hover{background:rgba(255,255,255,.1)}
.nav-toggle span{display:block;width:20px;height:2px;background:#fff;border-radius:2px;transition:transform .2s ease, opacity .2s ease}
.nav-toggle span + span{margin-top:4px}
.nav-close{display:none}
.nav-foot{display:none}
.nav-overlay{position:fixed;inset:0;background:rgba(15,23,42,.5);z-index:30;
  opacity:0;pointer-events:none;transition:opacity .25s ease}

@media(max-width:820px){
  .nav-toggle{display:inline-flex;margin-left:auto}
  .topbar-right{display:none}
  .nav{
    position:fixed;top:0;left:0;bottom:0;width:82%;max-width:300px;
    flex-direction:column;flex-wrap:nowrap;align-items:stretch;gap:4px;
    margin:0;padding:60px 14px 18px;background:var(--drawer-bg);
    box-shadow:2px 0 24px rgba(0,0,0,.35);
    transform:translateX(-100%);transition:transform .26s ease;
    z-index:40;overflow-y:auto;
  }
  .nav a{font-size:15px;padding:12px 14px;border-radius:10px}
  .nav a:hover{background:rgba(255,255,255,.16)}
  .nav a.active{background:rgba(255,255,255,.14);box-shadow:inset 3px 0 0 var(--accent)}
  .nav-foot{display:flex;flex-direction:column;gap:4px;margin-top:auto;
    padding-top:14px;border-top:1px solid rgba(255,255,255,.14)}
  .nav-user{color:var(--slate-400);font-size:13px;font-weight:600;padding:4px 14px}
  .nav-close{display:flex;align-items:center;justify-content:center;
    position:absolute;top:12px;right:12px;width:36px;height:36px;
    border:0;background:transparent;color:#fff;font-size:26px;line-height:1;cursor:pointer;border-radius:9px}
  .nav-close:hover{background:rgba(255,255,255,.1)}
  body.nav-open{overflow:hidden}
  body.nav-open .nav{transform:translateX(0)}
  body.nav-open .nav-overlay{opacity:1;pointer-events:auto}
  body.nav-open .nav-toggle span:nth-child(1){transform:translateY(6px) rotate(45deg)}
  body.nav-open .nav-toggle span:nth-child(2){opacity:0}
  body.nav-open .nav-toggle span:nth-child(3){transform:translateY(-6px) rotate(-45deg)}
}

/* Styles (colour) customiser in Branding settings */
.style-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px 22px;margin-top:14px}
.style-row{display:flex;align-items:center;justify-content:space-between;gap:12px}
.style-row label{font-weight:600;font-size:14px;color:var(--ink)}
.style-pick{display:inline-flex;align-items:center;gap:8px}
.cpick{position:relative}
.cpick-swatch{width:30px;height:30px;flex:none;border-radius:50%;border:0;padding:0;cursor:pointer;
  box-shadow:inset 0 0 0 1px rgba(15,23,42,.18), 0 1px 2px rgba(15,23,42,.15)}
.cpick-swatch:hover{box-shadow:inset 0 0 0 1px rgba(15,23,42,.28), 0 1px 4px rgba(15,23,42,.2)}
.cpick-swatch:focus-visible{outline:2px solid var(--blue-600);outline-offset:2px}
.cp-pop{position:absolute;top:40px;right:0;left:auto;z-index:60;width:210px;background:#fff;
  border:1px solid var(--line);border-radius:12px;box-shadow:var(--shadow);padding:12px;display:none}
.cp-pop.open{display:block}
.cp-sv{position:relative;width:100%;height:130px;border-radius:8px;cursor:crosshair;touch-action:none;
  background-image:linear-gradient(to top,#000,rgba(0,0,0,0)),linear-gradient(to right,#fff,rgba(255,255,255,0))}
.cp-sv-h{position:absolute;width:14px;height:14px;border-radius:50%;border:2px solid #fff;
  box-shadow:0 0 0 1px rgba(0,0,0,.35);transform:translate(-50%,-50%);pointer-events:none}
.cp-hue{position:relative;width:100%;height:14px;margin-top:12px;border-radius:7px;cursor:pointer;touch-action:none;
  background:linear-gradient(to right,#f00,#ff0,#0f0,#0ff,#00f,#f0f,#f00)}
.cp-hue-h{position:absolute;top:50%;width:8px;height:20px;border-radius:4px;border:2px solid #fff;
  box-shadow:0 0 0 1px rgba(0,0,0,.4);transform:translate(-50%,-50%);pointer-events:none}
.cp-presets{display:flex;flex-wrap:wrap;gap:6px;margin-top:12px}
.cp-preset{width:18px;height:18px;border-radius:50%;border:0;padding:0;cursor:pointer;
  box-shadow:inset 0 0 0 1px rgba(15,23,42,.18)}
.cp-preset:hover{transform:scale(1.12)}
.style-hex{width:92px;padding:7px 9px;border:1px solid var(--line);border-radius:8px;font:inherit;font-size:13px;text-transform:lowercase}
@media(max-width:560px){.style-grid{grid-template-columns:1fr}}
