/* LifeSync SaaS Theme - inspired by modern SaaS dashboards. No proprietary styles copied. */
:root {
    --bg: #0b0b0f;
    --surface: #121217;
    --surface-2: #17171f;
    --surface-3: #1d1d26;
    --border: #252535;
    --text: #e6e6f0;
    --text-secondary: #a0a0b2;
    --text-tertiary: #7a7a8c;
    --primary: #8257e6;
    --primary-600: #9466ff;
    --secondary: #04d361;
    --success: #10b981;
    --warning: #f59e0b;
    --error: #ef4444;
    --radius: 12px;
    --radius-sm: 8px;
    --shadow: 0 8px 28px rgba(0,0,0,.35);
}

html, body {
    background: var(--bg);
    color: var(--text);
    /* include emoji-capable fallbacks so icons like emojis render across platforms */
    font-family: 'Inter', 'Segoe UI Emoji', 'Apple Color Emoji', 'Noto Color Emoji', 'Segoe UI Symbol', Helvetica, Arial, sans-serif;
}

/* Layout */
.ls-app {
    display: flex;
    min-height: 100vh;
}

.ls-sidebar {
    width: 280px;
    background: linear-gradient(180deg,var(--surface-2),var(--surface));
    border-right: 1px solid var(--border);
    position: sticky;
    top: 0;
    height: 100vh;
    padding: 1.25rem 1rem;
}

.ls-main {
    flex: 1;
    display: flex;
    flex-direction: column;
}

.ls-topbar {
    height: 64px;
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 0 1.25rem;
    border-bottom: 1px solid var(--border);
    background: var(--surface);
    position: sticky;
    top: 0;
    z-index: 10
}

.ls-content {
    padding: 1.25rem 1.5rem;
}

/***** Navigation *****/
.brand {
    display: flex;
    align-items: center;
    gap: .6rem;
    font-weight: 700;
    letter-spacing: .2px
}

    .brand .dot {
        width: 10px;
        height: 10px;
        border-radius: 50%;
        background: var(--secondary);
        box-shadow: 0 0 16px var(--secondary)
    }

.nav-group {
    margin-top: 1rem;
    display: flex;
    flex-direction: column;
    gap: .25rem
}

.nav-link {
    display: flex;
    align-items: center;
    gap: .75rem;
    padding: .6rem .75rem;
    border-radius: 10px;
    color: var(--text-secondary);
    text-decoration: none
}

    .nav-link.active, .nav-link:hover {
        background: var(--surface-3);
        color: var(--text)
    }

.nav-sep {
    margin: .75rem 0;
    border-top: 1px solid var(--border)
}

/***** Common UI *****/
.content-header {
    display: flex;
    align-items: flex-end;
    justify-content: space-between;
    margin: 0 0 1.25rem 0
}

.page-title {
    font-size: 1.5rem;
    margin: 0
}

.page-description {
    margin: .25rem 0 0 0;
    color: var(--text-secondary)
}

.card {
    background: var(--surface);
    border: 1px solid var(--border);
    border-radius: var(--radius);
    box-shadow: var(--shadow)
}

.card-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 1rem 1rem;
    border-bottom: 1px solid var(--border)
}

.card-title {
    margin: 0;
    font-size: 1rem
}

.card-body {
    padding: 1rem
}

.btn {
    border: none;
    border-radius: 10px;
    padding: .6rem .9rem;
    font-weight: 600;
    cursor: pointer;
}

.btn-primary {
    background: linear-gradient(90deg,var(--primary),var(--primary-600));
    color: white
}

.btn-secondary {
    background: var(--surface-3);
    color: var(--text)
}

.btn-danger {
    background: var(--error);
    color: white
}

.btn-sm {
    padding: .35rem .6rem;
    border-radius: 8px;
    font-size: .875rem
}

.loading {
    border: 3px solid var(--surface-3);
    border-top: 3px solid var(--primary);
    border-radius: 50%;
    width: 28px;
    height: 28px;
    animation: spin 1s linear infinite
}

@keyframes spin {
    to {
        transform: rotate(360deg)
    }
}

