/* app.css - signed-in app skin: background, header, unified pill buttons */

body.app-shell {
    --app-accent: #c45c6a;
    --app-accent-hover: #a84a58;
    --app-brand-color: var(--wine-text);
    --app-shadow: 0 0.75rem 2rem rgba(0, 0, 0, 0.1);
    --app-radius: 1rem;
    --app-btn-radius: 999px;
    --app-btn-shadow: 0 0.3rem 0.85rem rgba(0, 0, 0, 0.1);
    background-image: none;
    background-color: var(--bg-color);
}

body.app-shell.dark-mode {
    --app-accent: #9d5a68;
    --app-accent-hover: #b86b7a;
    --app-brand-color: #ecc694;
    --app-shadow: 0 0.75rem 2rem rgba(0, 0, 0, 0.32);
    --app-btn-shadow: 0 0.3rem 0.85rem rgba(0, 0, 0, 0.22);
    background-image: none;
}

/* --- Login --- */
body.app-shell #page-login {
    background: linear-gradient(
        145deg,
        color-mix(in srgb, var(--wine-text) 10%, var(--bg-color)) 0%,
        var(--bg-color) 50%,
        color-mix(in srgb, var(--border-color) 6%, var(--bg-color)) 100%
    );
    min-height: 100vh;
    padding: 1.5rem 1rem 2.5rem;
    box-sizing: border-box;
}

body.app-shell.dark-mode #page-login {
    background: linear-gradient(145deg, #2a1520 0%, #151b2e 42%, #0b1020 100%);
}

body.app-shell .auth-title {
    color: var(--app-brand-color);
    text-wrap: balance;
}

body.app-shell .auth-subtitle {
    color: color-mix(in srgb, var(--app-brand-color) 72%, var(--text-color));
    opacity: 1;
}

body.app-shell .auth-card {
    border-radius: var(--app-radius);
    border: 1px solid color-mix(in srgb, var(--border-color) 32%, transparent);
    box-shadow: var(--app-shadow);
}

/* --- Header --- */
body.app-shell .app-header {
    background: color-mix(in srgb, var(--card-bg) 78%, transparent);
    backdrop-filter: blur(12px);
    -webkit-backdrop-filter: blur(12px);
    border-bottom: 1px solid color-mix(in srgb, var(--border-color) 35%, transparent);
    box-shadow: 0 0.25rem 1rem rgba(0, 0, 0, 0.06);
}

body.app-shell.dark-mode .app-header {
    box-shadow: 0 0.25rem 1rem rgba(0, 0, 0, 0.22);
}

body.app-shell .app-title {
    color: var(--app-brand-color);
}

/* --- Page panels --- */
body.app-shell .page:not(#page-login) {
    border-radius: var(--app-radius);
    box-shadow: var(--app-shadow);
    border: 1px solid color-mix(in srgb, var(--border-color) 28%, transparent);
}

/* --- Dashboard stat --- */
body.app-shell .dashboard-stat-card {
    background: color-mix(in srgb, var(--wine-text) 6%, var(--card-bg));
    padding: 1.5rem;
    border-radius: var(--app-radius);
    margin-bottom: 1.25rem;
    text-align: center;
    border: 1px solid color-mix(in srgb, var(--border-color) 35%, transparent);
}

body.app-shell .dashboard-stat-card__label {
    font-size: 1rem;
    opacity: 0.65;
    text-transform: uppercase;
    letter-spacing: 0.04em;
}

body.app-shell .dashboard-stat-card__value {
    font-size: 4rem;
    font-weight: 800;
    line-height: 1.05;
    color: var(--app-brand-color);
    font-variant-numeric: tabular-nums;
}

body.app-shell #page-dashboard > h3 {
    font-family: 'Eagle Lake', Georgia, 'Times New Roman', serif;
    font-weight: 400;
    color: var(--app-brand-color);
    font-size: 1.65rem;
    margin-bottom: 1.15rem;
}

/*
 * Unified pill buttons (marketing home2-btn style).
 * Excludes chrome controls: hamburger, dropdown triggers, wheel spin, zoom, search clear, aroma chips.
 */
body.app-shell button:not(.hamburger-btn):not(.mini-dropdown__trigger):not(.wheel-spin-btn):not(.camera-capture-modal__zoom-btn):not(.collector-search-clear):not(.grid-col-picker__pill):not(.section-aroma-btn),
body.app-shell label.file-picker-label,
body.app-shell label.camera-file-picker-label {
    border-radius: var(--app-btn-radius);
    padding: 0.95rem 1.25rem;
    font-size: 1.2rem;
    line-height: 1.25;
    font-weight: 600;
    transition: transform 0.15s, filter 0.15s, box-shadow 0.15s, background 0.15s, border-color 0.15s;
    box-shadow: var(--app-btn-shadow);
    box-sizing: border-box;
}

body.app-shell button:not(.hamburger-btn):not(.mini-dropdown__trigger):not(.wheel-spin-btn):not(.camera-capture-modal__zoom-btn):not(.collector-search-clear):not(.grid-col-picker__pill):not(.section-aroma-btn):hover,
body.app-shell label.file-picker-label:hover,
body.app-shell label.camera-file-picker-label:hover {
    transform: translateY(-1px);
    filter: brightness(1.04);
}

