/* OrderOK - Global Styles */
:root {
    --color-primary: #2e5c1e;
    --color-primary-dark: #1e3f14;
    --color-primary-light: #4a8a35;
    --color-success: #4CAF50;
    --color-danger: #E53935;
    --color-info: #2E7BE8;
    --color-warning: #FF9800;
    --color-dark: #2C2C2C;
    --color-gray: #6C757D;
    --color-light-gray: #F5F5F5;
    --color-beige: #f2ede4;
    --color-border: #e4ddd3;
}

/* Base */
body {
    font-family: 'Segoe UI', -apple-system, BlinkMacSystemFont, sans-serif;
    color: #333;
}

/* Primary Color Utilities */
.bg-primary-custom { background-color: var(--color-primary) !important; }
.text-primary-custom { color: var(--color-primary) !important; }
.border-primary-custom { border-color: var(--color-primary) !important; }

/* Buttons */
.btn {
    --ok-btn-radius: 12px;
    border-radius: var(--ok-btn-radius);
    font-weight: 700;
    letter-spacing: 0.01em;
    transition: transform 0.16s ease, box-shadow 0.16s ease, background-color 0.16s ease, color 0.16s ease, border-color 0.16s ease;
}

.btn:hover {
    transform: translateY(-1px);
}

.btn:disabled,
.btn.disabled {
    transform: none;
    box-shadow: none;
}