/* Stats */
.stats-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill,minmax(220px,1fr));
    gap: 1rem;
    margin: 0 0 1.25rem 0
}

.stat-card {
    background: var(--surface);
    border: 1px solid var(--border);
    border-radius: var(--radius);
    padding: 1rem
}

.stat-header {
    display: flex;
    align-items: center;
    justify-content: space-between
}

.stat-value {
    font-size: 1.35rem;
    font-weight: 700
}

.stat-label {
    color: var(--text-secondary);
    font-size: .9rem
}

.stat-icon {
    width: 40px;
    height: 40px;
    border-radius: 10px;
    display: flex;
    align-items: center;
    justify-content: center
}

    .stat-icon.primary {
        background: rgba(130,87,230,.15);
        color: var(--primary)
    }

    .stat-icon.secondary {
        background: rgba(4,211,97,.15);
        color: var(--secondary)
    }

    .stat-icon.success {
        background: rgba(16,185,129,.15);
        color: var(--success)
    }

    .stat-icon.warning {
        background: rgba(245,158,11,.15);
        color: var(--warning)
    }

    .stat-icon.error {
        background: rgba(239,68,68,.15);
        color: var(--error)
    }

.stat-change {
    margin-top: .6rem;
    color: var(--text-secondary);
    font-size: .85rem
}

    .stat-change.positive {
        color: var(--success)
    }

    .stat-change.negative {
        color: var(--error)
    }

/* Badges */
.badge {
    display: inline-flex;
    align-items: center;
    gap: .35rem;
    padding: .25rem .5rem;
    border-radius: 999px;
    font-size: .75rem;
    border: 1px solid var(--border);
    background: var(--surface-3)
}

.badge-primary {
    background: rgba(130,87,230,.15);
    color: var(--primary);
    border-color: rgba(130,87,230,.35)
}

.badge-success {
    background: rgba(16,185,129,.15);
    color: var(--success);
    border-color: rgba(16,185,129,.35)
}

.badge-warning {
    background: rgba(245,158,11,.15);
    color: var(--warning);
    border-color: rgba(245,158,11,.35)
}

.badge-error {
    background: rgba(239,68,68,.15);
    color: var(--error);
    border-color: rgba(239,68,68,.35)
}

.badge-secondary {
    background: rgba(160,160,178,.15);
    color: var(--text);
    border-color: rgba(160,160,178,.3)
}

/* Forms */
.form-group {
    margin-bottom: .9rem
}

.form-label {
    display: block;
    margin-bottom: .35rem;
    color: var(--text-secondary);
    font-size: .9rem
}

.form-control {
    background: var(--surface-3);
    border: 1px solid var(--border);
    color: var(--text);
    border-radius: 10px;
    padding: .5rem .75rem
}

/* Alerts */
.alert {
    border-radius: 10px;
    padding: .85rem 1rem;
    border: 1px solid var(--border)
}

.alert-info {
    background: rgba(130,87,230,.08);
    color: var(--text)
}

.alert-secondary {
    background: var(--surface-2);
    color: var(--text)
}

