@import"https://fonts.googleapis.com/css2?family=IBM+Plex+Mono:wght@400;500;600&family=Sora:wght@400;500;600;700&family=Source+Serif+4:opsz,wght@8..60,600&display=swap";:root{--bg-top: #ecf4ff;--bg-bottom: #e7f0e8;--panel: rgba(255, 255, 255, .92);--panel-border: rgba(9, 44, 75, .15);--ink: #0e2a42;--muted: #4d6276;--brand: #11608e;--brand-soft: #d6ecff;--danger: #c44130;--danger-soft: #fde4e0;--warn: #ba7a22;--warn-soft: #fff1df;--good: #1f7a4f;--good-soft: #dcf4e8;--great: #145a99;--great-soft: #d9ebff;--shadow: 0 16px 40px rgba(14, 42, 66, .12)}*{box-sizing:border-box}html,body{margin:0;min-height:100%;color:var(--ink);font-family:Sora,Trebuchet MS,sans-serif;background:radial-gradient(60vw 60vw at 15% -10%,rgba(17,96,142,.2),transparent 58%),radial-gradient(56vw 56vw at 100% 8%,rgba(31,122,79,.16),transparent 60%),linear-gradient(165deg,var(--bg-top),var(--bg-bottom))}body:before,body:after{content:"";position:fixed;pointer-events:none;z-index:0}body:before{inset:0;background-image:linear-gradient(rgba(14,42,66,.05) 1px,transparent 1px),linear-gradient(90deg,rgba(14,42,66,.05) 1px,transparent 1px);background-size:34px 34px;-webkit-mask-image:radial-gradient(circle at 35% 20%,black,transparent 84%);mask-image:radial-gradient(circle at 35% 20%,black,transparent 84%);opacity:.23}body:after{width:28rem;height:28rem;right:-8rem;bottom:-11rem;border-radius:50%;background:radial-gradient(circle,rgba(17,96,142,.22),transparent 68%)}#app{position:relative;z-index:1;min-height:100vh}.password-shell{width:min(1100px,calc(100vw - 2rem));margin:1.1rem auto 2rem;display:grid;gap:.9rem}.page-header,.panel{border-radius:18px;border:1px solid var(--panel-border);background:var(--panel);box-shadow:var(--shadow);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.page-header{padding:1.2rem}.eyebrow{margin:0;font-family:IBM Plex Mono,monospace;font-size:.78rem;letter-spacing:.06em;text-transform:uppercase;color:var(--brand)}h1{margin:.42rem 0 .58rem;font-family:"Source Serif 4",Georgia,serif;font-size:clamp(1.8rem,4vw,3rem);line-height:1.06}.subtitle{margin:0;max-width:66ch;color:var(--muted);font-size:1rem;line-height:1.56}.content-grid{display:grid;grid-template-columns:1.15fr 1fr;gap:.9rem}.panel{padding:1rem}h2{margin:0;font-size:1.1rem;font-weight:700}.panel-note{margin:.45rem 0 .8rem;color:var(--muted);font-size:.92rem}.field-label{display:inline-block;margin-bottom:.45rem;font-family:IBM Plex Mono,monospace;font-size:.76rem;letter-spacing:.05em;text-transform:uppercase;color:var(--muted)}input,button{font:inherit}.password-row{display:grid;grid-template-columns:1fr auto;gap:.5rem}#password-input{width:100%;border:1px solid rgba(14,42,66,.17);background:#fff;border-radius:12px;padding:.74rem .84rem;color:var(--ink)}#password-input:focus-visible,button:focus-visible{outline:2px solid rgba(17,96,142,.35);outline-offset:2px}.ghost-btn,.action-btn,.subtle-btn{border-radius:12px;border:1px solid transparent;cursor:pointer;transition:transform .14s ease,box-shadow .14s ease,filter .14s ease}.ghost-btn{background:#ffffffe6;border-color:#0e2a4233;color:var(--ink);padding:.65rem .9rem;min-width:5rem}.ghost-btn:hover,.action-btn:hover,.subtle-btn:hover{transform:translateY(-1px);filter:brightness(.99)}.meter-wrap{margin-top:.8rem}.meter-track{position:relative;height:12px;border-radius:999px;background:#e7edf4;overflow:hidden}.meter-fill{position:absolute;inset:0 auto 0 0;width:0;border-radius:inherit;transition:width .26s ease,background-color .26s ease}.meter-fill.weak{background:linear-gradient(90deg,#de5e4f,var(--danger))}.meter-fill.fair{background:linear-gradient(90deg,#d59c42,var(--warn))}.meter-fill.good{background:linear-gradient(90deg,#2f9564,var(--good))}.meter-fill.great{background:linear-gradient(90deg,#2878b8,var(--great))}.meter-headline{margin-top:.45rem;display:flex;justify-content:space-between;align-items:center;gap:1rem}.meter-headline strong{font-size:1.02rem}.meter-headline span{font-family:IBM Plex Mono,monospace;color:var(--muted);font-size:.86rem}.stat-grid{margin-top:.75rem;display:grid;grid-template-columns:1fr 1fr;gap:.55rem}.stat-card{border-radius:12px;border:1px solid rgba(14,42,66,.12);background:#ffffffb8;padding:.65rem .72rem}.stat-label{display:block;font-family:IBM Plex Mono,monospace;color:var(--muted);font-size:.75rem;margin-bottom:.3rem}.stat-card strong{font-size:.98rem}.button-row{margin-top:.78rem;display:grid;gap:.5rem;grid-template-columns:1fr 1fr}.action-btn{background:linear-gradient(135deg,#136b9f,#0b5f8f);color:#f6fbff;padding:.68rem .85rem;box-shadow:0 9px 20px #11608e3d}.subtle-btn{background:#f7fbff;border-color:#0e2a4226;color:var(--ink);padding:.68rem .85rem}.check-list,.tips-list{margin:.7rem 0 0;padding:0;list-style:none;display:grid;gap:.5rem}.check-item{display:grid;grid-template-columns:auto 1fr;gap:.58rem;align-items:center;border:1px solid rgba(14,42,66,.12);border-radius:10px;padding:.53rem .62rem;font-size:.95rem}.check-icon{width:1.25rem;height:1.25rem;border-radius:50%;display:grid;place-items:center;font-family:IBM Plex Mono,monospace;font-size:.77rem;font-weight:600}.check-item.passed{background:var(--good-soft);border-color:#1f7a4f38}.check-item.passed .check-icon{background:#1f7a4f2e;color:#145238}.check-item.failed{background:var(--danger-soft);border-color:#c4413033}.check-item.failed .check-icon{background:#c441302e;color:#8f2a1e}.tips-title{margin-top:1rem}.tips-list li{border-radius:10px;border:1px solid rgba(14,42,66,.11);background:#ffffffc2;padding:.58rem .64rem;line-height:1.45;color:#2f4458}.rise{opacity:0;animation:rise-in .58s ease forwards}.rise-1{animation-delay:40ms}.rise-2{animation-delay:.13s}.rise-3{animation-delay:.22s}@keyframes rise-in{0%{opacity:0;transform:translateY(11px)}to{opacity:1;transform:translateY(0)}}@media(max-width:940px){.content-grid{grid-template-columns:1fr}}@media(max-width:680px){.password-shell{width:calc(100vw - 1rem);margin:.6rem auto 1rem;gap:.65rem}.page-header,.panel{padding:.82rem;border-radius:14px}.password-row,.button-row,.stat-grid{grid-template-columns:1fr}.meter-headline{flex-direction:column;align-items:flex-start;gap:.15rem}}
