/* ============================================================
   app.css — โปรแกรมลาชั่วโมง ศูนย์สุขภาพจิตที่ 8
   Design System & Component Styles
   ============================================================ */

/* ---- DESIGN SYSTEM ---- */
:root{
  --primary:#E8620A;--primary-dark:#C04E06;--primary-light:#FF8C38;--primary-pale:#FFF3EB;
  --gold:#F5A623;--success:#27AE60;--warning:#F39C12;--danger:#E74C3C;--info:#2980B9;
  --dark:#1A1A2E;--dark2:#16213E;--text:#2C2C2C;--text-light:#777;
  --border:#E8E0D8;--bg:#FAF7F4;--white:#FFF;
  --shadow:0 4px 20px rgba(232,98,10,.12);--shadow-lg:0 10px 40px rgba(232,98,10,.18);
  --radius:14px;--radius-sm:8px;--font:'Sarabun',sans-serif;--font-head:'Prompt',sans-serif;
}
*{margin:0;padding:0;box-sizing:border-box}
body{font-family:var(--font);background:var(--bg);color:var(--text);min-height:100vh;font-size:15px;line-height:1.6}

/* ---- LOADER ---- */
#loader{position:fixed;inset:0;z-index:9999;background:linear-gradient(135deg,var(--dark),var(--dark2),#0F3460);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:20px}
.ld-logo{width:90px;height:90px;background:linear-gradient(135deg,var(--primary),var(--gold));border-radius:50%;display:flex;align-items:center;justify-content:center;animation:pulse 1.5s ease-in-out infinite;box-shadow:0 0 40px rgba(232,98,10,.5)}
.ld-logo i{font-size:40px;color:#fff}
.ld-text{color:#fff;font-family:var(--font-head);font-size:18px;font-weight:500}
.ld-bar{width:220px;height:4px;background:rgba(255,255,255,.15);border-radius:2px;overflow:hidden}
.ld-fill{height:100%;background:linear-gradient(90deg,var(--primary),var(--gold));border-radius:2px;animation:ldbar 2s ease forwards}
@keyframes ldbar{from{width:0}to{width:100%}}
@keyframes pulse{0%,100%{transform:scale(1)}50%{transform:scale(1.08)}}

/* ---- LOGIN ---- */
#loginPage{min-height:100vh;background:linear-gradient(135deg,var(--dark),var(--dark2),#0F3460);display:flex;align-items:center;justify-content:center;padding:20px}
#loginPage::before{content:'';position:absolute;inset:0;background:url("data:image/svg+xml,%3Csvg width='60' height='60' xmlns='http://www.w3.org/2000/svg'%3E%3Ccircle cx='30' cy='30' r='1' fill='rgba(232,98,10,0.12)'/%3E%3C/svg%3E") repeat;opacity:.5}
.login-card{background:#fff;border-radius:24px;padding:50px 44px;width:100%;max-width:430px;box-shadow:0 30px 80px rgba(0,0,0,.45);position:relative;z-index:1;animation:slideUp .5s ease}
@keyframes slideUp{from{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}
.lg-logo{width:80px;height:80px;margin:0 auto 16px;background:linear-gradient(135deg,var(--primary),var(--gold));border-radius:50%;display:flex;align-items:center;justify-content:center;box-shadow:0 8px 24px rgba(232,98,10,.4)}
.lg-logo i{font-size:36px;color:#fff}
.lg-title{font-family:var(--font-head);font-size:17px;font-weight:700;color:var(--primary);text-align:center;line-height:1.4;margin-bottom:4px}
.lg-sub{font-size:13px;color:var(--text-light);text-align:center;margin-bottom:32px}

/* ---- FORMS ---- */
.fg{margin-bottom:18px}
.fl{display:block;font-weight:600;font-size:13px;color:var(--text);margin-bottom:6px}
.fc{width:100%;padding:12px 16px;border:1.5px solid var(--border);border-radius:var(--radius-sm);font-family:var(--font);font-size:14px;color:var(--text);background:#fff;transition:.2s;outline:none}
.fc:focus{border-color:var(--primary);box-shadow:0 0 0 3px rgba(232,98,10,.12)}
.fc.err{border-color:var(--danger)}
.ii{position:relative}.ii i{position:absolute;left:14px;top:50%;transform:translateY(-50%);color:var(--text-light);font-size:15px}.ii .fc{padding-left:42px}
select.fc{cursor:pointer}
textarea.fc{resize:vertical}

/* ---- BUTTONS ---- */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:11px 22px;border:none;border-radius:var(--radius-sm);font-family:var(--font);font-size:14px;font-weight:600;cursor:pointer;transition:.2s;text-decoration:none;white-space:nowrap}
.btn-primary{background:linear-gradient(135deg,var(--primary),var(--primary-light));color:#fff;box-shadow:0 4px 14px rgba(232,98,10,.35)}
.btn-primary:hover{transform:translateY(-1px);box-shadow:0 6px 20px rgba(232,98,10,.45)}
.btn-success{background:var(--success);color:#fff}.btn-success:hover{background:#219a52}
.btn-danger{background:var(--danger);color:#fff}.btn-danger:hover{background:#c0392b}
.btn-warning{background:var(--warning);color:#fff}.btn-warning:hover{background:#d68910}
.btn-info{background:var(--info);color:#fff}.btn-info:hover{background:#1a6fa8}
.btn-outline{background:transparent;border:1.5px solid var(--border);color:var(--text-light)}
.btn-outline:hover{border-color:var(--primary);color:var(--primary);background:var(--primary-pale)}
.btn-sm{padding:6px 14px;font-size:12px}
.btn-lg{padding:14px 28px;font-size:16px;width:100%}
.btn:disabled{opacity:.6;cursor:not-allowed;transform:none!important}

/* ---- ALERT ---- */
.alert{padding:12px 16px;border-radius:var(--radius-sm);font-size:13px;font-weight:500;display:flex;align-items:flex-start;gap:8px;animation:fadeIn .3s ease;margin-bottom:14px}
.alert-danger{background:#FEE;color:var(--danger);border-left:3px solid var(--danger)}
.alert-success{background:#EFB;color:var(--success);border-left:3px solid var(--success)}
.alert-warning{background:#FFF3CD;color:#856404;border-left:3px solid var(--warning)}
.alert-info{background:#D1ECF1;color:#0C5460;border-left:3px solid var(--info)}
@keyframes fadeIn{from{opacity:0;transform:translateY(-5px)}to{opacity:1;transform:translateY(0)}}

/* ---- HEADER ---- */
.hdr{background:linear-gradient(135deg,var(--dark),var(--dark2),#0F3460);color:#fff;padding:0 24px;box-shadow:0 2px 20px rgba(0,0,0,.3);position:sticky;top:0;z-index:100}
.hdr-inner{max-width:1280px;margin:0 auto;display:flex;align-items:center;height:64px;gap:16px}
.hdr-logo{width:44px;height:44px;background:linear-gradient(135deg,var(--primary),var(--gold));border-radius:12px;display:flex;align-items:center;justify-content:center;flex-shrink:0;box-shadow:0 4px 12px rgba(232,98,10,.4)}
.hdr-logo i{font-size:22px;color:#fff}
.hdr-title{font-family:var(--font-head);font-size:15px;font-weight:600;line-height:1.3;flex:1}
.hdr-title span{display:block;font-size:11px;font-weight:400;color:rgba(255,255,255,.55)}
.hdr-user{display:flex;align-items:center;gap:10px;background:rgba(255,255,255,.08);border-radius:10px;padding:6px 12px;cursor:pointer}
.hdr-user:hover{background:rgba(255,255,255,.14)}
.hdr-avatar{width:32px;height:32px;background:linear-gradient(135deg,var(--primary),var(--gold));border-radius:50%;display:flex;align-items:center;justify-content:center}
.hdr-avatar i{font-size:15px;color:#fff}
.hdr-uname{font-size:13px;font-weight:600}
.hdr-urole{font-size:11px;color:rgba(255,255,255,.55)}
.logout-btn{background:rgba(232,98,10,.2);border:1px solid rgba(232,98,10,.4);color:var(--primary-light);border-radius:8px;padding:7px 14px;font-size:12px;font-weight:600;cursor:pointer;transition:.2s;font-family:var(--font)}
.logout-btn:hover{background:rgba(232,98,10,.35)}

/* ---- LAYOUT ---- */
.wrap{display:flex;flex:1;min-height:calc(100vh - 64px)}
.sidebar{width:240px;background:#fff;border-right:1px solid var(--border);flex-shrink:0;box-shadow:2px 0 10px rgba(0,0,0,.04)}
.nav-lbl{font-size:10px;font-weight:700;color:var(--text-light);text-transform:uppercase;letter-spacing:1.2px;padding:20px 20px 6px}
.nav-item{display:flex;align-items:center;gap:12px;padding:11px 20px;color:var(--text-light);font-size:14px;font-weight:500;border-left:3px solid transparent;cursor:pointer;transition:.2s;user-select:none}
.nav-item:hover{background:var(--primary-pale);color:var(--primary)}
.nav-item.active{background:var(--primary-pale);color:var(--primary);border-left-color:var(--primary);font-weight:600}
.nav-item i{width:18px;text-align:center;font-size:16px}
.nav-badge{margin-left:auto;background:var(--danger);color:#fff;border-radius:10px;padding:1px 7px;font-size:11px;font-weight:700}
.content{flex:1;padding:28px;overflow-x:hidden;background:var(--bg)}
.ci{max-width:1000px;margin:0 auto}

/* ---- PAGE HEADER ---- */
.ph{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:24px;gap:16px;flex-wrap:wrap}
.pt{font-family:var(--font-head);font-size:22px;font-weight:700;color:var(--dark)}
.ps{font-size:13px;color:var(--text-light);margin-top:2px}

/* ---- STATS CARDS ---- */
.sg{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:16px;margin-bottom:24px}
.sc{background:#fff;border-radius:var(--radius);padding:20px;box-shadow:var(--shadow);border:1px solid rgba(232,98,10,.08);position:relative;overflow:hidden;transition:transform .2s}
.sc:hover{transform:translateY(-2px);box-shadow:var(--shadow-lg)}
.sc::before{content:'';position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,var(--primary),var(--gold))}
.sc-icon{width:44px;height:44px;border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:20px;margin-bottom:12px}
.sc-val{font-family:var(--font-head);font-size:28px;font-weight:700;color:var(--dark)}
.sc-lbl{font-size:12px;color:var(--text-light);margin-top:2px}
.so .sc-icon{background:rgba(232,98,10,.1);color:var(--primary)}
.sg2 .sc-icon{background:rgba(39,174,96,.1);color:var(--success)}
.sr .sc-icon{background:rgba(231,76,60,.1);color:var(--danger)}
.sb .sc-icon{background:rgba(41,128,185,.1);color:var(--info)}

/* ---- CARD ---- */
.card{background:#fff;border-radius:var(--radius);padding:24px;box-shadow:var(--shadow);border:1px solid rgba(232,98,10,.06);margin-bottom:20px}
.ch{display:flex;align-items:center;justify-content:space-between;margin-bottom:20px;padding-bottom:16px;border-bottom:1px solid var(--border);flex-wrap:wrap;gap:10px}
.ct{font-family:var(--font-head);font-size:16px;font-weight:600;color:var(--dark)}

/* ---- TABLE ---- */
.tw{overflow-x:auto}
table{width:100%;border-collapse:collapse;font-size:13.5px}
thead tr{background:linear-gradient(135deg,var(--dark),var(--dark2))}
thead th{padding:12px 14px;text-align:left;font-weight:600;font-size:12px;color:rgba(255,255,255,.85);white-space:nowrap}
tbody tr{border-bottom:1px solid var(--border);transition:.15s}
tbody tr:hover{background:var(--primary-pale)}
tbody td{padding:12px 14px;color:var(--text);vertical-align:middle}
.te{text-align:center;padding:40px!important;color:var(--text-light)}

/* ---- STATUS BADGE ---- */
.badge{display:inline-flex;align-items:center;gap:4px;padding:3px 10px;border-radius:20px;font-size:12px;font-weight:600}
.bp{background:#FFF3CD;color:#856404}
.ba{background:#D4EDDA;color:#155724}
.br{background:#F8D7DA;color:#721C24}
.brs{background:#D1ECF1;color:#0C5460}
.badm{background:rgba(232,98,10,.12);color:var(--primary)}
.bsup{background:rgba(39,174,96,.12);color:var(--success)}
.busr{background:rgba(41,128,185,.12);color:var(--info)}

/* ---- HOURS METER ---- */
.hm{background:linear-gradient(135deg,var(--dark),var(--dark2));border-radius:var(--radius);padding:24px;color:#fff;margin-bottom:20px;position:relative;overflow:hidden}
.hm::before{content:'';position:absolute;width:200px;height:200px;background:radial-gradient(circle,rgba(232,98,10,.2),transparent 70%);top:-50px;right:-50px}
.hm-lbl{font-size:13px;color:rgba(255,255,255,.7);margin-bottom:6px}
.hm-val{font-family:var(--font-head);font-size:42px;font-weight:700;color:var(--gold)}
.hm-bar{height:8px;background:rgba(255,255,255,.15);border-radius:4px;margin:16px 0 8px;overflow:hidden}
.hm-fill{height:100%;border-radius:4px;background:linear-gradient(90deg,var(--primary),var(--gold));transition:width .8s ease}
.hm-fill.danger{background:linear-gradient(90deg,var(--danger),#FF6B6B)}
.hm-foot{display:flex;justify-content:space-between;font-size:12px;color:rgba(255,255,255,.6)}

/* ---- MODAL ---- */
.mo{position:fixed;inset:0;background:rgba(0,0,0,.5);backdrop-filter:blur(3px);z-index:500;display:flex;align-items:center;justify-content:center;padding:20px;animation:fadeIn .2s ease}
.md{background:#fff;border-radius:20px;width:100%;max-width:520px;box-shadow:0 30px 80px rgba(0,0,0,.3);overflow:hidden;animation:slideUp .3s ease}
.mh{padding:20px 24px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;background:linear-gradient(135deg,var(--primary-pale),#fff)}
.mt2{font-family:var(--font-head);font-size:17px;font-weight:600;color:var(--dark)}
.mc{width:32px;height:32px;border:none;background:var(--border);border-radius:50%;cursor:pointer;font-size:16px;display:flex;align-items:center;justify-content:center;transition:.2s}
.mc:hover{background:var(--danger);color:#fff}
.mb{padding:24px}
.mf{padding:16px 24px;border-top:1px solid var(--border);display:flex;gap:10px;justify-content:flex-end;background:#FAFAFA;flex-wrap:wrap}

/* ---- TOAST ---- */
#toasts{position:fixed;top:80px;right:20px;z-index:9999;display:flex;flex-direction:column;gap:10px}
.toast{background:#fff;border-radius:12px;padding:14px 18px;box-shadow:0 8px 30px rgba(0,0,0,.15);display:flex;align-items:center;gap:12px;min-width:280px;max-width:380px;animation:toastIn .3s ease;border-left:4px solid}
.toast.success{border-color:var(--success)}.toast.error{border-color:var(--danger)}.toast.warning{border-color:var(--warning)}.toast.info{border-color:var(--info)}
.toast i{font-size:20px}.toast.success i{color:var(--success)}.toast.error i{color:var(--danger)}.toast.warning i{color:var(--warning)}.toast.info i{color:var(--info)}
.toast-txt{font-size:13.5px;font-weight:500;flex:1}
@keyframes toastIn{from{opacity:0;transform:translateX(100%)}to{opacity:1;transform:translateX(0)}}

/* ---- FORM ROW ---- */
.fr{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.fr3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:14px}

/* ---- PROGRESS ---- */
.pw{margin:12px 0}
.pbar{height:10px;background:var(--border);border-radius:5px;overflow:hidden}
.pfill{height:100%;border-radius:5px;background:linear-gradient(90deg,var(--primary),var(--gold));transition:width .6s ease}
.pfill.danger{background:linear-gradient(90deg,var(--danger),#FF6B6B)}

/* ---- UTILS ---- */
.spin{animation:spin 1s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}
.hidden{display:none!important}
.mt4{margin-top:16px}.mt8{margin-top:32px}
.to{color:var(--primary)}.tg{color:var(--success)}.tr{color:var(--danger)}
.fw7{font-weight:700}
.divider{height:1px;background:var(--border);margin:16px 0}

/* ---- APP SHELL ---- */
.app-shell{display:flex;flex-direction:column;min-height:100vh}
.app-shell.hidden{display:none!important}

/* ---- RESPONSIVE ---- */
@media(max-width:768px){
  .sidebar{display:none}
  .content{padding:16px}
  .sg{grid-template-columns:repeat(2,1fr)}
  .fr,.fr3{grid-template-columns:1fr}
  .hdr-title{font-size:13px}
  .hdr-uinfo{display:none}
  .mf{justify-content:stretch}
  .mf .btn{flex:1}
}
@media(max-width:480px){
  .sg{grid-template-columns:1fr 1fr}
  .login-card{padding:36px 24px}
}
