/* =========================================================
   M.A.P — TOOL DECK  //  tools.css  (extends styles.css)
   ========================================================= */

/* ===== PAGE HEADER ===== */
.tools-hero {
  padding: 130px clamp(16px, 5vw, 64px) 30px;
  max-width: 1180px; margin: 0 auto;
}
.tools-hero__eyebrow { font-family: var(--font-mono); color: var(--cyan); font-size: 12px; letter-spacing: 2px; margin-bottom: 12px; }
.tools-hero h1 {
  font-family: var(--font-head); font-weight: 900; letter-spacing: 3px;
  font-size: clamp(34px, 7vw, 70px); color: var(--white); text-shadow: var(--glow); line-height: 1;
}
.tools-hero h1 .accent { color: transparent; -webkit-text-stroke: 1.5px var(--cyan); }
.tools-hero p { color: var(--text-dim); margin-top: 14px; font-family: var(--font-mono); font-size: 14px; }

/* search / filter */
.tools-search {
  display: flex; align-items: center; gap: 12px; margin-top: 24px;
  border: 1px solid var(--line); border-radius: 8px; background: var(--panel);
  padding: 12px 16px; max-width: 460px; backdrop-filter: blur(6px);
}
.tools-search span { color: var(--cyan); font-family: var(--font-mono); }
.tools-search input {
  flex: 1; background: none; border: none; outline: none;
  color: var(--white); font-family: var(--font-mono); font-size: 14px; letter-spacing: 1px;
}
.tools-search input::placeholder { color: var(--text-dim); }

