/* ════════════════════════════════════════════════════════════
   Print Magic Online — Quotation Catalog
   Design system: "Press Proof" — CMYK registration bars,
   spec-sheet typography, crop-mark framing.
   ════════════════════════════════════════════════════════════ */

:root{
  --bg:        #F1F0EC;
  --card:      #FFFFFF;
  --ink:       #1A1D24;
  --ink-soft:  #5B5F6B;
  --ink-faint: #9398A3;
  --line:      #DBD8CF;
  --line-soft: #EAE8E1;

  --c: #0E7AC4;  /* cyan    */
  --m: #D6336C;  /* magenta */
  --y: #F4B400;  /* yellow  */
  --k: #1A1D24;  /* key/black */

  --r-sm: 6px;
  --r-md: 10px;
  --r-lg: 16px;

  --font-display: 'Space Grotesk', 'Arial', sans-serif;
  --font-body:    'Inter', 'Helvetica Neue', sans-serif;
  --font-mono:    'IBM Plex Mono', 'Courier New', monospace;
}

*{ box-sizing:border-box; margin:0; padding:0; }

html{ scroll-behavior:smooth; }

body{
  font-family:var(--font-body);
  background:var(--bg);
  color:var(--ink);
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
  min-height:100vh;
}

a{ color:inherit; text-decoration:none; }

img{ max-width:100%; display:block; }

/* ── Focus visibility ─────────────────────────────────────── */
a:focus-visible, button:focus-visible{
  outline:2.5px solid var(--c);
  outline-offset:2px;
  border-radius:4px;
}

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

/* ── CMYK registration bar — the signature motif ─────────────
   A row of 4 colour blocks, as seen on every print proof sheet.
   Used as dividers, corner marks, and decorative accents.       */
.cmyk-bar{
  display:flex;
  height:6px;
  width:100%;
  border-radius:0;
  overflow:hidden;
}
.cmyk-bar > span{ flex:1; }
.cmyk-bar .c{ background:var(--c); }
.cmyk-bar .m{ background:var(--m); }
.cmyk-bar .y{ background:var(--y); }
.cmyk-bar .k{ background:var(--k); }

.cmyk-dots{
  display:inline-flex;
  gap:5px;
  align-items:center;
}
.cmyk-dots span{
  width:9px; height:9px; border-radius:50%; display:block;
}
.cmyk-dots .c{ background:var(--c); }
.cmyk-dots .m{ background:var(--m); }
.cmyk-dots .y{ background:var(--y); }
.cmyk-dots .k{ background:var(--k); }

/* ── Crop marks — corner registration marks on framed boxes ── */
.crop-frame{ position:relative; }
.crop-frame::before, .crop-frame::after,
.crop-frame > .crop-tl, .crop-frame > .crop-tr,
.crop-frame > .crop-bl, .crop-frame > .crop-br{
  content:''; position:absolute; width:14px; height:14px;
  pointer-events:none;
}
.crop-frame::before{ /* top-left */
  top:-7px; left:-7px;
  border-top:2px solid var(--ink); border-left:2px solid var(--ink);
}
.crop-frame::after{ /* bottom-right */
  bottom:-7px; right:-7px;
  border-bottom:2px solid var(--ink); border-right:2px solid var(--ink);
}
.crop-frame > .crop-tr{ top:-7px; right:-7px; border-top:2px solid var(--ink); border-right:2px solid var(--ink); }
.crop-frame > .crop-bl{ bottom:-7px; left:-7px; border-bottom:2px solid var(--ink); border-left:2px solid var(--ink); }

/* ── Layout shell ─────────────────────────────────────────── */
.wrap{ max-width:1080px; margin:0 auto; padding:0 24px; }

