:root{--bg: #f6f8fa;--surface: #ffffff;--text: #111827;--muted: #5f6775;--border: #d1d5db;--line: #e5e7eb;--blue: #2563eb;--blue-hover: #1d4ed8;--blue-soft: #eff6ff;--green: #16a34a;--green-soft: #dcfce7;--amber: #d97706;--red: #dc2626;--radius: 8px;--shadow-dialog: 0 24px 72px rgba(15, 23, 42, .24);--font-ui: Inter, ui-sans-serif, -apple-system, BlinkMacSystemFont, "Segoe UI", "PingFang SC", "Microsoft YaHei", sans-serif;--font-mono: "SFMono-Regular", Consolas, "Liberation Mono", monospace}*{box-sizing:border-box}html{color-scheme:light;background:var(--bg)}body{margin:0;color:var(--text);background:linear-gradient(180deg,rgba(37,99,235,.055),transparent 220px),var(--bg);font-family:var(--font-ui);-webkit-font-smoothing:antialiased}button,input{font:inherit}button{color:inherit}button,a,input{-webkit-tap-highlight-color:transparent}button:focus-visible,a:focus-visible,input:focus-visible{outline:3px solid rgba(37,99,235,.28);outline-offset:2px}.page-shell{width:min(960px,calc(100% - 48px));min-height:100vh;margin-inline:auto;padding-block:52px 64px}.utility-bar{min-height:62px;padding-block-end:18px;margin-block-end:28px;border-block-end:1px solid rgba(209,213,219,.8);display:flex;align-items:center;justify-content:space-between;gap:16px}.brand{display:inline-flex;align-items:center;gap:10px;color:#1f2937;text-decoration:none;font-size:15px;font-weight:800}.brand-logo{display:block;width:38px;height:38px;border-radius:9px;object-fit:cover}.language-button{min-height:42px;padding-inline:13px;border:1px solid #bfdbfe;border-radius:8px;display:inline-flex;align-items:center;gap:9px;background:#fff;color:#1d4ed8;font-size:14px;font-weight:700;cursor:pointer}.language-button svg{width:18px;height:18px;fill:none;stroke:currentColor;stroke-width:1.7;stroke-linecap:round;stroke-linejoin:round}.language-button .chevron{width:14px;color:#64748b}.intro{margin-block-end:24px;display:flex;align-items:flex-end;justify-content:space-between;gap:28px}h1{margin:0 0 10px;font-size:36px;line-height:1.18;letter-spacing:-.02em}.intro p{margin:0;color:var(--muted);font-size:16px;line-height:1.7}.privacy-pill{min-height:44px;padding-inline:16px;border:1px solid #bfdbfe;border-radius:999px;display:flex;align-items:center;gap:10px;flex:0 0 auto;background:var(--blue-soft);color:#1d4ed8;font-size:14px;font-weight:700}.privacy-pill i{width:10px;height:10px;border-radius:50%;background:var(--green);box-shadow:0 0 0 4px #16a34a24}.app-grid{display:grid;grid-template-columns:minmax(0,628px) 308px;gap:24px;align-items:start}.panel{border:1px solid var(--line);border-radius:var(--radius);background:var(--surface);overflow:hidden}.results-head{padding:18px 20px 16px;border-block-end:1px solid var(--line)}h2{margin:0;font-size:18px;line-height:1.35}.results-head p,.setting-block p{margin:4px 0 0;color:var(--muted);font-size:13px;line-height:1.5}.actions{display:flex;gap:8px;flex-wrap:wrap;margin-block-start:16px}.actions button,.quantity button,.copy-button{min-height:40px;padding-inline:14px;border:1px solid var(--border);border-radius:8px;background:#fff;font-size:14px;font-weight:700;cursor:pointer}.actions button:not(.primary):hover:not(:disabled),.copy-button:hover{border-color:#93c5fd;color:#1d4ed8}.actions button:disabled{color:#9ca3af;background:#f3f4f6;cursor:not-allowed}.actions .primary{margin-inline-start:auto;border-color:var(--blue);background:var(--blue);color:#fff}.actions .primary:hover{border-color:var(--blue-hover);background:var(--blue-hover);color:#fff}.password-list{padding-block:8px}.password-row{min-height:54px;padding-inline:16px;border-block-end:1px solid #f0f2f5;display:flex;align-items:center;gap:12px;cursor:pointer}.password-row:last-child{border-block-end:0}.password-row:hover,.password-row.selected{background:#f8fbff}.password-row>input{position:absolute;opacity:0;pointer-events:none}.row-check,.fake-check{width:20px;height:20px;border:1.5px solid #9ca3af;border-radius:5px;flex:0 0 auto;display:grid;place-items:center;background:#fff}.row-check svg,.fake-check svg{width:15px;height:15px;fill:none;stroke:#fff;stroke-width:2.5;stroke-linecap:round;stroke-linejoin:round;opacity:0}.password-row input:checked+.row-check,.rule-row input:checked+.fake-check{border-color:var(--blue);background:var(--blue)}.password-row input:checked+.row-check svg,.rule-row input:checked+.fake-check svg{opacity:1}.password-text{min-width:0;flex:1;color:#111827;font:700 17px/1.4 var(--font-mono);letter-spacing:.01em;overflow-wrap:anywhere}.strength-badge{min-width:46px;padding:5px 10px;border-radius:999px;background:var(--green-soft);color:#15803d;text-align:center;font-size:12px;font-weight:800}.strength-badge[data-strength=medium]{background:#fef3c7;color:#b45309}.strength-badge[data-strength=weak]{background:#fee2e2;color:#b91c1c}.copy-button{min-width:52px;padding-inline:12px;border-color:#bfdbfe;color:#1d4ed8}.sidebar{display:grid;gap:16px}.settings-panel,.security-panel{padding:20px;overflow:visible}.setting-block{padding-block:17px;border-block-end:1px solid var(--line)}.setting-block:last-child{padding-block-end:0;border-block-end:0}.setting-heading{display:flex;align-items:center;justify-content:space-between;gap:12px}.field-label,.setting-heading label{display:block;font-size:14px;font-weight:800}#length-number{width:64px;height:40px;border:1px solid var(--border);border-radius:8px;text-align:center;font-weight:700}.range{width:100%;margin:15px 0 0;accent-color:var(--blue)}.quantity{margin-block-start:12px;padding:4px;border-radius:8px;display:grid;grid-template-columns:repeat(3,1fr);background:#f3f4f6}.quantity button{min-width:0;border-color:transparent;background:transparent;color:var(--muted)}.quantity button[aria-checked=true]{border-color:var(--line);background:#fff;color:var(--blue);box-shadow:0 1px 4px #0f172a14}.rules-summary{display:inline-flex;margin-block-start:8px;padding:3px 7px;border-radius:999px;color:#1d4ed8;background:var(--blue-soft);font-size:11px;font-weight:800}.rule-list{margin-block-start:10px}.rule-row{position:relative;min-height:55px;display:flex;align-items:center;gap:10px;cursor:pointer}.rule-row.rule-divider{margin-block-start:4px;padding-block-start:10px;border-block-start:1px solid var(--line)}.rule-row input{position:absolute;opacity:0}.rule-row b,.rule-row small{display:block}.rule-row b{font-size:14px;line-height:1.35}.rule-row small{margin-block-start:2px;color:var(--muted);font:11px/1.35 var(--font-mono);overflow-wrap:anywhere}.security-panel h2{margin-block-end:16px}.score-row{display:flex;align-items:center;gap:14px}.score-track{height:10px;border-radius:999px;flex:1;overflow:hidden;background:#e5e7eb}.score-track i{display:block;width:72%;height:100%;border-radius:inherit;background:var(--green);transition:width .2s}.security-panel>p{margin:16px 0 0;padding:14px;border:1px solid var(--line);border-radius:8px;color:#4b5563;background:#fafafa;font-size:13px;line-height:1.65}.toast{position:fixed;z-index:30;inset-block-end:28px;inset-inline-start:50%;padding:10px 16px;border-radius:8px;color:#fff;background:#111827;box-shadow:0 8px 24px #0f172a38;font-size:14px;font-weight:700;transform:translate(-50%,14px);opacity:0;pointer-events:none;transition:.18s ease}.toast.show{transform:translate(-50%);opacity:1}[dir=rtl] .toast{transform:translate(50%,14px)}[dir=rtl] .toast.show{transform:translate(50%)}.language-dialog{width:min(960px,calc(100% - 40px));max-width:none;max-height:min(760px,calc(100vh - 64px));padding:0;border:0;border-radius:8px;overflow:hidden;background:#fff;box-shadow:var(--shadow-dialog)}.language-dialog::backdrop{background:#1e293b7a;backdrop-filter:blur(2px)}.language-sheet{max-height:inherit;display:flex;flex-direction:column}.language-head{padding:24px 28px 16px;display:flex;justify-content:space-between;gap:20px}.language-head h2{font-size:24px}.language-head p{margin:4px 0 0;color:var(--muted);font-size:13px}.icon-button{width:40px;height:40px;border:1px solid var(--border);border-radius:8px;background:#fff;cursor:pointer}.icon-button svg{width:20px;fill:none;stroke:#475569;stroke-width:2;stroke-linecap:round}.language-search-wrap{position:relative;margin:0 28px 20px}.language-search-wrap svg{position:absolute;width:20px;inset-inline-start:14px;inset-block-start:12px;fill:none;stroke:#64748b;stroke-width:2;stroke-linecap:round}.language-search-wrap input{width:100%;height:46px;padding-inline:44px 14px;border:1px solid #cbd5e1;border-radius:8px;color:var(--text);background:#f8fafc}.locale-grid{min-height:0;padding:20px 28px 28px;border-block-start:1px solid var(--line);display:grid;grid-template-columns:repeat(3,1fr);gap:24px;overflow:auto}.locale-group h3{margin:0 0 10px;color:#475569;font-size:12px;text-transform:uppercase}.locale-group-worldwide{grid-column:1}.locale-list{display:grid;align-content:start;gap:2px}.locale-option{width:100%;min-height:47px;padding:6px 9px;border:1px solid transparent;border-radius:8px;display:grid;grid-template-columns:28px 1fr 18px;align-items:center;gap:10px;background:transparent;text-align:start;cursor:pointer}.locale-option:hover,.locale-option:focus-visible{border-color:#bfdbfe;background:#eff6ff}.locale-option[aria-current=true]{border-color:#93c5fd;background:#eff6ff}.region-dot{width:28px;height:28px;border-radius:50%;display:grid;place-items:center;background:#f1f5f9;color:#475569;font-size:10px;font-weight:700}.locale-option b,.locale-option small{display:block}.locale-option b{font-size:13px;font-weight:500}.locale-option small{margin-block-start:2px;color:#7890b0;font-size:10px}.current-check{width:17px;fill:none;stroke:var(--blue);stroke-width:2.3;stroke-linecap:round;stroke-linejoin:round;opacity:0}.locale-option[aria-current=true] .current-check{opacity:1}.language-footer{min-height:48px;padding-inline:28px;border-block-start:1px solid var(--line);display:flex;align-items:center;justify-content:space-between;gap:20px;color:#64748b;background:#f8fafc;font-size:12px}.language-footer strong{color:#334155}.no-results{grid-column:1 / -1;color:var(--muted);text-align:center}.knowledge-content{margin-block-start:44px;display:grid;gap:18px}.content-section{padding:30px;border:1px solid var(--line);border-radius:10px;background:var(--surface)}.section-kicker{margin:0 0 8px;color:var(--blue);font-size:12px;font-weight:800;letter-spacing:.04em;text-transform:uppercase}.content-section>h2{font-size:24px;letter-spacing:-.015em}.content-lead{max-width:760px;margin:10px 0 0;color:var(--muted);font-size:15px;line-height:1.75}.guide-steps{margin-block-start:24px;display:grid;grid-template-columns:repeat(3,1fr);gap:16px}.guide-step{display:flex;align-items:flex-start;gap:12px}.guide-step>span{width:28px;height:28px;flex:0 0 auto;border-radius:50%;display:grid;place-items:center;color:#fff;background:var(--blue);font-size:13px;font-weight:800}.guide-step h3,.evidence-grid h3,.faq-list h3{margin:2px 0 6px;font-size:15px;line-height:1.4}.guide-step p,.evidence-grid p,.faq-list p{margin:0;color:var(--muted);font-size:13px;line-height:1.7}.evidence-grid{margin-block-start:22px;display:grid;grid-template-columns:repeat(3,1fr);gap:1px;overflow:hidden;border:1px solid var(--line);border-radius:8px;background:var(--line)}.evidence-grid article{padding:20px;background:#fff}.source-note{margin:16px 0 0;color:var(--muted);font-size:12px;line-height:1.6}.source-note a,.references a{color:#1d4ed8;text-underline-offset:3px}.practices ul{margin:20px 0 0;padding:0;display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px 24px;list-style:none}.practices li{position:relative;padding-inline-start:26px;color:#374151;font-size:14px;line-height:1.65}.practices li:before{content:"";position:absolute;inset-inline-start:2px;inset-block-start:8px;width:8px;height:8px;border:2px solid var(--green);border-radius:50%}.faq-list{margin-block-start:20px;display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:0 28px}.faq-list article{padding-block:17px;border-block-start:1px solid var(--line)}.trust-nav,.site-footer{padding:18px 22px;border:1px solid var(--line);border-radius:8px;display:flex;align-items:center;justify-content:center;gap:24px;background:#fff}.trust-nav a,.site-footer a,.back-to-tool{color:#1d4ed8;font-size:13px;font-weight:750;text-decoration:none}.trust-nav a:hover,.site-footer a:hover,.back-to-tool:hover{text-decoration:underline;text-underline-offset:3px}.info-shell{width:min(840px,calc(100% - 48px));min-height:100vh;margin-inline:auto;padding-block:52px 64px}.info-article{padding:44px 52px;border:1px solid var(--line);border-radius:10px;background:#fff}.info-article h1{max-width:700px;font-size:38px}.info-lead{max-width:700px;margin:14px 0 36px;color:var(--muted);font-size:17px;line-height:1.75}.info-article section{padding-block:24px;border-block-start:1px solid var(--line)}.info-article section h2{margin-block-end:9px;font-size:20px}.info-article section p,.info-article section li{margin:0;color:#4b5563;font-size:15px;line-height:1.8}.references ul{margin:0;padding-inline-start:20px}.site-footer{margin-block-start:18px}.editorial-shell{width:min(960px,calc(100% - 48px));margin:0 auto 64px}.editorial-article{color:#374151}.editorial-article>h2,.editorial-article>h3{color:var(--text);scroll-margin-top:24px}.editorial-article>h2{margin:34px 0 10px;font-size:24px}.editorial-article>h3{margin:24px 0 8px;font-size:18px}.editorial-article>p,.editorial-article>ul,.editorial-article>ol,.editorial-article>blockquote{max-width:780px;font-size:15px;line-height:1.82}.editorial-article>ul,.editorial-article>ol{padding-inline-start:24px}.editorial-article a{color:#1d4ed8;text-underline-offset:3px}.editorial-shell>.editorial-article{padding:38px 42px;border:1px solid var(--line);border-radius:10px;background:#fff}.editorial-meta{margin-block-start:32px;padding:18px 20px;border:1px solid #bfdbfe;border-radius:8px;background:#eff6ff}.editorial-meta p{margin:3px 0;color:#334155;font-size:12px;line-height:1.65}.source-list{margin-block-start:30px;padding-block-start:24px;border-block-start:1px solid var(--line)}.source-list h2{margin-block-end:10px}.source-list ul{margin:0;padding-inline-start:20px}.source-list li{margin-block:6px}.ad-slot{min-height:280px;margin-block:24px;padding:28px;border:1px solid var(--line);border-radius:8px;display:grid;place-items:center;background:#f8fafc}.ad-slot>span{align-self:start;color:#64748b;font-size:11px;text-transform:uppercase}.adsbygoogle{width:100%;min-height:250px}@media(max-width:840px){.page-shell{width:min(100% - 32px,680px);padding-block-start:24px}.intro{align-items:flex-start;flex-direction:column;gap:14px}.app-grid{grid-template-columns:1fr}.sidebar{grid-template-columns:1fr 1fr}.language-dialog{width:calc(100% - 24px)}.locale-grid{grid-template-columns:repeat(2,1fr)}.locale-group-worldwide{grid-column:auto}.guide-steps,.evidence-grid{grid-template-columns:1fr}}@media(max-width:560px){.page-shell{width:100%;padding:16px 12px 40px}.utility-bar{margin-block-end:22px}h1{font-size:30px}.intro p{font-size:14px}.privacy-pill{min-height:40px;padding-inline:13px;font-size:12px}.results-head{padding:16px 14px}.actions{display:grid;grid-template-columns:repeat(2,minmax(0,1fr))}.actions button{padding-inline:8px}.actions .primary{grid-column:1 / -1;margin:0}.password-row{min-height:60px;padding-inline:12px;gap:9px}.password-text{font-size:15px}.strength-badge{display:none}.copy-button{min-width:48px;padding-inline:8px}.sidebar{grid-template-columns:1fr}.settings-panel,.security-panel{padding:18px 16px}.language-dialog{width:100%;height:100%;max-height:none;margin:0;border-radius:0}.language-sheet{height:100%;max-height:none}.language-head{padding:22px 20px 16px}.language-head h2{font-size:23px}.language-head .icon-button{display:none}.language-search-wrap{margin:0 20px 16px}.locale-grid{padding:18px 20px;grid-template-columns:1fr;gap:28px}.language-dialog{height:calc(100% - 68px);margin:68px 0 0;border-radius:8px 8px 0 0}.locale-group-americas{order:1}.locale-group-worldwide{order:2}.locale-group-emea{order:3}.locale-group-apac{order:4}.language-footer{min-height:78px;padding:10px 20px;align-items:flex-start;flex-direction:column;justify-content:center;gap:8px}.knowledge-content{margin-block-start:28px}.content-section{padding:22px 18px}.content-section>h2{font-size:21px}.practices ul,.faq-list{grid-template-columns:1fr}.trust-nav,.site-footer{flex-wrap:wrap;gap:14px 20px}.info-shell{width:100%;padding:16px 12px 40px}.info-article{padding:28px 20px}.info-article h1{font-size:30px}.info-lead{font-size:15px}.editorial-shell{width:100%;margin-block-end:40px;padding-inline:12px}.editorial-shell>.editorial-article{padding:26px 20px}}@media(max-width:360px){.language-button span{max-width:110px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.brand>span:last-child{display:none}}@media(prefers-reduced-motion:reduce){*,*:before,*:after{scroll-behavior:auto!important;transition-duration:.01ms!important}}