/* site.css ou wwwroot/css/app.css */
.app-grid {
    background: var(--surface-1);
    border: 1px solid var(--border);
    border-radius: 14px;
    box-shadow: 0 4px 16px -8px rgba(0,0,0,.3);
    overflow: hidden;
    font-size: .85rem;
}

    .app-grid .e-gridheader {
        background: var(--surface-2);
        border-bottom: 1px solid var(--border);
    }

    .app-grid .e-headercell {
        background: transparent;
        color: var(--color-text);
        font-weight: 600;
        padding: 10px 14px;
    }

    .app-grid .e-rowcell {
        background: var(--surface-1);
        border-color: var(--surface-2);
        padding: 10px 14px;
    }

        .app-grid .e-rowcell:not(.e-active):hover {
            background: var(--surface-2);
            transition: background .15s;
        }

    .app-grid .e-row.e-altrow .e-rowcell {
        background: var(--surface-1);
    }

    .app-grid .e-selectionbackground {
        background: var(--primary) !important;
        color: #fff;
    }

    .app-grid .e-pager {
        background: var(--surface-2);
        border-top: 1px solid var(--border);
        padding: .35rem .75rem;
    }

        .app-grid .e-pager .e-numericitem.e-currentitem,
        .app-grid .e-pager .e-numericitem:hover {
            background: var(--primary);
            color: #fff;
            border-radius: 8px;
        }

    .app-grid .e-filterbarcell,
    .app-grid .e-filterbar {
        background: var(--surface-1);
        border-color: var(--border);
    }

    .app-grid .e-icons.e-icon-filter::before {
        color: var(--text-tertiary);
    }

    .app-grid .e-gridcontent {
        scrollbar-color: var(--primary) var(--surface-2);
    }

        .app-grid .e-gridcontent::-webkit-scrollbar {
            height: 10px;
            width: 10px;
        }

        .app-grid .e-gridcontent::-webkit-scrollbar-track {
            background: var(--surface-2);
        }

        .app-grid .e-gridcontent::-webkit-scrollbar-thumb {
            background: var(--primary);
            border-radius: 10px;
            border: 2px solid var(--surface-2);
        }

/* Responsive */
@media (max-width: 960px) {
    .ls-sidebar {
        position: fixed;
        left: -280px;
        transition: left .25s ease
    }

        .ls-sidebar.open {
            left: 0
        }

    .ls-topbar .menu-btn {
        display: inline-flex
    }
}

/* Task Cards */
.task-card {
    background: var(--surface);
    border: 1px solid var(--border);
    border-radius: var(--radius);
    padding: 1rem;
    transition: all 0.2s ease;
}

.task-card:hover {
    border-color: var(--primary);
    box-shadow: 0 4px 12px rgba(130, 87, 230, 0.15);
}

.task-card-header {
    margin-bottom: 0.75rem;
}

.task-title-row {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 0.5rem;
    margin-bottom: 0.5rem;
}

.task-title {
    margin: 0;
    font-size: 1rem;
    font-weight: 600;
    color: var(--text);
}

.task-description {
    color: var(--text-secondary);
    font-size: 0.875rem;
    line-height: 1.5;
}

.task-card-body {
    margin-bottom: 0.75rem;
}

.task-labels {
    display: flex;
    flex-wrap: wrap;
    gap: 0.35rem;
    margin-bottom: 0.75rem;
}

.task-meta {
    display: flex;
    gap: 1rem;
    flex-wrap: wrap;
}

.task-meta-item {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    font-size: 0.875rem;
}

.task-meta-label {
    color: var(--text-tertiary);
}

.task-meta-value {
    color: var(--text);
}

.task-card-actions {
    display: flex;
    gap: 0.5rem;
    padding-top: 0.75rem;
    border-top: 1px solid var(--border);
}

/* Task List */
.tasks-container {
    display: flex;
    flex-direction: column;
    gap: 1.5rem;
}

.tasks-date-section {
    display: flex;
    flex-direction: column;
    gap: 0.75rem;
}

.tasks-date-header {
    font-size: 0.875rem;
    font-weight: 600;
    color: var(--text-secondary);
    text-transform: uppercase;
    letter-spacing: 0.05em;
    padding: 0.5rem 0;
    border-bottom: 1px solid var(--border);
}

.tasks-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(320px, 1fr));
    gap: 1rem;
}

/* Filter Buttons */
.filter-buttons {
    display: flex;
    gap: 0.5rem;
    flex-wrap: wrap;
    margin-bottom: 1rem;
}

.filter-btn {
    padding: 0.5rem 1rem;
    border: 1px solid var(--border);
    background: var(--surface-2);
    color: var(--text);
    border-radius: 10px;
    cursor: pointer;
    font-weight: 500;
    font-size: 0.875rem;
    transition: all 0.2s ease;
}

.filter-btn:hover {
    background: var(--surface-3);
}

.filter-btn.active {
    background: var(--primary);
    border-color: var(--primary);
    color: white;
}

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

/* Diary Cards */
.diary-card {
    background: var(--surface);
    border: 1px solid var(--border);
    border-radius: var(--radius);
    padding: 1.25rem;
    transition: all 0.2s ease;
}