body.app-shell button:not(.hamburger-btn):not(.mini-dropdown__trigger):not(.wheel-spin-btn):not(.camera-capture-modal__zoom-btn):not(.collector-search-clear):not(.grid-col-picker__pill):not(.section-aroma-btn):active,
body.app-shell label.file-picker-label:active,
body.app-shell label.camera-file-picker-label:active {
    transform: translateY(0);
    filter: brightness(0.96);
}

body.app-shell button:not(.hamburger-btn):not(.mini-dropdown__trigger):not(.wheel-spin-btn):not(.camera-capture-modal__zoom-btn):not(.collector-search-clear):not(.grid-col-picker__pill):not(.section-aroma-btn):disabled,
body.app-shell button:not(.hamburger-btn):not(.mini-dropdown__trigger):not(.wheel-spin-btn):not(.camera-capture-modal__zoom-btn):not(.collector-search-clear):not(.grid-col-picker__pill):not(.section-aroma-btn)[disabled] {
    transform: none;
    filter: none;
    opacity: 0.55;
    cursor: not-allowed;
}

/* Semantic colors */
body.app-shell button.primary,
body.app-shell label.primary.file-picker-label,
body.app-shell label.primary.camera-file-picker-label {
    background: var(--wine-cta);
    color: #fff;
    border: none;
}

body.app-shell button.success,
body.app-shell label.success.file-picker-label {
    background: var(--success);
    color: #fff;
    border: none;
}

body.app-shell button.secondary {
    background: color-mix(in srgb, var(--secondary) 92%, #000);
    color: #fff;
    border: none;
}

body.app-shell button.danger,
body.app-shell button.dashboard-delete-btn {
    background: var(--danger);
    color: #fff;
    border: none;
}

body.app-shell button.somm {
    background: var(--wine-cta);
    color: #fff;
    border: none;
}

body.app-shell button.warning {
    background: #ffc107;
    color: #000;
    border: none;
}

/* Auth (login / forgot password) */
body.app-shell .auth-btn-primary {
    width: 100%;
    background: var(--wine-cta);
    color: #fff;
    border: none;
    margin-top: 0.5rem;
}

body.app-shell .auth-btn-primary:hover {
    opacity: 1;
    filter: brightness(1.04);
}

body.app-shell .auth-btn-primary:active {
    transform: translateY(0);
    filter: brightness(0.96);
}

body.app-shell .auth-btn-secondary {
    width: 100%;
    background: transparent;
    color: var(--wine-text);
    border: 1.5px solid color-mix(in srgb, var(--wine-text) 45%, var(--border-color));
    margin-top: 0.75rem;
}

body.app-shell .auth-btn-secondary:hover {
    background: color-mix(in srgb, var(--wine-text) 8%, transparent);
}

body.app-shell.dark-mode .auth-btn-secondary:hover {
    background: color-mix(in srgb, var(--app-brand-color) 10%, transparent);
}

/* Side menu */
body.app-shell .menu-item {
    text-align: center;
    background: color-mix(in srgb, var(--wine-text) 5%, var(--card-bg));
    border: 1px solid color-mix(in srgb, var(--border-color) 30%, transparent);
    color: var(--text-color);
    margin-bottom: 0.625rem;
}

body.app-shell .menu-item:hover {
    background: color-mix(in srgb, var(--wine-text) 12%, var(--card-bg));
    filter: none;
    transform: translateY(-1px);
}

body.app-shell #menuLogoutBtn {
    background: var(--danger);
    color: #fff;
    border: none;
    margin-top: auto;
}

body.app-shell #menuLogoutBtn:hover {
    filter: brightness(1.04);
}

/* Dashboard action accents */
body.app-shell #page-dashboard #goToQuickPeekBtn,
body.app-shell #quickPeekSnapBtn {
    background: #2a7a9e;
    color: #fff;
}

body.app-shell #page-dashboard #goToAddBtn {
    background: var(--success);
    color: #fff;
}

body.app-shell #scanLabelBtn.primary {
    background: var(--wine-cta);
    color: #fff;
}

/* Dropdown menu rows (language / theme lists) */
body.app-shell .mini-dropdown__menu li button,
body.app-shell .mini-dropdown__menu li a {
    border-radius: var(--app-btn-radius);
}

/* Add / Edit bottle: bottom grid (Virtual Somm, Save, Cancel, Delete) + heading Back/Save */
body.app-shell #page-add .action-stack--grid > button,
body.app-shell #bottleFormActions > button {
    border-radius: var(--app-btn-radius);
    padding: 0.95rem 1.25rem;
    font-size: 1.2rem;
    line-height: 1.25;
    box-shadow: var(--app-btn-shadow);
    min-width: 0;
}

body.app-shell #page-add .bottle-form-heading__btn {
    border-radius: var(--app-btn-radius);
    box-shadow: var(--app-btn-shadow);
}

body.app-shell #page-add #formSommBtn.somm {
    background: var(--wine-cta);
    color: #fff;
}

@media (orientation: landscape) and (max-height: 32rem) {
    body.app-shell #page-add .action-stack--grid > button,
    body.app-shell #bottleFormActions > button {
        padding: 0.85rem 1rem;
        font-size: 1.1rem;
    }
}
