/* ================================================
   GÜVENLİ CÜZDAN — v2 Style
   Dark/Light tema, Kategoriler, Modal, Loglar
   ================================================ */

@import url('https://fonts.googleapis.com/css2?family=Space+Mono:wght@400;700&family=Syne:wght@700;800&display=swap');

/* ---- DARK THEME (varsayılan) ---- */
:root, [data-theme="dark"] {
    --bg:       #0a0c10;
    --bg2:      #0f1117;
    --bg3:      #161b24;
    --bg4:      #1e2535;
    --border:   rgba(255,255,255,0.07);
    --border2:  rgba(255,255,255,0.13);
    --accent:   #00e5a0;
    --accent2:  #3b9eff;
    --danger:   #ff4757;
    --text:     #e2e8f0;
    --text2:    #8892a4;
    --text3:    #4a5568;
    --shadow:   0 8px 32px rgba(0,0,0,0.45);
    --glow:     0 0 20px rgba(0,229,160,0.12);
    --card-bg:  #0f1117;
    --input-bg: #161b24;
    --topbar-bg:rgba(10,12,16,0.92);
}

/* ---- LIGHT THEME ---- */
[data-theme="light"] {
    --bg:       #f0f2f7;
    --bg2:      #ffffff;
    --bg3:      #f7f8fc;
    --bg4:      #eef0f6;
    --border:   rgba(0,0,0,0.08);
    --border2:  rgba(0,0,0,0.14);
    --accent:   #00a876;
    --accent2:  #1a7fd4;
    --danger:   #e53e3e;
    --text:     #1a202c;
    --text2:    #4a5568;
    --text3:    #a0aec0;
    --shadow:   0 4px 20px rgba(0,0,0,0.1);
    --glow:     0 0 0 transparent;
    --card-bg:  #ffffff;
    --input-bg: #f7f8fc;
    --topbar-bg:rgba(255,255,255,0.95);
}

*, *::before, *::after { box-sizing:border-box; margin:0; padding:0; }
html { scroll-behavior:smooth; }

body {
    font-family: 'Space Mono','Courier New',monospace;
    background: var(--bg);
    color: var(--text);
    min-height: 100vh;
    font-size: 13px;
    line-height: 1.6;
    -webkit-font-smoothing: antialiased;
    transition: background 0.3s, color 0.3s;
}

::-webkit-scrollbar { width:5px; height:5px; }
::-webkit-scrollbar-track { background:var(--bg2); }
::-webkit-scrollbar-thumb { background:var(--bg4); border-radius:3px; }
::-webkit-scrollbar-thumb:hover { background:var(--accent); }

a { color:var(--accent); text-decoration:none; }
a:hover { opacity:0.8; }