.diary-card:hover {
    border-color: var(--primary);
    box-shadow: 0 4px 12px rgba(130, 87, 230, 0.15);
}

.diary-card-header {
    margin-bottom: 1rem;
    padding-bottom: 1rem;
    border-bottom: 1px solid var(--border);
}

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

.diary-title {
    margin: 0;
    font-size: 1.1rem;
    font-weight: 600;
    color: var(--text);
}

.diary-stats {
    display: flex;
    gap: 0.5rem;
}

.diary-card-body {
    display: flex;
    flex-direction: column;
    gap: 1rem;
}

.diary-section {
    background: var(--surface-2);
    border-radius: var(--radius-sm);
    padding: 1rem;
}

.section-title {
    margin: 0 0 0.75rem 0;
    font-size: 0.95rem;
    font-weight: 600;
    color: var(--text);
}

.meal-item {
    background: var(--surface-3);
    border-radius: var(--radius-sm);
    padding: 0.875rem;
    margin-bottom: 0.75rem;
}

.meal-item:last-child {
    margin-bottom: 0;
}

.meal-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin-bottom: 0.5rem;
}

.meal-name {
    font-weight: 600;
    color: var(--text);
}

.meal-description {
    margin: 0 0 0.75rem 0;
    font-size: 0.875rem;
    color: var(--text-secondary);
}

.meal-foods {
    display: flex;
    flex-direction: column;
    gap: 0.35rem;
    margin-bottom: 0.75rem;
}

.food-item {
    display: flex;
    align-items: center;
    justify-content: space-between;
    font-size: 0.875rem;
    padding: 0.25rem 0;
}

.food-name {
    color: var(--text);
}

.food-details {
    color: var(--text-tertiary);
}

.meal-actions {
    display: flex;
    gap: 0.5rem;
    padding-top: 0.75rem;
    border-top: 1px solid var(--border);
}

.liquids-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(150px, 1fr));
    gap: 0.75rem;
}

.liquid-item {
    background: var(--surface-3);
    border-radius: var(--radius-sm);
    padding: 0.75rem;
    display: flex;
    align-items: center;
    gap: 0.5rem;
}

.liquid-icon {
    font-size: 1.25rem;
}

.liquid-info {
    display: flex;
    flex-direction: column;
    flex: 1;
}

.liquid-name {
    font-size: 0.875rem;
    font-weight: 600;
    color: var(--text);
}

.liquid-quantity {
    font-size: 0.75rem;
    color: var(--text-secondary);
}

.empty-diary {
    text-align: center;
    padding: 2rem 1rem;
}

.empty-icon {
    font-size: 2.5rem;
    display: block;
    margin-bottom: 0.75rem;
}

.diary-card-actions {
    display: flex;
    gap: 0.5rem;
    padding-top: 1rem;
    border-top: 1px solid var(--border);
}

/* Diaries Container */
.diaries-container {
    display: flex;
    flex-direction: column;
    gap: 1.5rem;
}

.diaries-date-section {
    display: flex;
    flex-direction: column;
    gap: 1rem;
}

.diaries-date-header {
    font-size: 0.875rem;
    font-weight: 600;
    color: var(--text-secondary);
    text-transform: uppercase;
    letter-spacing: 0.05em;
    padding: 0.5rem 0;
    border-bottom: 1px solid var(--border);
}

/* Progress Panel */
.progress-panel {
    display: flex;
    flex-direction: column;
    gap: 1rem;
}

.progress-item {
    margin-bottom: 1.5rem;
}

.progress-item:last-child {
    margin-bottom: 0;
}

.progress-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin-bottom: 0.75rem;
}

.progress-label {
    font-size: 0.9rem;
    font-weight: 600;
    color: var(--text);
}

.progress-values {
    font-size: 0.875rem;
    color: var(--text-secondary);
}

.progress-values strong {
    color: var(--text);
    font-size: 1rem;
}

.progress-bar-container {
    height: 32px;
    background: var(--surface-3);
    border-radius: 8px;
    overflow: hidden;
    position: relative;
}

