/* =============================================================================
   OFFICE ENTRY PAGE — выбор кабинета для входа
   Использует токены из /css/filament/tokens.css.
   ============================================================================= */

:root {
    --font-family:          ui-sans-serif, system-ui, sans-serif;
    --office-bg:            var(--color-surface-warm,    #f6f1e6);
    --office-card:          var(--color-surface-card-88, rgba(255, 252, 246, 0.88));
    --office-border:        var(--color-border-card,     rgba(174, 116, 26, 0.18));
    --office-text:          var(--color-text-default,    #111827);
    --office-muted:         var(--color-text-muted,      #6b7280);
    --office-primary:       var(--color-brand-primary,   #c86c1a);
    --office-primary-dark:  var(--color-brand-dark,      #8f4b16);
    --office-buyer:         var(--color-brand-buyer,     #b45309);
    --office-supplier:      var(--color-brand-supplier,  #127c5a);
    --office-shadow:        var(--shadow-lg,             0 20px 60px rgba(57, 39, 12, 0.08));
}

* {
    box-sizing: border-box;
}

body {
    margin: 0;
    min-height: 100vh;
    font-family: var(--font-family);
    color: var(--office-text);
    background:
        radial-gradient(circle at top left,  rgba(242, 198, 125, 0.28), transparent 32%),
        radial-gradient(circle at top right, rgba(95,  163, 139, 0.18), transparent 28%),
        linear-gradient(180deg, #fbf8f1 0%, var(--office-bg) 100%);
}

/* --- Shell --- */

.office-shell {
    width: min(1120px, calc(100% - 40px));
    margin: 0 auto;
    padding: 72px 0 56px;
}

/* --- Hero --- */

.office-hero {
    display: grid;
    gap: 18px;
    margin-bottom: 36px;
}

.office-kicker {
    font-size: 13px;
    font-weight: 700;
    letter-spacing: 0.18em;
    text-transform: uppercase;
    color: var(--office-primary);
}

.office-title {
    margin: 0;
    font-size: clamp(38px, 5vw, 66px);
    line-height: 0.96;
    letter-spacing: -0.04em;
}

.office-subtitle {
    margin: 0;
    max-width: 720px;
    font-size: 18px;
    line-height: 1.6;
    color: var(--office-muted);
}

/* --- Grid --- */

.office-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 20px;
}

/* --- Card --- */

.office-card {
    display: grid;
    gap: 18px;
    padding: 28px;
    border: 1px solid var(--office-border);
    border-radius: 28px;
    background: var(--office-card);
    box-shadow: var(--office-shadow);
    backdrop-filter: blur(12px);
}

/* --- Badge --- */

.office-card__badge {
    display: inline-flex;
    width: fit-content;
    align-items: center;
    gap: 8px;
    padding: 8px 14px;
    border-radius: 999px;
    font-size: 12px;
    font-weight: 700;
    letter-spacing: 0.12em;
    text-transform: uppercase;
    background: rgba(255, 255, 255, 0.86);
    color: var(--office-primary-dark);
}

.office-card__badge--buyer    { color: var(--office-buyer); }
.office-card__badge--supplier { color: var(--office-supplier); }

/* --- Card text --- */

.office-card__title {
    margin: 0;
    font-size: 28px;
    line-height: 1.1;
}

.office-card__text {
    margin: 0;
    font-size: 16px;
    line-height: 1.6;
    color: var(--office-muted);
}

/* --- Features list --- */

.office-features {
    margin: 0;
    padding: 0;
    list-style: none;
    display: grid;
    gap: 10px;
}

.office-features__item {
    display: flex;
    align-items: baseline;
    gap: 10px;
    font-size: 15px;
    line-height: 1.4;
    color: var(--office-text);
}

.office-features__item::before {
    content: '';
    display: inline-block;
    flex-shrink: 0;
    width: 7px;
    height: 7px;
    border-radius: 50%;
    background: var(--office-buyer);
    opacity: 0.7;
    position: relative;
    top: -1px;
}

.office-features--supplier .office-features__item::before {
    background: var(--office-supplier);
}

/* --- Card actions --- */

.office-card__actions {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 16px;
    margin-top: 4px;
}

/* --- Links --- */

.office-card__link {
    display: inline-flex;
    width: fit-content;
    align-items: center;
    justify-content: center;
    padding: 14px 18px;
    border-radius: 16px;
    background: var(--office-primary);
    color: #fff8ef;
    text-decoration: none;
    font-weight: 700;
    transition:
        transform   var(--duration-normal, 0.16s) var(--easing-default, ease),
        opacity     var(--duration-normal, 0.16s) var(--easing-default, ease),
        background-color var(--duration-normal, 0.16s) var(--easing-default, ease);
}

.office-card__link:hover         { transform: translateY(-1px); opacity: 0.94; }
.office-card__link:focus-visible { outline: 2px solid var(--office-primary); outline-offset: 3px; }
.office-card__link--buyer        { background: var(--office-buyer); }
.office-card__link--supplier     { background: var(--office-supplier); }

.office-card__secondary-link {
    display: inline-flex;
    width: fit-content;
    color: var(--office-muted);
    text-decoration: none;
    font-size: 14px;
    font-weight: 600;
    border-bottom: 1px solid rgba(110, 118, 134, 0.25);
    transition:
        color        var(--duration-normal, 0.16s) var(--easing-default, ease),
        border-color var(--duration-normal, 0.16s) var(--easing-default, ease);
}

.office-card__secondary-link:hover        { color: var(--office-primary-dark); border-color: rgba(143, 75, 22, 0.35); }
.office-card__secondary-link:focus-visible { outline: 2px solid var(--office-primary); outline-offset: 3px; }

/* --- Footer --- */

.office-footer {
    margin-top: 26px;
    font-size: 14px;
    color: var(--office-muted);
}

.office-admin-link {
    display: inline-flex;
    margin-top: 10px;
    color: var(--office-muted);
    font-size: 13px;
    text-decoration: none;
    border-bottom: 1px solid rgba(110, 118, 134, 0.25);
    transition:
        color        var(--duration-normal, 0.16s) var(--easing-default, ease),
        border-color var(--duration-normal, 0.16s) var(--easing-default, ease);
}

.office-admin-link:hover        { color: var(--office-primary-dark); border-color: rgba(143, 75, 22, 0.35); }
.office-admin-link:focus-visible { outline: 2px solid var(--office-primary); outline-offset: 3px; }

/* --- Responsive (unified: 1024px) --- */

@media (max-width: 1024px) {
    .office-grid {
        grid-template-columns: 1fr;
    }

    .office-shell {
        padding-top: 44px;
    }
}
