/* ============================================================
   DiMasi — Owner Admin UI (admin.css)
   Loaded on every page; only paints when owner is logged in.
   ============================================================ */
:root{
  --dm-bg:#0c0d10;
  --dm-panel:#141519;
  --dm-line:rgba(246,242,234,.10);
  --dm-line2:rgba(246,242,234,.18);
  --dm-txt:#f4f1ea;
  --dm-mut:#9b958a;
  --dm-accent:#ff6a1a;
  --dm-accent2:#c0855a;
  --dm-ok:#36b37e;
  --dm-warn:#e0533a;
  --dm-bar-h:54px;
  --dm-font:'Archivo',system-ui,sans-serif;
}

/* ---------- Owner bar ---------- */
#dm-bar{
  position:fixed;top:0;left:0;right:0;height:var(--dm-bar-h);z-index:9000;
  display:flex;align-items:center;gap:16px;padding:0 16px;
  background:linear-gradient(180deg,#15161b,#0d0e11);
  border-bottom:1px solid var(--dm-line2);
  font-family:var(--dm-font);color:var(--dm-txt);
  box-shadow:0 10px 40px -16px rgba(0,0,0,.8);
}
body.dm-on{padding-top:var(--dm-bar-h)}
body.dm-on .topbar{top:var(--dm-bar-h)}
#dm-bar .dm-logo{display:flex;align-items:center;gap:9px;font-weight:800;text-transform:uppercase;font-size:13px;letter-spacing:.04em;white-space:nowrap}
#dm-bar .dm-logo .dm-dot{width:9px;height:9px;border-radius:50%;background:var(--dm-accent);box-shadow:0 0 10px var(--dm-accent)}
#dm-bar .dm-logo small{color:var(--dm-mut);font-weight:600;letter-spacing:.12em;font-size:9.5px;text-transform:uppercase}
#dm-bar .dm-spacer{flex:1}
.dm-btn{
  display:inline-flex;align-items:center;gap:8px;height:36px;padding:0 14px;border-radius:6px;
  font-family:var(--dm-font);font-weight:700;font-size:12px;letter-spacing:.04em;
  border:1px solid var(--dm-line2);background:#1b1c21;color:var(--dm-txt);cursor:pointer;
  transition:.2s;white-space:nowrap;text-transform:uppercase;
}
.dm-btn:hover{border-color:var(--dm-mut);background:#22232a}
.dm-btn svg{width:15px;height:15px}
.dm-btn--accent{background:var(--dm-accent);border-color:var(--dm-accent);color:#fff}
.dm-btn--accent:hover{background:#ff7d36;border-color:#ff7d36}
.dm-btn--ghost{background:transparent}
.dm-btn--sm{height:30px;padding:0 11px;font-size:11px}
.dm-btn.is-on{background:var(--dm-accent);border-color:var(--dm-accent);color:#fff;box-shadow:0 0 0 3px rgba(255,106,26,.2)}
.dm-pill{display:inline-flex;align-items:center;gap:7px;font-size:11px;font-weight:700;letter-spacing:.05em;color:var(--dm-mut);text-transform:uppercase}
.dm-save-state{font-size:11px;color:var(--dm-ok);display:none;align-items:center;gap:6px;font-weight:700}
.dm-save-state.show{display:inline-flex}
.dm-save-state .d{width:7px;height:7px;border-radius:50%;background:var(--dm-ok)}
#dm-quote-count{display:inline-flex;align-items:center;justify-content:center;min-width:18px;height:18px;padding:0 5px;border-radius:9px;background:var(--dm-accent);color:#fff;font-size:11px;font-weight:800;margin-left:2px}
#dm-quote-count:empty,#dm-quote-count[data-n="0"]{display:none}

/* ---------- Edit-mode affordances on live pages ---------- */
body.dm-edit [data-tkey]{outline:1px dashed rgba(255,106,26,.45);outline-offset:3px;cursor:text;border-radius:2px;transition:background .2s,outline-color .2s}
body.dm-edit [data-tkey]:hover{outline-color:var(--dm-accent);background:rgba(255,106,26,.07)}
body.dm-edit [data-tkey][contenteditable="true"]{outline:2px solid var(--dm-accent);background:rgba(255,106,26,.08);cursor:text}
[data-tkey].dm-changed{outline-color:var(--dm-accent2)!important}

/* image hover-to-swap */
body.dm-edit img:not(.dm-skip img):not(#dm-bar img){cursor:pointer}
.dm-img-wrap{position:relative;display:inline-block}
.dm-img-badge{
  position:absolute;z-index:60;top:8px;left:8px;display:none;align-items:center;gap:6px;
  padding:6px 10px;border-radius:6px;background:rgba(12,13,16,.86);backdrop-filter:blur(6px);
  border:1px solid var(--dm-accent);color:#fff;font-family:var(--dm-font);font-size:11px;font-weight:700;
  text-transform:uppercase;letter-spacing:.04em;pointer-events:none;
}
body.dm-edit .dm-img-badge{display:inline-flex}
.dm-img-badge svg{width:14px;height:14px}
body.dm-edit [data-okey]{outline:2px solid transparent;transition:outline-color .2s}
body.dm-edit [data-okey]:hover{outline-color:var(--dm-accent)}

/* edit hint toast */
#dm-hint{
  position:fixed;left:50%;bottom:22px;transform:translateX(-50%) translateY(20px);z-index:9100;
  background:rgba(12,13,16,.94);border:1px solid var(--dm-line2);border-radius:8px;
  padding:11px 18px;font-family:var(--dm-font);font-size:12.5px;color:var(--dm-txt);
  box-shadow:0 16px 50px -18px rgba(0,0,0,.9);opacity:0;visibility:hidden;transition:.3s;
  display:flex;align-items:center;gap:10px;max-width:90vw;
}
#dm-hint.show{opacity:1;visibility:visible;transform:translateX(-50%) translateY(0)}
#dm-hint b{color:var(--dm-accent)}

/* ---------- Login gate ---------- */
#dm-login{
  position:fixed;inset:0;z-index:9500;display:none;align-items:center;justify-content:center;
  background:rgba(6,6,8,.82);backdrop-filter:blur(10px);font-family:var(--dm-font);padding:20px;
}
#dm-login.show{display:flex}
.dm-login-card{
  width:100%;max-width:380px;background:var(--dm-panel);border:1px solid var(--dm-line2);
  border-radius:12px;padding:34px 30px;box-shadow:0 40px 90px -30px rgba(0,0,0,.9);
  animation:dmpop .35s cubic-bezier(.16,1,.3,1);
}
@keyframes dmpop{from{opacity:0;transform:translateY(16px) scale(.98)}to{opacity:1;transform:none}}
.dm-login-card .dm-lock{width:48px;height:48px;border-radius:10px;display:grid;place-items:center;background:rgba(255,106,26,.12);color:var(--dm-accent);margin-bottom:18px}
.dm-login-card .dm-lock svg{width:24px;height:24px}
.dm-login-card h3{font-size:20px;font-weight:800;text-transform:uppercase;letter-spacing:-.01em;margin-bottom:6px;color:var(--dm-txt)}
.dm-login-card p{font-size:13.5px;color:var(--dm-mut);margin-bottom:22px;line-height:1.5}
.dm-field{margin-bottom:16px}
.dm-field label{display:block;font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:var(--dm-mut);font-weight:700;margin-bottom:7px}
.dm-input{
  width:100%;height:46px;padding:0 14px;background:#0d0e11;border:1px solid var(--dm-line2);
  border-radius:8px;color:var(--dm-txt);font-family:var(--dm-font);font-size:15px;transition:.2s;
}
textarea.dm-input{height:auto;padding:12px 14px;min-height:90px;resize:vertical;line-height:1.5}
.dm-input:focus{outline:none;border-color:var(--dm-accent);box-shadow:0 0 0 3px rgba(255,106,26,.16)}
.dm-input::placeholder{color:#5d5950}
.dm-login-err{font-size:12.5px;color:var(--dm-warn);margin-top:-6px;margin-bottom:12px;display:none}
.dm-login-err.show{display:block}
.dm-login-hint{margin-top:18px;font-size:11.5px;color:#5d5950;text-align:center;line-height:1.5}
.dm-login-hint code{color:var(--dm-accent2);background:rgba(192,133,90,.1);padding:1px 6px;border-radius:4px;font-family:ui-monospace,monospace}

/* ============================================================
   DASHBOARD (admin.html)
   ============================================================ */
.dm-app{min-height:100vh;display:grid;grid-template-columns:248px 1fr;background:#08090b}
.dm-side{
  position:sticky;top:0;height:100vh;background:var(--dm-panel);border-right:1px solid var(--dm-line);
  display:flex;flex-direction:column;padding:22px 16px;gap:6px;font-family:var(--dm-font);
}
.dm-side .dm-brand{display:flex;align-items:center;gap:11px;padding:6px 8px 20px;margin-bottom:8px;border-bottom:1px solid var(--dm-line)}
.dm-side .dm-brand img{width:40px;height:40px;border-radius:7px;border:1px solid var(--dm-line2);object-fit:cover}
.dm-side .dm-brand b{display:block;font-size:14px;font-weight:800;text-transform:uppercase;letter-spacing:.02em;color:var(--dm-txt)}
.dm-side .dm-brand span{font-size:10px;letter-spacing:.18em;text-transform:uppercase;color:var(--dm-mut)}
.dm-nav-item{
  display:flex;align-items:center;gap:12px;padding:11px 12px;border-radius:8px;cursor:pointer;
  font-size:13.5px;font-weight:600;color:var(--dm-mut);transition:.2s;border:1px solid transparent;text-align:left;width:100%;
}
.dm-nav-item:hover{color:var(--dm-txt);background:#1b1c21}
.dm-nav-item.active{color:var(--dm-txt);background:#1b1c21;border-color:var(--dm-line2)}
.dm-nav-item svg{width:18px;height:18px;flex:none}
.dm-nav-item .dm-badge{margin-left:auto;min-width:20px;height:20px;padding:0 6px;border-radius:10px;background:var(--dm-accent);color:#fff;font-size:11px;font-weight:800;display:inline-flex;align-items:center;justify-content:center}
.dm-nav-item .dm-badge[data-n="0"]{display:none}
.dm-side .dm-side-foot{margin-top:auto;display:flex;flex-direction:column;gap:8px;padding-top:16px;border-top:1px solid var(--dm-line)}

.dm-main{padding:30px clamp(20px,4vw,48px) 80px;font-family:var(--dm-font);color:var(--dm-txt);max-width:1100px}
.dm-page{display:none}
.dm-page.active{display:block}
@keyframes dmfade{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}
.dm-h{display:flex;align-items:flex-end;justify-content:space-between;gap:20px;flex-wrap:wrap;margin-bottom:26px}
.dm-h h1{font-size:30px;font-weight:800;text-transform:uppercase;letter-spacing:-.01em;line-height:1}
.dm-h p{font-size:14px;color:var(--dm-mut);margin-top:8px;max-width:62ch;line-height:1.55}
.dm-actions{display:flex;gap:10px;flex-wrap:wrap}

/* stat cards */
.dm-stats{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin-bottom:30px}
.dm-stat{background:var(--dm-panel);border:1px solid var(--dm-line);border-radius:10px;padding:20px}
.dm-stat b{font-size:34px;font-weight:900;line-height:1;display:block}
.dm-stat span{font-size:12px;letter-spacing:.06em;text-transform:uppercase;color:var(--dm-mut);margin-top:8px;display:block}
.dm-stat .dm-accent{color:var(--dm-accent)}
@media(max-width:760px){.dm-stats{grid-template-columns:1fr 1fr}}

.dm-card{background:var(--dm-panel);border:1px solid var(--dm-line);border-radius:10px;padding:22px;margin-bottom:18px}
.dm-card h3{font-size:16px;font-weight:800;text-transform:uppercase;letter-spacing:.01em;margin-bottom:6px}
.dm-card .dm-sub{font-size:13px;color:var(--dm-mut);margin-bottom:18px;line-height:1.5}
.dm-row{display:flex;gap:14px;flex-wrap:wrap}
.dm-grid2{display:grid;grid-template-columns:1fr 1fr;gap:14px}
@media(max-width:600px){.dm-grid2{grid-template-columns:1fr}}

/* quotes list */
.dm-quotes{display:flex;flex-direction:column;gap:10px}
.dm-quote{
  background:var(--dm-panel);border:1px solid var(--dm-line);border-radius:10px;overflow:hidden;transition:.2s;
}
.dm-quote.unread{border-left:3px solid var(--dm-accent)}
.dm-quote-head{display:flex;align-items:center;gap:14px;padding:16px 18px;cursor:pointer}
.dm-quote-head:hover{background:#1b1c21}
.dm-quote .dm-av{width:42px;height:42px;border-radius:50%;background:linear-gradient(135deg,#3a3c42,#23242a);display:grid;place-items:center;font-weight:800;font-size:14px;flex:none;color:#f4f1ea}
.dm-quote .dm-qmeta{flex:1;min-width:0}
.dm-quote .dm-qmeta b{font-size:15px;display:flex;align-items:center;gap:9px}
.dm-quote .dm-qmeta .dm-newdot{width:8px;height:8px;border-radius:50%;background:var(--dm-accent)}
.dm-quote .dm-qmeta span{font-size:12.5px;color:var(--dm-mut);display:block;margin-top:3px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.dm-tag{font-size:10.5px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;padding:4px 9px;border-radius:100px;border:1px solid var(--dm-line2);color:var(--dm-mut);white-space:nowrap}
.dm-tag.new{background:rgba(255,106,26,.14);color:var(--dm-accent);border-color:transparent}
.dm-tag.replied{background:rgba(54,179,126,.14);color:var(--dm-ok);border-color:transparent}
.dm-quote-time{font-size:12px;color:var(--dm-mut);white-space:nowrap}
.dm-quote-body{display:none;padding:0 18px 18px;border-top:1px solid var(--dm-line)}
.dm-quote.open .dm-quote-body{display:block}
.dm-qfields{display:grid;grid-template-columns:1fr 1fr;gap:12px 26px;margin:16px 0}
.dm-qfield label{font-size:10.5px;letter-spacing:.1em;text-transform:uppercase;color:var(--dm-mut);font-weight:700;display:block;margin-bottom:4px}
.dm-qfield p{font-size:14px;color:var(--dm-txt);word-break:break-word}
.dm-qfield.full{grid-column:1/-1}
.dm-qfield a{color:var(--dm-accent2)}
.dm-q-actions{display:flex;gap:9px;flex-wrap:wrap;margin-top:6px}
.dm-empty{text-align:center;padding:56px 20px;color:var(--dm-mut)}
.dm-empty svg{width:42px;height:42px;margin:0 auto 16px;opacity:.5}
.dm-empty b{display:block;font-size:16px;color:var(--dm-txt);margin-bottom:6px;text-transform:uppercase}
.dm-filter-tabs{display:flex;gap:8px;margin-bottom:18px;flex-wrap:wrap}
.dm-filter-tabs button{padding:8px 15px;border-radius:100px;border:1px solid var(--dm-line2);background:transparent;color:var(--dm-mut);font-family:var(--dm-font);font-size:12px;font-weight:700;letter-spacing:.04em;text-transform:uppercase;cursor:pointer;transition:.2s}
.dm-filter-tabs button:hover{color:var(--dm-txt)}
.dm-filter-tabs button.active{background:var(--dm-txt);color:#0c0d10;border-color:var(--dm-txt)}

/* photo manager */
.dm-photo-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:12px}
.dm-photo{position:relative;border-radius:9px;overflow:hidden;border:1px solid var(--dm-line);aspect-ratio:1;background:#0d0e11}
.dm-photo img{width:100%;height:100%;object-fit:cover}
.dm-photo .dm-photo-cat{position:absolute;top:8px;left:8px;font-size:9.5px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;padding:3px 8px;border-radius:100px;background:rgba(12,13,16,.8);color:#fff}
.dm-photo .dm-photo-x{position:absolute;top:7px;right:7px;width:28px;height:28px;border-radius:50%;background:rgba(12,13,16,.82);border:1px solid var(--dm-line2);color:#fff;display:grid;place-items:center;cursor:pointer;opacity:0;transition:.2s}
.dm-photo:hover .dm-photo-x{opacity:1}
.dm-photo .dm-photo-x:hover{background:var(--dm-warn);border-color:var(--dm-warn)}
.dm-photo .dm-photo-x svg{width:14px;height:14px}
.dm-photo .dm-photo-foot{position:absolute;left:0;right:0;bottom:0;padding:18px 10px 8px;font-size:11px;color:#fff;background:linear-gradient(transparent,rgba(0,0,0,.85))}
.dm-photo.dm-added{border-color:var(--dm-accent)}
.dm-photo .dm-newbadge{position:absolute;bottom:8px;right:8px;font-size:9px;font-weight:800;letter-spacing:.06em;text-transform:uppercase;padding:3px 7px;border-radius:4px;background:var(--dm-accent);color:#fff}

/* dropzone */
.dm-drop{border:2px dashed var(--dm-line2);border-radius:10px;padding:34px 20px;text-align:center;cursor:pointer;transition:.2s;background:#0d0e11}
.dm-drop:hover,.dm-drop.drag{border-color:var(--dm-accent);background:rgba(255,106,26,.05)}
.dm-drop svg{width:30px;height:30px;color:var(--dm-mut);margin:0 auto 12px}
.dm-drop b{display:block;font-size:14px;margin-bottom:4px}
.dm-drop span{font-size:12.5px;color:var(--dm-mut)}
.dm-preview{display:flex;align-items:center;gap:14px;margin-top:16px;padding:12px;border:1px solid var(--dm-line);border-radius:9px;display:none}
.dm-preview.show{display:flex}
.dm-preview img{width:64px;height:64px;border-radius:7px;object-fit:cover}

/* select / generic */
.dm-select{width:100%;height:46px;padding:0 14px;background:#0d0e11;border:1px solid var(--dm-line2);border-radius:8px;color:var(--dm-txt);font-family:var(--dm-font);font-size:14.5px;cursor:pointer}
.dm-select:focus{outline:none;border-color:var(--dm-accent)}

/* edit-pages launcher */
.dm-launch{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:14px}
.dm-launch a{display:flex;flex-direction:column;gap:4px;padding:18px;border:1px solid var(--dm-line);border-radius:10px;background:var(--dm-panel);transition:.2s;text-decoration:none;color:var(--dm-txt)}
.dm-launch a:hover{border-color:var(--dm-accent);transform:translateY(-2px)}
.dm-launch a b{font-size:15px;font-weight:800;text-transform:uppercase;display:flex;align-items:center;gap:8px}
.dm-launch a span{font-size:12.5px;color:var(--dm-mut);line-height:1.45}
.dm-launch a .dm-go{margin-top:8px;font-size:11px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--dm-accent);display:inline-flex;align-items:center;gap:6px}
.dm-launch svg{width:16px;height:16px}

.dm-toast{position:fixed;right:20px;bottom:20px;z-index:9600;background:var(--dm-panel);border:1px solid var(--dm-line2);border-left:3px solid var(--dm-ok);border-radius:9px;padding:14px 18px;font-family:var(--dm-font);font-size:13.5px;color:var(--dm-txt);box-shadow:0 20px 60px -20px rgba(0,0,0,.9);transform:translateY(20px);opacity:0;transition:.3s;display:flex;align-items:center;gap:10px}
.dm-toast.show{transform:none;opacity:1}
.dm-toast svg{width:18px;height:18px;color:var(--dm-ok)}
.dm-toast.warn{border-left-color:var(--dm-warn)}
.dm-toast.warn svg{color:var(--dm-warn)}

.dm-divider{height:1px;background:var(--dm-line);margin:8px 0 16px}

/* ---------- Appearance / colour picker ---------- */
.dm-swatch-row{display:flex;flex-wrap:wrap;gap:12px}
.dm-swatch{width:46px;height:46px;border-radius:50%;border:2px solid transparent;cursor:pointer;transition:.2s;position:relative;box-shadow:inset 0 0 0 1px rgba(255,255,255,.08)}
.dm-swatch:hover{transform:scale(1.08)}
.dm-swatch.on{border-color:var(--dm-txt);box-shadow:0 0 0 3px rgba(244,241,234,.15)}
.dm-swatch.on::after{content:"";position:absolute;inset:0;margin:auto;width:14px;height:14px;background:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='white' stroke-width='3.5' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='20 6 9 17 4 12'/%3E%3C/svg%3E") center/contain no-repeat;filter:drop-shadow(0 1px 2px rgba(0,0,0,.6))}
.dm-picker-row{display:flex;align-items:center;gap:12px;flex-wrap:wrap}
.dm-picker-row input[type=color]{width:52px;height:46px;padding:0;border:1px solid var(--dm-line2);border-radius:8px;background:#0d0e11;cursor:pointer}
.dm-picker-row input[type=color]::-webkit-color-swatch-wrapper{padding:4px}
.dm-picker-row input[type=color]::-webkit-color-swatch{border:none;border-radius:5px}

.dm-look-preview{border:1px solid var(--dm-line);border-radius:10px;padding:30px;background:linear-gradient(150deg,#15161b,#0a0b0d);overflow:hidden}
.dm-lp-eyebrow{font-size:11px;font-weight:700;letter-spacing:.28em;text-transform:uppercase;color:var(--spark);display:inline-block;margin-bottom:14px}
.dm-lp-h{font-family:'Archivo',sans-serif;font-weight:900;text-transform:uppercase;font-size:34px;line-height:1;letter-spacing:-.02em;color:#f4f1ea;margin-bottom:22px}
.dm-lp-spark{color:var(--spark)}
.dm-lp-btns{display:flex;gap:10px;flex-wrap:wrap;margin-bottom:20px}
.dm-lp-btn-spark{font-family:'Archivo',sans-serif;font-weight:700;font-size:11px;letter-spacing:.14em;text-transform:uppercase;padding:13px 20px;border-radius:3px;color:#fff;background:var(--grad-spark);box-shadow:0 8px 26px -8px var(--spark)}
.dm-lp-btn-ghost{font-family:'Archivo',sans-serif;font-weight:700;font-size:11px;letter-spacing:.14em;text-transform:uppercase;padding:13px 20px;border-radius:3px;color:#f4f1ea;background:transparent;border:1px solid rgba(244,241,234,.16)}
.dm-lp-link{font-family:'Archivo',sans-serif;font-weight:700;font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--spark)}
.dm-help{font-size:12.5px;color:var(--dm-mut);line-height:1.6;background:rgba(192,133,90,.06);border:1px solid rgba(192,133,90,.18);border-radius:9px;padding:14px 16px;margin-bottom:18px;display:flex;gap:11px}
.dm-help svg{width:18px;height:18px;color:var(--dm-accent2);flex:none;margin-top:1px}
.dm-help b{color:var(--dm-txt)}

@media(max-width:820px){
  .dm-app{grid-template-columns:1fr}
  .dm-side{position:fixed;left:0;top:0;bottom:0;width:248px;z-index:200;transform:translateX(-100%);transition:transform .3s}
  .dm-side.open{transform:none}
  .dm-mobile-top{display:flex!important}
}
.dm-mobile-top{display:none;align-items:center;gap:12px;padding:14px 18px;border-bottom:1px solid var(--dm-line);position:sticky;top:0;background:#08090b;z-index:100}
.dm-scrim{position:fixed;inset:0;background:rgba(0,0,0,.5);z-index:150;display:none}
.dm-scrim.show{display:block}

/* hide owner UI cleanly during print/screenshot of the site */
@media print{#dm-bar,#dm-login,#dm-hint,.dm-img-badge{display:none!important}body.dm-on{padding-top:0}body.dm-on .topbar{top:0}}
