/* =====================================================================
   myBudasmart — alap stíluslap (arany/fekete prémium brand)
   Megj.: a CSP szigorú (default-src 'self'), ezért NINCS külső Google Font.
   A Playfair/Raleway később self-hostolható woff2-vel; addig elegáns
   rendszer-fontstack közelíti a brandet.
   ===================================================================== */

:root {
    --gold-primary: #C8963E;
    --gold-light:   #E0B662;
    --gold-dark:    #9C7430;
    --black:        #0E0E0F;
    --black-soft:   #1A1A1C;
    --gray:         #8A8A8E;
    --gray-light:   #C9C9CE;
    --surface:      #161617;
    --surface-2:    #202022;
    --white:        #F4F1EA;
    --danger:       #D8584F;
    --ok:           #4FA86A;
    --radius:       14px;
    --serif:  Georgia, "Times New Roman", serif;          /* ~Playfair Display */
    --sans:   "Segoe UI", Roboto, Helvetica, Arial, sans-serif; /* ~Raleway */
}

* { box-sizing: border-box; }

html, body {
    margin: 0;
    padding: 0;
    background: var(--black);
    color: var(--white);
    font-family: var(--sans);
    font-size: 16px;
    line-height: 1.55;
}

a { color: var(--gold-light); text-decoration: none; }
a:hover { color: var(--gold-primary); text-decoration: underline; }

h1, h2, h3 { font-family: var(--serif); font-weight: 600; letter-spacing: .2px; }

/* --- Egyszerű középre igazított kártya (login / üres oldalak) --- */
.mbs-center {
    min-height: 100vh;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 24px;
    background:
        radial-gradient(1200px 600px at 50% -10%, rgba(200,150,62,.12), transparent 60%),
        var(--black);
}

.mbs-card {
    width: 100%;
    max-width: 420px;
    background: var(--surface);
    border: 1px solid rgba(200,150,62,.22);
    border-radius: var(--radius);
    padding: 40px 32px;
    text-align: center;
    box-shadow: 0 20px 60px rgba(0,0,0,.45);
}

.mbs-logo {
    margin: 0 0 6px;
    font-size: 2rem;
    color: var(--white);
}
.mbs-logo span { color: var(--gold-primary); }

.mbs-muted { color: var(--gray-light); margin: 0 0 22px; }

.mbs-pill {
    display: inline-block;
    margin-top: 8px;
    padding: 7px 14px;
    font-size: .85rem;
    color: var(--gold-light);
    background: rgba(200,150,62,.10);
    border: 1px solid rgba(200,150,62,.30);
    border-radius: 999px;
}

/* --- Alap form-elemek (a 2. lépéstől használjuk) --- */
.mbs-field { text-align: left; margin-bottom: 16px; }
.mbs-field label { display: block; font-size: .85rem; color: var(--gray-light); margin-bottom: 6px; }
.mbs-field input, .mbs-field select, .mbs-field textarea {
    width: 100%;
    padding: 11px 13px;
    background: var(--surface-2);
    border: 1px solid rgba(255,255,255,.12);
    border-radius: 10px;
    color: var(--white);
    font-family: var(--sans);
    font-size: 1rem;
}
.mbs-field input:focus, .mbs-field select:focus, .mbs-field textarea:focus {
    outline: none;
    border-color: var(--gold-primary);
    box-shadow: 0 0 0 3px rgba(200,150,62,.18);
}

.mbs-btn {
    display: inline-block;
    width: 100%;
    padding: 12px 16px;
    background: linear-gradient(180deg, var(--gold-light), var(--gold-primary));
    color: #1a1305;
    font-weight: 700;
    border: none;
    border-radius: 10px;
    cursor: pointer;
    font-size: 1rem;
}
.mbs-btn:hover { filter: brightness(1.05); }

