/* ToolPry v5.0 — Global Styles with Light/Dark Theme */
*{margin:0;padding:0;box-sizing:border-box}

/* Dark theme (default) */
:root{
  --bg:#0a0a0b;--s:#141416;--s2:#1c1c1f;--b:#2a2a2e;
  --t:#e4e4e7;--t2:#a1a1aa;--t3:#71717a;
  --a:#22d3ee;--a2:#06b6d4;
  --err:#ef4444;--ok:#22c55e;--warn:#eab308;
  --fm:'IBM Plex Mono',monospace;--fs:'DM Sans',sans-serif;
  --shadow:0 1px 3px rgba(0,0,0,.3)
}

/* Light theme */
[data-theme="light"]{
  --bg:#fafafa;--s:#ffffff;--s2:#f4f4f5;--b:#e4e4e7;
  --t:#18181b;--t2:#52525b;--t3:#a1a1aa;
  --a:#0891b2;--a2:#0e7490;
  --shadow:0 1px 3px rgba(0,0,0,.08)
}

@media(prefers-color-scheme:light){
  :root:not([data-theme="dark"]){
    --bg:#fafafa;--s:#ffffff;--s2:#f4f4f5;--b:#e4e4e7;
    --t:#18181b;--t2:#52525b;--t3:#a1a1aa;
    --a:#0891b2;--a2:#0e7490;
    --shadow:0 1px 3px rgba(0,0,0,.08)
  }
}

body{font-family:var(--fs);background:var(--bg);color:var(--t);min-height:100vh;line-height:1.6;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;transition:background .2s,color .2s}
a{color:var(--a);text-decoration:none}

/* Layout */
.c{max-width:900px;margin:0 auto;padding:0 20px}

/* Nav */
header{padding:16px 0;border-bottom:1px solid var(--b)}
nav{display:flex;align-items:center;justify-content:space-between}
.logo-link,.logo-link:visited{display:flex;align-items:center;gap:10px;text-decoration:none;color:inherit}
.logo-icon{width:20px;height:20px}
.logo-text{font-family:var(--fm);font-size:14px;font-weight:700;letter-spacing:.06em;text-transform:uppercase}
.logo-text .t{color:var(--t)}.logo-text .a{color:var(--a)}
.nl{display:flex;gap:20px;align-items:center}
.nl a,.nl a:visited{font-size:13px;color:var(--t2);text-decoration:none;transition:color .15s}
.nl a:hover{color:var(--t)}
.theme-btn{background:none;border:1px solid var(--b);border-radius:6px;padding:5px 8px;cursor:pointer;color:var(--t2);font-size:14px;line-height:1;transition:all .15s}
.theme-btn:hover{border-color:var(--a);color:var(--a)}

/* Hero */
.hero{padding:40px 0 20px;text-align:center}
.hero h1{font-size:clamp(24px,5vw,36px);font-weight:700;margin-bottom:10px}
.hero h1 em{font-style:normal;color:var(--a)}
.hero p{font-size:15px;color:var(--t2);max-width:500px;margin:0 auto}