/* ==============================  LOGIN  ============================== */
.login-body {
    display:flex; align-items:center; justify-content:center;
    min-height:100vh; padding:20px; overflow:hidden;
}
.login-bg { position:fixed; inset:0; z-index:0; overflow:hidden; }
.grid-overlay {
    position:absolute; inset:0;
    background-image:
        linear-gradient(rgba(0,229,160,0.04) 1px, transparent 1px),
        linear-gradient(90deg, rgba(0,229,160,0.04) 1px, transparent 1px);
    background-size:40px 40px;
    animation:gridShift 20s linear infinite;
}
@keyframes gridShift { to { transform:translateY(40px); } }
.glow-orb { position:absolute; border-radius:50%; filter:blur(80px); opacity:.22; animation:orbFloat 8s ease-in-out infinite; }
.orb1 { width:400px;height:400px; background:radial-gradient(circle,#00e5a0,transparent); top:-100px;left:-100px; }
.orb2 { width:300px;height:300px; background:radial-gradient(circle,#3b9eff,transparent); bottom:-50px;right:-50px; animation-delay:4s; }
@keyframes orbFloat { 0%,100%{transform:translate(0,0)scale(1);} 50%{transform:translate(25px,15px)scale(1.1);} }

.login-wrap { position:relative; z-index:1; width:100%; max-width:420px; }
.login-card {
    background:rgba(15,17,23,0.88);
    backdrop-filter:blur(20px);
    border:1px solid var(--border2);
    border-radius:20px;
    padding:40px 36px;
    box-shadow:var(--shadow), var(--glow);
    animation:cardIn .6s cubic-bezier(.34,1.56,.64,1) both;
}
[data-theme="light"] .login-card { background:rgba(255,255,255,0.95); }
@keyframes cardIn { from{opacity:0;transform:translateY(30px)scale(.95);} to{opacity:1;transform:translateY(0)scale(1);} }

.login-header { text-align:center; margin-bottom:28px; }
.vault-icon {
    width:64px;height:64px;
    background:linear-gradient(135deg,rgba(0,229,160,.15),rgba(59,158,255,.12));
    border:1px solid rgba(0,229,160,.3);
    border-radius:16px;
    display:flex;align-items:center;justify-content:center;
    font-size:26px; color:var(--accent);
    margin:0 auto 16px;
    box-shadow:0 0 30px rgba(0,229,160,.2);
}
.login-header h1 { font-family:'Syne',sans-serif; font-size:26px; font-weight:800; letter-spacing:-.5px; }
.login-header .subtitle { color:var(--text2); font-size:12px; margin-top:4px; }

.last-access {
    background:var(--bg3); border:1px solid var(--border);
    border-radius:6px; padding:10px 14px;
    font-size:11px; color:var(--text3);
    margin-bottom:20px;
    display:flex; align-items:flex-start; gap:8px;
    word-break:break-all;
}

.alert { padding:12px 16px; border-radius:6px; font-size:12px; margin-bottom:16px; display:flex; align-items:center; gap:8px; }
.alert-danger { background:rgba(255,71,87,.1); border:1px solid rgba(255,71,87,.3); color:#ff8fa0; }
@keyframes shake { 0%,100%{transform:translateX(0);} 20%,60%{transform:translateX(-6px);} 40%,80%{transform:translateX(6px);} }
.animate-shake { animation:shake .4s ease; }

.form-group { margin-bottom:20px; }
.form-group label { display:block; font-size:11px; color:var(--text2); margin-bottom:8px; letter-spacing:.5px; text-transform:uppercase; }

.input-wrapper { position:relative; display:flex; align-items:center; }
.pin-input {
    width:100%; background:var(--input-bg); border:1px solid var(--border2);
    border-radius:6px; color:var(--text);
    font-family:'Space Mono',monospace; font-size:22px; font-weight:700;
    letter-spacing:8px; text-align:center;
    padding:14px 50px 14px 16px; transition:all .2s; outline:none;
}
.pin-input:focus { border-color:var(--accent); box-shadow:0 0 0 3px rgba(0,229,160,.1); background:var(--bg4); }
.pin-input::placeholder { letter-spacing:4px; color:var(--text3); font-size:16px; }
.eye-btn { position:absolute; right:12px; background:none; border:none; color:var(--text3); cursor:pointer; font-size:14px; padding:4px; transition:color .2s; }
.eye-btn:hover { color:var(--accent); }

.hint-row { display:flex; justify-content:center; gap:12px; margin-top:8px; font-size:11px; }
.hint-fake { color:var(--text3); }
.hint-real { color:var(--accent); opacity:0; transition:opacity 1s; font-weight:700; pointer-events:none; }

.attempts-bar { position:relative; height:4px; background:var(--bg4); border-radius:2px; margin-bottom:16px; overflow:visible; }
.attempts-fill { height:100%; background:linear-gradient(90deg,var(--accent),var(--danger)); border-radius:2px; transition:width .4s; }
.attempts-bar span { position:absolute; right:0; top:8px; font-size:11px; color:var(--text3); }

.btn-login {
    width:100%; background:linear-gradient(135deg,var(--accent),#00b37d);
    color:#0a2e20; border:none; border-radius:6px;
    padding:14px; font-family:'Space Mono',monospace;
    font-size:14px; font-weight:700; cursor:pointer;
    transition:all .2s; letter-spacing:1px;
    display:flex; align-items:center; justify-content:center; gap:8px; margin-top:8px;
}
.btn-login:hover { transform:translateY(-2px); box-shadow:0 8px 24px rgba(0,229,160,.3); }
.login-footer { text-align:center; margin-top:24px; padding-top:20px; border-top:1px solid var(--border); font-size:11px; color:var(--text3); }

/* ==============================  TOPBAR  ============================== */
.topbar {
    position:sticky; top:0; z-index:100;
    background:var(--topbar-bg);
    backdrop-filter:blur(16px);
    border-bottom:1px solid var(--border);
    padding:10px 20px;
    display:flex; align-items:center; justify-content:space-between;
    transition:background .3s;
}
.topbar-left { display:flex; align-items:center; gap:12px; }
.logo-mark {
    width:36px;height:36px;
    background:linear-gradient(135deg,rgba(0,229,160,.15),rgba(59,158,255,.1));
    border:1px solid rgba(0,229,160,.25); border-radius:10px;
    display:flex;align-items:center;justify-content:center;
    color:var(--accent); font-size:15px;
}
.topbar-title { display:flex; flex-direction:column; gap:1px; }
.brand { font-family:'Syne',sans-serif; font-size:15px; font-weight:800; letter-spacing:-.3px; }
.session-info { font-size:10px; color:var(--text3); }
.session-info i { color:var(--accent); }
.topbar-right { display:flex; gap:6px; align-items:center; }

.btn-topbar {
    background:var(--bg3); border:1px solid var(--border2);
    color:var(--text2); border-radius:6px;
    padding:7px 12px; font-family:'Space Mono',monospace;
    font-size:12px; cursor:pointer;
    transition:all .2s; display:flex; align-items:center; gap:6px;
    text-decoration:none; white-space:nowrap;
}
.btn-topbar:hover { background:var(--bg4); color:var(--text); }
.btn-logout:hover { background:rgba(255,71,87,.1); border-color:rgba(255,71,87,.3); color:var(--danger); }
.topbar-label { display:inline; }
@media(max-width:600px){ .topbar-label{display:none;} }

/* ==============================  VAULT MAIN  ============================== */
.vault-body { background:var(--bg); min-height:100vh; transition:background .3s; }
.vault-main { max-width:1400px; margin:0 auto; padding:20px; }

/* TOOLBAR */
.toolbar { display:flex; align-items:center; gap:10px; margin-bottom:20px; flex-wrap:wrap; }
.search-box { flex:1; min-width:200px; position:relative; display:flex; align-items:center; }
.search-box > i { position:absolute; left:12px; color:var(--text3); font-size:12px; pointer-events:none; }
.search-box input {
    width:100%; background:var(--bg2); border:1px solid var(--border2);
    border-radius:6px; color:var(--text);
    font-family:'Space Mono',monospace; font-size:12px;
    padding:9px 36px 9px 34px; outline:none; transition:all .2s;
}
.search-box input:focus { border-color:var(--accent); box-shadow:0 0 0 3px rgba(0,229,160,.07); background:var(--bg3); }
.search-box input::placeholder { color:var(--text3); }
.clear-search {
    position:absolute; right:8px; background:none; border:none;
    color:var(--text3); cursor:pointer; padding:4px;
    display:flex;align-items:center;justify-content:center;
    border-radius:50%; font-size:11px; transition:all .2s;
}
.clear-search:hover { color:var(--danger); }

.toolbar-actions { display:flex; align-items:center; gap:7px; flex-wrap:wrap; }

.cat-select {
    background:var(--bg2); border:1px solid var(--border2);
    border-radius:6px; color:var(--text2);
    font-family:'Space Mono',monospace; font-size:11px;
    padding:8px 10px; cursor:pointer; outline:none; transition:all .2s;
}
.cat-select:focus { border-color:var(--accent); color:var(--text); }

.entry-count { font-size:11px; color:var(--text3); display:flex; align-items:center; gap:5px; padding:8px 10px; background:var(--bg2); border:1px solid var(--border); border-radius:6px; white-space:nowrap; }
.entry-count i { color:var(--accent2); }

.btn-tool { width:34px;height:34px; background:var(--bg2); border:1px solid var(--border2); border-radius:6px; color:var(--text2); cursor:pointer; display:flex;align-items:center;justify-content:center; font-size:12px; transition:all .2s; }
.btn-tool:hover { background:var(--bg4); color:var(--text); }
.btn-tool.active { background:rgba(0,229,160,.1); border-color:rgba(0,229,160,.3); color:var(--accent); }

.btn-save { background:linear-gradient(135deg,var(--accent),#00b37d); border:none; border-radius:6px; color:#0a2e20; font-family:'Space Mono',monospace; font-size:12px; font-weight:700; padding:8px 16px; cursor:pointer; display:flex;align-items:center;gap:5px; transition:all .2s; }
.btn-save:hover { transform:translateY(-1px); box-shadow:0 4px 16px rgba(0,229,160,.25); }

/* NO RESULTS */
.no-results { flex-direction:column; align-items:center; justify-content:center; padding:60px 20px; color:var(--text3); gap:12px; }
.no-results i { font-size:30px; opacity:.35; }
.no-results p { font-size:13px; }
.no-results button { background:none; border:1px solid var(--border2); border-radius:6px; color:var(--text2); padding:7px 14px; font-family:'Space Mono',monospace; font-size:11px; cursor:pointer; transition:all .2s; }
.no-results button:hover { background:var(--bg3); }

/* ==============================  ENTRY CARDS  ============================== */
.entries-grid { display:grid; grid-template-columns:repeat(auto-fill,minmax(300px,1fr)); gap:14px; }
.entries-grid.list-view { grid-template-columns:1fr; }

.entry-card {
    background:var(--card-bg); border:1px solid var(--border);
    border-radius:12px; overflow:hidden;
    transition:transform .25s, border-color .25s, box-shadow .25s, opacity .3s;
}
.entry-card:hover { border-color:var(--border2); transform:translateY(-2px); box-shadow:var(--shadow); }
.entry-card.highlight { border-color:rgba(0,229,160,.4); box-shadow:0 0 0 1px rgba(0,229,160,.15); }

.card-header { display:flex; align-items:center; gap:10px; padding:12px 14px; border-bottom:1px solid var(--border); background:var(--bg3); }
.card-avatar {
    width:34px;height:34px; border-radius:9px; flex-shrink:0;
    background:hsl(var(--hue,160deg),55%,22%);
    border:1px solid hsl(var(--hue,160deg),55%,32%);
    display:flex;align-items:center;justify-content:center;
    font-size:14px; font-family:'Syne',sans-serif; font-weight:800;
    color:hsl(var(--hue,160deg),75%,68%); user-select:none;
}
[data-theme="light"] .card-avatar { background:hsl(var(--hue,160deg),55%,90%); border-color:hsl(var(--hue,160deg),45%,75%); color:hsl(var(--hue,160deg),55%,35%); }
.new-avatar { background:rgba(0,229,160,.08); border:1px dashed rgba(0,229,160,.3); color:var(--accent); font-size:13px; }

.card-meta { flex:1; min-width:0; display:flex; flex-direction:column; gap:2px; }
.card-meta-top { display:flex; align-items:center; gap:6px; }
.card-num { font-size:10px; color:var(--text3); letter-spacing:.5px; }

.cat-badge {
    font-size:9px; padding:2px 7px; border-radius:20px; font-weight:700; letter-spacing:.3px;
    background:rgba(59,158,255,.1); color:var(--accent2); border:1px solid rgba(59,158,255,.2);
}

.input-title { background:transparent; border:none; color:var(--text); font-family:'Space Mono',monospace; font-size:12px; font-weight:700; outline:none; width:100%; padding:2px 0; border-bottom:1px solid transparent; transition:border-color .2s; }
.input-title:focus { border-bottom-color:var(--accent); }
.input-title::placeholder { color:var(--text3); font-weight:400; }

.card-toggle { background:none; border:none; color:var(--text3); cursor:pointer; font-size:12px; padding:5px; border-radius:5px; transition:all .2s; flex-shrink:0; }
.card-toggle:hover { color:var(--accent2); background:rgba(59,158,255,.08); }

.card-body { padding:12px 14px; max-height:400px; opacity:1; transition:max-height .3s ease, opacity .3s ease; overflow:hidden; }

/* KATEGORİ SATIRI */
.cat-row { display:flex; align-items:center; gap:8px; margin-bottom:8px; }
.cat-row label { font-size:10px; color:var(--text3); white-space:nowrap; display:flex;align-items:center;gap:4px; }
.cat-select-inline { background:var(--bg4); border:1px solid var(--border2); border-radius:5px; color:var(--text2); font-family:'Space Mono',monospace; font-size:10px; padding:3px 6px; outline:none; cursor:pointer; transition:all .2s; }
.cat-select-inline:focus { border-color:var(--accent); color:var(--text); }

.input-content { width:100%; background:var(--input-bg); border:1px solid var(--border); border-radius:6px; color:var(--text); font-family:'Space Mono',monospace; font-size:12px; line-height:1.7; padding:9px 11px; resize:vertical; outline:none; transition:all .2s; min-height:65px; }
.input-content:focus { border-color:var(--accent); background:var(--bg4); box-shadow:0 0 0 2px rgba(0,229,160,.06); }
.input-content::placeholder { color:var(--text3); }

.card-actions { display:flex; gap:7px; margin-top:9px; align-items:center; }
.btn-copy { background:rgba(59,158,255,.08); border:1px solid rgba(59,158,255,.2); border-radius:5px; color:var(--accent2); font-family:'Space Mono',monospace; font-size:10px; padding:5px 10px; cursor:pointer; transition:all .2s; display:flex;align-items:center;gap:4px; }
.btn-copy:hover { background:rgba(59,158,255,.16); }
.btn-copy.copied { background:rgba(0,229,160,.1); border-color:rgba(0,229,160,.3); color:var(--accent); }
.btn-delete { background:none; border:1px solid transparent; border-radius:5px; color:var(--text3); font-size:12px; padding:5px 8px; cursor:pointer; transition:all .2s; margin-left:auto; display:flex;align-items:center;gap:4px; }
.btn-delete:hover { background:rgba(255,71,87,.08); border-color:rgba(255,71,87,.2); color:var(--danger); }
.btn-save-inline { background:rgba(0,229,160,.1); border:1px solid rgba(0,229,160,.25); border-radius:5px; color:var(--accent); font-family:'Space Mono',monospace; font-size:10px; padding:5px 12px; cursor:pointer; transition:all .2s; display:flex;align-items:center;gap:5px; }
.btn-save-inline:hover { background:rgba(0,229,160,.2); }

.entry-new { border-style:dashed; border-color:rgba(0,229,160,.2); background:rgba(0,229,160,.015); }
.entry-new:hover { border-color:rgba(0,229,160,.4); }
.entry-new .card-header { background:transparent; border-bottom-color:rgba(0,229,160,.1); }

/* ==============================  OTO-KİLİT  ============================== */
.autohide-overlay {
    position:fixed; inset:0; z-index:9998;
    background:rgba(5,7,12,0.94);
    backdrop-filter:blur(12px);
    display:flex; align-items:center; justify-content:center;
}
.autohide-box {
    text-align:center; padding:50px 40px;
    background:var(--bg2); border:1px solid var(--border2);
    border-radius:20px; box-shadow:var(--shadow);
    max-width:360px; width:90%;
}
.autohide-icon { width:72px;height:72px; background:rgba(255,71,87,.1); border:1px solid rgba(255,71,87,.25); border-radius:18px; display:flex;align-items:center;justify-content:center; font-size:28px; color:var(--danger); margin:0 auto 20px; }
.autohide-box h3 { font-family:'Syne',sans-serif; font-size:22px; font-weight:800; margin-bottom:8px; }
.autohide-box p { color:var(--text2); font-size:12px; margin-bottom:24px; }
.btn-unlock { background:linear-gradient(135deg,var(--accent),#00b37d); border:none; border-radius:8px; color:#0a2e20; font-family:'Space Mono',monospace; font-size:13px; font-weight:700; padding:12px 28px; cursor:pointer; transition:all .2s; display:inline-flex;align-items:center;gap:8px; }
.btn-unlock:hover { transform:translateY(-2px); box-shadow:0 6px 20px rgba(0,229,160,.3); }

/* ==============================  MODAL  ============================== */
.modal-overlay {
    position:fixed; inset:0; z-index:999;
    background:rgba(0,0,0,.6); backdrop-filter:blur(6px);
    display:flex; align-items:center; justify-content:center; padding:20px;
}
.modal-box {
    background:var(--bg2); border:1px solid var(--border2);
    border-radius:16px; width:100%; max-width:500px;
    box-shadow:var(--shadow); animation:cardIn .3s ease both;
}
.modal-header { display:flex; align-items:center; justify-content:space-between; padding:18px 22px; border-bottom:1px solid var(--border); }
.modal-header h3 { font-family:'Syne',sans-serif; font-size:16px; font-weight:800; display:flex;align-items:center;gap:8px; }
.modal-header h3 i { color:var(--accent2); }
.modal-close { background:none; border:none; color:var(--text3); cursor:pointer; font-size:16px; padding:4px; border-radius:5px; transition:all .2s; }
.modal-close:hover { color:var(--danger); background:rgba(255,71,87,.08); }
.modal-body { padding:22px; display:flex; flex-direction:column; gap:20px; }
.modal-divider { border:none; border-top:1px solid var(--border); margin:4px 0; }

.backup-section { display:flex; flex-direction:column; gap:10px; }
.backup-section h4 { font-size:13px; font-weight:700; display:flex;align-items:center;gap:7px; color:var(--text); }
.backup-section h4 i { color:var(--accent); }
.backup-section p { font-size:12px; color:var(--text2); }

.warning-text { font-size:11px; color:#f0a050; background:rgba(240,160,80,.08); border:1px solid rgba(240,160,80,.2); border-radius:5px; padding:8px 12px; display:flex;align-items:center;gap:6px; }
.warning-text i { color:#f0a050; }

.file-upload-area {
    display:flex; flex-direction:column; align-items:center; gap:8px;
    padding:20px; border:2px dashed var(--border2);
    border-radius:8px; cursor:pointer;
    color:var(--text3); font-size:12px;
    transition:all .2s;
}
.file-upload-area:hover, .file-upload-area.drag-over { border-color:var(--accent); background:rgba(0,229,160,.04); color:var(--accent); }
.file-upload-area i { font-size:22px; }
.selected-file { font-size:11px; color:var(--accent); display:flex;align-items:center;gap:6px; padding:6px 10px; background:rgba(0,229,160,.08); border-radius:5px; }

.btn-backup-dl { background:rgba(59,158,255,.1); border:1px solid rgba(59,158,255,.25); border-radius:7px; color:var(--accent2); font-family:'Space Mono',monospace; font-size:12px; font-weight:700; padding:10px 18px; cursor:pointer; display:flex;align-items:center;gap:7px; transition:all .2s; }
.btn-backup-dl:hover { background:rgba(59,158,255,.2); }
.btn-backup-ul { background:rgba(0,229,160,.1); border:1px solid rgba(0,229,160,.25); border-radius:7px; color:var(--accent); font-family:'Space Mono',monospace; font-size:12px; font-weight:700; padding:10px 18px; cursor:pointer; display:flex;align-items:center;gap:7px; transition:all .2s; margin-top:8px; }
.btn-backup-ul:hover { background:rgba(0,229,160,.2); }

/* ==============================  TOAST  ============================== */
.toast {
    position:fixed; top:18px; right:22px; z-index:9999;
    padding:11px 18px; border-radius:7px; font-size:12px; font-weight:700;
    display:flex;align-items:center;gap:9px;
    box-shadow:var(--shadow); animation:toastIn .3s cubic-bezier(.34,1.56,.64,1) both;
    transition:opacity .3s, transform .3s;
}
.toast-success { background:rgba(0,229,160,.12); border:1px solid rgba(0,229,160,.3); color:var(--accent); }
.toast-error { background:rgba(255,71,87,.12); border:1px solid rgba(255,71,87,.3); color:var(--danger); }
@keyframes toastIn { from{opacity:0;transform:translateX(30px);} to{opacity:1;transform:translateX(0);} }

/* ==============================  LOGS PAGE  ============================== */
.logs-header { display:flex; flex-direction:column; gap:16px; margin-bottom:20px; }
.logs-stats { display:flex; gap:12px; flex-wrap:wrap; }
.stat-card {
    background:var(--bg2); border:1px solid var(--border); border-radius:10px;
    padding:14px 18px; display:flex; align-items:center; gap:12px; flex:1; min-width:140px;
}
.stat-card > i { font-size:20px; color:var(--accent2); opacity:.7; }
.stat-val { display:block; font-family:'Syne',sans-serif; font-size:20px; font-weight:800; line-height:1; }
.stat-label { display:block; font-size:10px; color:var(--text3); margin-top:3px; }

.logs-actions { display:flex; gap:10px; align-items:center; flex-wrap:wrap; }

.logs-table-wrap { background:var(--bg2); border:1px solid var(--border); border-radius:12px; overflow:hidden; }
.logs-table { width:100%; border-collapse:collapse; }
.logs-table thead tr { background:var(--bg3); }
.logs-table th { padding:11px 14px; font-size:10px; color:var(--text3); text-align:left; letter-spacing:.5px; text-transform:uppercase; border-bottom:1px solid var(--border); font-weight:700; }
.logs-table th i { margin-right:4px; }
.logs-table td { padding:10px 14px; font-size:12px; border-bottom:1px solid var(--border); }
.logs-table tr:last-child td { border-bottom:none; }
.logs-table tr:hover td { background:var(--bg3); }
.log-num { color:var(--text3); font-size:11px; width:40px; }

.ip-tag { display:inline-flex; align-items:center; gap:5px; font-size:11px; }
.ip-tag i { color:var(--text3); }
.ip-current i { color:var(--accent); }

.badge-today { font-size:9px; background:rgba(0,229,160,.1); color:var(--accent); border:1px solid rgba(0,229,160,.25); border-radius:20px; padding:1px 7px; margin-left:6px; font-weight:700; }
.badge-me { font-size:9px; background:rgba(59,158,255,.1); color:var(--accent2); border:1px solid rgba(59,158,255,.25); border-radius:20px; padding:1px 7px; margin-left:6px; font-weight:700; }
.freq-badge { font-size:10px; background:var(--bg4); color:var(--text3); border-radius:5px; padding:2px 7px; }
.current-ip td { background:rgba(0,229,160,.02) !important; }

.btn-danger { background:rgba(255,71,87,.1); border:1px solid rgba(255,71,87,.25); border-radius:6px; color:var(--danger); font-family:'Space Mono',monospace; font-size:11px; padding:8px 14px; cursor:pointer; display:flex;align-items:center;gap:6px; transition:all .2s; }
.btn-danger:hover { background:rgba(255,71,87,.2); }

/* ==============================  RESPONSIVE  ============================== */
@media(max-width:640px){
    .vault-main { padding:12px; }
    .toolbar { flex-direction:column; align-items:stretch; }
    .toolbar-actions { justify-content:flex-end; }
    .entries-grid { grid-template-columns:1fr; }
    .login-card { padding:28px 18px; }
    .logs-stats { flex-direction:column; }
}

/* ---- Legacy compat ---- */
.gri { color:var(--text3); }
.button { background:rgba(0,229,160,.1); border:1px solid rgba(0,229,160,.25); border-radius:6px; color:var(--accent); font-family:'Space Mono',monospace; font-size:12px; padding:8px 14px; cursor:pointer; transition:all .2s; }
.button:hover { background:rgba(0,229,160,.2); }

/* ==============================
   ŞİFRE GÜÇ GÖSTERGESİ
   ============================== */
.textarea-wrap { position:relative; }

.strength-bar-wrap {
    display:flex; align-items:center; gap:8px;
    margin-top:5px; margin-bottom:6px;
}
.strength-bar {
    flex:1; height:3px; background:var(--bg4);
    border-radius:2px; overflow:hidden;
}
.strength-fill {
    height:100%; width:0; border-radius:2px;
    transition:width .4s ease, background .4s ease;
}
.strength-label {
    font-size:10px; font-weight:700;
    white-space:nowrap; min-width:80px;
    text-align:right; transition:color .4s;
}

/* Mini şifre üretici butonu */
.pw-gen-mini {
    background:rgba(0,229,160,.07);
    border:1px solid rgba(0,229,160,.2);
    border-radius:5px; color:var(--accent);
    font-family:'Space Mono',monospace;
    font-size:10px; padding:4px 10px;
    cursor:pointer; transition:all .2s;
    display:inline-flex; align-items:center; gap:5px;
    margin-bottom:6px;
}
.pw-gen-mini:hover { background:rgba(0,229,160,.15); transform:translateY(-1px); }

/* ==============================
   ŞİFRE ÜRETİCİ MODAL
   ============================== */
.modal-wide { max-width:560px; }

.pw-output-wrap {
    display:flex; align-items:center; gap:8px;
    background:var(--bg3); border:1px solid var(--border2);
    border-radius:8px; padding:12px 14px;
    margin-bottom:8px;
}
.pw-output {
    flex:1; font-family:'Space Mono',monospace;
    font-size:15px; font-weight:700;
    color:var(--accent); word-break:break-all;
    letter-spacing:1px; line-height:1.5;
}
.pw-copy-btn, .pw-regen-btn {
    width:34px; height:34px; flex-shrink:0;
    border:1px solid var(--border2); border-radius:6px;
    background:var(--bg4); color:var(--text2);
    cursor:pointer; font-size:13px;
    display:flex; align-items:center; justify-content:center;
    transition:all .2s;
}
.pw-copy-btn:hover { color:var(--accent); border-color:rgba(0,229,160,.3); background:rgba(0,229,160,.08); }
.pw-regen-btn:hover { color:var(--accent2); border-color:rgba(59,158,255,.3); background:rgba(59,158,255,.08); }

.pw-settings { display:flex; flex-direction:column; gap:12px; margin-top:12px; }
.pw-setting-row {
    display:flex; align-items:center; justify-content:space-between; gap:12px;
    font-size:12px; color:var(--text2);
}
.pw-setting-row input[type=range] {
    flex:1; accent-color:var(--accent);
    cursor:pointer; height:4px;
}
.pw-setting-row strong { color:var(--accent); min-width:24px; text-align:right; }

.pw-checkboxes { display:flex; flex-wrap:wrap; gap:8px; }
.pw-check {
    display:flex; align-items:center; gap:6px;
    font-size:11px; color:var(--text2); cursor:pointer;
    background:var(--bg3); border:1px solid var(--border);
    border-radius:6px; padding:6px 10px;
    transition:all .2s; user-select:none;
}
.pw-check:hover { border-color:var(--border2); color:var(--text); }
.pw-check input { accent-color:var(--accent); cursor:pointer; }
.pw-check span { font-family:'Space Mono',monospace; color:var(--accent); font-size:10px; }

.pw-bulk-list {
    background:var(--bg3); border:1px solid var(--border);
    border-radius:8px; padding:8px;
    display:flex; flex-direction:column; gap:4px;
    max-height:200px; overflow-y:auto; margin-top:8px;
}
.pw-bulk-item {
    display:flex; align-items:center; justify-content:space-between;
    padding:6px 10px; background:var(--bg4);
    border-radius:5px; font-family:'Space Mono',monospace;
    font-size:12px; color:var(--text);
}
.pw-bulk-copy {
    background:none; border:none; color:var(--text3);
    cursor:pointer; padding:3px 6px; border-radius:4px;
    font-size:12px; transition:all .2s;
}
.pw-bulk-copy:hover { color:var(--accent); }

/* ==============================
   PIN DEĞİŞTİR
   ============================== */
.pin-change-info {
    background:rgba(59,158,255,.08); border:1px solid rgba(59,158,255,.2);
    border-radius:6px; padding:10px 14px;
    font-size:11px; color:var(--accent2);
    display:flex; align-items:flex-start; gap:8px;
    margin-bottom:16px; line-height:1.6;
}
.pin-field-group { margin-bottom:14px; }
.pin-field-group > label {
    display:block; font-size:11px; color:var(--text2);
    margin-bottom:6px; letter-spacing:.4px; text-transform:uppercase;
}
.pin-match-msg { font-size:11px; margin-top:6px; font-weight:700; }

/* ==============================
   SÜRÜKLE-BIRAK
   ============================== */
.drag-handle {
    color:var(--text3); cursor:grab; padding:4px 6px;
    border-radius:4px; font-size:13px;
    opacity:0; transition:opacity .2s, color .2s;
    flex-shrink:0; touch-action:none;
}
.drag-handle:hover { color:var(--accent); }
.drag-handle:active { cursor:grabbing; }

.entry-card.dragging {
    opacity:.5; transform:scale(.97);
    box-shadow:0 12px 40px rgba(0,0,0,.5);
    z-index:10;
}
.entry-card.drag-over-card {
    border-color:var(--accent) !important;
    box-shadow:0 0 0 2px rgba(0,229,160,.25) !important;
}

.drag-banner {
    display:flex; align-items:center; gap:10px;
    background:rgba(0,229,160,.08);
    border:1px solid rgba(0,229,160,.25);
    border-radius:8px; padding:10px 16px;
    font-size:12px; color:var(--accent);
    margin-bottom:16px;
}
.drag-banner i { flex-shrink:0; }
.drag-exit {
    margin-left:auto; background:rgba(0,229,160,.1);
    border:1px solid rgba(0,229,160,.3);
    border-radius:5px; color:var(--accent);
    font-family:'Space Mono',monospace; font-size:11px;
    padding:4px 10px; cursor:pointer; transition:all .2s;
    display:flex; align-items:center; gap:5px;
}
.drag-exit:hover { background:rgba(0,229,160,.2); }

/* Topbar accent btn */
.btn-accent {
    background:rgba(0,229,160,.1) !important;
    border-color:rgba(0,229,160,.3) !important;
    color:var(--accent) !important;
}
.btn-accent:hover {
    background:rgba(0,229,160,.18) !important;
}

