:root{--primary:#0ea5e9;--secondary:#06b6d4;--accent:#8b5cf6;--success:#10b981;--warning:#f59e0b;--danger:#ef4444;--info:#3b82f6;--bg-dark:#0f172a;--bg-card:#1e293b;--bg-card-hover:#334155;--text-primary:#f1f5f9;--text-secondary:#94a3b8;--text-muted:#64748b;--border:#334155;--gradient-primary:linear-gradient(135deg,#0ea5e9 0%,#06b6d4 50%,#8b5cf6 100%);--gradient-card:linear-gradient(145deg,rgba(30,41,59,0.9) 0%,rgba(15,23,42,0.95) 100%);--shadow-glow:0 0 40px rgba(14,165,233,0.15);--shadow-card:0 4px 30px rgba(0,0,0,0.3)}
*{margin:0;padding:0;box-sizing:border-box}
body{font-family:'Plus Jakarta Sans',sans-serif;background:var(--bg-dark);color:var(--text-primary);min-height:100vh}
.bg-effects{position:fixed;top:0;left:0;width:100%;height:100%;pointer-events:none;z-index:-1;background:radial-gradient(ellipse at 20% 20%,rgba(14,165,233,0.08) 0%,transparent 50%),radial-gradient(ellipse at 80% 80%,rgba(139,92,246,0.08) 0%,transparent 50%)}
.login-screen{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:1rem}
.login-box{background:var(--gradient-card);backdrop-filter:blur(20px);border:1px solid var(--border);border-radius:24px;padding:2.5rem;width:100%;max-width:400px;box-shadow:var(--shadow-card)}
.login-logo{text-align:center;margin-bottom:2rem}
.login-logo i{font-size:3rem;background:var(--gradient-primary);-webkit-background-clip:text;-webkit-text-fill-color:transparent}
.login-logo h1{font-size:1.75rem;margin-top:1rem;background:var(--gradient-primary);-webkit-background-clip:text;-webkit-text-fill-color:transparent}
.login-logo p{color:var(--text-secondary);font-size:0.9rem;margin-top:0.5rem}
.app-container{display:none;min-height:100vh}
.app-container.active{display:flex}
.sidebar{width:260px;background:var(--gradient-card);backdrop-filter:blur(20px);border-right:1px solid var(--border);padding:1.25rem;display:flex;flex-direction:column;position:fixed;height:100vh;z-index:100;overflow-y:auto}
.sidebar-header{display:flex;align-items:center;gap:1rem;padding-bottom:1.25rem;border-bottom:1px solid var(--border);margin-bottom:1rem}
.logo{width:45px;height:45px;background:var(--gradient-primary);border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:1.25rem;color:white;box-shadow:var(--shadow-glow)}
.logo-text h1{font-size:1.1rem;background:var(--gradient-primary);-webkit-background-clip:text;-webkit-text-fill-color:transparent}
.logo-text span{font-size:0.7rem;color:var(--text-secondary)}
.clinic-selector{background:rgba(0,0,0,0.3);border-radius:10px;padding:0.875rem;margin-bottom:1rem}
.clinic-selector label{font-size:0.7rem;text-transform:uppercase;color:var(--text-muted);margin-bottom:0.5rem;display:block}
.clinic-selector select{width:100%;padding:0.6rem;background:var(--bg-card-hover);border:1px solid var(--border);border-radius:8px;color:var(--text-primary);font-size:0.85rem}
.nav-menu{flex:1;display:flex;flex-direction:column;gap:0.2rem;overflow-y:auto}
.nav-item{display:flex;align-items:center;gap:0.875rem;padding:0.7rem 1rem;border-radius:10px;color:var(--text-secondary);cursor:pointer;transition:all 0.3s;position:relative;font-size:0.9rem}
.nav-item::before{content:'';position:absolute;left:0;top:0;width:3px;height:100%;background:var(--gradient-primary);transform:scaleY(0);transition:transform 0.3s;border-radius:0 3px 3px 0}
.nav-item:hover,.nav-item.active{background:rgba(14,165,233,0.1);color:var(--text-primary)}
.nav-item.active::before{transform:scaleY(1)}
.nav-item i{width:18px;font-size:0.95rem}
.nav-section{font-size:0.65rem;text-transform:uppercase;letter-spacing:0.1em;color:var(--text-muted);padding:0.875rem 1rem 0.4rem}
.user-info{padding:1rem;background:rgba(0,0,0,0.3);border-radius:10px;margin-top:auto}
.user-info-header{display:flex;align-items:center;gap:0.75rem;margin-bottom:0.75rem}
.user-avatar{width:36px;height:36px;border-radius:50%;background:var(--gradient-primary);display:flex;align-items:center;justify-content:center;font-weight:600;font-size:0.9rem}
.user-name{font-weight:600;font-size:0.85rem}
.user-role{font-size:0.7rem;color:var(--text-muted)}
.btn-logout{width:100%;padding:0.5rem;background:transparent;border:1px solid var(--border);border-radius:8px;color:var(--text-secondary);cursor:pointer;transition:all 0.3s;display:flex;align-items:center;justify-content:center;gap:0.5rem;font-size:0.85rem}
.btn-logout:hover{border-color:var(--danger);color:var(--danger)}
.bot-status{padding:0.875rem;background:rgba(0,0,0,0.3);border-radius:10px;margin-bottom:1rem}
.status-indicator{display:flex;align-items:center;gap:0.75rem;margin-bottom:0.75rem}
.status-dot{width:10px;height:10px;border-radius:50%;background:var(--danger);box-shadow:0 0 10px var(--danger);animation:pulse 2s infinite}
.status-dot.connected{background:var(--success);box-shadow:0 0 10px var(--success)}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:0.5}}
.btn-bot{width:100%;padding:0.6rem;border:none;border-radius:8px;font-weight:600;cursor:pointer;transition:all 0.3s;font-size:0.8rem}
.btn-start{background:var(--gradient-primary);color:white}
.btn-stop{background:var(--danger);color:white}
.btn-warning{background:var(--warning);color:#1e293b}
.main-content{flex:1;margin-left:260px;padding:1.5rem;min-height:100vh}
.page-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem;flex-wrap:wrap;gap:1rem}
.page-title h2{font-size:1.5rem;margin-bottom:0.25rem}
.page-title p{color:var(--text-secondary);font-size:0.85rem}
.card{background:var(--gradient-card);backdrop-filter:blur(20px);border:1px solid var(--border);border-radius:14px;padding:1.25rem;margin-bottom:1.25rem;box-shadow:var(--shadow-card);transition:all 0.3s}
.card:hover{border-color:rgba(14,165,233,0.3)}
.card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.25rem;padding-bottom:0.875rem;border-bottom:1px solid var(--border)}
.card-title{font-size:1rem;display:flex;align-items:center;gap:0.75rem}
.card-title i{color:var(--primary)}
.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:1rem;margin-bottom:1.5rem}
.stat-card{background:var(--gradient-card);border:1px solid var(--border);border-radius:14px;padding:1.25rem;position:relative;overflow:hidden;transition:all 0.3s}
.stat-card::before{content:'';position:absolute;top:0;left:0;width:100%;height:3px;background:var(--gradient-primary)}
.stat-card:hover{transform:translateY(-3px);box-shadow:var(--shadow-glow)}
.stat-icon{width:40px;height:40px;border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:1rem;margin-bottom:0.75rem}
.stat-icon.blue{background:rgba(14,165,233,0.2);color:var(--primary)}
.stat-icon.green{background:rgba(16,185,129,0.2);color:var(--success)}
.stat-icon.purple{background:rgba(139,92,246,0.2);color:var(--accent)}
.stat-icon.orange{background:rgba(245,158,11,0.2);color:var(--warning)}
.stat-value{font-size:1.5rem;font-weight:700}
.stat-label{color:var(--text-secondary);font-size:0.8rem}
.form-group{margin-bottom:1rem}
.form-group label{display:block;margin-bottom:0.4rem;font-weight:500;color:var(--text-secondary);font-size:0.85rem}
.form-input,.form-textarea,.form-select{width:100%;padding:0.75rem;background:rgba(0,0,0,0.3);border:1px solid var(--border);border-radius:8px;color:var(--text-primary);font-size:0.9rem;font-family:inherit;transition:all 0.3s}
.form-input:focus,.form-textarea:focus,.form-select:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px rgba(14,165,233,0.1)}
.form-textarea{min-height:80px;resize:vertical}
.btn{padding:0.7rem 1.25rem;border:none;border-radius:8px;font-weight:600;font-size:0.85rem;cursor:pointer;transition:all 0.3s;display:inline-flex;align-items:center;gap:0.5rem;font-family:inherit}
.btn-primary{background:var(--gradient-primary);color:white}
.btn-secondary{background:var(--bg-card-hover);color:var(--text-primary);border:1px solid var(--border)}
.btn-danger{background:var(--danger);color:white}
.btn:hover{transform:translateY(-2px);box-shadow:var(--shadow-glow)}
.btn-icon{width:30px;height:30px;border-radius:6px;border:none;background:var(--bg-card-hover);color:var(--text-secondary);cursor:pointer;transition:all 0.3s;display:inline-flex;align-items:center;justify-content:center}
.btn-icon:hover{color:var(--text-primary);background:var(--primary)}
.btn-icon.danger:hover{background:var(--danger)}
table{width:100%;border-collapse:collapse}
th,td{padding:0.875rem;text-align:left;border-bottom:1px solid var(--border);font-size:0.9rem}
th{font-weight:600;color:var(--text-secondary);font-size:0.75rem;text-transform:uppercase}
tr:hover{background:rgba(14,165,233,0.05)}
.badge{display:inline-flex;align-items:center;padding:0.2rem 0.6rem;border-radius:20px;font-size:0.7rem;font-weight:600}
.badge-success{background:rgba(16,185,129,0.2);color:var(--success)}
.badge-warning{background:rgba(245,158,11,0.2);color:var(--warning)}
.badge-secondary{background:rgba(148,163,184,0.2);color:var(--text-muted)}
.badge-danger{background:rgba(239,68,68,0.2);color:var(--danger)}
.badge-info{background:rgba(14,165,233,0.2);color:var(--primary)}
.page-section{display:none;animation:fadeIn 0.3s ease}
.page-section.active{display:block}
@keyframes fadeIn{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}
.modal-overlay{position:fixed;top:0;left:0;width:100%;height:100%;background:rgba(0,0,0,0.7);backdrop-filter:blur(5px);display:flex;align-items:center;justify-content:center;z-index:1000;opacity:0;visibility:hidden;transition:all 0.3s}
.modal-overlay.active{opacity:1;visibility:visible}
.modal{background:var(--bg-card);border:1px solid var(--border);border-radius:16px;width:90%;max-width:480px;max-height:90vh;overflow-y:auto;transform:scale(0.9);transition:transform 0.3s}
.modal-overlay.active .modal{transform:scale(1)}
.modal-header{display:flex;justify-content:space-between;align-items:center;padding:1.25rem;border-bottom:1px solid var(--border)}
.modal-header h3{font-size:1.1rem}
.modal-close{background:none;border:none;color:var(--text-secondary);font-size:1.5rem;cursor:pointer}
.modal-close:hover{color:var(--danger)}
.modal-body{padding:1.25rem}
.modal-footer{display:flex;justify-content:flex-end;gap:0.75rem;padding:1.25rem;border-top:1px solid var(--border)}
.draggable-list{list-style:none}
.draggable-item{display:flex;align-items:center;gap:0.875rem;padding:0.875rem;background:rgba(0,0,0,0.2);border:1px solid var(--border);border-radius:10px;margin-bottom:0.5rem;cursor:grab;transition:all 0.3s}
.draggable-item:hover{border-color:var(--primary)}
.draggable-item.dragging{opacity:0.5}
.drag-handle{color:var(--text-muted)}
.item-content{flex:1}
.item-actions{display:flex;gap:0.4rem}
.toggle{position:relative;width:40px;height:22px;display:inline-block}
.toggle input{opacity:0;width:0;height:0}
.toggle-slider{position:absolute;cursor:pointer;top:0;left:0;right:0;bottom:0;background:var(--bg-card-hover);border-radius:22px;transition:0.3s}
.toggle-slider::before{position:absolute;content:"";height:16px;width:16px;left:3px;bottom:3px;background:white;border-radius:50%;transition:0.3s}
.toggle input:checked+.toggle-slider{background:var(--primary)}
.toggle input:checked+.toggle-slider::before{transform:translateX(18px)}
.qr-container{display:flex;flex-direction:column;align-items:center;padding:1.5rem}
.qr-code{background:white;padding:1rem;border-radius:12px;margin-bottom:1rem}
.qr-code img{width:180px;height:180px}
.photo-upload{display:flex;align-items:center;gap:1rem}
.photo-preview{width:70px;height:70px;border-radius:50%;background:var(--bg-card-hover);border:2px dashed var(--border);display:flex;align-items:center;justify-content:center;overflow:hidden}
.photo-preview img{width:100%;height:100%;object-fit:cover}
.photo-preview i{font-size:1.5rem;color:var(--text-muted)}
.chat-window{display:flex;flex-direction:column;height:500px;background:rgba(0,0,0,0.2);border-radius:10px;overflow:hidden}
.chat-messages{flex:1;overflow-y:auto;padding:1rem}
.chat-message{max-width:80%;padding:0.6rem 0.875rem;border-radius:10px;margin-bottom:0.5rem;font-size:0.85rem;word-wrap:break-word}
.chat-message.received{background:var(--bg-card-hover);border-bottom-left-radius:4px}
.chat-message.sent{background:var(--primary);margin-left:auto;border-bottom-right-radius:4px}
.chat-message.media-message{padding:0.5rem}
.chat-message.media-message img,.chat-message.media-message video{display:block;border-radius:8px}
.chat-message audio{filter:invert(1) hue-rotate(180deg)}
.chat-input-area{display:flex;gap:0.5rem;padding:0.875rem;border-top:1px solid var(--border)}
.chat-input-area input{flex:1}
.funnel-container{display:flex;gap:0.875rem;overflow-x:auto;padding:0.5rem 0}
.funnel-stage{flex:1;min-width:160px;background:rgba(0,0,0,0.2);border-radius:10px;padding:0.875rem}
.funnel-stage-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:0.75rem;padding-bottom:0.5rem;border-bottom:1px solid var(--border)}
.funnel-stage-title{font-weight:600;font-size:0.8rem}
.funnel-stage-count{background:var(--primary);color:white;width:22px;height:22px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:0.7rem;font-weight:600}
.hours-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:0.6rem}
.hour-item{display:flex;flex-direction:column;gap:0.3rem}
.hour-item label{font-size:0.75rem;font-weight:600;color:var(--text-secondary)}

