@import url("https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700&family=JetBrains+Mono:wght@400;500&display=swap");:root{--bg:#0a0e1a;--bg-dark:#060910;--bg-card:#111827;--bg-card2:#0f1623;--border:#1e2d45;--border-bright:#2a4066;--text:#e2e8f0;--text-muted:#94a3b8;--text-dim:#64748b;--accent:#38bdf8;--accent2:#818cf8;--green:#34d399;--red:#f87171;--yellow:#fbbf24;--grad-s:#38bdf8;--grad-e:#818cf8;--font:"Inter","Noto Sans KR",sans-serif;--mono:"JetBrains Mono",ui-monospace,monospace}*,:after,:before{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth}body{background:var(--bg);color:var(--text);font-family:var(--font);font-size:15px;line-height:1.6;min-height:100vh}::-webkit-scrollbar{width:5px;height:5px}::-webkit-scrollbar-track{background:var(--bg-dark)}::-webkit-scrollbar-thumb{background:var(--border-bright);border-radius:3px}.nav{position:-webkit-sticky;position:sticky;top:0;z-index:50;background:rgba(10,14,26,.88);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border-bottom:1px solid var(--border);height:56px;display:flex;align-items:center;padding:0 24px;gap:16px}.nav-logo{font-size:1.1rem;font-weight:800;color:var(--text);letter-spacing:-.02em}.nav-logo span{color:var(--accent)}.nav-sub{font-size:.78rem;color:var(--text-dim);border-left:1px solid var(--border);padding-left:16px}.nav-badge{margin-left:auto;font-size:.7rem;font-weight:700;letter-spacing:.1em;padding:3px 10px;border-radius:20px;background:rgba(56,189,248,.1);border:1px solid rgba(56,189,248,.3);color:var(--accent)}.app{max-width:1320px;margin:0 auto;padding:28px 20px 60px;display:grid;grid-template-columns:320px 1fr;grid-gap:20px;gap:20px;align-items:start}@media (max-width:960px){.app{grid-template-columns:1fr}}.zone-tag{display:inline-block;font-size:.65rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;padding:3px 10px;border-radius:4px;margin-bottom:14px}.zone-client{background:rgba(251,191,36,.12);color:var(--yellow)}.zone-server{background:rgba(56,189,248,.1);color:var(--accent)}.zone-secure{background:rgba(52,211,153,.1);color:var(--green)}.card{background:var(--bg-card);border:1px solid var(--border);border-radius:16px;padding:20px}.card-title{font-size:.82rem;font-weight:700;color:var(--text-muted);text-transform:uppercase;letter-spacing:.08em;margin-bottom:14px;gap:8px}.card-title,.card-title-num{display:flex;align-items:center}.card-title-num{width:22px;height:22px;border-radius:50%;background:linear-gradient(135deg,var(--grad-s),var(--grad-e));justify-content:center;font-size:.7rem;font-weight:800;color:#000;flex-shrink:0}.input-panel{display:flex;flex-direction:column;gap:16px}.input-panel textarea{width:100%;background:var(--bg-dark);border:1px solid var(--border);border-radius:10px;color:var(--text);font-family:var(--font);font-size:.9rem;padding:12px 14px;resize:vertical;min-height:120px;line-height:1.6;transition:border-color .2s}.input-panel textarea:focus{outline:none;border-color:var(--accent)}.presets-wrap{display:flex;flex-direction:column;gap:6px}.presets-label{font-size:.72rem;font-weight:600;color:var(--text-dim);text-transform:uppercase;letter-spacing:.1em}.presets{display:flex;flex-wrap:wrap;gap:6px}.preset-btn{font-size:.72rem;font-weight:600;padding:5px 10px;border-radius:6px;border:1px solid var(--border);cursor:pointer;font-family:var(--font);transition:all .15s;line-height:1;background:var(--bg-dark)}.preset-btn.danger{color:var(--red);border-color:hsla(0,91%,71%,.3)}.preset-btn.safe{color:var(--green);border-color:rgba(52,211,153,.3)}.preset-btn:hover{background:hsla(0,0%,100%,.05);transform:translateY(-1px)}.analyze-btn{width:100%;background:linear-gradient(90deg,var(--grad-s),var(--grad-e));color:#000;font-weight:700;font-size:.95rem;border:none;border-radius:10px;padding:13px;cursor:pointer;font-family:var(--font);transition:opacity .2s,transform .15s}.analyze-btn:hover:not(:disabled){opacity:.9;transform:translateY(-1px)}.analyze-btn:disabled{opacity:.5;cursor:default;transform:none}.error-msg{background:hsla(0,91%,71%,.08);border:1px solid hsla(0,91%,71%,.25);border-radius:8px;padding:10px 14px;font-size:.82rem;color:var(--red)}.right-col{display:flex;flex-direction:column;gap:16px}.pipeline-header{gap:0;background:var(--bg-card);border:1px solid var(--border);border-radius:12px;overflow:hidden}.ph-step,.pipeline-header{display:flex;align-items:center}.ph-step{flex:1 1;justify-content:center;gap:7px;padding:10px 8px;font-size:.72rem;font-weight:600;color:var(--text-dim);border-right:1px solid var(--border);transition:background .3s,color .3s}.ph-step:last-child{border-right:none}.ph-step.active{background:rgba(56,189,248,.08);color:var(--accent)}.ph-step.done{background:rgba(52,211,153,.06);color:var(--green)}.ph-step.error{background:hsla(0,91%,71%,.06);color:var(--red)}.ph-dot{width:7px;height:7px;border-radius:50%;background:var(--border-bright);flex-shrink:0;transition:background .3s}.ph-step.active .ph-dot{background:var(--accent);box-shadow:0 0 6px var(--accent)}.ph-step.done .ph-dot{background:var(--green)}.ph-step.error .ph-dot{background:var(--red)}.cipher-card{position:relative}.cipher-card .mono-preview{font-family:var(--mono);font-size:.72rem;line-height:1.55;word-break:break-all;white-space:pre-wrap;background:var(--bg-dark);border:1px solid var(--border);border-radius:8px;padding:14px;min-height:80px;color:#67e8f9}.cipher-meta{display:flex;gap:16px;margin-top:12px;flex-wrap:wrap}.cipher-pill{font-size:.72rem;padding:3px 10px;border-radius:6px;background:rgba(56,189,248,.08);border:1px solid rgba(56,189,248,.2);color:var(--accent);font-family:var(--mono)}.cipher-empty{font-size:.82rem;color:var(--text-dim);font-style:italic}.scores-grid{display:grid;grid-template-columns:1fr 1fr;grid-gap:20px;gap:20px}@media (max-width:700px){.scores-grid{grid-template-columns:1fr}}.score-item{display:flex;flex-direction:column;gap:7px}.score-head{display:flex;justify-content:space-between;align-items:baseline}.score-label{font-size:.82rem;font-weight:600}.score-value{font-size:.82rem;font-family:var(--mono);color:var(--text-muted)}.score-track{height:6px;border-radius:999px;background:var(--border);overflow:hidden}.score-fill{height:100%;border-radius:999px;background:linear-gradient(90deg,var(--grad-s),var(--grad-e));transition:width .6s cubic-bezier(.4,0,.2,1)}.score-fill.high{background:linear-gradient(90deg,#fb923c,#f87171)}.score-stats{grid-column:1/-1;display:flex;gap:12px;flex-wrap:wrap;margin-top:4px}.stat-pill{flex:1 1;min-width:100px;background:var(--bg-dark);border:1px solid var(--border);border-radius:8px;padding:10px 14px}.stat-pill-label{font-size:.7rem;color:var(--text-dim);margin-bottom:4px}.stat-pill-value{font-size:1rem;font-weight:700;font-family:var(--mono);color:var(--text)}.alert-card{transition:border-color .4s}.alert-card.is-alert{border-color:hsla(0,91%,71%,.45)}.alert-card.is-ok{border-color:rgba(52,211,153,.35)}.alert-badge{display:inline-flex;align-items:center;gap:8px;font-size:1.5rem;font-weight:800;padding:12px 20px;border-radius:12px;margin-bottom:16px}.alert-badge.danger{background:hsla(0,91%,71%,.1);border:1px solid hsla(0,91%,71%,.3);color:#fca5a5}.alert-badge.ok{background:rgba(52,211,153,.08);border:1px solid rgba(52,211,153,.25);color:var(--green)}.alert-body{font-size:.875rem;line-height:1.65;color:var(--text-muted)}.alert-body strong{color:var(--text)}.alert-empty{font-size:.85rem;color:var(--text-dim);font-style:italic}.privacy-note{margin-top:14px;display:flex;align-items:flex-start;gap:8px;font-size:.75rem;color:var(--text-dim);background:rgba(56,189,248,.04);border:1px solid rgba(56,189,248,.1);border-radius:8px;padding:10px 12px;line-height:1.5}@keyframes shimmer{0%{background-position:-600px 0}to{background-position:600px 0}}.loading-shimmer{background:linear-gradient(90deg,var(--bg-dark) 25%,var(--border) 50%,var(--bg-dark) 75%);background-size:600px 100%;animation:shimmer 1.2s linear infinite;border-radius:6px;height:14px}@keyframes spin{to{transform:rotate(1turn)}}.spinner{display:inline-block;width:14px;height:14px;border:2px solid var(--border);border-top-color:var(--accent);border-radius:50%;animation:spin .6s linear infinite;vertical-align:middle;margin-right:6px}