/* ============================================================
   member.css  -  Profile, Notifications, Bookmarks, Messages
   ============================================================ */

/* ---- Flash messages ---- */
.flash { padding:12px 16px; border-radius:7px; margin-bottom:16px; font-size:14px; }
.flash--ok  { background:#d1fae5; color:#065f46; border:1px solid #6ee7b7; }
.flash--err { background:#fee2e2; color:#991b1b; border:1px solid #fca5a5; }

/* ---- Profile page ---- */
.profile-wrap   { max-width:760px; margin:32px auto; padding:0 16px; }
.profile-card   { background:#fff; border-radius:12px; border:1px solid #e5e7eb; overflow:hidden; margin-bottom:20px; }

.profile-header {
    display:flex; align-items:flex-start; gap:20px;
    padding:24px; border-bottom:1px solid #f3f4f6; flex-wrap:wrap;
}
.profile-avatar { width:80px; height:80px; border-radius:50%; object-fit:cover; border:3px solid #e5e7eb; flex-shrink:0; }
.profile-header__info { flex:1; min-width:180px; }
.profile-name { font-size:22px; font-weight:800; color:#111; margin:0 0 6px; }
.profile-region { font-size:13px; color:#6b7280; margin-left:8px; }
.profile-karma  { font-size:13px; color:#6b7280; margin-top:6px; }
.profile-header__actions { margin-left:auto; }

.profile-bio { padding:16px 24px; font-size:15px; color:#374151; border-bottom:1px solid #f3f4f6; }

.profile-meta { display:flex; flex-wrap:wrap; gap:0; }
.profile-meta__item {
    flex:1; min-width:140px; padding:14px 20px;
    border-right:1px solid #f3f4f6;
}
.profile-meta__item:last-child { border-right:none; }
.profile-meta__label { font-size:11px; text-transform:uppercase; letter-spacing:0.06em; color:#9ca3af; margin-bottom:4px; }
.profile-meta__val   { font-size:16px; font-weight:700; color:#1e3a5f; }
.profile-meta__val a { color:#3b82f6; text-decoration:none; }

.profile-quick-links { display:grid; grid-template-columns:repeat(4,1fr); gap:12px; }
.profile-ql-card {
    background:#fff; border-radius:10px; border:1px solid #e5e7eb;
    padding:18px 12px; text-align:center; text-decoration:none;
    color:#374151; transition:all 0.15s; display:flex; flex-direction:column; align-items:center; gap:6px;
}
.profile-ql-card:hover { border-color:#3b82f6; background:#eff6ff; color:#1d4ed8; }
.profile-ql-card__icon { font-size:26px; }
@media(max-width:600px){ .profile-quick-links{ grid-template-columns:repeat(2,1fr); } }

.profile-avatar-preview { width:60px; height:60px; border-radius:50%; margin-top:8px; object-fit:cover; border:2px solid #e5e7eb; }

/* ---- Form card (profile edit, etc.) ---- */
.form-wrap  { max-width:620px; margin:32px auto; padding:0 16px; }
.form-card  { background:#fff; border-radius:12px; border:1px solid #e5e7eb; padding:28px; }
.form-card__title { font-size:20px; font-weight:800; color:#111; margin:0 0 22px; }

.form-group   { margin-bottom:18px; }
.form-label   { display:block; font-size:14px; font-weight:600; color:#374151; margin-bottom:6px; }
.form-input   { width:100%; padding:10px 12px; border:1px solid #d1d5db; border-radius:7px; font-size:14px; font-family:inherit; box-sizing:border-box; }
.form-input:focus { outline:none; border-color:#3b82f6; box-shadow:0 0 0 3px rgba(59,130,246,0.1); }
.form-hint    { font-size:12px; color:#9ca3af; margin-top:4px; }
.form-actions { display:flex; gap:10px; margin-top:24px; }

/* ---- Buttons ---- */
.btn { display:inline-flex; align-items:center; gap:5px; padding:9px 18px; border-radius:7px; font-size:14px; font-weight:600; cursor:pointer; text-decoration:none; border:none; font-family:inherit; transition:all 0.15s; }
.btn--primary  { background:#1e3a5f; color:#fff; }
.btn--primary:hover { background:#152e4d; }
.btn--outline  { background:transparent; color:#1e3a5f; border:1px solid #c5d2de; }
.btn--outline:hover  { background:#f0f4f8; }
.btn--ghost    { background:transparent; color:#374151; border:1px solid #e5e7eb; }
.btn--ghost:hover    { background:#f9fafb; }
.btn--sm { padding:6px 12px; font-size:13px; }

/* ---- Notifications ---- */
.notif-wrap   { max-width:700px; margin:32px auto; padding:0 16px; }
.notif-header { display:flex; align-items:center; justify-content:space-between; margin-bottom:18px; }
.notif-title  { font-size:22px; font-weight:800; color:#111; margin:0; }
.notif-empty  { text-align:center; padding:60px 0; color:#9ca3af; font-size:16px; }

.notif-list { display:flex; flex-direction:column; gap:0; background:#fff; border-radius:12px; border:1px solid #e5e7eb; overflow:hidden; }
.notif-item {
    display:flex; align-items:flex-start; gap:14px;
    padding:14px 18px; border-bottom:1px solid #f3f4f6;
    transition:background 0.1s;
}
.notif-item:last-child { border-bottom:none; }
.notif-item:hover { background:#f9fafb; }
.notif-item--unread { background:#eff6ff; }
.notif-item--unread:hover { background:#dbeafe; }
.notif-item__icon  { font-size:22px; flex-shrink:0; width:32px; text-align:center; }
.notif-item__body  { flex:1; min-width:0; }
.notif-item__title { font-size:14px; font-weight:600; color:#111; }
.notif-item__title a { color:#1d4ed8; text-decoration:none; }
.notif-item__msg   { font-size:13px; color:#6b7280; margin-top:2px; }
.notif-item__time  { font-size:12px; color:#9ca3af; flex-shrink:0; }
.notif-pagination  { margin-top:16px; }

/* ---- Nav user area ---- */
.nav-user-area { display:flex; align-items:center; gap:10px; }

.nav-notif-btn {
    position:relative; color:#374151; text-decoration:none; font-size:18px;
    display:flex; align-items:center; padding:4px;
}
.nav-notif-badge {
    position:absolute; top:-4px; right:-4px;
    background:#dc2626; color:#fff; border-radius:9999px;
    font-size:10px; font-weight:700; min-width:16px; height:16px;
    display:flex; align-items:center; justify-content:center; padding:0 3px;
    line-height:1;
}

.nav-user-drop { position:relative; }
.nav-user-drop__trigger {
    display:flex; align-items:center; gap:7px;
    background:none; border:none; cursor:pointer; padding:6px 10px;
    border-radius:8px; font-size:14px; color:#111;
    transition:background 0.15s; font-family:inherit;
}
.nav-user-drop__trigger:hover { background:#f3f4f6; }
.nav-user-avatar { width:28px; height:28px; border-radius:50%; object-fit:cover; border:2px solid #e5e7eb; }
.nav-user-name   { max-width:90px; overflow:hidden; text-overflow:ellipsis; white-space:nowrap; }

.nav-user-drop__menu {
    position:absolute; right:0; top:calc(100% + 8px);
    background:#fff; border:1px solid #e5e7eb; border-radius:10px;
    box-shadow:0 8px 24px rgba(0,0,0,0.12);
    min-width:180px; z-index:200; padding:6px 0;
    display:none;
}
.nav-user-drop.is-open .nav-user-drop__menu { display:block; }
.nav-user-drop__item {
    display:block; padding:9px 16px; font-size:14px;
    color:#374151; text-decoration:none; transition:background 0.1s;
    white-space:nowrap;
}
.nav-user-drop__item:hover { background:#f3f4f6; color:#111; }
.nav-user-drop__divider { border-top:1px solid #f3f4f6; margin:4px 0; }
.nav-user-drop__btn {
    width:100%; text-align:left; background:none; border:none;
    cursor:pointer; font-family:inherit;
}

.nav-auth-links { display:flex; align-items:center; gap:10px; }
.nav-btn-reg {
    padding:7px 14px; background:#1e3a5f; color:#fff !important;
    border-radius:7px; font-size:13px; font-weight:600; text-decoration:none;
    transition:background 0.15s;
}
.nav-btn-reg:hover { background:#152e4d; }

/* ============================================================
   Nav user dropdown overrides  (fix_member_bugs.ps1)
   ============================================================ */

/* Make sure dropdown is above EVERYTHING including dark links-bar */
.main-nav__brand-bar { overflow:visible !important; }
.main-nav__brand-inner { overflow:visible !important; }
.main-nav__auth { position:relative !important; z-index:500 !important; overflow:visible !important; }
.nav-user-drop { position:relative !important; z-index:500 !important; }

.nav-user-drop__menu {
    position:absolute !important;
    right:0 !important;
    top:calc(100% + 6px) !important;
    background:#ffffff !important;
    border:1px solid #e2e8f0 !important;
    border-radius:10px !important;
    box-shadow:0 10px 30px rgba(0,0,0,0.2) !important;
    min-width:200px !important;
    z-index:99999 !important;
    padding:6px 0 !important;
    display:none !important;
}
.nav-user-drop.is-open .nav-user-drop__menu {
    display:block !important;
}

/* Force readable text — override any inherited nav link colors */
.nav-user-drop__menu .nav-user-drop__item,
.nav-user-drop__menu a.nav-user-drop__item {
    color:#111827 !important;
    background:transparent !important;
    font-weight:400 !important;
    text-decoration:none !important;
}
.nav-user-drop__menu .nav-user-drop__item:hover,
.nav-user-drop__menu a.nav-user-drop__item:hover {
    background:#f3f4f6 !important;
    color:#111827 !important;
}
.nav-user-drop__btn {
    color:#111827 !important;
    background:none !important;
    border:none !important;
    cursor:pointer !important;
    font-family:inherit !important;
    font-size:14px !important;
    text-align:left !important;
    width:100% !important;
}
.nav-user-drop__btn:hover {
    background:#f3f4f6 !important;
}
.nav-user-drop__divider { border-top:1px solid #f3f4f6 !important; margin:4px 0 !important; }

/* Notification badge */
.nav-notif-btn { position:relative !important; color:#374151 !important; text-decoration:none !important; font-size:18px !important; display:flex !important; align-items:center !important; padding:4px !important; }
.nav-notif-badge { position:absolute !important; top:-4px !important; right:-4px !important; background:#dc2626 !important; color:#fff !important; border-radius:9999px !important; font-size:10px !important; font-weight:700 !important; min-width:16px !important; height:16px !important; display:flex !important; align-items:center !important; justify-content:center !important; padding:0 3px !important; line-height:1 !important; }

/* User trigger button */
.nav-user-drop__trigger { display:flex !important; align-items:center !important; gap:7px !important; background:none !important; border:none !important; cursor:pointer !important; padding:5px 8px !important; border-radius:8px !important; font-size:14px !important; color:#374151 !important; transition:background 0.15s !important; font-family:inherit !important; }
.nav-user-drop__trigger:hover { background:rgba(0,0,0,0.07) !important; }
.nav-user-avatar { width:30px !important; height:30px !important; border-radius:50% !important; object-fit:cover !important; border:2px solid #e2e8f0 !important; }

/* Auth links */
.nav-auth-links { display:flex !important; align-items:center !important; gap:8px !important; }
.nav-btn-reg { padding:7px 14px !important; background:#1e3a5f !important; color:#fff !important; border-radius:7px !important; font-size:13px !important; font-weight:600 !important; text-decoration:none !important; }
/* Brand-bar must be ABOVE links-bar in main-nav stacking context */
.main-nav__brand-bar {
    position: relative !important;
    z-index: 200 !important;
    overflow: visible !important;
}