.progress-bar {
    height: 100%;
    background: linear-gradient(90deg, var(--warning), var(--secondary));
    border-radius: 8px;
    transition: width 0.3s ease;
    display: flex;
    align-items: center;
    justify-content: flex-end;
    padding-right: 0.75rem;
    min-width: 50px;
}

.progress-bar.water {
    background: linear-gradient(90deg, var(--primary), #4a9eff);
}

.progress-percentage {
    font-size: 0.75rem;
    font-weight: 700;
    color: white;
    text-shadow: 0 1px 2px rgba(0, 0, 0, 0.3);
}

.quick-stats {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 1rem;
    margin-top: 1rem;
    padding-top: 1rem;
    border-top: 1px solid var(--border);
}

.stat-item {
    display: flex;
    align-items: center;
    gap: 0.75rem;
    background: var(--surface-2);
    padding: 0.875rem;
    border-radius: var(--radius-sm);
}

.stat-icon {
    font-size: 1.75rem;
}

.stat-info {
    display: flex;
    flex-direction: column;
}

.stat-value {
    font-size: 1.25rem;
    font-weight: 700;
    color: var(--text);
}

.stat-label {
    font-size: 0.75rem;
    color: var(--text-tertiary);
}

.water-shortcuts {
    margin-top: 1rem;
}

.water-buttons {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 0.75rem;
}

.water-btn {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 0.25rem;
    padding: 0.875rem;
    font-size: 0.875rem;
}

.water-icon {
    font-size: 1.25rem;
}

/* Nutrition Layout */
.nutrition-layout {
    display: grid;
    grid-template-columns: 1fr 380px;
    gap: 1.5rem;
}

@media (max-width: 1200px) {
    .nutrition-layout {
        grid-template-columns: 1fr;
    }
    
    .progress-panel {
        order: -1;
    }
}

@media (max-width: 768px) {
    .liquids-grid {
        grid-template-columns: 1fr;
    }
    
    .water-buttons {
        grid-template-columns: 1fr;
    }
}

/* Transaction Cards */
.transaction-card {
    background: var(--surface);
    border: 1px solid var(--border);
    border-radius: var(--radius);
    padding: 1.25rem;
    transition: all 0.2s ease;
}

.transaction-card:hover {
    border-color: var(--primary);
    box-shadow: 0 4px 12px rgba(130, 87, 230, 0.15);
}

.transaction-card-header {
    margin-bottom: 1rem;
    padding-bottom: 1rem;
    border-bottom: 1px solid var(--border);
}

.transaction-title-row {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 0.75rem;
    margin-bottom: 0.75rem;
}

.transaction-title {
    margin: 0;
    font-size: 1rem;
    font-weight: 600;
    color: var(--text);
}

.transaction-amount {
    font-size: 1.5rem;
    font-weight: 700;
    margin-top: 0.5rem;
}

.amount-positive {
    color: var(--success);
}

.amount-negative {
    color: var(--error);
}

.transaction-card-body {
    margin-bottom: 1rem;
}

.transaction-meta {
    display: flex;
    flex-direction: column;
    gap: 0.75rem;
}

.transaction-meta-item {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    flex-wrap: wrap;
}

.transaction-meta-label {
    font-size: 0.875rem;
    color: var(--text-secondary);
    font-weight: 500;
}

.transaction-meta-value {
    font-size: 0.875rem;
    color: var(--text);
}

.transaction-card-actions {
    display: flex;
    gap: 0.5rem;
    padding-top: 1rem;
    border-top: 1px solid var(--border);
}

/* Transactions Container */
.transactions-container {
    display: flex;
    flex-direction: column;
    gap: 1.5rem;
}

.transactions-month-section {
    display: flex;
    flex-direction: column;
    gap: 1rem;
}

.transactions-month-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 0.75rem 1rem;
    background: var(--surface-2);
    border: 1px solid var(--border);
    border-radius: var(--radius-sm);
    font-size: 1rem;
    font-weight: 600;
    color: var(--text);
}

.month-summary {
    display: flex;
    gap: 1.5rem;
    align-items: center;
    font-size: 0.875rem;
}

