/* =========================================================
   Vejbystrand Konsult AB – Admin Stylesheet
   ========================================================= */

*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }

:root {
    --navy:    #1a2744;
    --navy-dk: #111c33;
    --gold:    #c9a96e;
    --gold-lt: #dfc48c;
    --cream:   #f8f6f0;
    --white:   #ffffff;
    --text:    #2d2d2d;
    --side-w:  240px;
    --radius:  6px;
    --trans:   .25s ease;
    --danger:  #dc3545;
    --success: #198754;
}

body { font-family: 'Inter', system-ui, sans-serif; font-size: 15px; color: var(--text); }
a    { color: var(--navy); text-decoration: none; }

/* ---------- Login Page ---------- */
.login-page { background: var(--navy-dk); display: flex; align-items: center; justify-content: center; min-height: 100vh; }
.login-wrap  { width: 100%; max-width: 420px; padding: 1rem; }
.login-card  { background: var(--white); border-radius: 12px; padding: 2.5rem 2rem; box-shadow: 0 20px 60px rgba(0,0,0,.35); }
.login-brand { text-align: center; margin-bottom: 2rem; }
.login-brand h1 { font-size: 1.3rem; color: var(--navy); font-weight: 700; }
.login-brand p  { color: #888; font-size: .875rem; margin-top: .25rem; }
.back-link   { text-align: center; margin-top: 1.25rem; font-size: .85rem; color: #888; }

/* ---------- Admin Layout ---------- */
.admin-body   { background: #f0f2f5; min-height: 100vh; }
.admin-layout { display: grid; grid-template-columns: var(--side-w) 1fr; min-height: 100vh; }

/* Sidebar */
.admin-sidebar {
    background: var(--navy-dk);
    color: var(--white);
    display: flex;
    flex-direction: column;
    position: sticky;
    top: 0;
    height: 100vh;
    overflow-y: auto;
}
.sidebar-logo {
    padding: 1.5rem 1.25rem;
    border-bottom: 1px solid rgba(255,255,255,.08);
}
.sidebar-logo span { display: block; font-size: .95rem; font-weight: 700; color: var(--gold); line-height: 1.3; }
.sidebar-logo small { font-size: .75rem; color: rgba(255,255,255,.45); }

.sidebar-nav { flex: 1; padding: 1rem 0; }
.sidebar-nav ul { list-style: none; }
.sidebar-nav a {
    display: block;
    padding: .65rem 1.25rem;
    color: rgba(255,255,255,.72);
    font-size: .875rem;
    transition: background var(--trans), color var(--trans);
    border-left: 3px solid transparent;
}
.sidebar-nav a:hover, .sidebar-nav a.active {
    background: rgba(255,255,255,.06);
    color: var(--gold);
    border-left-color: var(--gold);
}
.sidebar-sep { border-top: 1px solid rgba(255,255,255,.08); margin: .5rem 0; }

.sidebar-user {
    padding: 1rem 1.25rem;
    border-top: 1px solid rgba(255,255,255,.08);
    font-size: .78rem;
    color: rgba(255,255,255,.4);
}

/* Main area */
.admin-main {
    padding: 2rem 2.5rem;
    max-width: 1200px;
}

.admin-topbar {
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin-bottom: 1.5rem;
}
.admin-topbar h1 { font-size: 1.5rem; color: var(--navy-dk); }

/* Cards */
.admin-card {
    background: var(--white);
    border-radius: 10px;
    padding: 1.75rem 2rem;
    box-shadow: 0 2px 12px rgba(0,0,0,.06);
}
.admin-card h2 { font-size: 1.1rem; color: var(--navy); margin-bottom: .75rem; }

/* Table */
.admin-table { width: 100%; border-collapse: collapse; font-size: .875rem; }
.admin-table thead th {
    text-align: left;
    padding: .75rem 1rem;
    font-size: .78rem;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: .05em;
    color: #888;
    border-bottom: 2px solid #eee;
    white-space: nowrap;
}
.admin-table tbody td {
    padding: .85rem 1rem;
    border-bottom: 1px solid #f0f0f0;
    vertical-align: middle;
}
.admin-table tbody tr:last-child td { border-bottom: none; }
.admin-table tbody tr:hover { background: #fafafa; }

.row-actions { display: flex; gap: .4rem; flex-wrap: wrap; }

code { font-size: .82rem; background: #f0f2f5; padding: .15rem .4rem; border-radius: 4px; color: #555; }

/* Badges */
.badge { display: inline-block; padding: .2rem .65rem; border-radius: 50px; font-size: .75rem; font-weight: 600; }
.badge-ok  { background: #d4edda; color: #155724; }
.badge-off { background: #f0f2f5; color: #888; }

/* ---------- Forms ---------- */
.form-group { margin-bottom: 1.25rem; }
.form-group label { display: block; font-size: .85rem; font-weight: 600; color: #444; margin-bottom: .4rem; }
.form-group small  { font-size: .78rem; font-weight: 400; color: #888; margin-left: .35rem; }
.form-group input[type=text],
.form-group input[type=url],
.form-group input[type=email],
.form-group input[type=password],
.form-group input[type=number],
.form-group select,
.form-group textarea {
    width: 100%;
    padding: .65rem .9rem;
    border: 1.5px solid #ddd;
    border-radius: var(--radius);
    font-size: .9rem;
    font-family: inherit;
    color: var(--text);
    transition: border-color var(--trans);
    background: var(--white);
}
.form-group input:focus,
.form-group select:focus,
.form-group textarea:focus { outline: none; border-color: var(--gold); }

.form-row { display: grid; grid-template-columns: 1fr 1fr; gap: 1.25rem; }
.form-check { display: flex; align-items: center; gap: .6rem; }
.form-check input[type=checkbox] { width: 16px; height: 16px; accent-color: var(--navy); }
.form-check label { font-weight: 400; }

.form-actions { display: flex; gap: .75rem; margin-top: 1.5rem; padding-top: 1.25rem; border-top: 1px solid #eee; }

.code-textarea {
    font-family: 'Cascadia Code', 'Fira Code', monospace;
    font-size: .82rem;
    line-height: 1.5;
    color: #333;
    background: #fafafa;
    resize: vertical;
}

/* Content preview */
.content-preview {
    border: 1.5px solid var(--gold);
    border-radius: var(--radius);
    padding: 1.25rem;
    margin-top: .5rem;
    background: var(--white);
    min-height: 80px;
}

/* Background image preview */
.bg-preview {
    height: 120px;
    border-radius: var(--radius);
    margin-top: .5rem;
    background-size: cover;
    background-position: center;
    border: 1px solid #ddd;
}

/* ---------- Alerts ---------- */
.alert {
    padding: .85rem 1.1rem;
    border-radius: var(--radius);
    font-size: .875rem;
    margin-bottom: 1.25rem;
}
.alert-success { background: #d4edda; color: #155724; border: 1px solid #c3e6cb; }
.alert-error   { background: #f8d7da; color: #721c24; border: 1px solid #f5c6cb; }

/* ---------- Buttons ---------- */
.btn {
    display: inline-flex;
    align-items: center;
    gap: .35rem;
    padding: .6rem 1.25rem;
    border-radius: var(--radius);
    font-size: .875rem;
    font-weight: 600;
    cursor: pointer;
    border: 2px solid transparent;
    transition: all var(--trans);
    text-decoration: none;
    white-space: nowrap;
    line-height: 1;
}
.btn-primary  { background: var(--navy); color: var(--white); border-color: var(--navy); }
.btn-primary:hover  { background: var(--navy-dk); border-color: var(--navy-dk); color: var(--white); }
.btn-secondary { background: #6c757d; color: var(--white); border-color: #6c757d; }
.btn-secondary:hover { background: #5a6268; color: var(--white); }
.btn-danger   { background: var(--danger); color: var(--white); border-color: var(--danger); }
.btn-danger:hover  { background: #b02a37; color: var(--white); }
.btn-ghost    { background: transparent; color: var(--navy); border-color: #ddd; }
.btn-ghost:hover  { background: #f0f2f5; color: var(--navy); }
.btn-full     { width: 100%; justify-content: center; }
.btn-sm       { padding: .35rem .75rem; font-size: .8rem; }

/* Code example block */
.code-example {
    background: #1e1e1e;
    color: #d4d4d4;
    padding: 1.25rem 1.5rem;
    border-radius: var(--radius);
    font-family: 'Cascadia Code', 'Fira Code', monospace;
    font-size: .82rem;
    overflow-x: auto;
    white-space: pre;
    margin-top: .75rem;
    line-height: 1.6;
}