/* ===== CATEGORY QUICK-NAV (sticky jump bar) ===== */
.cat-nav {
  position: sticky; top: 52px; z-index: 8000;
  background: linear-gradient(180deg, rgba(3,6,13,0.96), rgba(3,6,13,0.72));
  border-bottom: 1px solid var(--line);
  backdrop-filter: blur(10px);
}
.cat-nav__inner {
  display: flex; align-items: center; flex-wrap: wrap; gap: 8px;
  max-width: 1180px; margin: 0 auto;
  padding: 10px clamp(16px, 5vw, 64px);
}
.cat-chip {
  flex: 0 1 auto; display: inline-flex; align-items: center; gap: 7px;
  text-decoration: none; white-space: nowrap; cursor: pointer;
  font-family: var(--font-mono); font-size: 11px; letter-spacing: 1px;
  color: var(--text-dim); background: rgba(79,233,255,0.04);
  border: 1px solid var(--line); border-radius: 0 8px 0 8px;
  padding: 7px 11px;
  transition: color 0.2s ease, border-color 0.2s ease, box-shadow 0.2s ease, background 0.2s ease;
}
.cat-chip:hover { color: var(--white); border-color: var(--cyan); box-shadow: var(--glow); }
.cat-chip.active {
  color: #02080f; background: linear-gradient(90deg, var(--cyan), var(--teal));
  border-color: transparent; font-weight: 700;
}
.cat-chip__idx { color: var(--cyan-dim); }
.cat-chip.active .cat-chip__idx { color: rgba(2,8,15,0.55); }
.cat-chip__count {
  font-size: 9px; line-height: 1; color: var(--text-dim);
  border: 1px solid var(--line); border-radius: 999px; padding: 2px 6px;
}
.cat-chip.active .cat-chip__count { color: #02080f; border-color: rgba(2,8,15,0.35); }
.cat-chip--off { opacity: 0.35; pointer-events: none; }
/* On small screens the bar wraps to several rows — drop sticky so it doesn't eat the viewport */
@media (max-width: 719px) { .cat-nav { position: static; } }

/* ===== TOOL GRID ===== */
.tcat { padding: 30px clamp(16px, 5vw, 64px); max-width: 1180px; margin: 0 auto; scroll-margin-top: 128px; content-visibility: auto; contain-intrinsic-size: auto 700px; }
.tgrid { display: grid; grid-template-columns: repeat(auto-fill, minmax(240px, 1fr)); gap: 16px; }
.tcard {
  position: relative; display: block; text-align: left; cursor: pointer; text-decoration: none;
  border: 1px solid var(--line); border-radius: 0 8px 0 8px; background: var(--card);
  padding: 20px 18px; color: var(--text); width: 100%;
  transition: transform 0.2s ease, border-color 0.2s ease, box-shadow 0.2s ease;
  overflow: hidden; font-family: var(--font-body);
}
.tcard:active { transform: translateY(-1px) scale(0.99); }
.tcard::before {
  content: ""; position: absolute; top: 0; left: 0; right: 0; height: 1px;
  background: linear-gradient(90deg, transparent, var(--cyan), transparent);
  opacity: 0; transition: opacity 0.25s;
}
.tcard:hover { transform: translateY(-4px); border-color: var(--cyan); box-shadow: var(--glow); }
.tcard:hover::before { opacity: 1; }
.tcard__top { display: flex; align-items: center; justify-content: space-between; margin-bottom: 12px; }
.tcard__glyph {
  width: 44px; height: 44px; border-radius: 10px; display: flex; align-items: center; justify-content: center;
  font-family: var(--font-head); font-weight: 700; font-size: 18px; color: var(--cyan);
  border: 1px solid var(--line); background: rgba(79,233,255,0.05); text-shadow: var(--glow);
}
.tcard__id { font-family: var(--font-mono); font-size: 11px; color: var(--text-dim); }
.tcard__name { font-family: var(--font-head); font-weight: 700; color: var(--white); font-size: 15px; letter-spacing: 0.5px; }
.tcard__desc { color: var(--text-dim); font-size: 13px; margin-top: 6px; line-height: 1.4; }
.tcard__open { margin-top: 14px; font-family: var(--font-mono); font-size: 11px; letter-spacing: 1.5px; color: var(--cyan); }
.tcard.hidden { display: none; }

.tcat__empty { color: var(--text-dim); font-family: var(--font-mono); padding: 40px 0; text-align: center; display: none; }

/* ===== SINGLE TOOL PAGE ===== */
.tool-page { padding: 110px clamp(16px, 5vw, 64px) 60px; max-width: 900px; margin: 0 auto; }
.tool-back { display: inline-block; font-family: var(--font-mono); font-size: 12px; letter-spacing: 1.5px; color: var(--text-dim); text-decoration: none; margin-bottom: 18px; transition: color 0.2s ease; }
.tool-back:hover { color: var(--cyan); text-shadow: var(--glow); }
.tool-head { display: flex; align-items: center; gap: 18px; margin-bottom: 22px; }
.tool-head__glyph {
  width: 60px; height: 60px; flex-shrink: 0; border-radius: 12px; display: flex; align-items: center; justify-content: center;
  font-family: var(--font-head); font-weight: 700; font-size: 24px; color: var(--cyan);
  border: 1px solid var(--cyan); background: rgba(79,233,255,0.06); text-shadow: var(--glow); box-shadow: var(--glow);
}
.tool-head__name { font-family: var(--font-head); font-weight: 900; letter-spacing: 2px; font-size: clamp(22px, 4vw, 38px); color: var(--white); text-shadow: var(--glow); line-height: 1; }
.tool-head__desc { font-family: var(--font-mono); font-size: 13px; color: var(--text-dim); margin-top: 6px; }
.tool-head__status {
  display: inline-flex; align-items: center; gap: 7px; margin-top: 9px;
  font-family: var(--font-mono); font-size: 10px; letter-spacing: 1.5px; color: var(--teal);
}
.tool-head__status .dot { width: 7px; height: 7px; }
.tool-mount { padding: clamp(20px, 3vw, 32px); border-radius: 0 8px 0 8px; } /* brackets at TL + BR */

/* ===== MODAL / CONSOLE WINDOW ===== */
.modal {
  position: fixed; inset: 0; z-index: 9500;
  display: none; align-items: flex-start; justify-content: center;
  background: rgba(2,5,11,0.72); backdrop-filter: blur(4px);
  padding: 80px 16px 40px; overflow-y: auto;
}
.modal.open { display: flex; }
.modal__win {
  position: relative; width: min(820px, 100%);
  border: 1px solid var(--cyan); border-radius: 10px; background: var(--panel-2);
  box-shadow: 0 0 50px rgba(79,233,255,0.25); animation: winIn 0.28s cubic-bezier(.2,.8,.2,1);
}
@keyframes winIn { from { opacity: 0; transform: translateY(20px) scale(0.98); } to { opacity: 1; transform: none; } }
.modal__head {
  display: flex; align-items: center; gap: 12px;
  padding: 14px 18px; border-bottom: 1px solid var(--line);
  background: linear-gradient(180deg, rgba(79,233,255,0.06), transparent);
}
.modal__dots { display: flex; gap: 6px; }
.modal__dots i { width: 10px; height: 10px; border-radius: 50%; background: var(--line); }
.modal__dots i:first-child { background: var(--magenta); }
.modal__dots i:nth-child(2) { background: var(--amber); }
.modal__dots i:nth-child(3) { background: var(--teal); }
.modal__title { font-family: var(--font-head); font-weight: 700; color: var(--white); letter-spacing: 1px; font-size: 15px; }
.modal__tag { font-family: var(--font-mono); font-size: 11px; color: var(--cyan); margin-left: auto; }
.modal__close {
  background: none; border: 1px solid var(--line); color: var(--cyan);
  width: 40px; height: 40px; border-radius: 6px; cursor: pointer; font-size: 18px; line-height: 1;
  display: flex; align-items: center; justify-content: center;
  transition: border-color 0.2s ease, box-shadow 0.2s ease, color 0.2s ease;
}
.modal__close:hover { border-color: var(--cyan); box-shadow: var(--glow); }
.modal__body { padding: 22px; }

/* ===== SHARED TOOL CONTROLS ===== */
.field { margin-bottom: 16px; }
.field > label, .lbl {
  display: block; font-family: var(--font-mono); font-size: 11px; letter-spacing: 1.5px;
  color: var(--text-dim); margin-bottom: 7px; text-transform: uppercase;
}
.input, .textarea, select.input {
  width: 100%; background: rgba(3,10,18,0.7); border: 1px solid var(--line); border-radius: 6px;
  color: var(--white); font-family: var(--font-mono); font-size: 14px; padding: 11px 13px; outline: none;
  transition: border-color 0.2s ease, box-shadow 0.2s ease;
}
.input:focus, .textarea:focus, select.input:focus { border-color: var(--cyan); box-shadow: var(--glow); }
.textarea { resize: vertical; min-height: 120px; line-height: 1.5; }
select.input { cursor: pointer; appearance: none; background-image: linear-gradient(45deg, transparent 50%, var(--cyan) 50%), linear-gradient(135deg, var(--cyan) 50%, transparent 50%); background-position: calc(100% - 18px) center, calc(100% - 13px) center; background-size: 5px 5px, 5px 5px; background-repeat: no-repeat; padding-right: 36px; }

.row { display: flex; gap: 12px; flex-wrap: wrap; align-items: flex-end; }
.row > * { flex: 1; min-width: 0; }
.row--btns { align-items: center; }
.grow0 { flex: 0 0 auto; }

.btn--sm { padding: 9px 14px; font-size: 12px; }
.btn-group { display: flex; flex-wrap: wrap; gap: 8px; }
.btn.active { border-color: var(--cyan); color: var(--white); box-shadow: var(--glow); background: rgba(79,233,255,0.1); }

input[type="range"] { -webkit-appearance: none; appearance: none; width: 100%; height: 6px; border-radius: 4px; background: rgba(79,233,255,0.12); outline: none; }
input[type="range"]::-webkit-slider-thumb { -webkit-appearance: none; width: 16px; height: 16px; border-radius: 50%; background: var(--cyan); box-shadow: var(--glow); cursor: pointer; }
input[type="range"]::-moz-range-thumb { width: 16px; height: 16px; border: none; border-radius: 50%; background: var(--cyan); box-shadow: var(--glow); cursor: pointer; }

.check { display: inline-flex; align-items: center; gap: 8px; font-family: var(--font-mono); font-size: 12px; color: var(--text); cursor: pointer; letter-spacing: 1px; }
.check input { accent-color: var(--cyan); width: 16px; height: 16px; cursor: pointer; }

.out {
  background: rgba(3,10,18,0.85); border: 1px solid var(--line); border-radius: 6px;
  color: var(--teal); font-family: var(--font-mono); font-size: 13px; padding: 13px;
  white-space: pre-wrap; word-break: break-word; min-height: 44px; line-height: 1.5;
}
.out--big { min-height: 110px; max-height: 320px; overflow: auto; }
.out--err { color: var(--magenta); border-color: rgba(255,77,157,0.4); }

.muted { font-family: var(--font-mono); font-size: 11px; color: var(--text-dim); letter-spacing: 0.5px; }
.muted a { color: var(--cyan); }
.note { font-family: var(--font-mono); font-size: 11px; color: var(--amber); letter-spacing: 0.5px; margin-top: 6px; }

.statline { display: flex; flex-wrap: wrap; gap: 10px; margin-top: 14px; }
.statbox { flex: 1; min-width: 90px; border: 1px solid var(--line); border-radius: 6px; padding: 12px; text-align: center; background: rgba(79,233,255,0.03); }
.statbox b { display: block; font-family: var(--font-head); font-weight: 900; color: var(--cyan); font-size: 24px; text-shadow: var(--glow); }
.statbox span { display: block; font-family: var(--font-mono); font-size: 10px; color: var(--text-dim); letter-spacing: 1px; margin-top: 4px; }

/* drop zone */
.drop {
  border: 1px dashed var(--line); border-radius: 8px; padding: 28px; text-align: center;
  background: rgba(79,233,255,0.03); cursor: pointer; transition: all 0.2s ease;
  font-family: var(--font-mono); color: var(--text-dim); font-size: 13px;
}
.drop:hover, .drop.drag { border-color: var(--cyan); color: var(--cyan); box-shadow: var(--glow); }
.drop b { color: var(--cyan); }

.preview-img { max-width: 100%; max-height: 280px; border-radius: 6px; border: 1px solid var(--line); margin-top: 6px; display: block; }
.imgwrap { display: grid; grid-template-columns: 1fr 1fr; gap: 14px; margin-top: 14px; }
.imgwrap figure { margin: 0; }
.imgwrap figcaption { font-family: var(--font-mono); font-size: 10px; color: var(--text-dim); letter-spacing: 1px; margin-bottom: 6px; }
.checker { background-image: linear-gradient(45deg, #1a2733 25%, transparent 25%), linear-gradient(-45deg, #1a2733 25%, transparent 25%), linear-gradient(45deg, transparent 75%, #1a2733 75%), linear-gradient(-45deg, transparent 75%, #1a2733 75%); background-size: 16px 16px; background-position: 0 0, 0 8px, 8px -8px, -8px 0; }

.swatch { width: 100%; height: 90px; border-radius: 8px; border: 1px solid var(--line); }

.svg-preview { display: flex; align-items: center; justify-content: center; border: 1px solid var(--line); border-radius: 8px; padding: 18px; margin-top: 6px; min-height: 240px; overflow: hidden; }
.svg-preview svg { max-width: 100%; max-height: 320px; transition: transform 0.15s ease; }
.svg-preview.icon-stage svg { width: 220px; height: 220px; }
.svg-preview.bg-dark { background: #04121c; background-image: none; }
.svg-preview.bg-light { background: #cfe0ea; background-image: none; }
.svg-preview.bg-white { background: #ffffff; background-image: none; }

/* ===== ADVANCED TOOL CONTROLS ===== */
.ctrl-sec { font-family: var(--font-mono); font-size: 11px; letter-spacing: 2px; color: var(--cyan); margin: 20px 0 12px; padding-bottom: 6px; border-bottom: 1px solid var(--line); }
.ctrl-sec:first-child { margin-top: 0; }
input[type="color"].cinput { width: 100%; height: 40px; background: none; border: 1px solid var(--line); border-radius: 6px; cursor: pointer; padding: 2px; }
.icon-picker { display: grid; grid-template-columns: repeat(auto-fill, minmax(44px, 1fr)); gap: 8px; max-height: 184px; overflow: auto; border: 1px solid var(--line); border-radius: 8px; padding: 10px; background: rgba(3,10,18,0.4); }
.icon-picker button { aspect-ratio: 1; display: flex; align-items: center; justify-content: center; background: rgba(79,233,255,0.04); border: 1px solid var(--line); border-radius: 6px; cursor: pointer; padding: 7px; color: var(--cyan); transition: all 0.15s ease; }
.icon-picker button:hover { border-color: var(--cyan); }
.icon-picker button.active { border-color: var(--cyan); box-shadow: var(--glow); background: rgba(79,233,255,0.12); }
.icon-picker button svg { width: 100%; height: 100%; display: block; pointer-events: none; }
.svg-toolbar { display: flex; flex-wrap: wrap; gap: 8px; margin-bottom: 12px; align-items: center; }
.pill-row { display: flex; flex-wrap: wrap; gap: 6px; }
.mini { font-family: var(--font-mono); font-size: 11px; color: var(--text-dim); letter-spacing: 1px; }
.mini.ok { color: var(--teal); }
.mini.bad { color: var(--magenta); }
.canvas-fit { max-width: 100%; max-height: 280px; border-radius: 6px; border: 1px solid var(--line); display: block; }
.field--inline { display: flex; align-items: center; gap: 10px; }
.field--inline label { margin: 0; white-space: nowrap; }
.qr-out { display: flex; justify-content: center; padding: 18px; background: #eafaff; border-radius: 8px; margin-top: 6px; }
.qr-out img, .qr-out canvas { display: block; }

mark { background: var(--cyan); color: #02060d; border-radius: 2px; padding: 0 1px; }

/* markdown preview */
.md-prev { color: var(--text); font-family: var(--font-body); }
.md-prev h1, .md-prev h2, .md-prev h3 { font-family: var(--font-head); color: var(--white); margin: 12px 0 8px; }
.md-prev h1 { font-size: 24px; } .md-prev h2 { font-size: 20px; } .md-prev h3 { font-size: 17px; }
.md-prev p { margin: 8px 0; } .md-prev ul, .md-prev ol { margin: 8px 0 8px 22px; }
.md-prev code { font-family: var(--font-mono); background: rgba(79,233,255,0.1); color: var(--teal); padding: 1px 5px; border-radius: 4px; font-size: 13px; }
.md-prev pre { background: rgba(3,10,18,0.85); border: 1px solid var(--line); border-radius: 6px; padding: 12px; overflow: auto; margin: 8px 0; }
.md-prev pre code { background: none; padding: 0; }
.md-prev a { color: var(--cyan); }
.md-prev blockquote { border-left: 2px solid var(--cyan); padding-left: 12px; color: var(--text-dim); margin: 8px 0; }
.md-prev img { max-width: 100%; border-radius: 6px; }
.md-prev hr { border: none; border-top: 1px solid var(--line); margin: 14px 0; }

/* toast */
.toast-wrap { position: fixed; bottom: 24px; left: 50%; transform: translateX(-50%); z-index: 99999; display: flex; flex-direction: column; gap: 8px; align-items: center; }
.toast {
  font-family: var(--font-mono); font-size: 13px; letter-spacing: 1px; color: #02080f;
  background: linear-gradient(90deg, var(--cyan), var(--teal)); padding: 10px 18px; border-radius: 6px;
  box-shadow: 0 0 26px rgba(79,233,255,0.5); animation: toastIn 0.25s ease, toastOut 0.3s ease 2.2s forwards;
}
@keyframes toastIn { from { opacity: 0; transform: translateY(14px); } to { opacity: 1; transform: none; } }
@keyframes toastOut { to { opacity: 0; transform: translateY(14px); } }

@media (max-width: 620px) {
  .imgwrap { grid-template-columns: 1fr; }
  .modal { padding-top: 70px; }
}

@media (max-width: 719px) {
  .tools-search,
  .cat-nav,
  .modal {
    backdrop-filter: none;
  }

  .tcard:hover::before {
    opacity: 0;
  }

  .toast {
    animation: none;
  }
}
