@import "https://fonts.googleapis.com/css2?family=Sarabun:wght@300;400;600;700&display=swap";
:root{--green-primary:#1a531b;--green-dark:#113812;--green-light:#e8f5e9;--green-accent:#2e7d32;--bg-body:#f4f8f5;--text-main:#2d3436;--shadow-card:0 4px 24px #1a531b14;--shadow-hover:0 8px 32px #1a531b26;--radius:16px;--radius-sm:10px;--transition:all .3s cubic-bezier(.4,0,.2,1)}*{box-sizing:border-box;margin:0;padding:0}body{background-color:var(--bg-body);color:var(--text-main);font-family:Sarabun,sans-serif;line-height:1.6}.app-container{min-height:100vh;display:flex}.sidebar{z-index:1001;background:#fff;border-right:1px solid #e8ebe9;flex-direction:column;flex-shrink:0;width:260px;height:100vh;display:flex;position:relative;top:0;box-shadow:2px 0 20px #00000008}.sidebar-content{scrollbar-width:thin;scrollbar-color:#e0e0e0 transparent;flex:1;padding:20px 20px 30px;overflow-y:auto}.sidebar-content::-webkit-scrollbar{width:4px}.sidebar-content::-webkit-scrollbar-thumb{background:#e0e0e0;border-radius:4px}.sidebar-logo{color:var(--green-primary);text-align:center;letter-spacing:-.5px;margin-bottom:4px;font-size:1.4rem;font-weight:700}.sidebar-subtitle{color:#999;text-align:center;letter-spacing:1px;text-transform:uppercase;margin-bottom:10px;font-size:.7rem}.nav-list{flex-direction:column;gap:6px;list-style:none;display:flex}.nav-item{border-radius:var(--radius-sm);cursor:pointer;color:#666;transition:var(--transition);-webkit-user-select:none;user-select:none;align-items:center;gap:10px;padding:12px 16px;font-size:.95rem;font-weight:400;display:flex}.nav-item:hover{color:var(--green-primary);background-color:#f0f7f0}.nav-item.active{background-color:var(--green-light);color:var(--green-primary);box-shadow:inset 3px 0 0 var(--green-primary);font-weight:600}.main-content{flex:1;max-width:1200px;padding:32px 40px}.card{border-radius:var(--radius);box-shadow:var(--shadow-card);transition:var(--transition);background:#fff;border:1px solid #0000000a;margin-bottom:24px;padding:28px}.card:hover{box-shadow:var(--shadow-hover)}.card-header-bar{border-bottom:2px solid var(--green-light);align-items:center;gap:10px;margin-bottom:20px;padding-bottom:16px;display:flex}.card-header-bar h3,.card-header-bar h5{color:var(--green-primary);margin:0;font-weight:700}.page-title{color:var(--green-primary);border-left:4px solid var(--green-accent);margin-bottom:24px;padding-left:16px;font-size:1.5rem;font-weight:700}.btn-green{background:linear-gradient(135deg,var(--green-primary),var(--green-accent));color:#fff;cursor:pointer;transition:var(--transition);border:none;border-radius:25px;padding:10px 24px;font-family:Sarabun,sans-serif;font-size:.9rem;font-weight:600;box-shadow:0 2px 8px #1a531b4d}.btn-green:hover{transform:translateY(-2px);box-shadow:0 4px 16px #1a531b66}.btn-green:active{transform:translateY(0)}.btn-outline{cursor:pointer;transition:var(--transition);background:0 0;border:1.5px solid #ddd;border-radius:20px;padding:6px 16px;font-family:Sarabun,sans-serif;font-size:.8rem;font-weight:500}.btn-outline-success{border-color:var(--green-accent);color:var(--green-accent)}.btn-outline-success:hover{background:var(--green-light)}.btn-outline-primary{color:#1976d2;border-color:#1976d2}.btn-outline-primary:hover{background:#e3f2fd}.btn-outline-danger{color:#e53935;border-color:#e53935}.btn-outline-danger:hover{background:#ffebee}.btn-group{gap:6px;display:flex}.form-group{margin-bottom:16px}.form-label{color:#444;margin-bottom:6px;font-size:.85rem;font-weight:600;display:block}.required-star{color:#dc3545;margin-left:3px}.form-control{border-radius:var(--radius-sm);width:100%;transition:var(--transition);background:#fafffe;border:1.5px solid #ddd;outline:none;padding:10px 14px;font-family:Sarabun,sans-serif;font-size:.9rem}.form-control:focus{border-color:var(--green-accent);box-shadow:0 0 0 3px #2e7d321f}.form-select{border-radius:var(--radius-sm);width:100%;transition:var(--transition);cursor:pointer;appearance:auto;background:#fafffe;border:1.5px solid #ddd;outline:none;padding:10px 14px;font-family:Sarabun,sans-serif;font-size:.9rem}.form-select:focus{border-color:var(--green-accent);box-shadow:0 0 0 3px #2e7d321f}textarea.form-control{resize:vertical;min-height:80px}.form-grid{grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:16px;display:grid}.form-grid-2{grid-template-columns:1fr 1fr;gap:16px;display:grid}.form-grid-3{grid-template-columns:1fr 1fr 1fr;gap:16px;display:grid}.table-container{border-radius:var(--radius-sm);overflow-x:auto}table{border-collapse:collapse;width:100%}table th{text-align:left;color:#666;text-transform:uppercase;letter-spacing:.5px;background:#f8faf8;border-bottom:2px solid #eee;padding:12px 16px;font-size:.8rem;font-weight:600}table td{vertical-align:middle;border-bottom:1px solid #f0f0f0;padding:12px 16px;font-size:.9rem}table tr:hover{background:#f9fdf9}.status-badge{letter-spacing:.3px;border-radius:20px;padding:4px 12px;font-size:.7rem;font-weight:600;display:inline-block}.badge-approved{background:var(--green-light);color:var(--green-primary)}.badge-pending{color:#f57f17;background:#fff8e1}.status-success{color:#2e7d32;background:#e8f5e9}.status-danger{color:#c62828;background:#ffebee}.desk-grid{border-radius:var(--radius-sm);background:#f8faf8;border:1px solid #e8ebe9;flex-wrap:wrap;gap:8px;padding:16px;display:flex}.desk-btn{border:1.5px solid var(--green-accent);color:var(--green-accent);cursor:pointer;transition:var(--transition);background:#fff;border-radius:20px;padding:8px 16px;font-family:Sarabun,sans-serif;font-size:.85rem;font-weight:500}.desk-btn:hover{background:var(--green-light)}.desk-btn.selected{background:var(--green-primary);color:#fff;border-color:var(--green-primary)}.steps-banner{background:linear-gradient(135deg,var(--green-light),#c8e6c9);border-radius:var(--radius);grid-template-columns:1fr 1fr 1fr;gap:0;margin-bottom:24px;padding:20px;display:grid}.step-item{text-align:center;padding:8px 0}.step-item:not(:last-child){border-right:1px solid #1a531b26}.step-item strong{color:var(--green-primary);font-size:.9rem;display:block}.step-item small{color:#666;font-size:.75rem}.preview-img{aspect-ratio:16/9;object-fit:cover;border-radius:var(--radius-sm);cursor:pointer;background:#fafafa;border:2px dashed #ddd;width:100%;margin-bottom:12px}.room-grid{grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:20px;display:grid}.room-card{border-radius:var(--radius-sm);transition:var(--transition);background:#fff;border:1px solid #eee;overflow:hidden;box-shadow:0 2px 12px #0000000f}.room-card:hover{box-shadow:var(--shadow-hover);transform:translateY(-3px)}.room-card img{aspect-ratio:16/9;object-fit:cover;cursor:pointer;width:100%}.room-card-body{text-align:center;padding:12px}.room-card-body strong{color:var(--green-primary);font-size:.9rem}.list-group{border-radius:var(--radius-sm);border:1px solid #eee;list-style:none;overflow:hidden}.list-group-item{border-bottom:1px solid #f0f0f0;justify-content:space-between;align-items:center;padding:10px 16px;font-size:.9rem;display:flex}.list-group-item:last-child{border-bottom:none}.input-group{gap:8px;display:flex}.input-group .form-control{flex:1}.input-group .btn-green{border-radius:var(--radius-sm);white-space:nowrap;padding:10px 20px}.two-col{grid-template-columns:2fr 1fr;align-items:start;gap:24px;display:grid}.admin-grid{grid-template-columns:7fr 5fr;align-items:start;gap:28px;display:grid}.text-center{text-align:center}.text-muted{color:#999;font-size:.8rem}.text-success{color:var(--green-primary)}.text-danger{color:#e53935}.fw-bold{font-weight:600}.mt-2{margin-top:12px}.mt-3{margin-top:20px}.mb-2{margin-bottom:12px}.mb-3{margin-bottom:20px}.w-full{width:100%}.fc{overflow:hidden;border-radius:var(--radius)!important}.fc-event{cursor:pointer;border:none!important;border-radius:4px!important}.login-page{background:linear-gradient(135deg,#e8f5e9 0%,#c8e6c9 35%,#a5d6a7 70%,#81c784 100%);justify-content:center;align-items:center;min-height:100vh;padding:20px;display:flex}.login-card{border-radius:var(--radius);text-align:center;background:#fff;width:100%;max-width:420px;padding:48px 40px;animation:.6s ease-out fadeInUp;box-shadow:0 20px 60px #1a531b26}@keyframes fadeInUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}.login-logo{margin-bottom:8px;font-size:3.5rem}.login-title{color:var(--green-primary);margin-bottom:4px;font-size:1.8rem;font-weight:700}.login-subtitle{color:#999;margin-bottom:32px;font-size:.9rem}.login-divider{margin:24px 0;position:relative}.login-divider span{color:#999;z-index:1;background:#fff;padding:0 14px;font-size:.85rem;position:relative}.login-divider:before{content:"";background:#eee;height:1px;position:absolute;top:50%;left:0;right:0}.login-btn-wrapper{justify-content:center;margin:20px 0;display:flex}.login-note{color:#999;margin-top:24px;font-size:.8rem;line-height:1.6}.login-note small{color:#bbb}.sidebar-user{background:#fff;border-top:1px solid #f0f0f0;flex-shrink:0;justify-content:space-between;align-items:center;gap:12px;padding:16px 20px;display:flex}.sidebar-user-info{flex:1;align-items:center;gap:10px;min-width:0;display:flex}.sidebar-avatar{border:2px solid var(--green-light);border-radius:50%;flex-shrink:0;width:36px;height:36px}.sidebar-avatar-placeholder{background:linear-gradient(135deg,var(--green-primary),var(--green-accent));color:#fff;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:36px;height:36px;font-size:1rem;font-weight:700;display:flex}.sidebar-user-text{min-width:0}.sidebar-user-name{color:var(--green-primary);white-space:nowrap;text-overflow:ellipsis;margin-bottom:2px;font-size:.88rem;font-weight:600;overflow:hidden}.sidebar-user-level{color:#999;align-items:center;gap:5px;font-size:.7rem;display:flex}.level-dot{border-radius:50%;width:8px;height:8px;display:inline-block}.level-dot-1{background:#90caf9}.level-dot-2{background:#fbc02d}.level-dot-3{background:#e53935}.sidebar-logout-btn{cursor:pointer;transition:var(--transition);background:0 0;border:none;border-radius:8px;flex-shrink:0;padding:6px;font-size:1.2rem}.sidebar-logout-btn:hover{background:#ffebee}.badge-level-1{color:#1565c0;background:#e3f2fd}.badge-level-2{color:#f57f17;background:#fff8e1}.badge-level-3{color:#c62828;background:#ffebee}.mobile-topbar{z-index:999;background:#fff;border-bottom:1px solid #e8ebe9;justify-content:space-between;align-items:center;padding:12px 20px;display:none;position:sticky;top:0;box-shadow:0 2px 8px #0000000d}.mobile-menu-btn{color:var(--green-primary);cursor:pointer;background:0 0;border:none;padding:4px;font-size:1.5rem}.mobile-topbar-logo{color:var(--green-primary);letter-spacing:-.5px;font-size:1.2rem;font-weight:700}.sidebar-overlay{-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);z-index:1000;opacity:0;background:#0006;transition:opacity .3s;display:none;position:fixed;inset:0}.sidebar-overlay.active{opacity:1;display:block}.profile-header{align-items:flex-start;gap:30px;margin-top:20px;display:flex}.profile-details-grid{background-color:#f8f9fa;border:1px solid #eee;border-radius:12px;grid-template-columns:minmax(0,1fr) minmax(0,1fr);gap:20px;margin-top:25px;padding:20px;display:grid}@media (max-width:768px){.app-container{flex-direction:column}.sidebar{z-index:1100;width:260px;height:100vh;transition:left .3s;position:fixed;top:0;left:-280px;box-shadow:2px 0 20px #00000026}.sidebar.sidebar-mobile-open{left:0}.mobile-topbar{display:flex}.main-content{padding:16px}.two-col,.admin-grid,.form-grid-2,.form-grid-3{grid-template-columns:1fr}.steps-banner{grid-template-columns:1fr;gap:8px}.step-item:not(:last-child){border-bottom:1px solid #1a531b26;border-right:none;padding-bottom:12px}.login-card{padding:32px 24px}.profile-header{text-align:center;flex-direction:column;align-items:center;gap:15px}.profile-header-actions{flex-direction:column;align-items:center!important}.profile-details-grid{grid-template-columns:1fr;gap:15px}}.modal-overlay{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:1000;background:#00000080;justify-content:center;align-items:center;animation:.3s ease-out fadeIn;display:flex;position:fixed;inset:0}.modal-content{border-radius:var(--radius);background:#fff;width:90%;max-width:800px;max-height:90vh;padding:32px;animation:.3s ease-out slideUp;position:relative;overflow-y:auto;box-shadow:0 20px 60px #0003}.modal-close{cursor:pointer;color:#999;transition:var(--transition);background:0 0;border:none;font-size:1.5rem;position:absolute;top:20px;right:20px}.modal-close:hover{color:#333;transform:rotate(90deg)}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}