.attendance-mode-selector{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem;margin-top:0.5rem}
.mode-option{cursor:pointer}
.mode-option input{display:none}
.mode-card{background:var(--bg-card);border:2px solid var(--border);border-radius:12px;padding:1.25rem;text-align:center;transition:all 0.3s;display:flex;flex-direction:column;align-items:center;gap:0.5rem}
.mode-card i{font-size:1.75rem;color:var(--text-muted);transition:all 0.3s}
.mode-card strong{font-size:0.9rem;color:var(--text-primary)}
.mode-card small{font-size:0.7rem;color:var(--text-secondary);line-height:1.3}
.mode-option input:checked + .mode-card{border-color:var(--primary);background:rgba(14,165,233,0.1)}
.mode-option input:checked + .mode-card i{color:var(--primary)}
.mode-card:hover{border-color:var(--primary);transform:translateY(-2px)}
@media(max-width:768px){.attendance-mode-selector{grid-template-columns:1fr}}

.two-col{display:grid;grid-template-columns:repeat(2,1fr);gap:1rem}
.hour-item{display:flex;align-items:center;gap:0.5rem}
.hour-item label{min-width:60px;font-weight:500;font-size:0.8rem}
.hour-item input{flex:1;padding:0.4rem}
.two-col{display:grid;grid-template-columns:repeat(2,1fr);gap:1rem}
@media(max-width:768px){.two-col{grid-template-columns:1fr}.sidebar{transform:translateX(-100%)}.sidebar.open{transform:translateX(0)}.main-content{margin-left:0}}
.toast-container{position:fixed;top:1rem;right:1rem;z-index:2000;display:flex;flex-direction:column;gap:0.5rem}
.toast{padding:0.875rem 1.25rem;border-radius:10px;background:var(--bg-card);border:1px solid var(--border);box-shadow:var(--shadow-card);display:flex;align-items:center;gap:0.75rem;animation:slideIn 0.3s ease;min-width:260px;font-size:0.9rem}
.toast.success{border-left:4px solid var(--success)}
.toast.error{border-left:4px solid var(--danger)}
@keyframes slideIn{from{transform:translateX(100%);opacity:0}to{transform:translateX(0);opacity:1}}
.spinner{width:40px;height:40px;border:3px solid transparent;border-top-color:var(--primary);border-radius:50%;animation:spin 0.8s linear infinite;margin:60px auto}
@keyframes spin{to{transform:rotate(360deg)}}
::-webkit-scrollbar{width:6px;height:6px}
::-webkit-scrollbar-track{background:var(--bg-dark)}
::-webkit-scrollbar-thumb{background:var(--border);border-radius:3px}
::-webkit-scrollbar-thumb:hover{background:var(--primary)}
.hidden{display:none!important}
.table-container{overflow-x:auto}
.appointment-detail{margin-bottom:1.25rem}
.appointment-detail-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:1.25rem;padding-bottom:1rem;border-bottom:1px solid var(--border)}
.appointment-code{font-family:monospace;font-size:1.25rem;background:rgba(14,165,233,0.2);color:var(--primary);padding:0.4rem 0.8rem;border-radius:8px}
.appointment-info-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1rem;margin-bottom:1.25rem}
.appointment-info-item{background:rgba(0,0,0,0.2);padding:0.875rem;border-radius:10px}
.appointment-info-item label{font-size:0.7rem;text-transform:uppercase;color:var(--text-muted);display:block;margin-bottom:0.25rem}
.appointment-info-item span{font-size:0.95rem;color:var(--text-primary)}
.files-section{margin-top:1.25rem}
.files-section h4{font-size:0.9rem;margin-bottom:0.75rem;display:flex;align-items:center;gap:0.5rem}
.files-section h4 i{color:var(--primary)}
.files-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:0.75rem}
.file-card{background:rgba(0,0,0,0.3);border:1px solid var(--border);border-radius:10px;padding:0.75rem;text-align:center;transition:all 0.3s;cursor:pointer}
.file-card:hover{border-color:var(--primary);transform:translateY(-2px)}
.file-card i{font-size:2rem;margin-bottom:0.5rem}
.file-card i.fa-file-pdf{color:#ef4444}
.file-card i.fa-file-image{color:#10b981}
.file-card i.fa-file-word{color:#3b82f6}
.file-card i.fa-file{color:var(--text-muted)}
.file-card span{font-size:0.75rem;color:var(--text-secondary);display:block;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.file-card small{font-size:0.65rem;color:var(--text-muted)}
.obs-section{margin-top:1.25rem;background:rgba(0,0,0,0.2);padding:1rem;border-radius:10px}
.obs-section h4{font-size:0.9rem;margin-bottom:0.5rem;display:flex;align-items:center;gap:0.5rem}
.obs-section h4 i{color:var(--warning)}
.obs-section p{color:var(--text-secondary);font-size:0.9rem;line-height:1.5}
.badge-code{font-family:monospace;font-size:0.7rem;background:rgba(139,92,246,0.2);color:var(--accent);padding:0.2rem 0.5rem;border-radius:4px}
.link-copy{display:flex;align-items:center;gap:0.5rem;background:rgba(0,0,0,0.3);padding:0.5rem 0.75rem;border-radius:8px;margin-top:0.75rem}
.link-copy input{flex:1;background:transparent;border:none;color:var(--text-primary);font-size:0.8rem;outline:none}
.link-copy button{background:var(--primary);border:none;color:white;padding:0.4rem 0.75rem;border-radius:6px;cursor:pointer;font-size:0.75rem}
