/* ======================================================
   MODULE: LỊCH HẸN (ENHANCED v2)
   ====================================================== */
.appt-overlay{position:fixed;inset:0;background:var(--bg);z-index:300;display:none;flex-direction:column;}
.appt-overlay.open{display:flex;}
.appt-layout{display:flex;flex:1;overflow:hidden;}

/* KHO (Warehouse) Management Overlay */
.kho-overlay{position:fixed;inset:0;background:var(--bg);z-index:300;display:none;flex-direction:column;}
.kho-overlay.open{display:flex;}
.kho-iframe-container{flex:1;overflow:hidden;background:#fff;margin:16px;border-radius:12px;box-shadow:0 4px 20px rgba(0,0,0,.15);position:relative;}
.kho-iframe{width:100%;height:100%;border:none;}
.kho-header{padding:12px 16px;background:#fff;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;}
.kho-header h3{font-size:15px;font-weight:700;color:var(--text);display:flex;align-items:center;gap:8px;}
.kho-close{background:var(--accent);color:#fff;border:none;padding:6px 14px;border-radius:6px;font-family:var(--font);font-size:12px;font-weight:600;cursor:pointer;}

/* Calendar sidebar — 1.8/4 of screen */
.appt-sidebar{width:clamp(380px,28vw,480px);min-width:360px;background:var(--white);border-right:1px solid var(--border);display:flex;flex-direction:column;overflow-y:auto;flex-shrink:0;}
.appt-cal-hdr{padding:10px 14px;border-bottom:1px solid var(--border);display:flex;align-items:center;gap:8px;}
.appt-cal-nav{background:none;border:1px solid var(--border);border-radius:5px;padding:4px 10px;cursor:pointer;font-size:13px;font-family:var(--font);}
.appt-cal-nav:hover{border-color:var(--accent);color:var(--accent);}
.cal-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:2px;padding:8px 10px;}
.cal-day-lbl{font-size:10px;color:var(--muted);text-align:center;padding:3px 0;}
.cal-cell{aspect-ratio:1;border-radius:6px;display:flex;flex-direction:column;align-items:center;justify-content:center;cursor:pointer;font-size:11px;font-weight:600;border:1px solid transparent;transition:all .1s;position:relative;}
.cal-cell:hover{background:var(--accent-light);border-color:var(--accent);color:var(--accent);}
.cal-cell.today{background:var(--accent);color:#fff;font-weight:800;}
.cal-cell.selected{background:var(--accent-light);border-color:var(--accent);color:var(--accent);font-weight:800;}
.cal-cell.has-appt::after{content:'';position:absolute;bottom:2px;width:4px;height:4px;background:var(--green);border-radius:50%;}
.cal-cell.today.has-appt::after,.cal-cell.selected.has-appt::after{background:#fff;}
.cal-cell.other-month{opacity:.3;}

/* Quick date range buttons */
.appt-quick-dates{padding:8px 10px;border-bottom:1px solid var(--border);display:flex;gap:4px;flex-wrap:wrap;}
.appt-qd-btn{padding:4px 10px;border-radius:20px;border:1px solid var(--border);background:var(--white);font-family:var(--font);font-size:11px;cursor:pointer;color:var(--muted);font-weight:600;transition:all .15s;}
.appt-qd-btn:hover{border-color:var(--accent);color:var(--accent);}
.appt-qd-btn.active{background:var(--accent);color:#fff;border-color:var(--accent);}

/* Custom date range */
.appt-range-row{padding:8px 10px;border-bottom:1px solid var(--border);display:flex;gap:5px;align-items:center;}
.appt-range-inp{flex:1;padding:5px 8px;border:1px solid var(--border);border-radius:5px;font-family:var(--font);font-size:11px;outline:none;}
.appt-range-inp:focus{border-color:var(--accent);}

/* New appointment form */
.appt-form{padding:14px;border-top:1px solid var(--border);}
.appt-form-title{font-size:12px;font-weight:800;color:var(--muted);text-transform:uppercase;letter-spacing:.5px;margin-bottom:10px;}
.appt-fi{width:100%;padding:7px 10px;border:1px solid var(--border);border-radius:6px;font-family:var(--font);font-size:12px;outline:none;background:var(--white);color:var(--text);}
.appt-fi:focus{border-color:var(--accent);}
.appt-field{margin-bottom:8px;}
.appt-field label{display:block;font-size:10px;font-weight:700;color:var(--muted);text-transform:uppercase;letter-spacing:.3px;margin-bottom:3px;}
.appt-send-row{display:flex;gap:5px;margin-top:10px;}
.appt-send-btn{flex:1;padding:7px;border:none;border-radius:6px;font-family:var(--font);font-size:11px;font-weight:700;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:4px;}
.appt-send-fb{background:#e8f0ff;color:#1877f2;}
.appt-send-fb:hover{background:#1877f2;color:#fff;}
.appt-send-tg{background:#e3f4fd;color:#229ED9;}
.appt-send-tg:hover{background:#229ED9;color:#fff;}

/* Appointment main area */
.appt-main{flex:1;display:flex;flex-direction:column;overflow:hidden;}

/* Stats bar */
.appt-stats-bar{padding:10px 16px;border-bottom:1px solid var(--border);background:#fafaf8;display:flex;gap:8px;flex-wrap:wrap;align-items:center;flex-shrink:0;}
.appt-stat-pill{display:flex;align-items:center;gap:6px;background:var(--white);border:1px solid var(--border);border-radius:8px;padding:6px 12px;}
.appt-stat-num{font-size:18px;font-weight:800;}
.appt-stat-lbl{font-size:10px;color:var(--muted);font-weight:600;}

/* Filter bar */
.appt-filter-bar{padding:8px 16px;border-bottom:1px solid var(--border);display:flex;gap:6px;flex-wrap:wrap;align-items:center;background:var(--white);flex-shrink:0;}
.appt-filter-sel{padding:5px 10px;border:1px solid var(--border);border-radius:6px;font-family:var(--font);font-size:12px;outline:none;background:var(--white);color:var(--text);cursor:pointer;}
.appt-filter-sel:focus{border-color:var(--accent);}
.appt-search-inp{padding:6px 10px;border:1px solid var(--border);border-radius:6px;font-family:var(--font);font-size:12px;outline:none;width:160px;}
.appt-search-inp:focus{border-color:var(--accent);}

/* Status tabs row */
.appt-list-hdr{padding:8px 16px;background:var(--white);border-bottom:1px solid var(--border);display:flex;align-items:center;gap:8px;flex-shrink:0;flex-wrap:wrap;}
.appt-list-scroll{flex:1;overflow-y:auto;padding:12px 16px;}

/* Cards */
.appt-card{background:var(--white);border:1px solid var(--border);border-radius:var(--radius);padding:12px 14px;margin-bottom:10px;border-left:3px solid transparent;transition:box-shadow .15s;}
.appt-card:hover{box-shadow:0 2px 10px rgba(0,0,0,.08);}
.appt-card.confirmed{border-left-color:var(--green);}
.appt-card.pending{border-left-color:var(--gold);}
.appt-card.cancelled{border-left-color:var(--red);opacity:.55;}
.appt-card.checkin{border-left-color:var(--blue);}
.appt-card.doing{border-left-color:var(--purple);}
.appt-card.out{border-left-color:#888;}
.appt-card.thinking{border-left-color:#f59e0b;background:#fffbeb;}
.appt-time-pill{display:inline-block;background:var(--accent-light);color:var(--accent);border-radius:4px;padding:2px 8px;font-size:11px;font-weight:700;margin-bottom:4px;}
.appt-status-pill{display:inline-block;border-radius:20px;padding:2px 8px;font-size:10px;font-weight:700;margin-left:4px;}
.appt-status-pill.confirmed{background:var(--green-light);color:var(--green);}
.appt-status-pill.pending{background:var(--gold-light);color:var(--gold);}
.appt-status-pill.cancelled{background:#fef0f0;color:var(--red);}
.appt-status-pill.checkin{background:var(--blue-light);color:var(--blue);}
.appt-status-pill.doing{background:#f5f0ff;color:var(--purple);}
.appt-status-pill.out{background:#f5f5f5;color:#666;}
.appt-status-pill.thinking{background:#fef9ec;color:#b45309;}
.appt-card-actions{display:flex;gap:5px;margin-top:8px;padding-top:8px;border-top:1px solid var(--border);flex-wrap:wrap;}
.appt-ca{padding:5px 8px;border-radius:5px;border:none;cursor:pointer;font-family:var(--font);font-size:11px;font-weight:700;display:flex;align-items:center;justify-content:center;gap:3px;text-decoration:none;white-space:nowrap;}
.appt-ca-confirm{background:var(--green-light);color:var(--green);}
.appt-ca-confirm:hover{background:var(--green);color:#fff;}
.appt-ca-cancel{background:#fef0f0;color:var(--red);}
.appt-ca-cancel:hover{background:var(--red);color:#fff;}
.appt-ca-fb{background:#e8f0ff;color:#1877f2;}
.appt-ca-fb:hover{background:#1877f2;color:#fff;}
.appt-ca-tg{background:#e3f4fd;color:#229ED9;}
.appt-ca-tg:hover{background:#229ED9;color:#fff;}
.appt-ca-reminder{background:var(--accent-light);color:var(--accent);}
.appt-ca-reminder:hover{background:var(--accent);color:#fff;}
.appt-ca-call{background:var(--green-light);color:var(--green);}
.appt-ca-order{background:var(--purple);color:#fff;}
.appt-ca-order:hover{background:#6a3dbb;color:#fff;}

/* Status workflow buttons */
.appt-status-btns{display:flex;gap:4px;flex-wrap:wrap;margin-top:8px;}
.asb{padding:4px 10px;border-radius:20px;border:2px solid;font-family:var(--font);font-size:10px;font-weight:800;cursor:pointer;transition:all .15s;}
.asb-checkin{border-color:var(--blue);background:var(--blue-light);color:var(--blue);}
.asb-checkin:hover,.asb-checkin.active{background:var(--blue);color:#fff;}
.asb-doing{border-color:var(--purple);background:#f5f0ff;color:var(--purple);}
.asb-doing:hover,.asb-doing.active{background:var(--purple);color:#fff;}
.asb-out{border-color:#888;background:#f5f5f5;color:#555;}
.asb-out:hover,.asb-out.active{background:#555;color:#fff;}
.asb-thinking{border-color:#f59e0b;background:#fef9ec;color:#b45309;}
.asb-thinking:hover,.asb-thinking.active{background:#f59e0b;color:#fff;}

/* Out reason modal */
.out-modal{position:fixed;inset:0;background:rgba(0,0,0,.5);z-index:500;display:none;align-items:center;justify-content:center;}
.out-modal.open{display:flex;}
.out-modal-box{background:var(--white);border-radius:12px;width:420px;max-width:95vw;padding:24px;box-shadow:0 12px 48px rgba(0,0,0,.2);}

/* Thinking follow-up badge */
.think-badge{display:inline-flex;align-items:center;gap:4px;background:#fef9ec;border:1px solid #f59e0b;border-radius:4px;padding:2px 8px;font-size:10px;font-weight:700;color:#b45309;margin-top:4px;}

/* Quick add popup FAB */
.appt-fab{position:fixed;bottom:28px;right:28px;width:52px;height:52px;border-radius:50%;background:var(--accent);color:#fff;border:none;font-size:26px;cursor:pointer;box-shadow:0 4px 18px rgba(224,122,60,.5);z-index:350;display:flex;align-items:center;justify-content:center;transition:transform .2s;}
.appt-fab:hover{transform:scale(1.1);}
.appt-quick-popup{position:fixed;bottom:90px;right:28px;width:360px;background:var(--white);border-radius:14px;box-shadow:0 8px 40px rgba(0,0,0,.2);z-index:350;display:none;flex-direction:column;overflow:hidden;}
.appt-quick-popup.open{display:flex;}
.appt-qp-hdr{background:var(--accent);color:#fff;padding:12px 16px;display:flex;align-items:center;justify-content:space-between;}
.appt-qp-body{padding:14px 16px;display:flex;flex-direction:column;gap:8px;max-height:70vh;overflow-y:auto;}
/* Calendar grid view */
.appt-cal-grid-month{display:grid;grid-template-columns:repeat(7,1fr);gap:1px;background:var(--border);border:1px solid var(--border);border-radius:8px;overflow:hidden;}
.acg-header{background:#fafaf8;padding:6px;font-size:11px;font-weight:800;color:var(--muted);text-align:center;border-bottom:1px solid var(--border);}
.acg-day{background:var(--white);min-height:80px;padding:4px 5px;}
.acg-day-num{font-size:11px;font-weight:700;color:var(--muted);margin-bottom:3px;}
.acg-day.today .acg-day-num{color:var(--accent);font-size:13px;}
.acg-event{border-radius:3px;padding:2px 5px;font-size:10px;font-weight:700;margin-bottom:2px;cursor:pointer;overflow:hidden;white-space:nowrap;text-overflow:ellipsis;background:var(--accent-light);border-left:3px solid var(--accent);color:var(--accent);}
.acg-event.confirmed{border-color:var(--green);background:var(--green-light);color:var(--green);}
.acg-event.checkin{border-color:var(--blue);background:var(--blue-light);color:var(--blue);}
.acg-event.doing{border-color:var(--purple);background:#f5f0ff;color:var(--purple);}
.acg-event.out{border-color:#888;background:#f5f5f5;color:#666;}
.acg-event.thinking{border-color:#f59e0b;background:#fef9ec;color:#b45309;}
/* List 30-day */
.appt-l30-day-hdr{padding:6px 16px;background:#f5f5f0;font-size:11px;font-weight:800;color:var(--muted);text-transform:uppercase;letter-spacing:.4px;position:sticky;top:0;z-index:1;border-bottom:1px solid var(--border);}
.appt-l30-row{display:flex;align-items:center;gap:10px;padding:9px 16px;border-bottom:1px solid var(--border);cursor:pointer;transition:background .1s;}
.appt-l30-row:hover{background:#fafaf8;}
.appt-l30-time{font-size:12px;font-weight:800;color:var(--accent);min-width:44px;}
.appt-l30-name{font-size:13px;font-weight:700;min-width:130px;}
.appt-l30-svc{font-size:11px;color:var(--muted);flex:1;}
/* View toggle */
.appt-view-tabs{display:flex;gap:2px;padding:0 14px;border-bottom:1px solid var(--border);background:var(--white);flex-shrink:0;}
.appt-vtab{padding:7px 14px;font-size:12px;font-weight:600;cursor:pointer;border-bottom:2px solid transparent;color:var(--muted);transition:all .15s;white-space:nowrap;}
.appt-vtab.active{border-color:var(--accent);color:var(--accent);font-weight:800;}
/* Photo in customer detail */
.photo-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(90px,1fr));gap:8px;margin-top:8px;}
.photo-card{border-radius:6px;overflow:hidden;position:relative;background:#f5f5f0;aspect-ratio:1;border:1px solid var(--border);}
.photo-card img{width:100%;height:100%;object-fit:cover;}
.photo-label{position:absolute;bottom:0;left:0;right:0;background:rgba(0,0,0,.6);color:#fff;font-size:9px;font-weight:700;padding:2px 4px;text-align:center;}
.photo-add-btn{border:2px dashed var(--border);border-radius:6px;aspect-ratio:1;display:flex;flex-direction:column;align-items:center;justify-content:center;cursor:pointer;background:var(--white);gap:4px;color:var(--muted);font-size:11px;font-weight:700;transition:border-color .15s;}
.photo-add-btn:hover{border-color:var(--accent);color:var(--accent);}

/* Quick-create floating button & popup */
.appt-fab{position:fixed;bottom:28px;right:28px;width:52px;height:52px;border-radius:50%;background:var(--accent);color:#fff;border:none;font-size:24px;cursor:pointer;box-shadow:0 4px 16px rgba(224,122,60,.5);z-index:350;display:none;align-items:center;justify-content:center;transition:transform .15s;}
.appt-fab:hover{transform:scale(1.08);}
.appt-fab-open{display:flex;}
.appt-quick-popup{position:fixed;bottom:88px;right:28px;width:340px;background:var(--white);border-radius:12px;box-shadow:0 8px 40px rgba(0,0,0,.18);z-index:351;display:none;flex-direction:column;overflow:hidden;}
.appt-quick-popup.open{display:flex;}
.appt-quick-hdr{padding:12px 16px;background:var(--accent);color:#fff;font-size:13px;font-weight:800;display:flex;align-items:center;justify-content:space-between;}

/* View tabs */
.appt-view-tabs{display:flex;align-items:center;padding:0 16px;border-bottom:1px solid var(--border);background:var(--white);flex-shrink:0;}
.appt-vtab{padding:10px 14px;font-size:12px;cursor:pointer;border-bottom:2px solid transparent;color:var(--muted);font-weight:600;white-space:nowrap;transition:all .15s;}
.appt-vtab.active{border-color:var(--accent);color:var(--accent);font-weight:800;}
.appt-vtab:hover{color:var(--accent);}

/* Week calendar grid */
.appt-week-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:6px;padding:12px 16px;flex:1;overflow-y:auto;}
.appt-week-col{border:1px solid var(--border);border-radius:8px;overflow:hidden;min-height:200px;}
.appt-week-day-hdr{padding:6px 8px;background:#fafaf8;border-bottom:1px solid var(--border);text-align:center;}
.appt-week-day-name{font-size:10px;font-weight:800;color:var(--muted);text-transform:uppercase;}
.appt-week-day-num{font-size:18px;font-weight:800;color:var(--text);}
.appt-week-day-hdr.is-today{background:var(--accent);}
.appt-week-day-hdr.is-today .appt-week-day-name,.appt-week-day-hdr.is-today .appt-week-day-num{color:#fff;}
.appt-week-event{margin:4px;border-radius:5px;padding:4px 6px;font-size:10px;font-weight:700;cursor:pointer;line-height:1.3;}
.appt-week-event:hover{opacity:.85;}
.awe-confirmed{background:#eaf7f0;color:var(--green);border-left:3px solid var(--green);}
.awe-pending{background:#fdf8ec;color:var(--gold);border-left:3px solid var(--gold);}
.awe-checkin{background:var(--blue-light);color:var(--blue);border-left:3px solid var(--blue);}
.awe-doing{background:#f5f0ff;color:var(--purple);border-left:3px solid var(--purple);}
.awe-cancelled{background:#f5f5f0;color:#aaa;border-left:3px solid #ccc;text-decoration:line-through;}
.awe-out{background:#f5f5f0;color:#888;border-left:3px solid #aaa;}

/* 30-day list */
.appt-day-group{border-bottom:1px solid var(--border);}
.appt-day-group-hdr{padding:8px 16px;background:#f5f5f0;font-size:12px;font-weight:800;color:var(--text);display:flex;align-items:center;gap:8px;position:sticky;top:0;z-index:1;}
.appt-day-group-hdr.is-today-hdr{background:var(--accent);color:#fff;}
.appt-30-row{display:grid;grid-template-columns:70px 1fr 1fr 100px 90px;align-items:center;gap:10px;padding:8px 16px;border-bottom:1px solid rgba(0,0,0,.04);cursor:pointer;transition:background .1s;}
.appt-30-row:hover{background:#fdf9f5;}
.appt-30-row:last-child{border-bottom:none;}

/* Bot config modal */
.bot-config-mo{position:fixed;inset:0;background:rgba(0,0,0,.5);z-index:600;display:none;align-items:center;justify-content:center;}
.bot-config-mo.open{display:flex;}
.bot-config-box{background:var(--white);border-radius:12px;width:460px;max-width:96vw;padding:0;box-shadow:0 12px 48px rgba(0,0,0,.22);overflow:hidden;}

/* Photo grid */
.photo-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(90px,1fr));gap:8px;margin-top:8px;}
.photo-card{border-radius:6px;overflow:hidden;position:relative;background:#f5f5f0;aspect-ratio:1;border:1px solid var(--border);}
.photo-card img{width:100%;height:100%;object-fit:cover;}
.photo-label{position:absolute;bottom:0;left:0;right:0;background:rgba(0,0,0,.6);color:#fff;font-size:9px;font-weight:700;padding:2px 4px;text-align:center;}
.photo-add-btn{border:2px dashed var(--border);border-radius:6px;aspect-ratio:1;display:flex;flex-direction:column;align-items:center;justify-content:center;cursor:pointer;background:var(--white);gap:4px;color:var(--muted);font-size:11px;font-weight:700;transition:border-color .15s;}
.photo-add-btn:hover{border-color:var(--accent);color:var(--accent);}
.photo-delete-btn{position:absolute;top:3px;right:3px;width:18px;height:18px;border-radius:50%;background:rgba(0,0,0,.6);color:#fff;border:none;font-size:11px;cursor:pointer;display:flex;align-items:center;justify-content:center;line-height:1;}

.appt-wf-btn{display:block;width:100%;padding:5px 8px;border:none;border-top:1px solid var(--border);background:var(--white);font-family:var(--font);font-size:11px;font-weight:600;cursor:pointer;text-align:left;color:var(--text);transition:background .1s;}
.appt-wf-btn:first-of-type{border-top:none;}
.appt-wf-btn:hover{background:#f0f0ec;}
.appt-wf-checkin:hover,.appt-wf-checkin.appt-wf-active{background:var(--blue-light);color:var(--blue);font-weight:800;}
.appt-wf-doing:hover,.appt-wf-doing.appt-wf-active{background:#f5f0ff;color:var(--purple);font-weight:800;}
.appt-wf-out:hover{background:#fef0f0;color:var(--red);font-weight:800;}
.appt-wf-think:hover,.appt-wf-think.appt-wf-active{background:#fef9ec;color:#b45309;font-weight:800;}

/* Edit modal */
.appt-edit-mo{position:fixed;inset:0;background:rgba(0,0,0,.5);z-index:500;display:none;align-items:center;justify-content:center;}
.appt-edit-mo.open{display:flex;}
.appt-edit-box{background:var(--white);border-radius:12px;width:520px;max-width:96vw;max-height:92vh;overflow-y:auto;box-shadow:0 12px 48px rgba(0,0,0,.22);padding:0;}
.appt-edit-hdr{padding:16px 20px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;}
.appt-edit-body{padding:16px 20px;}
.appt-edit-foot{padding:12px 20px;border-top:1px solid var(--border);display:flex;gap:8px;justify-content:flex-end;background:#fafaf8;border-radius:0 0 12px 12px;}

/* Order push banner */
.appt-order-banner{background:linear-gradient(135deg,var(--purple),#9b4fe8);color:#fff;border-radius:8px;padding:12px 14px;margin-bottom:12px;}


/* Filter tabs for appt */
.appt-ftab{padding:4px 12px;border-radius:20px;border:1px solid var(--border);background:var(--white);font-family:var(--font);font-size:11px;cursor:pointer;color:var(--muted);}
.appt-ftab:hover{border-color:var(--accent);color:var(--accent);}
.appt-ftab.active{background:var(--accent);color:#fff;border-color:var(--accent);font-weight:700;}

/* Shared form field helper */
.kh-form-grid-2{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-bottom:10px;}
.kh-form-grid-3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:10px;margin-bottom:10px;}
.kh-fld{display:flex;flex-direction:column;gap:3px;margin-bottom:10px;}
.kh-fld label{font-size:10px;font-weight:700;color:var(--muted);text-transform:uppercase;letter-spacing:.3px;}
.kh-fld input,.kh-fld select,.kh-fld textarea{padding:7px 10px;border:1px solid var(--border);border-radius:6px;font-family:var(--font);font-size:13px;outline:none;background:var(--white);color:var(--text);}
.kh-fld input:focus,.kh-fld select:focus,.kh-fld textarea:focus{border-color:var(--accent);}