:root {
    --color-primary: #14471d;
    --color-primary-dark: #0d3015;
    --color-secondary: #2EC4B6;
    --color-bg: #FAFAFA;
    --color-surface: #FFFFFF;
    --color-text: #333333;
    --color-text-light: #777777;
    --color-border: #E0E0E0;
    --color-success: #4CAF50;
    --color-warning: #FF9800;
    --color-danger: #F44336;
    --radius: 8px;
    --shadow: 0 2px 8px rgba(0,0,0,0.08);
    --transition: 0.3s ease;
}

*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }

body {
    font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif;
    background: var(--color-bg);
    color: var(--color-text);
    line-height: 1.6;
}

a { color: var(--color-primary); text-decoration: none; }
a:hover { color: var(--color-primary-dark); }
a.btn:hover { color: #fff; }
a.btn-outline:hover { color: #fff; }
a.btn-link:hover { color: var(--color-primary-dark); }
a.btn-link-danger:hover { color: #c62828; }

.btn {
    display: inline-flex; align-items: center; gap: 6px;
    padding: 9px 20px; border: 2px solid transparent; border-radius: var(--radius);
    font-size: 13px; font-weight: 500; cursor: pointer;
    transition: background var(--transition), transform var(--transition), border-color var(--transition);
    text-decoration: none; line-height: 1.4;
}
.btn:hover { transform: translateY(-1px); }
.btn-primary { background: var(--color-primary); color: #fff; border-color: var(--color-primary); }
.btn-primary:hover { background: var(--color-primary-dark); border-color: var(--color-primary-dark); color: #fff; }
.btn-danger { background: var(--color-danger); color: #fff; border-color: var(--color-danger); }
.btn-danger:hover { background: #b71c1c; border-color: #b71c1c; }
.btn-outline { background: transparent; border-color: var(--color-primary); color: var(--color-primary); }
.btn-outline:hover { background: var(--color-primary); color: #fff; }
.btn-outline-danger { background: transparent; border-color: var(--color-danger); color: var(--color-danger); }
.btn-outline-danger:hover { background: var(--color-danger); color: #fff; }
.btn-sm { padding: 6px 14px; font-size: 12px; }
.btn-block { width: 100%; justify-content: center; }
.btn-link { background: none; border: none; padding: 4px; color: var(--color-primary); cursor: pointer; font-size: inherit; }
.btn-link-danger { background: none; border: none; padding: 4px; color: var(--color-danger); cursor: pointer; font-size: inherit; }
.btn-group { display: flex; align-items: center; gap: 8px; }

.form-group { margin-bottom: 16px; }
.form-group label { display: block; margin-bottom: 4px; font-weight: 600; font-size: 14px; }
.form-control {
    width: 100%; padding: 10px 12px; border: 1px solid var(--color-border);
    border-radius: var(--radius); font-size: 14px; transition: border-color var(--transition);
}
.form-control:focus { outline: none; border-color: var(--color-primary); box-shadow: 0 0 0 3px rgba(20,71,29,0.12); }
.form-error { color: var(--color-danger); font-size: 13px; margin-top: 4px; }

/* Custom dropdown (replaces native select) */
.cd-dropdown { position:relative; width:100%; }
.cd-dropdown-btn {
    width:100%; padding:10px 12px; border:1px solid var(--color-border); border-radius:var(--radius);
    background:#fff; font-size:14px; text-align:left; cursor:pointer;
    color:var(--color-text); transition:border-color var(--transition);
    display:flex; align-items:center; justify-content:space-between;
}
.cd-dropdown-btn::after {
    content:''; width:7px; height:7px; border-right:2px solid #aaa; border-bottom:2px solid #aaa;
    transform:rotate(45deg); flex-shrink:0; margin-top:-3px; transition:transform 0.2s;
}
.cd-dropdown-btn:hover { border-color:var(--color-primary); }
.cd-dropdown.open .cd-dropdown-btn { border-color:var(--color-primary); box-shadow:0 0 0 3px rgba(20,71,29,0.12); }
.cd-dropdown.open .cd-dropdown-btn::after { transform:rotate(-135deg); margin-top:3px; }
.cd-dropdown-content {
    display:none; position:absolute; top:100%; left:0; right:0; margin-top:4px;
    background:#fff; border:1px solid #e0e0e0; border-radius:10px;
    box-shadow:0 8px 24px rgba(0,0,0,0.12); z-index:100; overflow:hidden;
}
.cd-dropdown.open .cd-dropdown-content { display:block; }
.cd-dropdown-content a {
    display:block; padding:10px 14px; color:var(--color-text); text-decoration:none;
    font-size:14px; transition:background 0.1s; border-bottom:1px solid #f5f5f5;
}
.cd-dropdown-content a:last-child { border-bottom:none; }
.cd-dropdown-content a:hover { background:#f0faf2; }
.cd-dropdown-content a.active { background:#f0faf2; color:var(--color-primary); font-weight:600; }

/* Shared components */
.card { background: #fff; border-radius: 12px; border: 1px solid #e8e8e8; padding: 24px; margin-bottom: 16px; }
.badge { display: inline-block; padding: 4px 10px; border-radius: 20px; font-size: 12px; font-weight: 600; }
.badge-active { background: #e8f5e9; color: #2e7d32; }
.badge-paused { background: #fff3e0; color: #e65100; }
.badge-cancelled { background: #ffebee; color: #c62828; }
.badge-pending, .badge-pending_payment { background: #e3f2fd; color: #1565c0; }
.badge-preparing { background: #e8f5e9; color: #2e7d32; }
.badge-production { background: #fff3e0; color: #e65100; }
.badge-ready { background: #e0f7fa; color: #00695c; }
.badge-shipped { background: #ede7f6; color: #4527a0; }
.badge-delivered { background: #e8f5e9; color: #2e7d32; }
.table-wrap { overflow-x: auto; }
table { width: 100%; border-collapse: collapse; }
th, td { padding: 10px 12px; text-align: left; font-size: 14px; }
th { font-weight: 600; color: #999; font-size: 12px; text-transform: uppercase; letter-spacing: 0.5px; border-bottom: 1px solid #e8e8e8; }
td { border-bottom: 1px solid #f0f0f0; }
.alert { padding: 12px; border-radius: 8px; margin-bottom: 16px; font-size: 14px; }
.alert-error { background: #FFEBEE; color: #C62828; }
.alert-success { background: #E8F5E9; color: #2E7D32; }

/* Prevent iOS zoom-on-focus by ensuring inputs are at least 16px on mobile */
@media (max-width: 768px) {
    .form-control {
        font-size: 16px;
    }
}

/* Layout-specific sidebar and client styles are in admin.css and client.css */

/* ============ Custom confirm modal ============ */
.bb-confirm-overlay {
    position: fixed; inset: 0;
    background: rgba(0,0,0,0.5);
    display: flex; align-items: center; justify-content: center;
    z-index: 9999;
    padding: 16px;
    animation: bb-confirm-fade-in 0.15s ease;
}
.bb-confirm-modal {
    background: #fff;
    border-radius: 12px;
    max-width: 440px;
    width: 100%;
    padding: 24px;
    box-shadow: 0 12px 32px rgba(0,0,0,0.2);
    animation: bb-confirm-slide-in 0.2s ease;
}
.bb-confirm-title {
    margin: 0 0 8px;
    font-size: 18px;
    font-weight: 700;
    color: var(--color-text);
}
.bb-confirm-message {
    margin: 0 0 20px;
    font-size: 14px;
    color: #555;
    line-height: 1.5;
}
.bb-confirm-actions {
    display: flex;
    gap: 8px;
    justify-content: flex-end;
}
.bb-confirm-actions .btn { padding: 10px 20px; }
@keyframes bb-confirm-fade-in { from { opacity: 0 } to { opacity: 1 } }
@keyframes bb-confirm-slide-in {
    from { transform: translateY(20px); opacity: 0 }
    to { transform: translateY(0); opacity: 1 }
}
@media (max-width: 480px) {
    .bb-confirm-actions { flex-direction: column-reverse; }
    .bb-confirm-actions .btn { width: 100%; }
}
