/**
 * ZATANA Frontend Styles
 * Version: 1.0.0 - Giai đoạn 1
 */

/* === RESET & COMMON === */
.zatana-btn { display:inline-block; padding:10px 20px; border:none; border-radius:6px; cursor:pointer; font-size:14px; text-decoration:none; text-align:center; transition:all .2s; background:#eee; color:#333 }
.zatana-btn-primary { background:#2271b1; color:#fff }
.zatana-btn-primary:hover { background:#135e96; color:#fff }
.zatana-btn-full { width:100%; display:block }
.zatana-btn-sm { padding:6px 12px; font-size:13px }
.zatana-notice { padding:12px 16px; border-radius:6px; margin:12px 0; background:#f0f6fc; border-left:4px solid #2271b1 }
.zatana-notice-warning { background:#fcf9e8; border-left-color:#dba617 }
.zatana-notice-error { background:#fcf0f1; border-left-color:#d63638 }
.required { color:#e74c3c }

/* === FORM ELEMENTS === */
.zatana-form-group { margin-bottom:16px }
.zatana-form-group label { display:block; margin-bottom:5px; font-weight:600; font-size:14px }
.zatana-form-group input[type="text"],.zatana-form-group input[type="email"],.zatana-form-group input[type="tel"],
.zatana-form-group input[type="password"],.zatana-form-group input[type="number"],.zatana-form-group textarea,
.zatana-form-group select { width:100%; padding:10px 12px; border:1px solid #ddd; border-radius:6px; font-size:14px; transition:border .2s }
.zatana-form-group input:focus,.zatana-form-group textarea:focus { border-color:#2271b1; outline:none; box-shadow:0 0 0 2px rgba(34,113,177,.15) }
.zatana-form-row-2col { display:grid; grid-template-columns:1fr 1fr; gap:16px }
.zatana-form-row { display:flex; justify-content:space-between; align-items:center }
.zatana-checkbox { display:flex; align-items:center; gap:6px; cursor:pointer }
.zatana-checkbox input { margin:0 }

/* === AUTH (Login/Register) === */
.zatana-auth-wrapper { max-width:500px; margin:30px auto }
.zatana-auth-box { background:#fff; border:1px solid #e0e0e0; border-radius:12px; padding:30px }
.zatana-auth-box-wide { max-width:600px }
.zatana-auth-title { text-align:center; margin:0 0 24px; font-size:24px }
.zatana-auth-message { padding:10px 14px; border-radius:6px; margin-bottom:16px; font-size:14px }
.zatana-auth-message.success { background:#d5f5e3; color:#1e8449; border:1px solid #a9dfbf }
.zatana-auth-message.error { background:#fcf0f1; color:#c0392b; border:1px solid #f5b7b1 }
.zatana-auth-footer { text-align:center; margin-top:20px; color:#888 }
.zatana-auth-footer a { color:#2271b1 }
.zatana-forgot-link { color:#888; font-size:13px }
.zatana-account-type-selector { display:grid; grid-template-columns:1fr 1fr; gap:12px; margin-bottom:24px }
.zatana-type-option { display:flex; flex-direction:column; align-items:center; text-align:center; padding:16px; border:2px solid #e0e0e0; border-radius:10px; cursor:pointer; transition:all .2s }
.zatana-type-option.active { border-color:#2271b1; background:#f0f6fc }
.zatana-type-option input { display:none }
.zatana-type-icon { font-size:32px; margin-bottom:6px }
.zatana-type-option small { color:#888; font-size:12px; margin-top:4px }

/* === SERVICES GRID === */
.zatana-services-grid { display:grid; gap:24px }
.zatana-columns-2 { grid-template-columns:repeat(2,1fr) }
.zatana-columns-3 { grid-template-columns:repeat(3,1fr) }
.zatana-columns-4 { grid-template-columns:repeat(4,1fr) }
.zatana-service-card { border:1px solid #e0e0e0; border-radius:8px; overflow:hidden; transition:box-shadow .2s; background:#fff }
.zatana-service-card:hover { box-shadow:0 4px 12px rgba(0,0,0,.1) }
.zatana-service-image img { width:100%; height:200px; object-fit:cover; display:block }
.zatana-service-info { padding:16px }
.zatana-service-title { margin:0 0 8px; font-size:18px }
.zatana-service-price { color:#e74c3c; font-weight:bold; font-size:16px }

/* === BOOKING === */
.zatana-booking-header { display:flex; justify-content:space-between; align-items:center; flex-wrap:wrap; margin-bottom:20px }
.zatana-category-filter { display:flex; gap:8px; flex-wrap:wrap }
.zatana-filter-btn { padding:6px 14px; border:1px solid #ddd; border-radius:20px; background:#fff; cursor:pointer; font-size:13px; transition:all .2s }
.zatana-filter-btn.active,.zatana-filter-btn:hover { background:#2271b1; color:#fff; border-color:#2271b1 }
.zatana-booking-services { display:flex; flex-direction:column; gap:20px }
.zatana-booking-item { display:flex; gap:20px; background:#fff; border:1px solid #e8e8e8; border-radius:10px; padding:20px; transition:box-shadow .2s }
.zatana-booking-item:hover { box-shadow:0 2px 10px rgba(0,0,0,.06) }
.zatana-booking-item-image { flex:0 0 160px }
.zatana-booking-item-image img { width:160px; height:130px; object-fit:cover; border-radius:8px }
.zatana-no-image { width:160px; height:130px; background:#f5f5f5; display:flex; align-items:center; justify-content:center; border-radius:8px; color:#aaa; font-size:13px }
.zatana-booking-item-content { flex:1 }
.zatana-booking-item-content h3 { margin:0 0 6px; font-size:18px }
.zatana-item-desc { color:#666; font-size:14px; margin:0 0 4px }
.zatana-item-meta { color:#999; font-size:13px; margin:0 0 12px }
.zatana-variant-options { display:flex; flex-wrap:wrap; gap:8px; margin-top:6px }
.zatana-variant-option { display:flex; align-items:center; gap:6px; padding:6px 12px; border:1px solid #ddd; border-radius:6px; cursor:pointer; font-size:13px; transition:all .15s }
.zatana-variant-option.active { border-color:#2271b1; background:#f0f6fc }
.zatana-variant-option input { display:none }
.zatana-variant-price { color:#e74c3c; font-weight:bold }
.zatana-addon-options { display:flex; flex-wrap:wrap; gap:8px; margin-top:6px }
.zatana-addon-option { display:flex; align-items:center; gap:6px; font-size:13px; cursor:pointer }
.zatana-addon-price { color:#e67e22 }
.zatana-booking-item-actions { display:flex; align-items:center; gap:16px; margin-top:14px }
.zatana-quantity-control { display:flex; align-items:center; border:1px solid #ddd; border-radius:6px; overflow:hidden }
.zatana-qty-btn { width:32px; height:32px; border:none; background:#f5f5f5; cursor:pointer; font-size:16px; font-weight:bold }
.zatana-qty-btn:hover { background:#e0e0e0 }
.zatana-qty-input { width:42px; height:32px; border:none; text-align:center; font-size:14px; -moz-appearance:textfield }
.zatana-qty-input::-webkit-inner-spin-button { -webkit-appearance:none }
.zatana-quantity-control-sm .zatana-qty-btn { width:28px; height:28px; font-size:14px }
.zatana-quantity-control-sm .zatana-qty-input { width:36px; height:28px; font-size:13px }
.zatana-calculated-price { font-size:18px; font-weight:bold; color:#e74c3c }
.zatana-mini-cart { position:fixed; bottom:24px; right:24px; z-index:999 }
.zatana-mini-cart-link { display:inline-block; background:#2271b1; color:#fff; padding:12px 20px; border-radius:30px; text-decoration:none; font-size:15px; box-shadow:0 4px 12px rgba(0,0,0,.2) }
.zatana-mini-cart-link:hover { background:#135e96; color:#fff }

/* === CART === */
.zatana-cart-table { width:100%; border-collapse:collapse; background:#fff }
.zatana-cart-table th,.zatana-cart-table td { padding:12px; border-bottom:1px solid #eee; vertical-align:middle }
.zatana-cart-table th { background:#f8f8f8; font-size:13px; text-transform:uppercase; color:#666 }
.zatana-cart-remove { background:none; border:none; color:#e74c3c; font-size:20px; cursor:pointer; padding:4px 8px }
.zatana-cart-remove:hover { background:#fcf0f1; border-radius:4px }
.zatana-cart-summary { background:#fff; border:1px solid #e0e0e0; border-radius:8px; padding:20px; margin-top:20px; max-width:400px; margin-left:auto }
.zatana-cart-summary-row { display:flex; justify-content:space-between; padding:8px 0; font-size:15px }
.zatana-cart-total-row { border-top:2px solid #e0e0e0; margin-top:8px; padding-top:12px }
.zatana-cart-actions { display:flex; justify-content:space-between; margin-top:20px; gap:12px }
.zatana-empty-cart,.zatana-empty-state { text-align:center; padding:40px 20px }

/* === CHECKOUT === */
.zatana-checkout-layout { display:grid; grid-template-columns:1.5fr 1fr; gap:30px }
.zatana-checkout-form-col h3,.zatana-checkout-summary-col h3 { margin:0 0 16px; font-size:18px }
.zatana-payment-methods { display:flex; flex-direction:column; gap:10px }
.zatana-payment-option { display:flex; flex-direction:column; padding:14px; border:2px solid #e0e0e0; border-radius:8px; cursor:pointer; transition:all .2s }
.zatana-payment-option.active { border-color:#2271b1; background:#f0f6fc }
.zatana-payment-option input { display:none }
.zatana-payment-option small { color:#888; font-size:12px; margin-top:2px }
.zatana-order-summary { background:#f8f9fa; border:1px solid #e0e0e0; border-radius:10px; padding:20px; position:sticky; top:20px }
.zatana-summary-item { display:flex; justify-content:space-between; padding:10px 0; border-bottom:1px solid #eee; font-size:14px }
.zatana-summary-item small { color:#888 }
.zatana-summary-row { display:flex; justify-content:space-between; padding:8px 0; font-size:15px }
.zatana-summary-total { border-top:2px solid #ccc; margin-top:8px; padding-top:12px; font-weight:bold }

/* === MY ACCOUNT === */
.zatana-account-header { display:flex; justify-content:space-between; align-items:center; margin-bottom:20px }
.zatana-account-tabs { display:flex; gap:0; border-bottom:2px solid #e0e0e0; margin-bottom:24px }
.zatana-tab { padding:10px 20px; text-decoration:none; color:#666; font-weight:600; border-bottom:2px solid transparent; margin-bottom:-2px; transition:all .2s }
.zatana-tab.active,.zatana-tab:hover { color:#2271b1; border-bottom-color:#2271b1 }
.zatana-order-card { background:#fff; border:1px solid #e8e8e8; border-radius:8px; padding:16px; margin-bottom:12px }
.zatana-order-card-header { display:flex; justify-content:space-between; align-items:center; margin-bottom:8px }
.zatana-order-card-footer { display:flex; justify-content:flex-end; margin-top:8px }
.zatana-pagination { display:flex; gap:4px; justify-content:center; margin-top:20px }
.zatana-pagination a { display:inline-block; padding:6px 12px; border:1px solid #ddd; border-radius:4px; text-decoration:none; color:#333 }
.zatana-pagination a.active { background:#2271b1; color:#fff; border-color:#2271b1 }

/* === RESPONSIVE === */
@media (max-width:768px) {
.zatana-services-grid,.zatana-form-row-2col,.zatana-account-type-selector { grid-template-columns:1fr !important }
.zatana-booking-item { flex-direction:column }
.zatana-booking-item-image { flex:none }
.zatana-booking-item-image img,.zatana-no-image { width:100%; height:180px }
.zatana-booking-item-actions { flex-wrap:wrap }
.zatana-checkout-layout { grid-template-columns:1fr }
.zatana-cart-actions { flex-direction:column }
.zatana-cart-summary { max-width:none }
.zatana-stats-grid { grid-template-columns:1fr 1fr !important }
}

/* === PARTNER DASHBOARD === */
.zatana-partner-header { display:flex; justify-content:space-between; align-items:center; margin-bottom:20px }
.zatana-partner-header h2 { margin:0 }
.zatana-stats-grid { display:grid; grid-template-columns:repeat(4,1fr); gap:16px }
.zatana-stat-card { padding:20px; border-radius:10px; text-align:center }
.zatana-stat-number { font-size:28px; font-weight:bold; margin-bottom:4px }
.zatana-stat-label { font-size:13px; color:#666 }
.zatana-stat-blue { background:#f0f6fc; }
.zatana-stat-blue .zatana-stat-number { color:#2271b1 }
.zatana-stat-orange { background:#fef9e7 }
.zatana-stat-orange .zatana-stat-number { color:#f39c12 }
.zatana-stat-green { background:#d5f5e3 }
.zatana-stat-green .zatana-stat-number { color:#27ae60 }
.zatana-stat-red { background:#fcf0f1 }
.zatana-stat-red .zatana-stat-number { color:#e74c3c; font-size:20px }
