@font-face {
    font-family: "Plus Jakarta Sans";
    font-style: normal;
    font-weight: 500;
    font-display: swap;
    src: url("../fonts/plus-jakarta-sans/plus-jakarta-sans-500.ttf") format("truetype");
}

:root {
    --wc-bg: #f6f9fb;
    --wc-card: #ffffff;
    --wc-border: #e3ebef;
    --wc-text: #142033;
    --wc-muted: #667085;
    --wc-blue: #33528A;
    --wc-teal: #33A9A0;
    --wc-lime: #C4E81D;
    --wc-green: #8AB62E;
    --wc-olive: #597001;
    --wc-gradient: linear-gradient(135deg, #33A9A0 0%, #7BCB57 54%, #C4E81D 100%);
    --wc-radius: 22px;
    --wc-shadow: 0 16px 42px rgba(20, 32, 51, 0.07);
}

body {
    background: var(--wc-bg);
    color: var(--wc-text);
}

.login-page {
    background:
        radial-gradient(circle at 9% 4%, rgba(51, 169, 160, 0.18), transparent 25rem),
        radial-gradient(circle at 96% 11%, rgba(196, 232, 29, 0.28), transparent 24rem),
        linear-gradient(135deg, #f7fbfd 0%, #ffffff 50%, #eef8f6 100%);
    min-height: 100vh;
}

.login-shell {
    display: grid;
    grid-template-columns: minmax(0, 1.08fr) minmax(420px, 0.92fr);
    min-height: 100vh;
}

.login-brand-panel {
    align-content: space-between;
    background:
        linear-gradient(135deg, rgba(255, 255, 255, 0.84), rgba(255, 255, 255, 0.48)),
        radial-gradient(circle at 12% 16%, rgba(51, 169, 160, 0.22), transparent 16rem),
        radial-gradient(circle at 96% 92%, rgba(196, 232, 29, 0.32), transparent 18rem);
    border-right: 1px solid rgba(51, 82, 138, 0.1);
    display: grid;
    overflow: hidden;
    padding: clamp(2rem, 4vw, 4.5rem);
    position: relative;
}

/* ── Toast notifications ───────────────────────────────── */
#wc-toast-container {
    bottom: 1.5rem;
    display: flex;
    flex-direction: column;
    gap: 0.6rem;
    max-width: 360px;
    position: fixed;
    right: 1.5rem;
    width: calc(100vw - 3rem);
    z-index: 9999;
}

.wc-toast {
    align-items: flex-start;
    background: #fff;
    border-left: 4px solid #64748b;
    border-radius: 0.65rem;
    box-shadow: 0 8px 32px rgba(20,32,51,.14);
    display: flex;
    gap: 0.65rem;
    opacity: 0;
    padding: 0.85rem 1rem;
    transform: translateX(1.5rem);
    transition: opacity .25s ease, transform .25s ease;
}

.wc-toast.wc-toast-show {
    opacity: 1;
    transform: translateX(0);
}

.wc-toast-success { border-color: #16a34a; }
.wc-toast-danger  { border-color: #dc2626; }
.wc-toast-warning { border-color: #d97706; }
.wc-toast-info    { border-color: #2563eb; }

.wc-toast-icon {
    flex-shrink: 0;
    font-size: 1.05rem;
    padding-top: 0.05rem;
}

.wc-toast-success .wc-toast-icon { color: #16a34a; }
.wc-toast-danger  .wc-toast-icon { color: #dc2626; }
.wc-toast-warning .wc-toast-icon { color: #d97706; }
.wc-toast-info    .wc-toast-icon { color: #2563eb; }

.wc-toast-body {
    color: #1e293b;
    flex: 1;
    font-size: 0.9rem;
    font-weight: 500;
    line-height: 1.45;
}

.wc-toast-close {
    background: none;
    border: none;
    color: #94a3b8;
    cursor: pointer;
    flex-shrink: 0;
    font-size: 1.1rem;
    line-height: 1;
    padding: 0;
}

.wc-toast-close:hover { color: #475569; }
/* ───────────────────────────────────────────────────────── */

.login-brand-panel::before,
.login-brand-panel::after {
    content: "";
    position: absolute;
    pointer-events: none;
}

.login-brand-panel::before {
    background-image: radial-gradient(rgba(51, 169, 160, 0.36) 1.5px, transparent 1.5px);
    background-size: 12px 12px;
    height: 320px;
    left: -88px;
    opacity: 0.42;
    top: -78px;
    transform: rotate(-10deg);
    width: 420px;
}

.login-brand-panel::after {
    border: 1px solid rgba(51, 82, 138, 0.08);
    border-radius: 50%;
    box-shadow: -40px 50px 0 rgba(196, 232, 29, 0.14);
    height: 260px;
    right: -96px;
    top: 64px;
    width: 260px;
}

.login-brand,
.login-brand-copy {
    position: relative;
    z-index: 1;
}

.login-brand {
    align-items: center;
    color: #07183d;
    display: inline-flex;
    gap: 0.75rem;
    text-decoration: none;
}

.login-brand img {
    height: 54px;
    width: 54px;
}

.login-brand span {
    font-size: 1.6rem;
    font-weight: 900;
    letter-spacing: -0.03em;
}

.login-brand-copy {
    max-width: 620px;
}

.login-brand-copy p {
    color: var(--wc-teal);
    font-size: 0.9rem;
    font-weight: 900;
    letter-spacing: 0.35em;
    margin-bottom: 1rem;
    text-transform: uppercase;
}

.login-brand-copy h1 {
    color: #07183d;
    font-size: clamp(2.55rem, 5vw, 5.2rem);
    font-weight: 900;
    line-height: 0.98;
    margin: 0;
    max-width: 760px;
}

.login-brand-badges {
    display: flex;
    flex-wrap: wrap;
    gap: 0.8rem;
    margin-top: 2rem;
}

.login-brand-badges span {
    align-items: center;
    background: rgba(255, 255, 255, 0.82);
    border: 1px solid rgba(51, 169, 160, 0.18);
    border-radius: 999px;
    color: #23324c;
    display: inline-flex;
    font-weight: 800;
    gap: 0.5rem;
    padding: 0.72rem 0.95rem;
}

.login-brand-badges i {
    color: var(--wc-teal);
}

.login-card-wrap {
    align-items: center;
    display: flex;
    justify-content: center;
    padding: clamp(1.25rem, 4vw, 4rem);
}

.login-card {
    background: rgba(255, 255, 255, 0.94);
    border: 1px solid rgba(51, 82, 138, 0.1);
    border-radius: 24px;
    box-shadow: 0 24px 70px rgba(20, 32, 51, 0.12);
    max-width: 460px;
    padding: clamp(1.5rem, 3vw, 2.25rem);
    width: 100%;
}

.login-card-head {
    align-items: center;
    display: flex;
    gap: 1rem;
    margin-bottom: 1.6rem;
}

.login-card-head img {
    height: 52px;
    width: 52px;
}

.login-card-head p {
    color: var(--wc-teal);
    font-size: 0.78rem;
    font-weight: 900;
    letter-spacing: 0.12em;
    margin: 0;
    text-transform: uppercase;
}

.login-card-head h2 {
    color: #07183d;
    font-size: 1.8rem;
    font-weight: 900;
    margin: 0.15rem 0 0;
}

.login-field {
    margin-bottom: 1rem;
}

.login-field .form-label {
    color: #24324a;
    font-weight: 800;
    margin-bottom: 0.45rem;
}

.login-input,
.login-card .password-field {
    align-items: center;
    background: #fff;
    border: 1px solid #dce6ef;
    border-radius: 14px;
    display: flex;
    overflow: hidden;
}

.login-input i {
    color: #70809b;
    margin-left: 1rem;
}

.login-input .form-control,
.login-card .password-field .form-control {
    border: 0;
    box-shadow: none;
    min-height: 52px;
}

.login-card .password-toggle {
    margin-right: 0.35rem;
}

.login-submit {
    background: linear-gradient(135deg, var(--wc-blue), var(--wc-teal));
    border: 0;
    border-radius: 14px;
    color: #fff;
    font-weight: 900;
    min-height: 52px;
    margin-top: 0.35rem;
}

.login-submit:hover,
.login-submit:focus {
    color: #fff;
    filter: brightness(1.04);
}

.login-links {
    display: flex;
    justify-content: space-between;
    gap: 1rem;
    margin-top: 1.15rem;
}

.login-links a {
    color: var(--wc-blue);
    font-weight: 800;
    text-decoration: none;
}

.login-links a:hover {
    color: var(--wc-teal);
}

.register-page {
    background:
        radial-gradient(circle at 8% 5%, rgba(51, 169, 160, 0.16), transparent 25rem),
        radial-gradient(circle at 96% 8%, rgba(196, 232, 29, 0.22), transparent 24rem),
        linear-gradient(135deg, #f7fbfd 0%, #ffffff 48%, #eef8f6 100%);
    min-height: 100vh;
}

.register-shell {
    display: grid;
    grid-template-columns: minmax(360px, 0.9fr) minmax(480px, 1.1fr);
    margin: 0 auto;
    max-width: 1320px;
    min-height: 100vh;
    padding: clamp(1rem, 4vw, 3.75rem);
}

.register-brand-panel,
.register-card {
    border: 1px solid rgba(51, 82, 138, 0.1);
    box-shadow: 0 24px 70px rgba(20, 32, 51, 0.12);
}

.register-brand-panel {
    align-content: space-between;
    background:
        radial-gradient(circle at 12% 8%, rgba(51, 169, 160, 0.18), transparent 16rem),
        radial-gradient(circle at 100% 94%, rgba(196, 232, 29, 0.22), transparent 18rem),
        #ffffff;
    border-radius: 28px 0 0 28px;
    display: grid;
    overflow: hidden;
    padding: clamp(1.75rem, 4vw, 3.5rem);
    position: relative;
}

.register-brand-panel::before {
    background-image: radial-gradient(rgba(51, 169, 160, 0.34) 1.3px, transparent 1.3px);
    background-size: 12px 12px;
    content: "";
    height: 310px;
    left: -88px;
    opacity: 0.42;
    position: absolute;
    top: -80px;
    transform: rotate(-10deg);
    width: 410px;
}

.register-brand,
.register-brand-copy,
.register-brand-list,
.register-login-link {
    position: relative;
    z-index: 1;
}

.register-brand {
    align-items: center;
    color: #07183d;
    display: inline-flex;
    flex-wrap: wrap;
    gap: 0.7rem;
    text-decoration: none;
}

.register-brand img {
    height: 52px;
    width: 52px;
}

.register-brand span {
    font-size: 1.65rem;
    font-weight: 900;
    letter-spacing: -0.035em;
}

.register-brand small {
    color: var(--wc-green);
    font-size: 0.68rem;
    font-weight: 900;
    letter-spacing: 0.18em;
    text-transform: uppercase;
}

.register-brand-copy p {
    color: var(--wc-teal);
    font-size: 0.78rem;
    font-weight: 900;
    letter-spacing: 0.22em;
    margin-bottom: 1rem;
    text-transform: uppercase;
}

.register-brand-copy h1 {
    color: #07183d;
    font-size: clamp(2.4rem, 4.6vw, 4.6rem);
    font-weight: 900;
    letter-spacing: -0.055em;
    line-height: 0.98;
    margin: 0;
}

.register-brand-copy span {
    color: #506077;
    display: block;
    font-size: 1.08rem;
    line-height: 1.65;
    margin-top: 1.3rem;
    max-width: 520px;
}

.register-brand-list {
    display: grid;
    gap: 0.75rem;
}

.register-brand-list div {
    align-items: center;
    background: rgba(255, 255, 255, 0.78);
    border: 1px solid rgba(51, 169, 160, 0.16);
    border-radius: 16px;
    color: #23324c;
    display: flex;
    font-weight: 800;
    gap: 0.75rem;
    padding: 0.82rem 0.95rem;
}

.register-brand-list i {
    color: var(--wc-teal);
}

.register-login-link {
    color: #5f6d82;
    margin: 0;
}

.register-login-link a {
    color: var(--wc-blue);
    font-weight: 900;
    text-decoration: none;
}

.register-card-wrap {
    align-items: center;
    display: flex;
}

.register-card {
    background: rgba(255, 255, 255, 0.96);
    border-radius: 0 28px 28px 0;
    min-height: 696px;
    padding: clamp(1.5rem, 4vw, 3.4rem);
    width: 100%;
}

.register-card-head {
    align-items: flex-start;
    display: flex;
    gap: 1rem;
    justify-content: space-between;
    margin-bottom: 1.65rem;
}

.register-card-head p {
    color: var(--wc-teal);
    font-size: 0.78rem;
    font-weight: 900;
    letter-spacing: 0.18em;
    margin: 0 0 0.35rem;
    text-transform: uppercase;
}

.register-card-head h2 {
    color: #07183d;
    font-size: 2rem;
    font-weight: 900;
    margin: 0;
}

.register-card-head span {
    color: var(--wc-muted);
    display: block;
    margin-top: 0.3rem;
}

.register-steps {
    display: grid;
    gap: 0.75rem;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    margin-bottom: 1.5rem;
}

.register-step {
    align-items: center;
    background: #fff;
    border: 1px solid var(--wc-border);
    border-radius: 16px;
    color: #516178;
    display: flex;
    font-weight: 800;
    gap: 0.55rem;
    justify-content: center;
    min-height: 58px;
    padding: 0.75rem;
}

.register-step span {
    align-items: center;
    background: #edf4f7;
    border-radius: 999px;
    display: inline-flex;
    height: 28px;
    justify-content: center;
    width: 28px;
}

.register-step.active,
.register-step.done {
    background: linear-gradient(135deg, var(--wc-blue), var(--wc-teal));
    border-color: transparent;
    color: #fff;
}

.register-step.active span,
.register-step.done span {
    background: rgba(255, 255, 255, 0.2);
}

.wizard-step {
    display: none;
}

.wizard-step.active {
    display: block;
}

.register-field {
    margin-bottom: 1rem;
}

.register-field .form-label {
    color: #24324a;
    font-weight: 800;
    margin-bottom: 0.45rem;
}

.register-input,
.register-password {
    align-items: center;
    background: #fff;
    border: 1px solid #dce6ef;
    border-radius: 14px;
    display: flex;
    overflow: hidden;
}

.register-input i,
.register-password > i {
    color: #70809b;
    margin-left: 1rem;
}

.register-input .form-control,
.register-password .form-control {
    border: 0;
    box-shadow: none;
    min-height: 52px;
}

.register-select {
    border-color: #dce6ef;
    border-radius: 14px;
    min-height: 52px;
}

.register-note {
    align-items: center;
    background: rgba(51, 169, 160, 0.1);
    border: 1px solid rgba(51, 169, 160, 0.22);
    border-radius: 16px;
    color: #14756e;
    display: flex;
    gap: 0.75rem;
    padding: 0.9rem 1rem;
}

.register-actions {
    align-items: center;
    display: flex;
    justify-content: space-between;
    margin-top: 1.5rem;
}

.register-submit {
    background: linear-gradient(135deg, var(--wc-blue), var(--wc-teal));
    border: 0;
    border-radius: 14px;
    color: #fff;
    font-weight: 900;
    min-height: 48px;
    min-width: 150px;
}

.register-submit:hover,
.register-submit:focus {
    color: #fff;
    filter: brightness(1.04);
}

h1,
h2,
h3,
h4,
h5,
h6,
.wc-heading {
    font-family: "Plus Jakarta Sans", system-ui, -apple-system, "Segoe UI", sans-serif;
    font-weight: 500;
}

.navbar-brand {
    font-weight: 600;
}

.app-navbar {
    background: rgba(255, 255, 255, 0.92);
    border-bottom: 1px solid var(--wc-border);
    box-shadow: 0 8px 28px rgba(20, 32, 51, 0.05);
    backdrop-filter: blur(14px);
    position: relative;
    z-index: 1100;
}

.app-navbar .dropdown-menu {
    z-index: 1110;
}

.app-navbar .container-fluid {
    gap: 1rem;
    max-width: 1680px;
    min-height: 72px;
    padding-left: clamp(1rem, 2vw, 2rem);
    padding-right: clamp(1rem, 2vw, 2rem);
}

.app-navbar .navbar-collapse {
    min-width: 0;
    overflow-x: clip;   /* evita que items desborden sin bloquear dropdowns */
}

.app-navbar .navbar-nav {
    align-items: center;
    flex-wrap: nowrap;
    gap: 0.15rem;
    min-width: 0;
}

.app-navbar .nav-link {
    color: #526174;
    font-weight: 500;
    padding-left: 0.55rem;
    padding-right: 0.55rem;
    white-space: nowrap;
}

.app-navbar .nav-link:hover,
.app-navbar .nav-link:focus {
    color: var(--wc-blue);
}

.app-brand {
    align-items: center;
    color: var(--wc-blue) !important;
    display: inline-flex;
    flex-shrink: 0;
    gap: 0.55rem;
    letter-spacing: -0.02em;
    margin-right: clamp(0.75rem, 2vw, 2rem);
}

.app-brand img {
    filter: drop-shadow(0 8px 16px rgba(51, 169, 160, 0.18));
}

.app-brand span {
    font-weight: 800;
}

.app-brand small {
    color: var(--wc-green);
    font-size: 0.68rem;
    font-weight: 800;
    letter-spacing: 0.18em;
    margin-left: 0.1rem;
    text-transform: uppercase;
}

.app-user-chip {
    flex-shrink: 0;
    gap: 0.75rem;
    margin-left: 1rem;
    white-space: nowrap;
}

.app-user-chip span {
    color: var(--wc-text);
    font-weight: 600;
}

.role-module {
    align-items: flex-start;
    border: 1px solid var(--wc-border);
    border-radius: 12px;
    display: flex;
    gap: 0.55rem;
    padding: 0.65rem 0.75rem;
}

.role-module-child {
    background: #f8fbfd;
    margin-left: 1.3rem;
}

.role-module .form-check-input {
    margin-top: 0.18rem;
}

.role-module .form-check-label {
    display: grid;
    gap: 0.12rem;
    line-height: 1.25;
}

.role-module .form-check-label strong {
    color: var(--wc-text);
    font-weight: 700;
}

.role-module .form-check-label small {
    color: var(--wc-muted);
    font-size: 0.78rem;
}

@media (max-width: 1399px) {
    .app-navbar .nav-link {
        font-size: 0.94rem;
        padding-left: 0.42rem;
        padding-right: 0.42rem;
    }

    .app-brand {
        margin-right: 0.75rem;
    }
}

@media (max-width: 1199px) {
    .app-navbar .container-fluid {
        min-height: 64px;
    }

    .app-navbar .navbar-collapse {
        border-top: 1px solid var(--wc-border);
        margin-top: 0.75rem;
        padding-top: 0.75rem;
    }

    .app-navbar .navbar-nav {
        align-items: stretch;
    }

    .app-user-chip {
        align-items: flex-start !important;
        flex-direction: column;
        gap: 0.5rem;
        margin-left: 0;
        margin-top: 0.75rem;
    }
}

.app-wide-container {
    max-width: 1480px;
    padding-left: clamp(1rem, 2vw, 2rem);
    padding-right: clamp(1rem, 2vw, 2rem);
}

.card {
    border: 0;
}

.dashboard-page {
    background:
        radial-gradient(circle at 8% 0%, rgba(51, 169, 160, 0.13), transparent 28rem),
        radial-gradient(circle at 100% 6%, rgba(196, 232, 29, 0.16), transparent 24rem),
        var(--wc-bg);
}

.wc-dashboard {
    padding-bottom: 2rem;
}

.wc-hero {
    align-items: center;
    background:
        radial-gradient(circle at 88% 18%, rgba(196, 232, 29, 0.22), transparent 16rem),
        radial-gradient(circle at 0% 100%, rgba(51, 169, 160, 0.26), transparent 18rem),
        linear-gradient(135deg, #ffffff 0%, #f7fbfd 100%);
    border: 1px solid rgba(51, 169, 160, 0.16);
    border-radius: 28px;
    box-shadow: var(--wc-shadow);
    display: flex;
    justify-content: space-between;
    margin-bottom: 1.25rem;
    overflow: hidden;
    padding: clamp(1.35rem, 3vw, 2.35rem);
    position: relative;
}

.wc-hero::before,
.wc-hero::after {
    border-radius: 999px;
    content: "";
    position: absolute;
}

.wc-hero::before {
    background-image: radial-gradient(rgba(51, 169, 160, 0.28) 1px, transparent 1px);
    background-size: 10px 10px;
    height: 190px;
    left: -70px;
    opacity: 0.38;
    top: -75px;
    width: 270px;
}

.wc-hero::after {
    background: rgba(196, 232, 29, 0.18);
    height: 170px;
    right: -64px;
    top: -70px;
    width: 170px;
}

.wc-hero-copy,
.wc-hero-brand {
    position: relative;
    z-index: 1;
}

.wc-hero h1 {
    color: var(--wc-blue);
    font-size: clamp(2rem, 4vw, 3.4rem);
    font-weight: 850;
    letter-spacing: -0.05em;
    margin: 0.25rem 0 0.6rem;
}

.wc-hero p {
    color: var(--wc-muted);
    font-size: 1.05rem;
    max-width: 680px;
}

.wc-hero-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 0.75rem;
    margin-top: 1.2rem;
}

.wc-hero .btn-light {
    border: 1px solid rgba(51, 82, 138, 0.12);
    color: var(--wc-blue);
    font-weight: 700;
}

.wc-hero .btn-outline-light {
    border-color: rgba(51, 82, 138, 0.22);
    color: var(--wc-blue);
    font-weight: 700;
}

.wc-hero-brand {
    align-items: center;
    background: rgba(255, 255, 255, 0.7);
    border: 1px solid rgba(51, 169, 160, 0.16);
    border-radius: 26px;
    display: flex;
    flex-shrink: 0;
    height: 142px;
    justify-content: center;
    width: 172px;
}

.wc-hero-brand img {
    height: 110px;
    width: 110px;
}

.wc-eyebrow {
    color: var(--wc-teal);
    display: inline-block;
    font-size: 0.73rem;
    font-weight: 800;
    letter-spacing: 0.08em;
    text-transform: uppercase;
}

.wc-metrics-grid {
    display: grid;
    gap: 1rem;
    grid-template-columns: repeat(6, minmax(0, 1fr));
    margin-bottom: 1.5rem;
}

.wc-metric-card,
.wc-panel {
    background: var(--wc-card);
    border: 1px solid var(--wc-border);
    border-radius: var(--wc-radius);
    box-shadow: var(--wc-shadow);
}

.wc-metric-card {
    min-height: 150px;
    overflow: hidden;
    padding: 1.25rem;
    position: relative;
}

.wc-metric-card::after {
    background: var(--metric-color, var(--wc-teal));
    border-radius: 999px;
    content: "";
    height: 54px;
    opacity: 0.12;
    position: absolute;
    right: 18px;
    top: 18px;
    width: 54px;
}

.wc-metric-card strong {
    color: var(--wc-text);
    display: block;
    font-size: clamp(1.65rem, 2.2vw, 2.35rem);
    letter-spacing: -0.05em;
    line-height: 1.05;
    margin-top: 1rem;
}

.wc-metric-card small {
    color: var(--wc-muted);
    display: block;
    margin-top: 0.4rem;
}

.accent-blue { --metric-color: var(--wc-blue); }
.accent-teal { --metric-color: var(--wc-teal); }
.accent-lime { --metric-color: var(--wc-lime); }
.accent-green { --metric-color: var(--wc-green); }
.accent-olive { --metric-color: var(--wc-olive); }

.wc-panel {
    padding: 1.35rem;
}

.wc-panel-header {
    align-items: center;
    display: flex;
    justify-content: space-between;
    gap: 1rem;
    margin-bottom: 1.1rem;
}

.wc-panel-header h2 {
    color: var(--wc-text);
    font-size: 1.1rem;
    font-weight: 800;
    margin: 0.15rem 0 0;
}

.wc-panel-header > strong {
    color: var(--wc-teal);
    font-size: 1.75rem;
}

.wc-panel-header a,
.wc-panel-header span {
    color: var(--wc-muted);
    font-size: 0.9rem;
    text-decoration: none;
}

.wc-health-card {
    align-items: center;
    background: linear-gradient(135deg, rgba(51, 169, 160, 0.10), rgba(196, 232, 29, 0.12));
    border: 1px solid rgba(51, 169, 160, 0.17);
    border-radius: 20px;
    display: flex;
    gap: 1rem;
    padding: 1rem;
}

.wc-health-card p {
    color: var(--wc-muted);
    margin: 0.2rem 0 0.65rem;
}

.wc-health-icon,
.wc-avatar {
    align-items: center;
    border-radius: 50%;
    display: inline-flex;
    flex-shrink: 0;
    font-weight: 800;
    justify-content: center;
}

.wc-health-icon {
    background: rgba(51, 169, 160, 0.14);
    color: var(--wc-teal);
    height: 48px;
    width: 48px;
}

.wc-progress {
    background: rgba(51, 82, 138, 0.08);
    border-radius: 999px;
    height: 9px;
    overflow: hidden;
}

.wc-progress span {
    background: var(--wc-gradient);
    border-radius: inherit;
    display: block;
    height: 100%;
}

.wc-quick-actions {
    display: grid;
    gap: 0.75rem;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    margin-top: 1rem;
}

.wc-quick-actions a {
    background: #fff;
    border: 1px solid var(--wc-border);
    border-radius: 16px;
    color: var(--wc-blue);
    font-weight: 700;
    padding: 0.9rem 1rem;
    text-decoration: none;
}

.wc-quick-actions a:hover {
    border-color: rgba(51, 169, 160, 0.45);
    color: var(--wc-teal);
}

.wc-recent-list {
    display: grid;
    gap: 0.75rem;
}

.wc-recent-item {
    align-items: center;
    border: 1px solid transparent;
    border-radius: 16px;
    display: grid;
    gap: 0.75rem;
    grid-template-columns: 44px minmax(0, 1fr) auto;
    padding: 0.65rem;
}

.wc-recent-item:hover {
    background: #f8fbfc;
    border-color: var(--wc-border);
}

.wc-avatar {
    background: var(--wc-gradient);
    color: #fff;
    height: 42px;
    width: 42px;
}

.wc-recent-item strong,
.wc-recent-item small {
    display: block;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.wc-recent-item small,
.wc-recent-item time {
    color: var(--wc-muted);
    font-size: 0.82rem;
}

.wc-stage-bars {
    display: grid;
    gap: 0.85rem;
}

.wc-stage-row {
    align-items: center;
    display: grid;
    gap: 1rem;
    grid-template-columns: 180px minmax(160px, 1fr) 100px;
}

.wc-stage-label {
    align-items: center;
    display: flex;
    gap: 0.5rem;
    justify-content: flex-end;
}

.wc-stage-label span {
    background: #eef4f5;
    border-radius: 999px;
    color: var(--wc-muted);
    font-size: 0.75rem;
    font-weight: 800;
    padding: 0.12rem 0.55rem;
}

.wc-stage-track {
    background: #f0f5f7;
    border-radius: 999px;
    height: 24px;
    overflow: hidden;
}

.wc-stage-track span {
    border-radius: inherit;
    display: block;
    height: 100%;
}

.stage-color-0 { background: var(--wc-blue); }
.stage-color-1 { background: var(--wc-teal); }
.stage-color-2 { background: var(--wc-lime); }
.stage-color-3 { background: var(--wc-green); }
.stage-color-4 { background: var(--wc-olive); }

.wc-stage-value {
    color: var(--wc-muted);
    font-weight: 700;
    text-align: right;
}

@media (max-width: 1399px) {
    .wc-metrics-grid {
        grid-template-columns: repeat(3, minmax(0, 1fr));
    }
}

@media (max-width: 991px) {
    .wc-hero {
        align-items: flex-start;
        flex-direction: column;
    }

    .wc-hero-brand {
        height: 108px;
        width: 132px;
    }

    .wc-hero-brand img {
        height: 84px;
        width: 84px;
    }

    .wc-quick-actions {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
}

@media (max-width: 767px) {
    .wc-metrics-grid {
        grid-template-columns: 1fr;
    }

    .wc-health-card {
        align-items: flex-start;
        flex-direction: column;
    }

    .wc-stage-row {
        grid-template-columns: 1fr;
        gap: 0.4rem;
    }

    .wc-stage-label {
        justify-content: space-between;
    }

    .wc-stage-value {
        text-align: left;
    }
}

.table td, .table th {
    vertical-align: middle;
}

.password-field {
    position: relative;
}

.password-field .form-control {
    padding-right: 3rem;
}

.password-toggle {
    align-items: center;
    background: transparent;
    border: 0;
    color: #667085;
    display: inline-flex;
    height: 100%;
    justify-content: center;
    padding: 0 0.85rem;
    position: absolute;
    right: 0;
    top: 0;
}

.password-toggle:hover,
.password-toggle:focus {
    color: #0f1117;
}

.password-toggle:focus-visible {
    border-radius: 0.375rem;
    outline: 2px solid #0d6efd;
    outline-offset: -2px;
}

.password-toggle svg {
    height: 20px;
    width: 20px;
}

.linea-qr-box {
    align-items: center;
    background: #f8f9fa;
    border: 1px solid #e9ecef;
    border-radius: 0.75rem;
    display: flex;
    justify-content: center;
    margin: 0 auto;
    min-height: 288px;
    padding: 1rem;
    width: 288px;
}

.linea-qr-box img {
    height: 256px;
    width: 256px;
}

@keyframes linea-status-pulse {
    0%, 100% { opacity: 1; }
    50% { opacity: 0.45; }
}

.linea-badge-pulse {
    animation: linea-status-pulse 1.2s ease-in-out infinite;
}

.inbox-page {
    background: #f0f2f5;
    display: flex;
    flex-direction: column;
    height: 100vh;
    overflow: hidden;
}

.inbox-main-nav {
    flex-shrink: 0;
    min-height: 56px;
}

.inbox-page-container {
    flex: 1;
    min-height: 0;
    overflow: hidden;
    padding: 0;
}

.inbox-shell {
    background: #fff;
    display: grid;
    grid-template-columns: 355px minmax(420px, 1fr) 305px;
    height: 100%;
    margin: 0;
    width: 100%;
}

.inbox-sidebar,
.inbox-chat,
.inbox-contact {
    height: 100%;
    overflow: hidden;
}

.inbox-sidebar {
    background: #fff;
    border-right: 1px solid #d1d7db;
}

.inbox-sidebar-header,
.inbox-chat-header,
.inbox-detail-header {
    align-items: center;
    background: #f0f2f5;
    border-bottom: 1px solid #d1d7db;
    display: flex;
}

.inbox-sidebar-header {
    height: 64px;
    justify-content: space-between;
    padding: 0 16px 0 20px;
}

.inbox-sidebar-header h1 {
    color: #111b21;
    font-size: 1.35rem;
    font-weight: 600;
    line-height: 1.15;
    margin: 0;
}

.inbox-sidebar-header span {
    color: #667781;
    font-size: 0.75rem;
}

.inbox-icon-button,
.inbox-compose-tool,
.inbox-send-button {
    align-items: center;
    background: transparent;
    border: 0;
    border-radius: 50%;
    color: #54656f;
    display: inline-flex;
    height: 42px;
    justify-content: center;
    width: 42px;
}

.inbox-icon-button:hover,
.inbox-compose-tool:hover {
    background: #dfe3e5;
}

.inbox-icon-button svg,
.inbox-compose-tool svg,
.inbox-send-button svg {
    fill: none;
    height: 22px;
    stroke: currentColor;
    stroke-linecap: round;
    stroke-linejoin: round;
    stroke-width: 1.8;
    width: 22px;
}

.inbox-search {
    align-items: center;
    background: #fff;
    border-bottom: 1px solid #f0f2f5;
    display: flex;
    height: 58px;
    padding: 8px 12px;
    position: relative;
}

.inbox-search svg {
    color: #54656f;
    fill: none;
    height: 19px;
    left: 27px;
    position: absolute;
    stroke: currentColor;
    stroke-linecap: round;
    stroke-width: 2;
    width: 19px;
}

.inbox-search input {
    background: #f0f2f5;
    border: 0;
    border-radius: 8px;
    color: #111b21;
    height: 40px;
    outline: none;
    padding: 0 14px 0 51px;
    width: 100%;
}

.inbox-conversation-list {
    height: calc(100% - 122px);
    overflow-y: auto;
}

.inbox-conversation {
    align-items: center;
    background: #fff;
    border: 0;
    display: grid;
    gap: 0 14px;
    grid-template-columns: 50px minmax(0, 1fr);
    min-height: 74px;
    padding: 0 13px;
    position: relative;
    text-align: left;
    width: 100%;
}

.inbox-conversation::after {
    background: #e9edef;
    bottom: 0;
    content: "";
    height: 1px;
    left: 77px;
    position: absolute;
    right: 0;
}

.inbox-conversation:hover,
.inbox-conversation.active {
    background: #f0f2f5;
}

.inbox-avatar {
    align-items: center;
    background: #d9e3e6;
    border-radius: 50%;
    color: #54656f;
    display: inline-flex;
    flex-shrink: 0;
    font-size: 0.9rem;
    font-weight: 600;
    height: 48px;
    justify-content: center;
    letter-spacing: 0.03em;
    width: 48px;
}

.inbox-avatar.group {
    background: #d9fdd3;
    color: #008069;
}

.wc-pipeline-page {
    display: grid;
    gap: 1.25rem;
    padding-bottom: 2rem;
}

.wc-pipeline-hero,
.wc-pipeline-board-card,
.wc-closed-card {
    background: #fff;
    border: 1px solid var(--wc-border);
    border-radius: 20px;
    box-shadow: 0 14px 34px rgba(20, 32, 51, 0.055);
}

.wc-pipeline-hero {
    align-items: center;
    display: flex;
    gap: 1.5rem;
    justify-content: space-between;
    padding: 1.35rem;
}

.wc-pipeline-title {
    align-items: center;
    display: flex;
    gap: 1rem;
}

.wc-pipeline-icon {
    align-items: center;
    background: linear-gradient(135deg, rgba(51, 169, 160, 0.18), rgba(196, 232, 29, 0.22));
    border-radius: 16px;
    color: var(--wc-blue);
    display: inline-flex;
    font-size: 1.25rem;
    height: 54px;
    justify-content: center;
    width: 54px;
}

.wc-pipeline-title h1 {
    color: #07122f;
    font-size: clamp(1.65rem, 2.4vw, 2.25rem);
    letter-spacing: -0.04em;
    margin: 0.08rem 0 0.25rem;
}

.wc-pipeline-title p,
.wc-board-head p {
    color: #617087;
    margin: 0;
}

.wc-pipeline-actions {
    align-items: center;
    display: flex;
    flex-wrap: wrap;
    gap: 0.75rem;
    justify-content: flex-end;
}

.wc-pipeline-search {
    align-items: center;
    background: #fff;
    border: 1px solid var(--wc-border);
    border-radius: 14px;
    color: #667085;
    display: flex;
    gap: 0.65rem;
    min-width: min(360px, 100%);
    padding: 0.78rem 0.95rem;
}

.wc-pipeline-search input {
    border: 0;
    outline: none;
    width: 100%;
}

.wc-soft-btn {
    border: 1px solid var(--wc-border);
    color: var(--wc-blue);
    font-weight: 700;
}

.wc-flow-select {
    border-color: var(--wc-border);
    border-radius: 14px;
    color: var(--wc-blue);
    font-weight: 700;
    min-height: 46px;
    min-width: 190px;
}

.wc-primary-action {
    align-items: center;
    display: inline-flex;
    gap: 0.45rem;
    font-weight: 800;
}

.wc-pipeline-summary {
    display: grid;
    gap: 0.9rem;
    grid-template-columns: repeat(6, minmax(0, 1fr));
}

.pipeline-metric {
    align-items: center;
    background: #fff;
    border: 1px solid var(--wc-border);
    border-radius: 18px;
    box-shadow: 0 10px 26px rgba(20, 32, 51, 0.045);
    display: grid;
    gap: 0.8rem;
    grid-template-columns: 44px minmax(0, 1fr);
    padding: 1rem;
}

.pipeline-metric span {
    align-items: center;
    background: rgba(51, 169, 160, 0.13);
    border-radius: 14px;
    color: var(--wc-teal);
    display: inline-flex;
    height: 44px;
    justify-content: center;
    width: 44px;
}

.pipeline-metric strong {
    color: #07122f;
    display: block;
    font-size: 1.4rem;
    line-height: 1.05;
}

.pipeline-metric small {
    color: #667085;
}

.wc-pipeline-board-card,
.wc-closed-card,
.wc-forecast-card {
    padding: 1.25rem;
}

.wc-forecast-card {
    background: #fff;
    border: 1px solid var(--wc-border);
    border-radius: 20px;
    box-shadow: 0 14px 34px rgba(20, 32, 51, 0.055);
}

.wc-forecast-bars {
    display: grid;
    gap: 0.7rem;
}

.wc-forecast-row {
    align-items: center;
    display: grid;
    gap: 0.85rem;
    grid-template-columns: 170px minmax(0, 1fr) 130px;
}

.wc-forecast-row span {
    color: #344054;
    font-weight: 800;
}

.wc-forecast-row span em {
    background: #e9eff6;
    border-radius: 999px;
    color: #667085;
    font-size: 0.72rem;
    font-style: normal;
    margin-left: 0.35rem;
    padding: 0.15rem 0.48rem;
}

.wc-forecast-row div {
    background: #edf2f7;
    border-radius: 999px;
    height: 12px;
    overflow: hidden;
}

.wc-forecast-row i {
    background: linear-gradient(90deg, #33A9A0, #C4E81D);
    border-radius: inherit;
    display: block;
    height: 100%;
}

.wc-forecast-row strong {
    color: #07122f;
    text-align: right;
}

.wc-board-head {
    align-items: flex-start;
    display: flex;
    gap: 1rem;
    justify-content: space-between;
    margin-bottom: 1.1rem;
}

.wc-board-head h2 {
    color: #07122f;
    font-size: 1.2rem;
    margin: 0 0 0.25rem;
}

.wc-board-hint {
    color: #7a8599;
    font-size: 0.88rem;
    white-space: nowrap;
}

.kanban-board {
    display: flex;
    gap: 1rem;
    overflow-x: auto;
    padding: 0.25rem 0.1rem 1rem;
    scrollbar-color: rgba(51, 82, 138, 0.35) transparent;
}

.kanban-board::-webkit-scrollbar {
    height: 10px;
}

.kanban-board::-webkit-scrollbar-thumb {
    background: rgba(51, 82, 138, 0.28);
    border-radius: 999px;
}

.kanban-column {
    background: #f8fbfd;
    border: 1px solid var(--wc-border);
    border-radius: 20px;
    flex: 0 0 318px;
    min-height: 360px;
    padding: 1rem;
    position: relative;
}

.kanban-column::before {
    background: var(--wc-blue);
    border-radius: 999px 999px 0 0;
    content: "";
    height: 4px;
    left: 14px;
    position: absolute;
    right: 14px;
    top: 0;
}

.kanban-column:nth-child(2)::before { background: #2f80ed; }
.kanban-column:nth-child(3)::before { background: #f59e0b; }
.kanban-column:nth-child(4)::before { background: #f97316; }
.kanban-column:nth-child(5)::before { background: #22c55e; }

.kanban-column-header {
    align-items: center;
    display: flex;
    justify-content: space-between;
    margin-bottom: 0.35rem;
}

.kanban-column-header > div {
    align-items: center;
    display: flex;
    gap: 0.55rem;
}

.kanban-stage-dot {
    background: var(--wc-blue);
    border-radius: 50%;
    box-shadow: 0 0 0 4px rgba(51, 82, 138, 0.12);
    height: 10px;
    width: 10px;
}

.kanban-column:nth-child(2) .kanban-stage-dot { background: #2f80ed; box-shadow: 0 0 0 4px rgba(47, 128, 237, 0.12); }
.kanban-column:nth-child(3) .kanban-stage-dot { background: #f59e0b; box-shadow: 0 0 0 4px rgba(245, 158, 11, 0.13); }
.kanban-column:nth-child(4) .kanban-stage-dot { background: #f97316; box-shadow: 0 0 0 4px rgba(249, 115, 22, 0.13); }
.kanban-column:nth-child(5) .kanban-stage-dot { background: #22c55e; box-shadow: 0 0 0 4px rgba(34, 197, 94, 0.13); }

.kanban-column h5 {
    color: #142033;
    font-size: 1rem;
}

.kanban-column-count {
    background: #e9eff6;
    border-radius: 999px;
    color: #526174;
    font-size: 0.78rem;
    font-weight: 800;
    min-width: 28px;
    padding: 0.22rem 0.55rem;
    text-align: center;
}

.kanban-column-total {
    color: #5f7192;
    font-weight: 700;
    margin-bottom: 1rem;
    padding-left: 1.1rem;
}

.kanban-column-list {
    display: grid;
    gap: 0.8rem;
    min-height: 158px;
}

.kanban-add-card {
    align-items: center;
    background: rgba(255, 255, 255, 0.7);
    border: 1px dashed rgba(51, 82, 138, 0.24);
    border-radius: 14px;
    color: #5f7192;
    display: inline-flex;
    font-weight: 700;
    gap: 0.5rem;
    justify-content: center;
    margin-top: 0.85rem;
    padding: 0.82rem;
    width: 100%;
}

.kanban-add-card:hover {
    background: #fff;
    border-color: rgba(51, 169, 160, 0.5);
    color: var(--wc-teal);
}

.kanban-column.drag-over {
    background: rgba(51, 169, 160, 0.08);
    border-color: rgba(51, 169, 160, 0.45);
}

.deal-card {
    border: 1px solid rgba(51, 82, 138, 0.12);
    border-radius: 18px;
    box-shadow: 0 10px 24px rgba(20, 32, 51, 0.055);
    cursor: grab;
    overflow: hidden;
    position: relative;
}

.deal-card::before {
    background: linear-gradient(180deg, rgba(51, 82, 138, 0.62), rgba(51, 169, 160, 0.42));
    border-radius: 999px;
    bottom: 18px;
    content: "";
    left: 0;
    position: absolute;
    top: 18px;
    width: 3px;
}

.deal-card:active {
    cursor: grabbing;
}

.deal-card-title {
    align-items: flex-start;
    display: flex;
    gap: 0.75rem;
    justify-content: space-between;
}

.deal-card-title strong {
    color: #142033;
}

.deal-card-title .btn-link {
    color: #94a3b8;
}

.deal-card-meta small {
    align-items: center;
    display: inline-flex;
}

.deal-value-pill {
    background: rgba(51, 169, 160, 0.12);
    border-radius: 999px;
    color: #00866f;
    font-weight: 800;
    padding: 0.22rem 0.58rem;
}

.deal-alert {
    align-items: center;
    background: #fff4ce;
    border-radius: 999px;
    color: #9a6700;
    display: inline-flex;
    font-size: 0.72rem;
    font-weight: 800;
    gap: 0.35rem;
    margin-bottom: 0.45rem;
    padding: 0.26rem 0.58rem;
}

.deal-card .card-footer {
    padding-top: 0;
    padding-bottom: 0.9rem;
}

.wc-empty-inline {
    align-items: center;
    background: #f8fbfd;
    border: 1px dashed var(--wc-border);
    border-radius: 16px;
    color: #667085;
    display: flex;
    gap: 0.65rem;
    padding: 1rem;
}

.wc-deal-offcanvas {
    border-left: 1px solid var(--wc-border);
    width: min(520px, 100vw) !important;
}

.wc-deal-offcanvas .offcanvas-header {
    align-items: flex-start;
    border-bottom: 1px solid var(--wc-border);
    padding: 1.35rem 1.45rem;
}

.wc-deal-offcanvas .offcanvas-title {
    color: #07122f;
    font-size: 1.35rem;
    margin: 0.1rem 0 0;
}

.wc-deal-form .form-label {
    color: #344054;
    font-weight: 700;
}

.wc-deal-form .form-control,
.wc-deal-form .form-select {
    border-color: #dbe4ea;
    border-radius: 14px;
    padding: 0.78rem 0.9rem;
}

.wc-deal-form .form-control:focus,
.wc-deal-form .form-select:focus {
    border-color: rgba(51, 169, 160, 0.72);
    box-shadow: 0 0 0 0.2rem rgba(51, 169, 160, 0.12);
}

.wc-close-panel {
    align-items: center;
    background: linear-gradient(135deg, rgba(51, 169, 160, 0.1), rgba(196, 232, 29, 0.12));
    border: 1px solid rgba(51, 169, 160, 0.2);
    border-radius: 18px;
    display: flex;
    gap: 1rem;
    justify-content: space-between;
    margin-top: 1rem;
    padding: 1rem;
}

.wc-deal-activity {
    border-top: 1px solid var(--wc-border);
    margin-top: 1rem;
    padding-top: 1rem;
}

.wc-deal-activity-head {
    display: flex;
    justify-content: space-between;
    margin-bottom: 0.75rem;
}

.wc-deal-activity-head strong,
.wc-deal-activity-head small {
    display: block;
}

.wc-deal-activity-head strong {
    color: #142033;
}

.wc-deal-activity-head small {
    color: #667085;
}

.wc-activity-row {
    background: #f8fbfd;
    border: 1px solid var(--wc-border);
    border-radius: 14px;
    margin-bottom: 0.55rem;
    padding: 0.75rem;
}

.wc-activity-row span {
    color: var(--wc-teal);
    display: block;
    font-size: 0.72rem;
    font-weight: 900;
    text-transform: uppercase;
}

.wc-activity-row p {
    color: #142033;
    margin: 0.2rem 0;
}

.wc-activity-row small {
    color: #667085;
}

.wc-close-panel strong,
.wc-close-panel small {
    display: block;
}

.wc-close-panel strong {
    color: #142033;
    font-size: 1rem;
}

.wc-close-panel small {
    color: #667085;
    line-height: 1.35;
    margin-top: 0.2rem;
}

.wc-close-panel-kicker {
    color: var(--wc-teal);
    display: block;
    font-size: 0.72rem;
    font-weight: 800;
    letter-spacing: 0.08em;
    margin-bottom: 0.2rem;
    text-transform: uppercase;
}

.wc-close-panel-actions {
    display: flex;
    flex-shrink: 0;
    flex-wrap: wrap;
    gap: 0.5rem;
    justify-content: flex-end;
}

.wc-settings-block {
    border-bottom: 1px solid var(--wc-border);
    margin-bottom: 1.1rem;
    padding-bottom: 1.1rem;
}

.wc-settings-block .form-label {
    color: #344054;
    font-weight: 800;
}

.wc-settings-block small,
.wc-settings-danger small {
    color: #667085;
}

.wc-stage-settings-list {
    display: grid;
    gap: 0.75rem;
}

.wc-stage-settings-row {
    align-items: center;
    background: #f8fbfd;
    border: 1px solid var(--wc-border);
    border-radius: 16px;
    display: grid;
    gap: 0.6rem;
    grid-template-columns: 34px minmax(0, 1fr) auto auto auto;
    padding: 0.7rem;
}

.wc-stage-settings-row > span {
    align-items: center;
    background: rgba(51, 169, 160, 0.12);
    border-radius: 50%;
    color: var(--wc-teal);
    display: inline-flex;
    font-weight: 800;
    height: 30px;
    justify-content: center;
    width: 30px;
}

.wc-stage-order-actions {
    display: inline-flex;
    gap: 0.35rem;
}

.wc-stage-order-actions .btn {
    align-items: center;
    display: inline-flex;
    height: 32px;
    justify-content: center;
    padding: 0;
    width: 32px;
}

.wc-settings-danger {
    align-items: center;
    background: rgba(244, 63, 94, 0.055);
    border: 1px solid rgba(244, 63, 94, 0.16);
    border-radius: 18px;
    display: flex;
    gap: 1rem;
    justify-content: space-between;
    padding: 1rem;
}

.wc-settings-danger strong {
    color: #9f1239;
    display: block;
}

.wc-offcanvas-actions {
    align-items: center;
    border-top: 1px solid var(--wc-border);
    display: flex;
    gap: 0.75rem;
    justify-content: flex-end;
    margin: 1.5rem -1rem -0.5rem;
    padding: 1rem 1rem 0;
}

.inbox-conversation-copy {
    display: block;
    min-width: 0;
}

.inbox-conversation-top {
    align-items: baseline;
    display: flex;
    gap: 6px;
    justify-content: space-between;
    margin-bottom: 4px;
}

.inbox-conversation-top strong {
    color: #111b21;
    font-size: 1rem;
    font-weight: 500;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.inbox-conversation-top time {
    color: #667781;
    flex-shrink: 0;
    font-size: 0.72rem;
}

.inbox-conversation-preview {
    color: #667781;
    display: block;
    font-size: 0.86rem;
    overflow: hidden;
    padding-right: 50px;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.inbox-conversation-badges {
    display: flex;
    flex-wrap: wrap;
    gap: 4px;
    margin-top: 5px;
}

.inbox-mini-badge {
    border-radius: 999px;
    font-size: 0.64rem;
    font-weight: 700;
    line-height: 1;
    padding: 4px 7px;
    text-transform: uppercase;
}

.inbox-mini-badge.priority-alta {
    background: #fff4ce;
    color: #9a6700;
}

.inbox-mini-badge.priority-urgente,
.inbox-mini-badge.sentiment-negative {
    background: #fde7e9;
    color: #b42318;
}

.inbox-mini-badge.ia-paused {
    background: #e9eff6;
    color: #3b4a54;
}

.inbox-conversation-line {
    bottom: 10px;
    color: #00a884;
    font-size: 0.67rem;
    position: absolute;
    right: 13px;
}

.inbox-chat {
    background: #efeae2;
    border-right: 1px solid #d1d7db;
    position: relative;
}

.inbox-chat::before {
    background-image: radial-gradient(rgba(17, 27, 33, 0.045) 1px, transparent 1px);
    background-size: 13px 13px;
    bottom: 0;
    content: "";
    left: 0;
    opacity: 0.65;
    position: absolute;
    right: 0;
    top: 0;
}

.inbox-chat > * {
    position: relative;
    z-index: 1;
}

.inbox-empty-state {
    align-items: center;
    background: #f0f2f5;
    border-bottom: 6px solid #25d366;
    color: #41525d;
    display: flex;
    flex-direction: column;
    height: 100%;
    justify-content: center;
    text-align: center;
}

.inbox-empty-logo {
    color: #c4cdd2;
    margin-bottom: 20px;
}

.inbox-empty-logo svg {
    fill: none;
    height: 118px;
    stroke: currentColor;
    stroke-linecap: round;
    stroke-linejoin: round;
    stroke-width: 0.75;
    width: 118px;
}

.inbox-empty-state h3 {
    color: #41525d;
    font-size: 2rem;
    font-weight: 300;
    margin-bottom: 12px;
}

.inbox-empty-state p {
    color: #667781;
}

.inbox-chat-header {
    height: 64px;
    justify-content: space-between;
    padding: 0 18px;
}

.inbox-chat-person {
    align-items: center;
    display: flex;
    gap: 14px;
}

.inbox-chat-header .inbox-avatar {
    height: 42px;
    width: 42px;
}

.inbox-chat-header h3 {
    color: #111b21;
    font-size: 1rem;
    font-weight: 500;
    margin: 0 0 2px;
}

.inbox-chat-subtitle {
    color: #667781;
    font-size: 0.77rem;
}

.inbox-status-select {
    background-color: #f0f2f5;
    border-color: #c6ced3;
    color: #3b4a54;
    font-size: 0.83rem;
    width: 122px;
}

.inbox-messages {
    background: transparent;
    display: flex;
    flex: 1;
    flex-direction: column;
    gap: 4px;
    overflow-y: auto;
    padding: 20px max(7%, 24px) 16px;
}

.chat-bubble {
    border-radius: 8px;
    box-shadow: 0 1px 0.5px rgba(11, 20, 26, 0.13);
    color: #111b21;
    font-size: 0.9rem;
    line-height: 1.4;
    margin: 1px 0;
    max-width: min(68%, 560px);
    min-width: 88px;
    padding: 7px 10px 5px;
}

.chat-bubble small {
    color: #667781;
    display: block;
    font-size: 0.67rem;
    line-height: 1;
    margin-top: 5px;
    text-align: right;
}

.chat-sender {
    color: #008069;
    display: block;
    font-size: 0.78rem;
    font-weight: 600;
    margin-bottom: 2px;
}

.chat-bubble.incoming {
    align-self: flex-start;
    background: #fff;
    border-top-left-radius: 0;
}

.chat-bubble.outgoing {
    align-self: flex-end;
    background: #d9fdd3;
    border-top-right-radius: 0;
}

.inbox-compose {
    align-items: flex-end;
    background: #f0f2f5;
    display: flex;
    gap: 8px;
    min-height: 64px;
    padding: 10px 14px;
}

.inbox-compose textarea {
    background: #fff;
    border: 0;
    border-radius: 9px;
    flex: 1;
    max-height: 120px;
    min-height: 44px;
    outline: none;
    padding: 11px 14px;
    resize: vertical;
}

.inbox-send-button {
    background: #00a884;
    color: #fff;
}

.inbox-send-button:hover {
    background: #008f72;
}

.inbox-contact {
    background: #fff;
}

.inbox-detail-header {
    height: 64px;
    padding: 0 22px;
}

.inbox-detail-header h2 {
    color: #111b21;
    font-size: 1rem;
    font-weight: 500;
    margin: 0;
}

.inbox-detail-body {
    height: calc(100% - 64px);
    overflow-y: auto;
    padding: 25px 22px;
}

.inbox-detail-body .form-label {
    color: #667781;
}

.inbox-detail-body .form-control {
    border: 0;
    border-bottom: 1px solid #d1d7db;
    border-radius: 0;
    box-shadow: none;
    padding-left: 0;
}

.inbox-detail-body .form-control:focus {
    border-color: #00a884;
}

.inbox-crm-status {
    align-items: center;
    background: #e7fce3;
    border-radius: 8px;
    color: #087443;
    display: flex;
    font-size: 0.83rem;
    font-weight: 500;
    gap: 9px;
    padding: 10px 12px;
}

.inbox-crm-dot {
    background: #00a884;
    border-radius: 50%;
    display: inline-block;
    height: 9px;
    width: 9px;
}

.inbox-crm-status.pending {
    background: #fff3cd;
    color: #8a5b00;
}

.inbox-crm-status.pending .inbox-crm-dot {
    background: #d39e00;
}

.inbox-save-contact {
    background: #00a884;
    border: 0;
    color: #fff;
    margin-top: 8px;
}

.inbox-save-contact:hover {
    background: #008f72;
    color: #fff;
}

.inbox-ai-panel {
    background: #f8fbfd;
    border: 1px solid #dbe4ea;
    border-radius: 14px;
    margin-bottom: 18px;
    padding: 14px;
}

.inbox-ai-panel-head {
    align-items: flex-start;
    display: flex;
    gap: 10px;
    justify-content: space-between;
    margin-bottom: 12px;
}

.inbox-ai-panel-head strong,
.inbox-ai-panel-head small {
    display: block;
}

.inbox-ai-panel-head strong {
    color: #111b21;
}

.inbox-ai-panel-head small {
    color: #667781;
    font-size: 0.75rem;
}

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

.inbox-insight-pill {
    border-radius: 999px;
    font-size: 0.72rem;
    font-weight: 800;
    padding: 7px 9px;
    text-align: center;
}

.inbox-insight-pill.sentiment-neutral,
.inbox-insight-pill.priority-normal {
    background: #e9eff6;
    color: #3b4a54;
}

.inbox-insight-pill.sentiment-positivo {
    background: #e7fce3;
    color: #087443;
}

.inbox-insight-pill.sentiment-negativo,
.inbox-insight-pill.priority-urgente {
    background: #fde7e9;
    color: #b42318;
}

.inbox-insight-pill.priority-alta {
    background: #fff4ce;
    color: #9a6700;
}

.inbox-ai-summary {
    color: #344054;
    font-size: 0.84rem;
    line-height: 1.45;
    margin-bottom: 10px;
}

.inbox-ai-tags,
.inbox-quick-replies {
    display: flex;
    flex-wrap: wrap;
    gap: 6px;
    margin-bottom: 12px;
}

.inbox-ai-tags span,
.inbox-quick-replies button {
    background: #e7f8f6;
    border: 1px solid #c3ece8;
    border-radius: 999px;
    color: #08786f;
    font-size: 0.76rem;
    font-weight: 700;
    padding: 6px 9px;
}

.inbox-quick-replies button {
    background: #fff;
    cursor: pointer;
}

.inbox-note {
    background: #fff;
    border: 1px solid #e6edf2;
    border-radius: 10px;
    margin-bottom: 8px;
    padding: 8px 10px;
}

.inbox-note p {
    color: #111b21;
    font-size: 0.82rem;
    line-height: 1.35;
    margin: 0 0 4px;
}

.inbox-note small {
    color: #667781;
    font-size: 0.7rem;
}

.inbox-note.empty {
    color: #667781;
    font-size: 0.8rem;
}

.contact-360-score {
    align-items: center;
    background: linear-gradient(135deg, rgba(51, 169, 160, 0.12), rgba(196, 232, 29, 0.14));
    border: 1px solid rgba(51, 169, 160, 0.18);
    border-radius: 14px;
    display: flex;
    justify-content: space-between;
    margin-bottom: 12px;
    padding: 12px;
}

.contact-360-score span,
.contact-360-block p {
    color: #617087;
}

.contact-360-score strong {
    color: #07122f;
    font-size: 1.55rem;
}

.contact-360-block {
    background: #fff;
    border: 1px solid #e4eaf0;
    border-radius: 14px;
    margin-bottom: 10px;
    padding: 12px;
}

.contact-360-block strong {
    color: #07122f;
    display: block;
    margin-bottom: 7px;
}

.contact-360-block p {
    font-size: 0.86rem;
    margin: 0 0 5px;
}

.contact-360-block.warning {
    background: #fff8e6;
    border-color: #f2d18b;
}

@media (max-width: 1199px) {
    .wc-pipeline-summary {
        grid-template-columns: repeat(3, minmax(0, 1fr));
    }

    .wc-forecast-row {
        grid-template-columns: 140px minmax(0, 1fr) 110px;
    }

    .inbox-shell {
        grid-template-columns: 330px minmax(360px, 1fr);
    }

    .inbox-contact {
        display: none;
    }
}

@media (max-width: 767px) {
    .wc-pipeline-summary {
        grid-template-columns: 1fr;
    }

    .wc-forecast-row {
        align-items: start;
        grid-template-columns: 1fr;
    }

    .wc-forecast-row strong {
        text-align: left;
    }

    .inbox-page {
        overflow: auto;
    }

    .inbox-shell {
        display: flex;
        flex-direction: column;
        height: auto;
    }

    .inbox-sidebar {
        height: 340px;
    }

    .inbox-chat {
        height: calc(100vh - 56px);
        min-height: 520px;
    }
}
.agent-prompt-preview {
    filter: blur(3px);
    user-select: none;
    pointer-events: none;
    line-height: 1.8;
}

.dashboard-page .app-wide-container {
    max-width: none;
    padding: 0.55rem;
}

.wc-app-shell {
    background: #ffffff;
    border: 1px solid rgba(51, 82, 138, 0.12);
    border-radius: 18px;
    box-shadow: 0 26px 70px rgba(20, 32, 51, 0.08);
    display: grid;
    grid-template-columns: 300px minmax(0, 1fr);
    min-height: calc(100vh - 1.1rem);
    overflow: hidden;
}

.wc-sidebar {
    background: rgba(255, 255, 255, 0.96);
    border-right: 1px solid var(--wc-border);
    display: flex;
    flex-direction: column;
    gap: 1.5rem;
    padding: 2rem 1.55rem;
}

.wc-sidebar-brand {
    align-items: center;
    color: #09142f;
    display: flex;
    gap: 0.75rem;
    font-size: 1.45rem;
    font-weight: 900;
    letter-spacing: -0.035em;
    text-decoration: none;
}

.wc-sidebar-brand img {
    height: 54px;
    width: 54px;
}

.wc-sidebar-nav {
    display: grid;
    gap: 0.45rem;
}

.wc-sidebar-nav a {
    align-items: center;
    border-radius: 16px;
    color: #0e1731;
    display: flex;
    font-size: 1.02rem;
    font-weight: 700;
    gap: 0.9rem;
    padding: 0.9rem 1rem;
    text-decoration: none;
    transition: background 0.18s ease, color 0.18s ease, transform 0.18s ease;
}

.wc-sidebar-nav a:hover {
    background: #f4f9fa;
    color: var(--wc-blue);
}

.wc-sidebar-nav a.active {
    background: linear-gradient(135deg, rgba(196, 232, 29, 0.32), rgba(51, 169, 160, 0.12));
    color: #07122f;
}

.wc-sidebar-nav span {
    align-items: center;
    display: inline-flex;
    font-size: 1.05rem;
    justify-content: center;
    width: 26px;
}

.wc-sidebar-nav i,
.wc-kpi-icon i,
.wc-icon-btn i,
.wc-user-menu a i,
.wc-agent-list i,
.wc-health-mini > span i {
    line-height: 1;
}

.wc-help-card {
    border: 1px solid var(--wc-border);
    border-radius: 18px;
    margin-top: auto;
    padding: 1rem;
}

.wc-help-card img {
    height: 58px;
    margin-bottom: 0.65rem;
    width: 58px;
}

.wc-help-card strong {
    color: #07122f;
    display: block;
}

.wc-help-card p {
    color: var(--wc-muted);
    font-size: 0.9rem;
    margin: 0.2rem 0 0;
}

.wc-main {
    background:
        radial-gradient(circle at 100% 0%, rgba(196, 232, 29, 0.10), transparent 22rem),
        linear-gradient(180deg, #ffffff 0%, #fbfdff 100%);
    padding: 2rem;
}

.wc-topbar {
    align-items: center;
    display: flex;
    gap: 1.5rem;
    justify-content: space-between;
    margin-bottom: 1.8rem;
}

.wc-topbar h1 {
    color: #07122f;
    font-size: clamp(2.1rem, 3vw, 3rem);
    font-weight: 500;
    letter-spacing: -0.05em;
    margin: 0;
}

.wc-topbar h1 span {
    font-size: 0.8em;
}

.wc-topbar p {
    color: #5e6b83;
    font-size: 1.12rem;
    margin: 0.3rem 0 0;
}

.wc-topbar-actions {
    align-items: center;
    display: flex;
    gap: 1rem;
}

.wc-search {
    align-items: center;
    background: #fff;
    border: 1px solid var(--wc-border);
    border-radius: 20px;
    box-shadow: 0 10px 26px rgba(20, 32, 51, 0.05);
    color: #667085;
    display: flex;
    gap: 0.7rem;
    height: 54px;
    padding: 0 1rem;
    width: 265px;
}

.wc-search input {
    border: 0;
    outline: none;
    width: 100%;
}

.wc-icon-btn {
    align-items: center;
    background: #fff;
    border: 0;
    border-radius: 50%;
    box-shadow: 0 8px 20px rgba(20, 32, 51, 0.06);
    color: var(--wc-blue);
    display: inline-flex;
    height: 48px;
    justify-content: center;
    position: relative;
    width: 48px;
}

.wc-icon-btn::after {
    background: var(--wc-lime);
    border: 2px solid #fff;
    border-radius: 50%;
    content: "";
    height: 10px;
    position: absolute;
    right: 11px;
    top: 10px;
    width: 10px;
}

.wc-user-menu {
    align-items: center;
    display: flex;
    gap: 0.75rem;
}

.wc-user-menu > span {
    align-items: center;
    background: var(--wc-gradient);
    border-radius: 50%;
    color: #fff;
    display: inline-flex;
    font-size: 1.35rem;
    font-weight: 900;
    height: 54px;
    justify-content: center;
    width: 54px;
}

.wc-user-menu strong,
.wc-user-menu small {
    display: block;
    line-height: 1.15;
}

.wc-user-menu strong {
    color: #07122f;
}

.wc-user-menu small {
    color: #667085;
}

.wc-user-menu a {
    color: var(--wc-blue);
    text-decoration: none;
}

.wc-kpi-grid {
    display: grid;
    gap: 1.25rem;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    margin-bottom: 1.5rem;
}

.wc-kpi-card,
.wc-pro-card {
    background: #fff;
    border: 1px solid var(--wc-border);
    border-radius: 18px;
    box-shadow: 0 12px 30px rgba(20, 32, 51, 0.045);
}

.wc-kpi-card {
    min-height: 178px;
    padding: 1.45rem;
}

.wc-kpi-icon {
    align-items: center;
    border-radius: 50%;
    display: inline-flex;
    font-size: 1.05rem;
    font-weight: 900;
    height: 44px;
    justify-content: center;
    margin-bottom: 0.9rem;
    width: 44px;
}

.wc-kpi-icon.teal { background: rgba(196, 232, 29, 0.16); color: var(--wc-green); }
.wc-kpi-icon.cyan { background: rgba(51, 169, 160, 0.15); color: var(--wc-teal); }
.wc-kpi-icon.green { background: rgba(51, 169, 160, 0.14); color: var(--wc-teal); }
.wc-kpi-icon.red { background: rgba(244, 63, 94, 0.12); color: #c0263f; }

.wc-kpi-card p {
    color: #3f4b60;
    font-weight: 700;
    margin-bottom: 1.1rem;
}

.wc-kpi-card div {
    align-items: baseline;
    display: flex;
    justify-content: space-between;
    gap: 1rem;
}

.wc-kpi-card strong {
    color: #07122f;
    font-size: 2.45rem;
    font-weight: 900;
    letter-spacing: -0.055em;
    line-height: 1;
}

.wc-kpi-card em {
    font-style: normal;
    font-weight: 900;
}

.wc-kpi-card em.up { color: var(--wc-green); }
.wc-kpi-card em.down { color: #ef4444; }

.wc-kpi-card small {
    color: #7a8599;
    display: block;
    margin-top: 0.45rem;
    text-align: right;
}

.wc-dashboard-grid {
    display: grid;
    gap: 1.25rem;
    grid-template-columns: 1.3fr 1fr 1fr;
}

.wc-bottom-grid {
    grid-template-columns: 1.2fr 1fr;
    margin-top: 1.25rem;
}

.wc-pro-card {
    padding: 1.55rem;
}

.wc-pro-card h2 {
    color: #07122f;
    font-size: 1.25rem;
    font-weight: 500;
    letter-spacing: -0.03em;
    margin-bottom: 1.25rem;
}

.wc-chart-layout {
    align-items: center;
    display: grid;
    gap: 1rem;
    grid-template-columns: 1fr 0.9fr;
}

.wc-chart-box {
    height: 285px;
    min-height: 260px;
    position: relative;
}

.wc-chart-box canvas,
.wc-mini-chart-box canvas {
    display: block;
    width: 100%;
}

.wc-mini-chart-box {
    height: 175px;
    margin-top: 1.15rem;
    position: relative;
}

.wc-funnel-empty {
    align-items: center;
    background:
        radial-gradient(circle at 80% 0%, rgba(196, 232, 29, 0.14), transparent 14rem),
        linear-gradient(135deg, rgba(51, 169, 160, 0.08), rgba(255, 255, 255, 0.92));
    border: 1px dashed rgba(51, 169, 160, 0.34);
    border-radius: 18px;
    color: #4c5870;
    display: flex;
    flex-direction: column;
    justify-content: center;
    min-height: 285px;
    padding: 1.5rem;
    text-align: center;
}

.wc-funnel-empty span {
    align-items: center;
    background: rgba(51, 169, 160, 0.13);
    border-radius: 50%;
    color: var(--wc-teal);
    display: inline-flex;
    font-size: 1.45rem;
    height: 58px;
    justify-content: center;
    margin-bottom: 1rem;
    width: 58px;
}

.wc-funnel-empty strong {
    color: #07122f;
    font-family: "Plus Jakarta Sans", system-ui, -apple-system, "Segoe UI", sans-serif;
    font-size: 1.05rem;
    font-weight: 500;
}

.wc-funnel-empty p {
    margin: 0.55rem auto 1rem;
    max-width: 310px;
}

.wc-funnel-legend {
    display: grid;
    gap: 1rem;
}

.wc-funnel-legend div {
    align-items: center;
    display: grid;
    gap: 0.65rem;
    grid-template-columns: 16px minmax(0, 1fr) auto;
}

.wc-funnel-legend i {
    border-radius: 4px;
    height: 16px;
    width: 16px;
}

.wc-funnel-legend span {
    color: #4c5870;
}

.wc-funnel-legend strong {
    color: #07122f;
    font-size: 1.05rem;
}

.wc-agent-list {
    display: grid;
    gap: 1rem;
}

.wc-agent-list div {
    align-items: center;
    border: 1px solid var(--wc-border);
    border-radius: 16px;
    display: grid;
    gap: 0.85rem;
    grid-template-columns: 42px minmax(0, 1fr) auto;
    padding: 1rem;
}

.wc-agent-list span {
    color: var(--wc-green);
    font-size: 1.35rem;
}

.wc-agent-list strong,
.wc-agent-list small {
    display: block;
}

.wc-agent-list small {
    color: #7a8599;
    font-size: 0.82rem;
    margin-top: 0.12rem;
}

.wc-agent-list em {
    background: rgba(196, 232, 29, 0.2);
    border-radius: 10px;
    color: var(--wc-green);
    font-style: normal;
    font-weight: 900;
    padding: 0.55rem 0.65rem;
}

.wc-summary-card p {
    color: #4c5870;
    font-size: 1.02rem;
    line-height: 1.65;
}

.wc-line-chart {
    align-items: end;
    background: linear-gradient(180deg, transparent, rgba(196, 232, 29, 0.12));
    display: flex;
    gap: 0.55rem;
    height: 170px;
    margin-top: 1.3rem;
    padding: 0 0.5rem;
}

.wc-line-chart span {
    background: linear-gradient(180deg, var(--wc-lime), var(--wc-green));
    border-radius: 999px 999px 0 0;
    flex: 1;
    min-width: 16px;
}

.wc-card-title-row {
    align-items: center;
    display: flex;
    justify-content: space-between;
    gap: 1rem;
}

.wc-card-title-row h2 {
    margin-bottom: 0;
}

.wc-card-title-row > strong {
    color: var(--wc-teal);
    font-size: 2rem;
    font-weight: 900;
}

.wc-card-title-row a {
    color: #59657a;
    text-decoration: none;
}

.wc-health-mini {
    align-items: center;
    background: linear-gradient(135deg, rgba(51, 169, 160, 0.11), rgba(196, 232, 29, 0.14));
    border: 1px solid rgba(51, 169, 160, 0.18);
    border-radius: 18px;
    display: grid;
    gap: 1rem;
    grid-template-columns: 56px minmax(0, 1fr) auto;
    margin-top: 1.25rem;
    padding: 1.05rem;
}

.wc-health-mini > span {
    align-items: center;
    background: rgba(51, 169, 160, 0.14);
    border-radius: 50%;
    color: var(--wc-teal);
    display: inline-flex;
    font-size: 1.5rem;
    height: 56px;
    justify-content: center;
    width: 56px;
}

.wc-health-mini small {
    color: #617087;
    display: block;
    margin: 0.2rem 0 0.8rem;
}

.wc-health-mini .wc-progress {
    background: rgba(51, 82, 138, 0.09);
    border-radius: 999px;
    height: 10px;
    overflow: hidden;
}

.wc-health-mini .wc-progress i {
    background: var(--wc-gradient);
    border-radius: inherit;
    display: block;
    height: 100%;
}

.wc-compact-list {
    display: grid;
    gap: 1rem;
    margin-top: 1.25rem;
}

.wc-compact-list > div {
    align-items: center;
    display: grid;
    gap: 1rem;
    grid-template-columns: 48px minmax(0, 1fr) auto;
}

.wc-compact-list span {
    align-items: center;
    background: var(--wc-gradient);
    border-radius: 50%;
    color: #fff;
    display: inline-flex;
    font-weight: 900;
    height: 48px;
    justify-content: center;
    width: 48px;
}

.wc-compact-list strong,
.wc-compact-list small {
    display: block;
}

.wc-compact-list small,
.wc-compact-list time {
    color: #667085;
    font-weight: 500;
}

@media (max-width: 1199px) {
    .wc-app-shell {
        grid-template-columns: 1fr;
    }

    .wc-sidebar {
        display: none;
    }

    .wc-dashboard-grid,
    .wc-bottom-grid {
        grid-template-columns: 1fr;
    }
}

@media (max-width: 991px) {
    .login-shell {
        grid-template-columns: 1fr;
    }

    .register-shell {
        grid-template-columns: 1fr;
        padding: 1rem;
    }

    .register-brand-panel,
    .register-card {
        border-radius: 24px;
    }

    .register-brand-panel {
        min-height: 520px;
    }

    .login-brand-panel {
        border-right: 0;
        min-height: 420px;
    }

    .wc-kpi-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .wc-topbar {
        align-items: flex-start;
        flex-direction: column;
    }

    .wc-topbar-actions {
        flex-wrap: wrap;
        width: 100%;
    }

    .wc-search {
        flex: 1;
        min-width: 220px;
    }
}

@media (max-width: 640px) {
    .login-brand-panel {
        min-height: auto;
        padding: 1.5rem;
    }

    .login-brand-copy {
        margin-top: 3rem;
    }

    .login-brand-copy h1 {
        font-size: 2.45rem;
    }

    .login-brand-badges {
        display: none;
    }

    .login-card-wrap {
        padding: 1rem;
    }

    .register-card-head,
    .login-links {
        align-items: flex-start;
        flex-direction: column;
    }

    .register-steps {
        grid-template-columns: 1fr;
    }

    .register-actions {
        gap: 0.75rem;
    }

    .dashboard-page .app-wide-container {
        padding: 0;
    }

    .wc-app-shell {
        border-radius: 0;
        border-width: 0;
    }

    .wc-main {
        padding: 1.15rem;
    }

    .wc-kpi-grid,
    .wc-chart-layout {
        grid-template-columns: 1fr;
    }

    .wc-health-mini {
        grid-template-columns: 1fr;
    }
}

.admin-wabi {
    display: grid;
    font-family: "Plus Jakarta Sans", system-ui, -apple-system, "Segoe UI", sans-serif;
    gap: 1.5rem;
    padding-bottom: 2rem;
}

.admin-wabi .btn,
.admin-wabi .form-control,
.admin-wabi .form-select,
.admin-wabi .form-label,
.admin-wabi textarea,
.admin-wabi input,
.admin-wabi select {
    font-family: inherit;
}

.admin-wabi-header,
.admin-wabi-panel,
.admin-wabi-metrics article {
    background: #fff;
    border: 1px solid var(--wc-border);
    border-radius: 18px;
    box-shadow: 0 12px 30px rgba(15, 23, 42, 0.06);
}

.admin-wabi-header {
    align-items: center;
    display: flex;
    gap: 1rem;
    justify-content: space-between;
    padding: 1.35rem 1.5rem;
}

.admin-wabi-kicker {
    color: var(--wc-teal);
    font-size: 0.78rem;
    font-weight: 600;
    letter-spacing: 0;
    margin: 0 0 0.25rem;
    text-transform: uppercase;
}

.admin-wabi-header h1,
.admin-wabi-panel h2 {
    color: var(--wc-text);
    font-weight: 500;
    margin: 0;
}

.admin-wabi-header h1 {
    font-size: 1.75rem;
}

.admin-wabi-header p,
.admin-wabi-panel p {
    color: var(--wc-muted);
    margin: 0.25rem 0 0;
}

.admin-wabi-lock,
.admin-wabi-secret {
    align-items: center;
    background: rgba(51, 169, 160, 0.12);
    border: 1px solid rgba(51, 169, 160, 0.22);
    border-radius: 999px;
    color: var(--wc-primary);
    display: inline-flex;
    font-weight: 600;
    gap: 0.45rem;
    padding: 0.6rem 0.85rem;
    white-space: nowrap;
}

.admin-wabi-ai-actions {
    align-items: center;
    display: flex;
    flex-wrap: wrap;
    gap: 0.75rem;
    justify-content: flex-end;
}

.admin-wabi-metrics {
    display: grid;
    gap: 1rem;
    grid-template-columns: repeat(4, minmax(0, 1fr));
}

.admin-wabi-metrics article {
    display: grid;
    gap: 0.3rem;
    grid-template-columns: 48px minmax(0, 1fr);
    padding: 1rem;
}

.admin-wabi-metrics span {
    align-items: center;
    background: rgba(51, 82, 138, 0.08);
    border-radius: 14px;
    color: var(--wc-primary);
    display: inline-flex;
    font-size: 1.1rem;
    grid-row: span 2;
    height: 48px;
    justify-content: center;
    width: 48px;
}

.admin-wabi-metrics small {
    color: var(--wc-muted);
    font-weight: 500;
}

.admin-wabi-metrics strong {
    color: var(--wc-text);
    font-size: 1.65rem;
    font-weight: 600;
    line-height: 1;
}

.admin-wabi-panel {
    padding: 1.25rem;
}

.admin-wabi-panel-head {
    align-items: flex-start;
    display: flex;
    gap: 1rem;
    justify-content: space-between;
    margin-bottom: 1rem;
}

.admin-wabi-panel h2 {
    font-size: 1.1rem;
}

.admin-wabi .form-label {
    color: var(--wc-text);
    font-weight: 500;
}

.admin-wabi .btn {
    font-weight: 500;
}

.admin-wabi-search {
    align-items: center;
    background: #f7f9fc;
    border: 1px solid var(--wc-border);
    border-radius: 999px;
    color: var(--wc-muted);
    display: flex;
    gap: 0.5rem;
    min-width: 230px;
    padding: 0.55rem 0.8rem;
}

.admin-wabi-search input {
    background: transparent;
    border: 0;
    min-width: 0;
    outline: 0;
    width: 100%;
}

.admin-wabi-table td {
    border-color: var(--wc-border);
    vertical-align: middle;
}

.admin-wabi-table td strong,
.admin-wabi-table td small {
    display: block;
}

.admin-wabi-table td strong {
    font-weight: 600;
}

.admin-wabi-table td small {
    color: var(--wc-muted);
    margin-top: 0.15rem;
}

.admin-wabi-pill,
.admin-wabi-status {
    border-radius: 999px;
    display: inline-flex;
    font-size: 0.78rem;
    font-weight: 600;
    padding: 0.38rem 0.62rem;
}

.admin-wabi-pill {
    background: rgba(51, 82, 138, 0.09);
    color: var(--wc-primary);
    text-transform: uppercase;
}

.admin-wabi-status.active {
    background: rgba(51, 169, 160, 0.13);
    color: #14756e;
}

.admin-wabi-status.suspended {
    background: rgba(245, 158, 11, 0.14);
    color: #9a5d00;
}

.admin-wabi-status.cancelled {
    background: rgba(244, 63, 94, 0.12);
    color: #b42345;
}

.admin-wabi-form {
    display: grid;
    gap: 1rem;
}

.admin-wabi-label-row {
    align-items: center;
    display: flex;
    gap: 0.75rem;
    justify-content: space-between;
    margin-bottom: 0.35rem;
}

.admin-wabi-label-row .form-label {
    margin-bottom: 0;
}

.admin-ai-assist {
    border-color: rgba(51, 169, 160, 0.28);
    color: var(--wc-primary);
    font-weight: 600;
    white-space: nowrap;
}

.admin-wabi-test-result {
    background: #f7f9fc;
    border: 1px solid var(--wc-border);
    border-radius: 14px;
    color: var(--wc-muted);
    font-weight: 500;
    margin-top: 0.5rem;
    padding: 0.85rem 1rem;
}

.admin-wabi-test-result.success {
    background: rgba(51, 169, 160, 0.1);
    border-color: rgba(51, 169, 160, 0.25);
    color: #14756e;
}

.admin-wabi-test-result.danger {
    background: rgba(244, 63, 94, 0.1);
    border-color: rgba(244, 63, 94, 0.22);
    color: #b42345;
}

.admin-wabi-user-list {
    display: grid;
    gap: 0.6rem;
    margin-bottom: 1rem;
}

.admin-wabi-user-row {
    align-items: center;
    background: #f7f9fc;
    border: 1px solid var(--wc-border);
    border-radius: 14px;
    color: var(--wc-text);
    display: flex;
    gap: 0.75rem;
    justify-content: space-between;
    padding: 0.75rem 0.85rem;
    text-align: left;
    width: 100%;
}

.admin-wabi-user-row:hover {
    border-color: rgba(51, 169, 160, 0.45);
}

.admin-wabi-user-row strong,
.admin-wabi-user-row small {
    display: block;
}

.admin-wabi-user-row strong {
    font-weight: 600;
}

.admin-wabi-user-row small {
    color: var(--wc-muted);
}

.admin-wabi-user-row em {
    border-radius: 999px;
    font-style: normal;
    font-weight: 600;
    padding: 0.32rem 0.58rem;
    white-space: nowrap;
}

.admin-wabi-user-row em.active {
    background: rgba(51, 169, 160, 0.13);
    color: #14756e;
}

.admin-wabi-user-row em.inactive {
    background: rgba(244, 63, 94, 0.1);
    color: #b42345;
}

.admin-wabi-empty {
    background: #f7f9fc;
    border: 1px dashed var(--wc-border);
    border-radius: 14px;
    color: var(--wc-muted);
    padding: 0.85rem 1rem;
}

.admin-wabi-user-form {
    border-top: 1px solid var(--wc-border);
    padding-top: 1rem;
}

.admin-wabi-danger-zone {
    background: rgba(244, 63, 94, 0.06);
    border: 1px solid rgba(244, 63, 94, 0.22);
    border-radius: 16px;
    display: grid;
    gap: 1rem;
    margin-top: 1.2rem;
    padding: 1rem;
}

.admin-wabi-danger-zone strong {
    color: #9f1239;
    display: block;
    font-weight: 600;
}

.admin-wabi-danger-zone p {
    color: #7f1d1d;
    margin: 0.2rem 0 0;
}

.admin-wabi-delete-form {
    display: grid;
    gap: 0.65rem;
}

.admin-wabi-delete-form .btn {
    justify-self: start;
}

.admin-wabi-textarea {
    min-height: 1150px;
    resize: vertical;
}

.admin-wabi-usage-card {
    background: #f8fafc;
    border: 1px solid #e2e8f0;
    border-radius: 0.75rem;
    padding: 1rem 1.25rem;
    margin-bottom: 1.5rem;
}

.admin-wabi-usage-head {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 0.75rem;
    gap: 1rem;
}

.admin-wabi-usage-total {
    font-size: 1.4rem;
    font-weight: 600;
    color: var(--wc-text);
    white-space: nowrap;
}

.admin-wabi-usage-list {
    display: grid;
    gap: 0.5rem;
}

.admin-wabi-usage-row {
    display: grid;
    grid-template-columns: 1fr auto auto;
    align-items: center;
    gap: 0.75rem;
}

.admin-wabi-usage-row-info {
    min-width: 0;
}

.admin-wabi-usage-row-info strong {
    display: block;
    font-size: 0.875rem;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.admin-wabi-usage-row-info small {
    color: var(--wc-muted);
    font-size: 0.75rem;
}

.admin-wabi-usage-bar {
    width: 140px;
    flex-shrink: 0;
}

.admin-wabi-usage-amount {
    font-size: 0.875rem;
    font-weight: 500;
    white-space: nowrap;
    min-width: 90px;
    text-align: right;
}

.admin-wabi-usage-amount.over-budget {
    color: #dc2626;
    font-weight: 700;
}

.admin-wabi-openai-card {
    background: #fff;
    border: 1px solid #e2e8f0;
    border-radius: 0.65rem;
    padding: 0.75rem 1rem;
}

.admin-wabi-openai-card small {
    display: block;
    color: var(--wc-muted);
    font-size: 0.75rem;
    margin-bottom: 0.25rem;
}

.admin-wabi-openai-card strong {
    font-size: 1.2rem;
    color: var(--wc-text);
}

@media (max-width: 991px) {
    .admin-wabi-header,
    .admin-wabi-panel-head {
        align-items: stretch;
        flex-direction: column;
    }

    .admin-wabi-metrics {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .admin-wabi-search {
        width: 100%;
    }
}

@media (max-width: 575px) {
    .admin-wabi-metrics {
        grid-template-columns: 1fr;
    }
}

.quote-page,
.quote-editor {
    color: var(--wc-text);
    padding-bottom: 2rem;
}

.quote-header,
.quote-editor-bar,
.quote-card {
    background: #fff;
    border: 1px solid var(--wc-border);
    border-radius: 20px;
    box-shadow: var(--wc-shadow);
}

.quote-header {
    align-items: center;
    display: flex;
    gap: 1rem;
    justify-content: space-between;
    margin-bottom: 1.5rem;
    padding: 1.5rem;
}

.quote-header h1,
.quote-editor h1,
.quote-card h2 {
    color: var(--wc-text);
    font-weight: 700;
    letter-spacing: 0;
    margin: 0;
}

.quote-header p,
.quote-card p,
.quote-editor-title span + h1 {
    color: var(--wc-muted);
    margin: 0.25rem 0 0;
}

.quote-header-actions,
.quote-editor-actions,
.quote-card-head,
.quote-section-head,
.quote-editor-bar {
    align-items: center;
    display: flex;
    gap: 1rem;
    justify-content: space-between;
}

.quote-grid,
.quote-editor-grid {
    display: grid;
    gap: 1.5rem;
}

.quote-grid {
    grid-template-columns: minmax(0, 1.6fr) minmax(360px, 0.8fr);
}

.quote-editor-grid {
    grid-template-columns: minmax(0, 1.7fr) minmax(340px, 0.7fr);
}

.quote-card {
    padding: 1.5rem;
}

.quote-search {
    align-items: center;
    background: #f8fafc;
    border: 1px solid var(--wc-border);
    border-radius: 999px;
    display: flex;
    gap: 0.65rem;
    padding: 0.72rem 1rem;
    min-width: 280px;
}

.quote-search input {
    background: transparent;
    border: 0;
    min-width: 0;
    outline: 0;
    width: 100%;
}

.quote-tabs {
    display: flex;
    flex-wrap: wrap;
    gap: 0.5rem;
    margin: 1.25rem 0;
}

.quote-tabs button,
.quote-pill,
.quote-status {
    border: 1px solid var(--wc-border);
    border-radius: 999px;
    font-weight: 700;
    padding: 0.45rem 0.8rem;
}

.quote-tabs button {
    background: #f8fafc;
    color: var(--wc-muted);
}

.quote-tabs button.active {
    background: rgba(51, 169, 160, 0.12);
    border-color: rgba(51, 169, 160, 0.3);
    color: #14756e;
}

.quote-table-wrap {
    overflow-x: auto;
}

.quote-table {
    border-collapse: collapse;
    width: 100%;
}

.quote-table th,
.quote-table td {
    border-bottom: 1px solid var(--wc-border);
    padding: 0.9rem 0.6rem;
    vertical-align: middle;
}

.quote-table th {
    color: var(--wc-muted);
    font-size: 0.82rem;
    text-transform: uppercase;
}

.quote-table small,
.quote-product-row small,
.quote-version-row small {
    color: var(--wc-muted);
    display: block;
}

.quote-actions {
    display: flex;
    gap: 0.4rem;
    justify-content: flex-end;
}

.quote-empty {
    color: var(--wc-muted);
    padding: 1rem;
    text-align: center;
}

.quote-product-form {
    border-bottom: 1px solid var(--wc-border);
    margin-bottom: 1rem;
    padding-bottom: 1rem;
}

.quote-product-list,
.quote-version-list {
    display: grid;
    gap: 0.75rem;
}

.quote-product-row,
.quote-version-row,
.quote-picker-row {
    background: #f8fafc;
    border: 1px solid var(--wc-border);
    border-radius: 16px;
    padding: 0.85rem;
}

.quote-product-row {
    align-items: center;
    display: flex;
    gap: 0.75rem;
    justify-content: space-between;
}

.quote-product-row p {
    font-size: 0.9rem;
}

.quote-editor-bar {
    margin-bottom: 1.5rem;
    padding: 1rem 1.25rem;
}

.quote-editor-title {
    flex: 1;
}

.quote-editor-title h1 {
    font-size: 1.3rem;
}

.quote-section-head {
    border-top: 1px solid var(--wc-border);
    margin-top: 1.5rem;
    padding-top: 1.25rem;
}

.quote-item-table {
    margin-top: 1rem;
}

.quote-item-head,
.quote-item-row {
    display: grid;
    gap: 0.75rem;
    grid-template-columns: minmax(260px, 1fr) 88px 120px 96px 120px 44px;
}

.quote-item-head {
    color: var(--wc-muted);
    font-size: 0.82rem;
    font-weight: 700;
    padding: 0 0.4rem 0.5rem;
    text-transform: uppercase;
}

.quote-item-row {
    align-items: start;
    border-top: 1px solid var(--wc-border);
    padding: 0.8rem 0;
}

.quote-item-row textarea {
    margin-top: 0.45rem;
}

.quote-item-row strong {
    padding-top: 0.55rem;
    text-align: right;
}

.quote-summary {
    align-self: start;
    position: sticky;
    top: 1rem;
}

.quote-total-row {
    align-items: center;
    border-bottom: 1px solid var(--wc-border);
    display: flex;
    justify-content: space-between;
    padding: 0.75rem 0;
}

.quote-grand-total strong {
    color: var(--wc-primary);
    font-size: 1.6rem;
}

.quote-version-box {
    border-top: 1px solid var(--wc-border);
    margin-top: 1.25rem;
    padding-top: 1rem;
}

.quote-version-box h3 {
    font-size: 1rem;
    font-weight: 700;
}

.quote-picker-row {
    align-items: center;
    color: var(--wc-text);
    display: flex;
    gap: 1rem;
    justify-content: space-between;
    margin-bottom: 0.75rem;
    text-align: left;
    width: 100%;
}

.quote-picker-row em {
    color: var(--wc-muted);
    display: block;
    font-style: normal;
    margin-top: 0.25rem;
}

.quote-status {
    display: inline-flex;
    font-size: 0.82rem;
    line-height: 1;
}

.status-borrador { background: #f1f5f9; color: #475569; }
.status-enviada { background: rgba(51, 82, 138, 0.12); color: var(--wc-primary); }
.status-vista { background: rgba(51, 169, 160, 0.13); color: #14756e; }
.status-aceptada { background: rgba(138, 182, 46, 0.16); color: #597001; }
.status-rechazada { background: rgba(244, 63, 94, 0.12); color: #b42345; }

.quote-public-body {
    background: #f4f7fb;
    color: var(--wc-text);
    font-family: var(--wc-font, inherit);
    margin: 0;
    padding: 2rem 1rem;
}

.quote-public-doc,
.quote-public-invalid {
    background: #fff;
    border: 1px solid var(--wc-border);
    border-radius: 20px;
    box-shadow: var(--wc-shadow);
    margin: 0 auto;
    max-width: 980px;
    padding: 2rem;
}

.quote-public-invalid {
    max-width: 520px;
    text-align: center;
}

.quote-public-head,
.quote-public-client,
.quote-public-notes,
.quote-public-actions {
    align-items: flex-start;
    display: flex;
    gap: 1.5rem;
    justify-content: space-between;
}

.quote-public-head {
    border-bottom: 2px solid var(--wc-border);
    padding-bottom: 1.25rem;
}

.quote-public-head > div:first-child {
    align-items: center;
    display: flex;
    gap: 0.7rem;
}

.quote-public-head h1 {
    margin: 0.5rem 0 0.2rem;
}

.quote-public-head p,
.quote-public-client p {
    color: var(--wc-muted);
    margin: 0;
}

.quote-public-client {
    background: #f8fafc;
    border: 1px solid var(--wc-border);
    border-radius: 16px;
    margin: 1.5rem 0;
    padding: 1rem;
}

.quote-public-client span {
    color: var(--wc-muted);
    display: block;
    font-size: 0.78rem;
    font-weight: 700;
    text-transform: uppercase;
}

.quote-public-table {
    border-collapse: collapse;
    width: 100%;
}

.quote-public-table th,
.quote-public-table td {
    border-bottom: 1px solid var(--wc-border);
    padding: 0.85rem 0.6rem;
    vertical-align: top;
}

.quote-public-table p {
    color: var(--wc-muted);
    margin: 0.25rem 0 0;
}

.quote-public-total {
    margin-left: auto;
    margin-top: 1.25rem;
    max-width: 340px;
}

.quote-public-total div {
    display: flex;
    justify-content: space-between;
    padding: 0.5rem 0;
}

.quote-public-grand {
    border-top: 2px solid var(--wc-border);
    font-size: 1.35rem;
    font-weight: 800;
}

.quote-public-notes {
    border-top: 1px solid var(--wc-border);
    margin-top: 1.5rem;
    padding-top: 1rem;
}

.quote-public-notes div {
    flex: 1;
}

.quote-public-notes h2 {
    font-size: 1rem;
    font-weight: 700;
}

.quote-public-actions {
    border-top: 1px solid var(--wc-border);
    justify-content: flex-start;
    margin-top: 1.5rem;
    padding-top: 1.25rem;
}

@media (max-width: 1199px) {
    .quote-grid,
    .quote-editor-grid {
        grid-template-columns: 1fr;
    }

    .quote-summary {
        position: static;
    }
}

@media (max-width: 767px) {
    .quote-header,
    .quote-card-head,
    .quote-section-head,
    .quote-editor-bar,
    .quote-public-head,
    .quote-public-client,
    .quote-public-notes,
    .quote-public-actions {
        align-items: stretch;
        flex-direction: column;
    }

    .quote-search {
        min-width: 0;
        width: 100%;
    }

    .quote-item-head {
        display: none;
    }

    .quote-item-row {
        grid-template-columns: 1fr;
    }

    .quote-item-row strong {
        text-align: left;
    }
}

@media print {
    .quote-public-body {
        background: #fff;
        padding: 0;
    }

    .quote-public-doc {
        border: 0;
        box-shadow: none;
        max-width: none;
        padding: 0;
    }

    .quote-public-actions {
        display: none;
    }
}

.agenda-page {
    color: var(--wc-text);
    padding-bottom: 2rem;
}

.agenda-header,
.agenda-card,
.booking-card,
.booking-brand {
    background: #fff;
    border: 1px solid var(--wc-border);
    border-radius: 20px;
    box-shadow: var(--wc-shadow);
}

.agenda-header {
    align-items: center;
    display: flex;
    gap: 1rem;
    justify-content: space-between;
    margin-bottom: 1.5rem;
    padding: 1.5rem;
}

.agenda-header h1,
.agenda-card h2 {
    font-weight: 700;
    margin: 0;
}

.agenda-header p,
.agenda-card p {
    color: var(--wc-muted);
    margin: 0.25rem 0 0;
}

.agenda-header-actions,
.agenda-toolbar,
.agenda-panel-head {
    align-items: center;
    display: flex;
    gap: 1rem;
    justify-content: space-between;
}

.agenda-grid {
    display: grid;
    gap: 1.5rem;
    grid-template-columns: minmax(0, 1.55fr) minmax(360px, 0.85fr);
}

.agenda-card {
    padding: 1.5rem;
}

.agenda-date-controls {
    display: grid;
    gap: 0.75rem;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    width: 100%;
}

.agenda-timeline {
    display: grid;
    gap: 0.75rem;
    margin-top: 1rem;
}

.agenda-timeline h3 {
    color: var(--wc-muted);
    font-size: 0.9rem;
    font-weight: 800;
    margin: 1rem 0 0.25rem;
    text-transform: uppercase;
}

.agenda-event {
    background: #f8fafc;
    border: 1px solid var(--wc-border);
    border-left: 5px solid var(--wc-primary);
    border-radius: 16px;
    color: var(--wc-text);
    display: grid;
    gap: 0.2rem;
    padding: 0.95rem 1rem;
    text-align: left;
}

.agenda-event:hover {
    border-color: rgba(51, 169, 160, 0.45);
}

.agenda-event.status-confirmada {
    border-left-color: var(--wc-teal);
}

.agenda-event.status-completada {
    border-left-color: var(--wc-green);
}

.agenda-event.status-cancelada {
    border-left-color: var(--wc-danger);
    opacity: 0.7;
}

.agenda-time,
.agenda-event small {
    color: var(--wc-muted);
}

.agenda-event em {
    color: #14756e;
    font-style: normal;
    font-weight: 700;
}

.agenda-form,
.agenda-config {
    display: grid;
    gap: 0.65rem;
}

.agenda-config {
    border-top: 1px solid var(--wc-border);
    margin-top: 1.5rem;
    padding-top: 1.25rem;
}

.agenda-alternatives {
    background: #fff7ed;
    border: 1px solid #fed7aa;
    border-radius: 14px;
    display: flex;
    flex-wrap: wrap;
    gap: 0.5rem;
    padding: 0.85rem;
}

.agenda-alternatives strong {
    flex: 1 0 100%;
}

.booking-body {
    background: linear-gradient(135deg, #f8fbff 0%, #eefbf9 100%);
    color: var(--wc-text);
    margin: 0;
    min-height: 100vh;
    padding: 2rem 1rem;
}

.booking-shell {
    display: grid;
    gap: 1.5rem;
    grid-template-columns: minmax(280px, 0.65fr) minmax(320px, 1fr);
    margin: 0 auto;
    max-width: 1120px;
}

.booking-brand,
.booking-card {
    padding: 2rem;
}

.booking-brand {
    align-content: center;
    display: grid;
}

.booking-brand span {
    color: var(--wc-teal);
    font-weight: 800;
    letter-spacing: 0.08em;
    margin-top: 1rem;
    text-transform: uppercase;
}

.booking-brand h1 {
    font-size: clamp(2rem, 5vw, 4rem);
    font-weight: 800;
    letter-spacing: 0;
    line-height: 1;
    margin: 0.75rem 0;
}

.booking-brand p {
    color: var(--wc-muted);
    font-size: 1.1rem;
}

.booking-card form {
    display: grid;
    gap: 0.75rem;
}

.booking-slots {
    display: grid;
    gap: 0.6rem;
    grid-template-columns: repeat(auto-fit, minmax(96px, 1fr));
    margin: 1rem 0;
}

.booking-slot {
    background: #f8fafc;
    border: 1px solid var(--wc-border);
    border-radius: 999px;
    color: var(--wc-primary);
    font-weight: 800;
    padding: 0.7rem;
}

.booking-slot.active {
    background: var(--wc-primary);
    color: #fff;
}

.booking-message {
    border-radius: 14px;
    font-weight: 700;
    margin-top: 0.75rem;
    padding: 0.85rem;
}

.booking-message.success {
    background: rgba(51, 169, 160, 0.12);
    color: #14756e;
}

.booking-message.danger {
    background: rgba(244, 63, 94, 0.12);
    color: #b42345;
}

@media (max-width: 1199px) {
    .agenda-grid,
    .booking-shell {
        grid-template-columns: 1fr;
    }
}

@media (max-width: 767px) {
    .agenda-header,
    .agenda-toolbar,
    .agenda-panel-head {
        align-items: stretch;
        flex-direction: column;
    }

    .agenda-date-controls {
        grid-template-columns: 1fr;
    }
}

/* ── Inbox context menu ───────────────────────────────────────────────────── */
.inbox-ctx-menu {
    background: #fff;
    border-radius: 10px;
    box-shadow: 0 8px 28px rgba(11, 20, 26, 0.18), 0 1px 4px rgba(11, 20, 26, 0.12);
    min-width: 200px;
    padding: 6px 0;
    position: fixed;
    z-index: 9999;
}

.inbox-ctx-menu .ctx-client-label {
    border-bottom: 1px solid #f0f2f5;
    color: #667781;
    font-size: 0.72rem;
    font-weight: 600;
    letter-spacing: 0.05em;
    padding: 6px 16px 8px;
    text-transform: uppercase;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    max-width: 220px;
}

.inbox-ctx-menu .ctx-item {
    align-items: center;
    color: #111b21;
    display: flex;
    font-size: 0.9rem;
    gap: 10px;
    padding: 9px 16px;
    text-decoration: none;
    transition: background 0.1s;
}

.inbox-ctx-menu .ctx-item:hover {
    background: #f0f2f5;
    color: #111b21;
}

.inbox-ctx-menu .ctx-item i {
    color: #54656f;
    font-size: 0.85rem;
    width: 16px;
    text-align: center;
}

/* ── Inbox line tabs ──────────────────────────────────────────────────────── */
.inbox-line-tabs {
    background: #fff;
    border-bottom: 1px solid #e9edef;
    display: flex;
    gap: 4px;
    overflow-x: auto;
    padding: 8px 12px;
    scrollbar-width: thin;
}

.inbox-line-tabs button {
    background: #f0f2f5;
    border: 0;
    border-radius: 16px;
    color: #54656f;
    flex-shrink: 0;
    font-size: 0.82rem;
    font-weight: 500;
    padding: 5px 14px;
    transition: all 0.15s;
    white-space: nowrap;
}

.inbox-line-tabs button:hover {
    background: #e4e8eb;
}

.inbox-line-tabs button.active {
    background: #00a884;
    color: #fff;
}