/* Buttons */
.btn{font-family:var(--fs);font-size:13px;font-weight:600;padding:8px 16px;border-radius:8px;border:1px solid var(--b);background:var(--s2);color:var(--t);cursor:pointer;transition:all .15s}
.btn:hover{border-color:var(--a);color:var(--a)}
.btn.p{background:var(--a);color:#fff;border-color:var(--a)}
.btn.p:hover{background:var(--a2)}
.btn.on{background:var(--a)!important;color:#fff!important;border-color:var(--a)!important}
.acts{display:flex;gap:8px;justify-content:center;margin:20px 0;flex-wrap:wrap}
.tbr{display:flex;gap:6px;align-items:center;flex-wrap:wrap;margin:0 0 16px;justify-content:center}
.tbr-label{font-family:var(--fm);font-size:10px;color:var(--t2);letter-spacing:.08em;text-transform:uppercase}

/* Panels */
.panels{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-bottom:24px}
@media(max-width:700px){.panels{grid-template-columns:1fr}}
.pnl{background:var(--s);border:1px solid var(--b);border-radius:12px;overflow:hidden;display:flex;flex-direction:column;box-shadow:var(--shadow)}
.ph{padding:10px 16px;border-bottom:1px solid var(--b);background:var(--s2);font-family:var(--fm);font-size:11px;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:var(--t2);display:flex;justify-content:space-between;align-items:center}
textarea{width:100%;min-height:250px;padding:16px;background:transparent;border:none;color:var(--t);font-family:var(--fm);font-size:13px;line-height:1.7;resize:vertical;outline:none}
textarea::placeholder{color:var(--t3)}
.outa{width:100%;min-height:250px;padding:16px;font-family:var(--fm);font-size:13px;line-height:1.7;overflow:auto;white-space:pre-wrap;word-break:break-all}
input[type=text],input[type=number]{width:100%;padding:10px 14px;background:var(--s);border:1px solid var(--b);border-radius:8px;color:var(--t);font-family:var(--fm);font-size:13px;outline:none;transition:border-color .15s}
input[type=text]:focus,input[type=number]:focus{border-color:var(--a)}
select{padding:8px 12px;background:var(--s2);border:1px solid var(--b);border-radius:8px;color:var(--t);font-size:13px;outline:none}
input[type=range]{width:100%;accent-color:var(--a)}

/* Status */
.st{padding:8px 16px;border-top:1px solid var(--b);font-family:var(--fm);font-size:11px;display:flex;align-items:center;gap:6px}
.dot{width:6px;height:6px;border-radius:50%;display:inline-block}
.dot.ok{background:var(--ok)}.dot.err{background:var(--err)}.dot.e{background:var(--t3)}
.msg{color:var(--t2)}.msg.ok{color:var(--ok)}.msg.err{color:var(--err)}

/* Syntax highlighting */
.sk{color:var(--a)}.ss{color:#a78bfa}.sn{color:#f59e0b}.sb{color:#f472b6}.sl{color:#64748b}.sp{color:var(--t2)}

/* Tree view */
.tv-node{padding:1px 0 1px 16px;font-family:var(--fm);font-size:13px;line-height:1.5}
.tv-toggle{cursor:pointer;display:inline-block;width:14px;color:var(--t2);font-size:10px}
.tv-key{cursor:pointer;border-radius:3px;padding:0 2px}
.tv-key:hover{background:rgba(34,211,238,.15)}
.tv-children{margin-left:4px}
.tv-count{font-size:10px;color:var(--t2);margin-left:4px}
.collapsed .tv-children{display:none}
.collapsed .tv-toggle{transform:rotate(-90deg)}

/* Regex */
.regex-input{display:flex;align-items:center;padding:12px 16px;gap:8px}
.regex-input span{color:var(--t2);font-family:var(--fm);font-size:18px}
.regex-input input{flex:1;background:transparent;border:none;color:var(--t);font-family:var(--fm);font-size:15px;outline:none;width:auto}
.flags{display:flex;gap:6px}
.flag{padding:4px 10px;border-radius:6px;border:1px solid var(--b);background:var(--s2);color:var(--t2);font-family:var(--fm);font-size:12px;cursor:pointer;transition:all .15s}
.flag.on{background:var(--a);color:#fff;border-color:var(--a)}
mark{background:rgba(34,211,238,.2);color:var(--a);border-radius:3px;padding:1px 2px}

/* Password */
.pw-display{background:var(--s);border:1px solid var(--b);border-radius:12px;padding:24px;text-align:center;margin-bottom:16px;box-shadow:var(--shadow)}
.pw-output{font-family:var(--fm);font-size:18px;word-break:break-all;line-height:1.6;margin-bottom:12px;min-height:28px}

/* Stats */
.stats{display:grid;grid-template-columns:repeat(auto-fill,minmax(120px,1fr));gap:12px;margin-bottom:24px}
.stat-card{background:var(--s);border:1px solid var(--b);border-radius:8px;padding:12px;text-align:center;box-shadow:var(--shadow)}
.stat-val{font-family:var(--fm);font-size:20px;font-weight:700;color:var(--a)}
.stat-label{font-size:11px;color:var(--t2);margin-top:4px}

/* Color */
.color-preview{width:100%;height:80px;border-radius:8px;border:1px solid var(--b);margin-bottom:16px}

/* Content */
.cnt{padding:40px 0;border-top:1px solid var(--b)}
.cnt h2{font-size:22px;font-weight:700;margin-bottom:14px}
.cnt h3{font-size:17px;font-weight:600;margin:20px 0 8px;color:var(--a)}
.cnt p{font-size:14px;color:var(--t2);margin-bottom:10px;max-width:700px}

/* Related */
.related{padding:24px 0;border-top:1px solid var(--b)}
.related h3{font-size:15px;font-weight:600;margin-bottom:12px}
.tags{display:flex;gap:8px;flex-wrap:wrap}
.tags a{font-size:12px;padding:8px 14px;background:var(--s);border:1px solid var(--b);border-radius:8px;color:var(--t2);text-decoration:none;transition:all .15s}
.tags a:hover{border-color:var(--a);color:var(--a)}

/* Ad (non-intrusive, bottom only) */
.ad-bottom{margin:24px 0;text-align:center;min-height:90px}

/* Footer */
footer{padding:24px 0;border-top:1px solid var(--b);text-align:center}
footer p{font-size:12px;color:var(--t3)}
footer a{color:var(--t2);text-decoration:none;margin:0 8px}
.fl{display:flex;gap:16px;justify-content:center;margin-bottom:8px;flex-wrap:wrap;font-size:12px}

/* Hidden */
.tool-metadata{display:none!important}

/* Animations */
@keyframes fadeUp{from{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}
.hero,.pnl,.acts,.pw-display{animation:fadeUp .4s ease-out}

/* Markdown preview */
#preview h1{font-size:24px;margin:0 0 12px}#preview h2{font-size:20px;margin:16px 0 8px;color:var(--a)}#preview h3{font-size:16px;margin:12px 0 6px}#preview p{margin:0 0 10px;color:var(--t2)}#preview ul,#preview ol{margin:0 0 10px;padding-left:20px;color:var(--t2)}#preview blockquote{border-left:3px solid var(--a);padding:8px 16px;margin:0 0 10px;color:var(--t2)}#preview code{background:var(--s2);padding:2px 6px;border-radius:4px;font-family:var(--fm);font-size:12px}#preview pre{background:var(--s2);padding:12px;border-radius:8px;overflow:auto;margin:0 0 10px}#preview pre code{background:none;padding:0}#preview a{color:var(--a)}
