:root {
    --surface: #f8f9ff;
    --surface-2: #f2f5ff;
    --surface-3: #eaf0ff;
    --surface-container: #ffffff;
    --surface-glass: rgba(255,255,255,.78);
    --text: #111827;
    --text-muted: #515b70;
    --text-soft: #6b7280;
    --outline: #d9deec;
    --outline-strong: #c2c8d8;
    --primary: #0058be;
    --primary-strong: #2170e4;
    --primary-deep: #003a82;
    --primary-soft: #eaf2ff;
    --indigo: #6366f1;
    --success: #067647;
    --success-bg: #dcfae6;
    --warning: #b54708;
    --warning-bg: #fff4d6;
    --error: #b42318;
    --error-bg: #fee4e2;
    --radius-sm: 10px;
    --radius: 16px;
    --radius-lg: 22px;
    --radius-xl: 30px;
    --shadow: 0 18px 45px rgba(17, 24, 39, .08), 0 2px 8px rgba(0, 88, 190, .04);
    --shadow-soft: 0 10px 28px rgba(0, 88, 190, .08);
    --shadow-modal: 0 32px 90px rgba(15, 23, 42, .25);
    --sidebar-width: 292px;
}

* { box-sizing: border-box; }
html { font-family: "Plus Jakarta Sans", Inter, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif; scroll-behavior: smooth; }
body { margin: 0; min-height: 100vh; background: var(--surface); color: var(--text); -webkit-font-smoothing: antialiased; text-rendering: optimizeLegibility; }
body::before, body::after { content: ""; position: fixed; pointer-events: none; z-index: -1; border-radius: 999px; filter: blur(10px); opacity: .72; }
body::before { width: 520px; height: 520px; top: -240px; right: -160px; background: radial-gradient(circle, rgba(33,112,228,.16), transparent 66%); }
body::after { width: 460px; height: 460px; left: -210px; bottom: -180px; background: radial-gradient(circle, rgba(99,102,241,.10), transparent 68%); }
a { color: inherit; text-decoration: none; }
button, input, select, textarea { font: inherit; }
button { cursor: pointer; }
img, svg { max-width: 100%; }

.material-symbols-outlined { font-family: 'Material Symbols Outlined'; font-weight: normal; font-style: normal; font-size: 22px; line-height: 1; letter-spacing: normal; text-transform: none; display: inline-flex; white-space: nowrap; word-wrap: normal; direction: ltr; -webkit-font-feature-settings: 'liga'; -webkit-font-smoothing: antialiased; font-variation-settings: 'FILL' 0, 'wght' 450, 'GRAD' 0, 'opsz' 24; }

