/* IM Video Flow — design system (brand tokens + app shell).
   Extend these tokens; do not hardcode colors in components. */
:root {
    --brand:        #FF731D;
    --brand-soft:   #FFCC99;
    --text:         #111111;
    --surface:      #ffffff;
    --surface-2:    #f5f5f4;
    --border:       #e6e3df;
    --muted:        #6b6b6b;
    --danger:       #c0392b;
    --ok:           #1e8a4c;
    --radius:       14px;
    --shadow:       0 6px 24px rgba(17, 17, 17, .08);
    font-family: "Raleway", system-ui, sans-serif;
}
[data-theme="dark"] {
    --text:       #f4f2ef;
    --surface:    #1b1b1d;
    --surface-2:  #242427;
    --border:     #34343a;
    --muted:      #a4a2a0;
    --shadow:     0 6px 24px rgba(0, 0, 0, .35);
}
* { box-sizing: border-box; }
body {
    margin: 0;
    min-height: 100vh;
    background: var(--surface-2);
    color: var(--text);
}
[hidden] { display: none !important; }

/* --- Top bar ----------------------------------------------------------- */
.topbar {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
    padding: .75rem 1.25rem;
    background: var(--surface);
    border-bottom: 1px solid var(--border);
    position: sticky;
    top: 0;
    z-index: 10;
}
.topbar-right { display: flex; align-items: center; gap: .6rem; }
.who { color: var(--muted); font-size: .85rem; font-weight: 600; }

/* --- Layout ------------------------------------------------------------ */
.centered { min-height: 100vh; display: grid; place-items: center; padding: 1.5rem; }
.container { max-width: 960px; margin: 0 auto; padding: 1.5rem 1.25rem 3rem; display: grid; gap: 1.25rem; }
.page-title { margin: .25rem 0 .25rem; }

/* --- Cards -------------------------------------------------------------- */
.card {
    background: var(--surface);
    border: 1px solid var(--border);
    border-radius: var(--radius);
    box-shadow: var(--shadow);
    padding: 1.5rem;
}
.login-card { width: min(420px, 92vw); padding: 2rem; }
.card.narrow { max-width: 460px; }
.card-head { display: flex; align-items: center; justify-content: space-between; gap: 1rem; margin-bottom: 1rem; }
.card h3 { margin: 0; }

.brand { margin: 0 0 .25rem; font-weight: 700; color: var(--brand); letter-spacing: -.01em; }
.brand-lg { font-size: 1.6rem; }
.muted { color: var(--muted); margin-top: 0; }

/* --- Forms ------------------------------------------------------------- */
.stack { display: grid; gap: .85rem; }
.login-card .stack { margin-top: 1.25rem; }
.stack label { display: grid; gap: .3rem; font-size: .85rem; font-weight: 600; }
.stack label.row { grid-auto-flow: column; justify-content: start; align-items: center; gap: .5rem; }
.stack input, .stack select {
    font: inherit;
    padding: .6rem .7rem;
    border: 1px solid var(--border);
    border-radius: 10px;
    background: var(--surface-2);
    color: var(--text);
}
.stack input:focus, .stack select:focus { outline: 2px solid var(--brand-soft); border-color: var(--brand); }

button {
    font: inherit; font-weight: 600; cursor: pointer;
    padding: .55rem 1rem; border: 1px solid transparent; border-radius: 10px;
    background: var(--brand); color: #fff; transition: filter .15s ease;
}
button:hover { filter: brightness(1.05); }
button.ghost { background: transparent; color: var(--text); border-color: var(--border); }
button.ghost:hover { background: var(--surface-2); filter: none; }
button.link { background: none; border: none; color: var(--brand); padding: .2rem .4rem; }
button.danger { background: var(--danger); }

/* --- Messages ---------------------------------------------------------- */
.msg { margin: .25rem 0 0; font-size: .85rem; font-weight: 600; }
.msg-error { color: var(--danger); }
.msg-ok { color: var(--ok); }

/* --- Table ------------------------------------------------------------- */
.table-wrap { overflow-x: auto; }
table.data { width: 100%; border-collapse: collapse; font-size: .9rem; }
table.data th, table.data td { text-align: left; padding: .55rem .6rem; border-bottom: 1px solid var(--border); }
table.data th { color: var(--muted); font-size: .78rem; text-transform: uppercase; letter-spacing: .03em; }
table.data .right { text-align: right; }
table.data tr.inactive td { opacity: .55; }

.badge {
    display: inline-block; padding: .15rem .55rem; border-radius: 999px;
    font-size: .75rem; font-weight: 700;
    background: var(--brand-soft); color: #5a2c00;
}
.badge.muted-badge { background: var(--surface-2); color: var(--muted); }
.row-actions { display: inline-flex; gap: .35rem; justify-content: flex-end; }

/* --- Dialog ------------------------------------------------------------ */
dialog {
    border: 1px solid var(--border); border-radius: var(--radius);
    background: var(--surface); color: var(--text);
    box-shadow: var(--shadow); padding: 1.5rem; width: min(440px, 92vw);
}
dialog::backdrop { background: rgba(0, 0, 0, .4); }
.dialog-actions { display: flex; justify-content: flex-end; gap: .6rem; margin-top: .5rem; }
