/* ══ DEFAULT THEME ══════════════════════════════════════════════ */
body {
    --nav-bg:        #1a1a2e;
    --nav-text:      #9aa0bc;
    --nav-active:    #ffffff;
    --nav-btn-bg:    #4f46e5;
    --nav-btn-hover: #4338ca;
    --nav-btn-text:  #ffffff;
    --accent:        #4f46e5;
    --accent-hover:  #4338ca;
    --accent-light:  #ede9fe;
    --accent-text:   #4f46e5;
    --page-bg:       #f4f5f7;
    --card-bg:       #ffffff;
    --card-radius:   12px;
    --btn-radius:    8px;
    --input-radius:  8px;
    --card-shadow:   0 2px 12px rgba(0,0,0,.07);
    --border:        #e5e7eb;
    --border-input:  #d1d5db;
    --border-focus:  #4f46e5;
    --text-primary:  #1a1a2e;
    --text-muted:    #6b7280;
    --text-hint:     #9ca3af;
    --input-bg:      #fafafa;
    --thead-bg:      #f9fafb;
    --tag-bg:        #ede9fe;
    --tag-color:     #4f46e5;
    --row-hover:     #f9fafb;
    --divider:       #f3f4f6;
}

/* ══ FIELDPIECE THEME ═══════════════════════════════════════════ */
body.theme-dark {
    --nav-bg:        #111111;
    --nav-text:      #888888;
    --nav-active:    #ffffff;
    --nav-btn-bg:    #F5A800;
    --nav-btn-hover: #d48f00;
    --nav-btn-text:  #111111;
    --accent:        #F5A800;
    --accent-hover:  #d48f00;
    --accent-light:  #fff8e1;
    --accent-text:   #b37800;
    --page-bg:       #1a1a1a;
    --card-bg:       #222222;
    --card-radius:   4px;
    --btn-radius:    3px;
    --input-radius:  3px;
    --card-shadow:   0 2px 12px rgba(0,0,0,.3);
    --border:        #333333;
    --border-input:  #444444;
    --border-focus:  #F5A800;
    --text-primary:  #f0f0f0;
    --text-muted:    #aaaaaa;
    --text-hint:     #666666;
    --input-bg:      #2a2a2a;
    --thead-bg:      #2a2a2a;
    --tag-bg:        #332800;
    --tag-color:     #F5A800;
    --row-hover:     #2a2a2a;
    --divider:       #2e2e2e;
}

/* ══ SHARED BASE ════════════════════════════════════════════════ */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }

body {
    font-family: system-ui, -apple-system, sans-serif;
    background: var(--page-bg);
    color: var(--text-primary);
    min-height: 100vh;
}

/* Nav */
nav {
    background: var(--nav-bg);
    padding: 0 32px;
    height: 56px;
    display: flex;
    align-items: center;
    justify-content: space-between;
    position: sticky;
    top: 0;
    z-index: 100;
}
nav .brand {
    font-weight: 700;
    font-size: 17px;
    color: var(--nav-active);
    text-decoration: none;
    display: flex;
    align-items: center;
    gap: 8px;
    flex-shrink: 0;
}
body.theme-dark nav .brand .brand-dot {
    width: 10px; height: 10px;
    background: var(--accent);
    display: inline-block;
    border-radius: 2px;
}
nav .nav-links {
    display: flex;
    gap: 24px;
    align-items: center;
}
nav a {
    color: var(--nav-text);
    text-decoration: none;
    font-size: 14px;
    transition: color .15s;
}
nav a:hover, nav a.active { color: var(--nav-active); }
nav .logout {
    background: var(--nav-btn-bg);
    color: var(--nav-btn-text);
    padding: 6px 16px;
    border-radius: var(--btn-radius);
    font-size: 13px;
    font-weight: 700;
}
nav .logout:hover { background: var(--nav-btn-hover); }