/* Base UI */
.brand { display: inline-flex; align-items: center; gap: 10px; font-size: 24px; font-weight: 900; letter-spacing: -.04em; color: var(--primary); }
.brand::before { content: ""; width: 34px; height: 34px; display: inline-block; border-radius: 12px; background: linear-gradient(145deg, var(--primary), var(--primary-strong)); box-shadow: 0 14px 26px rgba(0,88,190,.22); position: relative; }
.btn { min-height: 44px; border: 0; border-radius: 14px; padding: 11px 18px; display: inline-flex; align-items: center; justify-content: center; gap: 9px; cursor: pointer; font-weight: 800; letter-spacing: -.01em; transition: transform .16s ease, box-shadow .16s ease, background .16s ease, color .16s ease, border-color .16s ease; white-space: nowrap; }
.btn:hover { transform: translateY(-1px); }
.btn:active { transform: translateY(0) scale(.99); }
.btn-primary { background: linear-gradient(135deg, var(--primary), var(--primary-strong)); color: #fff; box-shadow: 0 14px 24px rgba(0, 88, 190, .22); }
.btn-primary:hover { box-shadow: 0 18px 30px rgba(0, 88, 190, .28); }
.btn-light, .btn-ghost { background: var(--primary-soft); color: var(--primary); border: 1px solid rgba(0,88,190,.12); }
.btn-light:hover, .btn-ghost:hover { background: #dceaff; }
.btn-danger { background: var(--error-bg); color: var(--error); border: 1px solid rgba(180,35,24,.12); }
.btn-lg { min-height: 54px; padding: 14px 24px; font-size: 16px; border-radius: 17px; }
.btn-sm { min-height: 36px; padding: 7px 12px; font-size: 13px; border-radius: 12px; }
.btn:disabled { opacity: .55; cursor: not-allowed; transform: none; box-shadow: none; }

.card { background: var(--surface-glass); border: 1px solid rgba(194, 198, 213, .72); border-radius: var(--radius-lg); padding: 24px; box-shadow: var(--shadow); backdrop-filter: blur(14px); }
.card h1, .card h2, .card h3 { margin-top: 0; letter-spacing: -.025em; }
.card h2 { font-size: 22px; margin-bottom: 10px; }
.card-mini { background: linear-gradient(180deg, rgba(255,255,255,.9), rgba(246,248,255,.9)); border: 1px solid var(--outline); box-shadow: none; }
.muted { color: var(--text-muted); font-size: 14px; line-height: 1.55; }
.eyebrow { color: var(--primary); text-transform: uppercase; font-weight: 900; letter-spacing: .1em; font-size: 12px; display: inline-flex; align-items: center; gap: 6px; }
.eyebrow::before { content: ""; width: 8px; height: 8px; border-radius: 999px; background: linear-gradient(135deg, var(--primary), var(--indigo)); box-shadow: 0 0 0 5px rgba(0,88,190,.08); }
.mt-lg { margin-top: 24px; }
.mb-lg { margin-bottom: 24px; }
.mt-xs { margin-top: 6px; }
.hidden { display: none !important; }
.block-small { display: block; margin-top: 3px; }
.link, .text-link { color: var(--primary); font-weight: 800; text-decoration: underline; text-underline-offset: 3px; }

.badge { display: inline-flex; align-items: center; gap: 6px; padding: 7px 11px; border-radius: 999px; background: var(--primary-soft); color: var(--primary); font-weight: 900; font-size: 12px; line-height: 1; border: 1px solid rgba(0,88,190,.10); }
.badge::before { content: ""; width: 7px; height: 7px; border-radius: 999px; background: currentColor; opacity: .72; }
.badge-soft { margin-left: 8px; background: #eef4ff; color: var(--text-muted); }
.badge:has(+ *) {}

/* Public */
.public-body { padding-bottom: 0; }
.topbar { min-height: 76px; display: flex; align-items: center; justify-content: space-between; padding: 0 clamp(16px, 4vw, 48px); background: rgba(255,255,255,.76); border-bottom: 1px solid rgba(194,198,213,.55); position: sticky; top: 0; z-index: 40; backdrop-filter: blur(18px); }
.topbar-actions { display: flex; align-items: center; gap: 12px; }
.public-topbar .brand { font-size: 26px; }
.hero { max-width: 1240px; margin: 0 auto; padding: clamp(54px, 9vw, 112px) 24px 72px; display: grid; grid-template-columns: minmax(0, 1.05fr) minmax(360px, .95fr); gap: 52px; align-items: center; position: relative; }
.hero::before { content: ""; position: absolute; inset: 28px 24px auto auto; width: 220px; height: 220px; border-radius: 46px; transform: rotate(14deg); background: linear-gradient(135deg, rgba(0,88,190,.10), rgba(99,102,241,.06)); z-index: -1; }
.hero-copy { position: relative; }
.hero h1 { font-size: clamp(38px, 5vw, 68px); line-height: 1.02; margin: 14px 0 20px; letter-spacing: -.06em; color: var(--text); }
.hero p { font-size: 18px; line-height: 1.7; color: var(--text-muted); max-width: 660px; }
.hero-actions { display: flex; flex-wrap: wrap; gap: 14px; margin-top: 30px; }
.hero-card { background: linear-gradient(150deg, rgba(255,255,255,.94), rgba(235,242,255,.86)); border: 1px solid rgba(194,198,213,.75); border-radius: 32px; padding: 28px; box-shadow: var(--shadow); backdrop-filter: blur(14px); position: relative; overflow: hidden; }
.hero-card::before { content: ""; position: absolute; width: 170px; height: 170px; border-radius: 50%; background: radial-gradient(circle, rgba(33,112,228,.22), transparent 70%); right: -60px; top: -54px; }
.metric-card { background: rgba(255,255,255,.84); border: 1px solid rgba(194,198,213,.55); border-radius: 24px; padding: 24px; box-shadow: var(--shadow-soft); margin-bottom: 18px; position: relative; z-index: 1; }
.metric-card span { display: block; color: var(--success); font-weight: 900; font-size: 12px; text-transform: uppercase; letter-spacing: .09em; margin-bottom: 8px; }
.metric-card strong { display: block; font-size: 28px; line-height: 1.18; letter-spacing: -.03em; }
.pipeline { display: grid; gap: 12px; }
.pipeline div { padding: 16px 18px; border-radius: 18px; background: #fff; border: 1px solid rgba(217,222,236,.95); font-weight: 800; display: flex; align-items: center; gap: 10px; }
.pipeline div::before { content: "check_circle"; font-family: 'Material Symbols Outlined'; color: var(--primary); background: var(--primary-soft); width: 30px; height: 30px; border-radius: 10px; display: grid; place-items: center; font-size: 19px; }
.feature-grid { max-width: 1240px; margin: 0 auto; padding: 0 24px 84px; display: grid; grid-template-columns: repeat(3, 1fr); gap: 20px; }
.feature-grid .card { min-height: 180px; position: relative; overflow: hidden; }
.feature-grid .card::after { content: ""; position: absolute; right: 18px; bottom: 18px; width: 54px; height: 54px; border-radius: 18px; background: linear-gradient(135deg, rgba(0,88,190,.13), rgba(99,102,241,.08)); }

/* Auth */
.auth-page { min-height: calc(100vh - 76px); display: grid; place-items: center; padding: 40px 16px 72px; }
.auth-card { width: min(100%, 480px); position: relative; overflow: hidden; }
.auth-card::before { content: ""; position: absolute; inset: 0 0 auto 0; height: 5px; background: linear-gradient(90deg, var(--primary), var(--indigo), var(--primary-strong)); }
.auth-card.wide { width: min(100%, 980px); }
.auth-card h1 { font-size: 30px; margin-bottom: 8px; }
.auth-links { display: flex; justify-content: space-between; gap: 12px; margin-top: 18px; color: var(--primary); font-weight: 800; font-size: 14px; }

/* Forms */
.form-stack { display: grid; gap: 16px; }
.grid-form { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 16px; }
.grid-form .full, .full { grid-column: 1 / -1; }
label { display: grid; gap: 8px; color: var(--text-muted); font-weight: 800; font-size: 13px; }
input, select, textarea { width: 100%; min-height: 50px; border: 1.5px solid var(--outline); border-radius: 14px; padding: 12px 14px; background: rgba(255,255,255,.92); color: var(--text); transition: border-color .16s ease, box-shadow .16s ease, background .16s ease; }
textarea { min-height: 110px; resize: vertical; }
input:focus, select:focus, textarea:focus { outline: 0; border-color: var(--primary-strong); box-shadow: 0 0 0 4px rgba(33,112,228,.13); background: #fff; }
input::placeholder, textarea::placeholder { color: #858da2; }
.form-actions { display: flex; justify-content: flex-end; gap: 12px; }
.section-title h2 { margin-bottom: 4px; }
.compact-head { margin-bottom: 14px; }

/* App shell */
.app-shell { display: grid; grid-template-columns: var(--sidebar-width) minmax(0, 1fr); min-height: 100vh; }
.sidebar { background: rgba(255,255,255,.82); border-right: 1px solid rgba(194,198,213,.7); padding: 26px 18px; position: sticky; top: 0; height: 100vh; backdrop-filter: blur(20px); box-shadow: 12px 0 32px rgba(17,24,39,.03); }
.sidebar-brand { display: flex; margin-bottom: 34px; padding: 0 10px; }
.side-nav { display: grid; gap: 6px; }
.side-nav a { min-height: 46px; padding: 12px 14px; border-radius: 16px; color: var(--text-muted); font-weight: 800; display: flex; align-items: center; gap: 12px; transition: .16s ease; position: relative; }
.side-nav a:hover, .side-nav a.is-active { background: linear-gradient(135deg, var(--primary-soft), rgba(255,255,255,.72)); color: var(--primary); box-shadow: inset 0 0 0 1px rgba(0,88,190,.09); }
.side-nav a .nav-icon { width: 34px; height: 34px; display: grid; place-items: center; border-radius: 12px; background: rgba(0,88,190,.08); color: var(--primary); flex: 0 0 auto; }
.main-area { min-width: 0; }
.mobile-header { display: none; }
.content-wrap { max-width: 1240px; margin: 0 auto; padding: 28px 28px 64px; }
.userbar { min-height: 58px; display: flex; justify-content: space-between; align-items: center; margin-bottom: 22px; padding: 8px 0; }
.userbar > div { display: flex; align-items: center; gap: 8px; flex-wrap: wrap; }
.page-head { display: flex; justify-content: space-between; align-items: flex-start; gap: 18px; margin-bottom: 24px; }
.page-head h1 { margin: 6px 0 8px; font-size: clamp(30px, 3vw, 42px); letter-spacing: -.05em; line-height: 1.05; }
.page-head .actions { flex-shrink: 0; }

.stats-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 16px; }
.stat { position: relative; overflow: hidden; min-height: 142px; display: grid; align-content: end; }
.stat::before { content: ""; position: absolute; right: 18px; top: 18px; width: 48px; height: 48px; border-radius: 16px; background: linear-gradient(135deg, var(--primary-soft), #fff); border: 1px solid rgba(0,88,190,.08); }
.stat span { display: block; color: var(--text-muted); font-weight: 900; font-size: 12px; text-transform: uppercase; letter-spacing: .06em; }
.stat strong { display: block; font-size: 30px; margin-top: 8px; letter-spacing: -.04em; }
.quick-actions { display: grid; grid-template-columns: repeat(4, 1fr); gap: 16px; }
.quick-card { display: grid; gap: 8px; }
.quick-card strong { color: var(--primary); }
.quick-card span { color: var(--text-muted); font-size: 14px; line-height: 1.4; }
.grid-two { display: grid; grid-template-columns: repeat(2, 1fr); gap: 22px; }

/* Filters and tables */
.filter-bar { display: grid; grid-template-columns: 1.4fr 1fr .85fr auto; gap: 12px; margin-bottom: 18px; padding: 16px; align-items: end; }
.filter-bar-wide { grid-template-columns: 1.3fr .8fr 1fr 1fr 1fr 1fr auto; }
.table-card { overflow-x: auto; }
.table-card.flat { box-shadow: none; border: 0; padding: 0; background: transparent; backdrop-filter: none; }
table { width: 100%; border-collapse: separate; border-spacing: 0; min-width: 760px; }
th, td { padding: 15px 14px; border-bottom: 1px solid var(--outline); text-align: left; vertical-align: middle; }
th { color: #3f4656; font-size: 12px; text-transform: uppercase; letter-spacing: .075em; background: #eef3ff; font-weight: 900; }
th:first-child { border-top-left-radius: 12px; }
th:last-child { border-top-right-radius: 12px; }
tbody tr { transition: background .16s ease; }
tbody tr:hover { background: rgba(234,242,255,.52); }
.table-empty-cell { padding: 24px 14px; text-align: center; }
.actions { display: flex; gap: 9px; align-items: center; flex-wrap: wrap; }
.action-stack { display: grid; gap: 10px; }
.full-btn { width: 100%; }

.alert { margin: 0 0 16px; border-radius: 16px; padding: 14px 16px; border: 1px solid var(--outline); background: var(--primary-soft); color: var(--primary-deep); font-weight: 700; }
.alert-success { background: var(--success-bg); border-color: rgba(6,118,71,.18); color: var(--success); }
.alert-error { background: var(--error-bg); border-color: rgba(180,35,24,.18); color: var(--error); }

/* Lists / cards */
.list-stack { display: grid; gap: 12px; }
.list-item { display: flex; align-items: center; justify-content: space-between; gap: 16px; }
.responsive-list-item { align-items: flex-start; }
.invitation-card { display: grid; gap: 18px; }
.payment-card-list { display: grid; gap: 14px; }
.payment-readonly-card { display: flex; justify-content: space-between; gap: 16px; align-items: center; }
.payment-readonly-values { display: grid; justify-items: end; gap: 8px; }
.payment-readonly-values strong { font-size: 22px; }
.empty-state { padding: 24px; border: 1px dashed var(--outline); border-radius: var(--radius); background: rgba(255,255,255,.6); text-align: center; }

/* Checks, chips, profile */
.check-row { display: flex; align-items: center; gap: 10px; background: var(--surface-2); padding: 12px; border-radius: 14px; }
.check-row input { width: auto; min-height: auto; }
.check-grid, .checkbox-grid { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 12px; }
.check-card { display: flex; align-items: flex-start; gap: 10px; border: 1px solid var(--outline); border-radius: 16px; padding: 14px; background: #fff; color: var(--text); min-height: 58px; }
.check-card input { width: auto; min-height: auto; margin-top: 2px; }
.check-card small { display: block; color: var(--text-muted); font-weight: 600; margin-top: 2px; }
.checks-row { display: flex; flex-wrap: wrap; gap: 12px; }
.role-row { display: grid; grid-template-columns: 1.1fr 1.2fr .6fr .7fr 1fr; gap: 12px; padding: 14px; border: 1px solid var(--outline); border-radius: 18px; background: linear-gradient(180deg, rgba(255,255,255,.9), rgba(242,245,255,.82)); }
.profile-grid { display: grid; grid-template-columns: minmax(0, 1fr) 360px; gap: 24px; align-items: start; }
.profile-main { display: grid; gap: 16px; }
.profile-main h3 { margin: 28px 0 10px; }
.avatar-row { display: flex; align-items: center; gap: 16px; margin-bottom: 22px; }
.avatar, .profile-avatar { width: 68px; height: 68px; border-radius: 22px; background: linear-gradient(145deg, var(--primary), var(--indigo)); color: #fff; display: grid; place-items: center; font-size: 28px; font-weight: 900; box-shadow: 0 16px 26px rgba(0,88,190,.20); }
.chip-row, .chip-list { display: flex; flex-wrap: wrap; gap: 8px; }
.chip { display: inline-flex; align-items: center; padding: 8px 11px; border-radius: 999px; background: var(--primary-soft); border: 1px solid rgba(0,88,190,.10); font-size: 13px; font-weight: 900; color: var(--primary); }
.info-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 12px; }
.info-grid.compact { grid-template-columns: repeat(3, 1fr); }
.info-grid div { border: 1px solid var(--outline); border-radius: 16px; padding: 14px; background: #fff; }
.info-grid span { display: block; font-size: 11px; color: var(--text-muted); font-weight: 900; text-transform: uppercase; letter-spacing: .06em; }
.info-grid strong { display: block; margin-top: 6px; }
.info-list { display: grid; grid-template-columns: 140px 1fr; gap: 10px 16px; }
.info-list dt { color: var(--text-muted); font-weight: 900; }
.info-list dd { margin: 0; }
.vertical-actions { align-items: stretch; flex-direction: column; }
.vertical-actions form, .vertical-actions .btn { width: 100%; }

/* Finance modal */
.financial-summary-card { padding: 26px; }
.collaborator-total-table .btn { min-width: 110px; }
body.modal-open { overflow: hidden; }

[data-modal][hidden] { display: none !important; }
.modal-backdrop, .modal { position: fixed; inset: 0; z-index: 100; display: grid; place-items: center; padding: 24px; background: rgba(15, 23, 42, .45); backdrop-filter: blur(10px); opacity: 0; pointer-events: none; transition: opacity .18s ease; }
.modal-backdrop.is-open, .modal.is-open { opacity: 1; pointer-events: auto; }
.modal-panel { width: min(100%, 1180px); max-height: calc(100vh - 48px); overflow: hidden; border-radius: 26px; background: #fff; box-shadow: var(--shadow-modal); border: 1px solid rgba(255,255,255,.72); outline: none; display: flex; flex-direction: column; transform: translateY(10px) scale(.985); transition: transform .18s ease; }
.modal-backdrop.is-open .modal-panel, .modal.is-open .modal-panel { transform: translateY(0) scale(1); }
.modal-head { padding: 26px 30px 20px; display: flex; align-items: flex-start; justify-content: space-between; gap: 18px; border-bottom: 1px solid var(--outline); }
.modal-head h2 { margin: 0 0 4px; font-size: 30px; letter-spacing: -.04em; }
.modal-close { width: 42px; height: 42px; border: 0; border-radius: 14px; background: #f1f5ff; color: var(--text); font-size: 30px; line-height: 1; display: grid; place-items: center; }
.modal-close:hover { background: var(--primary-soft); color: var(--primary); }
.payment-modal-form { display: flex; flex-direction: column; min-height: 0; flex: 1; }
.modal-body { padding: 22px 30px 24px; overflow: auto; }
.modal-section-title { margin: 0 0 12px; font-size: 18px; }
.payment-event-list { display: grid; gap: 14px; }
.payment-event-card { display: grid; grid-template-columns: 42px minmax(220px, 1fr) 140px 160px 168px 190px; gap: 14px; align-items: center; padding: 18px; border: 1px solid var(--outline); border-radius: 20px; background: linear-gradient(180deg, #fff, #fbfcff); box-shadow: 0 8px 20px rgba(17,24,39,.035); }
.payment-event-icon { width: 42px; height: 42px; display: grid; place-items: center; border-radius: 15px; background: var(--primary-soft); color: var(--primary); font-weight: 900; }
.payment-event-info strong { display: block; font-size: 16px; margin-bottom: 7px; }
.payment-event-info span { display: block; color: var(--text-muted); font-size: 13px; font-weight: 800; }
.payment-event-info p { margin: 8px 0 0; }
.payment-field { gap: 7px; }
.payment-field span { font-size: 12px; color: #3f4656; }
.payment-field input, .payment-field select { min-height: 48px; }
.payment-modal-summary { margin-top: 22px; display: grid; grid-template-columns: repeat(3, 1fr); gap: 0; overflow: hidden; border: 1px solid var(--outline); border-radius: 20px; background: #f1f5ff; }
.payment-modal-summary > div { display: grid; grid-template-columns: 48px 1fr; gap: 6px 14px; align-items: center; padding: 18px 22px; border-right: 1px solid var(--outline); }
.payment-modal-summary > div:last-child { border-right: 0; }
.payment-modal-summary span:not(.summary-icon) { color: var(--text-muted); font-weight: 800; }
.payment-modal-summary strong { grid-column: 2; font-size: 21px; letter-spacing: -.03em; }
.summary-icon { grid-row: 1 / span 2; width: 46px; height: 46px; border-radius: 16px; display: grid; place-items: center; font-weight: 900; }
.summary-wallet { background: var(--primary-soft); color: var(--primary); }
.summary-paid { background: var(--success-bg); color: var(--success); }
.summary-pending { background: var(--warning-bg); color: var(--warning); }
.modal-footer { border-top: 1px solid var(--outline); padding: 18px 30px; display: flex; justify-content: space-between; align-items: center; gap: 18px; background: #fff; }
.grand-total { display: flex; align-items: baseline; gap: 16px; }
.grand-total span { color: var(--text-muted); font-weight: 900; }
.grand-total strong { font-size: 28px; letter-spacing: -.04em; }
.footer-actions { display: flex; gap: 12px; flex-wrap: wrap; justify-content: flex-end; }

/* Mobile bottom navs */
.mobile-bottom-nav, .public-mobile-bottom { display: none; }
.mobile-nav-scroll, .mobile-nav { display: none; }

/* Responsive */
@media (max-width: 1180px) {
    .stats-grid, .quick-actions { grid-template-columns: repeat(2, minmax(0, 1fr)); }
    .filter-bar-wide { grid-template-columns: repeat(2, minmax(0, 1fr)); }
    .role-row { grid-template-columns: repeat(2, minmax(0, 1fr)); }
    .profile-grid { grid-template-columns: 1fr; }
    .payment-event-card { grid-template-columns: 42px minmax(220px, 1fr) repeat(2, minmax(150px, 1fr)); }
    .payment-field-notes { grid-column: 3 / span 2; }
}

@media (max-width: 900px) {
    body { padding-bottom: calc(76px + env(safe-area-inset-bottom)); }
    .topbar { min-height: 66px; padding: 0 16px; }
    .public-topbar .brand { font-size: 22px; }
    .public-register-action { display: none; }
    .public-login-action { min-height: 40px; padding: 8px 14px; }
    .hero, .feature-grid, .grid-two { grid-template-columns: 1fr; }
    .hero { padding: 42px 16px 38px; gap: 24px; }
    .hero h1 { font-size: clamp(34px, 12vw, 46px); }
    .hero p { font-size: 16px; }
    .hero-actions { flex-direction: column; }
    .hero-actions .btn { width: 100%; }
    .hero-card { border-radius: 26px; padding: 20px; }
    .feature-grid { padding: 0 16px 90px; gap: 14px; }
    .auth-page { min-height: calc(100vh - 66px); padding: 22px 16px 92px; place-items: start center; }
    .auth-card { border-radius: 24px; padding: 22px; }
    .auth-card h1 { font-size: 26px; }
    .auth-links { flex-direction: column; }
    .app-shell { grid-template-columns: 1fr; }
    .sidebar { display: none; }
    .mobile-header { display: flex; align-items: center; justify-content: space-between; gap: 12px; padding: 12px 16px; background: rgba(255,255,255,.84); border-bottom: 1px solid rgba(194,198,213,.68); position: sticky; top: 0; z-index: 40; backdrop-filter: blur(18px); }
    .mobile-header .brand { font-size: 22px; }
    .mobile-header-user { display: flex; align-items: center; gap: 8px; font-size: 13px; font-weight: 800; }
    .content-wrap { padding: 18px 16px 98px; }
    .userbar { display: none; }
    .page-head { flex-direction: column; margin-bottom: 18px; }
    .page-head h1 { font-size: 32px; }
    .page-head .btn, .page-head form { width: 100%; }
    .page-head .actions { width: 100%; }
    .stats-grid, .quick-actions, .grid-form, .filter-bar, .filter-bar-wide, .role-row, .check-grid, .checkbox-grid, .info-grid, .info-grid.compact { grid-template-columns: 1fr; }
    .form-actions { justify-content: stretch; }
    .form-actions .btn { width: 100%; }
    .filter-bar { padding: 14px; }
    .card { padding: 18px; border-radius: 22px; }
    .stat { min-height: 116px; }
    .table-card { overflow-x: visible; }
    table { min-width: 0; }
    .table-card table, .table-card thead, .table-card tbody, .table-card tr, .table-card th, .table-card td { display: block; }
    .table-card thead { display: none; }
    .table-card tr { padding: 14px; margin-bottom: 12px; border: 1px solid var(--outline); border-radius: 18px; background: #fff; box-shadow: 0 8px 18px rgba(17,24,39,.04); }
    .table-card td { border: 0; padding: 7px 0; display: flex; justify-content: space-between; gap: 14px; align-items: center; }
    .table-card td::before { content: attr(data-label); font-size: 11px; text-transform: uppercase; letter-spacing: .06em; color: var(--text-muted); font-weight: 900; }
    .table-card td:last-child { justify-content: flex-start; }
    .table-card td:last-child::before { display: none; }
    .collaborator-total-table td:nth-child(1)::before { content: "Colaborador"; }
    .collaborator-total-table td:nth-child(2)::before { content: "Total"; }
    .collaborator-total-table td:nth-child(3)::before { content: "Pago"; }
    .collaborator-total-table td:nth-child(4)::before { content: "Pendente"; }
    .collaborator-total-table td:nth-child(5) { padding-top: 12px; }
    .collaborator-total-table td:nth-child(5) .btn { width: 100%; }
    .responsive-list-item, .list-item, .payment-readonly-card { flex-direction: column; align-items: stretch; }
    .payment-readonly-values { justify-items: start; }
    .profile-grid { gap: 16px; }
    .modal-backdrop { padding: 0; align-items: end; }
    .modal-panel { width: 100%; max-height: calc(100vh - 18px); border-radius: 28px 28px 0 0; }
    .modal-head { padding: 22px 18px 16px; }
    .modal-body { padding: 18px; }
    .payment-event-card { grid-template-columns: 40px minmax(0, 1fr); gap: 12px; padding: 15px; }
    .payment-event-info { grid-column: 2; }
    .payment-field { grid-column: 1 / -1; }
    .payment-modal-summary { grid-template-columns: 1fr; }
    .payment-modal-summary > div { border-right: 0; border-bottom: 1px solid var(--outline); }
    .payment-modal-summary > div:last-child { border-bottom: 0; }
    .modal-footer { padding: 16px 18px calc(16px + env(safe-area-inset-bottom)); flex-direction: column; align-items: stretch; }
    .grand-total { justify-content: space-between; }
    .footer-actions { display: grid; grid-template-columns: 1fr; }
    .footer-actions .btn { width: 100%; }
    .mobile-bottom-nav, .public-mobile-bottom { position: fixed; left: 12px; right: 12px; bottom: calc(10px + env(safe-area-inset-bottom)); z-index: 80; display: grid; grid-template-columns: repeat(5, 1fr); gap: 4px; padding: 7px; border-radius: 24px; background: rgba(255,255,255,.88); border: 1px solid rgba(194,198,213,.72); box-shadow: 0 20px 50px rgba(17,24,39,.18); backdrop-filter: blur(18px); }
    .public-mobile-bottom { grid-template-columns: repeat(3, 1fr); }
    .mobile-bottom-nav a, .public-mobile-bottom a { min-height: 54px; border-radius: 18px; display: grid; place-items: center; gap: 2px; color: var(--text-muted); font-size: 11px; font-weight: 900; }
    .mobile-bottom-nav a span:first-child, .public-mobile-bottom a span:first-child { font-size: 20px; line-height: 1; }
    .mobile-bottom-nav a.is-active, .mobile-bottom-nav a:hover, .public-mobile-bottom a:hover { color: var(--primary); background: var(--primary-soft); }
    .mobile-bottom-nav__icon { font-size: 20px; }
}

@media (max-width: 520px) {
    .stats-grid { grid-template-columns: 1fr 1fr; gap: 10px; }
    .stat { padding: 16px; min-height: 112px; }
    .stat strong { font-size: 24px; }
    .stat span { font-size: 10px; }
    .brand::before { width: 30px; height: 30px; border-radius: 10px; }
    .metric-card strong { font-size: 22px; }
    input, select, textarea { min-height: 52px; }
}

/* Imprezza 1.2.6 - Pool publico e busca de empresas */
.public-company-hero {
    padding: clamp(28px, 6vw, 72px) 18px 0;
}
.public-company-card {
    max-width: 960px;
    margin: 0 auto;
    text-align: center;
    position: relative;
    overflow: hidden;
}
.public-company-card::before,
.pool-share-strip::before {
    content: "";
    position: absolute;
    inset: -80px auto auto -80px;
    width: 220px;
    height: 220px;
    background: radial-gradient(circle, rgba(33,112,228,.18), transparent 65%);
    pointer-events: none;
}
.company-avatar {
    width: 72px;
    height: 72px;
    border-radius: 24px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-weight: 900;
    font-size: 28px;
    color: #fff;
    background: linear-gradient(135deg, var(--primary), var(--accent));
    box-shadow: 0 16px 40px rgba(0, 88, 190, .22);
    margin-bottom: 16px;
}
.company-avatar.small {
    width: 52px;
    height: 52px;
    border-radius: 18px;
    font-size: 20px;
    margin: 0;
    flex: 0 0 auto;
}
.company-public-meta,
.chip-row {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    justify-content: center;
    margin-top: 14px;
}
.pool-public-page {
    padding-top: 24px;
}
.company-card-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
    gap: 16px;
}
.company-result-card {
    display: flex;
    flex-direction: column;
    gap: 18px;
}
.company-result-main {
    display: flex;
    gap: 14px;
    align-items: flex-start;
}
.company-result-main h2 {
    margin: 0 0 4px;
    font-size: 1.1rem;
}
.copy-row {
    display: flex;
    gap: 10px;
    align-items: center;
}
.copy-row input {
    flex: 1;
    min-width: 0;
}
.copy-row.compact-copy {
    min-width: min(520px, 100%);
}
.public-link-card,
.pool-share-strip {
    position: relative;
    overflow: hidden;
}
.pool-share-strip {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 20px;
}
.callout {
    border: 1px solid rgba(33, 112, 228, .16);
    background: rgba(33, 112, 228, .07);
    border-radius: 18px;
    padding: 16px;
}
.callout p {
    margin: 6px 0 0;
}
.badge.success {
    background: rgba(0, 108, 73, .12);
    color: #006c49;
}
.empty-state {
    text-align: center;
    padding: 32px;
}
.section-head.compact {
    display: flex;
    justify-content: space-between;
    gap: 16px;
    align-items: flex-start;
    margin-bottom: 16px;
}

@media (max-width: 760px) {
    .pool-share-strip,
    .copy-row {
        flex-direction: column;
        align-items: stretch;
    }
    .company-result-main {
        align-items: center;
    }
    .public-company-card {
        text-align: left;
    }
    .public-company-card .company-avatar {
        display: flex;
    }
    .company-public-meta {
        justify-content: flex-start;
    }
}

/* MVP 1.2.7 - logos, event cover, payment extract */
.company-brand-card { display: grid; grid-template-columns: 96px 1fr minmax(260px, 360px); align-items: center; gap: 20px; }
.company-brand-preview img, .company-logo-placeholder { width: 88px; height: 88px; border-radius: 26px; object-fit: cover; box-shadow: 0 16px 38px rgba(0,88,190,.16); border: 1px solid var(--outline); background: #fff; }
.company-logo-placeholder { display: grid; place-items: center; color: var(--primary); font-size: 34px; font-weight: 900; background: linear-gradient(135deg, #eaf2ff, #fff); }
.company-logo-form { display: grid; gap: 10px; }
.company-logo-form input[type=file], input[type=file] { min-height: auto; padding: 12px; background: #fff; border-style: dashed; }
.upload-preview { width: 100%; max-width: 240px; height: 130px; object-fit: cover; border-radius: 18px; border: 1px solid var(--outline); margin: 8px 0 10px; display: block; }
.field-hint { display: block; color: var(--text-muted); font-size: 12px; font-weight: 700; margin-top: 6px; }
.event-title-cell { display: flex; align-items: center; gap: 12px; }
.table-thumb { width: 52px; height: 52px; object-fit: cover; border-radius: 16px; box-shadow: 0 10px 24px rgba(17,24,39,.08); border: 1px solid var(--outline); }
.event-cover { min-height: 230px; background-size: cover; background-position: center; padding: 0; overflow: hidden; display: flex; align-items: flex-end; }
.event-cover__overlay { width: 100%; padding: 34px; color: #fff; background: linear-gradient(180deg, rgba(10,20,40,0), rgba(7,18,38,.82)); }
.event-cover__overlay .eyebrow, .event-cover__overlay h2 { color: #fff; }
.payment-event-card--wide { grid-template-columns: 42px minmax(190px, 1.1fr) 135px 135px 110px 150px 165px 170px; }
.payment-field-readonly input[readonly] { background: #f6f8fd; color: var(--text); font-weight: 900; cursor: not-allowed; }
.payment-balance-field strong { min-height: 48px; display: flex; align-items: center; padding: 0 14px; border: 1px solid var(--outline); border-radius: 14px; background: #fff8eb; color: #8a5200; }
.payment-extract-card { align-items: stretch; }
.payment-extract-main { display: flex; gap: 16px; align-items: center; min-width: 0; }
.payment-extract-image { width: 86px; height: 86px; border-radius: 22px; object-fit: cover; border: 1px solid var(--outline); }
.payment-extract-values { display: grid; grid-template-columns: repeat(3, minmax(120px, 1fr)); gap: 10px; align-items: center; text-align: right; }
.payment-extract-values div { padding: 12px; border-radius: 16px; background: #f6f8fd; }
.payment-extract-values span { display: block; color: var(--text-muted); font-size: 12px; font-weight: 800; }
.payment-extract-values strong { font-size: 18px; }
@media (max-width: 1180px) {
  .payment-event-card--wide { grid-template-columns: 42px minmax(220px, 1fr) repeat(2, minmax(150px, 1fr)); }
  .payment-event-card--wide .payment-balance-field,
  .payment-event-card--wide .payment-field-notes { grid-column: span 2; }
}
@media (max-width: 760px) {
  .company-brand-card { grid-template-columns: 1fr; text-align: left; }
  .payment-event-card--wide { grid-template-columns: 40px minmax(0, 1fr); }
  .payment-event-card--wide .payment-field,
  .payment-event-card--wide .payment-balance-field,
  .payment-event-card--wide .payment-field-notes { grid-column: 1 / -1; }
  .event-cover { min-height: 180px; }
  .event-cover__overlay { padding: 24px; }
  .payment-extract-main { align-items: flex-start; }
  .payment-extract-values { grid-template-columns: 1fr; text-align: left; width: 100%; }
}
.company-avatar-img { width: 84px; height: 84px; border-radius: 26px; object-fit: cover; border: 1px solid var(--outline); box-shadow: 0 14px 34px rgba(0,88,190,.14); }
.company-avatar-img.small { width: 54px; height: 54px; border-radius: 18px; }

/* Landing page 1.2.8 */
.landing-hero {
    position: relative;
    display: grid;
    grid-template-columns: minmax(0, 1.05fr) minmax(420px, .95fr);
    gap: 42px;
    align-items: center;
    padding: 74px clamp(20px, 5vw, 76px) 42px;
    overflow: hidden;
}
.landing-hero::before {
    content: "";
    position: absolute;
    inset: 26px clamp(12px, 3vw, 44px) auto;
    height: 80%;
    z-index: -1;
    border-radius: 42px;
    background:
        radial-gradient(circle at 84% 14%, rgba(99,102,241,.24), transparent 36%),
        radial-gradient(circle at 12% 0%, rgba(0,88,190,.14), transparent 38%),
        linear-gradient(135deg, rgba(255,255,255,.84), rgba(234,242,255,.66));
    border: 1px solid rgba(194, 198, 213, .56);
    box-shadow: 0 30px 90px rgba(15, 23, 42, .08);
}
.landing-hero__content h1 {
    margin: 16px 0 18px;
    font-size: clamp(42px, 5.4vw, 76px);
    line-height: .96;
    letter-spacing: -.07em;
    max-width: 920px;
}
.landing-lead {
    max-width: 720px;
    margin: 0;
    color: var(--text-muted);
    font-size: clamp(17px, 1.5vw, 21px);
    line-height: 1.62;
    font-weight: 600;
}
.landing-hero__actions {
    display: flex;
    gap: 13px;
    flex-wrap: wrap;
    margin-top: 28px;
}
.landing-trust-row {
    margin-top: 26px;
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
}
.landing-trust-row span {
    display: inline-flex;
    gap: 5px;
    padding: 10px 13px;
    border-radius: 999px;
    background: rgba(255,255,255,.68);
    border: 1px solid rgba(194,198,213,.58);
    color: var(--text-muted);
    font-size: 13px;
    font-weight: 800;
}
.landing-trust-row strong { color: var(--text); }
.landing-hero__visual { position: relative; min-height: 520px; }
.hero-orb { position: absolute; border-radius: 999px; filter: blur(1px); opacity: .9; }
.hero-orb-one { width: 130px; height: 130px; right: 10px; top: 4px; background: linear-gradient(135deg, rgba(99,102,241,.28), rgba(33,112,228,.1)); }
.hero-orb-two { width: 86px; height: 86px; left: 22px; bottom: 30px; background: linear-gradient(135deg, rgba(6,118,71,.18), rgba(108,248,187,.26)); }
.landing-dashboard-preview {
    position: relative;
    margin: 22px auto 0;
    max-width: 540px;
    padding: 22px;
    border-radius: 32px;
    background: rgba(255,255,255,.84);
    border: 1px solid rgba(194,198,213,.7);
    box-shadow: 0 32px 80px rgba(0, 58, 130, .16);
    backdrop-filter: blur(18px);
}
.preview-topline { display: flex; justify-content: space-between; align-items: flex-start; gap: 14px; margin-bottom: 16px; }
.preview-kicker { display: block; color: var(--primary); font-size: 12px; font-weight: 900; text-transform: uppercase; letter-spacing: .08em; }
.preview-topline strong { display: block; font-size: 26px; letter-spacing: -.045em; margin-top: 4px; }
.preview-metrics { display: grid; grid-template-columns: repeat(3, 1fr); gap: 12px; margin-bottom: 16px; }
.preview-metrics div { padding: 14px; border-radius: 18px; background: linear-gradient(180deg, #fff, #f2f6ff); border: 1px solid var(--outline); }
.preview-metrics span { display: block; color: var(--text-muted); font-size: 12px; font-weight: 900; }
.preview-metrics strong { display: block; margin-top: 6px; font-size: 24px; letter-spacing: -.04em; }
.preview-flow { display: grid; gap: 12px; }
.flow-step { display: grid; grid-template-columns: 42px 1fr; gap: 12px; align-items: center; padding: 14px; border-radius: 18px; background: #fff; border: 1px solid var(--outline); }
.flow-step span { width: 42px; height: 42px; display: grid; place-items: center; border-radius: 15px; background: var(--surface-2); color: var(--text-muted); font-weight: 900; }
.flow-step strong { display: block; letter-spacing: -.02em; }
.flow-step small { display: block; margin-top: 3px; color: var(--text-muted); font-weight: 700; }
.flow-step.is-done span { background: var(--success-bg); color: var(--success); }
.flow-step.is-active { border-color: rgba(0,88,190,.28); box-shadow: 0 14px 28px rgba(0,88,190,.08); }
.flow-step.is-active span { background: var(--primary); color: #fff; }
.landing-section { padding: 42px clamp(20px, 5vw, 76px); }
.landing-section__head { max-width: 840px; margin-bottom: 24px; }
.landing-section__head h2,
.landing-split h2,
.future-card h2,
.pricing-card h2,
.final-cta h2 {
    margin: 12px 0 12px;
    font-size: clamp(30px, 3.5vw, 52px);
    line-height: 1.02;
    letter-spacing: -.055em;
}
.landing-section__head p,
.future-card p,
.pricing-card p,
.final-cta p { color: var(--text-muted); font-size: 17px; line-height: 1.65; font-weight: 600; }
.pain-grid,
.benefit-grid { display: grid; grid-template-columns: repeat(4, minmax(0, 1fr)); gap: 16px; }
.pain-card,
.benefit-card,
.timeline-card,
.pricing-card,
.faq-card,
.future-card,
.final-cta {
    border: 1px solid rgba(194,198,213,.72);
    background: rgba(255,255,255,.78);
    box-shadow: var(--shadow);
    border-radius: 26px;
    backdrop-filter: blur(14px);
}
.pain-card, .benefit-card { padding: 22px; }
.pain-card .material-symbols-outlined,
.benefit-card .material-symbols-outlined { width: 50px; height: 50px; border-radius: 17px; display: grid; place-items: center; background: var(--primary-soft); color: var(--primary); margin-bottom: 16px; }
.pain-card h3, .benefit-card h3 { margin: 0 0 10px; font-size: 18px; letter-spacing: -.03em; }
.pain-card p, .benefit-card p { margin: 0; color: var(--text-muted); line-height: 1.55; font-weight: 600; }
.benefit-grid { grid-template-columns: repeat(3, minmax(0, 1fr)); }
.featured-benefit { background: linear-gradient(135deg, rgba(0,88,190,.96), rgba(99,102,241,.9)); color: #fff; border: 0; }
.featured-benefit p { color: rgba(255,255,255,.84); }
.featured-benefit .material-symbols-outlined { background: rgba(255,255,255,.16); color: #fff; }
.landing-split { display: grid; grid-template-columns: minmax(0, .9fr) minmax(420px, 1.1fr); gap: 34px; align-items: start; }
.landing-copy { font-size: 16px; }
.timeline-card { padding: 20px; display: grid; gap: 14px; }
.timeline-item { display: grid; grid-template-columns: 58px 1fr; gap: 16px; padding: 16px; border-radius: 20px; background: #fff; border: 1px solid var(--outline); }
.timeline-item > span { width: 50px; height: 50px; display: grid; place-items: center; border-radius: 18px; background: linear-gradient(135deg, var(--primary), var(--primary-strong)); color: #fff; font-weight: 900; }
.timeline-item strong { display: block; font-size: 17px; letter-spacing: -.02em; }
.timeline-item p { margin: 6px 0 0; color: var(--text-muted); line-height: 1.5; font-weight: 600; }
.collaborator-band { display: grid; grid-template-columns: minmax(0, 1.1fr) minmax(340px, .9fr); gap: 28px; align-items: center; background: linear-gradient(135deg, var(--primary-deep), var(--primary), var(--indigo)); color: #fff; margin: 42px clamp(20px, 5vw, 76px); border-radius: 34px; padding: 42px; box-shadow: 0 28px 70px rgba(0,58,130,.22); }
.collaborator-band .eyebrow { color: #cfe1ff; }
.collaborator-band .eyebrow::before { background: #fff; box-shadow: 0 0 0 5px rgba(255,255,255,.14); }
.collaborator-band h2 { margin: 12px 0; font-size: clamp(30px, 3.5vw, 50px); line-height: 1.05; letter-spacing: -.055em; }
.collaborator-band p { color: rgba(255,255,255,.82); font-size: 17px; line-height: 1.65; font-weight: 600; max-width: 760px; }
.collab-pills { display: flex; flex-wrap: wrap; gap: 10px; margin: 22px 0 24px; }
.collab-pills span { padding: 9px 12px; border-radius: 999px; background: rgba(255,255,255,.12); border: 1px solid rgba(255,255,255,.16); color: #fff; font-weight: 800; font-size: 13px; }
.collaborator-card-stack { display: grid; gap: 14px; }
.talent-card { padding: 18px; border-radius: 22px; background: rgba(255,255,255,.92); color: var(--text); box-shadow: 0 18px 40px rgba(0,0,0,.12); transform: rotate(-1.5deg); }
.talent-card:nth-child(2) { transform: rotate(1.2deg); margin-left: 34px; }
.talent-card:nth-child(3) { transform: rotate(-.5deg); margin-left: 12px; }
.talent-card strong { display: block; font-size: 18px; }
.talent-card span { display: block; margin-top: 5px; color: var(--text-muted); font-weight: 700; }
.talent-card em { display: inline-flex; margin-top: 12px; padding: 7px 10px; border-radius: 999px; background: var(--primary-soft); color: var(--primary); font-style: normal; font-weight: 900; font-size: 12px; }
.future-card { padding: 30px; display: grid; grid-template-columns: minmax(0, 1fr) 320px; gap: 28px; align-items: center; }
.rating-preview { padding: 24px; border-radius: 24px; background: linear-gradient(180deg, #fff, #f2f6ff); border: 1px solid var(--outline); }
.stars { color: #f59e0b; font-size: 28px; letter-spacing: 2px; margin-bottom: 12px; }
.rating-preview strong { display: block; font-size: 28px; letter-spacing: -.04em; }
.rating-preview span { display: block; color: var(--text-muted); font-weight: 700; margin-top: 5px; }
.private-note { margin-top: 18px; padding: 14px; border-radius: 16px; background: var(--primary-soft); color: var(--primary-deep); font-weight: 700; line-height: 1.45; }
.pricing-cta { display: grid; grid-template-columns: minmax(0, 1fr) 420px; gap: 22px; align-items: stretch; }
.pricing-card, .faq-card { padding: 28px; }
.price-line { display: flex; align-items: center; justify-content: space-between; gap: 18px; margin: 24px 0 6px; padding: 18px; border-radius: 20px; background: var(--primary-soft); border: 1px solid rgba(0,88,190,.12); }
.price-line span { color: var(--text-muted); font-weight: 900; }
.price-line strong { color: var(--primary); font-size: 28px; letter-spacing: -.04em; }
.faq-card h3 { margin: 0 0 16px; font-size: 24px; letter-spacing: -.04em; }
.faq-card details { border-top: 1px solid var(--outline); padding: 15px 0; }
.faq-card details:first-of-type { border-top: 0; }
.faq-card summary { cursor: pointer; font-weight: 900; }
.faq-card p { color: var(--text-muted); line-height: 1.5; font-weight: 600; margin: 10px 0 0; }
.final-cta { margin: 42px clamp(20px, 5vw, 76px) 76px; padding: 46px; text-align: center; background: linear-gradient(135deg, rgba(255,255,255,.9), rgba(234,242,255,.82)); position: relative; overflow: hidden; }
.final-cta::before { content: ""; position: absolute; width: 280px; height: 280px; border-radius: 999px; right: -100px; top: -110px; background: radial-gradient(circle, rgba(0,88,190,.18), transparent 66%); }
.final-cta h2, .final-cta p { margin-left: auto; margin-right: auto; max-width: 860px; }
.center-actions { justify-content: center; }

@media (max-width: 1100px) {
    .landing-hero { grid-template-columns: 1fr; padding-top: 46px; }
    .landing-hero__visual { min-height: auto; }
    .landing-dashboard-preview { max-width: 720px; }
    .pain-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
    .benefit-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
    .landing-split, .collaborator-band, .future-card, .pricing-cta { grid-template-columns: 1fr; }
}

@media (max-width: 760px) {
    .public-body { padding-bottom: 84px; }
    .landing-hero { padding: 28px 16px 26px; gap: 20px; }
    .landing-hero::before { inset: 8px 8px auto; height: 96%; border-radius: 28px; }
    .landing-hero__content h1 { font-size: 40px; letter-spacing: -.06em; }
    .landing-lead { font-size: 16px; }
    .landing-hero__actions { flex-direction: column; }
    .landing-hero__actions .btn { width: 100%; }
    .landing-trust-row { display: grid; grid-template-columns: 1fr; }
    .landing-dashboard-preview { padding: 16px; border-radius: 24px; }
    .preview-metrics { grid-template-columns: 1fr; }
    .flow-step { grid-template-columns: 38px 1fr; }
    .flow-step span { width: 38px; height: 38px; }
    .landing-section { padding: 28px 16px; }
    .landing-section__head h2, .landing-split h2, .future-card h2, .pricing-card h2, .final-cta h2 { font-size: 32px; }
    .pain-grid, .benefit-grid { grid-template-columns: 1fr; }
    .timeline-card { padding: 14px; border-radius: 22px; }
    .timeline-item { grid-template-columns: 46px 1fr; padding: 14px; }
    .timeline-item > span { width: 44px; height: 44px; }
    .collaborator-band { margin: 28px 16px; padding: 28px 18px; border-radius: 28px; }
    .talent-card:nth-child(2), .talent-card:nth-child(3) { margin-left: 0; transform: none; }
    .future-card, .pricing-card, .faq-card, .final-cta { padding: 22px; border-radius: 24px; }
    .future-card { gap: 16px; }
    .pricing-cta { padding-left: 16px; padding-right: 16px; }
    .price-line { align-items: flex-start; flex-direction: column; }
    .final-cta { margin: 28px 16px 104px; }
}

/* Imprezza 1.2.9 - Avaliações */
.rating-hero {
    display: flex;
    align-items: center;
    justify-content: space-between;
    background: linear-gradient(135deg, rgba(0,88,190,.10), rgba(124,58,237,.08));
    border-color: rgba(33,112,228,.18);
}
.rating-score-line,
.inline-rating {
    display: flex;
    align-items: center;
    gap: .55rem;
    flex-wrap: wrap;
}
.rating-score-line strong {
    font-size: clamp(2rem, 6vw, 3.7rem);
    letter-spacing: -.06em;
    color: var(--ink, #111827);
}
.stars {
    color: #f59e0b;
    letter-spacing: .08em;
    white-space: nowrap;
    font-weight: 900;
}
.stars-lg { font-size: 1.45rem; }
.rating-count {
    color: var(--muted, #667085);
    font-weight: 800;
}
.section-title-row {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 1rem;
    margin-bottom: 1rem;
}
.review-list,
.review-history-list,
.review-mini-list {
    display: grid;
    gap: 1rem;
}
.review-card {
    display: grid;
    grid-template-columns: minmax(220px, 1fr) minmax(320px, 1.5fr);
    gap: 1.2rem;
    padding: 1rem;
    border: 1px solid rgba(148,163,184,.35);
    border-radius: 24px;
    background: rgba(255,255,255,.82);
    box-shadow: 0 18px 40px rgba(15,23,42,.06);
}
.review-card.is-reviewed {
    background: linear-gradient(135deg, rgba(236,253,245,.85), rgba(255,255,255,.94));
}
.review-card-main {
    display: flex;
    gap: .9rem;
    align-items: flex-start;
}
.review-avatar {
    width: 46px;
    height: 46px;
    border-radius: 18px;
    display: grid;
    place-items: center;
    background: linear-gradient(135deg, #e0ecff, #eef2ff);
    color: #0058be;
    font-weight: 900;
    flex: 0 0 auto;
}
.review-form {
    display: grid;
    grid-template-columns: 140px 1fr;
    gap: .8rem;
    align-items: end;
}
.review-form .review-comment,
.review-form .review-public-check {
    grid-column: 1 / -1;
}
.check-line {
    display: flex !important;
    align-items: flex-start;
    gap: .6rem;
    font-weight: 700;
    color: var(--muted, #475569);
}
.check-line input { width: auto; min-height: auto; margin-top: .18rem; }
.review-history-item,
.review-mini-card {
    padding: 1rem;
    border: 1px solid rgba(148,163,184,.3);
    border-radius: 20px;
    background: rgba(255,255,255,.78);
}
.review-history-item {
    display: grid;
    grid-template-columns: minmax(180px, 1fr) auto;
    gap: .9rem;
}
.review-history-comment {
    grid-column: 1 / -1;
    margin: 0;
    padding: .9rem;
    border-radius: 16px;
    background: rgba(248,250,252,.9);
}
.review-history-comment.is-private {
    border: 1px dashed rgba(100,116,139,.35);
}
.review-mini-card p { margin: .45rem 0; }
.public-company-rating { justify-content: center; margin: .9rem 0 0; }
.public-review-strip {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: .8rem;
    margin-top: 1.2rem;
}
.public-review-strip article {
    padding: .95rem;
    border-radius: 20px;
    background: rgba(255,255,255,.72);
    border: 1px solid rgba(148,163,184,.25);
    text-align: left;
}
.public-review-strip p { margin: .4rem 0; }
.mt-sm { margin-top: .5rem; }
@media (max-width: 760px) {
    .review-card,
    .review-form,
    .review-history-item,
    .public-review-strip {
        grid-template-columns: 1fr;
    }
    .rating-hero { display: block; }
    .stars-lg { font-size: 1.15rem; }
    .review-card { border-radius: 22px; padding: .9rem; }
    .review-form .btn { width: 100%; }
}

/* Imprezza 1.2.10 - correção do card de fluxo na landing page */
.preview-topline strong {
    white-space: normal;
    line-height: 1.08;
    letter-spacing: -.05em;
}
.flow-step {
    grid-template-columns: 42px minmax(0, 1fr);
    grid-template-areas:
        "icon title"
        "icon desc";
    align-items: center;
}
.flow-step span {
    grid-area: icon;
}
.flow-step strong {
    grid-area: title;
    min-width: 0;
    line-height: 1.15;
}
.flow-step small {
    grid-area: desc;
    min-width: 0;
    max-width: 100%;
    line-height: 1.35;
    word-break: normal;
    overflow-wrap: normal;
    white-space: normal;
}
@media (max-width: 760px) {
    .flow-step {
        grid-template-columns: 38px minmax(0, 1fr);
    }
    .preview-topline {
        align-items: flex-start;
    }
    .preview-topline strong {
        font-size: 22px;
    }
}

/* Calendar module - MVP 1.2.11 */
.calendar-hero {
    align-items: center;
    gap: 1.25rem;
}

.calendar-toolbar {
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 1rem;
    margin-bottom: 1rem;
}

.calendar-toolbar__center {
    text-align: center;
}

.calendar-toolbar__center h2 {
    margin: 0;
    font-size: clamp(1.25rem, 2vw, 1.8rem);
}

.calendar-toolbar__center p {
    margin: .25rem 0 0;
    color: var(--muted, #64748b);
    font-size: .92rem;
}

.calendar-toolbar__actions {
    display: flex;
    gap: .6rem;
    align-items: center;
}

.calendar-legend {
    margin-bottom: 1rem;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
}

.calendar-legend__items {
    display: flex;
    flex-wrap: wrap;
    gap: .45rem .8rem;
    justify-content: flex-end;
}

.calendar-legend__item {
    display: inline-flex;
    gap: .35rem;
    align-items: center;
    font-size: .86rem;
    color: #475569;
}

.calendar-dot {
    width: .65rem;
    height: .65rem;
    border-radius: 999px;
    display: inline-block;
    background: #0f62c9;
}

.calendar-card {
    overflow: hidden;
    padding: 0;
}

.calendar-grid {
    display: grid;
    grid-template-columns: repeat(7, minmax(0, 1fr));
}

.calendar-weekdays {
    background: linear-gradient(180deg, #f8fbff, #eef4ff);
    border-bottom: 1px solid rgba(148, 163, 184, .28);
}

.calendar-weekdays > div {
    padding: .9rem .75rem;
    font-size: .74rem;
    text-transform: uppercase;
    letter-spacing: .08em;
    font-weight: 800;
    color: #64748b;
    text-align: center;
}

.calendar-day {
    min-height: 142px;
    border-right: 1px solid rgba(148, 163, 184, .24);
    border-bottom: 1px solid rgba(148, 163, 184, .24);
    padding: .7rem;
    background: rgba(255, 255, 255, .72);
    position: relative;
}

.calendar-day:nth-child(7n) {
    border-right: none;
}

.calendar-day.is-muted {
    background: rgba(248, 250, 252, .72);
    color: #94a3b8;
}

.calendar-day.is-today {
    background: linear-gradient(180deg, rgba(33, 112, 228, .1), rgba(255, 255, 255, .9));
    box-shadow: inset 0 0 0 1px rgba(33, 112, 228, .18);
}

.calendar-day__top {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: .4rem;
    margin-bottom: .55rem;
}

.calendar-day__number {
    display: inline-grid;
    place-items: center;
    min-width: 1.9rem;
    height: 1.9rem;
    border-radius: 999px;
    font-weight: 800;
    color: #0f172a;
}

.calendar-day.is-today .calendar-day__number {
    background: #0058be;
    color: #fff;
}

.calendar-today-badge {
    font-size: .68rem;
    font-weight: 800;
    color: #0058be;
    background: rgba(33, 112, 228, .1);
    border: 1px solid rgba(33, 112, 228, .18);
    padding: .18rem .45rem;
    border-radius: 999px;
}

.calendar-day__items {
    display: grid;
    gap: .38rem;
}

.calendar-event-chip {
    border: 0;
    width: 100%;
    text-align: left;
    cursor: pointer;
    border-radius: 14px;
    padding: .55rem .62rem;
    color: #0f172a;
    background: #eaf2ff;
    box-shadow: inset 3px 0 0 #0f62c9;
    transition: transform .16s ease, box-shadow .16s ease;
}

.calendar-event-chip:hover {
    transform: translateY(-1px);
    box-shadow: inset 3px 0 0 #0f62c9, 0 12px 24px rgba(15, 23, 42, .08);
}

.calendar-event-chip__time,
.calendar-event-chip small {
    display: block;
    font-size: .72rem;
    color: #475569;
    line-height: 1.25;
}

.calendar-event-chip__title {
    display: block;
    font-weight: 800;
    font-size: .82rem;
    line-height: 1.2;
    margin: .12rem 0;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.calendar-more {
    font-size: .75rem;
    color: #64748b;
    font-weight: 700;
    padding: .25rem .4rem;
}

.calendar-event-chip.is-blue, .calendar-dot.is-blue { background-color: #eaf2ff; }
.calendar-event-chip.is-indigo, .calendar-dot.is-indigo { background-color: #eef2ff; }
.calendar-event-chip.is-green, .calendar-dot.is-green { background-color: #e8f8ee; }
.calendar-event-chip.is-amber, .calendar-dot.is-amber { background-color: #fff4d8; }
.calendar-event-chip.is-rose, .calendar-dot.is-rose { background-color: #ffe9ee; }
.calendar-event-chip.is-cyan, .calendar-dot.is-cyan { background-color: #e6fbff; }
.calendar-event-chip.is-violet, .calendar-dot.is-violet { background-color: #f4eaff; }

.calendar-event-chip.is-blue { box-shadow: inset 3px 0 0 #0f62c9; }
.calendar-event-chip.is-indigo { box-shadow: inset 3px 0 0 #4f46e5; }
.calendar-event-chip.is-green { box-shadow: inset 3px 0 0 #16a34a; }
.calendar-event-chip.is-amber { box-shadow: inset 3px 0 0 #f59e0b; }
.calendar-event-chip.is-rose { box-shadow: inset 3px 0 0 #e11d48; }
.calendar-event-chip.is-cyan { box-shadow: inset 3px 0 0 #0891b2; }
.calendar-event-chip.is-violet { box-shadow: inset 3px 0 0 #7c3aed; }

.calendar-modal-panel {
    max-width: 920px;
}

.calendar-modal-cover {
    width: 100%;
    max-height: 220px;
    object-fit: cover;
    border-radius: 22px;
    margin-bottom: 1rem;
    border: 1px solid rgba(148, 163, 184, .22);
}

.calendar-info-grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: .8rem;
    margin-bottom: 1.25rem;
}

.calendar-info-grid > div {
    background: linear-gradient(180deg, #f8fbff, #f2f6ff);
    border: 1px solid rgba(148, 163, 184, .22);
    border-radius: 18px;
    padding: .9rem;
}

.calendar-info-grid span {
    display: block;
    font-size: .78rem;
    color: #64748b;
    font-weight: 800;
    margin-bottom: .35rem;
}

.calendar-info-grid strong {
    display: block;
    color: #0f172a;
    line-height: 1.25;
}

.section-title-sm {
    font-size: 1rem;
    margin: 0 0 .75rem;
}

.calendar-staff-list {
    display: grid;
    gap: .7rem;
}

.calendar-staff-card {
    display: grid;
    grid-template-columns: auto minmax(0, 1fr) auto;
    align-items: center;
    gap: .85rem;
    padding: .85rem;
    border: 1px solid rgba(148, 163, 184, .24);
    border-radius: 20px;
    background: #fff;
}

.calendar-avatar {
    width: 44px;
    height: 44px;
    border-radius: 16px;
    display: grid;
    place-items: center;
    background: linear-gradient(135deg, #0058be, #2170e4);
    color: #fff;
    font-weight: 900;
}

.calendar-staff-card strong,
.calendar-staff-card span,
.calendar-staff-card small {
    display: block;
}

.calendar-staff-card span,
.calendar-staff-card small {
    color: #64748b;
    font-size: .86rem;
}

.calendar-staff-time {
    text-align: right;
    background: #f8fbff;
    border-radius: 16px;
    padding: .55rem .7rem;
    min-width: 86px;
}

.calendar-staff-time span {
    font-size: 1.1rem;
    font-weight: 900;
    color: #0058be;
}

.calendar-detail-card {
    display: flex;
    gap: .85rem;
    align-items: flex-start;
    border: 1px solid rgba(148, 163, 184, .24);
    background: #fff;
    border-radius: 20px;
    padding: 1rem;
}

.calendar-detail-card .material-symbols-outlined {
    background: #eaf2ff;
    color: #0058be;
    border-radius: 16px;
    padding: .55rem;
}

.calendar-detail-card p,
.calendar-detail-card small {
    color: #64748b;
    margin: .2rem 0 0;
}

.empty-state.is-compact {
    padding: 1rem;
    text-align: center;
}

@media (max-width: 900px) {
    .calendar-toolbar,
    .calendar-legend {
        align-items: stretch;
        flex-direction: column;
    }

    .calendar-toolbar__actions,
    .calendar-legend__items {
        justify-content: center;
    }

    .calendar-weekdays {
        display: none;
    }

    .calendar-month {
        display: grid;
        grid-template-columns: 1fr;
    }

    .calendar-day {
        min-height: auto;
        border-right: none;
        padding: .95rem;
    }

    .calendar-day.is-muted:empty {
        display: none;
    }

    .calendar-day__top::after {
        content: attr(data-weekday);
    }

    .calendar-info-grid {
        grid-template-columns: 1fr;
    }

    .calendar-staff-card {
        grid-template-columns: auto minmax(0, 1fr);
    }

    .calendar-staff-time {
        grid-column: 1 / -1;
        text-align: left;
    }
}

@media (max-width: 640px) {
    .calendar-event-chip__title {
        white-space: normal;
    }

    .calendar-modal-panel {
        width: calc(100vw - 1rem);
        max-height: calc(100vh - 1rem);
        border-radius: 24px;
    }
}

/* Imprezza 1.3.0 - Times */
.team-metrics {
    margin-bottom: 1rem;
}
.team-members-card .section-title-inline {
    margin-bottom: 1rem;
}
.team-member-form {
    display: contents;
}
.team-member-form select,
.team-member-form input {
    min-width: 150px;
}
.danger-zone {
    margin-top: 1rem;
    border-color: rgba(239, 68, 68, .22);
    background: linear-gradient(135deg, rgba(254, 242, 242, .86), rgba(255,255,255,.92));
}
.empty-state {
    display: grid;
    place-items: center;
    text-align: center;
    gap: .65rem;
    padding: 2rem 1rem;
}
.empty-state .material-symbols-outlined {
    width: 54px;
    height: 54px;
    border-radius: 18px;
    display: grid;
    place-items: center;
    color: var(--primary);
    background: rgba(33, 112, 228, .10);
    font-size: 30px;
}
.btn-danger {
    color: #b91c1c;
    background: #fff1f2;
    border-color: rgba(225, 29, 72, .22);
}
.btn-danger:hover {
    background: #ffe4e6;
}
@media (max-width: 760px) {
    .team-members-card table,
    .team-members-card thead,
    .team-members-card tbody,
    .team-members-card tr,
    .team-members-card th,
    .team-members-card td {
        display: block;
        width: 100%;
    }
    .team-members-card thead { display: none; }
    .team-members-card tr {
        border: 1px solid var(--border);
        border-radius: 22px;
        padding: .85rem;
        margin-bottom: .85rem;
        background: #fff;
    }
    .team-members-card td {
        border: 0 !important;
        padding: .35rem 0 !important;
    }
    .team-members-card .actions {
        display: grid;
        gap: .5rem;
    }
    .team-member-form {
        display: grid;
        gap: .5rem;
    }
}
.team-member-list {
    display: grid;
    gap: .85rem;
}
.team-member-card {
    display: grid;
    grid-template-columns: minmax(220px, 1.2fr) repeat(4, minmax(145px, 1fr)) auto;
    gap: .8rem;
    align-items: end;
    padding: 1rem;
    border: 1px solid var(--border);
    border-radius: 22px;
    background: rgba(255,255,255,.86);
}
.team-member-card__person {
    display: grid;
    gap: .18rem;
    align-self: center;
}
.team-member-card__actions {
    align-self: end;
    white-space: nowrap;
}
@media (max-width: 1100px) {
    .team-member-card {
        grid-template-columns: 1fr 1fr;
    }
    .team-member-card__person,
    .team-member-card__actions {
        grid-column: 1 / -1;
    }
}
@media (max-width: 640px) {
    .team-member-card {
        grid-template-columns: 1fr;
    }
}

/* Imprezza 1.3.1 - criacao de evento com cargos dinamicos */
.event-builder { display: grid; gap: 22px; }
.event-form-head .actions { display: flex; gap: 10px; flex-wrap: wrap; justify-content: flex-end; }
.event-step-card { overflow: visible; }
.event-step-title { display: flex; align-items: flex-start; gap: 14px; margin-bottom: 20px; }
.event-step-title h2 { margin: 0 0 5px; }
.event-step-title .muted { margin: 0; }
.event-step-title-actions { justify-content: space-between; align-items: center; gap: 18px; }
.event-step-title-left { display: flex; align-items: flex-start; gap: 14px; }
.event-step-number { width: 42px; height: 42px; display: inline-grid; place-items: center; flex: 0 0 42px; border-radius: 16px; background: linear-gradient(135deg, var(--primary), var(--primary-strong)); color: #fff; font-weight: 900; box-shadow: 0 14px 24px rgba(0,88,190,.22); }
.event-role-summary { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 12px; margin-bottom: 18px; }
.event-role-summary > div { padding: 16px 18px; border: 1px solid rgba(194,198,213,.75); border-radius: 18px; background: linear-gradient(180deg, rgba(255,255,255,.95), rgba(238,244,255,.82)); }
.event-role-summary span { display: block; font-size: 12px; color: var(--text-muted); font-weight: 900; text-transform: uppercase; letter-spacing: .06em; margin-bottom: 5px; }
.event-role-summary strong { display: block; font-size: 24px; letter-spacing: -.04em; }
.event-role-list { display: grid; gap: 14px; }
.event-role-line { display: grid; grid-template-columns: 46px minmax(190px, 1fr) minmax(190px, 1.1fr) 120px 150px minmax(170px, 1fr) 48px; gap: 12px; align-items: end; padding: 15px; border: 1px solid rgba(194,198,213,.78); border-radius: 22px; background: linear-gradient(180deg, rgba(255,255,255,.95), rgba(246,248,255,.88)); box-shadow: 0 10px 24px rgba(17,24,39,.04); }
.event-role-line__index { align-self: stretch; min-height: 50px; display: grid; place-items: center; }
.event-role-line__index span { width: 34px; height: 34px; display: grid; place-items: center; border-radius: 12px; background: var(--primary-soft); color: var(--primary); font-weight: 900; }
.event-role-line__notes { min-width: 0; }
.event-role-remove { width: 44px; min-width: 44px; padding-left: 0; padding-right: 0; }
.event-role-empty { text-align: center; border: 1px dashed var(--outline-strong); border-radius: 22px; padding: 28px 18px; background: rgba(255,255,255,.58); }
.event-role-empty .material-symbols-outlined { font-size: 42px; color: var(--primary); }
.event-role-empty strong { display: block; margin-top: 8px; font-size: 18px; }
.event-builder-footer { display: flex; justify-content: space-between; align-items: center; gap: 18px; position: sticky; bottom: 16px; z-index: 8; }
.event-builder-footer p { margin: 4px 0 0; }
.event-roles-overview { display: grid; gap: 12px; }
.event-role-overview-card { display: grid; grid-template-columns: 1fr auto auto; gap: 14px; align-items: center; padding: 15px 16px; border: 1px solid var(--outline); border-radius: 18px; background: linear-gradient(180deg, #fff, #f8faff); }
.event-role-overview-card strong { display: block; margin-bottom: 4px; }
.event-role-overview-card__qty { padding: 8px 12px; border-radius: 999px; background: var(--primary-soft); color: var(--primary); font-weight: 900; font-size: 13px; }
.event-role-overview-card__price { font-size: 16px; font-weight: 900; white-space: nowrap; }
.event-next-step { border: 1px solid rgba(0,88,190,.14); background: linear-gradient(135deg, rgba(0,88,190,.08), rgba(99,102,241,.06)); }
.event-next-step h2 { margin-bottom: 4px; }
.event-next-step .actions { margin-top: 16px; display: flex; flex-wrap: wrap; gap: 10px; }

@media (max-width: 1180px) {
    .event-role-line { grid-template-columns: 42px repeat(2, minmax(0, 1fr)); }
    .event-role-line__notes { grid-column: 2 / span 2; }
    .event-role-remove { grid-column: 1 / -1; width: 100%; }
}

@media (max-width: 900px) {
    .event-step-title-actions, .event-step-title-left, .event-step-title { flex-direction: column; align-items: stretch; }
    .event-step-title-actions .btn { width: 100%; }
    .event-role-summary { grid-template-columns: 1fr; }
    .event-role-line { grid-template-columns: 1fr; padding: 14px; }
    .event-role-line__index { min-height: 0; place-items: start; }
    .event-role-line__notes { grid-column: auto; }
    .event-builder-footer { position: static; flex-direction: column; align-items: stretch; }
    .event-builder-footer .form-actions { display: grid; grid-template-columns: 1fr; }
    .event-role-overview-card { grid-template-columns: 1fr; }
    .event-role-overview-card__qty, .event-role-overview-card__price { width: fit-content; }
}

/* Imprezza 1.3.2 - convite em lote e por time */
.invite-wizard-card, .invite-filter-card, .invite-selection-card, .invite-message-card { overflow: visible; }
.invite-role-tabs { display: grid; grid-template-columns: repeat(auto-fit, minmax(190px, 1fr)); gap: 12px; }
.invite-role-tab { display: block; padding: 16px 18px; border: 1px solid var(--outline); border-radius: 20px; background: linear-gradient(180deg, #fff, #f8faff); color: var(--text); text-decoration: none; transition: transform .18s ease, border-color .18s ease, box-shadow .18s ease; }
.invite-role-tab:hover { transform: translateY(-2px); border-color: rgba(0,88,190,.28); box-shadow: 0 14px 30px rgba(17,24,39,.08); }
.invite-role-tab.is-active { border-color: rgba(0,88,190,.45); background: linear-gradient(135deg, rgba(0,88,190,.10), rgba(99,102,241,.08)); box-shadow: 0 14px 32px rgba(0,88,190,.10); }
.invite-role-tab strong { display: block; margin-bottom: 5px; font-size: 16px; }
.invite-role-tab span { color: var(--text-muted); font-weight: 800; font-size: 13px; }
.invite-filter-grid { align-items: end; }
.invite-filter-check { min-height: 50px; display: flex; align-items: center; gap: 8px; padding-bottom: 8px; }
.invite-selection-head { display: flex; align-items: flex-start; justify-content: space-between; gap: 16px; margin-bottom: 18px; }
.invite-selection-head h2 { margin: 0 0 5px; }
.select-all-pill { display: inline-flex; align-items: center; gap: 8px; padding: 11px 14px; border: 1px solid var(--outline); border-radius: 999px; background: #fff; font-weight: 900; white-space: nowrap; }
.invite-cards-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(285px, 1fr)); gap: 14px; }
.invite-candidate-card { display: grid; gap: 12px; padding: 16px; border: 1px solid var(--outline); border-radius: 22px; background: linear-gradient(180deg, #fff, #f8faff); cursor: pointer; position: relative; transition: transform .16s ease, border-color .16s ease, box-shadow .16s ease; }
.invite-candidate-card:hover { transform: translateY(-2px); border-color: rgba(0,88,190,.28); box-shadow: 0 16px 34px rgba(17,24,39,.08); }
.invite-candidate-card > input[type="checkbox"] { position: absolute; top: 16px; right: 16px; width: 20px; height: 20px; }
.invite-candidate-card.has-invite { background: linear-gradient(180deg, #fff, rgba(108,248,187,.08)); }
.invite-candidate-card.has-conflict { opacity: .72; cursor: not-allowed; background: linear-gradient(180deg, #fff, rgba(186,26,26,.06)); }
.invite-candidate-main { display: flex; gap: 12px; align-items: center; padding-right: 30px; }
.avatar-mini { width: 44px; height: 44px; border-radius: 16px; display: grid; place-items: center; background: linear-gradient(135deg, var(--primary), var(--primary-strong)); color: #fff; font-weight: 950; box-shadow: 0 12px 22px rgba(0,88,190,.20); }
.invite-chip-row { display: flex; flex-wrap: wrap; gap: 7px; }
.chip { display: inline-flex; align-items: center; padding: 7px 10px; border-radius: 999px; background: rgba(17,24,39,.06); font-size: 12px; font-weight: 850; color: var(--text); }
.chip-blue { background: var(--primary-soft); color: var(--primary); }
.chip-soft { background: rgba(99,102,241,.11); color: #3730a3; }
.invite-skill-line { margin: 0; font-size: 13px; line-height: 1.45; }
.invite-card-footer { display: flex; flex-wrap: wrap; gap: 8px; align-items: center; }
.conflict-note { margin: 0; padding: 10px 12px; border-radius: 14px; background: rgba(186,26,26,.07); color: #7f1d1d; }
.event-roles-overview.compact { max-height: 280px; overflow: auto; padding-right: 3px; }
.event-role-overview-card.is-link { color: var(--text); text-decoration: none; transition: transform .16s ease, border-color .16s ease; }
.event-role-overview-card.is-link:hover { transform: translateY(-2px); border-color: rgba(0,88,190,.28); }
.invite-submit-bar { margin-top: 18px; padding: 16px; border: 1px solid rgba(0,88,190,.16); border-radius: 20px; background: linear-gradient(135deg, rgba(0,88,190,.08), rgba(99,102,241,.06)); display: flex; align-items: center; justify-content: space-between; gap: 16px; }
.invite-submit-bar p { margin: 4px 0 0; }
.empty-state.full { grid-column: 1 / -1; }
.badge-success { background: rgba(0,108,73,.12); color: #006c49; }
.badge-danger { background: rgba(186,26,26,.12); color: #ba1a1a; }

@media (max-width: 760px) {
    .invite-selection-head, .invite-submit-bar { flex-direction: column; align-items: stretch; }
    .select-all-pill { justify-content: center; }
    .invite-cards-grid { grid-template-columns: 1fr; }
}