/* ── Header ───────────────────────────────────────────────── */
.site-header{
  background:var(--card);
  border-bottom:1px solid var(--line);
  position:sticky; top:0; z-index:50;
}
.site-header .wrap{
  display:flex; align-items:center; justify-content:space-between;
  padding-top:16px; padding-bottom:16px; gap:16px;
}
.brand{
  display:flex; align-items:center; gap:12px;
  font-family:var(--font-display);
  font-weight:700; font-size:18px; letter-spacing:-.2px;
  color:var(--ink);
}
.brand-mark{
  width:34px; height:34px; border-radius:8px;
  background:var(--ink); color:#fff;
  display:grid; place-items:center;
  font-family:var(--font-mono); font-weight:700; font-size:13px;
  letter-spacing:-.5px;
}
.brand-text-sub{
  font-size:10.5px; color:var(--ink-soft); font-weight:500;
  letter-spacing:.4px; text-transform:uppercase;
  margin-top:1px;
}
.header-actions{ display:flex; align-items:center; gap:10px; }
.btn-wa{
  display:inline-flex; align-items:center; gap:8px;
  background:var(--ink); color:#fff;
  font-family:var(--font-body); font-weight:600; font-size:13.5px;
  padding:10px 18px; border-radius:30px;
  border:none; cursor:pointer;
  transition:transform .15s ease, background .15s ease;
}
.btn-wa:hover{ background:#2E3340; transform:translateY(-1px); }
.btn-wa svg{ width:16px; height:16px; flex-shrink:0; }

.back-link{
  font-family:var(--font-mono); font-size:12.5px; font-weight:600;
  color:var(--ink-soft);
  display:inline-flex; align-items:center; gap:6px;
  transition:color .15s ease;
}
.back-link:hover{ color:var(--ink); }

/* ── Hero (catalog page) ──────────────────────────────────── */
.hero{ padding:56px 0 40px; }
.hero-eyebrow{
  font-family:var(--font-mono); font-size:12px; font-weight:600;
  letter-spacing:2px; text-transform:uppercase; color:var(--ink-soft);
  display:flex; align-items:center; gap:10px; margin-bottom:18px;
}
.hero h1{
  font-family:var(--font-display); font-weight:700;
  font-size:clamp(34px, 6vw, 58px);
  letter-spacing:-1.5px; line-height:1.05;
  color:var(--ink); max-width:14ch;
}
.hero p{
  font-size:16px; color:var(--ink-soft); max-width:46ch;
  margin-top:18px;
}
.hero-bar{ margin-top:32px; }

/* ── Catalog grid ─────────────────────────────────────────── */
.catalog-section{ padding:8px 0 72px; }
.catalog-section h2{
  font-family:var(--font-display); font-size:13px; font-weight:700;
  letter-spacing:2px; text-transform:uppercase; color:var(--ink-faint);
  margin-bottom:20px;
}
.catalog-grid{
  display:grid;
  grid-template-columns:repeat(auto-fill, minmax(252px, 1fr));
  gap:18px;
}
.ticket{
  background:var(--card);
  border:1px solid var(--line);
  border-radius:var(--r-md);
  padding:22px 20px 20px;
  display:flex; flex-direction:column; gap:14px;
  transition:border-color .18s ease, transform .18s ease, box-shadow .18s ease;
  position:relative;
}
.ticket:hover{
  border-color:var(--ink);
  transform:translateY(-3px);
  box-shadow:0 10px 24px -16px rgba(26,29,36,.35);
}
.ticket-top{ display:flex; align-items:flex-start; justify-content:space-between; gap:10px; }
.ticket-icon{
  width:46px; height:46px; border-radius:10px;
  background:var(--bg); border:1px solid var(--line-soft);
  display:grid; place-items:center; font-size:22px;
  flex-shrink:0;
}
.ticket-code{
  font-family:var(--font-mono); font-size:11px; font-weight:600;
  color:var(--ink-faint); letter-spacing:1px;
  border:1px solid var(--line); border-radius:20px;
  padding:4px 10px; white-space:nowrap;
}
.ticket h3{
  font-family:var(--font-display); font-size:17px; font-weight:700;
  letter-spacing:-.3px; color:var(--ink);
}
.ticket p{ font-size:13px; color:var(--ink-soft); flex:1; }
.ticket-foot{
  display:flex; align-items:center; justify-content:space-between;
  font-family:var(--font-mono); font-size:11.5px; color:var(--ink-faint);
  padding-top:12px; border-top:1px dashed var(--line);
}
.ticket-cta{
  font-weight:700; color:var(--ink);
  display:inline-flex; align-items:center; gap:5px;
}
.ticket:hover .ticket-cta{ color:var(--c); }
.ticket:hover .ticket-cta svg{ transform:translateX(3px); }
.ticket-cta svg{ width:13px; height:13px; transition:transform .18s ease; }

/* ── Product page ─────────────────────────────────────────── */
.product-hero{ padding:36px 0 8px; }
.product-grid{
  display:grid; grid-template-columns:1.05fr 1fr; gap:48px;
  align-items:start; padding:28px 0 64px;
}
@media (max-width: 860px){
  .product-grid{ grid-template-columns:1fr; gap:36px; }
}

.product-eyebrow{
  font-family:var(--font-mono); font-size:12px; font-weight:600;
  letter-spacing:2px; text-transform:uppercase; color:var(--ink-soft);
  display:flex; align-items:center; gap:12px; margin-bottom:16px;
}
.product-hero h1{
  font-family:var(--font-display); font-weight:700;
  font-size:clamp(32px, 5.5vw, 48px);
  letter-spacing:-1.2px; line-height:1.06;
  color:var(--ink); max-width:16ch;
}
.product-tagline{
  font-size:16px; color:var(--ink-soft); margin-top:14px; max-width:42ch;
}

/* Visual swatch placeholder */
.swatch{
  background:var(--card); border:1px solid var(--line);
  border-radius:var(--r-lg);
  padding:28px; margin:6px 4px;
  display:flex; flex-direction:column; align-items:center; justify-content:center;
  gap:18px; text-align:center; min-height:300px;
  position:relative;
}
.swatch img{
  width:100%; height:100%; object-fit:cover;
  border-radius:var(--r-md);
  position:absolute; inset:0; z-index:2;
}
.swatch.has-image .swatch-icon,
.swatch.has-image .swatch-label,
.swatch.has-image .swatch-name,
.swatch.has-image .cmyk-bar{ display:none; }
.swatch-icon{
  font-size:64px; line-height:1; position:relative; z-index:1;
}
.swatch-label{
  font-family:var(--font-mono); font-size:12px; color:var(--ink-faint);
  letter-spacing:1.5px; text-transform:uppercase; position:relative; z-index:1;
}
.swatch-name{
  font-family:var(--font-display); font-weight:700; font-size:20px;
  color:var(--ink); position:relative; z-index:1;
}

/* Description */
.product-desc{
  font-size:15px; color:var(--ink-soft); margin:24px 0 0; max-width:48ch;
}

/* Spec sections */
.spec-block{ margin-top:32px; }
.spec-block h2{
  font-family:var(--font-display); font-size:13px; font-weight:700;
  letter-spacing:2px; text-transform:uppercase; color:var(--ink-faint);
  margin-bottom:14px;
  display:flex; align-items:center; gap:10px;
}
.spec-block h2::after{
  content:''; flex:1; height:1px; background:var(--line);
}
.spec-block-sub{
  font-size:13px; color:var(--ink-soft); margin:-4px 0 16px;
}

/* Specification dropdowns ("Choose Your Specifications") */
.spec-select-grid{
  display:grid;
  grid-template-columns:repeat(auto-fill, minmax(220px, 1fr));
  gap:14px;
}
.spec-select-group{
  display:flex; flex-direction:column; gap:6px;
}
.spec-select-group label{
  font-family:var(--font-mono); font-size:10.5px; font-weight:600;
  letter-spacing:1.5px; text-transform:uppercase; color:var(--ink-faint);
}
.spec-select-group select{
  font-family:var(--font-body); font-size:13.5px; font-weight:500;
  color:var(--ink); background:var(--card);
  border:1px solid var(--line); border-radius:var(--r-md);
  padding:11px 14px;
  appearance:none; -webkit-appearance:none; -moz-appearance:none;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%231A1D24' stroke-width='2.4' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E");
  background-repeat:no-repeat; background-position:right 12px center; background-size:16px;
  padding-right:38px;
  cursor:pointer;
  transition:border-color .15s ease;
}
.spec-select-group select:hover, .spec-select-group select:focus{
  border-color:var(--ink);
}

/* "Good to Know" trust list */
.trust-list{
  list-style:none; display:flex; flex-direction:column; gap:12px;
}
.trust-list li{
  display:flex; align-items:flex-start; gap:12px;
  font-size:13.5px; color:var(--ink-soft); line-height:1.5;
}
.trust-icon{ font-size:17px; flex-shrink:0; line-height:1.4; }

/* Price calculator */
.calc-block{
  background:var(--card); border:1.5px solid var(--ink);
  border-radius:var(--r-lg); padding:24px;
}
.calc-block h2::after{ display:none; }
.calc-grid{
  display:grid;
  grid-template-columns:repeat(auto-fill, minmax(180px, 1fr));
  gap:14px; margin-bottom:18px;
}
.calc-result{
  display:flex; align-items:center; justify-content:space-between;
  background:var(--bg); border:1px solid var(--line); border-radius:var(--r-md);
  padding:18px 20px;
}
.calc-result-label{
  font-family:var(--font-mono); font-size:11px; font-weight:600;
  letter-spacing:1.5px; text-transform:uppercase; color:var(--ink-faint);
}
.calc-result-price{
  font-family:var(--font-display); font-size:30px; font-weight:700;
  color:var(--ink); letter-spacing:-1px;
}

/* Rate table */
.rate-table{
  width:100%; border-collapse:collapse;
  font-family:var(--font-mono); font-size:13.5px;
  border:1px solid var(--line); border-radius:var(--r-md);
  overflow:hidden;
}
.rate-table thead th{
  background:var(--ink); color:#fff;
  text-align:left; font-weight:600;
  padding:11px 16px; font-size:11px; letter-spacing:1px;
  text-transform:uppercase;
}
.rate-table thead th:last-child, .rate-table tbody td:last-child{ text-align:right; }
.rate-table tbody td{
  padding:13px 16px; border-bottom:1px solid var(--line-soft);
  color:var(--ink); background:var(--card);
}
.rate-table tbody tr:last-child td{ border-bottom:none; }
.rate-table tbody td.rate-cell{ font-weight:700; color:var(--ink); }
.rate-note{
  font-size:12px; color:var(--ink-faint); margin-top:10px;
  font-style:italic;
}

/* Chips */
.chip-row{ display:flex; flex-wrap:wrap; gap:8px; }
.chip{
  font-family:var(--font-body); font-size:13px; font-weight:500;
  color:var(--ink); background:var(--card);
  border:1px solid var(--line); border-radius:30px;
  padding:7px 15px;
}

/* Meta row (MOQ / turnaround) */
.meta-row{
  display:grid; grid-template-columns:1fr 1fr; gap:12px; margin-top:32px;
}
.meta-card{
  border:1px solid var(--line); border-radius:var(--r-md);
  padding:16px 18px; background:var(--card);
}
.meta-label{
  font-family:var(--font-mono); font-size:10.5px; font-weight:600;
  letter-spacing:1.5px; text-transform:uppercase; color:var(--ink-faint);
  margin-bottom:6px;
}
.meta-value{
  font-family:var(--font-display); font-size:18px; font-weight:700;
  color:var(--ink);
}

/* CTA — ink-stamp button */
.cta-block{ margin-top:36px; display:flex; flex-direction:column; gap:12px; align-items:flex-start; }
.stamp-btn{
  display:inline-flex; align-items:center; gap:12px;
  font-family:var(--font-display); font-weight:700; font-size:16px;
  color:var(--ink); background:transparent;
  border:2.5px solid var(--ink); border-radius:var(--r-md);
  padding:16px 28px;
  transform:rotate(-1.2deg);
  transition:transform .18s ease, background .18s ease, color .18s ease;
  cursor:pointer;
  position:relative;
}
.stamp-btn:hover{
  transform:rotate(0deg) translateY(-2px);
  background:var(--ink); color:#fff;
}
.stamp-btn svg{ width:20px; height:20px; flex-shrink:0; }
.cta-sub{ font-size:12.5px; color:var(--ink-faint); padding-left:4px; }

/* Related products */
.related{ padding:8px 0 72px; border-top:1px solid var(--line); margin-top:8px; }
.related h2{
  font-family:var(--font-display); font-size:13px; font-weight:700;
  letter-spacing:2px; text-transform:uppercase; color:var(--ink-faint);
  margin:40px 0 20px;
}

/* ── Footer ───────────────────────────────────────────────── */
.site-footer{
  border-top:1px solid var(--line);
  background:var(--card);
  padding:36px 0;
  margin-top:0;
}
.site-footer .wrap{
  display:flex; flex-wrap:wrap; gap:18px;
  align-items:center; justify-content:space-between;
}
.footer-left{
  font-family:var(--font-display); font-weight:700; font-size:15px;
  color:var(--ink);
}
.footer-sub{
  font-size:12.5px; color:var(--ink-faint); margin-top:4px;
  font-family:var(--font-mono);
}
.footer-right{ display:flex; gap:18px; flex-wrap:wrap; }
.footer-right a{
  font-size:13px; font-weight:600; color:var(--ink-soft);
  transition:color .15s ease;
}
.footer-right a:hover{ color:var(--ink); }

/* ── Responsive tweaks ────────────────────────────────────── */
@media (max-width:600px){
  .wrap{ padding:0 18px; }
  .meta-row{ grid-template-columns:1fr; }
  .hero{ padding:36px 0 28px; }
  .product-hero{ padding:24px 0 4px; }
}

/* ── Loading / empty states ───────────────────────────────── */
.loading-state, .empty-state{
  padding:60px 20px; text-align:center;
  color:var(--ink-faint); font-family:var(--font-mono); font-size:13px;
}
.loading-bar{
  width:120px; height:4px; margin:0 auto 16px;
  background:var(--line); border-radius:4px; overflow:hidden;
  position:relative;
}
.loading-bar::after{
  content:''; position:absolute; inset:0;
  background:var(--c);
  animation:loadsweep 1.1s ease-in-out infinite;
}
@keyframes loadsweep{
  0%{ transform:translateX(-100%); }
  50%{ transform:translateX(0); }
  100%{ transform:translateX(100%); }
}

/* ── Image gallery (product page) ─────────────────────────── */
.gallery-thumbs{
  display:flex; gap:8px; margin-top:10px; flex-wrap:wrap;
}
.gallery-thumb{
  width:56px; height:56px; border-radius:8px; overflow:hidden;
  border:2px solid var(--line); cursor:pointer; background:var(--card);
  transition:border-color .15s ease;
}
.gallery-thumb.active{ border-color:var(--c); }
.gallery-thumb img{ width:100%; height:100%; object-fit:cover; }

/* ════════════════════════════════════════════════════════════
   ADMIN PANEL
   ════════════════════════════════════════════════════════════ */
.admin-body{ background:var(--bg); min-height:100vh; }

.admin-login{
  max-width:380px; margin:80px auto; padding:0 24px;
}
.admin-login .login-card{
  background:var(--card); border:1px solid var(--line);
  border-radius:var(--r-lg); padding:36px 32px;
}
.admin-login h1{
  font-family:var(--font-display); font-size:22px; font-weight:700;
  margin-bottom:6px; letter-spacing:-.5px;
}
.admin-login p.sub{ font-size:13px; color:var(--ink-soft); margin-bottom:24px; }

.field{ margin-bottom:16px; }
.field label{
  display:block; font-family:var(--font-mono); font-size:11px; font-weight:600;
  letter-spacing:1px; text-transform:uppercase; color:var(--ink-soft);
  margin-bottom:6px;
}
.field input, .field textarea, .field select{
  width:100%; padding:10px 13px; border:1.5px solid var(--line);
  border-radius:8px; font-family:var(--font-body); font-size:14px;
  background:var(--card); color:var(--ink);
}
.field input:focus, .field textarea:focus, .field select:focus{
  outline:none; border-color:var(--c);
}
.field textarea{ resize:vertical; min-height:80px; }
.field-hint{ font-size:11.5px; color:var(--ink-faint); margin-top:5px; }
.field-error{ font-size:12.5px; color:var(--m); margin-top:8px; min-height:1px; }

.btn{
  font-family:var(--font-body); font-weight:600; font-size:13.5px;
  padding:10px 20px; border-radius:8px; border:1.5px solid var(--ink);
  background:var(--ink); color:#fff; cursor:pointer;
  transition:all .15s ease; display:inline-flex; align-items:center; gap:6px;
}
.btn:hover{ background:#2E3340; }
.btn.btn-outline{ background:transparent; color:var(--ink); }
.btn.btn-outline:hover{ background:var(--bg); }
.btn.btn-danger{ background:transparent; color:var(--m); border-color:var(--m); }
.btn.btn-danger:hover{ background:var(--m); color:#fff; }
.btn.btn-sm{ font-size:12px; padding:6px 12px; border-radius:6px; }
.btn:disabled{ opacity:.5; cursor:not-allowed; }

/* Admin header */
.admin-header{
  background:var(--card); border-bottom:1px solid var(--line);
  padding:14px 0; position:sticky; top:0; z-index:50;
}
.admin-header .wrap{ display:flex; align-items:center; justify-content:space-between; gap:16px; }
.admin-title{ font-family:var(--font-display); font-weight:700; font-size:16px; }
.admin-title .sub{ font-family:var(--font-mono); font-size:11px; color:var(--ink-faint); font-weight:500; }

/* Admin layout */
.admin-wrap{ max-width:1100px; margin:0 auto; padding:28px 24px 80px; }
.admin-toolbar{
  display:flex; align-items:center; justify-content:space-between;
  margin-bottom:20px; gap:12px; flex-wrap:wrap;
}
.admin-toolbar h2{
  font-family:var(--font-display); font-size:18px; font-weight:700; letter-spacing:-.3px;
}

/* Product list table */
.admin-table{
  width:100%; border-collapse:collapse; background:var(--card);
  border:1px solid var(--line); border-radius:var(--r-md); overflow:hidden;
}
.admin-table th{
  text-align:left; font-family:var(--font-mono); font-size:10.5px;
  font-weight:600; letter-spacing:1px; text-transform:uppercase;
  color:var(--ink-faint); padding:10px 14px; border-bottom:1px solid var(--line);
  background:var(--bg);
}
.admin-table td{
  padding:12px 14px; border-bottom:1px solid var(--line-soft); font-size:13.5px;
  vertical-align:middle;
}
.admin-table tr:last-child td{ border-bottom:none; }
.admin-table tr:hover td{ background:#FAFAF8; }
.admin-table .row-icon{ font-size:20px; width:40px; }
.admin-table .row-actions{ text-align:right; white-space:nowrap; }
.admin-table .pill{
  font-family:var(--font-mono); font-size:10.5px; font-weight:600;
  padding:3px 9px; border-radius:20px; border:1px solid var(--line);
}
.pill.active{ background:#E6F4EA; border-color:#A6D9B6; color:#1A7F37; }
.pill.inactive{ background:#F3F3F1; border-color:var(--line); color:var(--ink-faint); }

/* Edit form sections */
.admin-card{
  background:var(--card); border:1px solid var(--line); border-radius:var(--r-lg);
  padding:24px; margin-bottom:20px;
}
.admin-card h3{
  font-family:var(--font-display); font-size:14px; font-weight:700;
  letter-spacing:-.2px; margin-bottom:16px;
  display:flex; align-items:center; justify-content:space-between;
}
.field-grid{ display:grid; grid-template-columns:1fr 1fr; gap:14px 18px; }
@media (max-width:640px){ .field-grid{ grid-template-columns:1fr; } }

/* Dynamic row editors (variants / materials / finishing) */
.row-editor-item{
  display:flex; gap:8px; align-items:flex-start; margin-bottom:10px;
}
.row-editor-item .field{ margin-bottom:0; flex:1; }
.row-editor-item .remove-row{
  flex-shrink:0; width:38px; height:38px; border-radius:8px;
  border:1.5px solid var(--line); background:var(--card); color:var(--m);
  cursor:pointer; display:grid; place-items:center; font-size:16px;
  transition:all .15s ease;
}
.row-editor-item .remove-row:hover{ background:var(--m); color:#fff; border-color:var(--m); }

/* Image manager */
.image-grid{
  display:grid; grid-template-columns:repeat(auto-fill, minmax(120px,1fr));
  gap:12px; margin-bottom:14px;
}
.image-tile{
  position:relative; border:1.5px solid var(--line); border-radius:10px;
  overflow:hidden; aspect-ratio:1; background:var(--bg);
}
.image-tile img{ width:100%; height:100%; object-fit:cover; }
.image-tile .remove-img{
  position:absolute; top:6px; right:6px; width:26px; height:26px;
  border-radius:50%; background:rgba(26,29,36,.75); color:#fff;
  border:none; cursor:pointer; display:grid; place-items:center; font-size:14px;
}
.upload-drop{
  border:2px dashed var(--line); border-radius:10px; padding:24px;
  text-align:center; font-size:13px; color:var(--ink-soft);
  cursor:pointer; transition:border-color .15s ease;
}
.upload-drop:hover, .upload-drop.dragover{ border-color:var(--c); }
.upload-drop input{ display:none; }

/* Toast */
.toast{
  position:fixed; bottom:24px; right:24px; z-index:9999;
  background:var(--ink); color:#fff; padding:12px 20px; border-radius:8px;
  font-size:13.5px; font-weight:600; box-shadow:0 10px 30px -10px rgba(0,0,0,.4);
  transform:translateY(20px); opacity:0; transition:all .25s ease; max-width:320px;
}
.toast.show{ transform:translateY(0); opacity:1; }
.toast.error{ background:var(--m); }

/* Slug preview */
.slug-preview{
  font-family:var(--font-mono); font-size:12px; color:var(--ink-faint);
  margin-top:6px;
}
.slug-preview b{ color:var(--ink); font-weight:600; }

