/* SecureVault Labs — Password Center PRO */
.pw-page{--cyan:#00e5ff;--blue:#2f8cff;--purple:#8b5cf6;--pink:#ff4fa3;--red:#ff4b6e;--orange:#f97316;--yellow:#fbbf24;--green:#20e7bd;--text:#f7f9ff;--muted:#b9c6da;--dim:#8290aa;width:min(1600px,calc(100vw - 56px));margin:28px auto 56px;color:var(--text);font-family:'JetBrains Mono',ui-monospace,monospace;position:relative;z-index:5}.pw-page *{box-sizing:border-box}.pw-page h2,.pw-page h3{font-family:'Syne',system-ui,sans-serif;margin:0;letter-spacing:-.035em}.pw-page p{margin:0;color:var(--muted);line-height:1.58}.pw-kicker{display:block;font-size:.68rem;letter-spacing:.3em;text-transform:uppercase;color:var(--cyan);font-weight:900;text-shadow:0 0 14px rgba(0,229,255,.42);margin-bottom:8px}.pw-top-tools{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:18px;align-items:stretch}.pw-tool-card,.pw-result-wide,.pw-education-section,.pw-academy-section,.pw-stats-section,.pw-mini-card{position:relative;border:1px solid rgba(96,165,250,.22);border-radius:20px;background:linear-gradient(135deg,rgba(6,17,36,.82),rgba(7,12,28,.9) 56%,rgba(30,16,62,.58));box-shadow:0 22px 62px rgba(0,0,0,.34),inset 0 1px rgba(255,255,255,.045);overflow:hidden}.pw-tool-card:before,.pw-result-wide:before,.pw-education-section:before,.pw-academy-section:before,.pw-stats-section:before,.pw-mini-card:before{content:"";position:absolute;inset:0;background:radial-gradient(circle at 10% 0,rgba(0,229,255,.12),transparent 34%),radial-gradient(circle at 90% 0,rgba(139,92,246,.15),transparent 38%);pointer-events:none}.pw-tool-card>* , .pw-result-wide>* , .pw-education-section>* , .pw-academy-section>* , .pw-stats-section>* , .pw-mini-card>*{position:relative;z-index:2}.pw-tool-card{min-height:350px;padding:24px;display:flex;flex-direction:column}.pw-card-head{display:flex;gap:14px;align-items:flex-start;margin-bottom:10px}.pw-step{flex:0 0 auto;display:grid;place-items:center;width:38px;height:38px;border-radius:13px;background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.12);font-weight:900;color:#fff}.pw-tool-card h2{font-size:1.35rem;line-height:1.1}.pw-tool-card p{font-size:.86rem;min-height:64px}.pw-field{display:block;margin-top:14px;color:#e6efff;font-weight:900}.pw-input,.pw-textarea{width:100%;margin-top:8px;border:1px solid rgba(105,170,255,.2);background:rgba(2,7,18,.78);color:#fff;border-radius:12px;padding:13px 14px;font:900 .9rem 'JetBrains Mono',monospace;outline:none}.pw-textarea{min-height:94px;resize:vertical;line-height:1.55}.pw-input:focus,.pw-textarea:focus{border-color:rgba(0,229,255,.58);box-shadow:0 0 0 3px rgba(0,229,255,.08)}.pw-range{width:100%;margin-top:12px;accent-color:var(--cyan)}.pw-range-row b{color:#fff}.pw-check-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:9px;margin-top:14px}.pw-check-grid.compact{grid-template-columns:1fr}.pw-check-grid label{border:1px solid rgba(255,255,255,.09);background:rgba(255,255,255,.05);border-radius:12px;padding:10px 11px;color:#dce8ff;font-size:.82rem;font-weight:900}.pw-check-grid input{accent-color:var(--cyan);margin-right:8px}.pw-mini-options{display:grid;grid-template-columns:1fr 1fr;gap:12px}.pw-actions{display:flex;gap:9px;flex-wrap:wrap;margin-top:auto;padding-top:14px}.pw-btn,.pw-chip,.pw-mini-btn,.pw-copy-btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;border:1px solid rgba(120,180,255,.24);background:rgba(5,12,28,.62);color:#fff;border-radius:12px;padding:11px 14px;font-weight:900;font-family:'JetBrains Mono',monospace;cursor:pointer;transition:.16s ease;white-space:nowrap;text-decoration:none}.pw-btn:hover,.pw-chip:hover,.pw-mini-btn:hover,.pw-copy-btn:hover{transform:translateY(-2px);box-shadow:0 0 24px rgba(0,229,255,.18)}.pw-btn-cyan{background:linear-gradient(135deg,#17defa,#8b5cf6);border-color:transparent}.pw-btn-purple{background:linear-gradient(135deg,#8b5cf6,#ff4fa3);border-color:transparent}.pw-btn-green{background:linear-gradient(135deg,#16c983,#20e7bd);border-color:transparent}.pw-btn-amber{background:linear-gradient(135deg,#fbbf24,#f97316);border-color:transparent}.pw-btn-blue{background:linear-gradient(135deg,#2f8cff,#00e5ff);border-color:transparent}.pw-generate{border-color:rgba(0,229,255,.34);background:linear-gradient(135deg,rgba(0,48,70,.72),rgba(8,13,31,.9) 56%,rgba(42,18,72,.44))}.pw-passphrase{border-color:rgba(139,92,246,.36);background:linear-gradient(135deg,rgba(38,18,80,.68),rgba(8,13,31,.9) 56%,rgba(70,16,80,.42))}.pw-strength{border-color:rgba(32,231,189,.36);background:linear-gradient(135deg,rgba(4,54,42,.66),rgba(8,13,31,.9) 56%,rgba(18,72,62,.38))}.pw-policy{border-color:rgba(251,191,36,.36);background:linear-gradient(135deg,rgba(72,45,8,.66),rgba(8,13,31,.9) 56%,rgba(72,35,14,.42))}.pw-reuse{border-color:rgba(47,140,255,.36);background:linear-gradient(135deg,rgba(10,38,76,.66),rgba(8,13,31,.9) 56%,rgba(20,28,80,.48))}.pw-guardian{border-color:rgba(255,75,110,.36);background:linear-gradient(135deg,rgba(72,15,30,.66),rgba(8,13,31,.9) 56%,rgba(56,18,72,.48))}.pw-generate:after,.pw-passphrase:after,.pw-strength:after,.pw-policy:after,.pw-reuse:after,.pw-guardian:after{content:"";position:absolute;left:0;right:0;top:0;height:4px;background:var(--bar,#00e5ff)}.pw-generate{--bar:linear-gradient(90deg,#00e5ff,#8b5cf6)}.pw-passphrase{--bar:linear-gradient(90deg,#8b5cf6,#ff4fa3)}.pw-strength{--bar:linear-gradient(90deg,#16c983,#20e7bd)}.pw-policy{--bar:linear-gradient(90deg,#fbbf24,#f97316)}.pw-reuse{--bar:linear-gradient(90deg,#2f8cff,#00e5ff)}.pw-guardian{--bar:linear-gradient(90deg,#ff4b6e,#f97316)}.pw-rule-list{display:grid;gap:9px;margin-top:14px}.pw-rule-list div{border:1px solid rgba(255,255,255,.09);background:rgba(255,255,255,.05);border-radius:13px;padding:12px}.pw-rule-list b{display:block;color:#fff}.pw-rule-list span{display:block;color:var(--muted);font-size:.78rem;margin-top:3px}.pw-result-wide{margin-top:18px;display:grid;grid-template-columns:240px minmax(0,1fr) 390px;gap:22px;align-items:stretch;padding:24px;border-color:rgba(0,229,255,.32);background:linear-gradient(135deg,rgba(5,25,42,.86),rgba(8,13,31,.93) 54%,rgba(42,18,72,.68))}.pw-result-score{border:1px solid rgba(0,229,255,.26);background:rgba(4,12,28,.62);border-radius:18px;padding:18px;display:flex;flex-direction:column;justify-content:center;box-shadow:inset 0 0 32px rgba(0,229,255,.06)}.pw-score-label{color:var(--cyan);text-transform:uppercase;letter-spacing:.16em;font-size:.72rem;font-weight:900}.pw-result-score strong{font-family:'Syne',sans-serif;font-size:4.1rem;line-height:1;margin-top:8px}.pw-result-score small{color:var(--dim);font-weight:900}.pw-score-bar{height:12px;border-radius:999px;background:rgba(255,255,255,.08);overflow:hidden;margin:14px 0}.pw-score-bar i{display:block;width:0%;height:100%;border-radius:999px;background:linear-gradient(90deg,#ff4b6e,#fbbf24,#20e7bd);transition:.24s ease}.pw-result-score em{font-style:normal;color:#dce8ff;font-weight:900;font-size:.83rem}.pw-result-main h2{font-size:1.8rem;line-height:1.1;margin-bottom:10px}.pw-status{display:inline-flex;border:1px solid rgba(255,255,255,.1);background:rgba(255,255,255,.06);border-radius:999px;padding:8px 11px;font-weight:900;color:#e7f2ff}.pw-output-box{display:grid;grid-template-columns:1fr auto;gap:10px;margin-top:14px}.pw-output-box code{display:block;border:1px solid rgba(255,255,255,.1);background:rgba(2,7,18,.76);border-radius:13px;padding:14px 15px;word-break:break-all;color:#d9f7ff;min-height:52px}.pw-findings{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px;margin-top:14px}.pw-finding{padding:12px 13px;border-radius:13px;border:1px solid rgba(255,255,255,.09);background:rgba(255,255,255,.05);color:#dce8ff}.pw-finding.ok{border-color:rgba(32,231,189,.28);box-shadow:inset 3px 0 rgba(32,231,189,.9)}.pw-finding.warn{border-color:rgba(251,191,36,.32);box-shadow:inset 3px 0 rgba(251,191,36,.9)}.pw-finding.bad{border-color:rgba(255,75,110,.42);box-shadow:inset 3px 0 rgba(255,75,110,.9)}.pw-result-details{display:grid;grid-template-columns:repeat(2,1fr);gap:10px}.pw-result-details div{border:1px solid rgba(255,255,255,.09);background:rgba(255,255,255,.05);border-radius:14px;padding:13px}.pw-result-details small{display:block;color:var(--dim);font-weight:900;text-transform:uppercase;letter-spacing:.1em;margin-bottom:6px}.pw-result-details b{word-break:break-word}.pw-education-section,.pw-academy-section,.pw-stats-section{margin-top:22px;padding:22px}.pw-section-title{display:block;margin-bottom:16px}.pw-section-title h2{font-size:1.45rem;line-height:1.14}.pw-section-title p{margin-top:8px;max-width:1080px}.pw-guide-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px}.pw-guide-card{position:relative;border-radius:18px;padding:18px;border:1px solid rgba(255,255,255,.1);background:rgba(8,14,31,.76);box-shadow:0 18px 44px rgba(0,0,0,.26);overflow:hidden}.pw-guide-card h3{font-size:1.05rem;margin:0 0 8px}.pw-guide-card p{font-size:.84rem}.pw-guide-card.ok{border-color:rgba(32,231,189,.38);background:linear-gradient(135deg,rgba(6,50,39,.75),rgba(8,14,31,.86))}.pw-guide-card.danger{border-color:rgba(255,75,110,.45);background:linear-gradient(135deg,rgba(70,14,28,.76),rgba(8,14,31,.86))}.pw-guide-card.warn{border-color:rgba(251,191,36,.42);background:linear-gradient(135deg,rgba(68,43,9,.74),rgba(8,14,31,.86))}.pw-guide-card.info{border-color:rgba(47,140,255,.42);background:linear-gradient(135deg,rgba(8,38,76,.74),rgba(8,14,31,.86))}.pw-academy-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px}.pw-mini-card{padding:18px;min-height:176px;display:flex;flex-direction:column}.pw-mini-card h3{font-size:1.05rem;margin-bottom:8px}.pw-mini-card p{font-size:.82rem;min-height:54px;flex:1}.pw-mini-btn{margin-top:auto;padding:9px 11px;width:max-content}.pw-stats-grid{display:grid;grid-template-columns:repeat(6,1fr);gap:12px}.pw-stats-grid div{border:1px solid rgba(255,255,255,.09);background:rgba(255,255,255,.05);border-radius:14px;padding:14px;position:relative;overflow:hidden}.pw-stats-grid div:after{content:"";position:absolute;left:0;right:0;top:0;height:4px;background:rgba(255,255,255,.15)}.pw-stats-grid small{display:block;color:var(--muted);font-weight:900}.pw-stats-grid strong{display:block;font-family:'Syne',sans-serif;font-size:1.45rem;margin-top:5px}.pw-stats-grid em{display:inline-flex;margin-top:8px;font-style:normal;font-size:.68rem;letter-spacing:.08em;text-transform:uppercase;color:rgba(230,240,255,.72);font-weight:900}.stat-total{border-color:rgba(0,229,255,.28)!important}.stat-total:after{background:linear-gradient(90deg,#00e5ff,#2f8cff)!important}.stat-risk{border-color:rgba(255,75,110,.48)!important}.stat-risk strong,.stat-risk em{color:#ff9aad!important}.stat-risk:after{background:linear-gradient(90deg,#ff4b6e,#f97316)!important}.stat-safe{border-color:rgba(32,231,189,.45)!important}.stat-safe strong,.stat-safe em{color:#92ffee!important}.stat-safe:after{background:linear-gradient(90deg,#20e7bd,#16c983)!important}.stat-pass{border-color:rgba(139,92,246,.38)!important}.stat-pass:after{background:linear-gradient(90deg,#8b5cf6,#ff4fa3)!important}.stat-policy{border-color:rgba(251,191,36,.38)!important}.stat-policy:after{background:linear-gradient(90deg,#fbbf24,#f97316)!important}.stat-reuse{border-color:rgba(47,140,255,.38)!important}.stat-reuse:after{background:linear-gradient(90deg,#2f8cff,#00e5ff)!important}.pw-active{outline:2px solid rgba(0,229,255,.36);box-shadow:0 0 32px rgba(0,229,255,.14),0 22px 62px rgba(0,0,0,.34)!important}.pw-result-flash{animation:pwFlash .42s ease}@keyframes pwFlash{0%{transform:scale(.995)}50%{box-shadow:0 0 48px rgba(0,229,255,.24)}100%{transform:scale(1)}}.pw-modal{position:fixed;inset:0;z-index:99999;display:flex;align-items:center;justify-content:center;padding:24px;background:rgba(2,6,16,.72);backdrop-filter:blur(12px)}.pw-modal[hidden]{display:none}.pw-modal-box{width:min(680px,calc(100vw - 34px));border:1px solid rgba(0,229,255,.28);border-radius:22px;background:linear-gradient(135deg,rgba(8,18,39,.98),rgba(16,10,38,.98));box-shadow:0 30px 100px rgba(0,0,0,.58);padding:30px;position:relative}.pw-modal-box h2{font-family:'Syne',system-ui,sans-serif;font-size:2rem;margin:0 0 12px}.pw-modal-box p{color:#cbd8ed;line-height:1.7}.pw-modal-close{position:absolute;right:16px;top:14px;width:38px;height:38px;border-radius:12px;border:1px solid rgba(255,255,255,.14);background:rgba(255,255,255,.06);color:white;font-size:24px;cursor:pointer}@media(max-width:1220px){.pw-top-tools{grid-template-columns:repeat(2,1fr)}.pw-result-wide{grid-template-columns:220px 1fr}.pw-result-details{grid-column:1/-1;grid-template-columns:repeat(4,1fr)}.pw-guide-grid,.pw-academy-grid{grid-template-columns:repeat(2,1fr)}.pw-stats-grid{grid-template-columns:repeat(3,1fr)}}@media(max-width:760px){.pw-page{width:min(100% - 26px,680px);margin-top:22px}.pw-top-tools,.pw-guide-grid,.pw-academy-grid{grid-template-columns:1fr}.pw-result-wide{grid-template-columns:1fr}.pw-output-box{grid-template-columns:1fr}.pw-findings,.pw-result-details,.pw-stats-grid{grid-template-columns:1fr}.pw-tool-card{min-height:auto}.pw-mini-options{grid-template-columns:1fr}.pw-check-grid{grid-template-columns:1fr}.pw-result-score strong{font-size:3.4rem}}
/* === PHASE 2.3 SAFE CENTER FIX — keeps full design, only centers wrapper === */
body.sv-password-pro-page .pw-page{
  width:min(1500px, calc(100vw - 64px)) !important;
  max-width:1500px !important;
  margin-left:auto !important;
  margin-right:auto !important;
  left:auto !important;
  right:auto !important;
  transform:none !important;
}
@media(max-width:1220px){
  body.sv-password-pro-page .pw-page{
    width:min(100% - 32px, 980px) !important;
    margin-left:auto !important;
    margin-right:auto !important;
  }
}
@media(max-width:760px){
  body.sv-password-pro-page .pw-page{
    width:min(100% - 26px, 680px) !important;
  }
}

/* === PHASE 2.4 SAFE CENTER FIX — Password Center follows Phishing Check wrapper ===
   Problem: previous Password Center width used 100vw inside .sv-tools-shell.
   Result: when the element became wider than its parent, auto margins could not center it.
   Fix: use parent-relative width like Phishing Check PRO, no design/function changes. */
body.sv-password-pro-page .pw-page{
  width:min(1460px, calc(100% - 42px)) !important;
  max-width:none !important;
  margin:30px auto 56px !important;
  left:auto !important;
  right:auto !important;
  transform:none !important;
}
@media(max-width:760px){
  body.sv-password-pro-page .pw-page{
    width:min(100% - 26px, 680px) !important;
    margin-top:22px !important;
  }
}

/* === PHASE 2.5 HARD VIEWPORT CENTERING FIX — same logic as Phishing Check PRO v28 ===
   Problem: Password Center is inside .sv-tools-shell, but its content is wider than that shell.
   Result: auto margins center it inside the parent, not inside the full viewport, so it visually moves right.
   Fix: center #svPasswordPro against the viewport exactly like the working Phishing Check page.
   Scope: Password Center only. No header/footer/menu/JS changes. */
html body.sv-password-pro-page .pw-page,
body.sv-password-pro-page main.pw-page,
main.pw-page#svPasswordPro,
.sv-password-pro-page #svPasswordPro{
  width:min(1720px,calc(100vw - 64px)) !important;
  max-width:none !important;
  margin-top:34px !important;
  margin-right:0 !important;
  margin-left:calc(50% - 50vw + max(32px,calc(50vw - 860px))) !important;
  transform:none !important;
  left:auto !important;
  right:auto !important;
  float:none !important;
}