.month-income {
    color: var(--success);
}

.month-expense {
    color: var(--error);
}

.month-balance {
    font-weight: 700;
}

.transactions-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(350px, 1fr));
    gap: 1rem;
}

/* Financial Summary Cards */
.financial-summary {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
    gap: 1rem;
    margin-bottom: 1.5rem;
}

.summary-card {
    background: var(--surface-2);
    border: 1px solid var(--border);
    border-radius: var(--radius-sm);
    padding: 1.25rem;
}

.summary-label {
    font-size: 0.875rem;
    color: var(--text-secondary);
    margin-bottom: 0.5rem;
}

.summary-value {
    font-size: 1.75rem;
    font-weight: 700;
    margin-bottom: 0.25rem;
}

.summary-detail {
    font-size: 0.75rem;
    color: var(--text-tertiary);
}

/* Filter Pills */
.filter-pills {
    display: flex;
    gap: 0.5rem;
    flex-wrap: wrap;
    margin-bottom: 1.5rem;
}

.filter-pill {
    padding: 0.5rem 1rem;
    background: var(--surface-2);
    border: 1px solid var(--border);
    border-radius: 20px;
    font-size: 0.875rem;
    color: var(--text);
    cursor: pointer;
    transition: all 0.2s ease;
}

.filter-pill:hover {
    background: var(--surface-3);
    border-color: var(--primary);
}

.filter-pill.active {
    background: var(--primary);
    border-color: var(--primary);
    color: white;
}

@media (max-width: 768px) {
    .transactions-grid {
        grid-template-columns: 1fr;
    }
    
    .month-summary {
        flex-direction: column;
        gap: 0.5rem;
        align-items: flex-start;
    }
    
    .transactions-month-header {
        flex-direction: column;
        align-items: flex-start;
        gap: 0.75rem;
    }
}

/* Exercise Cards */
.exercise-card {
    background: var(--surface);
    border: 1px solid var(--border);
    border-radius: var(--radius);
    padding: 1.25rem;
    transition: all 0.2s ease;
}

.exercise-card:hover {
    border-color: var(--primary);
    box-shadow: 0 4px 12px rgba(130, 87, 230, 0.15);
}

.exercise-card-header {
    margin-bottom: 1rem;
    padding-bottom: 1rem;
    border-bottom: 1px solid var(--border);
}

.exercise-title-row {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 0.75rem;
    margin-bottom: 0.5rem;
}

.exercise-title {
    margin: 0;
    font-size: 1rem;
    font-weight: 600;
    color: var(--text);
}

.exercise-description {
    color: var(--text-secondary);
    font-size: 0.875rem;
    line-height: 1.5;
}

.exercise-card-body {
    margin-bottom: 1rem;
}

.exercise-meta {
    display: flex;
    flex-direction: column;
    gap: 0.75rem;
}

.exercise-meta-item {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    flex-wrap: wrap;
}

.exercise-meta-label {
    font-size: 0.875rem;
    color: var(--text-secondary);
    font-weight: 500;
}

.exercise-meta-value {
    font-size: 0.875rem;
    color: var(--text);
}

.exercise-card-actions {
    display: flex;
    gap: 0.5rem;
    padding-top: 1rem;
    border-top: 1px solid var(--border);
    flex-wrap: wrap;
}

/* Session Cards */
.session-card {
    background: var(--surface);
    border: 1px solid var(--border);
    border-radius: var(--radius);
    padding: 1.25rem;
    transition: all 0.2s ease;
}

.session-card:hover {
    border-color: var(--primary);
    box-shadow: 0 4px 12px rgba(130, 87, 230, 0.15);
}

.session-card-header {
    margin-bottom: 1rem;
    padding-bottom: 1rem;
    border-bottom: 1px solid var(--border);
}

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

.session-title {
    margin: 0;
    font-size: 1rem;
    font-weight: 600;
    color: var(--text);
}

.session-card-body {
    margin-bottom: 1rem;
}

.session-meta {
    display: flex;
    flex-direction: column;
    gap: 0.75rem;
}

.session-meta-item {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    flex-wrap: wrap;
}