.btn-primary,
.btn-primary-custom {
    background: linear-gradient(135deg, #4338ca 0%, #3730a3 100%);
    border-color: #3730a3;
    color: #ffffff;
    box-shadow: 0 10px 24px rgba(55,48,163,0.26);
}

.btn-primary:hover,
.btn-primary-custom:hover {
    background: linear-gradient(135deg, #4f46e5 0%, #4338ca 100%);
    border-color: #4338ca;
    color: #ffffff;
    box-shadow: 0 14px 28px rgba(55,48,163,0.3);
}

.btn-primary:focus,
.btn-primary-custom:focus,
.btn-outline-primary:focus,
.btn-outline-primary-custom:focus,
.btn-outline-secondary:focus,
.btn-secondary:focus,
.btn-warning:focus,
.btn-success:focus,
.btn-danger:focus {
    box-shadow: 0 0 0 0.2rem rgba(99,102,241,0.25);
}

.btn-primary:disabled,
.btn-primary-custom:disabled,
.btn-primary-custom.disabled {
    background: linear-gradient(135deg, #4338ca 0%, #3730a3 100%);
    border-color: #3730a3;
    color: #ffffff;
    opacity: 0.65;
    pointer-events: none;
    box-shadow: none;
}

.btn-outline-primary,
.btn-outline-primary-custom {
    border-color: #6366f1;
    color: #4338ca;
    background: #ffffff;
}

.btn-outline-primary:hover,
.btn-outline-primary-custom:hover {
    background: #eef2ff;
    border-color: #4f46e5;
    color: #3730a3;
}

.btn-outline-secondary,
.btn-outline-dark,
.btn-secondary {
    border-color: #cbd5e1;
    color: #334155;
    background: #ffffff;
}

.btn-outline-secondary:hover,
.btn-outline-dark:hover,
.btn-secondary:hover {
    background: #f8fafc;
    border-color: #94a3b8;
    color: #0f172a;
}

.btn-success {
    background: linear-gradient(135deg, #16a34a 0%, #15803d 100%);
    border-color: #15803d;
    color: #ffffff;
    box-shadow: 0 10px 24px rgba(21,128,61,0.22);
}

.btn-success:hover {
    background: linear-gradient(135deg, #22c55e 0%, #16a34a 100%);
    border-color: #16a34a;
    color: #ffffff;
}

.btn-warning {
    background: linear-gradient(135deg, #f59e0b 0%, #d97706 100%);
    border-color: #d97706;
    color: #111827;
    box-shadow: 0 10px 24px rgba(217,119,6,0.22);
}

.btn-warning:hover {
    background: linear-gradient(135deg, #fbbf24 0%, #f59e0b 100%);
    border-color: #f59e0b;
    color: #111827;
}

.btn-info {
    background: linear-gradient(135deg, #0f4c81 0%, #0b3b68 100%);
    border-color: #0b3b68;
    color: #ffffff;
    box-shadow: 0 10px 24px rgba(15,76,129,0.22);
}

.btn-info:hover {
    background: linear-gradient(135deg, #155e99 0%, #0f4c81 100%);
    border-color: #0f4c81;
    color: #ffffff;
}

.btn-danger {
    background: linear-gradient(135deg, #b42318 0%, #991b1b 100%);
    border-color: #991b1b;
    color: #ffffff;
    box-shadow: 0 10px 24px rgba(153,27,27,0.22);
}

.btn-danger:hover {
    background: linear-gradient(135deg, #dc2626 0%, #b42318 100%);
    border-color: #b42318;
    color: #ffffff;
}

.btn-outline-danger {
    border-color: #b42318;
    color: #991b1b;
    background: #ffffff;
}

.btn-outline-danger:hover {
    background: #fef2f2;
    border-color: #991b1b;
    color: #7f1d1d;
}

.btn-outline-warning {
    border-color: #f59e0b;
    color: #92400e;
    background: #fff;
}

.btn-outline-warning:hover {
    background: #fffbeb;
    border-color: #d97706;
    color: #78350f;
}

.btn-light {
    background: #ffffff;
    border-color: #cbd5e1;
    color: #0f172a;
}

.btn-light:hover {
    background: #f8fafc;
    border-color: #94a3b8;
    color: #0f172a;
}

.btn-back-nav {
    border: 1px solid #d7dde5 !important;
    border-radius: 12px !important;
    background: linear-gradient(180deg, #f8fafc 0%, #eef2f6 100%) !important;
    color: #475569 !important;
    box-shadow: 0 8px 18px rgba(148, 163, 184, 0.12);
}

.btn-back-nav:hover,
.btn-back-nav:focus {
    background: linear-gradient(180deg, #ffffff 0%, #f1f5f9 100%) !important;
    border-color: #c4ced9 !important;
    color: #1f2937 !important;
    box-shadow: 0 12px 22px rgba(148, 163, 184, 0.18);
}

.btn-back-nav .bi,
.btn-back-nav .fas,
.btn-back-nav .fa {
    color: inherit;
}

.btn-back-nav.btn-sm {
    padding: 0.42rem 0.8rem;
    font-size: 0.84rem;
}

.btn-back-nav:not(.btn-sm) {
    padding-inline: 0.95rem;
}

.btn-back-nav--icon-only {
    width: 2.35rem;
    height: 2.35rem;
    padding: 0 !important;
    display: inline-flex !important;
    align-items: center;
    justify-content: center;
}

.btn-back-nav--icon-only.btn-sm {
    width: 2rem;
    height: 2rem;
}

.bg-warning-subtle.text-warning-emphasis,
.badge.bg-warning-subtle,
.badge.bg-warning-subtle.text-warning,
.badge.bg-warning-subtle.text-warning-emphasis {
    background: #fef3c7 !important;
    color: #7c2d12 !important;
    border-color: #f59e0b !important;
}

.btn-close--xs {
    font-size: 0.5rem;
}

/* Quill rendered content display helpers */
.quill-render {
    overflow-wrap: anywhere;
}

.quill-render img {
    max-width: 100%;
    height: auto;
    border-radius: 8px;
}

.quill-render .ql-size-small {
    font-size: 0.75em;
}

.quill-render .ql-size-large {
    font-size: 1.5em;
}

.quill-render .ql-size-huge {
    font-size: 2.5em;
}

.quill-render .ql-align-center {
    text-align: center;
}

.quill-render .ql-align-right {
    text-align: right;
}

.quill-render .ql-align-justify {
    text-align: justify;
}

.quill-render .ql-indent-1:not(.ql-direction-rtl) { padding-left: 3em; }
.quill-render .ql-indent-2:not(.ql-direction-rtl) { padding-left: 6em; }
.quill-render .ql-indent-3:not(.ql-direction-rtl) { padding-left: 9em; }
.quill-render .ql-indent-4:not(.ql-direction-rtl) { padding-left: 12em; }
.quill-render .ql-indent-5:not(.ql-direction-rtl) { padding-left: 15em; }
.quill-render .ql-indent-6:not(.ql-direction-rtl) { padding-left: 18em; }
.quill-render .ql-indent-7:not(.ql-direction-rtl) { padding-left: 21em; }
.quill-render .ql-indent-8:not(.ql-direction-rtl) { padding-left: 24em; }

.quill-render .ql-indent-1.ql-direction-rtl.ql-align-right { padding-right: 3em; }
.quill-render .ql-indent-2.ql-direction-rtl.ql-align-right { padding-right: 6em; }
.quill-render .ql-indent-3.ql-direction-rtl.ql-align-right { padding-right: 9em; }
.quill-render .ql-indent-4.ql-direction-rtl.ql-align-right { padding-right: 12em; }
.quill-render .ql-indent-5.ql-direction-rtl.ql-align-right { padding-right: 15em; }
.quill-render .ql-indent-6.ql-direction-rtl.ql-align-right { padding-right: 18em; }
.quill-render .ql-indent-7.ql-direction-rtl.ql-align-right { padding-right: 21em; }
.quill-render .ql-indent-8.ql-direction-rtl.ql-align-right { padding-right: 24em; }

.quill-render blockquote {
    border-left: 4px solid #ced4da;
    margin: 0 0 1rem;
    padding-left: 0.75rem;
    color: #495057;
}

.btn-group-max-400 {
    max-width: 400px;
}

.ok-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 0.5rem;
    min-height: 2.5rem;
    padding-inline: 1rem;
    margin: 0.3125rem;
    vertical-align: middle;
    text-decoration: none;
}

.ok-btn.w-100,
.ok-btn.d-flex {
    display: flex;
}

.ok-btn.btn-sm {
    min-height: 2rem;
    gap: 0.4rem;
    margin: 0.25rem;
}

.ok-btn.btn-lg {
    min-height: 3rem;
    gap: 0.6rem;
}

.ok-btn .ok-btn__icon {
    flex-shrink: 0;
    font-size: 0.95em;
    line-height: 1;
}

.ok-btn .ok-btn__label {
    line-height: 1.1;
}

.ok-btn-role-primary,
.ok-btn-role-create,
.ok-btn-role-save {
    background: linear-gradient(135deg, #4338ca 0%, #3730a3 100%) !important;
    border-color: #3730a3 !important;
    color: #ffffff !important;
    box-shadow: 0 10px 24px rgba(55,48,163,0.24);
}

.ok-btn-role-primary:hover,
.ok-btn-role-create:hover,
.ok-btn-role-save:hover {
    background: linear-gradient(135deg, #4f46e5 0%, #4338ca 100%) !important;
    border-color: #4338ca !important;
    color: #ffffff !important;
}

.ok-btn-role-success,
.ok-btn-role-confirm,
.ok-btn-role-import {
    background: linear-gradient(135deg, #166534 0%, #14532d 100%) !important;
    border-color: #14532d !important;
    color: #ffffff !important;
    box-shadow: 0 10px 24px rgba(20,83,45,0.24);
}

.ok-btn-role-success:hover,
.ok-btn-role-confirm:hover,
.ok-btn-role-import:hover {
    background: linear-gradient(135deg, #15803d 0%, #166534 100%) !important;
    border-color: #166534 !important;
    color: #ffffff !important;
}

.ok-btn-role-warning,
.ok-btn-role-disable {
    background: linear-gradient(135deg, #64748b 0%, #475569 100%) !important;
    border-color: #475569 !important;
    color: #ffffff !important;
    box-shadow: 0 10px 24px rgba(71,85,105,0.22);
}

.ok-btn-role-warning:hover,
.ok-btn-role-disable:hover {
    background: linear-gradient(135deg, #94a3b8 0%, #64748b 100%) !important;
    border-color: #64748b !important;
    color: #ffffff !important;
}

.ok-btn-role-edit {
    background: linear-gradient(135deg, #2563eb 0%, #1d4ed8 100%) !important;
    border-color: #1d4ed8 !important;
    color: #ffffff !important;
    box-shadow: 0 10px 24px rgba(29,78,216,0.22);
}

.ok-btn-role-edit:hover {
    background: linear-gradient(135deg, #3b82f6 0%, #2563eb 100%) !important;
    border-color: #2563eb !important;
    color: #ffffff !important;
}

.ok-btn-role-info,
.ok-btn-role-search,
.ok-btn-role-view,
.ok-btn-role-export {
    background: linear-gradient(135deg, #0f4c81 0%, #0b3b68 100%) !important;
    border-color: #0b3b68 !important;
    color: #ffffff !important;
    box-shadow: 0 10px 24px rgba(15,76,129,0.22);
}

.ok-btn-role-info:hover,
.ok-btn-role-search:hover,
.ok-btn-role-view:hover,
.ok-btn-role-export:hover {
    background: linear-gradient(135deg, #155e99 0%, #0f4c81 100%) !important;
    border-color: #0f4c81 !important;
    color: #ffffff !important;
}

.ok-btn-role-danger,
.ok-btn-role-delete {
    background: linear-gradient(135deg, #b42318 0%, #991b1b 100%) !important;
    border-color: #991b1b !important;
    color: #ffffff !important;
    box-shadow: 0 10px 24px rgba(153,27,27,0.24);
}

.ok-btn-role-danger:hover,
.ok-btn-role-delete:hover {
    background: linear-gradient(135deg, #dc2626 0%, #b42318 100%) !important;
    border-color: #b42318 !important;
    color: #ffffff !important;
}

.ok-btn-role-neutral,
.ok-btn-role-back,
.ok-btn-role-cancel {
    background: linear-gradient(180deg, #f8fafc 0%, #eef2f6 100%) !important;
    border-color: #cbd5e1 !important;
    color: #334155 !important;
    box-shadow: 0 8px 18px rgba(148,163,184,0.14);
}

.ok-btn-role-neutral:hover,
.ok-btn-role-back:hover,
.ok-btn-role-cancel:hover {
    background: linear-gradient(180deg, #ffffff 0%, #f1f5f9 100%) !important;
    border-color: #94a3b8 !important;
    color: #0f172a !important;
}

.btn-group > .ok-btn,
.input-group > .ok-btn,
.pagination .ok-btn,
.swal2-actions .ok-btn,
.toast .ok-btn,
.dropdown-menu .ok-btn,
.navbar .ok-btn,
.nav .ok-btn {
    margin: 0;
}

.table .ok-btn {
    margin: 0.18rem;
}

.ok-form-actions {
    display: flex;
    width: 100%;
    justify-content: flex-end;
    align-items: center;
    flex-wrap: wrap;
    gap: 0.625rem;
    margin-top: 1rem;
    padding-top: 0.25rem;
}

.ok-form-actions > .ok-btn,
.ok-form-actions > .btn,
.ok-form-actions form > .ok-btn,
.ok-form-actions form > .btn {
    margin: 0;
}

@media (max-width: 767.98px) {
    .ok-form-actions {
        justify-content: stretch;
    }

    .ok-form-actions > .ok-btn,
    .ok-form-actions > .btn,
    .ok-form-actions form > .ok-btn,
    .ok-form-actions form > .btn {
        flex: 1 1 calc(50% - 0.625rem);
    }
}

/* Cards */
.card {
    border: 1px solid var(--color-border);
    border-radius: 12px;
    box-shadow: 0 2px 8px rgba(0,0,0,0.06);
}

/* Form Controls */
.form-control:focus, .form-select:focus {
    border-color: var(--color-primary);
    box-shadow: 0 0 0 0.2rem rgba(217,120,88,0.25);
}

/* Badge */
.badge-vip { background: linear-gradient(135deg, #f6d365 0%, #fda085 100%); color: white; }
.badge-normal { background: #E8F5E9; color: #2E7D32; }
.badge-blocked { background: #FFEBEE; color: #C62828; }

/* Status badges */
.status-pending { background: #FFF3CD; color: #856404; }
.status-confirmed { background: #D1ECF1; color: #0C5460; }
.status-completed { background: #D4EDDA; color: #155724; }
.status-cancelled { background: #F8D7DA; color: #721C24; }
.status-noshow { background: #E2E3E5; color: #383D41; }

/* Scrollbar */
::-webkit-scrollbar { width: 6px; height: 6px; }
::-webkit-scrollbar-track { background: #f1f1f1; }
::-webkit-scrollbar-thumb { background: #ccc; border-radius: 3px; }
::-webkit-scrollbar-thumb:hover { background: var(--color-primary); }

/* Transitions */
.transition-all { transition: all 0.2s ease; }

/* Loading spinner */
.spinner-overlay {
    position: fixed;
    inset: 0;
    background: rgba(255,255,255,0.8);
    display: flex;
    align-items: center;
    justify-content: center;
    z-index: 9999;
}

/* Alpine.js */
[x-cloak] { display: none !important; }