@media(max-width:1784px){
  html body.sv-password-pro-page .pw-page,
  body.sv-password-pro-page main.pw-page,
  main.pw-page#svPasswordPro,
  .sv-password-pro-page #svPasswordPro{
    width:calc(100vw - 64px) !important;
    margin-left:calc(50% - 50vw + 32px) !important;
  }
}

@media(max-width:1180px){
  html body.sv-password-pro-page .pw-page,
  body.sv-password-pro-page main.pw-page,
  main.pw-page#svPasswordPro,
  .sv-password-pro-page #svPasswordPro{
    width:calc(100vw - 28px) !important;
    margin-left:calc(50% - 50vw + 14px) !important;
  }
}

@media(max-width:720px){
  html body.sv-password-pro-page .pw-page,
  body.sv-password-pro-page main.pw-page,
  main.pw-page#svPasswordPro,
  .sv-password-pro-page #svPasswordPro{
    width:calc(100vw - 22px) !important;
    margin-left:calc(50% - 50vw + 11px) !important;
  }
}

body.sv-password-pro-page .pw-result-wide,
.sv-password-pro-page #pwResultPanel{
  scroll-margin-top:110px !important;
}

/* Password Center PRO — security hierarchy / policy cards 20260602 */
.pw-hierarchy-section{margin-top:22px;padding:22px;border:1px solid rgba(255,75,110,.34);border-radius:22px;background:linear-gradient(135deg,rgba(72,15,30,.45),rgba(8,13,31,.88) 58%,rgba(42,18,72,.42));box-shadow:0 22px 62px rgba(0,0,0,.32);position:relative;overflow:hidden}
.pw-hierarchy-section:before{content:"";position:absolute;inset:0;background:radial-gradient(circle at 10% 0,rgba(255,75,110,.13),transparent 35%),radial-gradient(circle at 90% 0,rgba(0,229,255,.11),transparent 38%);pointer-events:none}.pw-hierarchy-section>*{position:relative;z-index:2}
.pw-hierarchy-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:14px;margin-top:14px}.pw-hierarchy-card{border:1px solid rgba(255,255,255,.1);background:rgba(255,255,255,.055);border-radius:16px;padding:16px;min-height:150px;box-shadow:inset 3px 0 var(--pw-line,#00e5ff)}
.pw-hierarchy-card strong{display:block;font-family:'Syne',system-ui,sans-serif;color:#fff;font-size:1.05rem;line-height:1.15;margin-bottom:8px}.pw-hierarchy-card small{display:block;color:#9fb0cc;font-weight:900;letter-spacing:.12em;text-transform:uppercase;margin-bottom:8px}.pw-hierarchy-card p{font-size:.82rem;color:#b9c6da;line-height:1.55}.pw-h1{--pw-line:#ff4b6e}.pw-h2{--pw-line:#fbbf24}.pw-h3{--pw-line:#00e5ff}.pw-h4{--pw-line:#20e7bd}
@media(max-width:1220px){.pw-hierarchy-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}@media(max-width:760px){.pw-hierarchy-grid{grid-template-columns:1fr}}

/* Password Center PRO — hierarchy layout fix 20260602 */
.pw-hierarchy-section{
  border-color:rgba(0,229,255,.24) !important;
  background:linear-gradient(135deg,rgba(5,25,42,.84),rgba(8,13,31,.92) 58%,rgba(42,18,72,.58)) !important;
  padding:22px !important;
  overflow:hidden !important;
}
.pw-hierarchy-section:after{
  content:"";position:absolute;left:0;right:0;top:0;height:4px;
  background:linear-gradient(90deg,#00e5ff,#8b5cf6,#ff4b6e);pointer-events:none;
}
.pw-hierarchy-section .pw-section-title{
  margin:0 0 14px !important;
  padding:0 0 14px !important;
  border-bottom:1px solid rgba(255,255,255,.08);
}
.pw-hierarchy-section .pw-section-title p{
  max-width:1180px !important;
  color:#c9d7ef !important;
  font-size:.88rem !important;
  line-height:1.55 !important;
}
.pw-hierarchy-grid{
  display:grid !important;
  grid-template-columns:repeat(4,minmax(0,1fr)) !important;
  gap:14px !important;
  align-items:stretch !important;
}
.pw-hierarchy-card{
  display:flex !important;
  flex-direction:column !important;
  min-height:132px !important;
  padding:15px 16px 16px 18px !important;
  background:linear-gradient(135deg,rgba(255,255,255,.075),rgba(255,255,255,.035)) !important;
  border:1px solid rgba(255,255,255,.12) !important;
  box-shadow:0 14px 34px rgba(0,0,0,.18), inset 3px 0 var(--pw-line,#00e5ff), inset 0 1px rgba(255,255,255,.05) !important;
}
.pw-hierarchy-card p{min-height:0 !important;margin:0 !important;font-size:.8rem !important;line-height:1.52 !important;color:#c3d0e6 !important;}
.pw-hierarchy-card strong{font-size:1.02rem !important;line-height:1.16 !important;margin:0 0 8px !important;}
.pw-hierarchy-card small{font-size:.68rem !important;margin:0 0 7px !important;}
@media(max-width:1420px){.pw-hierarchy-grid{grid-template-columns:repeat(2,minmax(0,1fr)) !important;}}
@media(max-width:760px){.pw-hierarchy-grid{grid-template-columns:1fr !important}.pw-hierarchy-section{padding:18px !important;}}


/* Password Center — local self-test panel 20260602 */
.pw-selftest-section{position:relative;border:1px solid rgba(32,231,189,.30);border-radius:22px;background:linear-gradient(135deg,rgba(4,48,42,.50),rgba(8,13,31,.90) 58%,rgba(42,18,72,.48));padding:22px;margin-top:22px;overflow:hidden;box-shadow:0 22px 62px rgba(0,0,0,.30),inset 0 1px rgba(255,255,255,.045)}
.pw-selftest-section:before{content:"";position:absolute;inset:0;background:radial-gradient(circle at 10% 0,rgba(0,229,255,.12),transparent 34%),radial-gradient(circle at 90% 0,rgba(139,92,246,.14),transparent 38%);pointer-events:none}.pw-selftest-section>*{position:relative;z-index:2}
.pw-selftest-actions{display:flex;gap:10px;flex-wrap:wrap;margin-top:14px}.pw-selftest-output{display:block;margin-top:14px;border:1px solid rgba(32,231,189,.20);background:rgba(2,7,18,.78);border-radius:14px;padding:14px 15px;white-space:pre-wrap;word-break:break-word;color:#dffcf7;min-height:86px;font:800 .82rem/1.55 'JetBrains Mono',ui-monospace,monospace}.pw-selftest-output.ok{border-color:rgba(32,231,189,.42);box-shadow:inset 3px 0 rgba(32,231,189,.9)}.pw-selftest-output.bad{border-color:rgba(255,75,110,.42);box-shadow:inset 3px 0 rgba(255,75,110,.9)}

/* Password Center PRO — Phase 2 local report + actionable recommendations 20260602 */
.pw-report-section{position:relative;margin-top:22px;padding:22px;border-radius:22px;border:1px solid rgba(0,229,255,.28);background:linear-gradient(135deg,rgba(5,25,42,.78),rgba(8,13,31,.93) 58%,rgba(42,18,72,.50));box-shadow:0 22px 62px rgba(0,0,0,.30),inset 0 1px rgba(255,255,255,.045);overflow:hidden}
.pw-report-section:before{content:"";position:absolute;inset:0;background:radial-gradient(circle at 8% 0,rgba(0,229,255,.13),transparent 36%),radial-gradient(circle at 92% 0,rgba(139,92,246,.15),transparent 38%);pointer-events:none}.pw-report-section>*{position:relative;z-index:2}
.pw-report-grid{display:grid;grid-template-columns:minmax(280px,.72fr) minmax(420px,1.28fr);gap:14px;margin-top:14px;align-items:stretch}.pw-report-card{border:1px solid rgba(255,255,255,.12);background:linear-gradient(135deg,rgba(255,255,255,.072),rgba(255,255,255,.032));border-radius:16px;padding:16px;box-shadow:inset 3px 0 rgba(0,229,255,.8),0 12px 30px rgba(0,0,0,.18)}.pw-report-card h3{margin:0 0 10px;color:#fff;font-family:'Syne',system-ui,sans-serif;font-size:1.05rem}.pw-report-head{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:10px}.pw-report-head h3{margin:0}.pw-next-steps{display:grid;gap:8px;color:#d9e7ff;font-size:.86rem;line-height:1.45}.pw-next-steps div{padding:10px 11px;border-radius:12px;border:1px solid rgba(255,255,255,.10);background:rgba(2,7,18,.42)}.pw-report-output{display:block;margin:0;border:1px solid rgba(0,229,255,.18);background:rgba(2,7,18,.76);border-radius:14px;padding:14px 15px;color:#dff7ff;min-height:170px;white-space:pre-wrap;word-break:break-word;font:800 .80rem/1.52 'JetBrains Mono',ui-monospace,monospace}.pw-report-card.wide{box-shadow:inset 3px 0 rgba(139,92,246,.85),0 12px 30px rgba(0,0,0,.18)}
@media(max-width:1100px){.pw-report-grid{grid-template-columns:1fr}.pw-report-head{align-items:flex-start;flex-direction:column}.pw-report-head .pw-chip{align-self:flex-start}}