.session-meta-label {
    font-size: 0.875rem;
    color: var(--text-secondary);
    font-weight: 500;
}

.session-meta-value {
    font-size: 0.875rem;
    color: var(--text);
}

.session-notes {
    margin: 0.5rem 0 0 0;
    padding: 0.75rem;
    background: var(--surface-2);
    border-radius: var(--radius-sm);
    font-size: 0.875rem;
    color: var(--text);
    line-height: 1.5;
}

.session-card-actions {
    display: flex;
    gap: 0.5rem;
    padding-top: 1rem;
    border-top: 1px solid var(--border);
    flex-wrap: wrap;
}

/* Routine Cards */
.routine-card {
    background: var(--surface);
    border: 1px solid var(--border);
    border-radius: var(--radius);
    padding: 1.25rem;
    transition: all 0.2s ease;
}

.routine-card:hover {
    border-color: var(--primary);
    box-shadow: 0 4px 12px rgba(130, 87, 230, 0.15);
}

.routine-card-header {
    margin-bottom: 1rem;
    padding-bottom: 1rem;
    border-bottom: 1px solid var(--border);
}

.routine-title-row {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 0.75rem;
    margin-bottom: 0.5rem;
}

.routine-title {
    margin: 0;
    font-size: 1rem;
    font-weight: 600;
    color: var(--text);
}

.routine-description {
    color: var(--text-secondary);
    font-size: 0.875rem;
    line-height: 1.5;
}

.routine-card-body {
    margin-bottom: 1rem;
}

.routine-meta {
    display: flex;
    flex-direction: column;
    gap: 0.75rem;
}

.routine-meta-item {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    flex-wrap: wrap;
}

.routine-meta-label {
    font-size: 0.875rem;
    color: var(--text-secondary);
    font-weight: 500;
}

.routine-meta-value {
    font-size: 0.875rem;
    color: var(--text);
}

.routine-card-actions {
    display: flex;
    gap: 0.5rem;
    padding-top: 1rem;
    border-top: 1px solid var(--border);
    flex-wrap: wrap;
}

/* Gym Containers */
.exercises-container,
.sessions-container,
.routines-container {
    display: flex;
    flex-direction: column;
    gap: 1.5rem;
}

.exercises-group-section,
.sessions-month-section,
.routines-section {
    display: flex;
    flex-direction: column;
    gap: 1rem;
}

.exercises-group-header,
.sessions-month-header,
.routines-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 0.75rem 1rem;
    background: var(--surface-2);
    border: 1px solid var(--border);
    border-radius: var(--radius-sm);
    font-size: 1rem;
    font-weight: 600;
    color: var(--text);
}

.exercises-grid,
.sessions-grid,
.routines-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(350px, 1fr));
    gap: 1rem;
}

@media (max-width: 768px) {
    .exercises-grid,
    .sessions-grid,
    .routines-grid {
        grid-template-columns: 1fr;
    }
}

/* Routine Details Modal */
.routine-exercises-list {
    display: flex;
    flex-direction: column;
    gap: 1rem;
}

.routine-exercise-item {
    display: flex;
    gap: 1rem;
    padding: 1.25rem;
    background: var(--surface-2);
    border: 1px solid var(--border);
    border-radius: var(--radius-sm);
    transition: all 0.2s ease;
}

.routine-exercise-item:hover {
    border-color: var(--primary);
    box-shadow: 0 2px 8px rgba(130, 87, 230, 0.1);
}

.exercise-number {
    display: flex;
    align-items: center;
    justify-content: center;
    min-width: 40px;
    height: 40px;
    background: var(--primary);
    color: white;
    border-radius: 50%;
    font-weight: 700;
    font-size: 1.1rem;
}

.exercise-info {
    flex: 1;
    display: flex;
    flex-direction: column;
    gap: 0.75rem;
}

.exercise-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
}

.exercise-name {
    margin: 0;
    font-size: 1rem;
    font-weight: 600;
    color: var(--text);
}

.exercise-details {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(150px, 1fr));
    gap: 0.75rem;
}

.detail-item {
    display: flex;
    flex-direction: column;
    gap: 0.25rem;
}

