@font-face {
    font-family: 'Vazirmatn';
    src: url('../fonts/vazirmatn/Vazirmatn-Regular.woff2') format('woff2');
    font-weight: 400;
    font-style: normal;
    font-display: swap;
}

@font-face {
    font-family: 'Vazirmatn';
    src: url('../fonts/vazirmatn/Vazirmatn-Bold.woff2') format('woff2');
    font-weight: 700;
    font-style: normal;
    font-display: swap;
}

:root {
    --bg: #FAFAFB;
    --pink: #EFB7BA;
    --rose: #E5C0C8;
    --blue-soft: #CBD5F0;
    --blue: #194F92;
    --blue-dark: #123B6F;
    --blue-50: #EEF3FF;
    --white: #FFFFFF;
    --ink-900: #172033;
    --ink-700: #3F4B63;
    --ink-500: #7A8599;
    --line: rgba(25, 79, 146, 0.12);
    --line-strong: rgba(25, 79, 146, 0.20);
    --success: #16724B;
    --success-bg: #E7F7EE;
    --warning: #A86000;
    --warning-bg: #FFF4DF;
    --danger: #B93854;
    --danger-bg: #FFF0F3;
    --shadow-soft: 0 18px 48px rgba(25, 79, 146, 0.10);
    --shadow-card: 0 10px 30px rgba(25, 79, 146, 0.07);
    --radius-2xl: 28px;
    --radius-xl: 22px;
    --radius-lg: 18px;
    --radius-md: 14px;
    --safe-bottom: env(safe-area-inset-bottom);
}

* { box-sizing: border-box; }

html { min-height: 100%; background: var(--bg); }