/* Theme toggle */
.theme-toggle {
    display: flex;
    align-items: center;
    gap: 6px;
    font-size: 12px;
    color: var(--nav-text) !important;
    background: rgba(255,255,255,.07);
    border: 1px solid rgba(255,255,255,.12);
    border-radius: 20px;
    padding: 4px 10px;
    text-decoration: none;
    transition: background .15s;
    white-space: nowrap;
}
.theme-toggle:hover { background: rgba(255,255,255,.14); color: var(--nav-active) !important; }
.theme-toggle .dot {
    width: 8px; height: 8px;
    border-radius: 50%;
    background: var(--accent);
    flex-shrink: 0;
}

/* Language picker */
.lang-picker { position: relative; }
.lang-picker-btn {
    display: flex;
    align-items: center;
    gap: 5px;
    background: rgba(255,255,255,.07);
    border: 1px solid rgba(255,255,255,.12);
    border-radius: var(--btn-radius);
    padding: 5px 10px;
    color: var(--nav-text);
    font-size: 12px;
    font-weight: 600;
    cursor: pointer;
    white-space: nowrap;
    font-family: inherit;
}
.lang-picker-btn:hover { background: rgba(255,255,255,.14); color: var(--nav-active); }
.lang-picker-btn .arrow { font-size: 9px; opacity: .6; }
.lang-dropdown {
    display: none;
    position: absolute;
    right: 0;
    top: calc(100% + 6px);
    background: var(--card-bg);
    border: 1px solid var(--border);
    border-radius: var(--card-radius);
    box-shadow: 0 8px 24px rgba(0,0,0,.18);
    min-width: 148px;
    z-index: 9999;
    overflow: hidden;
}
.lang-dropdown.open { display: block; }
.lang-dropdown a {
    display: flex;
    align-items: center;
    gap: 8px;
    padding: 9px 14px;
    font-size: 13px;
    color: var(--text-primary);
    text-decoration: none;
}
.lang-dropdown a:hover  { background: var(--thead-bg); }
.lang-dropdown a.active { font-weight: 700; color: var(--accent-text); }
body.theme-dark .lang-dropdown a.active { color: var(--accent); }

/* Hamburger */
.nav-hamburger {
    display: none;
    background: none;
    border: none;
    cursor: pointer;
    padding: 6px;
    color: var(--nav-active);
    flex-direction: column;
    gap: 5px;
    flex-shrink: 0;
}
.nav-hamburger span {
    display: block;
    width: 22px; height: 2px;
    background: currentColor;
    border-radius: 2px;
    transition: transform .2s, opacity .2s;
}
.nav-hamburger.open span:nth-child(1) { transform: translateY(7px) rotate(45deg); }
.nav-hamburger.open span:nth-child(2) { opacity: 0; }
.nav-hamburger.open span:nth-child(3) { transform: translateY(-7px) rotate(-45deg); }

/* Mobile drawer */
.nav-drawer {
    display: none;
    position: fixed;
    top: 56px; left: 0; right: 0; bottom: 0;
    background: var(--nav-bg);
    z-index: 99;
    overflow-y: auto;
    flex-direction: column;
    padding-bottom: 32px;
}
.nav-drawer.open { display: flex; }
.nav-drawer a {
    color: var(--nav-text);
    text-decoration: none;
    font-size: 16px;
    font-weight: 500;
    padding: 14px 24px;
    border-bottom: 1px solid rgba(255,255,255,.05);
    display: block;
}
.nav-drawer a:hover, .nav-drawer a.active { color: var(--nav-active); background: rgba(255,255,255,.05); }
.drawer-section {
    padding: 14px 24px 6px;
    font-size: 10px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: .8px;
    color: rgba(255,255,255,.3);
}
.drawer-lang-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
}
.drawer-lang-grid a { font-size: 14px; padding: 12px 24px; border: none; }
.drawer-lang-grid a.active { color: var(--nav-active); font-weight: 700; }
.drawer-theme {
    margin: 12px 16px 0;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 6px;
    background: rgba(255,255,255,.08);
    border: 1px solid rgba(255,255,255,.15);
    border-radius: 20px;
    padding: 10px 16px;
    color: var(--nav-active) !important;
    text-decoration: none;
    font-size: 13px;
    font-weight: 600;
}
.drawer-theme .dot { width: 7px; height: 7px; border-radius: 50%; background: var(--accent); }
.drawer-logout {
    margin: 10px 16px 0;
    background: var(--nav-btn-bg);
    color: var(--nav-btn-text) !important;
    font-weight: 700 !important;
    border-radius: var(--btn-radius) !important;
    text-align: center;
    padding: 13px 24px !important;
    font-size: 15px;
    display: block;
    text-decoration: none;
}