.detail-label {
    font-size: 0.8rem;
    color: var(--text-secondary);
    font-weight: 500;
}

.detail-value {
    font-size: 0.95rem;
    color: var(--text);
    font-weight: 600;
}

.exercise-instructions {
    padding: 0.75rem;
    background: var(--surface-3);
    border-radius: var(--radius-sm);
}

.exercise-instructions p {
    margin: 0.5rem 0 0 0;
    font-size: 0.875rem;
    color: var(--text);
    line-height: 1.5;
}

/* Complete Exercise Modal */
.complete-exercise-content {
    display: flex;
    flex-direction: column;
    gap: 1.5rem;
}

.proposed-values {
    padding: 1.25rem;
    background: var(--surface-2);
    border: 1px solid var(--border);
    border-radius: var(--radius-sm);
}

.values-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(120px, 1fr));
    gap: 1rem;
}

.value-item {
    display: flex;
    flex-direction: column;
    gap: 0.5rem;
    padding: 0.75rem;
    background: var(--surface-3);
    border-radius: var(--radius-sm);
    text-align: center;
}

.value-label {
    font-size: 0.8rem;
    color: var(--text-secondary);
}

.value-number {
    font-size: 1.5rem;
    font-weight: 700;
    color: var(--text);
}

/* Add Exercise to Routine Modal */
.form-row {
    display: flex;
    gap: 1rem;
}

@media (max-width: 768px) {
    .form-row {
        flex-direction: column;
    }

    .exercise-details {
        grid-template-columns: 1fr;
    }

    .values-grid {
        grid-template-columns: 1fr;
    }

    .routine-exercise-item {
        flex-direction: column;
    }

    .exercise-number {
        align-self: flex-start;
    }
}

.e-dialog {
    background: var(--surface) !important;
    border: 1px solid var(--border) !important;
    border-radius: var(--radius) !important;
    box-shadow: var(--shadow) !important;
    z-index: 100000 !important;
}

.e-dlg-header {
    background: var(--surface-2) !important;
    border-bottom: 1px solid var(--border) !important;
    color: var(--text) !important;
}

.e-dlg-content {
    background: var(--surface) !important;
    color: var(--text) !important;
}

/* Backdrop escuro */
.e-dlg-overlay {
    position: fixed !important;
    z-index: 99999 !important;
    background: rgba(0, 0, 0, 0.7) !important;
}

/* Dialog / Modal form improvements */
.e-dlg-content .form-group,
.e-dialog .form-group {
    display: flex;
    flex-direction: column;
    gap: .35rem;
    margin-bottom: .75rem;
}

.e-dlg-content .form-label,
.e-dialog .form-label {
    margin-bottom: .25rem;
    color: var(--text-secondary);
    font-size: .9rem;
}

.e-dlg-content .form-control,
.e-dialog .form-control,
.e-dlg-content input,
.e-dlg-content textarea,
.e-dlg-content select,
.e-dialog input,
.e-dialog textarea,
.e-dialog select {
    width: 100% !important;
    box-sizing: border-box;
    background: var(--surface-3);
    border: 1px solid var(--border);
    color: var(--text);
    border-radius: 8px;
    padding: .45rem .6rem;
}

/* Smaller inputs used in inline rows inside dialogs */
.e-dlg-content .form-row,
.e-dialog .form-row {
    display: flex;
    gap: .5rem;
    align-items: center;
}

.e-dlg-content .form-row .form-control,
.e-dialog .form-row .form-control {
    width: auto;
    flex: 1 1 auto;
}

/* Footer/action buttons alignment inside dialog */
.e-dlg-content .dlg-actions,
.e-dialog .dlg-actions {
    display: flex;
    justify-content: flex-end;
    gap: .5rem;
    padding-top: .5rem;
}

/* Ensure dialog templates content spacing looks consistent */
.e-dlg-content {
    padding: 1rem !important;
}

/* Responsive adjustments */
@media (max-width: 520px) {
    .e-dlg-content .form-row,
    .e-dialog .form-row {
        flex-direction: column;
        align-items: stretch;
    }
}