body {
    margin: 0;
    min-height: 100%;
    direction: rtl;
    text-align: right;
    font-family: 'Vazirmatn', Tahoma, sans-serif;
    color: var(--ink-900);
    background:
        radial-gradient(circle at 86% -6%, rgba(203, 213, 240, 0.80), transparent 28%),
        radial-gradient(circle at 8% 3%, rgba(239, 183, 186, 0.52), transparent 26%),
        linear-gradient(180deg, var(--bg) 0%, #F7F8FC 54%, #FDF6F7 100%);
}

body::before {
    content: '';
    position: fixed;
    inset: 0;
    pointer-events: none;
    opacity: 0.54;
    background-image:
        linear-gradient(90deg, rgba(25, 79, 146, 0.035) 1px, transparent 1px),
        linear-gradient(180deg, rgba(25, 79, 146, 0.030) 1px, transparent 1px);
    background-size: 28px 28px;
    mask-image: linear-gradient(180deg, #000 0%, transparent 78%);
}

body, input, button, textarea, select { font-family: 'Vazirmatn', Tahoma, sans-serif; }
button, input, select, textarea { font: inherit; }
button { cursor: pointer; }
a { color: inherit; text-decoration: none; }
img { max-width: 100%; }

.app-shell {
    position: relative;
    width: min(100%, 1120px);
    min-height: 100vh;
    margin: 0 auto;
    padding-bottom: calc(96px + var(--safe-bottom));
}

.app-header {
    position: sticky;
    top: 0;
    z-index: 40;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
    padding: 10px 14px;
    background: rgba(250, 250, 251, 0.86);
    border-bottom: 1px solid var(--line);
    backdrop-filter: blur(18px);
}

.brand-lockup {
    display: inline-flex;
    align-items: center;
    gap: 9px;
    min-width: 0;
}

.brand-mark {
    width: 42px;
    height: 42px;
    flex: 0 0 42px;
    display: grid;
    place-items: center;
    color: #fff;
    background: linear-gradient(145deg, var(--blue), var(--blue-dark));
    border-radius: 16px;
    box-shadow: 0 12px 28px rgba(25, 79, 146, 0.22);
    font-size: 19px;
}

.brand-name {
    display: block;
    font-size: 18px;
    line-height: 1.2;
    color: var(--blue);
    letter-spacing: -0.3px;
}

.brand-subtitle { display: none; }

.header-action,
.primary-link,
.submit-button,
.search-box button,
.form-card button,
.filter-panel button,
.row-actions button,
.inline-status-form button,
.submit-inline {
    border: 0;
    color: #fff;
    background: linear-gradient(135deg, var(--blue), #2B65A9);
    box-shadow: 0 12px 26px rgba(25, 79, 146, 0.22);
}

.header-action {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 70px;
    padding: 10px 14px;
    border-radius: 999px;
    font-size: 13px;
    font-weight: 700;
    white-space: nowrap;
}


.header-main-nav {
    display: none;
    align-items: center;
    gap: 6px;
    margin-inline: auto;
    padding: 5px;
    border: 1px solid rgba(25,79,146,.10);
    border-radius: 999px;
    background: rgba(255,255,255,.64);
    box-shadow: 0 10px 24px rgba(25,79,146,.06);
}

.header-main-nav a {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 34px;
    padding: 7px 11px;
    border-radius: 999px;
    color: var(--ink-500);
    font-size: 12px;
    font-weight: 900;
    white-space: nowrap;
}

.header-main-nav a.active {
    color: var(--blue);
    background: var(--blue-50);
}

.header-main-nav .header-tool-pill {
    color: #fff;
    background: linear-gradient(135deg, var(--blue), #2B65A9);
    box-shadow: 0 10px 22px rgba(25,79,146,.16);
}

.app-main {
    position: relative;
    z-index: 2;
    width: min(100%, 980px);
    margin: 0 auto;
    padding: 12px;
}

.hero-card,
.auth-card,
.section-block,
.role-card,
.dashboard-card,
.detail-card,
.form-page,
.admin-page {
    background: rgba(255, 255, 255, 0.88);
    border: 1px solid var(--line);
    border-radius: var(--radius-2xl);
    padding: 16px;
    box-shadow: var(--shadow-soft);
}

.hero-card {
    position: relative;
    overflow: hidden;
    min-height: 360px;
    display: grid;
    align-items: end;
    background:
        linear-gradient(145deg, rgba(25,79,146,0.96), rgba(18,59,111,0.92)),
        var(--blue);
    color: #fff;
}

.hero-card::before {
    content: '';
    position: absolute;
    inset: -50px -60px auto auto;
    width: 220px;
    height: 220px;
    border-radius: 50%;
    background: rgba(203, 213, 240, 0.34);
}

.hero-card::after {
    content: '';
    position: absolute;
    inset: auto -42px -56px auto;
    width: 184px;
    height: 184px;
    border-radius: 50%;
    background: rgba(239, 183, 186, 0.48);
}

.hero-grid {
    position: relative;
    z-index: 1;
    display: grid;
    gap: 16px;
}

.hero-badge,
.step-badge,
.badge,
.status-pill {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 6px;
    border-radius: 999px;
    padding: 7px 11px;
    font-size: 12px;
    font-weight: 700;
    white-space: nowrap;
}

.hero-badge {
    background: rgba(255,255,255,0.14);
    color: #fff;
    border: 1px solid rgba(255,255,255,0.18);
}

.hero-card h1,
.auth-card h1,
.role-card h1,
.dashboard-card h1,
.form-page h1,
.detail-card h1,
.market-hero h1,
.admin-page h1 {
    margin: 12px 0 8px;
    font-size: 24px;
    line-height: 1.6;
    letter-spacing: -0.7px;
    color: inherit;
}

.section-block h1,
.auth-card h1,
.role-card h1,
.dashboard-card h1,
.form-page h1,
.detail-card h1,
.market-hero h1,
.admin-page h1 { color: var(--ink-900); }

.hero-card p,
.auth-card p,
.role-card p,
.dashboard-card p,
.empty-state p {
    color: var(--ink-500);
    line-height: 1.9;
    margin: 0;
}

.hero-card p { color: rgba(255,255,255,0.78); }

.hero-stats {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 8px;
    margin-top: 14px;
}

.hero-stat {
    min-height: 72px;
    display: grid;
    align-content: center;
    gap: 4px;
    background: rgba(255,255,255,0.13);
    border: 1px solid rgba(255,255,255,0.15);
    border-radius: 18px;
    padding: 12px;
}

.hero-stat strong { color: #fff; font-size: 16px; }
.hero-stat span { color: rgba(255,255,255,0.70); font-size: 11px; line-height: 1.7; }

.search-box,
.form-card,
.filter-panel,
.piece-form,
.admin-form { display: grid; gap: 12px; }
.search-box { margin-top: 16px; }

input,
select,
textarea,
.search-box input,
.form-card input,
.filter-panel input,
.filter-panel select,
.piece-form input,
.piece-form select,
.piece-form textarea,
.row-actions select,
.inline-status-form select,
.admin-form select,
.admin-form input,
.admin-form textarea {
    width: 100%;
    min-height: 48px;
    border: 1px solid var(--line-strong);
    background: rgba(255, 255, 255, 0.94);
    color: var(--ink-900);
    border-radius: 16px;
    padding: 13px 14px;
    outline: none;
    transition: border-color .18s ease, box-shadow .18s ease, background .18s ease;
}

textarea { resize: vertical; }

input:focus,
select:focus,
textarea:focus {
    border-color: rgba(25, 79, 146, 0.58);
    box-shadow: 0 0 0 4px rgba(203, 213, 240, 0.55);
    background: #fff;
}

.search-box button,
.form-card button,
.filter-panel button,
.submit-button {
    min-height: 50px;
    border-radius: 16px;
    padding: 14px 16px;
    font-size: 15px;
    font-weight: 700;
}

.quick-actions,
.service-grid,
.dashboard-grid,
.admin-stats {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 12px;
    margin: 14px 0;
}

.quick-card,
.tool-card,
.stat-card,
.panel-box,
.form-step,
.admin-form,
.admin-row,
.admin-review-card,
.empty-state,
.wallet-card,
.transaction-row {
    background: rgba(255,255,255,0.92);
    border: 1px solid var(--line);
    border-radius: var(--radius-xl);
    box-shadow: var(--shadow-card);
}

.quick-card,
.tool-card {
    position: relative;
    overflow: hidden;
    min-height: 96px;
    display: grid;
    align-content: space-between;
    gap: 8px;
    padding: 14px;
    color: var(--blue);
    font-weight: 700;
}

.quick-card::after,
.tool-card::after {
    content: '';
    position: absolute;
    inset: auto -28px -32px auto;
    width: 86px;
    height: 86px;
    border-radius: 50%;
    background: rgba(229, 192, 200, 0.35);
}

.icon-bubble {
    width: 40px;
    height: 40px;
    display: grid;
    place-items: center;
    border-radius: 15px;
    color: var(--blue);
    background: linear-gradient(145deg, var(--blue-soft), #EEF3FF);
    box-shadow: 0 10px 20px rgba(25, 79, 146, 0.10);
}

.quick-card small,
.tool-card small { display: none; }

.section-title {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 12px;
    margin-bottom: 14px;
}

.section-title h2 { margin: 0; font-size: 18px; color: var(--ink-900); }
.section-title span, .muted { color: var(--ink-500); font-size: 12px; }

.primary-link,
.small-link,
.link-button {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border-radius: 14px;
    font-size: 13px;
    font-weight: 700;
}

.primary-link { padding: 10px 14px; }
.small-link,
.link-button {
    border: 0;
    background: var(--blue-50);
    color: var(--blue);
    padding: 9px 12px;
}

.inline-form { margin-top: 14px; text-align: center; }

.listing-list { display: grid; gap: 12px; margin-top: 14px; }

.listing-card {
    display: grid;
    grid-template-columns: 112px 1fr;
    gap: 12px;
    padding: 10px;
    background: rgba(255,255,255,0.94);
    border: 1px solid var(--line);
    border-radius: var(--radius-xl);
    box-shadow: var(--shadow-card);
}

.listing-card--clickable { transition: transform .18s ease, box-shadow .18s ease, border-color .18s ease; }
.listing-card--clickable:hover { transform: translateY(-2px); border-color: rgba(25,79,146,0.25); box-shadow: var(--shadow-soft); }
.listing-card--clickable:active { transform: scale(0.985); }

.listing-card__image {
    min-height: 126px;
    display: grid;
    place-items: center;
    overflow: hidden;
    border-radius: 18px;
    background:
        linear-gradient(135deg, rgba(203,213,240,.72), rgba(229,192,200,.50)),
        repeating-linear-gradient(45deg, rgba(25,79,146,.08) 0 2px, transparent 2px 10px);
    color: var(--ink-500);
    font-size: 13px;
}

.listing-card__image img { width: 100%; height: 100%; min-height: 126px; object-fit: cover; display: block; }
.listing-card h3 { margin: 2px 0 8px; font-size: 15px; color: var(--ink-900); line-height: 1.65; }
.listing-card p { margin: 4px 0; color: var(--ink-500); font-size: 13px; line-height: 1.7; }

.listing-card strong,
.price-chip {
    display: inline-flex;
    align-items: center;
    margin-top: 8px;
    color: var(--blue);
    background: var(--blue-50);
    border-radius: 999px;
    padding: 7px 11px;
    font-weight: 700;
}

.empty-state { padding: 18px; color: var(--ink-500); border-style: dashed; }
.empty-state strong { display: block; color: var(--blue); margin-bottom: 8px; }

.form-step { padding: 16px; display: grid; gap: 12px; }
.form-step h2, .panel-box h2, .admin-form h2, .admin-review-card h2, .description-box h2 { margin: 0; font-size: 17px; color: var(--ink-900); }
.step-badge { justify-self: start; background: var(--blue-50); color: var(--blue); border: 1px solid var(--line); }

.piece-form label,
.admin-form label,
.form-card label { display: grid; gap: 7px; color: var(--ink-700); font-size: 13px; font-weight: 700; }

.form-grid-3 { display: grid; grid-template-columns: 1fr; gap: 10px; }
.check-row { display: flex !important; grid-template-columns: none !important; align-items: center; gap: 9px !important; color: var(--blue) !important; }
.check-row input { min-height: auto; width: 18px !important; height: 18px; accent-color: var(--blue); }
.submit-button { position: sticky; bottom: calc(88px + var(--safe-bottom)); z-index: 18; }

.auth-card { max-width: 520px; margin: 18px auto; }
.auth-card .form-card { margin-top: 16px; }

.dashboard-grid,
.admin-stats { grid-template-columns: repeat(2, minmax(0, 1fr)); }
.stat-card, .panel-box, .wallet-card { padding: 16px; }
.stat-card span, .stat-card small, .spec-grid span, .seller-box span { display: block; color: var(--ink-500); font-size: 12px; }
.stat-card strong { display: block; margin: 8px 0; color: var(--blue); font-size: 22px; }

.wallet-card {
    display: grid;
    gap: 10px;
    margin-top: 14px;
    background:
        radial-gradient(circle at 12% 8%, rgba(239,183,186,0.32), transparent 35%),
        linear-gradient(135deg, var(--blue), var(--blue-dark));
    color: #fff;
}
.wallet-card span { color: rgba(255,255,255,0.76); }
.wallet-card strong { font-size: 30px; }

.transaction-list { display: grid; gap: 10px; margin-top: 12px; }
.transaction-row { display: flex; align-items: flex-start; justify-content: space-between; gap: 12px; padding: 12px; }
.transaction-row strong { color: var(--ink-900); }
.transaction-row small { display: block; color: var(--ink-500); margin-top: 5px; line-height: 1.7; }
.transaction-amount { direction: ltr; white-space: nowrap; font-weight: 700; color: var(--blue); }

.chips { display: flex; flex-wrap: wrap; gap: 8px; }
.chips span { display: inline-flex; background: var(--blue-50); color: var(--blue); border-radius: 999px; padding: 7px 11px; font-size: 13px; font-weight: 700; }

.mini-list { display: grid; gap: 8px; }
.mini-list a { display: flex; align-items: center; justify-content: space-between; gap: 10px; background: rgba(255,255,255,0.72); border: 1px solid var(--line); border-radius: 14px; padding: 10px 12px; }
.mini-list span { color: var(--blue); font-weight: 700; }
.mini-list small { color: var(--ink-500); }
.dashboard-actions { margin-top: 14px; }

.piece-detail { display: grid; gap: 14px; }
.detail-gallery { display: grid; grid-auto-flow: column; grid-auto-columns: 82%; gap: 12px; overflow-x: auto; scroll-snap-type: x mandatory; padding-bottom: 4px; }
.detail-gallery img,
.detail-placeholder {
    width: 100%;
    height: 260px;
    border-radius: var(--radius-2xl);
    object-fit: cover;
    background:
        linear-gradient(135deg, rgba(203,213,240,.72), rgba(229,192,200,.50)),
        repeating-linear-gradient(45deg, rgba(25,79,146,.08) 0 2px, transparent 2px 10px);
    display: grid;
    place-items: center;
    color: var(--ink-500);
    scroll-snap-align: center;
}
.detail-price { display: inline-flex; margin: 6px 0 16px; background: var(--blue-50); color: var(--blue); border-radius: 999px; padding: 9px 14px; font-size: 18px; }
.spec-grid { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 10px; }
.spec-grid div, .description-box, .seller-box { background: rgba(255,255,255,0.78); border: 1px solid var(--line); border-radius: 16px; padding: 13px; }
.spec-grid strong, .seller-box strong { display: block; margin-top: 6px; color: var(--ink-900); font-size: 14px; }
.description-box, .seller-box { margin-top: 12px; }
.description-box p { margin: 0; line-height: 1.9; color: var(--ink-500); }
.seller-box .primary-link { margin-top: 12px; }

.admin-tabs { display: flex; gap: 8px; overflow-x: auto; padding: 8px 2px 16px; margin-bottom: 8px; }
.admin-tabs a { flex: 0 0 auto; background: rgba(255,255,255,0.78); border: 1px solid var(--line); color: var(--blue); border-radius: 999px; padding: 9px 12px; font-size: 13px; font-weight: 700; }
.admin-list { display: grid; gap: 10px; }
.admin-row, .admin-review-card { display: flex; align-items: center; justify-content: space-between; gap: 12px; padding: 12px; }
.admin-row small, .admin-table small { display: block; margin-top: 5px; color: var(--ink-500); line-height: 1.8; }
.badge { background: var(--blue-50); color: var(--blue); }
.badge-warning { background: var(--warning-bg); color: var(--warning); }
.badge-success { background: var(--success-bg); color: var(--success); }
.badge-danger { background: var(--danger-bg); color: var(--danger); }
.admin-filter { margin-bottom: 14px; }
.admin-table-wrap { overflow-x: auto; border-radius: 20px; border: 1px solid var(--line); background: rgba(255,255,255,0.82); }
.admin-table { width: 100%; min-width: 780px; border-collapse: collapse; }
.admin-table th, .admin-table td { padding: 12px; border-bottom: 1px solid var(--line); text-align: right; vertical-align: top; font-size: 13px; }
.admin-table th { background: rgba(203,213,240,0.36); color: var(--blue); font-weight: 700; }
.admin-table tr:last-child td { border-bottom: 0; }
.row-actions, .row-actions form, .inline-status-form { display: flex; flex-wrap: wrap; align-items: center; gap: 8px; }
.row-actions button, .inline-status-form button, .submit-inline { border-radius: 12px; padding: 9px 12px; font-weight: 700; }
.admin-form { padding: 16px; margin: 12px 0 16px; }
.admin-review-card { align-items: flex-start; }
.admin-review-card p { margin: 7px 0 0; color: var(--ink-500); line-height: 1.8; }

.tool-card strong { color: var(--blue); }
.tool-preview { display: grid; gap: 10px; margin-top: 12px; }

.bottom-nav {
    position: fixed;
    right: 0;
    bottom: 0;
    left: 0;
    z-index: 50;
    width: 100%;
    display: grid;
    grid-template-columns: repeat(5, 1fr);
    gap: 6px;
    padding: 9px 10px calc(9px + var(--safe-bottom));
    background: rgba(255, 255, 255, 0.92);
    border-top: 1px solid var(--line);
    backdrop-filter: blur(18px);
}

.bottom-nav__item {
    position: relative;
    display: grid;
    place-items: center;
    gap: 3px;
    min-height: 54px;
    border-radius: 18px;
    color: var(--ink-500);
    font-size: 11px;
    transition: transform .18s ease, background .18s ease, color .18s ease;
}
.bottom-nav__icon { font-size: 18px; line-height: 1; }
.bottom-nav__item.active { color: var(--blue); background: var(--blue-50); font-weight: 700; }
.bottom-nav__item--primary { min-height: 62px; margin-top: -18px; color: #fff !important; background: linear-gradient(145deg, var(--blue), #2B65A9); box-shadow: 0 14px 34px rgba(25, 79, 146, 0.24); border: 3px solid rgba(255,255,255,0.94); }

.toast { position: fixed; top: 76px; right: 16px; left: 16px; z-index: 70; padding: 12px 14px; border-radius: 16px; box-shadow: var(--shadow-soft); font-size: 14px; }
.toast-error { background: var(--danger-bg); color: var(--danger); border: 1px solid #FFD0DA; }
.toast-success { background: var(--success-bg); color: var(--success); border: 1px solid #CDEED8; }

.role-grid { display: grid; grid-template-columns: 1fr; gap: 10px; margin: 12px 0; }
.role-option { display: flex; align-items: center; gap: 10px; padding: 14px; background: rgba(255,255,255,0.78); border: 1px solid var(--line); border-radius: 18px; cursor: pointer; color: var(--blue); font-weight: 700; }
.role-option input { min-height: auto; width: 18px; height: 18px; accent-color: var(--blue); }
.role-option span { color: var(--ink-900); }

@media (min-width: 600px) {
    .role-grid,
    .dashboard-grid,
    .admin-stats,
    .service-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
}

@media (min-width: 700px) {
    .filter-panel { grid-template-columns: 2fr 1fr 1fr; }
    .form-grid-3 { grid-template-columns: repeat(3, minmax(0, 1fr)); }
    .detail-gallery { grid-auto-flow: initial; grid-template-columns: repeat(3, 1fr); overflow: visible; }
    .detail-gallery img, .detail-placeholder { height: 220px; }
    .admin-stats { grid-template-columns: repeat(3, minmax(0, 1fr)); }
}

@media (min-width: 768px) {
    .app-main { padding: 24px; }
    .hero-grid { grid-template-columns: 1.25fr 0.75fr; align-items: center; }
    .hero-card h1, .auth-card h1 { font-size: 34px; }
    .search-box { grid-template-columns: 1fr 150px; }
    .quick-actions { grid-template-columns: repeat(4, minmax(0, 1fr)); }
    .bottom-nav { width: min(100%, 560px); right: 50%; left: auto; transform: translateX(50%); border-radius: 28px 28px 0 0; border: 1px solid var(--line); border-bottom: 0; box-shadow: 0 -12px 40px rgba(25,79,146,.09); }
}

@media (prefers-reduced-motion: reduce) {
    *, *::before, *::after { transition-duration: 0.01ms !important; animation-duration: 0.01ms !important; scroll-behavior: auto !important; }
}

.form-help {
    display: block;
    margin-top: .75rem;
    color: var(--color-muted);
    font-size: .86rem;
}

.ghost-button {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: .85rem 1rem;
    border-radius: 16px;
    background: var(--color-card);
    color: var(--color-primary);
    border: 1px solid var(--color-border);
    text-decoration: none;
    font-weight: 700;
}

.action-row {
    display: flex;
    gap: .75rem;
    flex-wrap: wrap;
    margin-top: 1rem;
}

.payment-result-card {
    border-radius: 22px;
    padding: 1.2rem;
    display: grid;
    gap: .45rem;
    border: 1px solid var(--color-border);
}

.payment-result-card strong {
    font-size: 1.05rem;
}

.payment-result-card small {
    color: var(--color-muted);
}

.payment-ok {
    background: rgba(63, 166, 107, .12);
    border-color: rgba(63, 166, 107, .28);
}

.payment-fail {
    background: rgba(239, 183, 186, .25);
    border-color: rgba(239, 183, 186, .55);
}

.field-hint {
    display: block;
    margin-top: 6px;
    color: var(--ink-500);
    font-size: 12px;
    line-height: 1.8;
}

.image-preview-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 10px;
    margin-top: 8px;
}

.image-preview-card {
    position: relative;
    display: grid;
    gap: 7px;
    padding: 8px;
    border: 1px solid var(--line);
    border-radius: 16px;
    background: #fff;
    cursor: pointer;
    overflow: hidden;
}

.image-preview-card.is-primary {
    border-color: var(--blue);
    box-shadow: 0 0 0 3px rgba(203, 213, 240, 0.65);
}

.image-preview-card img {
    width: 100%;
    aspect-ratio: 1.2 / 1;
    object-fit: cover;
    border-radius: 12px;
    background: var(--blue-50);
}

.image-preview-card input {
    position: absolute;
    top: 10px;
    right: 10px;
    width: 20px;
    min-height: 20px;
    accent-color: var(--blue);
}

.image-preview-card span {
    color: var(--ink-700);
    font-size: 11px;
    line-height: 1.7;
}

.featured-badge {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: fit-content;
    margin-bottom: 6px;
    padding: 5px 10px;
    border-radius: 999px;
    color: #fff;
    background: linear-gradient(135deg, #194F92, #EFB7BA);
    font-size: 12px;
    font-weight: 800;
    box-shadow: 0 10px 22px rgba(25, 79, 146, .18);
}

.mini-list__item {
    display: grid;
    grid-template-columns: 1fr auto;
    align-items: center;
    gap: 10px;
    padding: 10px 0;
    border-bottom: 1px solid var(--line);
}

.mini-list__item:last-child { border-bottom: 0; }

.mini-boost-button {
    min-height: 38px;
    border: 0;
    border-radius: 999px;
    padding: 8px 12px;
    color: #fff;
    background: linear-gradient(135deg, var(--blue), #2B65A9);
    font-size: 12px;
    font-weight: 800;
    white-space: nowrap;
}

@media (min-width: 720px) {
    .image-preview-grid {
        grid-template-columns: repeat(5, minmax(0, 1fr));
    }
}

/* v0.8.1: Mobile image picker preview + lightbox */
.image-uploader {
    display: grid;
    gap: 8px;
}

.image-uploader__label {
    display: grid;
    gap: 8px;
    color: var(--ink-700);
    font-size: 13px;
    font-weight: 800;
}

.image-uploader__drop {
    position: relative;
    min-height: 92px;
    display: grid;
    place-items: center;
    gap: 4px;
    border: 1.5px dashed rgba(25, 79, 146, 0.34);
    border-radius: 20px;
    background:
        linear-gradient(135deg, rgba(203,213,240,.34), rgba(239,183,186,.20)),
        #fff;
    color: var(--blue);
    cursor: pointer;
}

.image-uploader__drop strong { font-size: 15px; }
.image-uploader__drop small { color: var(--ink-500); font-weight: 700; }
.image-uploader__input { margin-top: -8px; }

.image-preview-empty {
    grid-column: 1 / -1;
    padding: 12px;
    border: 1px dashed var(--line-strong);
    border-radius: 16px;
    color: var(--ink-500);
    background: rgba(255,255,255,.64);
    font-size: 12px;
    text-align: center;
}

.image-preview-card {
    position: relative;
    display: grid;
    gap: 7px;
    padding: 8px;
    border: 1px solid var(--line);
    border-radius: 18px;
    background: #fff;
    cursor: default;
    overflow: hidden;
}

.image-preview-card.is-processing::after {
    content: '';
    position: absolute;
    inset: 0;
    background: linear-gradient(110deg, transparent 0%, rgba(255,255,255,.48) 45%, transparent 90%);
    animation: tc-shimmer 1.15s infinite;
    pointer-events: none;
}

@keyframes tc-shimmer {
    0% { transform: translateX(110%); }
    100% { transform: translateX(-110%); }
}

.image-preview-card__image {
    width: 100%;
    border: 0;
    padding: 0;
    background: transparent;
    cursor: zoom-in;
}

.image-preview-card__image img,
.image-preview-card img {
    width: 100%;
    aspect-ratio: 1.2 / 1;
    object-fit: cover;
    border-radius: 13px;
    background: var(--blue-50);
    display: block;
}

.image-preview-card__badge {
    position: absolute;
    top: 12px;
    right: 12px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 24px;
    padding: 4px 8px;
    border-radius: 999px;
    color: #fff;
    background: rgba(25,79,146,.86);
    font-size: 10px;
    font-weight: 900;
    backdrop-filter: blur(8px);
}

.image-preview-card.is-primary .image-preview-card__badge {
    background: linear-gradient(135deg, var(--blue), #2B65A9);
}

.image-preview-card__meta {
    color: var(--ink-600);
    font-size: 11px;
    line-height: 1.7;
}

.image-preview-card__actions {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 6px;
}

.image-preview-action {
    min-height: 34px;
    border: 0;
    border-radius: 12px;
    padding: 7px 8px;
    background: var(--blue-50);
    color: var(--blue);
    font-size: 11px;
    font-weight: 900;
}

.image-preview-action:disabled {
    opacity: .72;
    cursor: default;
}

.image-preview-action--danger {
    background: rgba(239,183,186,.28);
    color: #A73845;
}

.image-lightbox {
    position: fixed;
    inset: 0;
    z-index: 9999;
    display: none;
    align-items: center;
    justify-content: center;
    padding: 18px;
    background: rgba(12, 23, 38, .82);
    backdrop-filter: blur(10px);
}

.image-lightbox.is-open { display: flex; }

.image-lightbox__body {
    width: min(980px, 96vw);
    display: grid;
    gap: 10px;
    justify-items: center;
}

.image-lightbox__body img {
    max-width: 96vw;
    max-height: 86vh;
    object-fit: contain;
    border-radius: 18px;
    background: #fff;
    box-shadow: 0 24px 80px rgba(0,0,0,.36);
}

.image-lightbox__close {
    position: absolute;
    top: calc(16px + env(safe-area-inset-top));
    left: 16px;
    width: 44px;
    height: 44px;
    border: 0;
    border-radius: 999px;
    color: #fff;
    background: rgba(255,255,255,.16);
    font-size: 28px;
    line-height: 1;
    cursor: pointer;
}

.image-lightbox__caption {
    max-width: min(760px, 92vw);
    color: rgba(255,255,255,.84);
    font-size: 12px;
    text-align: center;
    word-break: break-word;
}

@media (max-width: 420px) {
    .image-preview-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
    .image-preview-card { border-radius: 16px; padding: 7px; }
    .image-preview-card__actions { grid-template-columns: 1fr; }
}

/* v0.8.2: fixed 5-slot photo uploader, responsive and no page refresh while adding */
.tc-photo-uploader {
    display: grid;
    gap: 12px;
    padding: 12px;
    border: 1px solid var(--line);
    border-radius: 22px;
    background: linear-gradient(135deg, rgba(203,213,240,.28), rgba(239,183,186,.16)), #fff;
}

.tc-photo-uploader__head {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
}

.tc-photo-uploader__head > div {
    display: grid;
    gap: 3px;
}

.tc-photo-uploader__head strong {
    color: var(--ink-900);
    font-size: 14px;
    font-weight: 950;
}

.tc-photo-uploader__head small {
    color: var(--ink-500);
    font-size: 11px;
    font-weight: 700;
    line-height: 1.8;
}

.tc-photo-bulk-btn {
    flex: 0 0 auto;
    min-height: 40px;
    border: 0;
    border-radius: 14px;
    padding: 9px 14px;
    color: #fff;
    background: var(--blue);
    font-size: 12px;
    font-weight: 950;
    box-shadow: 0 12px 24px rgba(25,79,146,.18);
}

.tc-photo-slots {
    display: grid;
    grid-template-columns: repeat(5, minmax(0, 1fr));
    gap: 9px;
}

.tc-photo-slot {
    position: relative;
    min-width: 0;
    border: 1px solid rgba(25,79,146,.12);
    border-radius: 18px;
    background: rgba(255,255,255,.86);
    overflow: hidden;
}

.tc-photo-slot.is-primary {
    border-color: rgba(25,79,146,.70);
    box-shadow: 0 12px 26px rgba(25,79,146,.14);
}

.tc-photo-slot__empty {
    width: 100%;
    min-height: 118px;
    display: grid;
    place-items: center;
    align-content: center;
    gap: 4px;
    border: 0;
    background: linear-gradient(135deg, rgba(203,213,240,.42), rgba(250,250,251,.92));
    color: var(--blue);
    cursor: pointer;
}

.tc-photo-slot__empty span {
    width: 34px;
    height: 34px;
    display: inline-grid;
    place-items: center;
    border-radius: 50%;
    color: #fff;
    background: var(--blue);
    font-size: 26px;
    line-height: 1;
    box-shadow: 0 12px 24px rgba(25,79,146,.18);
}

.tc-photo-slot__empty strong {
    font-size: 12px;
    font-weight: 950;
}

.tc-photo-slot__empty small {
    color: var(--ink-500);
    font-size: 10px;
    font-weight: 800;
}

.tc-photo-slot__filled {
    display: grid;
    gap: 7px;
    padding: 7px;
}

.tc-photo-slot__image {
    width: 100%;
    border: 0;
    padding: 0;
    background: transparent;
    cursor: zoom-in;
}

.tc-photo-slot__image img {
    width: 100%;
    aspect-ratio: 1 / 1;
    display: block;
    object-fit: cover;
    border-radius: 13px;
    background: var(--blue-50);
}

.tc-photo-slot__badge {
    position: absolute;
    top: 10px;
    right: 10px;
    min-height: 23px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border-radius: 999px;
    padding: 3px 8px;
    color: #fff;
    background: rgba(25,79,146,.82);
    font-size: 10px;
    font-weight: 950;
    backdrop-filter: blur(8px);
}

.tc-photo-slot.is-primary .tc-photo-slot__badge {
    background: linear-gradient(135deg, var(--blue), #2B65A9);
}

.tc-photo-slot__meta {
    min-height: 18px;
    color: var(--ink-500);
    font-size: 10px;
    font-weight: 750;
    line-height: 1.8;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.tc-photo-slot__actions {
    display: grid;
    grid-template-columns: 1fr 1fr 1fr;
    gap: 5px;
}

.tc-photo-slot__actions button {
    min-height: 31px;
    border: 0;
    border-radius: 11px;
    padding: 6px 4px;
    background: var(--blue-50);
    color: var(--blue);
    font-size: 10px;
    font-weight: 950;
}

.tc-photo-slot__actions button:disabled {
    opacity: .72;
}

.tc-photo-slot__actions button.danger {
    color: #A73845;
    background: rgba(239,183,186,.28);
}

.tc-photo-slot.is-processing::after {
    content: '';
    position: absolute;
    inset: 0;
    background: linear-gradient(110deg, transparent 0%, rgba(255,255,255,.58) 45%, transparent 90%);
    animation: tc-shimmer 1.15s infinite;
    pointer-events: none;
}

.tc-photo-lightbox {
    position: fixed;
    inset: 0;
    z-index: 10000;
    display: none;
    align-items: center;
    justify-content: center;
    padding: 18px;
    background: rgba(12,23,38,.84);
    backdrop-filter: blur(10px);
}

.tc-photo-lightbox.is-open { display: flex; }

.tc-photo-lightbox img {
    max-width: 96vw;
    max-height: 84vh;
    object-fit: contain;
    border-radius: 18px;
    background: #fff;
    box-shadow: 0 24px 80px rgba(0,0,0,.36);
}

.tc-photo-lightbox__close {
    position: absolute;
    top: calc(16px + env(safe-area-inset-top));
    left: 16px;
    width: 44px;
    height: 44px;
    border: 0;
    border-radius: 999px;
    color: #fff;
    background: rgba(255,255,255,.16);
    font-size: 28px;
    line-height: 1;
}

.tc-photo-lightbox__meta {
    position: absolute;
    right: 18px;
    bottom: calc(18px + env(safe-area-inset-bottom));
    left: 18px;
    color: rgba(255,255,255,.84);
    font-size: 12px;
    text-align: center;
    word-break: break-word;
}

@media (max-width: 900px) {
    .tc-photo-slots { grid-template-columns: repeat(3, minmax(0, 1fr)); }
}

@media (max-width: 560px) {
    .tc-photo-uploader { padding: 10px; border-radius: 20px; }
    .tc-photo-uploader__head { align-items: stretch; flex-direction: column; }
    .tc-photo-bulk-btn { width: 100%; }
    .tc-photo-slots { grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 8px; }
    .tc-photo-slot__empty { min-height: 110px; }
    .tc-photo-slot:first-child { grid-column: span 2; }
    .tc-photo-slot:first-child .tc-photo-slot__image img { aspect-ratio: 16 / 9; }
    .tc-photo-slot__actions { grid-template-columns: 1fr 1fr; }
    .tc-photo-slot__actions button:first-child { grid-column: span 2; }
}

/* v0.8.4: Divar-style photo uploader with fixed 150x150 thumbnails and local FontAwesome icons */
.divar-photo-uploader {
    display: grid;
    gap: 12px;
    padding: 14px;
    border: 1px solid var(--line);
    border-radius: 22px;
    background: rgba(255, 255, 255, 0.74);
    box-shadow: var(--shadow-card);
}

.divar-photo-uploader__title {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 12px;
}

.divar-photo-uploader__title strong {
    display: inline-flex;
    align-items: center;
    gap: 4px;
    font-size: 17px;
    color: var(--ink-900);
}

.divar-photo-uploader__title strong span { color: var(--danger); }
.divar-photo-uploader__title small {
    max-width: 58%;
    color: var(--ink-500);
    font-size: 12px;
    line-height: 1.9;
    text-align: left;
}

.divar-photo-rail {
    display: flex;
    flex-direction: row;
    align-items: stretch;
    gap: 10px;
    overflow-x: auto;
    overflow-y: hidden;
    padding: 2px 0 8px;
    scroll-snap-type: x proximity;
    -webkit-overflow-scrolling: touch;
}

.divar-photo-rail::-webkit-scrollbar { height: 6px; }
.divar-photo-rail::-webkit-scrollbar-thumb {
    background: rgba(25, 79, 146, .20);
    border-radius: 999px;
}

.divar-add-photo-card,
.divar-photo-thumb {
    position: relative;
    flex: 0 0 150px;
    width: 150px;
    height: 150px;
    min-width: 150px;
    max-width: 150px;
    border-radius: 18px;
    scroll-snap-align: start;
}

.divar-add-photo-card {
    display: grid;
    place-content: center;
    gap: 6px;
    color: var(--ink-500);
    background: #fff;
    border: 2px dashed rgba(23, 32, 51, .28);
    box-shadow: inset 0 0 0 1px rgba(255,255,255,.6);
    transition: .18s ease;
}

.divar-add-photo-card:hover,
.divar-add-photo-card:focus-visible {
    color: var(--blue);
    border-color: var(--blue);
    background: var(--blue-50);
    outline: none;
}

.divar-add-photo-card__icon {
    position: relative;
    width: 58px;
    height: 58px;
    margin: 0 auto;
    display: grid;
    place-items: center;
    color: currentColor;
}

.divar-add-photo-card__icon .fa-camera {
    font-size: 48px;
    line-height: 1;
}

.divar-add-photo-card__plus {
    position: absolute;
    top: -4px;
    left: -4px;
    width: 24px;
    height: 24px;
    border-radius: 50%;
    display: grid;
    place-items: center;
    color: #fff;
    background: var(--blue);
    border: 2px solid #fff;
    font-size: 13px;
    box-shadow: 0 8px 18px rgba(25,79,146,.24);
}

.divar-add-photo-card strong {
    font-size: 14px;
    color: currentColor;
}

.divar-photo-thumb {
    overflow: hidden;
    background: #fff;
    border: 1px solid var(--line-strong);
    box-shadow: 0 8px 22px rgba(25,79,146,.10);
}

.divar-photo-thumb.is-primary {
    border-color: var(--blue);
    box-shadow: 0 10px 26px rgba(25,79,146,.18);
}

.divar-photo-thumb.is-processing::after {
    content: '';
    position: absolute;
    inset: 0;
    background: linear-gradient(110deg, transparent, rgba(255,255,255,.58), transparent);
    animation: tc-shimmer 1.2s linear infinite;
    pointer-events: none;
}

.divar-photo-thumb__image {
    width: 100%;
    height: 100%;
    border: 0;
    padding: 0;
    display: block;
    background: #f4f6fb;
}

.divar-photo-thumb__image img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
}

.divar-photo-thumb__badge {
    position: absolute;
    right: 8px;
    bottom: 8px;
    z-index: 2;
    padding: 4px 8px;
    color: #fff;
    background: rgba(23,32,51,.76);
    border-radius: 999px;
    font-size: 11px;
    font-weight: 800;
    backdrop-filter: blur(8px);
    display: inline-flex;
    align-items: center;
    gap: 4px;
}

.divar-photo-thumb.is-primary .divar-photo-thumb__badge {
    background: rgba(25,79,146,.88);
}

.divar-photo-thumb__remove {
    position: absolute;
    top: 7px;
    left: 7px;
    z-index: 3;
    width: 30px;
    height: 30px;
    border: 0;
    border-radius: 50%;
    display: grid;
    place-items: center;
    font-size: 16px;
    line-height: 1;
    color: #fff;
    background: rgba(23,32,51,.70);
    backdrop-filter: blur(8px);
}

.divar-photo-thumb__primary {
    position: absolute;
    right: 8px;
    top: 8px;
    z-index: 3;
    min-height: 28px;
    padding: 4px 8px;
    border: 0;
    border-radius: 999px;
    color: var(--blue);
    background: rgba(250,250,251,.90);
    font-size: 11px;
    font-weight: 900;
    backdrop-filter: blur(8px);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 4px;
}

.divar-photo-thumb__primary:disabled {
    color: #fff;
    background: rgba(25,79,146,.90);
    cursor: default;
}

.divar-photo-thumb__meta {
    position: absolute;
    left: 7px;
    bottom: 8px;
    z-index: 2;
    max-width: 52px;
    overflow: hidden;
    white-space: nowrap;
    text-overflow: ellipsis;
    color: #fff;
    font-size: 10px;
    direction: ltr;
    text-align: left;
    opacity: .86;
    text-shadow: 0 1px 8px rgba(0,0,0,.38);
}

.divar-photo-lightbox {
    position: fixed;
    inset: 0;
    z-index: 400;
    display: none;
    align-items: center;
    justify-content: center;
    padding: 18px;
    background: rgba(5, 10, 20, .86);
    backdrop-filter: blur(10px);
}
.divar-photo-lightbox.is-open { display: flex; }
.divar-photo-lightbox__body {
    width: min(96vw, 880px);
    display: grid;
    gap: 10px;
    justify-items: center;
}
.divar-photo-lightbox__body img {
    width: auto;
    max-width: 100%;
    max-height: 82vh;
    object-fit: contain;
    border-radius: 18px;
    box-shadow: 0 18px 60px rgba(0,0,0,.35);
}
.divar-photo-lightbox__meta {
    color: #fff;
    opacity: .82;
    font-size: 13px;
    direction: ltr;
}
.divar-photo-lightbox__close {
    position: fixed;
    top: max(18px, env(safe-area-inset-top));
    left: 18px;
    width: 44px;
    height: 44px;
    border: 0;
    border-radius: 50%;
    display: grid;
    place-items: center;
    color: #fff;
    background: rgba(255,255,255,.16);
    font-size: 30px;
    line-height: 1;
}

@media (max-width: 680px) {
    .divar-photo-uploader { padding: 12px; border-radius: 20px; }
    .divar-photo-uploader__title { display: grid; gap: 3px; }
    .divar-photo-uploader__title small { max-width: 100%; text-align: right; }
    .divar-photo-rail {
        gap: 8px;
        margin-inline: -2px;
        padding-inline: 2px;
    }
    .divar-add-photo-card,
    .divar-photo-thumb {
        flex-basis: 150px;
        width: 150px;
        height: 150px;
        min-width: 150px;
        max-width: 150px;
        border-radius: 16px;
    }
    .divar-add-photo-card__icon { width: 54px; height: 54px; }
    .divar-add-photo-card__icon .fa-camera { font-size: 44px; }
    .divar-add-photo-card strong { font-size: 13px; }
    .divar-photo-thumb__primary { font-size: 10px; padding-inline: 7px; }
    .divar-photo-thumb__badge { font-size: 10px; }
    .divar-photo-lightbox { padding: 10px; }
    .divar-photo-lightbox__body img { max-height: 76vh; border-radius: 14px; }
}

/* v0.8.6: separate operator review panel */
.operator-page .section-title h1 { display: flex; align-items: center; gap: 8px; }
.operator-tabs a { display: inline-flex; align-items: center; gap: 6px; }
.operator-stats .stat-card strong { color: var(--primary); }
.compact-title { margin-bottom: 12px; }
.operator-review-list { display: grid; gap: 12px; }
.operator-review-card {
    display: grid;
    grid-template-columns: 96px minmax(0, 1fr);
    gap: 12px;
    align-items: stretch;
    background: rgba(255,255,255,.92);
    border: 1px solid rgba(25,79,146,.12);
    border-radius: 22px;
    padding: 10px;
    box-shadow: 0 14px 35px rgba(25,79,146,.06);
}
.operator-review-card--wide { grid-template-columns: 112px minmax(0, 1fr); }
.operator-review-card__image {
    width: 96px;
    height: 96px;
    border-radius: 18px;
    overflow: hidden;
    background: #FAFAFB;
    border: 1px dashed rgba(25,79,146,.24);
    display: flex;
    align-items: center;
    justify-content: center;
    color: var(--primary);
    text-decoration: none;
}
.operator-review-card--wide .operator-review-card__image { width: 112px; height: 112px; }
.operator-review-card__image img { width: 100%; height: 100%; object-fit: cover; display: block; }
.operator-review-card__image i { font-size: 28px; opacity: .55; }
.operator-review-card__body { min-width: 0; display: grid; gap: 6px; align-content: center; }
.operator-review-card__body strong { color: var(--text); overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.operator-review-card__body small { color: var(--muted); line-height: 1.9; }
.operator-review-card__top { display: flex; justify-content: space-between; gap: 10px; align-items: flex-start; }
.operator-price { white-space: nowrap; color: var(--primary); font-weight: 900; }
.operator-actions { display: flex; flex-wrap: wrap; gap: 8px; align-items: center; }
.operator-inline-form { display: flex; flex-wrap: wrap; gap: 6px; margin: 0; }
.btn-approve,
.btn-reject {
    border: 0;
    border-radius: 14px;
    padding: 8px 12px;
    font-weight: 800;
    cursor: pointer;
    display: inline-flex;
    align-items: center;
    gap: 6px;
}
.btn-approve { background: #e6f7ef; color: #167349; }
.btn-reject { background: #fff0f1; color: #b3263a; }
.btn-approve:hover { filter: brightness(.97); }
.btn-reject:hover { filter: brightness(.97); }
.operator-detail-grid { display: grid; grid-template-columns: minmax(0, .95fr) minmax(0, 1.05fr); gap: 16px; align-items: start; }
.operator-detail-gallery { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 10px; }
.operator-detail-image {
    position: relative;
    display: block;
    border-radius: 20px;
    overflow: hidden;
    border: 1px solid rgba(25,79,146,.14);
    background: #FAFAFB;
    min-height: 150px;
}
.operator-detail-image img { width: 100%; height: 100%; aspect-ratio: 1 / 1; object-fit: cover; display: block; }
.operator-detail-image span {
    position: absolute;
    right: 8px;
    bottom: 8px;
    background: rgba(25,79,146,.92);
    color: #fff;
    border-radius: 999px;
    padding: 6px 10px;
    font-size: 12px;
    font-weight: 800;
}
.operator-detail-card { margin: 0; }
.operator-detail-head { display: flex; align-items: flex-start; justify-content: space-between; gap: 10px; }
.operator-detail-head h2 { margin: 0; }
.operator-review-actions { display: flex; gap: 10px; flex-wrap: wrap; margin-top: 16px; }
.operator-review-actions button { min-height: 44px; padding-inline: 18px; }
@media (max-width: 720px) {
    .operator-review-card,
    .operator-review-card--wide { grid-template-columns: 88px minmax(0, 1fr); border-radius: 18px; }
    .operator-review-card__image,
    .operator-review-card--wide .operator-review-card__image { width: 88px; height: 88px; border-radius: 16px; }
    .operator-review-card__top { display: grid; gap: 4px; }
    .operator-inline-form { width: 100%; }
    .operator-inline-form button { flex: 1; justify-content: center; }
    .operator-detail-grid { grid-template-columns: 1fr; }
    .operator-detail-gallery { display: flex; gap: 10px; overflow-x: auto; padding-bottom: 4px; }
    .operator-detail-image { min-width: 150px; width: 150px; height: 150px; }
    .operator-review-actions button { flex: 1; justify-content: center; }
}

/* v0.8.8: improved public listing detail page with compact clickable gallery */
.piece-show-page {
    display: grid;
    gap: 14px;
}

.piece-show-topbar {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 10px;
    flex-wrap: wrap;
}

.piece-show-back {
    gap: 8px;
    min-height: 42px;
}

.piece-show-grid {
    display: grid;
    gap: 14px;
}

.piece-show-gallery-card,
.piece-show-card {
    overflow: hidden;
}

.piece-gallery-head {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 10px;
    margin-bottom: 12px;
}

.piece-gallery-head strong {
    display: inline-flex;
    align-items: center;
    gap: 7px;
    color: var(--ink-900);
    font-size: 15px;
}

.piece-gallery-head strong i { color: var(--blue); }
.piece-gallery-head span { color: var(--ink-500); font-size: 12px; }

.piece-thumb-rail {
    display: flex;
    gap: 10px;
    overflow-x: auto;
    padding: 2px 1px 8px;
    scroll-snap-type: x proximity;
    -webkit-overflow-scrolling: touch;
}

.piece-thumb-rail::-webkit-scrollbar { height: 6px; }
.piece-thumb-rail::-webkit-scrollbar-thumb {
    background: rgba(25,79,146,.24);
    border-radius: 999px;
}

.piece-thumb {
    position: relative;
    flex: 0 0 150px;
    width: 150px;
    height: 150px;
    border: 1px solid var(--line);
    border-radius: 18px;
    padding: 0;
    overflow: hidden;
    background: var(--white);
    box-shadow: 0 8px 18px rgba(25,79,146,.07);
    scroll-snap-align: start;
    transition: transform .18s ease, border-color .18s ease, box-shadow .18s ease;
}

.piece-thumb:hover,
.piece-thumb:focus-visible {
    transform: translateY(-2px);
    border-color: rgba(25,79,146,.42);
    box-shadow: 0 14px 26px rgba(25,79,146,.13);
    outline: 0;
}

.piece-thumb.is-primary {
    border: 2px solid var(--blue);
}

.piece-thumb img {
    width: 150px;
    height: 150px;
    display: block;
    object-fit: cover;
}

.piece-thumb::after {
    content: '\f00e';
    font-family: 'Font Awesome 6 Free';
    font-weight: 900;
    position: absolute;
    left: 8px;
    bottom: 8px;
    display: grid;
    place-items: center;
    width: 28px;
    height: 28px;
    border-radius: 999px;
    color: #fff;
    background: rgba(25,79,146,.86);
    box-shadow: 0 8px 18px rgba(25,79,146,.22);
}

.piece-thumb__badge {
    position: absolute;
    right: 8px;
    bottom: 8px;
    display: inline-flex;
    align-items: center;
    gap: 4px;
    padding: 5px 8px;
    border-radius: 999px;
    color: #fff;
    background: var(--blue);
    font-size: 11px;
    font-weight: 700;
}

.piece-empty-gallery {
    display: grid;
    place-items: center;
    gap: 8px;
    min-height: 150px;
    border: 1px dashed rgba(25,79,146,.32);
    border-radius: 18px;
    color: var(--ink-500);
    background: rgba(203,213,240,.24);
}

.piece-empty-gallery i {
    color: var(--blue);
    font-size: 34px;
}

.piece-show-title-row {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    gap: 12px;
    flex-wrap: wrap;
}

.piece-show-title-row h1 {
    margin: 0 0 8px;
    font-size: 22px;
    line-height: 1.55;
    color: var(--ink-900);
}

.piece-show-meta {
    display: flex;
    align-items: center;
    gap: 8px;
    flex-wrap: wrap;
    color: var(--ink-500);
    font-size: 12px;
}

.piece-show-meta span,
.piece-seller-card span,
.piece-price-card span,
.piece-spec-list span {
    color: var(--ink-500);
}

.piece-show-meta i { color: var(--blue); }

.piece-price-card {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
    margin: 14px 0;
    padding: 14px;
    border: 1px solid rgba(25,79,146,.12);
    border-radius: 18px;
    background: linear-gradient(135deg, rgba(203,213,240,.42), rgba(239,183,186,.20));
}

.piece-price-card strong {
    direction: ltr;
    color: var(--blue);
    font-size: 22px;
    font-weight: 800;
    white-space: nowrap;
}

.piece-spec-list {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 10px;
}

.piece-spec-list > div {
    display: grid;
    grid-template-columns: 28px 1fr;
    align-items: center;
    column-gap: 8px;
    row-gap: 2px;
    min-height: 68px;
    padding: 12px;
    border: 1px solid var(--line);
    border-radius: 16px;
    background: rgba(255,255,255,.82);
}

.piece-spec-list i {
    grid-row: span 2;
    display: grid;
    place-items: center;
    width: 28px;
    height: 28px;
    border-radius: 10px;
    color: var(--blue);
    background: var(--blue-50);
}

.piece-spec-list strong {
    color: var(--ink-900);
    font-size: 13px;
    line-height: 1.7;
}

.piece-description-card {
    margin-top: 12px;
    padding: 14px;
    border: 1px solid var(--line);
    border-radius: 18px;
    background: rgba(255,255,255,.82);
}

.piece-description-card h2 {
    display: flex;
    align-items: center;
    gap: 7px;
    margin: 0 0 8px;
    color: var(--ink-900);
    font-size: 15px;
}

.piece-description-card h2 i { color: var(--blue); }
.piece-description-card p { margin: 0; color: var(--ink-700); line-height: 1.95; }

.piece-seller-card {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
    margin-top: 12px;
    padding: 14px;
    border-radius: 18px;
    color: #fff;
    background: linear-gradient(135deg, var(--blue), #2E6FB5);
    box-shadow: 0 14px 32px rgba(25,79,146,.18);
}

.piece-seller-card span { color: rgba(255,255,255,.76); font-size: 12px; }
.piece-seller-card strong { display: block; margin-top: 5px; font-size: 18px; }
.piece-seller-card .primary-link { margin: 0; background: #fff; color: var(--blue); white-space: nowrap; }

.piece-detail-lightbox {
    position: fixed;
    inset: 0;
    z-index: 120;
    display: none;
    align-items: center;
    justify-content: center;
    padding: 16px;
    background: rgba(12, 20, 34, .82);
    backdrop-filter: blur(12px);
}

.piece-detail-lightbox.is-open { display: flex; }

.piece-detail-lightbox__body {
    position: relative;
    display: grid;
    gap: 10px;
    width: min(96vw, 980px);
}

.piece-detail-lightbox__body img {
    max-width: 100%;
    max-height: 82vh;
    object-fit: contain;
    border-radius: 18px;
    background: #fff;
    box-shadow: 0 24px 80px rgba(0,0,0,.34);
}

.piece-detail-lightbox__caption {
    color: #fff;
    text-align: center;
    font-size: 13px;
}

.piece-detail-lightbox__close {
    position: fixed;
    top: 14px;
    left: 14px;
    z-index: 2;
    display: grid;
    place-items: center;
    width: 44px;
    height: 44px;
    border: 0;
    border-radius: 999px;
    color: #fff;
    background: rgba(255,255,255,.18);
    font-size: 30px;
}

@media (min-width: 860px) {
    .piece-show-grid {
        grid-template-columns: 360px 1fr;
        align-items: start;
    }
    .piece-show-gallery-card {
        position: sticky;
        top: 86px;
    }
    .piece-thumb-rail {
        display: grid;
        grid-template-columns: repeat(2, 150px);
        overflow: visible;
        justify-content: center;
    }
}

@media (max-width: 560px) {
    .piece-show-card,
    .piece-show-gallery-card { padding: 12px; border-radius: 20px; }
    .piece-show-title-row h1 { font-size: 19px; }
    .piece-price-card { align-items: flex-start; flex-direction: column; }
    .piece-price-card strong { font-size: 20px; }
    .piece-spec-list { grid-template-columns: 1fr; }
    .piece-thumb-rail { margin-inline: -2px; }
    .piece-seller-card { align-items: stretch; flex-direction: column; }
    .piece-seller-card .primary-link { width: 100%; }
}

/* v0.9.0 internal chat */
.messages-page,
.chat-page {
    display: grid;
    gap: 14px;
}

.chat-empty-state {
    text-align: center;
    padding: 34px 18px;
}

.chat-empty-state i {
    display: grid;
    place-items: center;
    width: 64px;
    height: 64px;
    margin: 0 auto 14px;
    border-radius: 22px;
    color: var(--blue);
    background: var(--blue-50);
    font-size: 28px;
}

.chat-thread-list {
    display: grid;
    gap: 10px;
}

.chat-thread-card {
    display: grid;
    grid-template-columns: 48px 1fr auto;
    gap: 12px;
    align-items: center;
    padding: 12px;
    border: 1px solid var(--line);
    border-radius: 18px;
    color: inherit;
    text-decoration: none;
    background: rgba(255,255,255,.86);
    box-shadow: 0 8px 24px rgba(25,79,146,.06);
}

.chat-thread-card.has-unread {
    border-color: rgba(25,79,146,.25);
    background: linear-gradient(135deg, rgba(203,213,240,.36), rgba(255,255,255,.92));
}

.chat-thread-card__icon {
    display: grid;
    place-items: center;
    width: 48px;
    height: 48px;
    border-radius: 16px;
    color: var(--blue);
    background: var(--blue-50);
    font-size: 20px;
}

.chat-thread-card__body {
    display: grid;
    gap: 3px;
    min-width: 0;
}

.chat-thread-card__body strong,
.chat-thread-card__body small,
.chat-thread-card__body em {
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.chat-thread-card__body strong { color: var(--ink-900); }
.chat-thread-card__body small { color: var(--ink-500); font-style: normal; }
.chat-thread-card__body em { color: var(--ink-600); font-style: normal; font-size: 12px; }

.chat-thread-card__meta {
    display: grid;
    justify-items: end;
    gap: 6px;
    color: var(--ink-400);
    font-size: 12px;
}

.chat-thread-card__meta b {
    display: grid;
    place-items: center;
    min-width: 24px;
    height: 24px;
    padding: 0 7px;
    border-radius: 999px;
    color: #fff;
    background: var(--blue);
    font-size: 12px;
}

.chat-header-card,
.chat-context-card {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
    padding: 12px;
    border: 1px solid var(--line);
    border-radius: 18px;
    background: rgba(255,255,255,.9);
}

.chat-header-card__info {
    display: grid;
    gap: 3px;
    flex: 1;
    min-width: 0;
}

.chat-header-card__info strong { color: var(--ink-900); }
.chat-header-card__info span {
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
    color: var(--ink-500);
    font-size: 12px;
}

.chat-context-card {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
}

.chat-context-card div {
    display: grid;
    gap: 4px;
}

.chat-context-card span { color: var(--ink-500); font-size: 12px; }
.chat-context-card strong { color: var(--ink-900); }

.chat-bubbles {
    display: grid;
    gap: 10px;
    padding: 12px;
    min-height: 320px;
    max-height: min(58vh, 620px);
    overflow: auto;
    border: 1px solid var(--line);
    border-radius: 20px;
    background: linear-gradient(180deg, rgba(203,213,240,.22), rgba(250,250,251,.92));
}

.chat-bubble-row {
    display: flex;
}

.chat-bubble-row.is-mine { justify-content: flex-start; }
.chat-bubble-row.is-theirs { justify-content: flex-end; }

.chat-bubble {
    max-width: min(76%, 560px);
    padding: 10px 12px;
    border-radius: 18px;
    box-shadow: 0 8px 22px rgba(15,23,42,.08);
}

.chat-bubble-row.is-mine .chat-bubble {
    color: #fff;
    border-bottom-right-radius: 6px;
    background: linear-gradient(135deg, var(--blue), #2E6FB5);
}

.chat-bubble-row.is-theirs .chat-bubble {
    color: var(--ink-900);
    border-bottom-left-radius: 6px;
    background: #fff;
    border: 1px solid var(--line);
}

.chat-bubble p {
    margin: 0 0 5px;
    line-height: 1.9;
    white-space: normal;
    overflow-wrap: anywhere;
}

.chat-bubble span {
    display: block;
    font-size: 11px;
    opacity: .72;
}

.chat-system-note {
    align-self: center;
    justify-self: center;
    padding: 10px 14px;
    border-radius: 999px;
    color: var(--ink-500);
    background: rgba(255,255,255,.8);
    font-size: 12px;
}

.chat-compose {
    position: sticky;
    bottom: 76px;
    display: grid;
    grid-template-columns: 1fr auto;
    gap: 10px;
    padding: 10px;
    border: 1px solid var(--line);
    border-radius: 20px;
    background: rgba(255,255,255,.94);
    box-shadow: 0 -8px 24px rgba(25,79,146,.08);
}

.chat-compose textarea {
    resize: vertical;
    min-height: 46px;
    max-height: 140px;
    border: 1px solid var(--line);
    border-radius: 16px;
    padding: 11px 12px;
    font: inherit;
    background: var(--bg);
}

.chat-compose button,
.operator-message-box button {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 7px;
    border: 0;
    border-radius: 16px;
    padding: 0 16px;
    color: #fff;
    background: var(--blue);
    font: inherit;
    font-weight: 700;
    cursor: pointer;
}

.operator-message-box {
    margin-top: 14px;
    padding: 14px;
    border: 1px dashed rgba(25,79,146,.25);
    border-radius: 18px;
    background: rgba(203,213,240,.18);
}

.operator-message-box h3 {
    display: flex;
    align-items: center;
    gap: 8px;
    margin: 0 0 6px;
    color: var(--ink-900);
    font-size: 15px;
}

.operator-message-box p {
    margin: 0 0 10px;
    color: var(--ink-600);
    font-size: 12px;
    line-height: 1.8;
}

.operator-message-box form {
    display: grid;
    gap: 10px;
}

.operator-message-box textarea {
    width: 100%;
    border: 1px solid var(--line);
    border-radius: 16px;
    padding: 12px;
    font: inherit;
    resize: vertical;
    background: #fff;
}

.piece-action-card {
    align-items: flex-start;
}

.piece-action-card small {
    display: block;
    margin-top: 6px;
    color: rgba(255,255,255,.72);
    font-size: 12px;
}

.piece-action-card__actions {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    justify-content: flex-end;
}

.piece-action-card__actions form { margin: 0; }
.piece-action-card__actions button.primary-link { border: 0; cursor: pointer; font: inherit; font-weight: 700; }
.secondary-call-link { background: rgba(255,255,255,.16) !important; color: #fff !important; border: 1px solid rgba(255,255,255,.34); }

@media (max-width: 560px) {
    .chat-thread-card { grid-template-columns: 44px 1fr; }
    .chat-thread-card__meta { grid-column: 2; display: flex; align-items: center; justify-content: space-between; }
    .chat-header-card { align-items: stretch; flex-direction: column; }
    .chat-context-card { grid-template-columns: 1fr; }
    .chat-bubble { max-width: 88%; }
    .chat-compose { grid-template-columns: 1fr; bottom: 72px; }
    .chat-compose button { min-height: 44px; }
    .piece-action-card__actions { justify-content: stretch; width: 100%; }
    .piece-action-card__actions .primary-link,
    .piece-action-card__actions form { width: 100%; }
}

/* v0.9.1 chat delivery/read state */
.chat-message-meta {
    display: flex !important;
    align-items: center;
    justify-content: space-between;
    gap: 10px;
}

.chat-message-status {
    display: inline-flex;
    align-items: center;
    gap: 4px;
    white-space: nowrap;
    opacity: .82;
    font-size: 11px;
}

.chat-message-status i {
    font-size: 12px;
}

.chat-message-status.is-seen {
    opacity: 1;
    color: #dff0ff;
}

.chat-bubble-row.is-theirs .chat-message-status.is-seen {
    color: var(--blue);
}

.chat-compose.has-error {
    border-color: rgba(220, 38, 38, .35);
    box-shadow: 0 -8px 24px rgba(220,38,38,.08);
}

.chat-compose button.is-loading {
    opacity: .7;
    pointer-events: none;
}

.chat-compose button.is-loading span::after {
    content: '...';
}

.operator-rejection-reason {
    display: none;
    margin-top: 12px;
}

.operator-review-actions:has(button[name="status"][value="rejected"]:focus) .operator-rejection-reason,
.operator-review-actions.is-rejecting .operator-rejection-reason {
    display: grid;
}

.operator-rejection-reason textarea {
    width: 100%;
    min-height: 86px;
    border: 1px solid var(--line);
    border-radius: 16px;
    padding: 11px 12px;
    font: inherit;
    resize: vertical;
    background: #fff;
}
.operator-rejection-reason label {
    color: var(--ink-900);
    font-weight: 800;
    font-size: 13px;
}

.operator-rejection-reason small {
    color: var(--ink-500);
    font-size: 12px;
    line-height: 1.8;
}

/* v0.9.3 Trusted-device auth polish */
.form-hint {
    display: block;
    margin-top: .65rem;
    color: var(--color-muted);
    font-size: .82rem;
    line-height: 1.8;
}
.dashboard-logout-actions {
    display: flex;
    align-items: center;
    gap: .65rem;
    flex-wrap: wrap;
    justify-content: flex-end;
}
.dashboard-logout-actions form {
    margin: 0;
}
.danger-link {
    color: #b42318 !important;
}
.trusted-device-note p {
    margin: .4rem 0 0;
    color: var(--color-muted);
    line-height: 1.9;
}

/* v0.9.4: listing edit/resubmit/history UI */
.panel-title-row {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 10px;
    margin-bottom: 10px;
}
.mini-list__actions {
    display: flex;
    align-items: center;
    gap: 8px;
    flex-wrap: wrap;
    justify-content: flex-end;
}
.mini-edit-link,
.owner-listing-card__actions a,
.owner-listing-card__actions button {
    min-height: 34px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border: 0;
    border-radius: 12px;
    padding: 7px 10px;
    color: var(--blue);
    background: var(--blue-50);
    font-size: 12px;
    font-weight: 900;
    text-decoration: none;
}
.review-alert {
    margin: 0 0 14px;
    padding: 12px 14px;
    border-radius: 18px;
    border: 1px solid var(--line);
    background: rgba(255,255,255,.86);
    display: grid;
    gap: 6px;
}
.review-alert strong { display: inline-flex; align-items: center; gap: 7px; color: var(--ink-900); }
.review-alert p { margin: 0; color: var(--ink-600); line-height: 1.9; }
.review-alert--danger { border-color: rgba(178,54,68,.22); background: rgba(239,183,186,.18); }
.review-alert--danger strong { color: #A73845; }
.review-alert--info { border-color: rgba(25,79,146,.16); background: rgba(203,213,240,.22); }
.review-alert--info strong { color: var(--blue); }

.existing-photo-editor {
    display: grid;
    gap: 10px;
    padding: 14px;
    border: 1px solid var(--line);
    border-radius: 22px;
    background: rgba(255,255,255,.78);
    box-shadow: var(--shadow-card);
}
.existing-photo-rail { padding-bottom: 8px; }
.existing-photo-thumb { flex: 0 0 150px; width: 150px; height: 150px; min-width: 150px; max-width: 150px; }
.existing-photo-thumb .divar-photo-thumb__primary { left: auto; right: 8px; }
.status-history-box { margin-top: 16px; }
.status-history-box h2 { display: flex; align-items: center; gap: 8px; margin-top: 0; }
.status-timeline { display: grid; gap: 10px; }
.status-timeline__item {
    position: relative;
    padding: 12px 14px;
    border: 1px solid rgba(25,79,146,.10);
    border-radius: 16px;
    background: rgba(250,250,251,.72);
}
.status-timeline__item strong { color: var(--blue); display: block; margin-bottom: 3px; }
.status-timeline__item small { color: var(--ink-500); font-size: 12px; }
.status-timeline__item p { margin: 6px 0 0; color: var(--ink-600); line-height: 1.8; }
.owner-action-panel {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
    padding: 12px;
    border-radius: 18px;
    background: rgba(203,213,240,.18);
    border: 1px solid rgba(25,79,146,.14);
    margin-bottom: 12px;
}
.owner-action-panel strong { display: flex; align-items: center; gap: 7px; color: var(--blue); }
.owner-action-panel small { color: var(--ink-500); display: block; margin-top: 3px; }
.owner-action-panel__actions { display: flex; gap: 8px; flex-wrap: wrap; }
.owner-action-panel__actions form { margin: 0; }
.piece-status-history { margin-top: 14px; }

.my-listing-filters { margin-bottom: 14px; }
.filter-pills { display: flex; gap: 8px; overflow-x: auto; padding-bottom: 6px; }
.filter-pills a {
    flex: 0 0 auto;
    border-radius: 999px;
    padding: 8px 13px;
    color: var(--ink-600);
    background: rgba(255,255,255,.82);
    border: 1px solid var(--line);
    font-size: 12px;
    font-weight: 900;
    text-decoration: none;
}
.filter-pills a.is-active { background: var(--blue); color: #fff; border-color: var(--blue); }
.owner-listings-grid { display: grid; gap: 12px; }
.owner-listing-card {
    display: grid;
    grid-template-columns: 112px minmax(0, 1fr);
    gap: 12px;
    padding: 10px;
    border-radius: 20px;
    border: 1px solid var(--line);
    background: rgba(255,255,255,.90);
    box-shadow: var(--shadow-card);
}
.owner-listing-card.is-rejected { border-color: rgba(178,54,68,.22); }
.owner-listing-card__image {
    width: 112px;
    height: 112px;
    border-radius: 16px;
    overflow: hidden;
    background: var(--blue-50);
    display: grid;
    place-items: center;
    color: var(--blue);
}
.owner-listing-card__image img { width: 100%; height: 100%; object-fit: cover; display: block; }
.owner-listing-card__image i { font-size: 28px; }
.owner-listing-card__body { min-width: 0; display: grid; gap: 7px; }
.owner-listing-card__head { display: flex; align-items: flex-start; justify-content: space-between; gap: 10px; }
.owner-listing-card h2 { margin: 0; font-size: 15px; line-height: 1.7; }
.owner-listing-card h2 a { color: var(--ink-900); text-decoration: none; }
.owner-listing-card strong { color: var(--blue); }
.owner-listing-card small { color: var(--ink-500); }
.listing-status {
    flex: 0 0 auto;
    border-radius: 999px;
    padding: 4px 8px;
    font-size: 11px;
    font-weight: 900;
    background: var(--blue-50);
    color: var(--blue);
}
.listing-status--published { background: rgba(63,166,107,.12); color: #26764B; }
.listing-status--rejected { background: rgba(239,183,186,.28); color: #A73845; }
.listing-status--pending { background: rgba(203,213,240,.42); color: var(--blue); }
.rejection-inline { margin: 0; color: #A73845; font-size: 12px; line-height: 1.8; }
.owner-listing-card__actions { display: flex; gap: 7px; flex-wrap: wrap; align-items: center; }
.owner-listing-card__actions form { margin: 0; }
.empty-state-card {
    min-height: 220px;
    display: grid;
    place-items: center;
    align-content: center;
    gap: 10px;
    padding: 20px;
    border: 1px dashed var(--line-strong);
    border-radius: 24px;
    background: rgba(255,255,255,.75);
    text-align: center;
}
.empty-state-card i { color: var(--blue); font-size: 40px; }
.empty-state-card h2 { margin: 0; }
.empty-state-card p { margin: 0; color: var(--ink-500); }

@media (max-width: 680px) {
    .owner-action-panel { align-items: stretch; flex-direction: column; }
    .owner-action-panel__actions, .mini-list__actions { justify-content: stretch; }
    .owner-action-panel__actions > *, .mini-list__actions > * { flex: 1 1 auto; }
    .owner-listing-card { grid-template-columns: 92px minmax(0, 1fr); gap: 10px; }
    .owner-listing-card__image { width: 92px; height: 92px; border-radius: 14px; }
    .owner-listing-card__head { display: grid; gap: 5px; }
}

/* v0.9.5 admin settings, click-to-call, interaction stats */
.settings-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 14px;
}
.settings-card {
    display: grid;
    gap: 12px;
}
.settings-card--wide {
    grid-column: 1 / -1;
}
.form-grid-2 {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 10px;
}
.settings-switches {
    display: grid;
    gap: 10px;
}
.switch-row {
    display: flex;
    align-items: flex-start;
    gap: 10px;
    padding: 12px;
    border: 1px solid var(--line);
    border-radius: 16px;
    background: rgba(255,255,255,.78);
}
.switch-row input {
    width: 20px;
    height: 20px;
    margin-top: 3px;
    accent-color: var(--blue);
}
.switch-row span {
    display: grid;
    gap: 3px;
}
.switch-row strong { color: var(--ink-900); }
.switch-row small { color: var(--ink-500); line-height: 1.8; }
.admin-settings-form textarea {
    min-height: 110px;
}
.revealed-phone-link {
    color: #fff;
    font-weight: 900;
    text-decoration: none;
    direction: ltr;
    display: inline-block;
}
.piece-owner-stats {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 10px;
    margin-top: 12px;
}
.piece-owner-stats > div {
    display: grid;
    gap: 4px;
    padding: 12px;
    border: 1px solid var(--line);
    border-radius: 16px;
    background: rgba(255,255,255,.84);
    box-shadow: 0 8px 20px rgba(25,79,146,.05);
}
.piece-owner-stats i {
    color: var(--blue);
    font-size: 18px;
}
.piece-owner-stats span {
    color: var(--ink-500);
    font-size: 12px;
}
.piece-owner-stats strong {
    color: var(--ink-900);
    font-size: 18px;
}

@media (max-width: 720px) {
    .settings-grid,
    .form-grid-2,
    .piece-owner-stats {
        grid-template-columns: 1fr;
    }
}

/* v0.9.6 - Admin user management */
.admin-filter-form .compact-grid,
.compact-grid {
    grid-template-columns: repeat(3, minmax(0, 1fr));
}
.compact-actions {
    justify-content: flex-start;
    margin-top: 12px;
}
.table-responsive {
    overflow-x: auto;
    border: 1px solid var(--line);
    border-radius: 20px;
    background: rgba(255,255,255,.82);
}
.user-admin-table strong,
.fa-num {
    direction: ltr;
    unicode-bidi: plaintext;
}
.soft-badge {
    background: rgba(203,213,240,.45);
    color: var(--blue);
}
.status-active,
.status-published,
.status-success { background: rgba(26, 142, 91, .12); color: #157347; }
.status-inactive,
.status-pending { background: rgba(239,183,186,.22); color: #8a4a4d; }
.status-blocked,
.status-rejected,
.status-failed { background: rgba(190, 32, 54, .12); color: #a31428; }
.admin-user-hero,
.two-col-grid {
    display: grid;
    grid-template-columns: minmax(0, .9fr) minmax(0, 1.1fr);
    gap: 14px;
    margin: 14px 0;
}
.user-profile-card {
    display: grid;
    grid-template-columns: auto minmax(0, 1fr);
    align-items: center;
    gap: 14px;
}
.user-profile-card .alert-box { grid-column: 1 / -1; }
.user-avatar-lg {
    width: 64px;
    height: 64px;
    display: grid;
    place-items: center;
    border-radius: 22px;
    color: #fff;
    background: linear-gradient(135deg, var(--blue), #4678bc);
    box-shadow: 0 14px 32px rgba(25,79,146,.2);
    font-size: 26px;
}
.mini-stats {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    margin: 0;
}
.alert-box {
    padding: 12px 14px;
    border-radius: 18px;
    border: 1px solid var(--line);
    background: rgba(203,213,240,.18);
    line-height: 1.9;
}
.danger-alert {
    border-color: rgba(190,32,54,.2);
    background: rgba(190,32,54,.08);
    color: #7f1d2d;
}
.stack-form,
.role-checkbox-grid {
    display: grid;
    gap: 12px;
}
.role-checkbox-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
}
.role-checkbox-grid .btn { grid-column: 1 / -1; }
.check-card {
    display: flex;
    align-items: flex-start;
    gap: 10px;
    padding: 12px;
    border: 1px solid var(--line);
    border-radius: 16px;
    background: rgba(255,255,255,.78);
}
.check-card input {
    width: 18px;
    height: 18px;
    margin-top: 3px;
    accent-color: var(--blue);
}
.check-card span { display: block; font-weight: 800; color: var(--ink-900); }
.check-card small { display: block; color: var(--ink-500); direction: ltr; }
.badge-list { display: flex; flex-wrap: wrap; gap: 8px; }
.split-heading {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 10px;
    margin-bottom: 12px;
}
.compact-list { display: grid; gap: 8px; }
.btn-danger,
.danger-link {
    color: #a31428 !important;
    border-color: rgba(190,32,54,.24) !important;
    background: rgba(190,32,54,.08) !important;
}
.btn-small {
    padding: 7px 11px;
    border-radius: 12px;
    font-size: 12px;
}
.account-status-alert { margin-bottom: 14px; }

@media (max-width: 820px) {
    .admin-filter-form .compact-grid,
    .compact-grid,
    .admin-user-hero,
    .two-col-grid,
    .mini-stats,
    .role-checkbox-grid {
        grid-template-columns: 1fr;
    }
    .split-heading {
        align-items: stretch;
        flex-direction: column;
    }
}

/* v0.9.7 - Admin users UX refinement */
.admin-users-v2 {
    display: grid;
    gap: 16px;
}
.admin-users-hero-card {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 16px;
    padding: 20px;
    border: 1px solid rgba(25,79,146,.12);
    border-radius: 28px;
    background: linear-gradient(135deg, rgba(203,213,240,.48), rgba(255,255,255,.92) 54%, rgba(239,183,186,.26));
    box-shadow: 0 18px 45px rgba(25,79,146,.08);
}
.admin-users-hero-card h1 { margin: 5px 0 7px; }
.admin-users-hero-card p { margin: 0; color: var(--ink-500); line-height: 1.9; }
.eyebrow {
    display: inline-flex;
    align-items: center;
    width: fit-content;
    padding: 4px 10px;
    border-radius: 999px;
    background: rgba(25,79,146,.09);
    color: var(--blue);
    font-size: 12px;
    font-weight: 900;
}
.admin-users-kpis {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 10px;
}
.mini-kpi {
    display: grid;
    gap: 5px;
    padding: 14px;
    border-radius: 20px;
    border: 1px solid var(--line);
    background: rgba(255,255,255,.86);
    box-shadow: 0 12px 28px rgba(25,79,146,.05);
}
.mini-kpi i { color: var(--blue); font-size: 18px; }
.mini-kpi span { color: var(--ink-500); font-size: 12px; }
.mini-kpi strong { color: var(--ink-900); font-size: 24px; }
.modern-filter {
    display: grid;
    grid-template-columns: minmax(240px, 1.4fr) minmax(160px, .75fr) minmax(160px, .75fr) auto;
    gap: 12px;
    align-items: end;
}
.modern-filter label { margin: 0; }
.filter-actions-inline {
    display: flex;
    gap: 8px;
    flex-wrap: wrap;
    align-items: center;
}
.admin-user-card-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 14px;
}
.admin-user-card {
    display: grid;
    gap: 13px;
    padding: 16px;
    border: 1px solid var(--line);
    border-radius: 24px;
    background: rgba(255,255,255,.9);
    box-shadow: 0 16px 38px rgba(25,79,146,.06);
}
.admin-user-card.is-staff-user {
    border-color: rgba(25,79,146,.25);
    background: linear-gradient(180deg, rgba(203,213,240,.24), rgba(255,255,255,.92));
}
.admin-user-card__top {
    display: grid;
    grid-template-columns: auto minmax(0, 1fr) auto;
    align-items: center;
    gap: 10px;
}
.admin-user-card__avatar {
    width: 48px;
    height: 48px;
    display: grid;
    place-items: center;
    border-radius: 18px;
    background: var(--blue-50);
    color: var(--blue);
    font-size: 20px;
}
.admin-user-card__top strong { display: block; color: var(--ink-900); }
.admin-user-card__top span.fa-num { color: var(--ink-500); font-size: 13px; }
.admin-user-role-line {
    display: flex;
    flex-wrap: wrap;
    gap: 7px;
    min-height: 28px;
}
.admin-user-card__stats {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 8px;
}
.admin-user-card__stats > div {
    display: grid;
    gap: 3px;
    padding: 9px;
    border-radius: 14px;
    background: rgba(203,213,240,.18);
}
.admin-user-card__stats span { color: var(--ink-500); font-size: 11px; }
.admin-user-card__stats strong { color: var(--ink-900); font-size: 13px; }
.admin-user-card__meta {
    display: flex;
    flex-wrap: wrap;
    gap: 8px 14px;
    color: var(--ink-500);
    font-size: 12px;
}
.admin-user-card__meta i { color: var(--blue); }
.admin-user-card__actions {
    display: flex;
    justify-content: flex-end;
}
.role-help-text {
    padding: 10px 12px;
    border: 1px dashed rgba(25,79,146,.18);
    border-radius: 14px;
    background: rgba(203,213,240,.16);
}
.alert-box code {
    direction: ltr;
    display: inline-block;
    padding: 2px 7px;
    border-radius: 8px;
    background: rgba(255,255,255,.75);
}

@media (max-width: 940px) {
    .modern-filter,
    .admin-users-kpis,
    .admin-user-card-grid {
        grid-template-columns: 1fr;
    }
    .admin-users-hero-card {
        align-items: stretch;
        flex-direction: column;
    }
    .admin-user-card__stats {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
    .admin-user-card__actions .btn {
        width: 100%;
        justify-content: center;
    }
}

/* v0.9.8 content reports */
.report-box {
    margin-top: 1rem;
    border: 1px solid rgba(25, 79, 146, .14);
    background: rgba(250, 250, 251, .92);
    border-radius: 18px;
    padding: .9rem 1rem;
}
.report-box summary {
    cursor: pointer;
    font-weight: 800;
    color: #194F92;
    display: flex;
    gap: .5rem;
    align-items: center;
}
.report-box__grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 1rem;
    margin-top: 1rem;
}
.compact-report-form {
    background: #fff;
    border: 1px solid rgba(25,79,146,.10);
    border-radius: 16px;
    padding: .9rem;
}
.compact-report-form strong { color: #194F92; }
.compact-report-form textarea { resize: vertical; min-height: 72px; }
.report-box--login a { color: #194F92; font-weight: 800; }
.chat-report-box { margin: .75rem 0; }
.message-report-mini {
    margin-top: .55rem;
    font-size: .78rem;
}
.message-report-mini summary {
    cursor: pointer;
    color: #8a5b00;
    font-weight: 800;
}
.message-report-mini form {
    margin-top: .45rem;
    display: grid;
    gap: .45rem;
    background: rgba(255,255,255,.64);
    padding: .55rem;
    border-radius: 12px;
    border: 1px dashed rgba(25,79,146,.22);
}
.message-report-mini select,
.message-report-mini textarea {
    width: 100%;
    border: 1px solid rgba(25,79,146,.16);
    border-radius: 10px;
    padding: .45rem .55rem;
    font: inherit;
}
.message-report-mini button {
    justify-self: start;
    border: 0;
    border-radius: 10px;
    padding: .42rem .75rem;
    background: #194F92;
    color: #fff;
    cursor: pointer;
}
.report-kpis {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: .75rem;
    margin: 1rem 0;
}
.report-kpis div,
.report-card,
.report-detail-card,
.report-action-card,
.report-actions-history {
    border: 1px solid rgba(25,79,146,.12);
    border-radius: 18px;
    background: #fff;
    box-shadow: 0 12px 30px rgba(25,79,146,.06);
}
.report-kpis div { padding: .9rem 1rem; }
.report-kpis span { display:block; color:#667085; font-size:.82rem; }
.report-kpis strong { color:#194F92; font-size:1.35rem; }
.report-list { display:grid; gap:.85rem; margin-top:1rem; }
.report-card { padding:1rem; border-right: 5px solid rgba(25,79,146,.20); }
.report-card.priority-high { border-right-color:#ff9800; }
.report-card.priority-critical { border-right-color:#d92d20; }
.report-card__top,
.report-card__actions,
.report-detail-head,
.report-quick-links {
    display:flex;
    justify-content:space-between;
    align-items:flex-start;
    gap:1rem;
    flex-wrap:wrap;
}
.report-card__top strong { color:#101828; }
.report-card__top small { display:block; color:#667085; margin-top:.25rem; }
.report-card__badges { display:flex; gap:.4rem; flex-wrap:wrap; }
.report-card__meta { display:flex; gap:1rem; flex-wrap:wrap; color:#667085; font-size:.83rem; margin:.75rem 0; }
.report-card p { margin:.5rem 0 0; color:#344054; }
.report-status-open { background:#fff4d6; color:#8a5b00; }
.report-status-reviewing { background:#e8f0ff; color:#194F92; }
.report-status-resolved { background:#e7f8ef; color:#087443; }
.report-status-rejected { background:#f2f4f7; color:#475467; }
.report-priority-high { background:#fff0db; color:#9a4a00; }
.report-priority-critical { background:#ffe4e4; color:#b42318; }
.report-show-grid { display:grid; grid-template-columns:minmax(0, 1.5fr) minmax(320px, .8fr); gap:1rem; margin-top:1rem; }
.report-detail-card,
.report-action-card,
.report-actions-history { padding:1rem; }
.report-detail-head { margin-bottom:1rem; }
.report-detail-head div { background:#FAFAFB; border-radius:14px; padding:.75rem; min-width:140px; }
.report-detail-head span { display:block; color:#667085; font-size:.8rem; }
.report-detail-head strong { color:#194F92; }
.report-dl { display:grid; grid-template-columns:150px minmax(0,1fr); gap:.7rem 1rem; }
.report-dl dt { color:#667085; font-weight:700; }
.report-dl dd { margin:0; color:#101828; }
.report-quick-links { justify-content:flex-start; margin-top:1rem; }
.stacked-form { display:grid; gap:.75rem; }
.stacked-form label span { display:block; margin-bottom:.35rem; color:#475467; font-weight:700; }
.stacked-form input,
.stacked-form select,
.stacked-form textarea {
    width:100%; border:1px solid rgba(25,79,146,.18); border-radius:12px; padding:.65rem .75rem; font:inherit; background:#fff;
}
@media (max-width: 780px) {
    .report-box__grid,
    .report-kpis,
    .report-show-grid { grid-template-columns:1fr; }
    .report-dl { grid-template-columns:1fr; }
}

/* v0.9.9 image processing settings */
.settings-inline-switch {
    margin-top: 8px;
}

/* v1.0.0 launch polish */
.header-actions{display:flex;align-items:center;gap:10px}.header-icon-action{position:relative;display:inline-flex;align-items:center;justify-content:center;width:42px;height:42px;border-radius:16px;background:#fff;border:1px solid rgba(25,79,146,.12);color:#194F92;text-decoration:none;box-shadow:0 10px 24px rgba(25,79,146,.08)}.bottom-nav__icon--badge,.header-icon-action{position:relative}.nav-badge{position:absolute;top:-7px;left:-7px;min-width:18px;height:18px;padding:0 5px;border-radius:999px;background:#e33b58;color:#fff;font-size:10px;line-height:18px;text-align:center;font-weight:800;box-shadow:0 4px 12px rgba(227,59,88,.28)}
.dashboard-v100{display:flex;flex-direction:column;gap:18px}.dashboard-hero-v100{display:flex;align-items:center;justify-content:space-between;gap:16px;padding:22px;border-radius:28px;background:linear-gradient(135deg,#194F92 0%,#CBD5F0 100%);color:#fff;box-shadow:0 18px 45px rgba(25,79,146,.2)}.dashboard-hero-v100 h1{margin:8px 0 6px;font-size:28px}.dashboard-hero-v100 p{margin:0;opacity:.92}.eyebrow{display:inline-flex;align-items:center;gap:8px;font-size:12px;font-weight:800;letter-spacing:-.02em;opacity:.88}.dashboard-hero-actions{display:flex;gap:10px;flex-wrap:wrap}.primary-link,.secondary-link,.secondary-button{display:inline-flex;align-items:center;justify-content:center;gap:8px;border:none;border-radius:16px;padding:11px 16px;text-decoration:none;font-weight:800;cursor:pointer}.primary-link{background:#194F92;color:#fff}.secondary-link,.secondary-button{background:#fff;color:#194F92;border:1px solid rgba(25,79,146,.12)}.dashboard-hero-v100 .primary-link{background:#fff;color:#194F92}.dashboard-hero-v100 .secondary-link{background:rgba(255,255,255,.14);color:#fff;border-color:rgba(255,255,255,.35)}.dashboard-metric-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:12px}.metric-card{display:flex;flex-direction:column;gap:6px;padding:16px;border-radius:22px;background:#fff;border:1px solid rgba(25,79,146,.1);text-decoration:none;color:#17233a;box-shadow:0 12px 30px rgba(25,79,146,.07)}.metric-card span{font-size:12px;color:#64748b;font-weight:700}.metric-card strong{font-size:24px;color:#194F92}.metric-card small{color:#94a3b8}.metric-card--blue{background:#194F92;color:#fff}.metric-card--blue span,.metric-card--blue small,.metric-card--blue strong{color:#fff}.dashboard-two-col{display:grid;grid-template-columns:1fr 1fr;gap:14px}.dashboard-panel-v100{border-radius:24px}.panel-title-row{display:flex;align-items:center;justify-content:space-between;gap:12px}.listing-mini-stack,.notification-mini-list{display:flex;flex-direction:column;gap:10px}.listing-mini-card{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:12px;border-radius:18px;background:#FAFAFB;border:1px solid rgba(25,79,146,.08)}.listing-mini-title{display:block;color:#17233a;text-decoration:none;font-weight:900;margin-bottom:8px}.listing-mini-meta,.listing-mini-actions{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.listing-mini-actions a,.listing-mini-actions button{border:0;background:#fff;color:#194F92;border-radius:12px;padding:8px 10px;text-decoration:none;font-weight:800;cursor:pointer}.status-pill{display:inline-flex;align-items:center;border-radius:999px;padding:5px 10px;font-size:12px;font-weight:800;background:#eef2ff;color:#194F92}.status-pill.success{background:#dcfce7;color:#166534}.status-pill.warning{background:#fef3c7;color:#92400e}.status-pill.danger{background:#fee2e2;color:#991b1b}.status-pill.neutral{background:#f1f5f9;color:#475569}.notification-mini-item{display:flex;flex-direction:column;gap:4px;padding:12px;border-radius:18px;background:#FAFAFB;border:1px solid rgba(25,79,146,.08);text-decoration:none;color:#17233a}.notification-mini-item span{color:#64748b;font-size:13px}.notification-mini-item small,.muted-text{color:#94a3b8}.timeline-lite{display:flex;flex-direction:column;gap:12px}.timeline-lite-item{display:grid;grid-template-columns:18px 1fr;gap:10px}.timeline-lite-item>span{width:10px;height:10px;border-radius:999px;background:#194F92;margin-top:7px;box-shadow:0 0 0 5px rgba(25,79,146,.1)}.timeline-lite-item strong{display:block}.timeline-lite-item p{margin:4px 0;color:#64748b}.timeline-lite-item small{display:block;color:#475569}.timeline-lite-item em{display:block;margin-top:4px;color:#94a3b8;font-style:normal;font-size:12px}.account-compact-list{display:grid;gap:10px;margin:12px 0}.account-compact-list div{display:flex;justify-content:space-between;gap:12px;padding:10px;border-radius:14px;background:#FAFAFB}.account-compact-list span{color:#64748b}.danger-outline-button{border:1px solid rgba(220,38,38,.25);color:#b91c1c;background:#fff;border-radius:14px;padding:10px 14px;font-weight:800;cursor:pointer}.empty-state-box{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:10px;padding:28px;border-radius:20px;background:#FAFAFB;color:#64748b;text-align:center}.empty-state-box i{font-size:30px;color:#CBD5F0}.dashboard-actions-v100 .quick-card{display:flex;align-items:center;gap:8px}
.notifications-page .section-title{align-items:center}.notification-list-v100{display:flex;flex-direction:column;gap:12px}.notification-card-v100{display:grid;grid-template-columns:46px 1fr;gap:12px;padding:14px;border-radius:22px;background:#fff;border:1px solid rgba(25,79,146,.09);box-shadow:0 10px 26px rgba(25,79,146,.06)}.notification-card-v100.is-unread{border-color:rgba(25,79,146,.28);background:linear-gradient(180deg,#fff,#FAFAFB)}.notification-card-icon{display:flex;align-items:center;justify-content:center;width:46px;height:46px;border-radius:17px;background:#CBD5F0;color:#194F92}.notification-card-title-row{display:flex;justify-content:space-between;gap:10px}.notification-card-title-row h2{margin:0;font-size:16px}.notification-card-title-row span{font-size:12px;color:#94a3b8}.notification-card-body p{margin:8px 0;color:#475569}.notification-actions-row{display:flex;align-items:center;gap:12px;flex-wrap:wrap}.link-button{border:0;background:transparent;color:#194F92;cursor:pointer;font-weight:800;padding:0}.system-health-grid{display:grid;grid-template-columns:2fr 1fr;gap:12px;margin-bottom:14px}.health-card{padding:16px;border-radius:22px;background:#fff;border:1px solid rgba(25,79,146,.1);box-shadow:0 10px 28px rgba(25,79,146,.06)}.health-card--main{background:#194F92;color:#fff}.health-card span,.health-card small{display:block;opacity:.8}.health-card strong{display:block;font-size:24px;margin:6px 0}.health-check-list{display:grid;gap:10px}.health-check-item{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:13px;border-radius:18px;background:#fff;border:1px solid rgba(25,79,146,.08)}.health-check-item span{display:block;color:#64748b;font-size:13px;margin-top:4px}.health-check-item em{font-style:normal;font-weight:900}.health-check-item.ok{border-right:4px solid #16a34a}.health-check-item.warning{border-right:4px solid #f59e0b}.health-check-item.danger{border-right:4px solid #dc2626}.health-check-item.neutral{border-right:4px solid #CBD5F0}.public-page-card{padding:24px;border-radius:28px;background:#fff;border:1px solid rgba(25,79,146,.1);box-shadow:0 16px 42px rgba(25,79,146,.08);line-height:2}.public-page-card h1{margin:10px 0 12px;color:#194F92}.public-feature-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:12px;margin-top:18px}.public-feature-grid div,.contact-cards div{display:flex;flex-direction:column;gap:8px;padding:16px;border-radius:20px;background:#FAFAFB;border:1px solid rgba(25,79,146,.08)}.public-feature-grid i{font-size:24px;color:#194F92}.public-feature-grid strong,.contact-cards strong{color:#17233a}.public-feature-grid span,.contact-cards span{color:#64748b}.public-rules-list{padding-right:20px;color:#334155}.warning-note{padding:12px 14px;border-radius:16px;background:#fff7ed;color:#9a3412;border:1px solid #fed7aa}.contact-cards{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-top:18px}
@media (max-width: 860px){.dashboard-hero-v100{align-items:flex-start;flex-direction:column}.dashboard-metric-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.dashboard-two-col,.system-health-grid,.public-feature-grid,.contact-cards{grid-template-columns:1fr}.listing-mini-card{align-items:flex-start;flex-direction:column}.app-header{gap:8px}.brand-subtitle{display:none}.dashboard-hero-v100 h1{font-size:23px}.health-check-item{align-items:flex-start;flex-direction:column}.notification-card-v100{grid-template-columns:1fr}.notification-card-icon{display:none}}@media (max-width: 430px){.dashboard-metric-grid{grid-template-columns:1fr}.dashboard-hero-actions{width:100%}.dashboard-hero-actions a{flex:1}.metric-card strong{font-size:22px}}

/* v1.1.0 business profiles */
.business-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px;margin:16px 0}.business-card{display:grid;grid-template-columns:72px 1fr;gap:14px;align-items:center;padding:16px;border-radius:24px;background:#fff;border:1px solid rgba(25,79,146,.1);box-shadow:0 12px 30px rgba(25,79,146,.06);text-decoration:none;color:#17233a}.business-card__logo{width:72px;height:72px;border-radius:22px;background:#FAFAFB;border:1px solid rgba(25,79,146,.1);display:flex;align-items:center;justify-content:center;color:#194F92;font-size:28px;overflow:hidden}.business-card__logo img{width:100%;height:100%;object-fit:cover}.business-card__logo--large{width:104px;height:104px;border-radius:30px}.business-card strong{display:block;font-size:17px}.business-card span{display:block;color:#64748b;margin-top:5px}.business-card p{margin:8px 0 0;color:#475569}.verified-badge{display:inline-flex!important;align-items:center;gap:4px;color:#087443!important;font-size:12px!important;font-weight:900}.business-status-card{padding:14px 16px;border-radius:20px;margin-bottom:14px;border:1px solid rgba(25,79,146,.12);background:#fff}.business-status-card.status-approved{background:#ecfdf3;color:#087443}.business-status-card.status-pending{background:#fff7ed;color:#9a3412}.business-status-card.status-rejected,.business-status-card.status-suspended{background:#fef2f2;color:#b42318}.business-hero-card{display:flex;align-items:center;gap:18px;padding:20px;border-radius:28px;background:linear-gradient(135deg,#fff,#FAFAFB);border:1px solid rgba(25,79,146,.1);box-shadow:0 16px 38px rgba(25,79,146,.08)}.business-hero-card h1{margin:6px 0;color:#17233a}.business-info-grid,.business-admin-detail-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:12px;margin:14px 0}.business-info-grid div{padding:14px;border-radius:18px;background:#fff;border:1px solid rgba(25,79,146,.08)}.business-info-grid span{display:block;color:#64748b;font-size:12px;margin-bottom:6px}.business-info-grid strong{color:#194F92}.business-admin-detail-grid{grid-template-columns:1.2fr .8fr}.business-admin-row .badge.status-pending{background:#fff7ed;color:#9a3412}.business-admin-row .badge.status-approved{background:#ecfdf3;color:#087443}.business-admin-row .badge.status-rejected,.business-admin-row .badge.status-suspended{background:#fef2f2;color:#b42318}.business-listing-show .piece-price-card h1{font-size:24px}.piece-price-main{display:block;font-size:24px;color:#194F92;margin:12px 0}.business-page .filter-panel{margin-top:14px}@media(max-width:780px){.business-grid,.business-info-grid,.business-admin-detail-grid{grid-template-columns:1fr}.business-card{grid-template-columns:56px 1fr}.business-card__logo{width:56px;height:56px;border-radius:18px}.business-hero-card{align-items:flex-start;flex-direction:column}.business-card__logo--large{width:84px;height:84px}}

/* v1.1.1 - service marketplace */
.service-market-hero .action-row,
.service-action-row,
.action-stack {
    display: flex;
    flex-wrap: wrap;
    gap: .75rem;
    align-items: center;
}
.service-card .listing-card__image i {
    font-size: 2rem;
    opacity: .75;
}
.service-show-page .action-stack form { margin: 0; }
.service-create-page .alert-box,
.alert-warning {
    border: 1px solid rgba(239, 183, 186, .65);
    background: rgba(239, 183, 186, .14);
    border-radius: 18px;
    padding: 1rem;
    margin-top: 1rem;
}
.related-services-box { margin-top: 1rem; }
.request-grid .business-card { align-items: flex-start; }
.request-card small { display: block; margin-top: .4rem; opacity: .75; }
.mini-context-card {
    display: flex;
    gap: .6rem;
    align-items: center;
    border: 1px solid rgba(25,79,146,.12);
    background: rgba(203,213,240,.22);
    border-radius: 16px;
    padding: .75rem 1rem;
    margin-bottom: 1rem;
}
.service-request-detail h1 { margin-top: .25rem; }
.inline-form { display: flex; flex-wrap: wrap; gap: .6rem; }
.form-grid label, .form-card > label { display: flex; flex-direction: column; gap: .35rem; }
@media (max-width: 760px) {
    .service-market-hero .section-title,
    .service-create-page .section-title,
    .service-requests-page .section-title { align-items: stretch; }
    .service-market-hero .action-row,
    .service-action-row,
    .action-stack { flex-direction: column; align-items: stretch; }
    .service-market-hero .action-row a,
    .service-action-row a,
    .action-stack a,
    .action-stack button { width: 100%; justify-content: center; }
}

/* v1.1.3 monetization */
.plans-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:16px;margin:18px 0}.plan-card{display:flex;flex-direction:column;gap:10px}.plan-price{font-size:1.35rem;color:#194F92}.plain-list{margin:0;padding:0 18px 0 0;line-height:2}.form-grid-4{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:12px}.span-4{grid-column:1/-1}.admin-table{width:100%;border-collapse:collapse}.admin-table th,.admin-table td{padding:10px;border-bottom:1px solid rgba(25,79,146,.10);text-align:right}.table-responsive{overflow-x:auto}.urgent-badge{display:inline-flex;align-items:center;gap:4px;border-radius:999px;background:#fff2f2;color:#b42318;padding:3px 8px;font-size:.78rem;font-weight:800}.monetization-actions{display:flex;gap:8px;flex-wrap:wrap}.monetization-actions form{display:inline-flex}

/* v1.1.4 migration runner */
.migration-warning-box{display:flex;flex-direction:column;gap:.45rem;border:1px solid #fed7aa;background:#fff7ed;color:#9a3412;border-radius:20px;padding:14px 16px;margin:14px 0}.migration-warning-box strong{display:flex;align-items:center;gap:8px}.migration-warning-box p{margin:0;line-height:1.9}.migration-stats-grid{margin:14px 0}.migration-actions-card{display:flex;justify-content:space-between;align-items:center;gap:16px;padding:16px;border-radius:24px;background:#fff;border:1px solid rgba(25,79,146,.1);box-shadow:0 12px 30px rgba(25,79,146,.06);margin:14px 0}.migration-actions-card p{margin:.5rem 0 0;color:#64748b;line-height:1.8}.migration-action-buttons,.migration-row-actions{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.migration-table-wrap{margin-top:14px}.migration-table td strong{display:block;color:#17233a;margin-bottom:5px}.migration-table td small{display:block;color:#94a3b8;margin-top:4px}.migration-row--danger{background:rgba(254,226,226,.32)}.migration-row--warning{background:rgba(254,243,199,.26)}.migration-row--success{background:rgba(220,252,231,.18)}.migration-error-details{margin-top:8px}.migration-error-details summary{cursor:pointer;color:#b91c1c;font-weight:800}.migration-error-details pre{white-space:pre-wrap;direction:ltr;text-align:left;background:#111827;color:#f9fafb;border-radius:14px;padding:12px;max-width:680px;overflow:auto}.danger-text{color:#b91c1c!important}.migration-center-page code{direction:ltr;display:inline-block;background:#f1f5f9;border-radius:8px;padding:2px 6px}@media(max-width:860px){.migration-actions-card{align-items:stretch;flex-direction:column}.migration-action-buttons{align-items:stretch;flex-direction:column}.migration-action-buttons button{width:100%}.migration-row-actions{align-items:flex-start;flex-direction:column}}

/* v1.1.5 - business dashboard and quota management */
.business-dashboard-page{display:flex;flex-direction:column;gap:16px}.business-dashboard-hero{margin-bottom:0}.business-dashboard-metrics{margin-top:0}.business-quota-grid{display:grid;grid-template-columns:1.2fr .8fr;gap:14px}.quota-panel{padding:18px;border-radius:24px}.quota-row{display:flex;flex-direction:column;gap:7px;margin:14px 0}.quota-row__head{display:flex;align-items:center;justify-content:space-between;gap:12px;color:#475569}.quota-row__head span{font-weight:800}.quota-row__head strong{color:#194F92}.quota-bar{width:100%;height:10px;border-radius:999px;background:#eef2f7;overflow:hidden}.quota-bar span{display:block;height:100%;border-radius:999px;background:linear-gradient(90deg,#194F92,#CBD5F0)}.quota-note{margin-top:12px;padding:12px;border-radius:16px;background:#FAFAFB;color:#64748b;line-height:1.9}.business-action-stack{display:flex;flex-direction:column;gap:10px}.business-action-stack a{width:100%}.business-mini-card{display:grid;grid-template-columns:58px minmax(0,1fr);align-items:center}.business-mini-card img,.business-mini-card .mini-placeholder{width:58px;height:58px;border-radius:16px;object-fit:cover;background:#FAFAFB;border:1px solid rgba(25,79,146,.1);display:flex;align-items:center;justify-content:center;color:#194F92}.compact-rows{display:flex;flex-direction:column;gap:10px}.compact-rows div{display:grid;grid-template-columns:minmax(0,1fr) auto;gap:6px 12px;padding:12px;border-radius:16px;background:#FAFAFB;border:1px solid rgba(25,79,146,.08)}.compact-rows span{font-weight:800;color:#17233a}.compact-rows strong{color:#194F92}.compact-rows small{grid-column:1/-1;color:#94a3b8}.plans-quota-grid{grid-template-columns:repeat(3,minmax(0,1fr));margin:14px 0}.business-plans-page .action-row{display:flex;gap:10px;flex-wrap:wrap}@media(max-width:860px){.business-quota-grid,.plans-quota-grid{grid-template-columns:1fr}.business-mini-card{grid-template-columns:48px 1fr}.business-mini-card img,.business-mini-card .mini-placeholder{width:48px;height:48px}.compact-rows div{grid-template-columns:1fr}.business-dashboard-page .dashboard-hero-actions{width:100%;flex-direction:column}.business-dashboard-page .dashboard-hero-actions a{width:100%}}

/* v1.1.6 - refined business listing detail UX/UI */
.business-listing-detail-page {
    display: grid;
    gap: 14px;
}

.business-detail-breadcrumb {
    display: flex;
    align-items: center;
    gap: 8px;
    flex-wrap: wrap;
    color: var(--ink-500);
    font-size: 13px;
}

.business-detail-breadcrumb a {
    display: inline-flex;
    align-items: center;
    gap: 7px;
    padding: 9px 12px;
    border: 1px solid rgba(25,79,146,.10);
    border-radius: 999px;
    background: rgba(255,255,255,.72);
    color: var(--blue);
    font-weight: 800;
    text-decoration: none;
}

.business-detail-hero {
    display: grid;
    gap: 14px;
    align-items: start;
}

.business-detail-gallery,
.business-detail-summary,
.business-info-panel,
.business-contact-card {
    border: 1px solid rgba(25,79,146,.10);
    background: rgba(255,255,255,.88);
    border-radius: 28px;
    box-shadow: 0 16px 42px rgba(25,79,146,.08);
}

.business-detail-gallery {
    padding: 12px;
    overflow: hidden;
}

.business-main-photo {
    position: relative;
    width: 100%;
    aspect-ratio: 1.14 / 1;
    min-height: 280px;
    border: 0;
    border-radius: 24px;
    padding: 0;
    overflow: hidden;
    background: linear-gradient(145deg, rgba(203,213,240,.34), rgba(239,183,186,.20));
    box-shadow: inset 0 0 0 1px rgba(25,79,146,.08);
}

.business-main-photo img {
    width: 100%;
    height: 100%;
    display: block;
    object-fit: cover;
    transition: transform .24s ease;
}

.business-main-photo:hover img,
.business-main-photo:focus-visible img {
    transform: scale(1.025);
}

.business-main-photo:focus-visible {
    outline: 3px solid rgba(25,79,146,.22);
    outline-offset: 3px;
}

.business-main-photo__hint,
.business-main-photo__count {
    position: absolute;
    display: inline-flex;
    align-items: center;
    gap: 7px;
    z-index: 1;
    border-radius: 999px;
    color: #fff;
    background: rgba(23,32,51,.70);
    backdrop-filter: blur(10px);
    font-weight: 900;
    font-size: 12px;
}

.business-main-photo__hint {
    right: 12px;
    bottom: 12px;
    padding: 9px 12px;
}

.business-main-photo__count {
    left: 12px;
    top: 12px;
    padding: 8px 11px;
}

.business-main-photo--empty {
    display: grid;
    place-items: center;
    align-content: center;
    gap: 8px;
    color: var(--ink-500);
    text-align: center;
    padding: 22px;
}

.business-main-photo--empty i {
    color: var(--blue);
    font-size: 42px;
}

.business-main-photo--empty strong {
    color: var(--ink-900);
}

.business-thumb-strip {
    display: flex;
    gap: 10px;
    margin-top: 10px;
    padding-bottom: 4px;
    overflow-x: auto;
    scroll-snap-type: x proximity;
    -webkit-overflow-scrolling: touch;
}

.business-thumb {
    flex: 0 0 82px;
    width: 82px;
    height: 82px;
    border: 1px solid rgba(25,79,146,.12);
    border-radius: 18px;
    padding: 0;
    overflow: hidden;
    background: #fff;
    scroll-snap-align: start;
    opacity: .86;
}

.business-thumb.is-active,
.business-thumb:hover,
.business-thumb:focus-visible {
    opacity: 1;
    border-color: rgba(25,79,146,.50);
    box-shadow: 0 10px 22px rgba(25,79,146,.12);
    outline: 0;
}

.business-thumb img {
    width: 100%;
    height: 100%;
    display: block;
    object-fit: cover;
}

.business-detail-summary {
    position: relative;
    padding: 18px;
    overflow: hidden;
}

.business-detail-summary::before {
    content: '';
    position: absolute;
    inset: -90px auto auto -70px;
    width: 180px;
    height: 180px;
    border-radius: 50%;
    background: rgba(203,213,240,.46);
    pointer-events: none;
}

.business-detail-type-row {
    position: relative;
    display: flex;
    align-items: center;
    gap: 8px;
    flex-wrap: wrap;
    margin-bottom: 12px;
}

.business-type-pill,
.business-verified-pill {
    display: inline-flex;
    align-items: center;
    gap: 7px;
    border-radius: 999px;
    padding: 7px 10px;
    font-size: 12px;
    font-weight: 900;
}

.business-type-pill {
    background: var(--blue-50);
    color: var(--blue);
}

.business-verified-pill {
    background: var(--success-bg);
    color: var(--success);
}

.business-detail-summary h1 {
    position: relative;
    margin: 0 0 14px;
    color: var(--ink-900);
    font-size: 25px;
    line-height: 1.58;
    letter-spacing: -.02em;
}

.business-price-box {
    position: relative;
    display: grid;
    gap: 5px;
    padding: 16px;
    border-radius: 22px;
    border: 1px solid rgba(25,79,146,.10);
    background: linear-gradient(135deg, rgba(25,79,146,.96), rgba(46,111,181,.92));
    color: #fff;
    box-shadow: 0 16px 34px rgba(25,79,146,.18);
}

.business-price-box span {
    opacity: .76;
    font-size: 12px;
    font-weight: 700;
}

.business-price-box strong {
    direction: ltr;
    font-size: 27px;
    font-weight: 950;
    letter-spacing: -.03em;
}

.business-store-card {
    position: relative;
    display: grid;
    grid-template-columns: 58px 1fr;
    gap: 12px;
    align-items: center;
    margin: 14px 0;
    padding: 12px;
    border: 1px solid rgba(25,79,146,.10);
    border-radius: 22px;
    background: rgba(250,250,251,.78);
}

.business-store-card__logo {
    width: 58px;
    height: 58px;
    display: grid;
    place-items: center;
    border-radius: 20px;
    overflow: hidden;
    color: var(--blue);
    background: #fff;
    border: 1px solid rgba(25,79,146,.10);
    font-size: 24px;
}

.business-store-card__logo img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.business-store-card span,
.business-contact-card__label {
    display: block;
    color: var(--ink-500);
    font-size: 12px;
    font-weight: 800;
}

.business-store-card strong {
    display: block;
    margin-top: 3px;
    color: var(--ink-900);
    font-size: 16px;
}

.business-store-card small {
    display: inline-flex;
    align-items: center;
    gap: 5px;
    margin-top: 5px;
    color: var(--ink-500);
}

.business-cta-stack {
    position: relative;
    display: grid;
    grid-template-columns: 1fr;
    gap: 10px;
}

.business-call-button,
.business-profile-button,
.business-contact-card .primary-link,
.business-contact-card .secondary-link {
    width: 100%;
    min-height: 48px;
}

.business-buy-note {
    position: relative;
    display: flex;
    align-items: flex-start;
    gap: 8px;
    margin: 14px 0 0;
    color: var(--ink-700);
    line-height: 1.9;
    font-size: 13px;
}

.business-buy-note i {
    color: var(--success);
    margin-top: 5px;
}

.business-detail-content-grid {
    display: grid;
    gap: 14px;
    align-items: start;
}

.business-detail-main {
    display: grid;
    gap: 14px;
}

.business-info-panel {
    padding: 16px;
}

.business-info-panel h2 {
    display: flex;
    align-items: center;
    gap: 8px;
    margin: 0 0 13px;
    color: var(--ink-900);
    font-size: 18px;
}

.business-info-panel h2 i {
    color: var(--blue);
}

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

.business-spec-grid div {
    padding: 13px 14px;
    border-radius: 18px;
    background: #FAFAFB;
    border: 1px solid rgba(25,79,146,.08);
}

.business-spec-grid span {
    display: block;
    color: var(--ink-500);
    font-size: 12px;
    margin-bottom: 6px;
}

.business-spec-grid strong {
    display: block;
    color: var(--ink-900);
    line-height: 1.75;
    word-break: break-word;
}

.business-description-panel p {
    margin: 0;
    color: var(--ink-700);
    line-height: 2;
}

.business-contact-card {
    display: grid;
    gap: 10px;
    padding: 16px;
}

.business-contact-card strong {
    color: var(--ink-900);
    font-size: 17px;
}

.business-contact-card small {
    color: var(--ink-500);
}

@media (min-width: 900px) {
    .business-detail-hero {
        grid-template-columns: minmax(0, 1.15fr) minmax(330px, .85fr);
    }

    .business-detail-content-grid {
        grid-template-columns: minmax(0, 1fr) 300px;
    }

    .business-contact-card {
        position: sticky;
        top: 86px;
    }
}

@media (max-width: 899px) {
    .business-detail-summary h1 {
        font-size: 22px;
    }

    .business-price-box strong {
        font-size: 24px;
    }

    .business-contact-card {
        display: none;
    }
}

@media (max-width: 560px) {
    .business-detail-breadcrumb a {
        width: 100%;
        justify-content: center;
    }

    .business-detail-breadcrumb span {
        display: none;
    }

    .business-detail-gallery,
    .business-detail-summary,
    .business-info-panel {
        border-radius: 22px;
    }

    .business-main-photo {
        min-height: 220px;
        border-radius: 18px;
    }

    .business-thumb {
        flex-basis: 72px;
        width: 72px;
        height: 72px;
        border-radius: 16px;
    }

    .business-detail-summary {
        padding: 14px;
    }

    .business-spec-grid {
        grid-template-columns: 1fr;
    }
}

/* Business public profile page v1.1.7 */
.business-public-profile {
    display: grid;
    gap: 16px;
}

.business-public-hero {
    position: relative;
    overflow: hidden;
    padding: 0;
    background:
        radial-gradient(circle at 12% 18%, rgba(239,183,186,.42), transparent 24%),
        linear-gradient(135deg, rgba(25,79,146,.98), rgba(18,59,111,.94));
    color: #fff;
    border-color: rgba(25,79,146,.16);
}

.business-public-hero__pattern {
    position: absolute;
    inset: 0;
    pointer-events: none;
    opacity: .24;
    background-image:
        linear-gradient(90deg, rgba(255,255,255,.18) 1px, transparent 1px),
        linear-gradient(180deg, rgba(255,255,255,.14) 1px, transparent 1px);
    background-size: 26px 26px;
    mask-image: linear-gradient(180deg, #000 0%, transparent 88%);
}

.business-public-hero__top,
.business-public-hero__body,
.business-public-stats {
    position: relative;
    z-index: 1;
}

.business-public-hero__top {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 10px;
    padding: 16px 18px 0;
    flex-wrap: wrap;
}

.business-public-back,
.business-public-verified {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    min-height: 36px;
    padding: 8px 12px;
    border-radius: 999px;
    color: #fff;
    background: rgba(255,255,255,.13);
    border: 1px solid rgba(255,255,255,.22);
    backdrop-filter: blur(12px);
    font-size: 12px;
    font-weight: 900;
}

.business-public-verified {
    color: #dcffe8;
}

.business-public-hero__body {
    display: grid;
    grid-template-columns: 124px minmax(0, 1fr);
    gap: 18px;
    align-items: center;
    padding: 26px 18px 22px;
}

.business-public-logo {
    width: 124px;
    height: 124px;
    display: grid;
    place-items: center;
    overflow: hidden;
    border-radius: 34px;
    background: rgba(255,255,255,.96);
    border: 1px solid rgba(255,255,255,.58);
    box-shadow: 0 22px 52px rgba(0,0,0,.20);
    color: var(--blue);
    font-size: 46px;
}

.business-public-logo img,
.business-public-contact-card__avatar img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
}

.business-public-title .eyebrow {
    color: rgba(255,255,255,.82);
}

.business-public-title h1 {
    margin: 8px 0 8px;
    font-size: clamp(25px, 4vw, 42px);
    line-height: 1.35;
    letter-spacing: -.04em;
}

.business-public-title p {
    display: flex;
    align-items: center;
    gap: 8px;
    margin: 0;
    color: rgba(255,255,255,.82);
    line-height: 1.9;
}

.business-public-actions {
    display: flex;
    gap: 10px;
    flex-wrap: wrap;
    margin-top: 18px;
}

.business-public-actions .primary-link,
.business-public-actions .secondary-link {
    min-height: 48px;
    border-radius: 16px;
}

.business-public-actions .primary-link {
    background: #fff;
    color: var(--blue);
    box-shadow: 0 14px 32px rgba(0,0,0,.14);
}

.business-public-actions .secondary-link {
    color: #fff;
    background: rgba(255,255,255,.12);
    border-color: rgba(255,255,255,.30);
}

.business-public-stats {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 1px;
    border-top: 1px solid rgba(255,255,255,.18);
    background: rgba(255,255,255,.11);
    backdrop-filter: blur(16px);
}

.business-public-stats div {
    padding: 15px 18px;
    background: rgba(255,255,255,.06);
}

.business-public-stats span {
    display: block;
    color: rgba(255,255,255,.70);
    font-size: 12px;
    font-weight: 800;
    margin-bottom: 5px;
}

.business-public-stats strong {
    display: block;
    color: #fff;
    font-size: 16px;
    line-height: 1.7;
}

.business-public-layout {
    display: grid;
    gap: 16px;
    align-items: start;
}

.business-public-main {
    display: grid;
    gap: 14px;
    min-width: 0;
}

.business-public-panel {
    padding: 18px;
    box-shadow: var(--shadow-card);
}

.business-public-section-head {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 12px;
    margin-bottom: 14px;
}

.business-public-section-head h2 {
    margin: 6px 0 0;
    color: var(--ink-900);
    font-size: 19px;
    line-height: 1.55;
}

.business-public-count {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 34px;
    padding: 6px 12px;
    border-radius: 999px;
    background: var(--blue-50);
    color: var(--blue);
    font-size: 12px;
    font-weight: 900;
    white-space: nowrap;
}

.business-public-info-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 10px;
}

.business-public-info-grid div {
    position: relative;
    min-height: 108px;
    padding: 14px 14px 14px 48px;
    border-radius: 20px;
    background: #FAFAFB;
    border: 1px solid rgba(25,79,146,.09);
}

.business-public-info-grid__wide {
    grid-column: 1 / -1;
}

.business-public-info-grid i {
    position: absolute;
    top: 15px;
    left: 14px;
    width: 28px;
    height: 28px;
    display: grid;
    place-items: center;
    border-radius: 11px;
    color: var(--blue);
    background: #fff;
    border: 1px solid rgba(25,79,146,.08);
}

.business-public-info-grid span {
    display: block;
    margin-bottom: 7px;
    color: var(--ink-500);
    font-size: 12px;
    font-weight: 800;
}

.business-public-info-grid strong {
    display: block;
    color: var(--ink-900);
    line-height: 1.9;
    word-break: break-word;
}

.business-public-about p {
    margin: 0;
    color: var(--ink-700);
    line-height: 2.1;
}

.business-public-listing-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 12px;
}

.business-public-item {
    display: grid;
    grid-template-rows: 164px 1fr;
    overflow: hidden;
    border-radius: 24px;
    color: var(--ink-900);
    background: #fff;
    border: 1px solid rgba(25,79,146,.10);
    box-shadow: 0 12px 30px rgba(25,79,146,.06);
    transition: transform .18s ease, box-shadow .18s ease, border-color .18s ease;
}

.business-public-item:hover {
    transform: translateY(-3px);
    border-color: rgba(25,79,146,.24);
    box-shadow: var(--shadow-soft);
}

.business-public-item__image {
    display: grid;
    place-items: center;
    overflow: hidden;
    color: var(--blue);
    background:
        radial-gradient(circle at 20% 20%, rgba(203,213,240,.72), transparent 32%),
        linear-gradient(135deg, #F8FAFC, #EEF3FF);
    font-size: 34px;
}

.business-public-item__image img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
    transition: transform .24s ease;
}

.business-public-item:hover .business-public-item__image img {
    transform: scale(1.035);
}

.business-public-item__body {
    display: grid;
    gap: 8px;
    padding: 13px;
}

.business-public-item__body span {
    color: var(--ink-500);
    font-size: 12px;
    font-weight: 800;
    line-height: 1.7;
}

.business-public-item__body h3 {
    margin: 0;
    color: var(--ink-900);
    font-size: 15px;
    line-height: 1.75;
}

.business-public-item__foot {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 10px;
    margin-top: 4px;
}

.business-public-item__foot strong {
    color: var(--blue);
    font-size: 15px;
    line-height: 1.7;
}

.business-public-item__foot em {
    width: 32px;
    height: 32px;
    flex: 0 0 32px;
    display: grid;
    place-items: center;
    border-radius: 12px;
    color: #fff;
    background: var(--blue);
    font-style: normal;
}

.business-public-empty {
    display: grid;
    place-items: center;
    gap: 10px;
    min-height: 210px;
    padding: 24px;
    border-radius: 22px;
    text-align: center;
    color: var(--ink-500);
    background: #FAFAFB;
    border: 1px dashed rgba(25,79,146,.20);
}

.business-public-empty i {
    width: 58px;
    height: 58px;
    display: grid;
    place-items: center;
    border-radius: 22px;
    color: var(--blue);
    background: #fff;
    border: 1px solid rgba(25,79,146,.10);
    font-size: 25px;
}

.business-public-empty strong {
    color: var(--ink-900);
    font-size: 17px;
}

.business-public-empty p {
    margin: 0;
    line-height: 1.9;
}

.business-public-sidebar {
    min-width: 0;
}

.business-public-contact-card {
    display: grid;
    gap: 10px;
    justify-items: stretch;
    padding: 16px;
    text-align: center;
}

.business-public-contact-card__avatar {
    width: 76px;
    height: 76px;
    display: grid;
    place-items: center;
    justify-self: center;
    overflow: hidden;
    border-radius: 24px;
    color: var(--blue);
    background: #FAFAFB;
    border: 1px solid rgba(25,79,146,.10);
    font-size: 28px;
}

.business-public-contact-card strong {
    color: var(--ink-900);
    font-size: 17px;
    line-height: 1.6;
}

.business-public-contact-card span,
.business-public-contact-card small {
    color: var(--ink-500);
    line-height: 1.8;
}

.business-public-contact-card .primary-link,
.business-public-contact-card .secondary-link {
    width: 100%;
    min-height: 46px;
}

.business-public-contact-card p {
    display: flex;
    gap: 8px;
    align-items: flex-start;
    margin: 2px 0 0;
    color: var(--ink-500);
    text-align: right;
    line-height: 1.9;
    font-size: 12px;
}

.business-public-contact-card p i {
    color: var(--success);
    margin-top: 5px;
}

@media (min-width: 900px) {
    .business-public-layout {
        grid-template-columns: minmax(0, 1fr) 304px;
    }

    .business-public-sidebar {
        position: sticky;
        top: 86px;
    }
}

@media (max-width: 899px) {
    .business-public-hero__body {
        grid-template-columns: 92px minmax(0, 1fr);
    }

    .business-public-logo {
        width: 92px;
        height: 92px;
        border-radius: 28px;
        font-size: 34px;
    }

    .business-public-title h1 {
        font-size: 25px;
    }

    .business-public-listing-grid {
        grid-template-columns: 1fr;
    }

    .business-public-sidebar {
        display: none;
    }
}

@media (max-width: 640px) {
    .business-public-hero__top {
        padding: 12px 12px 0;
    }

    .business-public-back,
    .business-public-verified {
        width: 100%;
        justify-content: center;
    }

    .business-public-hero__body {
        grid-template-columns: 1fr;
        justify-items: center;
        text-align: center;
        padding: 20px 14px 18px;
    }

    .business-public-title p,
    .business-public-actions {
        justify-content: center;
    }

    .business-public-actions .primary-link,
    .business-public-actions .secondary-link {
        width: 100%;
    }

    .business-public-stats,
    .business-public-info-grid {
        grid-template-columns: 1fr;
    }

    .business-public-panel {
        padding: 14px;
        border-radius: 22px;
    }

    .business-public-section-head--row {
        display: grid;
    }

    .business-public-info-grid__wide {
        grid-column: auto;
    }

    .business-public-item {
        grid-template-rows: 148px 1fr;
        border-radius: 20px;
    }
}

/* v1.1.8 - Public home UX/UI refresh */
.home-v118 {
    display: flex;
    flex-direction: column;
    gap: 18px;
}

.home-hero-v118 {
    position: relative;
    overflow: hidden;
    display: grid;
    gap: 18px;
    padding: 20px;
    border-radius: 34px;
    color: #fff;
    background:
        radial-gradient(circle at 16% 12%, rgba(239, 183, 186, 0.34), transparent 26%),
        radial-gradient(circle at 88% 18%, rgba(203, 213, 240, 0.36), transparent 32%),
        linear-gradient(135deg, #123B6F 0%, #194F92 54%, #1E5EA9 100%);
    box-shadow: 0 24px 60px rgba(25, 79, 146, 0.20);
    isolation: isolate;
}

.home-hero-v118::before,
.home-hero-v118::after {
    content: '';
    position: absolute;
    z-index: -1;
    border-radius: 999px;
    background: rgba(255, 255, 255, 0.10);
}

.home-hero-v118::before {
    width: 260px;
    height: 260px;
    inset: -90px auto auto -70px;
}

.home-hero-v118::after {
    width: 190px;
    height: 190px;
    inset: auto -55px -70px auto;
}

.home-hero-v118__content,
.home-hero-v118__visual {
    position: relative;
    z-index: 1;
}

.home-kicker-v118 {
    display: inline-flex;
    width: fit-content;
    align-items: center;
    gap: 8px;
    padding: 8px 12px;
    border-radius: 999px;
    color: #fff;
    background: rgba(255, 255, 255, 0.14);
    border: 1px solid rgba(255, 255, 255, 0.22);
    font-size: 12px;
    font-weight: 900;
}

.home-kicker-v118::before {
    content: '';
    width: 8px;
    height: 8px;
    border-radius: 999px;
    background: #EFB7BA;
    box-shadow: 0 0 0 5px rgba(239, 183, 186, 0.20);
}

.home-kicker-v118--light {
    color: var(--blue);
    background: rgba(238, 243, 255, 0.82);
    border-color: rgba(25, 79, 146, 0.12);
}

.home-hero-v118 h1 {
    max-width: 720px;
    margin: 14px 0 10px;
    font-size: clamp(28px, 5vw, 46px);
    line-height: 1.55;
    letter-spacing: -1.2px;
}

.home-hero-v118 p,
.home-panel-v118 p,
.home-final-cta-v118 p,
.home-audience-card-v118 p,
.home-category-card-v118 p,
.home-trust-card-v118 p,
.home-step-v118 p {
    margin: 0;
    line-height: 1.95;
}

.home-hero-v118 p {
    max-width: 660px;
    color: rgba(255, 255, 255, 0.80);
    font-size: 15px;
}

.home-search-v118 {
    display: grid;
    grid-template-columns: 42px minmax(0, 1fr);
    gap: 8px;
    align-items: center;
    margin-top: 18px;
    padding: 7px;
    border-radius: 22px;
    background: rgba(255, 255, 255, 0.94);
    border: 1px solid rgba(255, 255, 255, 0.34);
    box-shadow: 0 18px 34px rgba(8, 28, 56, 0.18);
}

.home-search-v118__icon {
    display: grid;
    place-items: center;
    width: 42px;
    height: 42px;
    border-radius: 16px;
    color: var(--blue);
    background: var(--blue-50);
    font-size: 22px;
    font-weight: 900;
}

.home-search-v118 input {
    min-height: 42px;
    padding: 10px 2px;
    border: 0;
    border-radius: 0;
    background: transparent;
    box-shadow: none;
}

.home-search-v118 input:focus {
    box-shadow: none;
    background: transparent;
}

.home-search-v118 button {
    grid-column: 1 / -1;
    min-height: 48px;
    border: 0;
    border-radius: 17px;
    color: #fff;
    background: linear-gradient(135deg, var(--blue), #2B65A9);
    font-weight: 900;
    box-shadow: 0 12px 26px rgba(25, 79, 146, 0.24);
}

.home-chip-row-v118,
.home-hero-actions-v118,
.home-seller-actions-v118,
.home-final-actions-v118 {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
}

.home-chip-row-v118 {
    margin-top: 14px;
}

.home-chip-row-v118 a {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 36px;
    padding: 8px 12px;
    border-radius: 999px;
    color: rgba(255, 255, 255, 0.92);
    background: rgba(255, 255, 255, 0.12);
    border: 1px solid rgba(255, 255, 255, 0.18);
    font-size: 12px;
    font-weight: 800;
}

.home-hero-actions-v118 {
    margin-top: 18px;
}

.home-primary-v118,
.home-secondary-v118 {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    min-height: 46px;
    padding: 12px 16px;
    border-radius: 16px;
    font-weight: 900;
    text-align: center;
}

.home-primary-v118 {
    color: #fff;
    background: linear-gradient(135deg, var(--blue), #2B65A9);
    box-shadow: 0 14px 28px rgba(25, 79, 146, 0.20);
}

.home-hero-v118 .home-primary-v118 {
    color: var(--blue);
    background: #fff;
    box-shadow: 0 15px 28px rgba(8, 28, 56, 0.16);
}

.home-secondary-v118 {
    color: var(--blue);
    background: #fff;
    border: 1px solid rgba(25, 79, 146, 0.12);
}

.home-hero-v118 .home-secondary-v118 {
    color: #fff;
    background: rgba(255, 255, 255, 0.12);
    border-color: rgba(255, 255, 255, 0.26);
}

.home-hero-v118__visual {
    display: grid;
    gap: 12px;
    padding: 12px;
    border-radius: 28px;
    background: rgba(255, 255, 255, 0.10);
    border: 1px solid rgba(255, 255, 255, 0.18);
    backdrop-filter: blur(16px);
}

.home-visual-card-v118 {
    display: grid;
    gap: 6px;
    padding: 15px;
    border-radius: 22px;
    color: var(--ink-900);
    background: rgba(255, 255, 255, 0.94);
    border: 1px solid rgba(255, 255, 255, 0.48);
    box-shadow: 0 12px 24px rgba(8, 28, 56, 0.14);
}

.home-visual-card-v118 span,
.home-visual-card-v118 small {
    color: var(--ink-500);
    line-height: 1.7;
}

.home-visual-card-v118 span {
    font-size: 12px;
    font-weight: 800;
}

.home-visual-card-v118 strong {
    color: var(--ink-900);
}

.home-visual-card-v118 b {
    justify-self: start;
    color: var(--blue);
    background: var(--blue-50);
    border-radius: 999px;
    padding: 7px 10px;
}

.home-audience-grid-v118,
.home-category-grid-v118,
.home-trust-grid-v118 {
    display: grid;
    grid-template-columns: 1fr;
    gap: 12px;
}

.home-audience-card-v118,
.home-category-card-v118,
.home-panel-v118,
.home-section-v118,
.home-final-cta-v118 {
    background: rgba(255, 255, 255, 0.92);
    border: 1px solid var(--line);
    box-shadow: var(--shadow-card);
}

.home-audience-card-v118 {
    display: grid;
    gap: 9px;
    padding: 16px;
    border-radius: 26px;
    color: var(--ink-900);
    transition: transform .18s ease, border-color .18s ease, box-shadow .18s ease;
}

.home-audience-card-v118:hover,
.home-category-card-v118:hover {
    transform: translateY(-2px);
    border-color: rgba(25, 79, 146, 0.24);
    box-shadow: var(--shadow-soft);
}

.home-mini-icon-v118 {
    display: inline-flex;
    width: fit-content;
    align-items: center;
    justify-content: center;
    min-height: 34px;
    padding: 7px 10px;
    border-radius: 13px;
    color: var(--blue);
    background: var(--blue-50);
    font-size: 12px;
    font-weight: 900;
}

.home-audience-card-v118 strong,
.home-category-card-v118 strong,
.home-trust-card-v118 strong,
.home-step-v118 strong {
    color: var(--ink-900);
}

.home-audience-card-v118 p,
.home-category-card-v118 p,
.home-trust-card-v118 p,
.home-step-v118 p,
.home-final-cta-v118 p,
.home-panel-v118 p {
    color: var(--ink-500);
    font-size: 13px;
}

.home-audience-card-v118 em {
    color: var(--blue);
    font-style: normal;
    font-weight: 900;
}

.home-section-v118,
.home-final-cta-v118 {
    padding: 18px;
    border-radius: 30px;
}

.home-section-head-v118 {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 12px;
    margin-bottom: 14px;
}

.home-section-head-v118--compact {
    margin-bottom: 12px;
}

.home-section-head-v118 span,
.home-final-cta-v118 span {
    display: block;
    margin-bottom: 6px;
    color: var(--blue);
    font-size: 12px;
    font-weight: 900;
}

.home-section-head-v118 h2,
.home-panel-v118 h2,
.home-final-cta-v118 h2 {
    margin: 0;
    color: var(--ink-900);
    font-size: 20px;
    line-height: 1.7;
    letter-spacing: -0.45px;
}

.home-section-head-v118 a {
    flex: 0 0 auto;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 38px;
    padding: 9px 12px;
    border-radius: 999px;
    color: var(--blue);
    background: var(--blue-50);
    font-size: 12px;
    font-weight: 900;
}

.home-category-card-v118 {
    display: grid;
    gap: 8px;
    padding: 15px;
    border-radius: 22px;
    transition: transform .18s ease, border-color .18s ease, box-shadow .18s ease;
}

.home-category-card-v118 small {
    justify-self: start;
    color: #8A4C5C;
    background: rgba(239, 183, 186, 0.26);
    border-radius: 999px;
    padding: 6px 9px;
    font-weight: 900;
}

.home-category-card-v118 span {
    color: var(--blue);
    font-size: 13px;
    font-weight: 900;
}

.home-split-v118 {
    display: grid;
    gap: 12px;
}

.home-panel-v118 {
    padding: 18px;
    border-radius: 30px;
}

.home-panel-v118--seller {
    overflow: hidden;
    position: relative;
    background:
        radial-gradient(circle at 10% 10%, rgba(239, 183, 186, 0.28), transparent 30%),
        linear-gradient(135deg, #fff, #F6F8FF);
}

.home-panel-v118--seller::after {
    content: '';
    position: absolute;
    width: 150px;
    height: 150px;
    left: -46px;
    bottom: -58px;
    border-radius: 999px;
    background: rgba(203, 213, 240, 0.42);
}

.home-panel-v118--seller > * {
    position: relative;
    z-index: 1;
}

.home-panel-v118 h2 {
    margin: 12px 0 8px;
}

.home-seller-actions-v118 {
    margin-top: 16px;
}

.home-step-list-v118 {
    display: grid;
    gap: 10px;
}

.home-step-v118 {
    display: grid;
    grid-template-columns: 42px minmax(0, 1fr);
    gap: 10px;
    align-items: start;
    padding: 12px;
    border-radius: 20px;
    background: #FAFAFB;
    border: 1px solid rgba(25, 79, 146, 0.08);
}

.home-step-v118 b {
    display: grid;
    place-items: center;
    width: 42px;
    height: 42px;
    border-radius: 15px;
    color: #fff;
    background: var(--blue);
    box-shadow: 0 10px 20px rgba(25, 79, 146, 0.18);
}

.home-trust-v118 {
    background:
        linear-gradient(135deg, rgba(255,255,255,.94), rgba(250,250,251,.94)),
        radial-gradient(circle at 88% 12%, rgba(203, 213, 240, .42), transparent 34%);
}

.home-trust-card-v118 {
    display: grid;
    gap: 7px;
    padding: 14px;
    border-radius: 20px;
    background: #fff;
    border: 1px solid rgba(25, 79, 146, 0.08);
}

.home-final-cta-v118 {
    display: grid;
    gap: 14px;
    color: #fff;
    background:
        radial-gradient(circle at 14% 20%, rgba(239, 183, 186, 0.32), transparent 28%),
        linear-gradient(135deg, var(--blue), var(--blue-dark));
    box-shadow: 0 22px 55px rgba(25, 79, 146, 0.18);
}

.home-final-cta-v118 span,
.home-final-cta-v118 h2,
.home-final-cta-v118 p {
    color: #fff;
}

.home-final-cta-v118 p {
    opacity: .78;
}

.home-final-cta-v118 .home-primary-v118 {
    color: var(--blue);
    background: #fff;
}

.home-final-cta-v118 .home-secondary-v118 {
    color: #fff;
    background: rgba(255, 255, 255, 0.12);
    border-color: rgba(255, 255, 255, 0.24);
}

@media (min-width: 620px) {
    .home-search-v118 {
        grid-template-columns: 42px minmax(0, 1fr) 132px;
    }

    .home-search-v118 button {
        grid-column: auto;
    }

    .home-audience-grid-v118,
    .home-trust-grid-v118 {
        grid-template-columns: repeat(3, minmax(0, 1fr));
    }

    .home-category-grid-v118 {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
}

@media (min-width: 900px) {
    .home-hero-v118 {
        grid-template-columns: minmax(0, 1.35fr) minmax(300px, .65fr);
        align-items: center;
        min-height: 530px;
        padding: 34px;
    }

    .home-hero-v118__visual {
        transform: rotate(-1.5deg);
    }

    .home-visual-card-v118--top,
    .home-visual-card-v118--bottom {
        margin-inline-start: 24px;
    }

    .home-visual-card-v118--middle {
        margin-inline-end: 18px;
    }

    .home-category-grid-v118 {
        grid-template-columns: repeat(3, minmax(0, 1fr));
    }

    .home-split-v118 {
        grid-template-columns: .95fr 1.05fr;
    }

    .home-final-cta-v118 {
        grid-template-columns: 1fr auto;
        align-items: center;
    }
}

@media (max-width: 560px) {
    .home-hero-v118 {
        border-radius: 28px;
        padding: 16px;
    }

    .home-hero-v118 h1 {
        font-size: 27px;
    }

    .home-hero-actions-v118 a,
    .home-seller-actions-v118 a,
    .home-final-actions-v118 a {
        width: 100%;
    }

    .home-section-head-v118 {
        flex-direction: column;
    }

    .home-section-head-v118 a {
        width: 100%;
    }
}

/* v1.1.9 - Tools hub and cabinet meter */
.tools-hub-v119,
.cabinet-meter-v119 {
    display: grid;
    gap: 16px;
}

.tools-hero-v119,
.cabinet-hero-v119 {
    position: relative;
    overflow: hidden;
    display: grid;
    gap: 18px;
    padding: 20px;
    border-radius: 32px;
    color: #fff;
    background:
        radial-gradient(circle at 15% 20%, rgba(239, 183, 186, .38), transparent 28%),
        radial-gradient(circle at 85% 18%, rgba(203, 213, 240, .35), transparent 32%),
        linear-gradient(135deg, var(--blue), var(--blue-dark));
    box-shadow: 0 24px 60px rgba(25, 79, 146, .22);
}

.tools-eyebrow-v119,
.cabinet-chip-v119,
.cabinet-form-head-v119 span,
.cabinet-result-head-v119 span,
.cabinet-output-head-v119 span {
    display: inline-flex;
    align-items: center;
    width: fit-content;
    padding: 7px 10px;
    border-radius: 999px;
    font-size: 12px;
    font-weight: 900;
    color: #fff;
    background: rgba(255, 255, 255, .14);
    border: 1px solid rgba(255, 255, 255, .20);
}

.tools-hero-v119 h1,
.cabinet-hero-v119 h1 {
    margin: 12px 0 8px;
    font-size: clamp(28px, 5vw, 46px);
    line-height: 1.45;
    letter-spacing: -1px;
}

.tools-hero-v119 p,
.cabinet-hero-v119 p {
    max-width: 680px;
    margin: 0;
    color: rgba(255, 255, 255, .78);
    line-height: 2;
}

.tools-hero-actions-v119,
.cabinet-hero-actions-v119,
.cabinet-form-actions-v119 {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
    margin-top: 18px;
}

.tools-primary-v119,
.tools-secondary-v119,
.cabinet-primary-v119,
.cabinet-secondary-v119,
.cabinet-ghost-v119 {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 44px;
    padding: 10px 15px;
    border-radius: 999px;
    border: 0;
    font-weight: 900;
    font-size: 13px;
}

.tools-primary-v119,
.cabinet-primary-v119 {
    color: var(--blue);
    background: #fff;
    box-shadow: 0 14px 32px rgba(0, 0, 0, .14);
}

.tools-secondary-v119,
.cabinet-secondary-v119,
.cabinet-ghost-v119 {
    color: #fff;
    background: rgba(255, 255, 255, .12);
    border: 1px solid rgba(255, 255, 255, .22);
}

.cabinet-form-v119 .cabinet-primary-v119 {
    color: #fff;
    background: linear-gradient(135deg, var(--blue), #2B65A9);
    box-shadow: 0 12px 26px rgba(25, 79, 146, .22);
}

.cabinet-form-v119 .cabinet-secondary-v119,
.cabinet-results-v119 .cabinet-ghost-v119,
.cabinet-output-v119 .cabinet-secondary-v119 {
    color: var(--blue);
    background: var(--blue-50);
    border-color: rgba(25, 79, 146, .08);
    box-shadow: none;
}

.tools-mini-board-v119 {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 10px;
}

.tools-mini-board-v119 div {
    padding: 14px;
    border-radius: 22px;
    background: rgba(255, 255, 255, .12);
    border: 1px solid rgba(255, 255, 255, .18);
}

.tools-mini-board-v119 strong,
.tools-mini-board-v119 span {
    display: block;
}

.tools-mini-board-v119 span {
    margin-top: 5px;
    color: rgba(255, 255, 255, .72);
    font-size: 12px;
}

.tools-grid-v119 {
    display: grid;
    gap: 12px;
}

.tool-card--featured-v119 {
    position: relative;
    overflow: hidden;
    border-color: rgba(25, 79, 146, .20) !important;
    box-shadow: 0 18px 42px rgba(25, 79, 146, .11);
}

.tool-card em {
    justify-self: start;
    display: inline-flex;
    margin-top: 6px;
    padding: 5px 9px;
    border-radius: 999px;
    color: var(--blue);
    background: var(--blue-50);
    font-size: 11px;
    font-style: normal;
    font-weight: 900;
}

.cabinet-hero-v119__panel {
    position: relative;
    min-height: 250px;
}

.cabinet-board-v119 {
    position: absolute;
    inset: 18px 12px 18px 42px;
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 10px;
    padding: 12px;
    border-radius: 28px;
    background: rgba(255, 255, 255, .14);
    border: 1px solid rgba(255, 255, 255, .2);
    transform: rotate(-2deg);
}

.cabinet-board-v119 span {
    border-radius: 18px;
    background:
        linear-gradient(135deg, rgba(255,255,255,.56), rgba(255,255,255,.18)),
        repeating-linear-gradient(90deg, rgba(255,255,255,.18) 0, rgba(255,255,255,.18) 1px, transparent 1px, transparent 16px);
}

.cabinet-floating-stat-v119 {
    position: absolute;
    display: grid;
    gap: 2px;
    min-width: 112px;
    padding: 13px;
    border-radius: 20px;
    color: var(--ink-900);
    background: rgba(255, 255, 255, .92);
    box-shadow: 0 18px 35px rgba(0, 0, 0, .18);
}

.cabinet-floating-stat-v119 strong {
    color: var(--blue);
    font-size: 22px;
}

.cabinet-floating-stat-v119 small {
    color: var(--ink-500);
}

.cabinet-floating-stat-v119--one {
    right: 0;
    top: 38px;
}

.cabinet-floating-stat-v119--two {
    left: 0;
    bottom: 28px;
}

.cabinet-workspace-v119 {
    display: grid;
    gap: 14px;
}

.cabinet-form-v119,
.cabinet-results-v119,
.cabinet-output-v119 {
    padding: 16px;
    border-radius: 30px;
    background: rgba(255, 255, 255, .90);
    border: 1px solid var(--line);
    box-shadow: var(--shadow-soft);
}

.cabinet-form-head-v119,
.cabinet-result-head-v119,
.cabinet-output-head-v119,
.cabinet-edge-head-v119 {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 12px;
    margin-bottom: 14px;
}

.cabinet-form-head-v119 span,
.cabinet-result-head-v119 span,
.cabinet-output-head-v119 span {
    color: var(--blue);
    background: var(--blue-50);
    border-color: rgba(25, 79, 146, .08);
}

.cabinet-form-head-v119 h2,
.cabinet-result-head-v119 h2,
.cabinet-output-head-v119 h2 {
    margin: 7px 0 0;
    font-size: 20px;
    line-height: 1.6;
    color: var(--ink-900);
}

.cabinet-segment-v119 {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 8px;
    padding: 6px;
    margin-bottom: 14px;
    border-radius: 22px;
    background: #F4F7FD;
    border: 1px solid rgba(25, 79, 146, .08);
}

.cabinet-segment-v119 label {
    cursor: pointer;
}

.cabinet-segment-v119 input {
    position: absolute;
    opacity: 0;
    pointer-events: none;
}

.cabinet-segment-v119 span {
    display: grid;
    place-items: center;
    min-height: 42px;
    padding: 9px 8px;
    border-radius: 17px;
    color: var(--ink-700);
    font-weight: 900;
    font-size: 12px;
    transition: .18s ease;
}

.cabinet-segment-v119 input:checked + span {
    color: #fff;
    background: linear-gradient(135deg, var(--blue), #2B65A9);
    box-shadow: 0 12px 24px rgba(25, 79, 146, .20);
}

.cabinet-form-grid-v119,
.cabinet-edge-grid-v119 {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 10px;
    margin-bottom: 12px;
}

.cabinet-form-grid-v119--dense {
    grid-template-columns: repeat(3, minmax(0, 1fr));
}

.cabinet-form-grid-v119 label,
.cabinet-edge-grid-v119 label {
    display: grid;
    gap: 7px;
}

.cabinet-form-grid-v119 label span,
.cabinet-edge-grid-v119 label span {
    color: var(--ink-700);
    font-size: 12px;
    font-weight: 900;
}

.cabinet-form-v119 input,
.cabinet-form-v119 select {
    width: 100%;
    min-height: 46px;
    padding: 10px 12px;
    border-radius: 16px;
    border: 1px solid rgba(25, 79, 146, .12);
    background: #fff;
    color: var(--ink-900);
    outline: none;
    transition: border-color .16s ease, box-shadow .16s ease, background .16s ease;
}

.cabinet-form-v119 input:focus,
.cabinet-form-v119 select:focus {
    border-color: rgba(25, 79, 146, .42);
    box-shadow: 0 0 0 4px rgba(25, 79, 146, .08);
}

.cabinet-edge-box-v119,
.cabinet-details-v119 {
    margin-bottom: 12px;
    padding: 12px;
    border-radius: 22px;
    border: 1px dashed rgba(25, 79, 146, .20);
    background: #FAFCFF;
}

.cabinet-edge-head-v119 {
    margin-bottom: 12px;
}

.cabinet-edge-head-v119 strong {
    color: var(--ink-900);
}

.cabinet-edge-head-v119 small {
    color: var(--ink-500);
    line-height: 1.8;
}

.cabinet-details-v119 summary {
    cursor: pointer;
    margin-bottom: 12px;
    color: var(--blue);
    font-weight: 900;
}

.cabinet-form-note-v119 {
    margin: 10px 0 0;
    color: var(--ink-500);
    font-size: 12px;
    line-height: 1.9;
}

.cabinet-summary-grid-v119 {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 10px;
}

.cabinet-summary-grid-v119 div {
    display: grid;
    gap: 4px;
    min-height: 82px;
    align-content: center;
    padding: 12px;
    border-radius: 20px;
    background: linear-gradient(135deg, #fff, #F6F8FF);
    border: 1px solid rgba(25, 79, 146, .08);
}

.cabinet-summary-grid-v119 small {
    color: var(--ink-500);
    font-size: 11px;
    font-weight: 900;
}

.cabinet-summary-grid-v119 strong {
    color: var(--blue);
    font-size: 18px;
    line-height: 1.35;
}

.cabinet-empty-v119 {
    margin-top: 12px;
    padding: 18px;
    border-radius: 22px;
    text-align: center;
    background: #FAFAFB;
    border: 1px dashed rgba(25, 79, 146, .18);
}

.cabinet-empty-v119 p {
    margin: 8px 0 0;
    color: var(--ink-500);
    font-size: 13px;
    line-height: 1.8;
}

.cabinet-entry-list-v119 {
    display: grid;
    gap: 10px;
    margin-top: 12px;
}

.cabinet-entry-card-v119 {
    position: relative;
    display: grid;
    gap: 9px;
    padding: 12px 12px 12px 44px;
    border-radius: 20px;
    background: #fff;
    border: 1px solid rgba(25, 79, 146, .08);
    box-shadow: var(--shadow-card);
}

.cabinet-entry-card-v119 strong,
.cabinet-entry-card-v119 small {
    display: block;
}

.cabinet-entry-card-v119 small {
    margin-top: 4px;
    color: var(--ink-500);
    font-size: 12px;
}

.cabinet-entry-card-v119 button {
    position: absolute;
    left: 10px;
    top: 10px;
    width: 28px;
    height: 28px;
    border: 0;
    border-radius: 999px;
    color: var(--danger);
    background: var(--danger-bg);
    font-size: 18px;
    line-height: 1;
}

.cabinet-entry-metrics-v119 {
    display: flex;
    flex-wrap: wrap;
    gap: 6px;
}

.cabinet-entry-metrics-v119 span {
    display: inline-flex;
    padding: 5px 8px;
    border-radius: 999px;
    color: var(--blue);
    background: var(--blue-50);
    font-size: 11px;
    font-weight: 900;
}

.cabinet-output-v119 {
    display: grid;
    gap: 12px;
}

.cabinet-output-v119[hidden] {
    display: none;
}

.cabinet-table-wrap-v119 {
    overflow: auto;
    border-radius: 22px;
    border: 1px solid rgba(25, 79, 146, .08);
    background: #fff;
}

.cabinet-table-v119 {
    width: 100%;
    min-width: 720px;
    border-collapse: collapse;
}

.cabinet-table-v119 th,
.cabinet-table-v119 td {
    padding: 11px 12px;
    border-bottom: 1px solid rgba(25, 79, 146, .07);
    text-align: right;
    font-size: 12px;
    white-space: nowrap;
}

.cabinet-table-v119 th {
    position: sticky;
    top: 0;
    z-index: 1;
    color: var(--blue);
    background: #F5F8FF;
    font-weight: 900;
}

.cabinet-table-v119 tr:last-child td {
    border-bottom: 0;
}

.cabinet-toast-v119 {
    position: fixed;
    right: 50%;
    bottom: calc(94px + var(--safe-bottom));
    z-index: 200;
    transform: translate(50%, 12px);
    opacity: 0;
    padding: 11px 14px;
    border-radius: 999px;
    color: #fff;
    background: var(--blue);
    box-shadow: 0 18px 36px rgba(25, 79, 146, .24);
    transition: .22s ease;
    pointer-events: none;
    font-size: 13px;
    font-weight: 900;
}

.cabinet-toast-v119.is-visible {
    opacity: 1;
    transform: translate(50%, 0);
}

.is-hidden {
    display: none !important;
}

@media (min-width: 720px) {
    .tools-grid-v119 {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .cabinet-summary-grid-v119 {
        grid-template-columns: repeat(4, minmax(0, 1fr));
    }
}

@media (min-width: 960px) {
    .tools-hero-v119,
    .cabinet-hero-v119 {
        grid-template-columns: minmax(0, 1.25fr) minmax(290px, .75fr);
        align-items: center;
        padding: 30px;
    }

    .cabinet-workspace-v119 {
        grid-template-columns: minmax(0, 1.15fr) minmax(340px, .85fr);
        align-items: start;
    }

    .cabinet-results-v119 {
        position: sticky;
        top: 78px;
    }

    .tools-grid-v119 {
        grid-template-columns: repeat(4, minmax(0, 1fr));
    }
}

@media (max-width: 680px) {
    .tools-hero-v119,
    .cabinet-hero-v119,
    .cabinet-form-v119,
    .cabinet-results-v119,
    .cabinet-output-v119 {
        border-radius: 24px;
    }

    .tools-hero-actions-v119 a,
    .cabinet-hero-actions-v119 a,
    .cabinet-form-actions-v119 button {
        width: 100%;
    }

    .cabinet-segment-v119 {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .cabinet-form-grid-v119,
    .cabinet-edge-grid-v119,
    .cabinet-form-grid-v119--dense {
        grid-template-columns: 1fr;
    }

    .cabinet-form-head-v119,
    .cabinet-result-head-v119,
    .cabinet-output-head-v119,
    .cabinet-edge-head-v119 {
        flex-direction: column;
    }

    .cabinet-result-head-v119 button,
    .cabinet-output-head-v119 button {
        width: 100%;
    }

    .cabinet-summary-grid-v119 {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
}


/* v1.1.10 - tool access polish */
@media (min-width: 860px) {
    .header-main-nav { display: inline-flex; }
}

@media (max-width: 420px) {
    .bottom-nav { gap: 4px; padding-inline: 6px; }
    .bottom-nav__item { border-radius: 15px; font-size: 10px; }
    .bottom-nav__icon { font-size: 16px; }
}

/* v1.1.11 - cabinet meter Excel export and overflow fix */
.cabinet-meter-v119,
.cabinet-meter-v119 * {
    box-sizing: border-box;
}

.cabinet-meter-v119 {
    width: 100%;
    max-width: 100%;
    overflow-x: clip;
}

.cabinet-hero-v119,
.cabinet-workspace-v119,
.cabinet-output-v119,
.cabinet-form-v119,
.cabinet-results-v119,
.cabinet-hero-v119__copy,
.cabinet-hero-v119__panel {
    min-width: 0;
}

.cabinet-output-actions-v1111 {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    align-items: center;
    justify-content: flex-end;
}

.cabinet-excel-btn-v1111 {
    color: #fff;
    background: linear-gradient(135deg, #217346, #2F8F5A);
    box-shadow: 0 12px 26px rgba(33, 115, 70, .22);
}

.cabinet-output-v119 .cabinet-excel-btn-v1111 {
    color: #fff;
    border-color: transparent;
}

.cabinet-table-wrap-v119 {
    width: 100%;
    max-width: 100%;
    overflow-x: hidden;
}

.cabinet-table-v119 {
    width: 100%;
    min-width: 0;
    table-layout: fixed;
}

.cabinet-table-v119 th,
.cabinet-table-v119 td {
    white-space: normal;
    overflow-wrap: anywhere;
    word-break: normal;
    vertical-align: top;
}

.cabinet-table-v119--parts th:first-child,
.cabinet-table-v119--parts td:first-child {
    width: 20%;
}

@media (max-width: 680px) {
    .cabinet-meter-v119 {
        overflow-x: hidden;
    }

    .cabinet-output-actions-v1111 {
        width: 100%;
        justify-content: stretch;
    }

    .cabinet-output-actions-v1111 button {
        flex: 1 1 100%;
    }

    .cabinet-table-wrap-v119 {
        overflow: visible;
        border: 0;
        border-radius: 0;
        background: transparent;
    }

    .cabinet-table-v119,
    .cabinet-table-v119 thead,
    .cabinet-table-v119 tbody,
    .cabinet-table-v119 tr,
    .cabinet-table-v119 td {
        display: block;
        width: 100%;
    }

    .cabinet-table-v119 thead {
        display: none;
    }

    .cabinet-table-v119 tr {
        margin-bottom: 10px;
        padding: 10px 12px;
        border-radius: 18px;
        border: 1px solid rgba(25, 79, 146, .08);
        background: #fff;
        box-shadow: 0 10px 24px rgba(25, 79, 146, .05);
    }

    .cabinet-table-v119 tr:last-child {
        margin-bottom: 0;
    }

    .cabinet-table-v119 td {
        display: flex;
        align-items: flex-start;
        justify-content: space-between;
        gap: 12px;
        padding: 8px 0;
        border-bottom: 1px dashed rgba(25, 79, 146, .10);
        text-align: left;
        direction: rtl;
    }

    .cabinet-table-v119 td::before {
        content: attr(data-label);
        flex: 0 0 42%;
        color: var(--blue);
        font-weight: 900;
        text-align: right;
    }

    .cabinet-table-v119 td:last-child {
        border-bottom: 0;
    }
}


/* v1.1.13 - hard mobile overflow and bottom nav repair */
html,
body {
    width: 100%;
    max-width: 100%;
    overflow-x: hidden;
}

.app-shell,
.app-main {
    max-width: 100%;
    overflow-x: clip;
}

.bottom-nav,
.bottom-nav * {
    box-sizing: border-box;
}

.bottom-nav {
    max-width: 100%;
    min-width: 0;
}

.bottom-nav__item,
.bottom-nav__item span {
    min-width: 0;
}

.bottom-nav__item > span:last-child {
    max-width: 100%;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

@media (max-width: 767px) {
    .app-shell {
        padding-bottom: calc(92px + var(--safe-bottom));
    }

    .bottom-nav {
        right: 8px;
        left: 8px;
        bottom: 8px;
        width: auto;
        max-width: none;
        grid-template-columns: repeat(5, minmax(0, 1fr));
        gap: 4px;
        padding: 6px 6px calc(6px + var(--safe-bottom));
        border: 1px solid rgba(25, 79, 146, 0.12);
        border-radius: 24px;
        background: rgba(255, 255, 255, 0.96);
        box-shadow: 0 -10px 32px rgba(25, 79, 146, 0.12);
    }

    .bottom-nav__item {
        min-height: 50px;
        height: 50px;
        padding: 6px 2px;
        border-radius: 18px;
        gap: 3px;
        font-size: 10px;
        line-height: 1.2;
        overflow: hidden;
    }

    .bottom-nav__icon {
        font-size: 16px;
    }

    .bottom-nav__item--primary {
        min-height: 50px;
        height: 50px;
        margin-top: 0;
        color: var(--blue) !important;
        background: var(--blue-50);
        border: 0;
        box-shadow: none;
    }

    .bottom-nav__item.active,
    .bottom-nav__item--primary.active {
        color: #fff !important;
        background: linear-gradient(145deg, var(--blue), #2B65A9);
        box-shadow: 0 10px 22px rgba(25, 79, 146, 0.18);
    }

    .nav-badge {
        top: -4px;
        left: -4px;
    }
}

@media (min-width: 768px) {
    .bottom-nav {
        width: min(calc(100% - 24px), 560px);
        right: 50%;
        left: auto;
        transform: translateX(50%);
    }
}

.cabinet-meter-v119,
.cabinet-meter-v119 * {
    max-width: 100%;
}

.cabinet-meter-v119 {
    overflow-x: clip;
    contain: layout paint;
}

.cabinet-hero-v119,
.cabinet-workspace-v119,
.cabinet-output-v119,
.cabinet-form-v119,
.cabinet-results-v119,
.cabinet-form-grid-v119,
.cabinet-edge-grid-v119,
.cabinet-summary-grid-v119,
.cabinet-entry-list-v119,
.cabinet-table-wrap-v119 {
    width: 100%;
    min-width: 0;
    max-width: 100%;
}

.cabinet-form-grid-v119 label,
.cabinet-edge-grid-v119 label,
.cabinet-segment-v119 label,
.cabinet-form-v119 input,
.cabinet-form-v119 select,
.cabinet-entry-card-v119,
.cabinet-output-actions-v1111 button {
    min-width: 0;
}

.cabinet-table-wrap-v119 {
    overflow-x: auto;
    overscroll-behavior-inline: contain;
}

@media (max-width: 680px) {
    .cabinet-meter-v119 {
        gap: 12px;
    }

    .cabinet-hero-v119,
    .cabinet-form-v119,
    .cabinet-results-v119,
    .cabinet-output-v119 {
        padding: 14px;
    }

    .cabinet-hero-v119__panel {
        min-height: 210px;
        overflow: hidden;
    }

    .cabinet-board-v119 {
        inset: 18px 8px 18px 8px;
        transform: none;
    }

    .cabinet-floating-stat-v119 {
        min-width: 96px;
        padding: 10px;
    }

    .cabinet-floating-stat-v119--one {
        right: 8px;
    }

    .cabinet-floating-stat-v119--two {
        left: 8px;
    }

    .cabinet-table-wrap-v119 {
        overflow: visible;
    }

    .cabinet-table-v119 {
        min-width: 0 !important;
        max-width: 100%;
    }

    .cabinet-table-v119 tr,
    .cabinet-table-v119 td {
        max-width: 100%;
    }

    .cabinet-table-v119 td {
        min-width: 0;
        overflow-wrap: anywhere;
    }

    .cabinet-table-v119 td::before {
        min-width: 0;
    }
}

/* v1.1.14 - Extra free tools */
.tools-grid-v1114 {
    grid-template-columns: repeat(auto-fit, minmax(230px, 1fr));
}

.tool-calc-v1114,
.tool-calc-v1114 * {
    box-sizing: border-box;
    max-width: 100%;
}

.tool-calc-v1114 {
    display: grid;
    gap: 20px;
    overflow-x: clip;
    contain: layout paint;
}

.tool-calc-hero-v1114 {
    display: grid;
    grid-template-columns: minmax(0, 1.7fr) minmax(230px, .7fr);
    gap: 18px;
    align-items: stretch;
    padding: 24px;
    border-radius: 28px;
    background:
        radial-gradient(circle at 12% 18%, rgba(246, 154, 41, .18), transparent 32%),
        linear-gradient(135deg, #fff, #eef5ff);
    border: 1px solid rgba(25, 79, 146, .10);
    box-shadow: 0 22px 55px rgba(25, 79, 146, .08);
    min-width: 0;
}

.tool-calc-chip-v1114 {
    display: inline-flex;
    align-items: center;
    padding: 7px 12px;
    border-radius: 999px;
    background: rgba(25, 79, 146, .08);
    color: var(--blue);
    font-weight: 900;
    font-size: 12px;
    margin-bottom: 10px;
}

.tool-calc-hero-v1114 h1 {
    margin: 0;
    font-size: clamp(25px, 4vw, 42px);
    line-height: 1.55;
    color: var(--ink);
}

.tool-calc-hero-v1114 p {
    margin: 10px 0 0;
    color: var(--muted);
    line-height: 2;
    max-width: 760px;
}

.tool-calc-actions-v1114,
.tool-calc-form-actions-v1114 {
    display: flex;
    gap: 10px;
    flex-wrap: wrap;
    align-items: center;
    margin-top: 18px;
}

.tool-calc-primary-v1114,
.tool-calc-secondary-v1114,
.tool-calc-form-actions-v1114 button,
.tool-calc-card-head-v1114 button,
.tool-calc-table-v1114 button {
    appearance: none;
    border: 0;
    border-radius: 16px;
    padding: 11px 14px;
    font-weight: 900;
    text-decoration: none;
    cursor: pointer;
    display: inline-flex;
    justify-content: center;
    align-items: center;
    gap: 7px;
    font-family: inherit;
    line-height: 1.3;
    min-width: 0;
}

.tool-calc-primary-v1114,
.tool-calc-form-actions-v1114 button:first-child {
    background: linear-gradient(135deg, var(--blue), #2b65a9);
    color: #fff;
    box-shadow: 0 15px 28px rgba(25, 79, 146, .18);
}

.tool-calc-secondary-v1114,
.tool-calc-form-actions-v1114 button:last-child,
.tool-calc-card-head-v1114 button,
.tool-calc-table-v1114 button {
    background: #fff;
    color: var(--blue);
    border: 1px solid rgba(25, 79, 146, .14);
}

.tool-calc-score-v1114 {
    border-radius: 24px;
    padding: 22px;
    background: linear-gradient(145deg, var(--blue), #173e74);
    color: #fff;
    display: grid;
    align-content: center;
    justify-items: start;
    min-height: 180px;
    position: relative;
    overflow: hidden;
}

.tool-calc-score-v1114::after {
    content: '';
    position: absolute;
    width: 130px;
    height: 130px;
    border-radius: 34px;
    background: rgba(255,255,255,.09);
    left: -28px;
    bottom: -38px;
    transform: rotate(18deg);
}

.tool-calc-score-v1114 small,
.tool-calc-score-v1114 span {
    opacity: .82;
    position: relative;
    z-index: 1;
}

.tool-calc-score-v1114 strong {
    font-size: clamp(34px, 7vw, 62px);
    position: relative;
    z-index: 1;
    line-height: 1.1;
}

.tool-calc-grid-v1114 {
    display: grid;
    grid-template-columns: minmax(0, .95fr) minmax(0, 1.05fr);
    gap: 18px;
    align-items: start;
    min-width: 0;
}

.tool-calc-grid-v1114--single {
    grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
}

.tool-calc-card-v1114 {
    background: #fff;
    border: 1px solid rgba(25, 79, 146, .10);
    border-radius: 24px;
    box-shadow: 0 18px 40px rgba(25, 79, 146, .07);
    padding: 18px;
    min-width: 0;
    width: 100%;
}

.tool-calc-card-head-v1114 {
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 10px;
    margin-bottom: 14px;
    min-width: 0;
}

.tool-calc-card-head-v1114 h2 {
    margin: 0;
    color: var(--ink);
    font-size: 19px;
}

.tool-calc-card-head-v1114 small {
    color: var(--muted);
}

.tool-calc-form-grid-v1114 {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 12px;
    min-width: 0;
}

.tool-calc-form-grid-v1114 label {
    display: grid;
    gap: 7px;
    min-width: 0;
}

.tool-calc-form-grid-v1114 span,
.tool-edge-picker-v1114 span {
    color: var(--muted);
    font-size: 12px;
    font-weight: 900;
}

.tool-calc-form-grid-v1114 input,
.tool-calc-form-grid-v1114 select {
    width: 100%;
    border: 1px solid rgba(25, 79, 146, .14);
    border-radius: 15px;
    padding: 11px 12px;
    font-family: inherit;
    min-width: 0;
    background: #fff;
}

.tool-calc-form-grid-v1114 input:focus,
.tool-calc-form-grid-v1114 select:focus {
    outline: 3px solid rgba(25, 79, 146, .12);
    border-color: rgba(25, 79, 146, .34);
}

.tool-calc-details-v1114 {
    margin-top: 14px;
    padding: 12px;
    border-radius: 18px;
    background: #f8fbff;
    border: 1px dashed rgba(25, 79, 146, .16);
}

.tool-calc-details-v1114 summary {
    cursor: pointer;
    font-weight: 900;
    color: var(--blue);
    margin-bottom: 10px;
}

.tool-edge-picker-v1114 {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 10px;
    margin-top: 14px;
}

.tool-edge-picker-v1114 label {
    display: flex;
    gap: 8px;
    align-items: center;
    justify-content: center;
    border: 1px solid rgba(25, 79, 146, .13);
    border-radius: 15px;
    padding: 10px;
    min-width: 0;
    background: #f9fbff;
}

.tool-calc-metrics-v1114 {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 10px;
    margin-bottom: 14px;
}

.tool-calc-metrics-v1114 div {
    border-radius: 18px;
    padding: 13px;
    background: #f7fafe;
    border: 1px solid rgba(25, 79, 146, .08);
    display: grid;
    gap: 5px;
    min-width: 0;
}

.tool-calc-metrics-v1114 small,
.tool-converter-list-v1114 span {
    color: var(--muted);
    font-weight: 800;
    font-size: 12px;
}

.tool-calc-metrics-v1114 strong,
.tool-converter-list-v1114 strong {
    color: var(--ink);
    font-size: 18px;
    overflow-wrap: anywhere;
}

.tool-calc-table-wrap-v1114 {
    width: 100%;
    min-width: 0;
    overflow-x: auto;
    overscroll-behavior-inline: contain;
    border-radius: 18px;
    border: 1px solid rgba(25, 79, 146, .08);
}

.tool-calc-table-v1114 {
    width: 100%;
    border-collapse: collapse;
    min-width: 620px;
    background: #fff;
}

.tool-calc-table-v1114 th,
.tool-calc-table-v1114 td {
    padding: 12px;
    border-bottom: 1px solid rgba(25, 79, 146, .08);
    text-align: right;
    vertical-align: top;
    color: var(--ink);
}

.tool-calc-table-v1114 th {
    background: #f6f9fd;
    color: var(--muted);
    font-size: 12px;
}

.tool-calc-table-v1114 small {
    display: block;
    color: var(--muted);
    margin-top: 4px;
}

.tool-empty-cell-v1114 {
    text-align: center !important;
    color: var(--muted) !important;
    padding: 22px !important;
}

.tool-converter-list-v1114 {
    display: grid;
    gap: 10px;
}

.tool-converter-list-v1114 div {
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 12px;
    border-radius: 16px;
    background: #f7fafe;
    border: 1px solid rgba(25, 79, 146, .08);
    padding: 13px;
    min-width: 0;
}

@media (max-width: 820px) {
    .tool-calc-hero-v1114,
    .tool-calc-grid-v1114,
    .tool-calc-grid-v1114--single {
        grid-template-columns: 1fr;
    }
}

@media (max-width: 680px) {
    .tool-calc-v1114 {
        gap: 13px;
    }

    .tool-calc-hero-v1114,
    .tool-calc-card-v1114 {
        padding: 14px;
        border-radius: 20px;
    }

    .tool-calc-form-grid-v1114,
    .tool-calc-metrics-v1114,
    .tool-edge-picker-v1114 {
        grid-template-columns: 1fr;
    }

    .tool-calc-card-head-v1114 {
        align-items: flex-start;
        flex-direction: column;
    }

    .tool-calc-card-head-v1114 button,
    .tool-calc-form-actions-v1114 button,
    .tool-calc-actions-v1114 a {
        width: 100%;
    }

    .tool-calc-table-wrap-v1114 {
        overflow: visible;
        border: 0;
    }

    .tool-calc-table-v1114,
    .tool-calc-table-v1114 thead,
    .tool-calc-table-v1114 tbody,
    .tool-calc-table-v1114 th,
    .tool-calc-table-v1114 td,
    .tool-calc-table-v1114 tr {
        display: block;
        min-width: 0 !important;
        width: 100%;
    }

    .tool-calc-table-v1114 thead {
        display: none;
    }

    .tool-calc-table-v1114 tr {
        border: 1px solid rgba(25, 79, 146, .10);
        border-radius: 16px;
        padding: 8px;
        margin-bottom: 10px;
        background: #fff;
    }

    .tool-calc-table-v1114 td {
        border: 0;
        padding: 8px 4px;
        display: flex;
        justify-content: space-between;
        gap: 12px;
        overflow-wrap: anywhere;
    }

    .tool-calc-table-v1114 td::before {
        content: attr(data-label);
        color: var(--muted);
        font-size: 12px;
        font-weight: 900;
        flex: 0 0 auto;
    }

    .tool-empty-cell-v1114::before {
        content: none !important;
    }
}

/* v1.1.15 - cabinet meter mobile compact tables */
@media (max-width: 680px) {
    .cabinet-output-v119 {
        overflow: hidden;
    }

    .cabinet-output-v119 .cabinet-table-wrap-v119 {
        position: relative;
        display: block;
        width: 100%;
        max-width: 100%;
        overflow-x: auto;
        overflow-y: hidden;
        -webkit-overflow-scrolling: touch;
        overscroll-behavior-inline: contain;
        border: 1px solid rgba(25, 79, 146, .10);
        border-radius: 18px;
        background: #fff;
        box-shadow: inset 10px 0 18px -18px rgba(25, 79, 146, .35), inset -10px 0 18px -18px rgba(25, 79, 146, .35);
    }

    .cabinet-output-v119 .cabinet-table-wrap-v119::before {
        content: 'برای دیدن همه ستون‌ها جدول را به چپ و راست بکشید';
        display: block;
        position: sticky;
        right: 0;
        min-width: 100%;
        padding: 8px 10px;
        color: var(--ink-500);
        background: #F8FAFF;
        border-bottom: 1px solid rgba(25, 79, 146, .08);
        font-size: 11px;
        font-weight: 900;
        text-align: right;
        white-space: nowrap;
    }

    .cabinet-output-v119 .cabinet-table-v119,
    .cabinet-output-v119 .cabinet-table-v119 thead,
    .cabinet-output-v119 .cabinet-table-v119 tbody,
    .cabinet-output-v119 .cabinet-table-v119 tr,
    .cabinet-output-v119 .cabinet-table-v119 th,
    .cabinet-output-v119 .cabinet-table-v119 td {
        display: revert;
        width: auto;
        max-width: none;
    }

    .cabinet-output-v119 .cabinet-table-v119 {
        display: table;
        min-width: 560px !important;
        width: max-content;
        border-collapse: collapse;
        table-layout: auto;
    }

    .cabinet-output-v119 .cabinet-table-v119--parts {
        min-width: 920px !important;
    }

    .cabinet-output-v119 .cabinet-table-v119 thead {
        display: table-header-group;
    }

    .cabinet-output-v119 .cabinet-table-v119 tbody {
        display: table-row-group;
    }

    .cabinet-output-v119 .cabinet-table-v119 tr {
        display: table-row;
        margin: 0;
        padding: 0;
        border: 0;
        border-radius: 0;
        background: transparent;
        box-shadow: none;
    }

    .cabinet-output-v119 .cabinet-table-v119 th,
    .cabinet-output-v119 .cabinet-table-v119 td {
        display: table-cell;
        padding: 9px 10px;
        border-bottom: 1px solid rgba(25, 79, 146, .07);
        text-align: right;
        direction: rtl;
        vertical-align: middle;
        white-space: nowrap;
        overflow-wrap: normal;
        word-break: normal;
        font-size: 11px;
        line-height: 1.8;
    }

    .cabinet-output-v119 .cabinet-table-v119 th {
        position: sticky;
        top: 0;
        z-index: 2;
        background: #F5F8FF;
        color: var(--blue);
        font-weight: 900;
    }

    .cabinet-output-v119 .cabinet-table-v119 th:first-child,
    .cabinet-output-v119 .cabinet-table-v119 td:first-child {
        position: sticky;
        right: 0;
        z-index: 1;
        max-width: 150px;
        min-width: 120px;
        background: #fff;
        box-shadow: -8px 0 18px -16px rgba(25, 79, 146, .55);
        white-space: normal;
    }

    .cabinet-output-v119 .cabinet-table-v119 th:first-child {
        z-index: 3;
        background: #F5F8FF;
    }

    .cabinet-output-v119 .cabinet-table-v119 td::before {
        content: none !important;
        display: none !important;
    }
}

/* v1.1.16 - Cabinet meter technical pricing and hardware breakdown */
.cabinet-price-box-v1116 {
    margin-top: 16px;
    padding: 16px;
    border-radius: 24px;
    background:
        radial-gradient(circle at 12% 18%, rgba(246, 154, 41, .13), transparent 34%),
        linear-gradient(135deg, #fff, #F5F9FF);
    border: 1px solid rgba(25, 79, 146, .10);
}

.cabinet-price-box-v1116__head {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 12px;
    margin-bottom: 12px;
}

.cabinet-price-box-v1116__head strong {
    color: var(--ink);
    font-size: 15px;
    font-weight: 1000;
}

.cabinet-price-box-v1116__head small {
    max-width: 360px;
    color: var(--ink-500);
    font-size: 12px;
    line-height: 1.8;
    text-align: left;
}

.cabinet-form-grid-v1116 {
    grid-template-columns: repeat(3, minmax(0, 1fr));
}

.cabinet-summary-grid-v119 .cabinet-cost-card-v1116 {
    background: linear-gradient(135deg, #173F74, #2B65A9);
    border-color: transparent;
}

.cabinet-summary-grid-v119 .cabinet-cost-card-v1116 small,
.cabinet-summary-grid-v119 .cabinet-cost-card-v1116 strong {
    color: #fff;
}

.cabinet-table-v119--costs tr:last-child td {
    color: var(--blue);
    background: #F5F8FF;
    font-weight: 1000;
}

.cabinet-table-v119--hardware td strong,
.cabinet-table-v119--costs td strong {
    color: var(--blue);
}

@media (max-width: 860px) {
    .cabinet-form-grid-v1116 {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
}

@media (max-width: 680px) {
    .cabinet-price-box-v1116 {
        padding: 12px;
        border-radius: 20px;
    }

    .cabinet-price-box-v1116__head {
        display: grid;
    }

    .cabinet-price-box-v1116__head small {
        max-width: none;
        text-align: right;
    }

    .cabinet-form-grid-v1116 {
        grid-template-columns: 1fr;
    }

    .cabinet-output-v119 .cabinet-table-v119--costs,
    .cabinet-output-v119 .cabinet-table-v119--hardware {
        min-width: 620px !important;
    }
}

/* v1.1.17: Store-driven pricing inside cabinet meter */
.cabinet-store-price-v1117 {
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto;
    gap: 12px 16px;
    align-items: center;
    margin: 14px 0 18px;
    padding: 14px;
    border: 1px solid rgba(21, 101, 93, .18);
    border-radius: 18px;
    background: linear-gradient(135deg, rgba(21, 101, 93, .08), rgba(255, 255, 255, .92));
    overflow: hidden;
}
.cabinet-store-price-v1117 strong {
    display: block;
    color: #173b35;
    font-size: .98rem;
}
.cabinet-store-price-v1117 small,
.cabinet-store-price-v1117 p {
    color: #66746f;
    font-size: .82rem;
    line-height: 1.85;
}
.cabinet-store-price-v1117 p {
    grid-column: 1 / -1;
    margin: 0;
}
.cabinet-store-sources-v1117 {
    grid-column: 1 / -1;
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(210px, 1fr));
    gap: 10px;
    min-width: 0;
}
.cabinet-store-source-v1117 {
    display: grid;
    gap: 4px;
    padding: 10px 12px;
    border-radius: 14px;
    background: rgba(255, 255, 255, .86);
    border: 1px solid rgba(21, 101, 93, .12);
    text-decoration: none;
    color: inherit;
    min-width: 0;
}
.cabinet-store-source-v1117:hover {
    border-color: rgba(21, 101, 93, .28);
    transform: translateY(-1px);
}
.cabinet-store-source-v1117 span {
    font-size: .75rem;
    color: #15655d;
    font-weight: 800;
}
.cabinet-store-source-v1117 strong {
    font-size: .95rem;
    color: #222;
}
.cabinet-store-source-v1117 small,
.cabinet-store-source-v1117 em {
    display: block;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
    font-style: normal;
    color: #6b756f;
}
.cabinet-store-source-v1117 em {
    color: #8b6d2d;
    font-size: .74rem;
}
@media (max-width: 640px) {
    .cabinet-store-price-v1117 {
        grid-template-columns: 1fr;
        padding: 12px;
    }
    .cabinet-store-price-v1117 .cabinet-secondary-v119 {
        width: 100%;
        justify-content: center;
    }
    .cabinet-store-sources-v1117 {
        grid-template-columns: 1fr;
    }
}

/* v1.1.18 Cabinet project workflow */
.cabinet-project-panel-v1118 {
    margin: 24px 0;
    padding: 22px;
    border: 1px solid rgba(25, 79, 146, .14);
    border-radius: 24px;
    background: linear-gradient(135deg, #ffffff 0%, #f7fbff 100%);
    box-shadow: 0 16px 44px rgba(15, 45, 82, .08);
    overflow: hidden;
}
.cabinet-project-panel-v1118__head,
.cabinet-project-actions-v1118 {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 16px;
    flex-wrap: wrap;
}
.cabinet-project-panel-v1118__head h2 { margin: 6px 0 8px; }
.cabinet-project-panel-v1118__head span { color: var(--primary, #194F92); font-weight: 800; }
.cabinet-project-panel-v1118__head p,
.cabinet-project-actions-v1118 small { color: #5d6b7b; margin: 0; line-height: 1.9; }
.cabinet-project-grid-v1118 {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 14px;
    margin: 18px 0;
}
.cabinet-project-grid-v1118 label { display: flex; flex-direction: column; gap: 8px; }
.cabinet-project-grid-v1118 span { font-weight: 800; color: #24364b; }
.cabinet-project-grid-v1118 input,
.cabinet-project-grid-v1118 textarea {
    width: 100%;
    border: 1px solid rgba(25, 79, 146, .16);
    border-radius: 14px;
    padding: 12px 14px;
    background: #fff;
    color: #17253a;
    box-sizing: border-box;
}
.cabinet-project-grid-v1118__wide { grid-column: 1 / -1; }
.cabinet-project-status-v1118 {
    margin-top: 14px;
    padding: 14px;
    border-radius: 16px;
    background: #eef8f2;
    border: 1px solid rgba(32, 154, 92, .18);
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
    flex-wrap: wrap;
}
.cabinet-project-list-v1118 { display: grid; gap: 12px; }
.cabinet-project-card-v1118 {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
    padding: 16px;
    border: 1px solid rgba(25,79,146,.12);
    border-radius: 18px;
    background: #fff;
    text-decoration: none;
    color: inherit;
    box-shadow: 0 10px 26px rgba(15, 45, 82, .06);
}
.cabinet-project-card-v1118 strong { display: block; margin-bottom: 6px; color: #17253a; }
.cabinet-project-card-v1118 small { color: #64748b; }
.cabinet-project-summary-v1118 {
    display: grid;
    grid-template-columns: repeat(6, minmax(0, 1fr));
    gap: 12px;
    margin-bottom: 18px;
}
.cabinet-project-summary-v1118 > div {
    padding: 14px;
    border-radius: 18px;
    background: #fff;
    border: 1px solid rgba(25,79,146,.12);
    box-shadow: 0 10px 24px rgba(15,45,82,.05);
}
.cabinet-project-summary-v1118 span { display: block; color: #64748b; font-size: .86rem; margin-bottom: 6px; }
.cabinet-project-summary-v1118 strong { color: #194F92; }
.cabinet-order-flow-v1118 {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 16px;
    margin: 18px 0;
}
.success-note-v1118 {
    margin: 0;
    padding: 12px 14px;
    border-radius: 14px;
    background: #ecfdf3;
    color: #087443;
    border: 1px solid rgba(8,116,67,.16);
}
@media (max-width: 860px) {
    .cabinet-project-grid-v1118,
    .cabinet-order-flow-v1118 { grid-template-columns: 1fr; }
    .cabinet-project-summary-v1118 { grid-template-columns: repeat(2, minmax(0, 1fr)); }
    .cabinet-project-card-v1118 { align-items: flex-start; flex-direction: column; }
}
@media (max-width: 520px) {
    .cabinet-project-panel-v1118 { padding: 16px; border-radius: 20px; }
    .cabinet-project-summary-v1118 { grid-template-columns: 1fr; }
}

/* v1.1.19 - Cabinet project supplier workflow */
.cabinet-project-show-v1119 { overflow-x: clip; }
.project-timeline-v1119 {
    display: grid;
    grid-template-columns: repeat(6, minmax(0, 1fr));
    gap: .6rem;
    margin: 1rem 0 1.25rem;
}
.timeline-step-v1119 {
    position: relative;
    border: 1px solid rgba(148, 163, 184, .35);
    border-radius: 18px;
    padding: .8rem .75rem;
    background: linear-gradient(180deg, #fff, #fbfaf7);
    color: #64748b;
    min-height: 72px;
}
.timeline-step-v1119 span {
    display: inline-flex;
    width: 14px;
    height: 14px;
    border-radius: 999px;
    border: 2px solid #cbd5e1;
    margin-left: .35rem;
    vertical-align: middle;
}
.timeline-step-v1119 strong {
    display: block;
    font-size: .86rem;
    line-height: 1.8;
    margin-top: .25rem;
}
.timeline-step-v1119.is-done {
    border-color: rgba(34, 197, 94, .35);
    background: linear-gradient(180deg, #f0fdf4, #fff);
    color: #166534;
}
.timeline-step-v1119.is-done span {
    background: #22c55e;
    border-color: #16a34a;
    box-shadow: 0 0 0 4px rgba(34, 197, 94, .12);
}
.workflow-heading-v1119 {
    margin: 1.5rem 0 1rem;
    padding: 1.2rem;
    border-radius: 22px;
    background: linear-gradient(135deg, #2f2118, #6f4a2c);
    color: #fff;
}
.workflow-heading-v1119 h2 { margin: 0 0 .35rem; }
.workflow-heading-v1119 p { margin: 0; opacity: .86; }
.cabinet-order-flow-v1119 {
    align-items: start;
}
.supplier-panel-v1119 h2 { margin-bottom: .5rem; }
.supplier-picks-v1119 {
    display: grid;
    gap: .65rem;
    max-height: 330px;
    overflow: auto;
    padding: .15rem .1rem .45rem;
    scrollbar-width: thin;
}
.supplier-pick-v1119 {
    display: grid;
    grid-template-columns: auto 1fr;
    gap: .65rem;
    align-items: start;
    border: 1px solid rgba(148, 163, 184, .35);
    border-radius: 16px;
    background: #fff;
    padding: .75rem;
    cursor: pointer;
    transition: border-color .18s ease, box-shadow .18s ease, transform .18s ease;
}
.supplier-pick-v1119:hover {
    border-color: rgba(120, 77, 38, .42);
    box-shadow: 0 14px 34px rgba(15, 23, 42, .08);
    transform: translateY(-1px);
}
.supplier-pick-v1119 input { margin-top: .35rem; accent-color: #8a5a2e; }
.supplier-pick-v1119 span { display: grid; gap: .18rem; }
.supplier-pick-v1119 strong { color: #1f2937; font-size: .93rem; line-height: 1.8; }
.supplier-pick-v1119 small { color: #64748b; line-height: 1.8; }
.supplier-pick-v1119 b { color: #7c3f16; font-size: .88rem; }
.supplier-pick-v1119 em {
    justify-self: start;
    font-style: normal;
    color: #166534;
    background: #dcfce7;
    border-radius: 999px;
    padding: .12rem .55rem;
    font-size: .72rem;
}
.supplier-pick-v1119--manual { background: #fffbeb; border-color: rgba(217, 119, 6, .22); }
.supplier-empty-v1119 {
    background: #f8fafc;
    border: 1px dashed rgba(148, 163, 184, .6);
    border-radius: 16px;
    padding: .8rem;
}
.project-status-form-v1119, .inline-status-form-v1119 {
    display: flex;
    gap: .5rem;
    align-items: center;
    flex-wrap: wrap;
    margin-top: .8rem;
}
.project-status-form-v1119 select, .inline-status-form-v1119 select {
    min-width: 180px;
}
.project-status-form-v1119 button, .inline-status-form-v1119 button {
    border: 0;
    border-radius: 999px;
    padding: .65rem 1rem;
    background: #2f2118;
    color: #fff;
    cursor: pointer;
}
.order-status-grid-v1119 {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 1rem;
    margin-top: 1rem;
}
.order-card-v1119 {
    border: 1px solid rgba(148, 163, 184, .28);
    border-radius: 18px;
    background: #fff;
    padding: .9rem;
    margin-top: .75rem;
    box-shadow: 0 12px 28px rgba(15, 23, 42, .05);
}
.order-card-v1119 strong, .order-card-v1119 small, .order-card-v1119 b { display: block; }
.order-card-v1119 small { color: #64748b; margin-top: .25rem; line-height: 1.8; }
.order-card-v1119 p { margin: .5rem 0; color: #475569; line-height: 1.9; }
.order-card-v1119 b { color: #7c3f16; }
@media (max-width: 900px) {
    .project-timeline-v1119 { grid-template-columns: repeat(3, minmax(0, 1fr)); }
    .order-status-grid-v1119 { grid-template-columns: 1fr; }
}
@media (max-width: 640px) {
    .project-timeline-v1119 {
        display: flex;
        overflow-x: auto;
        padding-bottom: .35rem;
        overscroll-behavior-inline: contain;
    }
    .timeline-step-v1119 {
        min-width: 142px;
    }
    .supplier-picks-v1119 { max-height: 280px; }
    .supplier-pick-v1119 { padding: .65rem; }
    .project-status-form-v1119, .inline-status-form-v1119 { align-items: stretch; }
    .project-status-form-v1119 select, .project-status-form-v1119 button,
    .inline-status-form-v1119 select, .inline-status-form-v1119 button { width: 100%; min-width: 0; }
}

/* v1.1.21 cabinet project role-flow cleanup */
.cabinet-muted-pill-v1121 {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: .35rem;
    padding: .65rem .9rem;
    border-radius: 999px;
    background: #f3f4f6;
    color: #374151;
    font-weight: 800;
    white-space: nowrap;
}
.cabinet-project-gate-v1121 {
    border: 1px dashed rgba(120, 73, 34, .28);
    background: linear-gradient(135deg, rgba(255, 250, 240, .9), rgba(255,255,255,.96));
}
.status-parts_ready,
.status-draft_meter { background: #fff7ed; color: #9a3412; }
.status-parts_approved { background: #ecfdf5; color: #047857; }
.status-selecting_materials,
.status-selecting_hardware,
.status-selecting_service,
.status-selecting_delivery { background: #eff6ff; color: #1d4ed8; }
.status-materials_selected,
.status-hardware_selected,
.status-service_selected,
.status-delivery_selected { background: #f0fdf4; color: #15803d; }
.status-in_preparation,
.status-sent_to_service,
.status-service_in_progress,
.status-ready_for_delivery,
.status-delivered { background: #f5f3ff; color: #6d28d9; }
.status-needs_admin_review { background: #fef2f2; color: #b91c1c; }

/* v1.1.22 business capability matrix */
.capability-select-v1122 {
    margin-top: 16px;
    padding: 16px;
    border: 1px solid rgba(120, 90, 55, .16);
    border-radius: 18px;
    background: rgba(255,255,255,.72);
}
.capability-select-v1122 > strong {
    display: block;
    font-weight: 900;
    margin-bottom: 6px;
}
.capability-select-v1122 p,
.capability-select-v1122 small {
    color: var(--muted, #777);
    margin: 0 0 10px;
    line-height: 1.8;
}
.capability-grid-v1122 {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(170px, 1fr));
    gap: 10px;
    margin: 12px 0;
}
.capability-check-v1122 {
    display: flex !important;
    align-items: center;
    gap: 9px;
    padding: 10px 12px;
    border: 1px solid rgba(120, 90, 55, .15);
    border-radius: 14px;
    background: #fff;
    cursor: pointer;
    font-weight: 800;
}
.capability-check-v1122 input {
    width: auto !important;
    margin: 0;
    accent-color: #8a5a2b;
}
.capability-badges-v1122,
.business-public-capabilities-v1122 {
    display: flex;
    flex-wrap: wrap;
    gap: 7px;
    margin-top: 10px;
}
.capability-badges-v1122 span,
.capability-inline-v1122,
.business-public-capabilities-v1122 span {
    display: inline-flex;
    align-items: center;
    gap: 5px;
    padding: 6px 10px;
    border-radius: 999px;
    background: rgba(138, 90, 43, .1);
    color: #6f421c;
    font-size: .82rem;
    font-weight: 800;
}
.capability-inline-v1122 {
    margin-top: 4px;
    width: fit-content;
}
@media (max-width: 640px) {
    .capability-grid-v1122 {
        grid-template-columns: 1fr;
    }
}

/* v1.1.23 - Cabinet project market wood selection */
.wood-market-panel-v1123 {
    border: 1px solid rgba(122, 88, 54, 0.16);
    background: linear-gradient(135deg, rgba(255,255,255,0.98), rgba(248,244,238,0.94));
}
.wood-market-head-v1123 {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 1rem;
    margin-bottom: 1rem;
}
.wood-market-head-v1123 h2 { margin: 0 0 .35rem; }
.wood-market-head-v1123 p { margin: 0; color: var(--muted, #6b7280); }
.wood-market-tabs-v1123 {
    border: 1px solid rgba(0,0,0,.08);
    border-radius: 18px;
    padding: .85rem;
    margin-top: .85rem;
    background: rgba(255,255,255,.74);
}
.wood-market-tabs-v1123 summary {
    cursor: pointer;
    font-weight: 800;
    color: var(--text, #1f2937);
}
.wood-source-grid-v1123 {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(235px, 1fr));
    gap: .85rem;
    margin-top: .85rem;
}
.wood-source-card-v1123 {
    display: flex;
    flex-direction: column;
    gap: .55rem;
    min-width: 0;
    border: 1px solid rgba(122, 88, 54, .14);
    border-radius: 18px;
    padding: .85rem;
    background: #fff;
    box-shadow: 0 12px 26px rgba(39, 29, 17, .06);
}
.wood-source-card-v1123__top {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    gap: .75rem;
}
.wood-source-card-v1123 strong { line-height: 1.7; }
.wood-source-card-v1123 b { white-space: nowrap; color: var(--brand, #7a5836); }
.wood-source-card-v1123 small, .wood-source-card-v1123 p { color: var(--muted, #6b7280); margin: 0; }
.wood-source-card-v1123 textarea {
    min-height: 64px;
    resize: vertical;
}
.wood-source-card-v1123 button {
    border: 0;
    border-radius: 14px;
    padding: .72rem 1rem;
    font-weight: 800;
    cursor: pointer;
    color: #fff;
    background: var(--brand, #7a5836);
}
.wood-match-list-v1123 {
    margin: .2rem 0 0;
    padding: 0 1rem 0 0;
    color: #374151;
    font-size: .9rem;
}
.wood-match-list-v1123 li { margin: .18rem 0; }
.selected-sources-v1123 {
    margin: .9rem 0 1rem;
    padding: .8rem;
    border-radius: 16px;
    background: rgba(122, 88, 54, .055);
}
.selected-sources-v1123 > strong { display:block; margin-bottom: .65rem; }
@media (max-width: 640px) {
    .wood-market-head-v1123 { flex-direction: column; }
    .wood-source-grid-v1123 { grid-template-columns: 1fr; }
    .wood-source-card-v1123__top { flex-direction: column; }
}

/* v1.1.24 cabinet project order flow */
.order-hint-v1124 {
    border: 1px solid rgba(122, 74, 31, .16);
    background: linear-gradient(135deg, rgba(255, 247, 237, .92), rgba(255, 255, 255, .96));
    border-radius: 16px;
    padding: 12px 14px;
    margin: 12px 0;
    color: #6f4421;
    line-height: 1.9;
}
.check-row-v1124 {
    display: flex !important;
    align-items: center;
    gap: 10px;
    border: 1px dashed rgba(122, 74, 31, .24);
    background: rgba(255, 252, 247, .86);
    border-radius: 14px;
    padding: 10px 12px;
}
.check-row-v1124 input {
    width: auto !important;
    min-width: auto !important;
}
@media (max-width: 720px) {
    .check-row-v1124 { align-items: flex-start; }
}

/* v1.1.25 - Cabinet project full audit and UX stabilization */
.cabinet-project-show-v1125 {
    scroll-behavior: smooth;
}
.cabinet-project-show-v1125 .project-section-v1125 {
    scroll-margin-top: 92px;
}
.cabinet-project-nav-v1125 {
    position: sticky;
    top: 70px;
    z-index: 12;
    display: flex;
    align-items: center;
    gap: 8px;
    flex-wrap: wrap;
    margin: 14px 0 18px;
    padding: 10px;
    border: 1px solid rgba(122, 88, 54, .14);
    border-radius: 18px;
    background: rgba(255,255,255,.92);
    box-shadow: 0 14px 34px rgba(24, 39, 61, .08);
    backdrop-filter: blur(14px);
}
.cabinet-project-nav-v1125 a,
.cabinet-project-nav-v1125 span {
    display: inline-flex;
    align-items: center;
    min-height: 36px;
    padding: 7px 12px;
    border-radius: 999px;
    font-size: .86rem;
    font-weight: 850;
    text-decoration: none;
}
.cabinet-project-nav-v1125 a {
    color: #70431d;
    background: rgba(122, 88, 54, .08);
}
.cabinet-project-nav-v1125 a:hover {
    background: rgba(122, 88, 54, .14);
}
.cabinet-project-nav-v1125 span {
    margin-inline-start: auto;
    color: #174269;
    background: linear-gradient(135deg, rgba(219, 234, 254, .86), rgba(255, 255, 255, .94));
    border: 1px solid rgba(59, 130, 246, .14);
}
.workflow-heading-v1125 {
    padding: 14px;
    border-radius: 22px;
    border: 1px solid rgba(122, 88, 54, .12);
    background: linear-gradient(135deg, rgba(255,255,255,.95), rgba(250,246,240,.86));
}
.project-step-cards-v1125 {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 10px;
    margin-top: 12px;
}
.project-step-cards-v1125 > div {
    min-width: 0;
    padding: 12px;
    border-radius: 16px;
    background: #fff;
    border: 1px solid rgba(100, 116, 139, .12);
    box-shadow: 0 8px 20px rgba(15, 23, 42, .045);
}
.project-step-cards-v1125 span,
.project-step-cards-v1125 small {
    display: block;
    color: #64748b;
    line-height: 1.8;
}
.project-step-cards-v1125 strong {
    display: block;
    color: #334155;
    font-size: 1.25rem;
}
.project-step-cards-v1125 > div.is-done {
    border-color: rgba(34, 197, 94, .24);
    background: linear-gradient(135deg, rgba(240, 253, 244, .94), #fff);
}
.project-step-cards-v1125 > div.is-done strong {
    color: #15803d;
}
.cabinet-project-show-v1125 .cabinet-table-wrap-v119 {
    max-width: 100%;
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
}
.cabinet-project-show-v1125 .order-card-v1119 {
    min-width: 0;
}
@media (max-width: 900px) {
    .cabinet-project-nav-v1125 {
        position: relative;
        top: auto;
        overflow-x: auto;
        flex-wrap: nowrap;
        padding-bottom: 11px;
    }
    .cabinet-project-nav-v1125 a,
    .cabinet-project-nav-v1125 span {
        flex: 0 0 auto;
        white-space: nowrap;
    }
    .cabinet-project-nav-v1125 span {
        margin-inline-start: 0;
    }
    .project-step-cards-v1125 {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
}
@media (max-width: 560px) {
    .project-step-cards-v1125 {
        grid-template-columns: 1fr;
    }
    .cabinet-project-summary-v1118 {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
}

/* v1.1.26 - project request workflow */
.project-requests-page-v1126,
.project-request-show-v1126 { max-width: 1180px; margin-inline: auto; }
.project-request-list-v1126 { display: grid; gap: 12px; }
.project-request-card-v1126 {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 14px;
    padding: 14px 16px;
    border: 1px solid rgba(25,79,146,.14);
    border-radius: 18px;
    background: #fff;
    box-shadow: 0 12px 28px rgba(15, 39, 71, .06);
    color: inherit;
    text-decoration: none;
}
.project-request-card-v1126:hover { border-color: rgba(25,79,146,.32); transform: translateY(-1px); }
.project-request-card-v1126 strong { display:block; color:#14385f; margin-bottom: 5px; }
.project-request-card-v1126 span, .project-request-card-v1126 small { display:block; color:#6b7280; font-size:.88rem; }
.project-request-card-v1126 b { display:block; color:#176447; white-space:nowrap; margin-bottom:4px; }
.project-request-card-v1126--static:hover { transform:none; }
.project-request-detail-grid-v1126 { display:grid; grid-template-columns: minmax(0,1fr) minmax(320px,.75fr); gap:16px; align-items:start; }
.project-request-inline-v1126 { margin-top:12px; padding-top:10px; border-top:1px dashed rgba(15,39,71,.14); }
.project-request-send-v1126 { display:grid; gap:8px; }
.project-request-send-v1126 textarea { width:100%; min-height: 56px; resize:vertical; }
.project-request-send-v1126 button,
.project-request-inline-v1126 button {
    border:0;
    border-radius:12px;
    padding:10px 14px;
    background:#194F92;
    color:#fff;
    font-weight:800;
    cursor:pointer;
}
.project-request-chip-v1126 {
    display:grid;
    gap:5px;
    padding:10px 12px;
    border-radius:14px;
    background:rgba(25,79,146,.06);
    border:1px solid rgba(25,79,146,.12);
    margin-bottom:8px;
}
.project-request-chip-v1126 strong { color:#14385f; }
.project-request-chip-v1126 span { color:#194F92; font-weight:800; }
.project-request-chip-v1126 b { color:#176447; }
.project-request-chip-v1126 small { color:#596579; line-height:1.8; }
.project-requests-summary-v1126 { margin-top:16px; }
.json-preview-v1126 { direction:ltr; text-align:left; white-space:pre-wrap; overflow:auto; background:#0f172a; color:#e5e7eb; border-radius:16px; padding:16px; }
.project-requests-dashboard-v1126 { margin-top: 16px; }
@media (max-width: 760px) {
    .project-request-card-v1126 { align-items:flex-start; flex-direction:column; }
    .project-request-detail-grid-v1126 { grid-template-columns: 1fr; }
}

/* v1.1.27 live notification sound controls */
.notification-sound-enable {
    position: fixed;
    right: max(16px, env(safe-area-inset-right));
    bottom: calc(88px + env(safe-area-inset-bottom));
    z-index: 1200;
    display: inline-flex;
    align-items: center;
    gap: 8px;
    border: 0;
    border-radius: 999px;
    padding: 10px 14px;
    background: #194F92;
    color: #fff;
    font: inherit;
    font-size: 13px;
    box-shadow: 0 14px 36px rgba(25, 79, 146, .28);
    cursor: pointer;
}
.notification-sound-enable:hover { transform: translateY(-1px); }
.notification-live-toast {
    position: fixed;
    left: max(16px, env(safe-area-inset-left));
    bottom: calc(92px + env(safe-area-inset-bottom));
    z-index: 1201;
    width: min(360px, calc(100vw - 32px));
    display: grid;
    gap: 5px;
    padding: 14px 16px;
    border-radius: 18px;
    background: rgba(255,255,255,.96);
    color: #172033;
    border: 1px solid rgba(25, 79, 146, .16);
    box-shadow: 0 20px 46px rgba(15, 23, 42, .18);
    text-decoration: none;
    opacity: 0;
    transform: translateY(10px);
    transition: opacity .25s ease, transform .25s ease;
    backdrop-filter: blur(10px);
}
.notification-live-toast.is-visible {
    opacity: 1;
    transform: translateY(0);
}
.notification-live-toast strong {
    font-size: 14px;
    color: #194F92;
}
.notification-live-toast span {
    font-size: 12.5px;
    line-height: 1.8;
    color: #4b5563;
}
@media (max-width: 720px) {
    .notification-sound-enable {
        right: 12px;
        left: 12px;
        justify-content: center;
        bottom: calc(74px + env(safe-area-inset-bottom));
    }
    .notification-live-toast {
        left: 12px;
        right: 12px;
        width: auto;
        bottom: calc(78px + env(safe-area-inset-bottom));
    }
}

/* v1.1.28 - Quote approval workflow */
.quote-decision-actions-v1128 {
    display: flex;
    flex-wrap: wrap;
    gap: .45rem;
    margin-top: .65rem;
}
.quote-decision-actions-v1128 form { margin: 0; }
.quote-decision-btn-v1128 {
    border: 0;
    border-radius: 999px;
    padding: .48rem .78rem;
    font-weight: 800;
    cursor: pointer;
    font-size: .82rem;
}
.quote-decision-btn-v1128--approve { background: #dcfce7; color: #166534; }
.quote-decision-btn-v1128--reject { background: #fee2e2; color: #991b1b; }
.quote-decision-btn-v1128--revision { background: #fef3c7; color: #92400e; margin-top: .45rem; }
.quote-revision-v1128 {
    width: 100%;
    background: rgba(245, 158, 11, .08);
    border: 1px solid rgba(245, 158, 11, .18);
    border-radius: 14px;
    padding: .55rem .7rem;
}
.quote-revision-v1128 summary {
    cursor: pointer;
    font-weight: 800;
    color: #92400e;
}
.quote-revision-v1128 textarea {
    width: 100%;
    min-height: 72px;
    resize: vertical;
    border: 1px solid var(--border-color, #e5e7eb);
    border-radius: 12px;
    padding: .65rem;
    margin-top: .5rem;
}
.quote-decision-note-v1128 {
    display: block;
    margin-top: .35rem;
    color: #7c2d12;
}
.quote-closed-box-v1128 {
    border: 1px solid rgba(15, 23, 42, .08);
    background: #f8fafc;
    border-radius: 16px;
    padding: 1rem;
}
.quote-closed-box-v1128 strong { display: block; margin-bottom: .35rem; }
@media (max-width: 640px) {
    .quote-decision-actions-v1128 { gap: .35rem; }
    .quote-decision-btn-v1128 { padding: .42rem .62rem; font-size: .76rem; }
}

/* v1.1.29 - Cabinet project deposit cards */
.deposit-box-v1129 {
    margin-top: .65rem;
    padding: .75rem;
    border: 1px dashed rgba(19, 122, 74, .35);
    border-radius: 16px;
    background: rgba(19, 122, 74, .05);
}
.deposit-box-v1129 summary {
    cursor: pointer;
    font-weight: 800;
    color: #137a4a;
}
.deposit-box-v1129 form {
    display: grid;
    gap: .65rem;
    margin-top: .65rem;
}
.deposit-box-v1129 input,
.deposit-box-v1129 textarea {
    width: 100%;
    border: 1px solid rgba(15, 23, 42, .12);
    border-radius: 12px;
    padding: .65rem .75rem;
    background: #fff;
}
.deposit-box-v1129 button,
.payment-card-v1129 button {
    border: 0;
    border-radius: 12px;
    padding: .65rem .95rem;
    background: #137a4a;
    color: #fff;
    font-weight: 800;
    cursor: pointer;
}
.deposit-chip-v1129 {
    display: inline-flex;
    align-items: center;
    gap: .45rem;
    margin-top: .55rem;
    padding: .45rem .7rem;
    border-radius: 999px;
    background: rgba(19, 122, 74, .1);
    color: #137a4a;
    font-size: .88rem;
}
.project-payments-v1129 {
    margin-top: 1rem;
}
.project-payments-head-v1129 {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 1rem;
    flex-wrap: wrap;
}
.wallet-mini-v1129 {
    min-width: 220px;
    border: 1px solid rgba(15, 23, 42, .1);
    border-radius: 18px;
    padding: .85rem;
    background: linear-gradient(135deg, rgba(19,122,74,.08), rgba(245,158,11,.08));
    display: grid;
    gap: .25rem;
}
.wallet-mini-v1129 strong { font-size: 1.05rem; }
.wallet-mini-v1129 a { color: #137a4a; font-weight: 800; text-decoration: none; }
.payment-list-v1129 {
    display: grid;
    gap: .75rem;
    margin-top: .9rem;
}
.payment-card-v1129 {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
    border: 1px solid rgba(15, 23, 42, .1);
    border-radius: 18px;
    padding: .9rem;
    background: #fff;
}
.payment-card-v1129 div:first-child { display: grid; gap: .25rem; }
.payment-card-v1129 span,
.payment-card-v1129 small,
.payment-card-v1129 p { color: #64748b; margin: 0; }
.payment-card-v1129 button { background: #b42318; }
@media (max-width: 720px) {
    .project-payments-head-v1129,
    .payment-card-v1129 { display: grid; }
    .wallet-mini-v1129 { min-width: 0; }
}

/* v1.1.30 - project execution status */
.execution-box-v1130 {
  border: 1px solid rgba(146, 104, 54, .22);
  background: linear-gradient(135deg, rgba(255, 248, 238, .9), rgba(255, 255, 255, .96));
  border-radius: 18px;
  padding: 16px;
  display: grid;
  gap: 10px;
}
.execution-box-v1130 strong { color: #6b3f19; }
.execution-box-v1130 p { margin: 0; color: #66513e; line-height: 1.9; }
.execution-form-v1130 { margin-top: 6px; }
.execution-form-v1130 select,
.execution-form-v1130 textarea {
  width: 100%;
}
.execution-progress-v1130 {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-top: 10px;
}
.execution-progress-v1130 span {
  border-radius: 999px;
  background: #f3eadf;
  color: #6b4b2e;
  padding: 6px 10px;
  font-size: .86rem;
}
.project-request-card-v1126 .execution-note-v1130,
.execution-note-v1130 {
  display: block;
  color: #5f4630;
  background: #fff7ea;
  border-radius: 12px;
  padding: 7px 10px;
  margin-top: 6px;
}

/* v1.1.31 - completion confirmation, disputes, and settlement */
.completion-actions-v1131,
.completion-state-v1131 {
    margin-top: .75rem;
    padding: .85rem;
    border-radius: 18px;
    border: 1px solid rgba(15, 23, 42, .08);
    background: #fffdf7;
    display: grid;
    gap: .65rem;
}
.completion-actions-v1131 form,
.completion-actions-v1131 details form {
    display: grid;
    gap: .55rem;
}
.completion-actions-v1131 textarea,
.admin-dispute-action-v1131 textarea {
    width: 100%;
    border: 1px solid rgba(15,23,42,.14);
    border-radius: 12px;
    padding: .65rem;
    resize: vertical;
}
.completion-btn-v1131,
.admin-dispute-action-v1131 button {
    border: 0;
    border-radius: 999px;
    padding: .65rem 1rem;
    font-weight: 800;
    cursor: pointer;
}
.completion-btn-v1131--confirm,
.admin-dispute-action-v1131 form[action$="/release"] button {
    background: #0f766e;
    color: #fff;
}
.completion-btn-v1131--dispute,
.admin-dispute-action-v1131 form[action$="/refund"] button {
    background: #991b1b;
    color: #fff;
}
.completion-state-v1131--settled {
    background: #ecfdf5;
    border-color: rgba(16, 185, 129, .25);
}
.completion-state-v1131--disputed {
    background: #fff7ed;
    border-color: rgba(249, 115, 22, .28);
}
.completion-state-v1131--refunded {
    background: #f8fafc;
    border-color: rgba(100, 116, 139, .24);
}
.cabinet-disputes-v1131 .admin-dispute-action-v1131 {
    margin: .35rem 0;
}
.cabinet-disputes-v1131 .admin-dispute-action-v1131 summary {
    cursor: pointer;
    font-weight: 800;
}
.cabinet-disputes-v1131 .admin-dispute-action-v1131 form {
    margin-top: .5rem;
    display: grid;
    gap: .5rem;
}

/* v1.1.32 - cabinet invoice, finance report, reviews */
.cabinet-invoice-page-v1132,.cabinet-finance-v1132{max-width:1180px;margin:0 auto;padding:24px 16px 90px}.invoice-hero-v1132{display:flex;align-items:center;justify-content:space-between;gap:16px;padding:22px;border-radius:24px;background:linear-gradient(135deg,#fff7ed,#f5f0e8);border:1px solid rgba(120,77,42,.12);margin-bottom:16px}.invoice-hero-v1132 h1{margin:6px 0 4px}.invoice-actions-v1132{display:flex;gap:8px;flex-wrap:wrap}.invoice-summary-grid-v1132{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:12px;margin:16px 0}.invoice-summary-grid-v1132 article{padding:16px;border:1px solid rgba(120,77,42,.12);border-radius:18px;background:#fff}.invoice-summary-grid-v1132 span{display:block;color:#7a6a5a;font-size:.9rem}.invoice-summary-grid-v1132 strong{display:block;margin-top:6px;font-size:1.05rem}.invoice-summary-grid-v1132--compact{grid-template-columns:repeat(3,minmax(0,1fr));margin:10px 0}.invoice-stamp-v1132,.invoice-issued-note-v1132{display:flex;gap:14px;flex-wrap:wrap;align-items:center;padding:12px 14px;border-radius:16px;background:#ecfdf5;border:1px solid #bbf7d0;color:#166534;margin:12px 0}.project-invoice-head-v1132{display:flex;align-items:center;justify-content:space-between;gap:14px}.project-review-grid-v1132{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}.project-review-card-v1132{padding:14px;border:1px solid rgba(120,77,42,.12);border-radius:18px;background:#fff}.project-review-card-v1132 strong,.project-review-card-v1132 span,.project-review-card-v1132 small{display:block}.project-review-card-v1132 form{display:grid;gap:8px;margin-top:10px}.project-review-card-v1132 select,.project-review-card-v1132 textarea{width:100%;border:1px solid #e7dccf;border-radius:12px;padding:9px}.review-list-v1132{display:grid;gap:8px;margin-top:14px}.review-list-v1132>div{padding:12px;border-radius:14px;background:#faf7f2;border:1px solid #eadfce}.review-list-v1132 p{margin:6px 0 0;color:#6b5a48}.finance-grid-v1132{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px;margin-bottom:14px}@media(max-width:760px){.invoice-hero-v1132,.project-invoice-head-v1132{display:block}.invoice-actions-v1132{margin-top:12px}.invoice-summary-grid-v1132,.invoice-summary-grid-v1132--compact,.project-review-grid-v1132,.finance-grid-v1132{grid-template-columns:1fr}.cabinet-invoice-page-v1132,.cabinet-finance-v1132{padding-inline:12px}}@media print{header,.site-header,.mobile-bottom-nav,.invoice-actions-v1132,.cabinet-project-nav-v1125,.btn,button{display:none!important}.cabinet-invoice-page-v1132{padding:0}.panel-box,.invoice-hero-v1132{box-shadow:none!important;border-color:#ddd!important}}

/* v1.1.33 - Cabinet project document archive and print output */
.project-documents-page-v1133,
.print-document-page-v1133 {
    display: grid;
    gap: 14px;
}

.documents-hero-v1133,
.print-toolbar-v1133,
.project-documents-head-v1133,
.document-actions-v1133,
.project-invoice-actions-v1133 {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 10px;
    flex-wrap: wrap;
}

.documents-hero-v1133 {
    padding: 18px;
    border: 1px solid rgba(25,79,146,.10);
    border-radius: 24px;
    background: linear-gradient(135deg, rgba(255,255,255,.96), rgba(232,240,252,.82));
    box-shadow: 0 16px 34px rgba(20,45,76,.08);
}

.document-card-grid-v1133 {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
    gap: 12px;
}

.document-card-v1133,
.mini-document-list-v1133 a {
    display: grid;
    gap: 8px;
    padding: 14px;
    border: 1px solid rgba(25,79,146,.12);
    border-radius: 18px;
    background: rgba(255,255,255,.86);
    box-shadow: 0 10px 24px rgba(20,45,76,.06);
}

.document-card-v1133 span,
.document-card-v1133 small,
.mini-document-list-v1133 span {
    color: var(--ink-500);
    font-size: 12px;
}

.document-card-actions-v1133,
.mini-document-list-v1133 {
    display: flex;
    gap: 8px;
    flex-wrap: wrap;
}

.mini-document-list-v1133 a {
    min-width: 210px;
    color: inherit;
}

.print-paper-v1133 {
    width: min(100%, 860px);
    margin: 0 auto;
    padding: 28px;
    border: 1px solid rgba(25,79,146,.12);
    border-radius: 22px;
    background: #fff;
    box-shadow: 0 18px 46px rgba(20,45,76,.10);
}

.print-header-v1133,
.print-footer-v1133 {
    display: flex;
    justify-content: space-between;
    gap: 16px;
    padding-bottom: 16px;
    border-bottom: 1px solid rgba(20,45,76,.12);
}

.print-brand-v1133 {
    display: block;
    font-size: 24px;
    color: var(--blue);
}

.print-title-v1133 {
    margin: 20px 0;
    padding: 16px;
    border-radius: 18px;
    background: rgba(25,79,146,.06);
}

.print-info-grid-v1133,
.print-total-grid-v1133 {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(170px, 1fr));
    gap: 10px;
    margin: 14px 0 20px;
}

.print-info-grid-v1133 article,
.print-total-grid-v1133 article {
    display: grid;
    gap: 6px;
    padding: 12px;
    border: 1px solid rgba(25,79,146,.10);
    border-radius: 16px;
    background: rgba(248,250,252,.88);
}

.print-info-grid-v1133 span,
.print-total-grid-v1133 span {
    color: var(--ink-500);
    font-size: 12px;
}

.print-table-v1133 {
    width: 100%;
    border-collapse: collapse;
    margin: 10px 0 22px;
    overflow: hidden;
    border-radius: 14px;
}

.print-table-v1133 th,
.print-table-v1133 td {
    padding: 10px;
    border: 1px solid rgba(20,45,76,.12);
    text-align: right;
    font-size: 13px;
}

.print-table-v1133 th {
    background: rgba(25,79,146,.08);
}

.print-footer-v1133 {
    margin-top: 32px;
    padding-top: 22px;
    border-top: 1px solid rgba(20,45,76,.12);
    border-bottom: 0;
}

.print-footer-v1133 div {
    min-width: 180px;
    padding-top: 30px;
    border-top: 1px dashed rgba(20,45,76,.36);
    color: var(--ink-500);
    text-align: center;
}

@media print {
    body {
        background: #fff !important;
    }
    .app-header,
    .bottom-nav,
    .toast,
    .no-print-v1133,
    .notification-sound-enable,
    .live-notification-toast {
        display: none !important;
    }
    .app-shell,
    .app-main {
        width: 100% !important;
        max-width: none !important;
        padding: 0 !important;
        margin: 0 !important;
    }
    .print-paper-v1133 {
        width: 100% !important;
        padding: 0 !important;
        border: 0 !important;
        border-radius: 0 !important;
        box-shadow: none !important;
    }
    .print-table-v1133 th,
    .print-table-v1133 td {
        font-size: 11px;
    }
}

/* v1.1.34 - public business reputation */
.business-rating-chip-v1134{display:inline-flex;align-items:center;gap:.35rem;border-radius:999px;background:#fff8db;color:#7a4b00;border:1px solid #f5d36a;padding:.22rem .55rem;font-size:.82rem;font-weight:800;margin:.2rem 0;line-height:1.7}
.business-rating-chip-v1134 i{color:#f0a500}.business-order-proof-v1134{display:block;color:#667085;font-weight:700;margin-top:.12rem}.filter-check-v1134{display:inline-flex;align-items:center;gap:.35rem;background:#fff;border:1px solid #e7e0d7;border-radius:12px;padding:.65rem .8rem;white-space:nowrap;color:#5f4b35;font-weight:700}.filter-check-v1134 input{accent-color:#9a6a2f}.reputation-badge-v1134{display:inline-flex;align-items:center;gap:.45rem;border-radius:999px;padding:.45rem .75rem;border:1px solid #e6dccf;background:#fff;color:#4d3b2a;font-weight:900;box-shadow:0 8px 24px rgba(66,44,18,.07)}.reputation-badge-v1134 i{color:#b9822a}.reputation-badge-v1134--gold{background:linear-gradient(135deg,#fff6c7,#fff);border-color:#f2c14f;color:#6f4a00}.reputation-badge-v1134--silver{background:linear-gradient(135deg,#eef2f7,#fff);border-color:#c9d1dc;color:#485465}.reputation-badge-v1134--bronze{background:linear-gradient(135deg,#fff0df,#fff);border-color:#d79a62;color:#74451e}.reputation-badge-v1134--verified{background:linear-gradient(135deg,#e9f8ee,#fff);border-color:#b8e6c5;color:#22613a}.business-public-rating-v1134{display:flex;align-items:center;gap:.75rem;flex-wrap:wrap;margin:.65rem 0}.business-public-rating-v1134 span{display:inline-flex;align-items:center;gap:.35rem;color:#6f4a00;font-weight:900;background:#fff8db;border:1px solid #f4d56b;border-radius:999px;padding:.42rem .7rem}.business-public-rating-v1134 small{color:#725b43;font-weight:800}.business-reviews-panel-v1134{scroll-margin-top:90px}.business-review-list-v1134{display:grid;gap:.75rem}.business-review-list-v1134--compact{grid-template-columns:repeat(auto-fit,minmax(220px,1fr));margin-top:1rem}.business-review-card-v1134{background:#fff;border:1px solid #eee4d8;border-radius:18px;padding:1rem;box-shadow:0 10px 24px rgba(74,54,32,.06)}.business-review-card-v1134>div{display:flex;align-items:center;justify-content:space-between;gap:.75rem;flex-wrap:wrap}.business-review-card-v1134 strong{color:#6f4a00}.business-review-card-v1134 strong i{color:#f0a500}.business-review-card-v1134 span{color:#7b6a58;font-size:.9rem}.business-review-card-v1134 p{margin:.7rem 0 0;color:#3d3328;line-height:1.9}.business-sidebar-trust-v1134{display:grid;gap:.2rem;background:#f8f4ef;border:1px solid #eadfd3;border-radius:16px;padding:.75rem;margin:.75rem 0;text-align:center}.business-sidebar-trust-v1134 span{font-weight:900;color:#76522a}.business-sidebar-trust-v1134 strong{font-size:1.15rem}.business-sidebar-trust-v1134 small{color:#7d6d5f}.metric-card--trust-v1134{background:linear-gradient(135deg,#fff8db,#fff)}.business-reputation-dashboard-v1134{margin:1rem 0}.business-reputation-grid-v1134{display:grid;grid-template-columns:1.4fr repeat(3,1fr);gap:.8rem;align-items:stretch}.business-reputation-grid-v1134>div{background:#fbf8f4;border:1px solid #eee3d6;border-radius:18px;padding:1rem;display:grid;gap:.3rem}.business-reputation-grid-v1134 span{color:#7a6550;font-weight:800}.business-reputation-grid-v1134 strong{font-size:1.15rem;color:#2f2419}.business-reputation-score-v1134{border-radius:18px!important;align-items:start!important}.business-reputation-score-v1134 small{font-weight:700;color:#6f6257}.business-card .business-rating-chip-v1134,.listing-card .business-rating-chip-v1134{width:max-content;max-width:100%}@media (max-width: 760px){.business-reputation-grid-v1134{grid-template-columns:1fr}.business-public-rating-v1134{align-items:flex-start}.filter-check-v1134{width:100%;justify-content:center}.business-review-list-v1134--compact{grid-template-columns:1fr}}

/* v1.1.35 - Cabinet settlement commission dashboard */
.cabinet-settlements-v1135 .admin-page__header,
.cabinet-settlements-v1135 .admin-actions-v1135,
.cabinet-settlements-v1135 .filters-row-v1135,
.cabinet-settlements-v1135 .inline-rate-form-v1135,
.cabinet-settlements-v1135 .commission-status-form-v1135 {
    display: flex;
    gap: 0.75rem;
    align-items: center;
    flex-wrap: wrap;
}
.cabinet-settlements-v1135 .admin-page__header {
    justify-content: space-between;
}
.finance-summary-v1135 {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(170px, 1fr));
    gap: 0.75rem;
    margin: 1rem 0;
}
.finance-summary-v1135 > div {
    border: 1px solid var(--border-color, #e5e7eb);
    background: var(--surface-color, #fff);
    border-radius: 16px;
    padding: 1rem;
    box-shadow: 0 12px 28px rgba(15, 23, 42, 0.05);
}
.finance-summary-v1135 span,
.cabinet-settlements-v1135 .muted {
    color: var(--muted-color, #64748b);
    font-size: 0.88rem;
}
.finance-summary-v1135 strong {
    display: block;
    margin-top: 0.35rem;
    font-size: 1.08rem;
}
.finance-grid-v1135 {
    display: grid;
    grid-template-columns: minmax(0, 1.35fr) minmax(280px, 0.65fr);
    gap: 1rem;
    margin: 1rem 0;
}
.filters-row-v1135 label,
.inline-rate-form-v1135,
.commission-status-form-v1135 {
    min-width: 140px;
}
.filters-row-v1135 input,
.filters-row-v1135 select,
.inline-rate-form-v1135 input,
.commission-status-form-v1135 input,
.commission-status-form-v1135 select {
    width: 100%;
    max-width: 220px;
}
.cabinet-settlement-table-v1135 code {
    direction: ltr;
    display: inline-block;
    white-space: nowrap;
}
.status-pill.status-open { background: #fff7ed; color: #9a3412; }
.status-pill.status-collected { background: #ecfdf5; color: #047857; }
.status-pill.status-waived { background: #f1f5f9; color: #475569; }
.status-pill.status-needs_review { background: #fef2f2; color: #b91c1c; }
@media (max-width: 900px) {
    .finance-grid-v1135 { grid-template-columns: 1fr; }
    .cabinet-settlements-v1135 .admin-page__header { align-items: stretch; }
    .commission-status-form-v1135 { min-width: 260px; }
}