/* Layout */
.main { max-width: 1100px; margin: 0 auto; padding: 28px 24px; }
.page-header { display: flex; align-items: center; justify-content: space-between; gap: 12px; margin-bottom: 24px; flex-wrap: wrap; }
.page-title  { font-size: 20px; font-weight: 700; color: var(--text-primary); }

/* Buttons */
.btn {
    display: inline-flex; align-items: center; gap: 6px;
    padding: 8px 18px; border-radius: var(--btn-radius);
    font-size: 14px; font-weight: 600; cursor: pointer;
    border: none; text-decoration: none;
    transition: background .15s, color .15s;
    white-space: nowrap;
}
.btn-primary  { background: var(--accent); color: var(--nav-btn-text); }
body:not(.theme-dark) .btn-primary { color: #fff; }
.btn-primary:hover  { background: var(--accent-hover); }
body.theme-dark .btn-primary:hover { background: #d48f00; }
body.theme-light .btn-primary:hover { background: #4338ca; }
.btn-secondary { background: var(--card-bg); color: var(--text-primary); border: 1.5px solid var(--border-input); }
.btn-secondary:hover { background: var(--thead-bg); }
.btn-danger  { background: #fee2e2; color: #b91c1c; border: 1.5px solid #fecaca; }
.btn-danger:hover  { background: #fecaca; }
.btn-success { background: #d1fae5; color: #065f46; border: 1.5px solid #a7f3d0; }
.btn-success:hover { background: #a7f3d0; }
.btn-sm { padding: 5px 12px; font-size: 13px; }

/* Cards */
.card { background: var(--card-bg); border-radius: var(--card-radius); box-shadow: var(--card-shadow); padding: 28px 32px; }

/* Alerts */
.alert { border-radius: 8px; padding: 12px 16px; font-size: 14px; margin-bottom: 20px; }
.alert-success { background: #d1fae5; color: #065f46; border: 1px solid #a7f3d0; }
.alert-error   { background: #fef2f2; color: #b91c1c; border: 1px solid #fecaca; }

/* Table */
.table-wrap { background: var(--card-bg); border-radius: var(--card-radius); box-shadow: var(--card-shadow); overflow: hidden; }
table { width: 100%; border-collapse: collapse; }
thead th { background: var(--thead-bg); padding: 11px 16px; text-align: left; font-size: 12px; font-weight: 700; color: var(--text-muted); border-bottom: 1px solid var(--border); white-space: nowrap; text-transform: uppercase; letter-spacing: .4px; }
tbody tr { border-bottom: 1px solid var(--divider); transition: background .1s; }
tbody tr:last-child { border-bottom: none; }
tbody tr:hover { background: var(--row-hover); }
tbody td { padding: 12px 16px; font-size: 14px; vertical-align: middle; color: var(--text-primary); }
.td-name a { font-weight: 600; color: var(--accent-text); text-decoration: none; }
body.theme-dark .td-name a { color: var(--accent); }
.td-name a:hover { text-decoration: underline; }
.td-meta { color: var(--text-muted); font-size: 13px; }

/* Tags */
.tags { display: flex; flex-wrap: wrap; gap: 4px; }
.tag  { background: var(--tag-bg); color: var(--tag-color); border-radius: 4px; padding: 2px 8px; font-size: 12px; font-weight: 600; }

/* Forms */
.form-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 20px; }
.field { display: flex; flex-direction: column; gap: 6px; }
.field.full { grid-column: 1 / -1; }
label { font-size: 13px; font-weight: 600; color: var(--text-muted); }
input[type=text], input[type=email], input[type=tel], input[type=date], input[type=time],
input[type=password], select, textarea {
    padding: 9px 14px; border: 1.5px solid var(--border-input);
    border-radius: var(--input-radius); font-size: 14px; outline: none;
    background: var(--input-bg); color: var(--text-primary);
    font-family: inherit; transition: border-color .15s; width: 100%;
}
input[type=time]::-webkit-calendar-picker-indicator { filter: invert(0.7); cursor: pointer; }
input:focus, select:focus, textarea:focus { border-color: var(--border-focus); background: var(--card-bg); }
textarea { resize: vertical; min-height: 80px; }
.hint { font-size: 12px; color: var(--text-hint); }
.form-actions { display: flex; gap: 12px; margin-top: 28px; flex-wrap: wrap; }
.search-row { display: flex; gap: 10px; margin-bottom: 20px; align-items: center; }
.search-row input { flex: 1; }

/* Misc */
.section-title { font-size: 15px; font-weight: 700; margin-bottom: 16px; padding-bottom: 8px; border-bottom: 1px solid var(--border); color: var(--text-primary); }
.back-link { color: var(--text-muted); font-size: 14px; text-decoration: none; display: inline-flex; align-items: center; gap: 4px; margin-bottom: 20px; }
.back-link:hover { color: var(--text-primary); }
.info-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 20px 40px; margin-bottom: 28px; }
.info-item dt { font-size: 12px; font-weight: 600; color: var(--text-hint); text-transform: uppercase; letter-spacing: .5px; margin-bottom: 4px; }
.info-item dd { font-size: 15px; color: var(--text-primary); }
.info-item dd a { color: var(--accent-text); }
body.theme-dark .info-item dd a { color: var(--accent); }
.role-badge { border-radius: 4px; padding: 2px 10px; font-size: 12px; font-weight: 700; }
.role-admin { background: var(--accent-light); color: var(--accent-text); }
body.theme-dark .role-admin { color: var(--accent); }
.role-user  { background: var(--thead-bg); color: var(--text-muted); }
.you-tag { background: #d1fae5; color: #065f46; border-radius: 4px; padding: 1px 7px; font-size: 11px; font-weight: 700; margin-left: 6px; }
.tabs { display: flex; margin-bottom: 24px; border: 1.5px solid var(--border-input); border-radius: var(--btn-radius); overflow: hidden; width: fit-content; background: var(--card-bg); }
.tabs a { padding: 8px 20px; font-size: 14px; font-weight: 600; color: var(--text-muted); text-decoration: none; transition: background .12s; }
.tabs a:hover  { background: var(--thead-bg); color: var(--text-primary); }
.tabs a.active { background: var(--accent); color: #fff; }
body.theme-dark .tabs a.active { color: #111; }


/* ══ LIGHT THEME ════════════════════════════════════════════ */
body.theme-light {
    --body-bg:       #f0f2f5;
    --nav-bg:        #ffffff;
    --nav-text:      #6b7280;
    --nav-active:    #4f46e5;
    --card-bg:       #ffffff;
    --card-shadow:   0 1px 4px rgba(0,0,0,.08), 0 2px 12px rgba(0,0,0,.05);
    --border:        #e5e7eb;
    --divider:       #f3f4f6;
    --border-input:  #d1d5db;
    --border-focus:  #4f46e5;
    --input-bg:      #f9fafb;
    --row-hover:     #f9fafb;
    --thead-bg:      #f3f4f6;
    --text-primary:  #111827;
    --text-muted:    #6b7280;
    --text-hint:     #9ca3af;
    --accent:        #4f46e5;
    --accent-hover:  #4338ca;
    --accent-text:   #4f46e5;
    --tab-bg:        #e5e7eb;
    --tab-active-bg: #4f46e5;
    --tab-active-fg: #ffffff;
    --input-radius:  8px;
    --card-radius:   12px;
}
body.theme-light .btn-primary { color: #fff; }
body.theme-light nav { border-bottom: 1px solid #e5e7eb; }
body.theme-light .badge-count { color: #fff; }
body.theme-light nav a.active { color: #4f46e5; font-weight: 700; }
body.theme-light .nav-drawer a.active { background: rgba(79,70,229,.08); }

/* ══ RESPONSIVE — hide desktop nav, show hamburger ══════════════ */
@media (max-width: 860px) {
    nav { padding: 0 16px; }
    nav .nav-links { display: none; }
    nav .lang-picker { display: none; }
    nav .theme-toggle { display: none; }
    nav .logout { display: none; }
    .nav-hamburger { display: flex; }
}


/* ══ LIGHT THEME ════════════════════════════════════════════ */
body.theme-light {
    --body-bg:       #f0f2f5;
    --nav-bg:        #ffffff;
    --nav-text:      #6b7280;
    --nav-active:    #4f46e5;
    --card-bg:       #ffffff;
    --card-shadow:   0 1px 4px rgba(0,0,0,.08), 0 2px 12px rgba(0,0,0,.05);
    --border:        #e5e7eb;
    --divider:       #f3f4f6;
    --border-input:  #d1d5db;
    --border-focus:  #4f46e5;
    --input-bg:      #f9fafb;
    --row-hover:     #f9fafb;
    --thead-bg:      #f3f4f6;
    --text-primary:  #111827;
    --text-muted:    #6b7280;
    --text-hint:     #9ca3af;
    --accent:        #4f46e5;
    --accent-hover:  #4338ca;
    --accent-text:   #4f46e5;
    --tab-bg:        #e5e7eb;
    --tab-active-bg: #4f46e5;
    --tab-active-fg: #ffffff;
    --input-radius:  8px;
    --card-radius:   12px;
}
body.theme-light .btn-primary { color: #fff; }
body.theme-light nav { border-bottom: 1px solid #e5e7eb; }
body.theme-light .badge-count { color: #fff; }

/* ══ RESPONSIVE — mobile layout ════════════════════════════════ */
@media (max-width: 640px) {
    .main { padding: 16px 14px; }
    .card { padding: 16px; }
    .form-grid { grid-template-columns: 1fr; }
    .field.full { grid-column: 1; }
    .info-grid { grid-template-columns: 1fr; gap: 14px; }
    .page-title { font-size: 18px; }
    .search-row { flex-direction: column; align-items: stretch; }
    .tabs { width: 100%; }
    .tabs a { flex: 1; text-align: center; padding: 10px 6px; font-size: 13px; }
    .btn-sm { font-size: 12px; padding: 5px 10px; }

    /* Date input — keep compact on mobile, iOS makes it full-width by default */
    input[type=date] {
        width: auto;
        min-width: 160px;
        max-width: 100%;
        display: block;
        -webkit-appearance: none;
        appearance: none;
    }

    /* Tables → stacked card rows */
    .table-wrap { background: transparent; box-shadow: none; border-radius: 0; }
    table, thead, tbody, th, td, tr { display: block; }
    thead { display: none; }
    tbody tr { background: var(--card-bg); border-radius: var(--card-radius); box-shadow: var(--card-shadow); margin-bottom: 10px; border: none; }
    tbody td { display: flex; justify-content: space-between; align-items: center; padding: 9px 14px; border-bottom: 1px solid var(--divider); font-size: 13px; gap: 8px; }
    tbody td:last-child { border-bottom: none; justify-content: flex-end; flex-wrap: wrap; gap: 6px; padding: 10px 14px; }
    tbody td[data-label]:not(:last-child)::before { content: attr(data-label); font-size: 11px; font-weight: 700; color: var(--text-hint); text-transform: uppercase; letter-spacing: .4px; flex-shrink: 0; }

    /* Hide secondary columns on mobile */
    table tbody td.td-hide-mobile { display: none !important; }
    thead th.td-hide-mobile { display: none !important; }

    /* Checkbox cell — compact, no border */
    tbody td:not([data-label]):first-child { padding: 10px 14px 4px; border-bottom: none; }

    /* Company name cell — full block layout */
    table tbody td.td-co-cell { flex-direction: column; align-items: flex-start; gap: 3px; padding: 12px 14px; }
    table tbody td.td-co-cell::before { display: none !important; }

    /* Mobile names/badges — show inside name cell */
    .mobile-names { display: block; }
    .bulk-bar-desktop { display: none !important; }
}


/* ══ LIGHT THEME ════════════════════════════════════════════ */
body.theme-light {
    --body-bg:       #f0f2f5;
    --nav-bg:        #ffffff;
    --nav-text:      #6b7280;
    --nav-active:    #4f46e5;
    --card-bg:       #ffffff;
    --card-shadow:   0 1px 4px rgba(0,0,0,.08), 0 2px 12px rgba(0,0,0,.05);
    --border:        #e5e7eb;
    --divider:       #f3f4f6;
    --border-input:  #d1d5db;
    --border-focus:  #4f46e5;
    --input-bg:      #f9fafb;
    --row-hover:     #f9fafb;
    --thead-bg:      #f3f4f6;
    --text-primary:  #111827;
    --text-muted:    #6b7280;
    --text-hint:     #9ca3af;
    --accent:        #4f46e5;
    --accent-hover:  #4338ca;
    --accent-text:   #4f46e5;
    --tab-bg:        #e5e7eb;
    --tab-active-bg: #4f46e5;
    --tab-active-fg: #ffffff;
    --input-radius:  8px;
    --card-radius:   12px;
}
body.theme-light .btn-primary { color: #fff; }
body.theme-light nav { border-bottom: 1px solid #e5e7eb; }
body.theme-light .badge-count { color: #fff; }

/* ══ RESPONSIVE — table mobile (wider phones + tablets) ════════ */
@media (max-width: 768px) {
    .table-wrap { background: transparent; box-shadow: none; border-radius: 0; }
    table, thead, tbody, th, td, tr { display: block; }
    thead { display: none; }
    tbody tr { background: var(--card-bg); border-radius: var(--card-radius); box-shadow: var(--card-shadow); margin-bottom: 10px; border: none; }
    tbody td { display: flex; justify-content: space-between; align-items: center; padding: 9px 14px; border-bottom: 1px solid var(--divider); font-size: 13px; gap: 8px; }
    tbody td:last-child { border-bottom: none; justify-content: flex-end; flex-wrap: wrap; gap: 6px; padding: 10px 14px; }
    tbody td[data-label]:not(:last-child)::before { content: attr(data-label); font-size: 11px; font-weight: 700; color: var(--text-hint); text-transform: uppercase; letter-spacing: .4px; flex-shrink: 0; }
    table tbody td.td-hide-mobile { display: none !important; }
    thead th.td-hide-mobile { display: none !important; }
    tbody td:not([data-label]):first-child { padding: 10px 14px 4px; border-bottom: none; }
    table tbody td.td-co-cell { flex-direction: column; align-items: flex-start; gap: 3px; padding: 12px 14px; }
    table tbody td.td-co-cell::before { display: none !important; }
    .mobile-names { display: block; }
    .bulk-bar-desktop { display: none !important; }
}

/* ══ REGION PICKER ══════════════════════════════════════════════ */
.region-picker { position: relative; flex-shrink: 0; }
.region-btn {
    display: flex; align-items: center; gap: 5px;
    background: rgba(255,255,255,.1);
    border: 1px solid rgba(255,255,255,.2);
    border-radius: 6px; padding: 4px 10px;
    color: var(--nav-active); font-size: 12px; font-weight: 700;
    cursor: pointer; font-family: inherit; letter-spacing: .5px;
}
.region-btn:hover { background: rgba(255,255,255,.18); }
.region-btn .arr { font-size: 9px; opacity: .7; }
.region-badge {
    background: rgba(255,255,255,.1); border: 1px solid rgba(255,255,255,.2);
    border-radius: 6px; padding: 4px 10px; color: var(--nav-text);
    font-size: 12px; font-weight: 700; letter-spacing: .5px; flex-shrink: 0;
}
.region-menu {
    display: none; position: absolute; left: 0; top: calc(100% + 6px);
    background: var(--card-bg); border: 1px solid var(--border);
    border-radius: var(--card-radius); box-shadow: 0 8px 24px rgba(0,0,0,.18);
    min-width: 120px; z-index: 9999; overflow: hidden;
}
.region-menu.open { display: block; }
.region-menu a {
    display: block; padding: 9px 14px; font-size: 13px; font-weight: 600;
    color: var(--text-primary); text-decoration: none; letter-spacing: .4px;
}
.region-menu a:hover  { background: var(--thead-bg); }
.region-menu a.active { color: var(--accent-text); }
body.theme-dark .region-menu a.active { color: var(--accent); }

/* Drawer region grid */
.drawer-region-grid {
    display: grid; grid-template-columns: repeat(4, 1fr);
    gap: 1px; background: rgba(255,255,255,.05); margin-bottom: 4px;
}
.drawer-region-grid a {
    background: var(--nav-bg); color: var(--nav-text); text-decoration: none;
    font-size: 13px; font-weight: 700; padding: 12px 8px;
    text-align: center; letter-spacing: .4px;
}
.drawer-region-grid a:hover, .drawer-region-grid a.active { color: var(--nav-active); background: rgba(255,255,255,.08); }

/* Region filter bar on list pages */
.region-bar {
    display: flex; align-items: center; gap: 8px; margin-bottom: 20px;
    background: var(--card-bg); border-radius: var(--card-radius);
    padding: 10px 16px; box-shadow: var(--card-shadow);
    font-size: 13px; flex-wrap: wrap;
}
.region-bar .rb-label { color: var(--text-muted); font-weight: 600; flex-shrink: 0; }
.region-tag {
    padding: 3px 10px; border-radius: 20px; font-size: 12px; font-weight: 700;
    background: var(--accent-light); color: var(--accent-text); letter-spacing: .3px;
}
body.theme-dark .region-tag { color: var(--accent); }

/* ══ MOBILE REGION FIX ══════════════════════════════════════════ */
@media (max-width: 860px) {
    /* Hide desktop region picker on mobile — handled in drawer */
    .region-picker { display: none; }
    .region-badge  { display: none; }
}

/* ══ DOTS MENU ══════════════════════════════════════════════════ */
.dots-menu { position: relative; display: inline-block; }
.dots-btn {
    background: none;
    border: none;
    cursor: pointer;
    padding: 4px 8px;
    border-radius: 6px;
    color: var(--text-hint);
    font-size: 18px;
    line-height: 1;
    letter-spacing: 1px;
    transition: background .15s, color .15s;
    font-family: inherit;
}
.dots-btn:hover { background: var(--thead-bg); color: var(--text-primary); }
.dots-dropdown {
    display: none;
    position: absolute;
    right: 0;
    top: calc(100% + 4px);
    background: var(--card-bg);
    border: 1px solid var(--border);
    border-radius: var(--card-radius);
    box-shadow: 0 8px 24px rgba(0,0,0,.15);
    min-width: 160px;
    z-index: 500;
    overflow: hidden;
}
.dots-dropdown.open { display: block; }
.dots-dropdown a, .dots-dropdown button {
    display: flex;
    align-items: center;
    gap: 8px;
    width: 100%;
    padding: 10px 14px;
    font-size: 14px;
    color: var(--text-primary);
    text-decoration: none;
    background: none;
    border: none;
    cursor: pointer;
    font-family: inherit;
    text-align: left;
    transition: background .1s;
}
.dots-dropdown a:hover, .dots-dropdown button:hover { background: var(--thead-bg); }
.dots-dropdown .danger { color: #ef4444; }
.dots-dropdown .danger:hover { background: #fee2e2; }
.dots-separator { border: none; border-top: 1px solid var(--border); margin: 4px 0; }

/* ══ iOS ZOOM FIX ═══════════════════════════════════════════════ */
/* Prevent Safari from zooming on input focus (requires ≥16px) */
@media (max-width: 768px) {
    input[type=text], input[type=email], input[type=tel],
    input[type=date], input[type=password], input[type=search],
    select, textarea {
        font-size: 16px !important;
    }
}
