:root {
    --bg: #14141c;
    --bg-card: #1d1d29;
    --border: #2c2c3a;
    --text: #e8e8f0;
    --text-dim: #8d8da3;
    --accent: #7c5cff;
    --accent-hover: #9579ff;
    --success: #2ecc71;
    --error: #ff5c6c;
    --radius: 10px;
}

* { box-sizing: border-box; }

body {
    margin: 0;
    background: var(--bg);
    color: var(--text);
    font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;
    font-size: 15px;
}

.wrap { max-width: 880px; margin: 0 auto; padding: 32px 20px 60px; }

.topbar {
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin-bottom: 28px;
}

h1 { font-size: 22px; margin: 0; font-weight: 700; }
.dot { color: var(--accent); }

.logout { color: var(--text-dim); text-decoration: none; font-size: 13px; }
.logout:hover { color: var(--text); }

.card {
    background: var(--bg-card);
    border: 1px solid var(--border);
    border-radius: var(--radius);
    padding: 24px;
    margin-bottom: 24px;
}

.card h2 { margin: 0 0 16px; font-size: 16px; font-weight: 600; }

.link-form { display: flex; flex-direction: column; gap: 12px; }

input[type="url"], input[type="text"], input[type="password"] {
    background: var(--bg);
    border: 1px solid var(--border);
    border-radius: 8px;
    padding: 11px 14px;
    color: var(--text);
    font-size: 14px;
    width: 100%;
}

input:focus { outline: none; border-color: var(--accent); }

.slug-row {
    display: flex;
    align-items: center;
    background: var(--bg);
    border: 1px solid var(--border);
    border-radius: 8px;
    overflow: hidden;
}

.slug-prefix {
    padding: 11px 0 11px 14px;
    color: var(--text-dim);
    font-size: 13px;
    white-space: nowrap;
}

.slug-row input { border: none; background: transparent; }
.slug-row input:focus { outline: none; }

button[type="submit"] {
    background: var(--accent);
    color: #fff;
    border: none;
    border-radius: 8px;
    padding: 11px 18px;
    font-size: 14px;
    font-weight: 600;
    cursor: pointer;
    align-self: flex-start;
}

button[type="submit"]:hover { background: var(--accent-hover); }

.hint { color: var(--text-dim); font-size: 12.5px; margin: 10px 0 0; }

.alert {
    padding: 10px 14px;
    border-radius: 8px;
    font-size: 13.5px;
    margin-bottom: 14px;
    display: flex;
    align-items: center;
    gap: 10px;
    flex-wrap: wrap;
}
.alert-success { background: rgba(46, 204, 113, 0.12); color: var(--success); }
.alert-error { background: rgba(255, 92, 108, 0.12); color: var(--error); }
.alert a { color: inherit; text-decoration: underline; }

.copy-btn {
    background: var(--border);
    color: var(--text);
    border: none;
    border-radius: 6px;
    padding: 4px 10px;
    font-size: 12px;
    cursor: pointer;
}
.copy-btn:hover { background: var(--accent); }
.copy-btn.small { margin-left: 8px; }

.empty { color: var(--text-dim); font-size: 14px; }

.table-wrap { overflow-x: auto; }

table { width: 100%; border-collapse: collapse; font-size: 13.5px; }
th, td { text-align: left; padding: 10px 8px; border-bottom: 1px solid var(--border); }
th { color: var(--text-dim); font-weight: 600; font-size: 12px; text-transform: uppercase; letter-spacing: 0.03em; }
td a { color: var(--accent); text-decoration: none; }
td a:hover { text-decoration: underline; }

.truncate { max-width: 280px; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; color: var(--text-dim); }

.delete-btn {
    background: transparent;
    border: 1px solid var(--border);
    color: var(--error);
    border-radius: 6px;
    padding: 5px 10px;
    font-size: 12px;
    cursor: pointer;
}
.delete-btn:hover { background: rgba(255, 92, 108, 0.1); border-color: var(--error); }

/* Login page */
.auth-wrap {
    min-height: 100vh;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 20px;
}

.auth-card {
    background: var(--bg-card);
    border: 1px solid var(--border);
    border-radius: var(--radius);
    padding: 32px;
    width: 100%;
    max-width: 340px;
    display: flex;
    flex-direction: column;
    gap: 12px;
    text-align: center;
}

.auth-card .sub { color: var(--text-dim); font-size: 13px; margin: -6px 0 8px; }

.auth-card button {
    background: var(--accent);
    color: #fff;
    border: none;
    border-radius: 8px;
    padding: 11px;
    font-weight: 600;
    cursor: pointer;
}
.auth-card button:hover { background: var(--accent-hover); }
