:root {
    --odoo-primary: #875A7B;
    --odoo-primary-dark: #6d4862;
    --odoo-primary-light: #a17496;
    --odoo-bg: #f8f9fa;
    --odoo-border: #dee2e6;
}

body {
    background: var(--odoo-bg);
    font-size: 14px;
    color: #212529;
}

/* Navbar */
.odoo-navbar {
    background: var(--odoo-primary);
}
.odoo-navbar .navbar-brand,
.odoo-navbar .nav-link { color: #fff; }
.odoo-navbar .nav-link:hover { color: #f1e6ee; }

/* Breadcrumb */
.odoo-breadcrumb {
    background: #f1f3f5;
    padding: .5rem 1rem;
    font-size: 13px;
    border-bottom: 1px solid var(--odoo-border);
}
.odoo-breadcrumb a { color: var(--odoo-primary); text-decoration: none; }
.odoo-breadcrumb a:hover { text-decoration: underline; }

/* Buttons */
.btn-odoo-primary {
    background: var(--odoo-primary);
    color: #fff;
    border-radius: 6px;
    border: none;
}
.btn-odoo-primary:hover { background: var(--odoo-primary-dark); color: #fff; }
.btn-odoo-secondary {
    background: #fff;
    border: 1px solid var(--odoo-border);
    color: #495057;
    border-radius: 6px;
}
.btn-odoo-secondary:hover { background: #f1f3f5; color: #212529; }

/* Page header */
.odoo-page-header {
    background: #fff;
    border-bottom: 1px solid var(--odoo-border);
    padding: 1rem 1.5rem;
}
.odoo-page-title { font-size: 20px; font-weight: 600; color: #212529; margin: 0; }

/* Welcome header (dashboard) */
.dash-welcome { font-size: 2rem; font-weight: 400; color: #212529; }
.dash-welcome strong { font-weight: 700; }
.dash-sub { color: #6c757d; }

/* App cards (dashboard) */
.app-card {
    background: #fff;
    border: 1px solid #eef0f2;
    border-radius: 14px;
    padding: 2rem 1rem;
    text-align: center;
    text-decoration: none;
    color: #212529;
    transition: all .18s ease;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    min-height: 170px;
    height: 100%;
    box-shadow: 0 1px 3px rgba(0,0,0,.04);
}
.app-card:hover {
    transform: translateY(-4px);
    box-shadow: 0 10px 24px rgba(135,90,123,.14);
    border-color: var(--odoo-primary-light);
    color: var(--odoo-primary);
}
.app-card .app-icon {
    font-size: 2.6rem;
    line-height: 1;
    margin-bottom: 1rem;
    color: var(--odoo-primary);
}
.app-card .app-name { font-size: 1rem; font-weight: 600; margin: 0; }
.app-card.disabled { opacity: .5; cursor: not-allowed; }
.app-card.disabled:hover { transform: none; box-shadow: 0 1px 3px rgba(0,0,0,.04); border-color: #eef0f2; color: #212529; }

/* "New App" dashed card */
.app-card.app-card-add {
    border: 2px dashed #d4d7db;
    box-shadow: none;
    color: #8a9099;
    background: transparent;
}
.app-card.app-card-add .app-icon,
.app-card.app-card-add:hover { color: var(--odoo-primary); }
.app-card.app-card-add:hover { border-color: var(--odoo-primary-light); transform: translateY(-4px); box-shadow: none; }

/* Navbar app-launcher links */
.odoo-navbar .nav-link { font-size: .9rem; }
.btn-new-user {
    background: rgba(255,255,255,.12);
    border: 1px solid rgba(255,255,255,.4);
    color: #fff;
    border-radius: 6px;
    font-size: .85rem;
}
.btn-new-user:hover { background: #fff; color: var(--odoo-primary); }

/* Login */
.login-wrap {
    min-height: 100vh;
    display: flex; align-items: center; justify-content: center;
    background: linear-gradient(135deg, var(--odoo-primary) 0%, var(--odoo-primary-dark) 100%);
}
.login-card {
    background: #fff;
    border-radius: 12px;
    padding: 2.5rem;
    width: 100%; max-width: 400px;
    box-shadow: 0 12px 40px rgba(0,0,0,.2);
}

/* Tabbed form (estilo "Editar Tercero") */
.form-card {
    background: #fff;
    border-radius: 16px;
    box-shadow: 0 1px 4px rgba(0,0,0,.06);
    padding: 1.5rem 2rem 2rem;
}
.nav-tabs-modern {
    border-bottom: 1px solid #e9ecef;
    margin-bottom: 1.75rem;
    flex-wrap: wrap;
}
.nav-tabs-modern .nav-link {
    color: #6c757d;
    border: none;
    border-bottom: 2px solid transparent;
    font-weight: 600;
    font-size: .9rem;
    padding: .6rem 1rem;
    margin-bottom: -1px;
    background: none;
}
.nav-tabs-modern .nav-link:hover { color: var(--odoo-primary); }
.nav-tabs-modern .nav-link.active {
    color: var(--odoo-primary);
    border-bottom-color: var(--odoo-primary);
}
.form-label-modern { font-weight: 600; font-size: .82rem; color: #344050; margin-bottom: .35rem; }
.form-control-modern, .form-select-modern {
    border-radius: 10px;
    border: 1px solid #e3e6ea;
    padding: .55rem .9rem;
    font-size: .9rem;
}
.form-control-modern:focus, .form-select-modern:focus {
    border-color: var(--odoo-primary-light);
    box-shadow: 0 0 0 .2rem rgba(135,90,123,.12);
}
.subsection-title {
    font-weight: 700;
    font-size: .9rem;
    color: var(--odoo-primary);
    border-bottom: 1px solid #eef0f2;
    padding-bottom: .5rem;
    margin-bottom: 1rem;
}
.btn-save-lg { padding: .6rem 1.5rem; border-radius: 10px; font-weight: 600; }

/* Section headers (cliente form, inspired by the legacy UI) */
.section-header {
    background: #dce6f1;
    color: #1f3864;
    font-weight: 700;
    font-size: .85rem;
    letter-spacing: .3px;
    border-bottom: 1px solid #c5d4e8;
}
.section-header-dark {
    background: #8b0000;
    color: #fff;
    font-weight: 700;
    font-size: .85rem;
    letter-spacing: .3px;
}
.col-form-label-sm { font-size: .8rem; padding-top: .25rem; }

/* Inline-edit user table (per design system) */
.user-row:hover { background: #f8f9fa; }
.user-row:hover .edit-field {
    border: 1px solid var(--odoo-border) !important;
    background: #fff !important;
}
.edit-field { max-width: 200px; }
.password-input { max-width: 160px; font-size: .85rem; }
