/* =====================================================================
   Luvrix Tools — Public CSS (Enterprise design system)
   Full-page tool layout, per-category accents, professional palette.
   ===================================================================== */

:root{
  --lte-ink:#0b1020;
  --lte-ink-soft:#384058;
  --lte-muted:#6b7388;
  --lte-line:rgba(15,23,42,.10);
  --lte-line-2:rgba(15,23,42,.06);
  --lte-bg-soft:#f6f7fb;
  --lte-card:#ffffff;
  --lte-card-2:#f9fafc;
  --lte-shadow:0 1px 0 rgba(255,255,255,.7) inset, 0 12px 30px -12px rgba(15,23,42,.18), 0 4px 10px -4px rgba(15,23,42,.08);
  --lte-shadow-sm:0 1px 2px rgba(15,23,42,.06), 0 4px 12px -6px rgba(15,23,42,.08);
  --lte-radius:18px;
  --lte-radius-sm:12px;
  --lte-radius-lg:24px;
  --lte-grad:linear-gradient(135deg,var(--lte-accent,#0a84ff),var(--lte-accent-2,#5e5ce6));
  --lte-success:#16a34a; --lte-warn:#f59e0b; --lte-danger:#ef4444;
}
@media (prefers-color-scheme: dark){
  :root{
    --lte-ink:#f3f5fb;
    --lte-ink-soft:#c7cce0;
    --lte-muted:#8a93ad;
    --lte-line:rgba(255,255,255,.10);
    --lte-line-2:rgba(255,255,255,.05);
    --lte-bg-soft:#0e1220;
    --lte-card:#171b2c;
    --lte-card-2:#1d2236;
    --lte-shadow:0 1px 0 rgba(255,255,255,.05) inset, 0 18px 40px -16px rgba(0,0,0,.6), 0 6px 14px -6px rgba(0,0,0,.4);
    --lte-shadow-sm:0 1px 2px rgba(0,0,0,.4), 0 6px 16px -8px rgba(0,0,0,.5);
  }
}

/* Per-category accent — set on .lte-tool-page wrapper */
.lte-cat-calculator-tools{ --lte-accent:#0a84ff; --lte-accent-2:#0066cc; --lte-accent-soft:rgba(10,132,255,.10); }
.lte-cat-pdf-tools       { --lte-accent:#e0254a; --lte-accent-2:#b21e3a; --lte-accent-soft:rgba(224,37,74,.10); }
.lte-cat-image-tools     { --lte-accent:#7a3fdc; --lte-accent-2:#5b2eaa; --lte-accent-soft:rgba(122,63,220,.10); }
.lte-cat-text-tools      { --lte-accent:#0e9f6e; --lte-accent-2:#0a7a55; --lte-accent-soft:rgba(14,159,110,.10); }
.lte-cat-utility-tools   { --lte-accent:#d97706; --lte-accent-2:#a25908; --lte-accent-soft:rgba(217,119,6,.10); }
.lte-cat-security-tools  { --lte-accent:#0891b2; --lte-accent-2:#076f88; --lte-accent-soft:rgba(8,145,178,.10); }

/* ===== FULL-PAGE TOOL LAYOUT ===== */
.lte-tool-page{ display:block; padding:0; }
.lte-wide{ max-width:1320px; margin:0 auto; padding:0 28px; position:relative; }

.lte-tool-hero{
  position:relative; padding:64px 0 44px;
  background:linear-gradient(180deg, var(--lte-accent-soft) 0%, transparent 100%);
  border-bottom:1px solid var(--lte-line);
}
.lte-tool-hero::before{
  content:""; position:absolute; inset:0; pointer-events:none;
  background:radial-gradient(900px 360px at 80% 0%, var(--lte-accent-soft), transparent 60%);
}
.lte-hero-row{ display:flex; gap:24px; align-items:center; flex-wrap:wrap; }
.lte-hero-icon{
  width:78px; height:78px; border-radius:22px; display:grid; place-items:center;
  font-size:38px; color:#fff; background:var(--lte-grad);
  box-shadow:0 1px 0 rgba(255,255,255,.4) inset, 0 18px 40px -10px var(--lte-accent);
  flex:0 0 auto;
}
.lte-hero-text{ flex:1; min-width:260px; }
.lte-cat-pill{
  display:inline-block; padding:5px 12px; border-radius:999px; font-size:12.5px;
  font-weight:600; letter-spacing:.02em; color:var(--lte-accent-2);
  background:var(--lte-accent-soft); margin-bottom:10px;
}
.lte-tool-page h1{
  font-size:clamp(2rem,4vw,3rem); margin:0 0 8px; letter-spacing:-.025em;
  color:var(--lte-ink); font-weight:800; line-height:1.05;
}
.lte-hero-sub{ color:var(--lte-ink-soft); font-size:17px; margin:0; max-width:780px; line-height:1.5; }

/* Workspace grid: share rail + main */
.lte-tool-workspace{ padding:36px 0 64px; }
.lte-tool-workspace .lte-wide{
  display:grid; grid-template-columns:56px 1fr; gap:24px; align-items:start;
}
.lte-share-rail{
  position:sticky; top:90px; display:flex; flex-direction:column; gap:6px;
  padding:8px 6px; border-radius:999px; width:48px; align-self:start;
  background:var(--lte-card); border:1px solid var(--lte-line); box-shadow:var(--lte-shadow-sm);
}
.lte-share-rail a, .lte-share-rail .lte-copy{
  display:grid; place-items:center; width:36px; height:36px; border-radius:50%;
  color:var(--lte-ink-soft); text-decoration:none; font-weight:700; font-size:14px;
  background:transparent; border:0; cursor:pointer; transition:all .2s ease;
}
.lte-share-rail a:hover, .lte-share-rail .lte-copy:hover{ background:var(--lte-accent-soft); color:var(--lte-accent-2); }

.lte-workspace{ min-width:0; display:flex; flex-direction:column; gap:18px; }
.lte-tool-stage{
  background:var(--lte-card); border:1px solid var(--lte-line); border-radius:var(--lte-radius-lg);
  padding:32px; box-shadow:var(--lte-shadow); position:relative; overflow:hidden;
}
.lte-tool-stage::before{
  content:""; position:absolute; inset:0 0 auto 0; height:3px; background:var(--lte-grad);
}
.lte-privacy{
  display:inline-flex; align-items:center; gap:8px; padding:8px 14px; border-radius:999px;
  background:var(--lte-accent-soft); color:var(--lte-accent-2); font-size:13px; font-weight:500;
  width:fit-content; margin:0;
}

@media (max-width:900px){
  .lte-tool-workspace .lte-wide{ grid-template-columns:1fr; }
  .lte-share-rail{ flex-direction:row; width:auto; align-self:auto; position:static; padding:6px 8px; }
  .lte-tool-stage{ padding:22px; border-radius:18px; }
  .lte-tool-hero{ padding:44px 0 32px; }
  .lte-hero-icon{ width:62px; height:62px; font-size:28px; border-radius:18px; }
}

/* Info / FAQ / Related */
.lte-tool-info{ background:var(--lte-bg-soft); padding:64px 0; border-top:1px solid var(--lte-line); }
.lte-info-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:24px; }
.lte-info-block{ background:var(--lte-card); border:1px solid var(--lte-line); border-radius:var(--lte-radius); padding:24px; box-shadow:var(--lte-shadow-sm); }
.lte-info-block h2{ font-size:18px; margin:0 0 8px; color:var(--lte-ink); letter-spacing:-.01em; }
.lte-info-block p, .lte-info-block li{ color:var(--lte-ink-soft); font-size:14.5px; line-height:1.6; }
.lte-info-block ul{ margin:0; padding-left:18px; }
.lte-faq{ border-bottom:1px solid var(--lte-line-2); padding:10px 0; }
.lte-faq:last-child{ border-bottom:0; }
.lte-faq summary{ cursor:pointer; font-weight:600; color:var(--lte-ink); list-style:none; display:flex; justify-content:space-between; align-items:center; }
.lte-faq summary::-webkit-details-marker{ display:none; }
.lte-faq summary::after{ content:"+"; font-size:18px; color:var(--lte-muted); }
.lte-faq[open] summary::after{ content:"−"; color:var(--lte-accent); }
.lte-faq p{ margin:8px 0 0; color:var(--lte-ink-soft); font-size:14px; }
@media (max-width:900px){ .lte-info-grid{ grid-template-columns:1fr; } }

.lte-tool-related{ padding:64px 0 96px; }
.lte-tool-related h2{ font-size:24px; margin:0 0 18px; color:var(--lte-ink); }
.lte-related-grid{ display:grid; grid-template-columns:repeat(auto-fill,minmax(180px,1fr)); gap:14px; }
.lte-related-card{
  display:flex; flex-direction:column; gap:10px; align-items:flex-start;
  padding:18px; border-radius:var(--lte-radius); text-decoration:none;
  background:var(--lte-card); border:1px solid var(--lte-line); color:var(--lte-ink);
  transition:transform .25s ease, box-shadow .25s ease, border-color .25s ease;
}
.lte-related-card:hover{ transform:translateY(-3px); box-shadow:var(--lte-shadow); border-color:var(--lte-accent); }
.lte-related-icon{
  width:42px; height:42px; border-radius:12px; display:grid; place-items:center; font-size:20px;
  background:var(--lte-accent-soft); color:var(--lte-accent-2);
}
.lte-related-title{ font-weight:600; font-size:14.5px; }

/* ===== TOOL UI BUILDING BLOCKS ===== */
.qte-tool{ display:flex; flex-direction:column; gap:18px; }
.qte-tool h3{ margin:0; color:var(--lte-ink); font-size:16px; font-weight:600; }

/* Inputs */
.qte-tool input[type=text],
.qte-tool input[type=number],
.qte-tool input[type=date],
.qte-tool input[type=email],
.qte-tool input[type=url],
.qte-tool select,
.qte-tool textarea{
  width:100%; padding:12px 14px; border:1px solid var(--lte-line); border-radius:var(--lte-radius-sm);
  background:var(--lte-card-2); color:var(--lte-ink); outline:none; font:inherit; font-size:15px;
  transition:border-color .15s, box-shadow .15s, background .15s;
}
.qte-tool textarea{ resize:vertical; min-height:160px; line-height:1.6; font-family:inherit; }
.qte-tool input:focus,.qte-tool select:focus,.qte-tool textarea:focus{
  border-color:var(--lte-accent);
  box-shadow:0 0 0 4px var(--lte-accent-soft);
  background:var(--lte-card);
}
.qte-form{ display:grid; grid-template-columns:repeat(auto-fit,minmax(200px,1fr)); gap:14px; align-items:end; }
.qte-form label{ display:flex; flex-direction:column; gap:6px; font-weight:600; color:var(--lte-ink-soft); font-size:13px; letter-spacing:.01em; }
.qte-form-row{ display:flex; gap:10px; flex-wrap:wrap; align-items:end; }
.qte-form-row label{ flex:1; min-width:140px; }
.qte-check{ display:inline-flex !important; flex-direction:row !important; align-items:center; gap:8px; min-width:0 !important; }
.qte-tool input[type=range]{ accent-color:var(--lte-accent); }

/* Primary button */
.qte-btn-primary{
  display:inline-flex; align-items:center; justify-content:center; gap:8px;
  padding:13px 26px; border-radius:999px; border:0; cursor:pointer;
  font-weight:600; font-size:15px; color:#fff; background:var(--lte-grad);
  text-decoration:none; letter-spacing:-.005em;
  box-shadow:0 1px 0 rgba(255,255,255,.25) inset, 0 -1px 0 rgba(0,0,0,.12) inset, 0 12px 28px -8px var(--lte-accent);
  transition:transform .2s ease, box-shadow .2s ease;
  align-self:flex-start;
}
.qte-btn-primary:hover{ transform:translateY(-1px); color:#fff; box-shadow:0 1px 0 rgba(255,255,255,.3) inset, 0 -1px 0 rgba(0,0,0,.15) inset, 0 18px 36px -8px var(--lte-accent); }
.qte-btn-primary:active{ transform:translateY(0); }
.qte-btn-secondary{
  display:inline-flex; align-items:center; gap:6px; padding:10px 18px; border-radius:999px;
  background:var(--lte-card-2); border:1px solid var(--lte-line); color:var(--lte-ink);
  cursor:pointer; font-weight:500; font-size:14px; text-decoration:none; transition:all .2s ease;
}
.qte-btn-secondary:hover{ border-color:var(--lte-accent); color:var(--lte-accent-2); background:var(--lte-accent-soft); }
.qte-btn-danger{ background:transparent; border:1px solid var(--lte-line); color:var(--lte-danger); padding:6px 10px; border-radius:8px; font-size:12.5px; cursor:pointer; }
.qte-btn-danger:hover{ background:rgba(239,68,68,.10); }

/* Toggle */
.qte-toggle{ display:inline-flex; padding:4px; border-radius:999px; background:var(--lte-card-2); border:1px solid var(--lte-line); width:fit-content; }
.qte-toggle button{ padding:8px 18px; border-radius:999px; border:0; background:transparent; cursor:pointer; font-weight:500; font-size:13px; color:var(--lte-ink-soft); }
.qte-toggle button.active{ background:var(--lte-card); color:var(--lte-accent-2); box-shadow:var(--lte-shadow-sm); }

/* Result panels */
.qte-result{ min-height:1px; min-width:0; }
.qte-result:empty{ display:none; }
.qte-stat{
	background:var(--lte-card-2); border:1px solid var(--lte-line); border-radius:var(--lte-radius-sm);
	padding:18px; display:flex; flex-direction:column; gap:6px; min-width:0; overflow:hidden;
}
.qte-stat span{ font-size:11.5px; text-transform:uppercase; letter-spacing:.1em; color:var(--lte-muted); font-weight:600; }
.qte-stat strong{
	font-size:clamp(14px,2.4vw,24px); font-weight:700; color:var(--lte-ink); letter-spacing:-.02em;
	font-variant-numeric:tabular-nums;
	word-break:break-all; overflow-wrap:anywhere; line-height:1.15;
}

/* Drop / file UI */
.qte-drop{
  position:relative; padding:38px 22px; border:2px dashed var(--lte-line);
  border-radius:var(--lte-radius); text-align:center; cursor:pointer; background:var(--lte-card-2);
  transition:border-color .2s, background .2s;
}
.qte-drop:hover, .qte-drop.over{
  border-color:var(--lte-accent); background:var(--lte-accent-soft);
}
.qte-drop input[type=file]{ position:absolute; inset:0; opacity:0; cursor:pointer; z-index:2; }
.qte-drop-icon{ font-size:38px; display:block; margin-bottom:8px; }
.qte-drop p{ margin:0; color:var(--lte-ink-soft); font-weight:500; }
.qte-drop small{ color:var(--lte-muted); display:block; margin-top:4px; }

/* Notes */
.qte-note{ padding:12px 16px; border-radius:var(--lte-radius-sm); background:var(--lte-accent-soft); color:var(--lte-accent-2); font-size:14px; border:1px solid var(--lte-line); }

/* Calculator-specific (redesigned) */
.qte-calc{ display:grid; grid-template-columns:1fr; gap:14px; max-width:420px; margin:0 auto; padding:18px; background:var(--lte-card); border:1px solid var(--lte-line); border-radius:calc(var(--lte-radius) + 6px); box-shadow:var(--lte-shadow-sm); }
.qte-calc-screen{
  display:flex; flex-direction:column; justify-content:flex-end; gap:4px;
  min-height:120px; padding:18px 20px;
  background:linear-gradient(180deg, var(--lte-card-2) 0%, color-mix(in srgb, var(--lte-card-2) 80%, var(--lte-accent) 5%) 100%);
  border:1px solid var(--lte-line); border-radius:var(--lte-radius); overflow:hidden;
}
.qte-calc-expr{ font-size:14px; color:var(--lte-muted); text-align:right; min-height:18px; font-variant-numeric:tabular-nums; word-break:break-all; line-height:1.2; }
.qte-calc-display{
  font-size:clamp(28px,5.5vw,42px); font-weight:600; text-align:right;
  font-variant-numeric:tabular-nums; word-break:break-all; line-height:1.1;
  color:var(--lte-ink); letter-spacing:-.02em;
}
.qte-calc-keys{ display:grid; grid-template-columns:repeat(4,1fr); gap:10px; }
.qte-key{
  padding:0; height:60px; border-radius:14px; border:1px solid var(--lte-line);
  cursor:pointer; font-size:20px; font-weight:500; background:var(--lte-card-2);
  color:var(--lte-ink); transition:transform .12s ease, background .12s ease, box-shadow .12s ease;
  display:inline-flex; align-items:center; justify-content:center;
}
.qte-key:hover{ background:var(--lte-card); transform:translateY(-1px); box-shadow:var(--lte-shadow-sm); }
.qte-key:active{ transform:translateY(0) scale(.97); }
.qte-key-num{ background:var(--lte-card); }
.qte-key-num.wide{ grid-column:span 2; justify-content:flex-start; padding-left:26px; }
.qte-key-func{ background:color-mix(in srgb, var(--lte-card-2) 60%, var(--lte-accent) 8%); color:var(--lte-ink-soft); font-weight:600; }
.qte-key-op{ background:color-mix(in srgb, var(--lte-accent) 14%, var(--lte-card-2)); color:var(--lte-accent-2); font-weight:700; font-size:22px; }
.qte-key-op:hover{ background:color-mix(in srgb, var(--lte-accent) 22%, var(--lte-card-2)); }
.qte-key-equals{ background:var(--lte-grad); color:#fff; border-color:transparent; font-weight:700; box-shadow:0 8px 20px -8px var(--lte-accent); }
.qte-key-equals:hover{ color:#fff; box-shadow:0 12px 26px -8px var(--lte-accent); }
.qte-calc-history{ display:flex; flex-direction:column; gap:6px; max-height:120px; overflow:auto; padding:0 4px; }
.qte-calc-history:empty{ display:none; }
.qte-calc-h-item{ display:flex; justify-content:space-between; gap:10px; font-size:12.5px; color:var(--lte-muted); padding:6px 10px; border-radius:8px; background:var(--lte-card-2); }
.qte-calc-h-item strong{ color:var(--lte-ink); font-weight:600; font-variant-numeric:tabular-nums; }

/* Calculator-style two-column layout (inputs left, result right) */
.qte-split{
  display:grid; grid-template-columns:minmax(0,1fr) minmax(0,1fr); gap:24px; align-items:stretch;
}
.qte-split .qte-side{ display:flex; flex-direction:column; gap:14px; }
.qte-split .qte-side.result{
  background:var(--lte-card-2); border:1px solid var(--lte-line); border-radius:var(--lte-radius);
  padding:24px; min-height:200px;
}
.qte-split .qte-side.result h3{ font-size:13px; text-transform:uppercase; letter-spacing:.1em; color:var(--lte-muted); margin-bottom:8px; }
@media (max-width:760px){ .qte-split{ grid-template-columns:1fr; } }

/* PDF merge — responsive grid of file cards (4–5 per row) with drag-reorder */
.lte-pdf-list{
	display:grid; gap:14px; padding:0; margin:0; list-style:none;
	grid-template-columns:repeat(auto-fill,minmax(170px,1fr));
}
.lte-pdf-list:empty{ display:none; }
.lte-pdf-item{
	position:relative; display:flex; flex-direction:column; gap:8px;
	padding:12px; border:1px solid var(--lte-line); border-radius:var(--lte-radius-sm);
	background:var(--lte-card); cursor:grab; transition:all .2s ease; user-select:none;
}
.lte-pdf-item:hover{ border-color:var(--lte-accent); box-shadow:var(--lte-shadow-sm); transform:translateY(-2px); }
.lte-pdf-item.dragging{ opacity:.4; cursor:grabbing; transform:scale(.96); }
.lte-pdf-item.drag-over{ border-color:var(--lte-accent); border-style:dashed; background:var(--lte-accent-soft); }
.lte-pdf-handle{ display:none; }
.lte-pdf-thumb{
	width:100%; aspect-ratio:1/1.2; border-radius:8px; overflow:hidden;
	background:var(--lte-card-2); border:1px solid var(--lte-line); display:grid; place-items:center;
}
.lte-pdf-thumb canvas, .lte-pdf-thumb img{ width:100%; height:100%; object-fit:cover; }
.lte-pdf-meta{ display:flex; flex-direction:column; gap:2px; min-width:0; }
.lte-pdf-name{ font-weight:600; color:var(--lte-ink); font-size:13px; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.lte-pdf-info{ font-size:11.5px; color:var(--lte-muted); }
.lte-pdf-pos{
	position:absolute; top:8px; left:8px;
	display:inline-flex; align-items:center; justify-content:center;
	width:26px; height:26px; border-radius:50%; background:var(--lte-grad);
	color:#fff; font-size:12px; font-weight:700;
	box-shadow:0 4px 10px -2px var(--lte-accent); z-index:2;
}
.lte-pdf-item .qte-btn-danger{
	position:absolute; top:8px; right:8px; z-index:2;
	padding:4px 8px; font-size:11px; background:rgba(255,255,255,.92); backdrop-filter:blur(8px);
	opacity:0; transition:opacity .2s ease;
}
.lte-pdf-item:hover .qte-btn-danger{ opacity:1; }
@media (max-width:600px){ .lte-pdf-list{ grid-template-columns:repeat(2,1fr); } }

/* Image preview (compressor / resizer) */
.lte-img-preview{
  display:grid; grid-template-columns:1fr 1fr; gap:18px; align-items:start;
}
.lte-img-preview > div{
  background:var(--lte-card-2); border:1px solid var(--lte-line); border-radius:var(--lte-radius);
  padding:14px; display:flex; flex-direction:column; gap:8px;
}
.lte-img-preview h4{ margin:0; font-size:12px; text-transform:uppercase; letter-spacing:.1em; color:var(--lte-muted); }
.lte-img-preview img{ width:100%; max-height:340px; object-fit:contain; border-radius:10px; background:repeating-conic-gradient(#dadde6 0 25%, transparent 0 50%) 50% / 16px 16px; }
@media (max-width:680px){ .lte-img-preview{ grid-template-columns:1fr; } }

/* QR / Barcode preview centered */
.lte-preview-center{
  display:flex; align-items:center; justify-content:center; padding:30px;
  background:var(--lte-card-2); border:1px solid var(--lte-line); border-radius:var(--lte-radius);
  min-height:280px;
}
.lte-preview-center canvas, .lte-preview-center svg, .lte-preview-center img{ max-width:100%; height:auto; }

/* Password strength bar */
.lte-pw-display{
  display:flex; align-items:center; gap:10px; padding:14px 16px;
  background:var(--lte-card-2); border:1px solid var(--lte-line); border-radius:var(--lte-radius-sm);
  font-family:ui-monospace,SFMono-Regular,Menlo,monospace; font-size:18px; font-weight:600; color:var(--lte-ink);
  word-break:break-all;
}
.lte-pw-strength{ height:6px; border-radius:999px; background:var(--lte-line); overflow:hidden; }
.lte-pw-strength > span{ display:block; height:100%; transition:width .3s, background .3s; }

/* Range slider value chip */
.qte-range-row{ display:flex; align-items:center; gap:14px; }
.qte-range-row input[type=range]{ flex:1; }
.qte-range-val{
  min-width:64px; text-align:center; padding:6px 10px; border-radius:8px;
  background:var(--lte-card-2); border:1px solid var(--lte-line); font-weight:600; font-size:13px;
  font-variant-numeric:tabular-nums; color:var(--lte-ink);
}

/* Code/output block */
.lte-code-out{
  padding:16px; border-radius:var(--lte-radius-sm); background:var(--lte-card-2);
  border:1px solid var(--lte-line); font-family:ui-monospace,SFMono-Regular,Menlo,monospace;
  font-size:14px; color:var(--lte-ink); white-space:pre-wrap; word-break:break-word;
}

/* Word counter stats grid */
.qte-stats{ display:grid; grid-template-columns:repeat(auto-fit,minmax(140px,1fr)); gap:12px; }

/* Ad slot */
.qte-ad-wrap{ margin:8px 0; min-height:90px; }
.qte-ad-wrap:empty{ display:none; }

/* === Hide blog-specific cruft if it sneaks in on tool pages === */
.lte-tool-page .lx-share, .lte-tool-page .lx-author-card,
.lte-tool-page .lx-article-meta, .lte-tool-page .lx-toc,
.lte-tool-page .lx-comments, .lte-tool-page .lx-tags,
.lte-tool-page .lx-article-head, .lte-tool-page .lx-related{ display:none !important; }

/* === Specificity bumps to override aggressive theme styles === */
.lte-tool-page .qte-tool input[type=text],
.lte-tool-page .qte-tool input[type=number],
.lte-tool-page .qte-tool input[type=date],
.lte-tool-page .qte-tool input[type=email],
.lte-tool-page .qte-tool input[type=url],
.lte-tool-page .qte-tool input[type=password],
.lte-tool-page .qte-tool input[type=search],
.lte-tool-page .qte-tool select,
.lte-tool-page .qte-tool textarea{
	width:100% !important; padding:12px 14px !important; border:1px solid var(--lte-line) !important;
	border-radius:var(--lte-radius-sm) !important; background:var(--lte-card-2) !important;
	color:var(--lte-ink) !important; font:inherit !important; font-size:15px !important;
	box-shadow:none !important; outline:none !important;
}
.lte-tool-page .qte-tool .qte-btn-primary{ color:#fff !important; }
.lte-tool-page .qte-split{ display:grid !important; grid-template-columns:minmax(0,1fr) minmax(0,1fr) !important; gap:24px !important; }
@media (max-width:760px){ .lte-tool-page .qte-split{ grid-template-columns:1fr !important; } }
.lte-tool-page .qte-form{ display:grid !important; grid-template-columns:repeat(auto-fit,minmax(200px,1fr)) !important; gap:14px !important; }
.lte-tool-page .qte-form label{ display:flex !important; flex-direction:column !important; gap:6px !important; }
.lte-tool-page .qte-stats{ display:grid !important; grid-template-columns:repeat(auto-fit,minmax(140px,1fr)) !important; gap:12px !important; }
.lte-tool-page .lte-share-rail{ flex-direction:column !important; }
@media (max-width:900px){ .lte-tool-page .lte-share-rail{ flex-direction:row !important; } }

/* ===== MEGAMENU (lives in theme nav) ===== */
.lx-mega-trigger{ position:relative !important; }
.lx-mega-trigger > a{ cursor:default; }
/* defeat the theme's default .sub-menu positioning so the megamenu can show */
.lx-menu .lx-mega-trigger > .sub-menu{ display:none !important; }
.lx-megamenu{
	position:absolute; top:calc(100% + 12px); left:50%; transform:translateX(-50%) translateY(8px);
	width:min(960px,90vw); padding:24px; border-radius:20px;
	background:#ffffff; color:#0b1020;
	border:1px solid rgba(15,23,42,.10);
	box-shadow:0 30px 80px -20px rgba(15,23,42,.35), 0 8px 24px -8px rgba(15,23,42,.18);
	opacity:0; visibility:hidden; pointer-events:none; transition:all .25s ease; z-index:1000;
}
@media (prefers-color-scheme: dark){
	.lx-megamenu{ background:#171b2c; color:#f3f5fb; border-color:rgba(255,255,255,.08); }
}
.lx-mega-trigger:hover > .lx-megamenu,
.lx-mega-trigger:focus-within > .lx-megamenu,
.lx-mega-trigger.open > .lx-megamenu{ opacity:1 !important; visibility:visible !important; pointer-events:auto !important; transform:translateX(-50%) translateY(0) !important; }
.lx-mega-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:20px; }
.lx-mega-col h4{ margin:0 0 10px; font-size:12px; font-weight:700; text-transform:uppercase; letter-spacing:.08em; color:rgba(0,0,0,.55); display:flex; align-items:center; gap:8px; }
@media (prefers-color-scheme: dark){ .lx-mega-col h4{ color:rgba(255,255,255,.55); } }
.lx-mega-col h4 .lx-mega-dot{ width:8px; height:8px; border-radius:50%; background:var(--cat-color,#0a84ff); }
.lx-mega-col ul{ list-style:none; padding:0; margin:0; display:flex; flex-direction:column; gap:2px; }
.lx-mega-col a{ display:flex; align-items:center; gap:8px; padding:8px 10px; border-radius:10px; color:inherit; font-size:14px; text-decoration:none; transition:all .15s ease; }
.lx-mega-col a:hover{ background:var(--cat-soft,rgba(10,132,255,.10)); color:var(--cat-color,#0a84ff); }
.lx-mega-col a .lx-mega-ico{ font-size:16px; }
.lx-mega-foot{ margin-top:18px; padding-top:14px; border-top:1px solid rgba(15,23,42,.08); display:flex; justify-content:space-between; align-items:center; font-size:13px; opacity:.7; }
.lx-mega-foot a{ color:#0a84ff; font-weight:600; text-decoration:none; opacity:1; }
@media (max-width:900px){ .lx-megamenu{ display:none; } }

/* ===== TOOLS INDEX (full directory page) ===== */
/* ===== TOOLS INDEX (enterprise directory page) ===== */
.lte-index{ padding:8px 0 80px; }
.lte-index-controls{
	display:flex; flex-direction:column; gap:18px; margin:0 0 36px;
	padding:24px; border-radius:20px;
	background:linear-gradient(135deg, rgba(10,132,255,.06), rgba(94,92,230,.06));
	border:1px solid var(--lte-line);
	backdrop-filter:blur(12px);
}
.lte-index-search{ position:relative; max-width:680px; }
.lte-index-search > span{ position:absolute; left:20px; top:50%; transform:translateY(-50%); color:var(--lte-muted); font-size:18px; pointer-events:none; }
.lte-index-search input{
	width:100%; padding:16px 20px 16px 52px; border:1px solid var(--lte-line);
	border-radius:14px; background:var(--lte-card); color:var(--lte-ink);
	font-size:15px; box-shadow:var(--lte-shadow-sm); outline:none; transition:all .2s ease;
	font-weight:500; letter-spacing:-.005em;
}
.lte-index-search input::placeholder{ color:var(--lte-muted); font-weight:400; }
.lte-index-search input:focus{ border-color:var(--lte-accent,#0a84ff); box-shadow:0 0 0 4px var(--lte-accent-soft,rgba(10,132,255,.10)); }
.lte-index-filters{ display:flex; flex-wrap:wrap; gap:8px; }
.lte-filter-pill{
	display:inline-flex; align-items:center; gap:8px; padding:9px 16px; border-radius:10px;
	border:1px solid var(--lte-line); background:var(--lte-card); color:var(--lte-ink-soft);
	font-weight:600; font-size:13.5px; cursor:pointer; transition:all .18s ease;
	letter-spacing:-.005em;
}
.lte-filter-pill:hover{ border-color:var(--lte-accent,#0a84ff); color:var(--lte-accent-2,#0066cc); transform:translateY(-1px); }
.lte-filter-pill.active{ background:var(--lte-grad,linear-gradient(135deg,#0a84ff,#5e5ce6)); color:#fff; border-color:transparent; box-shadow:0 8px 22px -8px var(--lte-accent,#0a84ff); }
.lte-pill-count{ font-size:11.5px; padding:2px 8px; border-radius:999px; background:rgba(15,23,42,.08); font-weight:700; line-height:1.4; }
.lte-filter-pill.active .lte-pill-count{ background:rgba(255,255,255,.22); color:#fff; }

.lte-index-grid{
	display:grid; grid-template-columns:repeat(auto-fill,minmax(280px,1fr)); gap:16px;
}
.lte-idx-card{
	position:relative; display:flex; align-items:flex-start; gap:16px;
	padding:22px; border-radius:16px; text-decoration:none;
	background:var(--lte-card); border:1px solid var(--lte-line); color:var(--lte-ink);
	transition:transform .25s ease, box-shadow .25s ease, border-color .25s ease;
	overflow:hidden; min-height:120px;
}
.lte-idx-card::before{
	content:""; position:absolute; inset:0 0 auto 0; height:3px;
	background:var(--cat-color, var(--lte-grad,linear-gradient(135deg,#0a84ff,#5e5ce6)));
	opacity:0; transition:opacity .25s ease;
}
.lte-idx-card:hover{
	transform:translateY(-4px);
	box-shadow:0 24px 48px -16px rgba(15,23,42,.18), 0 8px 16px -8px rgba(15,23,42,.12);
	border-color:transparent; color:var(--lte-ink);
}
.lte-idx-card:hover::before{ opacity:1; }
.lte-idx-icon{
	flex:0 0 auto; width:52px; height:52px; border-radius:14px; display:grid; place-items:center;
	font-size:26px; background:var(--cat-soft, var(--lte-accent-soft));
	color:var(--cat-color, var(--lte-accent-2));
	transition:transform .25s ease;
}
.lte-idx-card:hover .lte-idx-icon{ transform:scale(1.06) rotate(-3deg); }
.lte-idx-body{ display:flex; flex-direction:column; gap:6px; min-width:0; flex:1; }
.lte-idx-cat{
	font-size:10.5px; font-weight:700; text-transform:uppercase; letter-spacing:.1em;
	color:var(--cat-color, var(--lte-accent-2));
	display:inline-flex; align-items:center; gap:6px;
}
.lte-idx-cat::before{ content:""; width:6px; height:6px; border-radius:50%; background:currentColor; opacity:.6; }
.lte-idx-title{ font-weight:700; font-size:16px; color:var(--lte-ink); letter-spacing:-.015em; line-height:1.3; }
.lte-idx-desc{ font-size:13px; color:var(--lte-muted); line-height:1.5; }
.lte-idx-arrow{
	color:var(--lte-muted); font-size:18px; align-self:center; flex:0 0 auto;
	transition:transform .25s ease, color .25s ease;
}
.lte-idx-card:hover .lte-idx-arrow{ color:var(--cat-color, var(--lte-accent)); transform:translateX(6px); }
.lte-index-empty{ text-align:center; padding:60px 20px; color:var(--lte-muted); font-size:15px; border:1px dashed var(--lte-line); border-radius:16px; }

/* Per-category accent variables on cards */
.lte-cat-calculator-tools{ --cat-color:#0a84ff; --cat-soft:rgba(10,132,255,.10); }
.lte-cat-pdf-tools{ --cat-color:#e0254a; --cat-soft:rgba(224,37,74,.10); }
.lte-cat-image-tools{ --cat-color:#7a3fdc; --cat-soft:rgba(122,63,220,.10); }
.lte-cat-text-tools{ --cat-color:#0e9f6e; --cat-soft:rgba(14,159,110,.10); }
.lte-cat-utility-tools{ --cat-color:#d97706; --cat-soft:rgba(217,119,6,.10); }
.lte-cat-security-tools{ --cat-color:#0891b2; --cat-soft:rgba(8,145,178,.10); }

@media (max-width:600px){
	.lte-index-grid{ grid-template-columns:1fr; }
	.lte-index-controls{ padding:18px; }
}

/* ===== Tool page extra content blocks (auto-injected) ===== */
.lte-tool-extra{ padding:48px 0; background:var(--lte-card); border-top:1px solid var(--lte-line); }
.lte-tool-extra h2{ font-size:26px; margin:0 0 12px; color:var(--lte-ink); letter-spacing:-.015em; }
.lte-tool-extra p{ color:var(--lte-ink-soft); font-size:15.5px; line-height:1.7; max-width:760px; margin:0 0 14px; }
.lte-tool-extra ul{ color:var(--lte-ink-soft); font-size:15px; line-height:1.8; padding-left:22px; max-width:760px; }
.lte-tool-extra .lte-feat-grid{ display:grid; grid-template-columns:repeat(auto-fit,minmax(220px,1fr)); gap:16px; margin-top:18px; }
.lte-tool-extra .lte-feat{ background:var(--lte-card-2); border:1px solid var(--lte-line); border-radius:var(--lte-radius); padding:18px; }
.lte-tool-extra .lte-feat h3{ margin:0 0 6px; font-size:15px; color:var(--lte-ink); }
.lte-tool-extra .lte-feat p{ margin:0; font-size:13.5px; }
.lte-tool-extra .lte-feat-ico{ display:inline-grid; place-items:center; width:34px; height:34px; border-radius:10px; background:var(--lte-accent-soft); color:var(--lte-accent-2); font-size:18px; margin-bottom:8px; }