.mbs-alert { padding: 12px 14px; border-radius: 10px; margin-bottom: 16px; font-size: .92rem; text-align: left; }
.mbs-alert--error { background: rgba(216,88,79,.12); border: 1px solid rgba(216,88,79,.4); color: #f0a8a3; }
.mbs-alert--ok    { background: rgba(79,168,106,.12); border: 1px solid rgba(79,168,106,.4); color: #a7e0ba; }

/* =====================================================================
   Alkalmazás-elrendezés (admin + ügyfél portál)
   ===================================================================== */
.mbs-app { min-height: 100vh; display: grid; grid-template-columns: 250px minmax(0, 1fr); }
.mbs-sidebar {
    background: var(--surface);
    border-right: 1px solid rgba(200,150,62,.18);
    padding: 24px 18px;
    display: flex; flex-direction: column;
}
.mbs-sidebar .mbs-logo { font-size: 1.4rem; text-align: left; margin-bottom: 4px; }
.mbs-side-role { color: var(--gray); font-size: .8rem; margin-bottom: 24px; }
.mbs-nav a {
    display: block; padding: 10px 12px; border-radius: 8px; margin-bottom: 4px;
    color: var(--gray-light); text-decoration: none; font-size: .95rem;
}
.mbs-nav a:hover { background: var(--surface-2); color: var(--white); }
.mbs-nav a.active { background: rgba(200,150,62,.14); color: var(--gold-light); }
.mbs-side-foot { margin-top: auto; padding-top: 18px; border-top: 1px solid rgba(255,255,255,.08); }
.mbs-side-foot a { color: var(--gray); font-size: .9rem; }

.mbs-main { padding: 32px 40px; max-width: 1100px; min-width: 0; }

/* Görgethető táblázat-burkoló (mobilon a táblázat nem feszíti szét az oldalt) */
.mbs-tablewrap { width: 100%; overflow-x: auto; -webkit-overflow-scrolling: touch; }

/* Szűrő-rácsok (osztályok az inline stílusok helyett, hogy mobilon tördelhessenek) */
.mbs-filtergrid { display: grid; grid-template-columns: repeat(5, 1fr) auto; gap: 12px; align-items: end; }
.mbs-catrow { display: grid; grid-template-columns: 1fr 1fr 1fr 90px auto auto; gap: 10px; align-items: center; padding: 10px 0; border-bottom: 1px solid rgba(255,255,255,.07); }
.mbs-main h2 { margin: 0 0 6px; font-size: 1.6rem; }
.mbs-crumb { color: var(--gray); font-size: .85rem; margin-bottom: 24px; }

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

/* Táblázat */
.mbs-table { width: 100%; border-collapse: collapse; background: var(--surface); border-radius: var(--radius); overflow: hidden; }
.mbs-table th, .mbs-table td { padding: 12px 14px; text-align: left; border-bottom: 1px solid rgba(255,255,255,.07); font-size: .92rem; }
.mbs-table th { background: var(--surface-2); color: var(--gray-light); font-weight: 600; }
.mbs-table tr:last-child td { border-bottom: none; }
.mbs-table tr:hover td { background: rgba(255,255,255,.02); }

/* Badge / státusz */
.mbs-badge {
    display: inline-block; padding: 3px 9px; border-radius: 999px;
    font-size: .78rem; line-height: 1.4; border: 1px solid transparent;
    white-space: nowrap; text-align: center; vertical-align: middle;
}
.mbs-badge--on  { background: rgba(79,168,106,.14); color: #a7e0ba; border-color: rgba(79,168,106,.35); }
.mbs-badge--off { background: rgba(138,138,142,.14); color: var(--gray-light); border-color: rgba(138,138,142,.3); }
/* Sorszám-chip: lekerekített téglalap (NEM pirula), monospace, nem törik, középre */
.mbs-badge--code{
    background: rgba(200,150,62,.12); color: var(--gold-light);
    border-color: rgba(200,150,62,.3); font-family: monospace;
    border-radius: 6px; letter-spacing: .3px; font-weight: 600;
}

/* Kártya / panel */
.mbs-panel { background: var(--surface); border: 1px solid rgba(255,255,255,.08); border-radius: var(--radius); padding: 24px; margin-bottom: 24px; }
.mbs-panel h3 { margin: 0 0 16px; font-size: 1.15rem; }

/* Gomb-variánsok */
.mbs-btn--sm { width: auto; padding: 8px 14px; font-size: .88rem; }
.mbs-btn--ghost { background: transparent; color: var(--gold-light); border: 1px solid rgba(200,150,62,.4); }
.mbs-btn--ghost:hover { background: rgba(200,150,62,.1); filter: none; }
.mbs-btn--danger { background: linear-gradient(180deg,#e57068,#c8463d); color:#fff; }

/* Form rács */
.mbs-grid2 { display: grid; grid-template-columns: 1fr 1fr; gap: 0 18px; }
.mbs-checks { display: grid; grid-template-columns: 1fr 1fr; gap: 8px; }
.mbs-check { display: flex; align-items: center; gap: 8px; padding: 8px 10px; background: var(--surface-2); border-radius: 8px; }
.mbs-check input { width: auto; }
.mbs-inline { display: flex; gap: 10px; align-items: flex-end; }
.mbs-actions { display: flex; gap: 10px; }

@media (max-width: 760px) {
    .mbs-app { grid-template-columns: minmax(0, 1fr); }
    .mbs-sidebar { flex-direction: row; flex-wrap: wrap; align-items: center; }
    .mbs-nav { display: flex; flex-wrap: wrap; gap: 4px; }
    .mbs-side-foot { margin: 0 0 0 auto; padding: 0; border: none; }
    .mbs-main { padding: 20px; }
    .mbs-grid2, .mbs-checks { grid-template-columns: 1fr; }
    .mbs-inline { flex-wrap: wrap; }
    .mbs-topbar { flex-wrap: wrap; gap: 10px; }
    .mbs-filtergrid { grid-template-columns: 1fr 1fr; }
    .mbs-catrow { grid-template-columns: 1fr 1fr; gap: 8px; }
    .mbs-field { min-width: 0; }

    /* Reszponzív táblázat → kártyák (nincs vízszintes görgetés, egy képernyő-szélesség) */
    .mbs-table--cards thead { display: none; }
    .mbs-table--cards, .mbs-table--cards tbody { display: block; width: 100%; }
    .mbs-table--cards tr {
        display: block; background: var(--surface-2);
        border: 1px solid rgba(255,255,255,.08); border-radius: 10px;
        padding: 4px 12px; margin-bottom: 10px;
    }
    .mbs-table--cards td {
        display: flex; align-items: center; justify-content: space-between; gap: 14px;
        border: none; border-bottom: 1px solid rgba(255,255,255,.06);
        padding: 8px 0; text-align: right; font-size: .9rem;
    }
    .mbs-table--cards tr td:last-child { border-bottom: none; }
    .mbs-table--cards td::before {
        content: attr(data-label); color: var(--gray); font-weight: 600;
        font-size: .78rem; text-align: left; white-space: nowrap; flex: 0 0 auto;
    }
    /* címke nélküli (pl. művelet) cella: teljes szélesség, balra, label nélkül */
    .mbs-table--cards td[data-label=""] { display: block; text-align: left; }
    .mbs-table--cards td[data-label=""]::before { content: ""; display: none; }
    .mbs-table--cards td[data-label=""] .mbs-actions { flex-wrap: wrap; }
    /* a kártyán belül a hivatkozott szöveg törhető */
    .mbs-table--cards td a { word-break: break-word; }
}

/* Státusz / prioritás badge-ek */
.mbs-st { display:inline-block; padding:3px 10px; border-radius:999px; font-size:.78rem; border:1px solid transparent; white-space:nowrap; text-align:center; }
.mbs-st--new    { background:rgba(80,140,210,.14);  color:#9cc4ee; border-color:rgba(80,140,210,.35); }
.mbs-st--prog   { background:rgba(200,150,62,.14);  color:#e0b662; border-color:rgba(200,150,62,.35); }
.mbs-st--wait   { background:rgba(180,130,210,.14); color:#cdaae0; border-color:rgba(180,130,210,.35); }
.mbs-st--res    { background:rgba(79,168,106,.14);  color:#a7e0ba; border-color:rgba(79,168,106,.35); }
.mbs-st--closed { background:rgba(138,138,142,.14); color:#c9c9ce; border-color:rgba(138,138,142,.3); }

.mbs-pr { display:inline-block; font-size:.78rem; padding:2px 8px; border-radius:6px; white-space:nowrap; }
.mbs-pr--low    { color:#9aa; }
.mbs-pr--medium { color:#cdb98a; }
.mbs-pr--high   { color:#e0a062; }
.mbs-pr--urgent { color:#e8746b; font-weight:700; }

/* Üzenetszál (a 6. lépésben bővül) */
.mbs-thread { display:flex; flex-direction:column; gap:14px; }
.mbs-msg { background:var(--surface); border:1px solid rgba(255,255,255,.08); border-radius:12px; padding:14px 16px; }
.mbs-msg--mine { border-color:rgba(200,150,62,.3); }
.mbs-msg--internal { border-color:rgba(180,130,210,.4); background:rgba(180,130,210,.05); }
.mbs-msg__head { display:flex; justify-content:space-between; font-size:.82rem; color:var(--gray); margin-bottom:6px; }
.mbs-msg__body { white-space:pre-wrap; word-break:break-word; }

/* Definíciós lista (jegy-fejléc) */
.mbs-dl { display:grid; grid-template-columns:auto 1fr; gap:6px 18px; font-size:.92rem; }
.mbs-dl dt { color:var(--gray); }
.mbs-dl dd { margin:0; }

/* Okos csatolmány UI (kamera + fájllista) */
.mbs-fileui { margin-top: 8px; }
.mbs-cam { display: inline-flex; align-items: center; gap: 6px; width: auto !important; cursor: pointer; }
.mbs-filenote { color: var(--danger); font-size: .85rem; margin-top: 6px; }
.mbs-filelist { list-style: none; padding: 0; margin: 8px 0 0; display: flex; flex-direction: column; gap: 6px; }
.mbs-filelist li { display: flex; justify-content: space-between; align-items: center; gap: 10px; background: var(--surface-2); border: 1px solid rgba(255,255,255,.1); border-radius: 8px; padding: 6px 10px; font-size: .88rem; }
.mbs-filerm { background: none; border: none; color: var(--gray-light); cursor: pointer; font-size: 1rem; padding: 0 4px; width: auto; }
.mbs-filerm:hover { color: var(--danger); }

/* Go-to-top lebegő gomb */
.mbs-totop {
    position: fixed; right: 22px; bottom: 22px;
    width: 46px; height: 46px; border-radius: 50%; border: none; cursor: pointer;
    background: linear-gradient(180deg, var(--gold-light), var(--gold-primary));
    color: #1a1305; font-size: 1.45rem; line-height: 46px; text-align: center;
    box-shadow: 0 6px 20px rgba(0,0,0,.45);
    opacity: 0; visibility: hidden; transform: translateY(10px);
    transition: opacity .25s ease, transform .25s ease, visibility .25s ease;
    z-index: 999; padding: 0;
}
.mbs-totop.show { opacity: 1; visibility: visible; transform: translateY(0); }
.mbs-totop:hover { filter: brightness(1.07); }
.mbs-totop:focus-visible { outline: 2px solid var(--white); outline-offset: 2px; }
@media (max-width: 760px) {
    .mbs-totop { right: 16px; bottom: 16px; width: 44px; height: 44px; line-height: 44px; }
}
@media (prefers-reduced-motion: reduce) {
    .mbs-totop { transition: opacity .2s ease; transform: none; }
}
