/* style.css */
:root {
    --bg-color: #121212;
    --container-bg: #1e1e1e;
    --text-color: #e0e0e0;
    --text-muted: #bbb;
    --border-color: #333;
    --accent-color: #bb86fc;
    --header-bg: #2c2c2c;
    --row-even: #252525;
    --row-hover: #333;
    --input-bg: #2c2c2c;
    --btn-primary: #3700b3;
    --btn-primary-hover: #6200ea;
    --btn-edit: #03dac5;
    --btn-delete: #cf6679;
}

body { 
    font-family: 'Segoe UI', Tahoma, Geneva, Verdana, sans-serif; 
    padding: 20px; 
    background-color: var(--bg-color); 
    color: var(--text-color);
}

h1 { margin-top: 0; color: #fff; margin-bottom: 20px; }

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

/* --- CONTAINERS --- */
.container { 
    max-width: 95%; 
    margin: auto; 
    background: var(--container-bg); 
    padding: 25px; 
    border-radius: 8px;
    box-shadow: 0 4px 6px rgba(0,0,0,0.3); 
}

.form-container { 
    max-width: 700px; 
    margin: auto; 
    background: var(--container-bg); 
    padding: 30px; 
    border-radius: 8px; 
    box-shadow: 0 4px 10px rgba(0,0,0,0.5);
}

/* --- FORMS & INPUTS --- */
.search-box { margin-bottom: 20px; display: flex; gap: 10px; }

label { display: block; margin-top: 15px; font-weight: 600; color: var(--text-muted); }

input[type="text"], input[type="password"], textarea { 
    width: 100%; 
    padding: 10px; 
    margin-top: 5px; 
    box-sizing: border-box; 
    background-color: var(--input-bg); 
    border: 1px solid #444; 
    color: #fff;
    border-radius: 4px;
}

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

/* Grid Layout for Forms */
.form-row { display: grid; grid-template-columns: 1fr 1fr; gap: 20px; }

/* --- TABLES --- */
table { border-collapse: collapse; width: 100%; margin-top: 10px; font-size: 14px; }

th, td { 
    border: 1px solid var(--border-color); 
    padding: 12px 15px; 
    text-align: left; 
    white-space: nowrap; /* Prevent wrapping */
}

/* NEW: specific class to allow Email to wrap */
.email-col {
    white-space: normal;       /* Allow text to wrap */
    word-break: break-word;    /* Break long emails preventing overflow */
    min-width: 150px;          /* Ensure it doesn't get too narrow */
    max-width: 300px;          /* Limit width so it wraps reasonably */
}

th { background-color: var(--header-bg); color: #fff; font-weight: 600; }
tr:nth-child(even) { background-color: var(--row-even); }
tr:hover { background-color: var(--row-hover); }

/* --- BUTTONS --- */
.btn { 
    padding: 6px 12px; 
    text-decoration: none; 
    color: #000; 
    border-radius: 4px; 
    font-size: 13px; 
    font-weight: bold; 
    border: none; 
    cursor: pointer; 
    display: inline-block;
}

.btn-edit { background-color: var(--btn-edit); }
.btn-delete { background-color: var(--btn-delete); }

.btn-primary { 
    background-color: var(--btn-primary); 
    color: white; 
    padding: 10px 20px; 
    font-size: 14px;
}
.btn-primary:hover { background-color: var(--btn-primary-hover); }

.btn-cancel { 
    background-color: transparent; 
    border: 1px solid #444; 
    color: var(--text-muted); 
    padding: 10px 20px; 
    border-radius: 4px;
    text-align: center;
}
.btn-cancel:hover { background-color: #333; color: #fff; text-decoration: none; }

.btn-group { margin-top: 30px; display: flex; gap: 10px; }

/* --- PAGINATION --- */
.pagination { margin-top: 25px; text-align: center; }
.pagination a { 
    text-decoration: none; 
    padding: 8px 14px; 
    border: 1px solid var(--border-color); 
    color: var(--text-color); 
    margin: 0 2px; 
    border-radius: 4px;
    background: var(--input-bg);
}
.pagination a.active { 
    background-color: var(--btn-primary); 
    color: white; 
    border-color: var(--btn-primary); 
}
.pagination a:hover:not(.active) { background-color: var(--border-color); }
