/* MapleSec Toolkit — Animal Crossing inspired theme (animal-island-vue design tokens) */
/* 动森手指光标 — 复用自 AnimalIslandNewTab / animal-island-ui (force 模式) */
*,*::before,*::after{cursor:url('cursor-icon.png') 4 0, default !important}
/* 输入控件保留 text 光标，便于编辑 */
input[type="text"],input[type="search"],input[type="number"],input[type="password"],
input[type="email"],input[type="url"],input[type="tel"],textarea{cursor:text !important}

:root{
  --primary:#19c8b9;--primary-hover:#3dd4c6;--primary-active:#11a89b;--primary-bg:#e6f9f6;
  --text:#794f27;--text-body:#725d42;--text-secondary:#9f927d;--text-muted:#8a7b66;--text-disabled:#c4b89e;
  --bg:#f8f8f0;--bg-content:rgb(247,243,223);--bg-disabled:#f0ece2;
  --border:#c4b89e;--border-hover:#a89878;--border-strong:#9f927d;
  --success:#6fba2c;--warning:#f5c31c;--error:#e05a5a;
  --focus-yellow:#ffcc00;--shadow-btn:#bdaea0;--shadow-input:#d4c9b4;--shadow-mint:#11a89b;--shadow-red:#c94444;
  --r-sm:12px;--r-base:18px;--r-lg:24px;--r-pill:50px;
  /* aliases for legacy refs */
  --sf:var(--bg-content);--bd:var(--border);--tx:var(--text-body);--tx2:var(--text-secondary);
  --ac:var(--primary);--gn:var(--success);--rd:var(--error);--or:var(--warning);--pu:#b08bd6;
  --mf:'Cascadia Code','Fira Code','JetBrains Mono',Consolas,monospace;
  --ease:cubic-bezier(0.4,0,0.2,1);
}
*{box-sizing:border-box;margin:0;padding:0}
body{font-family:'Nunito','Noto Sans SC',-apple-system,'PingFang SC',sans-serif;background:var(--bg);color:var(--text-body);min-height:100vh;overflow-x:hidden;font-weight:500;letter-spacing:.01em}
header{background:var(--bg-content);border-bottom:2px solid var(--border);padding:.6rem 1.2rem;display:flex;align-items:center;justify-content:space-between;position:sticky;top:0;z-index:100;flex-wrap:wrap;gap:.4rem;box-shadow:0 2px 0 0 var(--border)}
.logo{font-size:1.15rem;font-weight:800;white-space:nowrap;color:var(--text);letter-spacing:.02em}
.logo em{color:var(--primary);font-style:normal}
nav{display:flex;gap:4px;flex-wrap:wrap}
nav button{background:none;border:2px solid transparent;color:var(--text-secondary);padding:.35rem .7rem;border-radius:var(--r-pill);cursor:pointer;font-size:.78rem;white-space:nowrap;font-family:inherit;font-weight:600;transition:all .15s var(--ease);letter-spacing:.02em}
nav button:hover{color:var(--primary);background:var(--primary-bg)}
nav button.on{color:var(--primary-active);background:var(--primary-bg);border-color:var(--primary)}
main{padding:1.2rem;max-width:1400px;margin:0 auto}
.pane{display:none}.pane.on{display:block}
.g2{display:grid;grid-template-columns:1fr 1fr;gap:1.2rem}
@media(max-width:900px){.g2{grid-template-columns:1fr}}
.crd{background:var(--bg-content);border:2px solid var(--border);border-radius:var(--r-base);padding:1rem;margin-bottom:1rem;transition:transform .2s var(--ease)}
.crd-t{font-size:.82rem;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.05em;margin-bottom:.8rem;font-weight:700;display:flex;align-items:center;justify-content:space-between;gap:.5rem}
textarea,input{font-family:var(--mf);font-size:.8rem;font-weight:500}
textarea{width:100%;background:var(--bg-content);border:2px solid var(--border);border-radius:var(--r-sm);color:var(--text-body);padding:.65rem;resize:vertical;min-height:100px;display:block}
input{background:var(--bg-content);border:2px solid var(--border);border-radius:var(--r-pill);color:var(--text-body);padding:.45rem .8rem;font-weight:500}
input:focus,textarea:focus,select:focus{outline:none;border-color:var(--focus-yellow);box-shadow:0 0 0 3px rgba(255,204,0,.15)}
.inp-w{width:180px}.inp-s{width:130px}.inp-xs{width:80px}.inp-m{width:200px}
.b{background:var(--primary);color:#fff;border:2px solid var(--primary);padding:.45rem .9rem;border-radius:var(--r-pill);cursor:pointer;font-size:.78rem;font-weight:700;font-family:inherit;letter-spacing:.02em;box-shadow:0 5px 0 0 var(--shadow-mint);transition:all .15s var(--ease);line-height:1}
.b:hover{background:var(--primary-hover);transform:translateY(-1px);box-shadow:0 6px 0 0 var(--shadow-mint)}
.b:active{background:var(--primary-active);transform:translateY(3px);box-shadow:0 2px 0 0 var(--shadow-mint)}
.bs{padding:.3rem .65rem;font-size:.72px;font-size:.74rem;background:var(--bg);border:2px solid var(--border);color:var(--text-body);box-shadow:0 2px 4px 0 rgba(61,52,40,.06)}
.bs:hover{color:var(--primary);border-color:var(--primary);background:var(--bg);box-shadow:0 3px 10px 0 rgba(61,52,40,.10);transform:translateY(-1px)}
.bs:active{transform:translateY(0)}
.bd{background:var(--error);border-color:var(--error);color:#fff;box-shadow:0 5px 0 0 var(--shadow-red)}
.bd:hover{background:#e87070;border-color:#e87070;box-shadow:0 6px 0 0 var(--shadow-red)}
.bo{background:var(--warning);border-color:var(--warning);color:var(--text);box-shadow:0 5px 0 0 #dba90e}
.br{display:flex;gap:.4rem;margin-top:.5rem;flex-wrap:wrap;align-items:center}
select{background:var(--bg-content);border:2px solid var(--border);border-radius:var(--r-pill);color:var(--text-body);padding:.35rem .6rem;font-size:.8rem;font-family:var(--mf);cursor:pointer;font-weight:500}
.ob{background:var(--bg);border:2px solid var(--border);border-radius:var(--r-sm);padding:.65rem;font-family:var(--mf);font-size:.8rem;word-break:break-all;max-height:350px;overflow-y:auto;white-space:pre-wrap;color:var(--text-body)}
.ob:empty::before{content:'输出将显示在这里...';color:var(--text-muted)}
.badge{display:inline-block;padding:.12rem .45rem;border-radius:var(--r-pill);font-size:.68rem;font-weight:700;letter-spacing:.02em}
.bp{background:rgba(176,139,214,.18);color:var(--pu)}
.bgn{background:rgba(111,186,44,.18);color:var(--success)}
.brd{background:rgba(224,90,90,.18);color:var(--error)}
.cc{background:var(--bg);border:2px solid var(--border);border-radius:var(--r-sm);padding:.65rem;margin-bottom:.4rem;transition:all .15s var(--ease)}
.cc:hover{border-color:var(--border-hover);transform:translateY(-1px)}
.cc .lb{font-size:.72rem;color:var(--text-secondary);text-transform:uppercase;margin-bottom:.2rem;font-weight:600;letter-spacing:.05em}
.cc .cd{font-family:var(--mf);font-size:.78rem;color:var(--success-active);word-break:break-all;white-space:pre-wrap}
.cc .cp{color:var(--text-muted);font-size:.68rem;cursor:pointer;margin-top:.2rem;opacity:0;transition:.12s}
.cc:hover .cp{opacity:1}
.cs-layout{display:grid;grid-template-columns:170px 1fr;gap:1rem;align-items:start}
.cs-side{background:var(--bg-content);border:2px solid var(--border);border-radius:var(--r-base);padding:.4rem;position:sticky;top:72px;max-height:calc(100vh - 88px);overflow-y:auto}
.cs-side button{display:flex;justify-content:space-between;align-items:center;width:100%;text-align:left;background:none;border:none;color:var(--text-secondary);padding:.4rem .55rem;border-radius:var(--r-sm);cursor:pointer;font-size:.8rem;font-family:inherit;font-weight:600;transition:all .15s}
.cs-side button:hover{background:var(--primary-bg);color:var(--primary)}
.cs-side button.on{background:var(--primary-bg);color:var(--primary-active)}
.cs-side .cs-cnt{font-size:.66rem;color:var(--text-muted);opacity:.7}
.cs-side button.on .cs-cnt{color:var(--primary)}
.cs-main{display:grid;grid-template-columns:repeat(auto-fill,minmax(270px,1fr));gap:.8rem}
@media(max-width:760px){.cs-layout{grid-template-columns:1fr}.cs-side{position:static;max-height:none}}
.ci{background:var(--bg);border:2px solid var(--border);border-radius:var(--r-base);padding:.7rem;transition:all .2s var(--ease)}
.ci:hover{transform:translateY(-2px);border-color:var(--border-hover);box-shadow:0 4px 12px rgba(61,52,40,.08)}
.ci h4{font-size:.8rem;color:var(--primary-active);margin-bottom:.3rem;font-weight:700}
.ci pre{font-family:var(--mf);font-size:.72rem;color:var(--text-secondary);white-space:pre-wrap;max-height:180px;overflow-y:auto;margin:0}
.ci .cs-line{font-family:var(--mf);font-size:.72rem;color:var(--text-secondary);padding:.25rem .4rem;border-radius:var(--r-sm);cursor:pointer;white-space:pre-wrap;word-break:break-all;transition:all .12s var(--ease);border:1px solid transparent}
.ci .cs-line:hover{background:var(--primary-bg);color:var(--primary-active);border-color:var(--primary)}
.ci .cp{color:var(--text-muted);font-size:.68rem;cursor:pointer;opacity:0;transition:.12s;margin-top:.3rem;font-weight:700}
.ci:hover .cp{opacity:1}
.cs-card-btns{display:flex;gap:.8rem;margin-top:.3rem}
.cs-dl-all{text-align:center;padding:.5rem;margin-bottom:.6rem;background:var(--bg-content);border:2px dashed var(--border);border-radius:var(--r-base);cursor:pointer;color:var(--text-secondary);font-size:.78rem;font-weight:700;transition:all .15s var(--ease)}
.cs-dl-all:hover{color:var(--primary);border-color:var(--primary);transform:translateY(-1px)}
.cs-mode-toggle{display:flex;gap:.4rem;margin-bottom:.8rem}
.cs-mode-toggle button{background:var(--bg-content);border:2px solid var(--border);color:var(--text-secondary);padding:.4rem .9rem;border-radius:var(--r-pill);cursor:pointer;font-size:.8rem;font-weight:700;font-family:inherit;transition:all .15s var(--ease)}
.cs-mode-toggle button:hover{border-color:var(--primary)}
.cs-mode-toggle button.on{background:var(--primary);color:#fff;border-color:var(--primary)}
.fp-card{background:var(--bg);border:2px solid var(--border);border-radius:var(--r-base);padding:.7rem;transition:all .15s var(--ease);display:flex;align-items:center;gap:.6rem;flex-wrap:wrap}
.fp-card:hover{border-color:var(--border-hover);transform:translateY(-1px)}
.fp-icon{font-size:1.4rem;flex-shrink:0}
.fp-info{flex:1;min-width:0}
.fp-name{font-family:var(--mf);font-size:.78rem;color:var(--primary-active);word-break:break-all;font-weight:600}
.fp-meta{font-size:.68rem;color:var(--text-muted);margin-top:.1rem}
.fp-dl{flex-shrink:0}
.tag{display:inline-block;padding:.12rem .4rem;border-radius:var(--r-sm);font-size:.68rem;margin-right:.2rem;background:var(--primary-bg);color:var(--primary-active);font-weight:700}
.le{font-family:var(--mf);font-size:.76rem;padding:.35rem .4rem;border-bottom:1px solid rgba(196,184,158,.4);background:var(--bg);border-radius:4px;margin-bottom:2px}
.le .tm{color:var(--text-muted);margin-right:.4rem}
.le .mt{font-weight:700;margin-right:.4rem;color:var(--primary-active)}
.lr{font-family:var(--mf);font-size:.76rem;padding:.3rem .4rem;border-bottom:1px solid rgba(196,184,158,.2);display:flex;gap:.6rem;flex-wrap:wrap}
.lr .rt{font-weight:700;color:var(--success-active);min-width:40px}
.lr .dm{color:var(--primary-active);flex:1;word-break:break-all}
.lr .ip{color:var(--warning-active)}
.lr .rl{color:var(--text-muted);margin-left:auto;white-space:nowrap}
.dot{width:8px;height:8px;border-radius:50%;display:inline-block}
.dot.ok{background:var(--success)}.dot.no{background:var(--error)}
.log-box{max-height:450px;overflow-y:auto}
.muted{color:var(--text-muted)}.muted-sm{color:var(--text-secondary);font-size:.78rem}.muted-xs{color:var(--text-muted);font-size:.68rem}
.mb{margin-bottom:.5rem}.mtb{margin:.5rem 0}.mt{margin-top:.5rem}
.lbl{font-size:.78rem;font-weight:600;color:var(--text-secondary)}
.c-ac{color:var(--primary-active)}.c-gn{color:var(--success-active)}.c-or{color:var(--warning-active)}
.tip{font-size:.76rem;color:var(--warning-active)}
.ta-tall{min-height:160px}
.ts-list{font-family:var(--mf);font-size:.85rem;line-height:1.7;color:var(--text-body)}
.toast{position:fixed;bottom:16px;right:16px;background:var(--primary);color:#fff;padding:.5rem 1rem;border-radius:var(--r-pill);font-size:.82rem;z-index:9999;pointer-events:none;font-weight:700;box-shadow:0 4px 12px rgba(25,200,185,.3);animation:toastIn .3s var(--ease)}
@keyframes toastIn{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}
.dl-row{display:flex;align-items:center;gap:.4rem;flex-wrap:wrap;padding:.4rem;background:var(--bg);border:2px solid var(--border);border-radius:var(--r-sm);margin-bottom:.3rem}
.dl-name{font-family:var(--mf);font-size:.8rem;color:var(--primary-active);flex:1;word-break:break-all;font-weight:600}
.dl-sec{padding:.4rem;margin-bottom:.4rem;border:2px solid var(--border);border-radius:var(--r-sm);background:var(--bg)}
.dl-hdr{font-size:.78rem;font-family:var(--mf);margin-bottom:.2rem;color:var(--primary-active);font-weight:700}
.cc-frame{display:none}
.cc-launcher{text-align:center;padding:3rem 1rem;background:var(--bg-content);border:2px solid var(--border);border-radius:var(--r-lg)}
.cc-launcher .cc-logo{font-size:3rem;margin-bottom:.5rem}
.cc-launcher h2{font-size:1.3rem;color:var(--primary-active);margin-bottom:.3rem;font-weight:800}
.cc-launcher .b-big{font-size:1rem;padding:.7rem 1.5rem;margin:1rem 0}
.ipcard-big{display:inline-block;line-height:0;text-decoration:none}
.ipcard-big img{width:688px;height:325px;border-radius:var(--r-base);display:block;border:2px solid var(--border)}
@media(max-width:760px){.ipcard-big img{width:100%;height:auto}}
.ipsrc-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:.6rem}
.ipsrc-card{background:var(--bg);border:2px solid var(--border);border-radius:var(--r-base);padding:.7rem;min-height:80px;transition:all .2s var(--ease);cursor:pointer}
.ipsrc-card:hover{transform:translateY(-2px);border-color:var(--primary)}
.ipsrc-h{font-size:.78rem;color:var(--primary-active);font-weight:700;margin-bottom:.3rem;font-family:var(--mf)}
.ipsrc-b{font-family:var(--mf);font-size:.74rem;line-height:1.5;word-break:break-all;color:var(--text-body)}
.ipsrc-b.muted{color:var(--text-muted)}.ipsrc-b.err{color:var(--error)}
.kv{font-family:var(--mf);font-size:.78rem;line-height:1.7}
.kv .k{color:var(--text-secondary);display:inline-block;min-width:90px;font-weight:600}
.kv .v{color:var(--text-body)}
.tbl{width:100%;border-collapse:collapse;font-size:.76rem;font-family:var(--mf);background:var(--bg);border-radius:var(--r-sm);overflow:hidden}
.tbl th{background:var(--bg-disabled);padding:.4rem .5rem;text-align:left;color:var(--text-secondary);border-bottom:2px solid var(--border);font-weight:700;text-transform:uppercase;font-size:.7rem;letter-spacing:.05em}
.tbl td{padding:.4rem .5rem;border-bottom:1px solid rgba(196,184,158,.3);vertical-align:top;color:var(--text-body)}
.tbl tr:hover td{background:var(--primary-bg)}
.badge-sm{display:inline-block;padding:.1rem .4rem;border-radius:var(--r-sm);font-size:.66rem;margin-right:.2rem;font-weight:700}
.bs-open{background:rgba(111,186,44,.18);color:var(--success-active)}
.bs-closed{background:rgba(159,146,125,.18);color:var(--text-secondary)}
.bs-filtered{background:rgba(245,195,28,.18);color:var(--warning-active)}
.subnav{display:flex;gap:4px;margin-bottom:1rem;border-bottom:2px solid var(--border);padding-bottom:.4rem;flex-wrap:wrap}
.subnav button{background:none;border:2px solid transparent;color:var(--text-secondary);padding:.35rem .7rem;border-radius:var(--r-pill);cursor:pointer;font-size:.78rem;font-family:inherit;font-weight:600;transition:all .15s;letter-spacing:.02em}
.subnav button:hover{color:var(--primary);background:var(--primary-bg)}
.subnav button.on{color:var(--primary-active);background:var(--primary-bg);border-color:var(--primary)}
.subpane{display:none}.subpane.on{display:block}
.otp-code{font-family:var(--mf);font-size:2.4rem;font-weight:900;color:var(--success-active);letter-spacing:.3rem;text-align:center;padding:.5rem}
.diff-add{color:var(--success-active);background:rgba(111,186,44,.10);display:block;padding:0 .3rem}
.diff-del{color:var(--error);background:rgba(224,90,90,.10);display:block;padding:0 .3rem;text-decoration:line-through}
.diff-eq{color:var(--text-muted);display:block;padding:0 .3rem}
.git-cmd{font-family:var(--mf);font-size:.78rem;color:var(--success-active);background:var(--bg);border:2px solid var(--border);border-radius:var(--r-sm);padding:.5rem .7rem;margin:.3rem 0;cursor:pointer;white-space:pre-wrap;word-break:break-all;transition:all .15s}
.git-cmd:hover{border-color:var(--primary);transform:translateY(-1px)}
::-webkit-scrollbar{width:10px;height:10px}
::-webkit-scrollbar-track{background:var(--bg)}
::-webkit-scrollbar-thumb{background:var(--border);border-radius:var(--r-pill);border:2px solid var(--bg)}
::-webkit-scrollbar-thumb:hover{background:var(--border-strong)}

/* Dark mode — dark navy/blue variant (rgb(51,59,92) family) */
html[data-theme="dark"]{
  --primary:#4dd0e1;--primary-hover:#67dbea;--primary-active:#26c6da;--primary-bg:rgba(77,208,225,.12);
  --text:#e8eaf6;--text-body:#c5cae9;--text-secondary:#9fa8da;--text-muted:#7986cb;--text-disabled:#5c6bc0;
  --bg:#1e2342;--bg-content:#333b5c;--bg-disabled:#2a3050;
  --border:#4a5478;--border-hover:#62689a;--border-strong:#7986cb;
  --success:#81d68a;--warning:#ffd54f;--error:#ef9a9a;
  --focus-yellow:#ffeb3b;--shadow-btn:#2a3050;--shadow-input:#262b48;--shadow-mint:#1a5e63;--shadow-red:#8e3b3b;
  --pu:#b39ddb;
}
html[data-theme="dark"] body{color-scheme:dark}
html[data-theme="dark"] .cc-launcher{background:var(--bg-content)}
html[data-theme="dark"] .tbl th{background:var(--bg-disabled)}
html[data-theme="dark"] .le,.html[data-theme="dark"] .lr{background:#262b48}
.theme-toggle{background:var(--bg-content);border:2px solid var(--border);border-radius:var(--r-pill);width:36px;height:36px;cursor:pointer;font-size:1.1rem;color:var(--text);transition:all .15s var(--ease);flex-shrink:0}
.theme-toggle:hover{border-color:var(--primary);color:var(--primary);transform:translateY(-1px)}
/* Homepage */
.home-hero{text-align:center;padding:2.5rem 1rem 1.5rem}
.home-clock{font-size:4.5rem;font-weight:900;color:var(--primary);letter-spacing:.05em;font-family:'Nunito',monospace;line-height:1;text-shadow:0 4px 0 var(--shadow-mint)}
.home-date{font-size:1.1rem;color:var(--text);margin-top:.4rem;font-weight:600}
.home-greet{font-size:.9rem;color:var(--text-secondary);margin-top:.2rem;font-weight:500}
.home-search{display:flex;gap:.4rem;max-width:680px;margin:1.2rem auto 0;justify-content:center}
.home-search select{flex-shrink:0}
.home-search-input{flex:1;border-radius:var(--r-pill);min-width:200px}
.home-chips{max-width:680px;margin:.5rem auto 0;display:flex;flex-wrap:wrap;gap:.3rem;justify-content:center;min-height:1.2rem}
.home-chips:empty{min-height:0}
.home-chip{background:var(--bg-content);border:1.5px solid var(--border);color:var(--text-secondary);padding:.2rem .55rem;border-radius:var(--r-pill);cursor:pointer;font-size:.72rem;font-weight:600;font-family:var(--mf);transition:all .12s var(--ease);white-space:nowrap}
.home-chip:hover{background:var(--primary);color:#fff;border-color:var(--primary);transform:translateY(-1px)}
.home-chip.bool{background:var(--primary-bg);color:var(--primary-active);border-color:var(--primary)}
.home-tools{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:.7rem;max-width:1000px;margin:0 auto;padding:0 1rem 2rem}
.home-tool{background:var(--bg-content);border:2px solid var(--border);border-radius:var(--r-base);padding:1rem .8rem;text-align:center;cursor:pointer;transition:all .2s var(--ease);display:flex;flex-direction:column;align-items:center;gap:.3rem}
.home-tool:hover{transform:translateY(-3px);border-color:var(--primary);box-shadow:0 6px 0 0 var(--shadow-mint)}
.home-tool .ht-icon{font-size:1.8rem}
.home-tool .ht-name{font-size:.82rem;font-weight:700;color:var(--text)}
.home-tool .ht-desc{font-size:.68rem;color:var(--text-secondary)}
/* Vuln docs */
.vd-main{display:block !important;grid-template-columns:none}
.vd-card{background:var(--bg-content);border:2px solid var(--border);border-radius:var(--r-base);padding:1.2rem;margin-bottom:1rem}
.vd-card h3{color:var(--primary-active);font-size:1rem;margin-bottom:.5rem;font-weight:700}
.vd-card h4{color:var(--text);font-size:.82rem;margin:.6rem 0 .3rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em}
.vd-card p{color:var(--text-body);font-size:.82rem;line-height:1.6;margin-bottom:.4rem}
.vd-card code{background:var(--bg);padding:.1rem .35rem;border-radius:4px;font-family:var(--mf);font-size:.76rem;color:var(--success-active)}
.vd-card ul{margin:.3rem 0 .5rem 1.2rem;color:var(--text-body);font-size:.8rem;line-height:1.6}
