.login-container{height:100vh;display:flex;justify-content:center;align-items:center;background:linear-gradient(to bottom right,#cce5ff,#e6f0ff);padding:20px}.login-box{background-color:#fff;border-radius:16px;box-shadow:0 10px 30px #0000001a;padding:40px 30px;max-width:400px;width:100%;box-sizing:border-box}.login-header{text-align:center;margin-bottom:24px}.login-logo{width:80px;height:auto;margin-bottom:12px}.login-header h1{font-size:24px;font-weight:700;color:#1e3a8a;margin-bottom:4px}.login-header p{font-size:14px;color:#6b7280}.login-input{width:100%;padding:12px 16px;margin-bottom:16px;font-size:16px;border:1px solid #ccc;border-radius:8px;box-sizing:border-box}.login-button{width:100%;background-color:#2563eb;color:#fff;padding:12px 16px;font-size:16px;border:none;border-radius:8px;font-weight:700;cursor:pointer;transition:background-color .2s ease}.login-button:hover{background-color:#1e40af}.login-error{color:red;text-align:center;margin-bottom:12px;font-weight:700}.dashboard-container{padding:40px;background:#f9fafb;min-height:100vh;font-family:Segoe UI,sans-serif}.dashboard-title{font-size:36px;font-weight:700;color:#1e3a8a;margin-bottom:30px;text-align:center}.dashboard-summary{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:24px;margin-bottom:50px}.summary-card{background:#fff;padding:30px 24px;border-radius:16px;box-shadow:0 10px 25px #0000000d;text-align:center;transition:transform .2s ease,box-shadow .2s ease;cursor:default}.summary-card:hover{transform:translateY(-5px);box-shadow:0 15px 30px #00000014}.summary-card span{display:block;font-size:20px;color:#4b5563;margin-bottom:10px}.summary-card strong{font-size:28px;color:#111827}.dashboard-links{display:flex;justify-content:center;gap:20px;flex-wrap:wrap}.dashboard-link-btn{background-color:#2563eb;color:#fff;padding:14px 26px;border:none;border-radius:12px;font-weight:600;font-size:16px;text-decoration:none;transition:all .3s ease;box-shadow:0 4px 10px #2563eb4d}.dashboard-link-btn:hover{background-color:#1d4ed8;transform:translateY(-2px);box-shadow:0 6px 15px #2563eb66}.loader-container{height:60vh;display:flex;flex-direction:column;align-items:center;justify-content:center}.loader-logo{width:100px;margin-bottom:20px}.loader-bar{width:200px;height:10px;background:#eee;border-radius:5px;overflow:hidden}.loader-fill{width:100%;height:100%;background:linear-gradient(to right,#007bff,#00bcd4);animation:loading 1.5s infinite}@keyframes loading{0%{transform:translate(-100%)}to{transform:translate(100%)}}.workshops-container{min-height:100vh;padding:28px;box-sizing:border-box;background:#f6f7f9;color:#172033;font-family:Segoe UI,sans-serif}.workshops-feedback{position:fixed;top:18px;left:50%;z-index:2000;width:min(620px,calc(100vw - 32px));display:flex;align-items:center;justify-content:space-between;gap:12px;transform:translate(-50%);padding:12px 14px;border-radius:8px;border:1px solid transparent;font-weight:700;box-shadow:0 12px 26px #0f172a1f}.workshops-feedback.success{background:#ecfdf5;border-color:#bbf7d0;color:#166534}.workshops-feedback.error{background:#fef2f2;border-color:#fecaca;color:#991b1b}.workshops-feedback button{border:none;border-radius:6px;background:#ffffffb3;color:inherit;cursor:pointer;font-weight:800;padding:6px 8px}.workshops-hero{display:flex;align-items:flex-start;justify-content:space-between;gap:24px;margin-bottom:18px}.workshops-eyebrow{margin:0 0 6px;color:#64748b;font-size:13px;font-weight:700;letter-spacing:0;text-transform:uppercase}.workshops-hero h1{margin:0;font-size:30px;color:#111827}.workshops-subtitle{max-width:680px;margin:8px 0 0;color:#5b6475;line-height:1.45}.workshops-header-actions{display:flex;justify-content:flex-end;gap:10px;margin-left:auto}.workshops-toolbar,.bulk-bar,.workshops-tabs,.workshop-results-summary{width:100%;box-sizing:border-box}.workshops-toolbar{display:grid;grid-template-columns:minmax(240px,1.6fr) repeat(4,minmax(140px,1fr));gap:10px;margin-bottom:14px}.workshops-search,.workshops-select,.workshops-form input,.workshops-form select,.workshops-form textarea,.edit-panel input,.edit-panel select,.edit-panel textarea{width:100%;box-sizing:border-box;border:1px solid #d3d8e2;border-radius:8px;background:#fff;color:#172033;font-size:14px}.workshops-search,.workshops-select{height:42px;padding:0 12px}.workshops-search:focus,.workshops-select:focus,.workshops-form input:focus,.workshops-form select:focus,.workshops-form textarea:focus,.edit-panel input:focus,.edit-panel select:focus,.edit-panel textarea:focus{border-color:#2563eb;outline:none;box-shadow:0 0 0 3px #2563eb1f}.workshops-tabs{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:14px}.workshops-tabs button,.row-actions button,.bulk-bar button,.pdf-list button,.queued-files button,.workshops-add-btn,.workshops-submit-btn{border:none;border-radius:8px;cursor:pointer;font-weight:700;transition:background-color .18s ease,color .18s ease,border-color .18s ease}.workshops-tabs button{background:#eff6ff;color:#1d4ed8;border:1px solid #bfdbfe;padding:9px 14px}.workshops-tabs button:hover{background:#60a5fa;border-color:#3b82f6;color:#fff}.workshops-tabs button.active{background:#2563eb;border-color:#2563eb;color:#fff}.workshops-tabs button.active:hover{background:#1d4ed8;border-color:#1d4ed8}.workshops-add-btn,.workshops-select-mode-btn,.workshops-submit-btn{background:#2563eb;color:#fff;padding:11px 16px}.workshops-add-btn:hover,.workshops-select-mode-btn:hover,.workshops-submit-btn:hover{background:#1d4ed8}.workshops-select-mode-btn{border:none;border-radius:8px;cursor:pointer;font-weight:700}.workshops-select-mode-btn.active{background:#172033}.workshops-submit-btn.secondary{background:#0f766e}.workshops-submit-btn.secondary:hover{background:#115e59}.workshops-submit-btn.muted{background:#64748b}.workshops-submit-btn:disabled,.bulk-bar button:disabled{background:#cbd5e1;color:#64748b;cursor:not-allowed}.maps-actions{display:flex;flex-wrap:wrap;gap:8px;align-items:center}.maps-actions a{display:inline-flex;align-items:center;justify-content:center;min-height:40px;padding:0 12px;border-radius:8px;background:#f8fafc;border:1px solid #dbe1ea;color:#1d4ed8;font-weight:800;text-decoration:none}.maps-actions a:hover{background:#dbeafe;border-color:#93c5fd}.bulk-bar{display:flex;align-items:center;gap:10px;margin:0 0 16px;padding:10px;border:1px solid #d6dce6;border-radius:8px;background:#fff}.bulk-bar span{margin-right:auto;color:#475569;font-weight:700}.bulk-bar button{background:#eef2ff;color:#1e3a8a;padding:8px 12px}.bulk-bar button:hover:not(:disabled){background:#dbeafe}.bulk-bar.idle span{color:#94a3b8}.workshops-form{display:flex;flex-direction:column;gap:14px;margin:18px 0;padding:18px;border:1px solid #dbe1ea;border-radius:8px;background:#fff}.form-grid,.edit-panel{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:12px}.form-grid-wide{grid-template-columns:minmax(260px,1fr) minmax(260px,1fr)}.workshops-form input,.workshops-form select,.edit-panel input,.edit-panel select{height:40px;padding:0 12px}.workshops-form textarea,.edit-panel textarea{min-height:88px;padding:12px;resize:vertical}.team-checklist,.pdf-picker{padding:12px;border:1px solid #e2e8f0;border-radius:8px;background:#f8fafc}.team-checklist p,.pdf-picker label{display:block;margin:0 0 8px;color:#334155;font-weight:700}.team-checklist label{display:block;margin-bottom:7px;color:#475569;font-size:14px}.team-checklist input{width:auto;height:auto;margin-right:8px}.queued-files,.pdf-list,.plain-list{padding:0;margin:10px 0 0;list-style:none}.queued-files li,.pdf-list li,.plain-list li{display:flex;align-items:center;justify-content:space-between;gap:10px;padding:8px 0;border-bottom:1px solid #e5e7eb;color:#475569}.plain-list span{color:#64748b;font-size:13px}.form-actions{display:flex;flex-wrap:wrap;gap:10px}.workshops-error{padding:14px;border-radius:8px;background:#fff7ed;color:#9a3412}.blankmobil-empty{display:flex;justify-content:center;align-items:center;min-height:460px;padding:28px}.blankmobil-empty-art{display:flex;align-items:center;justify-content:center}.blankmobil-empty-art img{width:min(520px,84vw);max-width:100%;height:auto;display:block}.workshop-results-summary{margin:18px 0 12px;color:#64748b}.workshop-results-summary strong{color:#172033}.date-groups{display:flex;flex-direction:column;gap:24px}.date-group-heading{display:flex;align-items:center;gap:10px;margin-bottom:10px}.date-group-heading h2{margin:0;color:#111827;font-size:18px}.date-group-heading span{min-width:28px;padding:3px 8px;border-radius:999px;background:#e2e8f0;color:#475569;font-size:13px;font-weight:700;text-align:center}.workshops-list{display:grid;grid-template-columns:repeat(auto-fit,minmax(420px,1fr));gap:12px}.workshop-card{overflow:hidden;border:1px solid #dbe1ea;border-radius:8px;background:#fff}.workshop-card.expanded{border-color:#b9c7d8}.workshop-card.selected{border-color:#93c5fd;box-shadow:0 0 0 3px #93c5fd52;background:#f8fbff}.workshop-compact{display:grid;grid-template-columns:auto minmax(0,1fr) auto;gap:12px;align-items:center;padding:14px}.row-select input{width:18px;height:18px}.workshop-main{min-width:0}.workshop-title-row{display:flex;align-items:center;flex-wrap:wrap;gap:8px}.workshop-title-row h3{min-width:0;margin:0;color:#111827;font-size:16px;overflow-wrap:anywhere}.badge{display:inline-flex;align-items:center;min-height:22px;padding:0 8px;border-radius:999px;font-size:12px;font-weight:800;text-transform:capitalize}.badge-draft{background:#fef3c7;color:#92400e}.badge-published{background:#dcfce7;color:#166534}.badge-pending{background:#fef3c7;color:#92400e}.badge-done,.badge-completed{background:#dcfce7;color:#166534}.quick-info{display:flex;flex-wrap:wrap;gap:8px 14px;margin-top:8px;color:#64748b;font-size:13px}.quick-info span{overflow-wrap:anywhere}.row-actions{display:flex;justify-content:flex-end;flex-wrap:wrap;gap:6px}.row-actions button,.pdf-list button,.queued-files button{padding:7px 10px;background:#f1f5f9;color:#334155}.pdf-list button:hover,.queued-files button:hover{background:#e2e8f0}.row-actions .action-view{background:#fef3c7;color:#92400e}.row-actions .action-view:hover{background:#facc15;color:#713f12}.row-actions .action-edit{background:#dbeafe;color:#1e40af}.row-actions .action-edit:hover{background:#93c5fd;color:#1e3a8a}.row-actions .action-approve{background:#dcfce7;color:#166534}.row-actions .action-approve:hover{background:#86efac;color:#14532d}.row-actions .action-delete{background:#b91c1c;color:#fff}.row-actions .action-delete:hover{background:#7f1d1d;color:#fff}.workshop-details{border-top:1px solid #e5e7eb;padding:16px;background:#fbfcfe}.details-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:16px}.details-grid section{min-width:0}.details-grid .details-gallery-action{display:flex;align-items:flex-end;justify-content:flex-end}.details-grid h4{margin:0 0 8px;color:#111827;font-size:14px}.details-grid p{margin:0;color:#475569;line-height:1.45}.details-grid a,.pdf-list a,.open-gallery-btn{color:#2563eb;text-decoration:none;overflow-wrap:anywhere}.details-grid a:hover,.pdf-list a:hover{text-decoration:underline}.open-gallery-btn{display:inline-flex;align-items:center;justify-content:center;min-height:38px;padding:8px 12px;border:1px solid #bfdbfe;border-radius:8px;background:#eff6ff;cursor:pointer;font-weight:800}.open-gallery-btn:hover{border-color:#3b82f6;background:#60a5fa;color:#fff}.workshops-modal-overlay{position:fixed;inset:0;z-index:2100;display:flex;align-items:center;justify-content:center;padding:24px;background:#0f172a80}.workshops-confirm-modal{width:min(460px,100%);padding:22px;border-radius:12px;background:#fff;box-shadow:0 24px 80px #0f172a47}.workshops-confirm-icon{display:grid;place-items:center;width:44px;height:44px;margin-bottom:14px;border-radius:999px;background:#dcfce7;color:#166534;font-size:24px;font-weight:900}.workshops-confirm-eyebrow{margin:0 0 6px;color:#64748b;font-size:12px;font-weight:800;text-transform:uppercase}.workshops-confirm-modal h3{margin:0 0 8px;color:#111827;font-size:20px}.workshops-confirm-modal p{color:#475569;line-height:1.45}.workshops-confirm-actions{display:flex;justify-content:flex-end;gap:10px;margin-top:20px}.workshops-confirm-actions button{min-height:40px;padding:9px 14px;border:none;border-radius:8px;cursor:pointer;font-weight:800}.workshops-confirm-cancel{background:#f1f5f9;color:#334155}.workshops-confirm-cancel:hover{background:#e2e8f0}.workshops-confirm-primary{background:#16a34a;color:#fff}.workshops-confirm-primary:hover{background:#15803d}.workshops-delete-modal{border-top:4px solid #dc2626}.workshops-confirm-danger-icon{background:#fee2e2;color:#991b1b}.workshops-confirm-danger{background:#991b1b;color:#fff}.workshops-confirm-danger:hover{background:#7f1d1d}.edit-panel{grid-template-columns:repeat(2,minmax(0,1fr))}.edit-panel textarea,.edit-panel .team-checklist,.edit-panel .edit-pdf-manager,.edit-panel .form-actions{grid-column:1 / -1}.edit-pdf-manager{padding:12px;border:1px solid #e2e8f0;border-radius:8px;background:#f8fafc}.edit-pdf-manager h4{margin:0 0 8px;color:#111827;font-size:14px}.edit-pdf-manager p{margin:0 0 10px;color:#64748b}.edit-pdf-manager .edit-pdf-delete-btn{background:#fee2e2;color:#991b1b;border:1px solid #fecaca}.edit-pdf-manager .edit-pdf-delete-btn:hover{background:#b91c1c;border-color:#991b1b;color:#fff}.loader-wrapper{display:flex;align-items:center;justify-content:center;min-height:60vh}@media (max-width: 1020px){.workshops-toolbar{grid-template-columns:repeat(2,minmax(0,1fr))}.workshops-search{grid-column:1 / -1}}@media (max-width: 760px){.workshops-container{padding:18px}.workshops-hero,.bulk-bar{flex-direction:column;align-items:stretch}.workshops-header-actions{width:100%;flex-direction:column;margin-left:0}.workshops-add-btn,.workshops-select-mode-btn,.bulk-bar button{width:100%}.workshops-toolbar,.form-grid,.form-grid-wide,.details-grid,.edit-panel,.workshops-list{grid-template-columns:1fr}.workshop-compact{grid-template-columns:auto minmax(0,1fr)}.row-actions{grid-column:1 / -1;justify-content:stretch}.row-actions button{flex:1 1 120px}.blankmobil-empty{min-height:340px;padding:16px}}.users-container{min-height:100vh;padding:28px;background:#f6f7f9;box-sizing:border-box;color:#0f172a}.users-feedback{position:fixed;top:18px;left:50%;z-index:3000;display:flex;align-items:center;gap:14px;min-width:min(420px,calc(100vw - 32px));max-width:calc(100vw - 32px);padding:12px 14px;border-radius:8px;border:1px solid transparent;box-shadow:0 16px 42px #0f172a2e;transform:translate(-50%);font-weight:700}.users-feedback.success{background:#ecfdf5;border-color:#86efac;color:#166534}.users-feedback.error{background:#fef2f2;border-color:#fecaca;color:#991b1b}.users-feedback button{margin-left:auto;border:0;border-radius:7px;background:#ffffffd9;color:inherit;cursor:pointer;font-weight:800;padding:7px 10px}.users-hero{display:flex;align-items:flex-end;justify-content:space-between;gap:18px;margin-bottom:18px}.users-eyebrow{margin:0 0 6px;color:#2563eb;font-size:.78rem;font-weight:800;letter-spacing:0;text-transform:uppercase}.users-hero h1{margin:0;color:#0f172a;font-size:clamp(1.7rem,2vw,2.25rem);line-height:1.1}.users-subtitle{max-width:620px;margin:8px 0 0;color:#64748b;font-size:.96rem;line-height:1.55}.users-add-btn,.users-submit-btn,.edit-save-btn,.edit-cancel-btn,.edit-btn,.delete-btn,.users-confirm-cancel,.users-confirm-danger{min-height:40px;border:1px solid transparent;border-radius:8px;cursor:pointer;font-weight:800;transition:background-color .18s ease,border-color .18s ease,color .18s ease,box-shadow .18s ease}.users-add-btn,.users-submit-btn{background:#2563eb;color:#fff;padding:0 18px;white-space:nowrap}.users-add-btn:hover,.users-submit-btn:hover{background:#1d4ed8;box-shadow:0 10px 24px #2563eb3d}.users-summary-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:12px;margin-bottom:14px}.users-summary-card{display:flex;align-items:center;justify-content:space-between;gap:12px;min-height:78px;padding:16px;border:1px solid #dbe4f0;border-radius:8px;background:#fff;box-shadow:0 8px 22px #0f172a0d}.users-summary-card span{color:#64748b;font-size:.9rem;font-weight:800}.users-summary-card strong{color:#0f172a;font-size:1.65rem}.users-summary-card.all{border-left:4px solid #2563eb}.users-summary-card.manager{border-left:4px solid #7c3aed}.users-summary-card.supervisor{border-left:4px solid #0ea5e9}.users-summary-card.employee{border-left:4px solid #16a34a}.users-toolbar{display:grid;grid-template-columns:minmax(240px,1fr) auto;align-items:center;gap:12px;margin-bottom:14px}.users-search,.users-form input,.users-form select,.edit-input,.edit-select{width:100%;min-height:42px;border:1px solid #cbd5e1;border-radius:8px;background:#fff;color:#0f172a;box-sizing:border-box;font:inherit;padding:0 12px;outline:none;transition:border-color .18s ease,box-shadow .18s ease}.users-search:focus,.users-form input:focus,.users-form select:focus,.edit-input:focus,.edit-select:focus{border-color:#0ea5e9;box-shadow:0 0 0 3px #0ea5e929}.users-role-tabs{display:flex;justify-content:flex-end;gap:8px;flex-wrap:wrap}.users-role-tabs button{min-height:38px;border:1px solid #bfdbfe;border-radius:8px;background:#eff6ff;color:#1d4ed8;cursor:pointer;font-weight:800;padding:0 13px;transition:background-color .18s ease,color .18s ease,border-color .18s ease}.users-role-tabs button:hover{background:#60a5fa;border-color:#60a5fa;color:#fff}.users-role-tabs button.active{background:#2563eb;border-color:#2563eb;color:#fff}.users-form{margin:0 0 16px;padding:16px;border:1px solid #dbe4f0;border-radius:8px;background:#fff;box-shadow:0 8px 22px #0f172a0d}.users-form-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:10px}.users-form-actions{display:flex;justify-content:flex-end;margin-top:12px}.users-error{margin:0 0 14px;padding:11px 13px;border:1px solid #fecaca;border-radius:8px;background:#fef2f2;color:#991b1b;font-weight:700}.users-results-summary{margin:0 0 10px;color:#64748b;font-size:.92rem}.users-results-summary strong{color:#0f172a}.users-list{display:flex;flex-direction:column;gap:10px}.user-card{display:grid;grid-template-columns:46px minmax(0,1fr) auto auto;align-items:center;gap:14px;min-height:74px;padding:14px;border:1px solid #dbe4f0;border-radius:8px;background:#fff;box-shadow:0 7px 18px #0f172a0b;transition:border-color .18s ease,box-shadow .18s ease,transform .18s ease}.user-card:hover{border-color:#93c5fd;box-shadow:0 10px 26px #0f172a14;transform:translateY(-1px)}.user-avatar{display:grid;width:46px;height:46px;place-items:center;border-radius:8px;background:#e0f2fe;color:#0369a1;font-size:1.2rem;font-weight:900}.user-main{min-width:0}.user-main h3{margin:0 0 4px;color:#0f172a;font-size:1rem;line-height:1.2;overflow-wrap:anywhere}.user-main p{margin:0;color:#64748b;font-size:.9rem;overflow-wrap:anywhere}.role-badge{justify-self:start;padding:6px 10px;border-radius:999px;font-size:.78rem;font-weight:900;line-height:1;white-space:nowrap}.role-badge.manager{background:#ede9fe;color:#5b21b6}.role-badge.supervisor{background:#e0f2fe;color:#0369a1}.role-badge.employee{background:#dcfce7;color:#166534}.user-card-actions{display:flex;align-items:center;justify-content:flex-end;gap:8px}.edit-btn,.delete-btn,.edit-save-btn,.edit-cancel-btn{padding:0 12px}.edit-btn{background:#f8fafc;border-color:#cbd5e1;color:#334155}.edit-btn:hover{background:#dbeafe;border-color:#93c5fd;color:#1d4ed8}.delete-btn{background:#fef2f2;border-color:#fecaca;color:#991b1b}.delete-btn:hover{background:#991b1b;border-color:#991b1b;color:#fff}.edit-save-btn{background:#dcfce7;border-color:#86efac;color:#166534}.edit-save-btn:hover{background:#16a34a;border-color:#16a34a;color:#fff}.edit-cancel-btn{background:#f8fafc;border-color:#cbd5e1;color:#475569}.edit-cancel-btn:hover{background:#e2e8f0;color:#0f172a}.user-edit-grid{grid-column:1 / -1;display:grid;grid-template-columns:minmax(160px,1fr) minmax(190px,1.4fr) minmax(140px,.7fr) auto;align-items:center;gap:10px}.pagination{display:flex;flex-wrap:wrap;justify-content:center;gap:8px;margin-top:20px}.pagination button{min-width:38px;min-height:38px;border:1px solid #cbd5e1;border-radius:8px;background:#fff;color:#334155;cursor:pointer;font-weight:800;padding:0 12px;transition:background-color .18s ease,border-color .18s ease,color .18s ease}.pagination button:not(:disabled):hover{background:#e0f2fe;border-color:#0ea5e9;color:#0369a1}.pagination button.active{background:#2563eb;border-color:#2563eb;color:#fff}.pagination button:disabled{cursor:not-allowed;opacity:.5}.users-empty-state{display:grid;min-height:420px;place-items:center}.users-empty-state img{width:min(520px,88vw);max-height:460px;object-fit:contain}.users-modal-overlay{position:fixed;inset:0;z-index:2500;display:grid;place-items:center;padding:18px;background:#0f172a6b}.users-confirm-modal{width:min(420px,100%);padding:22px;border-radius:8px;background:#fff;box-shadow:0 24px 70px #0f172a47;text-align:center}.users-confirm-icon{display:grid;width:44px;height:44px;margin:0 auto 12px;place-items:center;border-radius:999px;background:#fee2e2;color:#991b1b;font-size:1.3rem;font-weight:900}.users-confirm-eyebrow{margin:0 0 4px;color:#991b1b;font-size:.78rem;font-weight:900;letter-spacing:0;text-transform:uppercase}.users-confirm-modal h3{margin:0 0 8px;color:#0f172a;font-size:1.25rem}.users-confirm-modal p{margin:0;color:#64748b;line-height:1.5}.users-confirm-actions{display:flex;justify-content:center;gap:10px;margin-top:20px}.users-confirm-cancel,.users-confirm-danger{min-width:112px;padding:0 14px}.users-confirm-cancel{background:#fff;border-color:#cbd5e1;color:#334155}.users-confirm-cancel:hover{background:#f1f5f9}.users-confirm-danger{background:#991b1b;border-color:#991b1b;color:#fff}.users-confirm-danger:hover{background:#7f1d1d;border-color:#7f1d1d}@media (max-width: 980px){.users-summary-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.users-toolbar{grid-template-columns:1fr}.users-role-tabs{justify-content:flex-start}.users-form-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.user-card{grid-template-columns:46px minmax(0,1fr)}.role-badge,.user-card-actions{grid-column:2}.user-card-actions{justify-content:flex-start}.user-edit-grid{grid-template-columns:1fr 1fr}.user-edit-grid .user-card-actions{grid-column:1 / -1}}@media (max-width: 640px){.users-container{padding:18px 14px}.users-hero{align-items:stretch;flex-direction:column}.users-add-btn,.users-submit-btn{width:100%}.users-summary-grid,.users-form-grid,.user-edit-grid{grid-template-columns:1fr}.users-role-tabs{display:grid;grid-template-columns:repeat(2,minmax(0,1fr))}.users-role-tabs button{padding:0 8px}.user-card{grid-template-columns:40px minmax(0,1fr);gap:11px;padding:12px}.user-avatar{width:40px;height:40px}.role-badge{grid-column:1 / -1}.user-card-actions{grid-column:1 / -1;width:100%}.user-card-actions button{flex:1}.users-confirm-actions{flex-direction:column-reverse}.users-confirm-cancel,.users-confirm-danger{width:100%}}.header{display:flex;justify-content:space-between;align-items:center;background-color:#1e3a8a;color:#fff;padding:16px 32px;box-shadow:0 2px 10px #0000001a;position:sticky;top:0;z-index:100;border-radius:12px}.header-left{display:flex;align-items:center;gap:12px}.logo-wrapper{background-color:#fff;border-radius:20%;padding:12px;display:flex;align-items:center;justify-content:center;box-shadow:0 0 8px #0000001a;cursor:pointer}.logo-img{height:50px;width:50px;object-fit:contain}.logo-text{font-size:22px;font-weight:700;color:#fff;cursor:pointer}.header-right{display:flex;align-items:center;gap:12px;position:relative}.lang-switcher button{background:none;border:none;cursor:pointer;font-size:20px}.logout-btn,.login-btn{padding:8px 16px;border-radius:6px;font-weight:500;cursor:pointer;border:none;transition:all .2s ease}.logout-btn{background-color:#ef4444;color:#fff}.logout-btn:hover{background-color:#dc2626}.login-btn{background-color:#22c55e;color:#fff;text-decoration:none}.login-btn:hover{background-color:#16a34a}.user-name{font-weight:500;color:#fff}.divider{height:24px;width:2px;background-color:#fff;border-radius:10px;margin:0 8px}.header-nav{display:flex;gap:24px}.nav-link{color:#fff;text-decoration:none;font-weight:500;transition:color .2s ease}.nav-link:hover{color:#93c5fd}.hamburger-btn{display:none;flex-direction:column;justify-content:space-between;width:28px;height:22px;background:none;border:none;cursor:pointer;padding:0;position:relative;z-index:110}.hamburger-btn span{display:block;height:3px;width:100%;background-color:#fff;border-radius:2px;transition:all .3s ease}.hamburger-btn.active span:nth-child(1){transform:rotate(45deg) translate(5px,5px)}.hamburger-btn.active span:nth-child(2){opacity:0}.hamburger-btn.active span:nth-child(3){transform:rotate(-45deg) translate(6px,-6px)}@media (max-width: 768px){.header{flex-wrap:wrap;padding:16px 20px}.header-nav{position:absolute;top:100%;right:16px;background-color:#1e3a8a;flex-direction:column;align-items:flex-end;gap:12px;padding:16px;border-radius:8px;max-height:0;overflow:hidden;transition:max-height .3s ease,opacity .3s ease;opacity:0;z-index:105}.header-nav.open{max-height:500px;opacity:1}.hamburger-btn{display:flex;margin-left:auto}}.footer{background-color:#1e3a8a;color:#fff;padding:20px 40px;text-align:center;box-shadow:0 -2px 10px #0000001a;font-size:14px;border-radius:12px}.footer-content{max-width:1200px;margin:0 auto}.footer-nav{margin-top:8px;display:flex;justify-content:center;gap:24px}.footer-link{color:#93c5fd;text-decoration:none;transition:color .2s ease;font-weight:500}.footer-link:hover{color:#bfdbfe}@media (max-width: 600px){.footer{padding:16px 20px}.footer-nav{flex-direction:column;gap:12px}}.weekly-plan-container{max-width:500px;margin:40px auto;padding:20px;border:2px solid #ddd;border-radius:12px;text-align:center;font-family:sans-serif}.drop-zone{border:2px dashed #999;padding:40px;border-radius:10px;background-color:#f9f9f9;margin-bottom:15px;cursor:pointer;transition:background-color .3s}.drop-zone:hover{background-color:#f0f0f0}.drop-zone.disabled{cursor:not-allowed;opacity:.65}.buttons{display:flex;justify-content:center;gap:15px;margin-top:10px}.weekly-plan-container button{padding:8px 16px;border:none;background-color:#007bff;color:#fff;border-radius:8px;cursor:pointer;transition:background-color .25s}.weekly-plan-container button:disabled{background-color:#ccc;cursor:not-allowed}.weekly-plan-container button:hover:not(:disabled){background-color:#0056b3}.status-msg{padding:10px;margin:10px 0;font-weight:700;border-radius:8px;animation:fadeIn .4s ease-in-out}.status-msg.success{background-color:#e6ffe6;color:#037a00}.status-msg.error{background-color:#ffe6e6;color:#b00000}.weekly-loading{display:inline-flex;align-items:center;gap:8px;margin:8px 0 16px;padding:10px 14px;border-radius:999px;color:#075985;background:#e0f2fe;font-weight:700}.weekly-spinner{width:16px;height:16px;border:2px solid rgba(2,132,199,.25);border-top-color:#0284c7;border-radius:999px;animation:weekly-spin .75s linear infinite}.pdf-indicator{margin-top:12px;padding:10px;background-color:#e6fff2;border:1px solid #66cc99;color:#2e7d5a;border-radius:6px;font-weight:700}@keyframes fadeIn{0%{opacity:0;transform:translateY(-5px)}to{opacity:1;transform:translateY(0)}}@keyframes weekly-spin{to{transform:rotate(360deg)}}.error-page{text-align:center;padding:4rem 2rem;font-family:sans-serif;color:#333}.error-page h1{font-size:2.5rem;color:#d32f2f}.error-page p{font-size:1.2rem;margin:1rem 0}.error-page a{color:#1976d2;text-decoration:none;font-weight:700}.error-image{width:150px;height:auto;margin-bottom:1.5rem}.notes-container{max-width:600px;margin:auto;padding:20px}h2{text-align:center;margin-bottom:20px}.note-textarea{width:100%;font-size:16px;padding:10px;border-radius:6px;border:1px solid #ccc;resize:vertical;min-height:200px;box-sizing:border-box}.note-textarea:disabled{background:#f8fafc;cursor:wait}.note-button{margin-top:15px;padding:10px 20px;font-size:16px;background-color:#1e88e5;color:#fff;border:none;border-radius:6px;cursor:pointer;transition:background-color .3s ease}.note-button:hover{background-color:#1565c0}.note-button:disabled{background-color:#90caf9;cursor:not-allowed}.feedback-box{padding:12px 16px;border-radius:8px;margin-bottom:20px;font-size:16px;text-align:center}.feedback-box.success{background-color:#d4edda;color:#155724;border:1px solid #c3e6cb}.feedback-box.error{background-color:#f8d7da;color:#721c24;border:1px solid #f5c6cb}.note-loading{display:inline-flex;align-items:center;gap:8px;margin-bottom:16px;padding:10px 14px;border-radius:999px;color:#075985;background:#e0f2fe;font-weight:700}.note-spinner{width:16px;height:16px;border:2px solid rgba(2,132,199,.25);border-top-color:#0284c7;border-radius:999px;animation:note-spin .75s linear infinite}@keyframes note-spin{to{transform:rotate(360deg)}}.gallery-container{min-height:calc(100vh - 120px);padding:24px;background:#f6f8fb;color:#172033}.gallery-page-header{margin-bottom:18px}.gallery-page-header h2{margin:0;font-size:28px;font-weight:800}.gallery-layout{display:grid;grid-template-columns:minmax(280px,360px) minmax(0,1fr);gap:18px;align-items:start;min-width:0}.gallery-sidebar,.gallery-detail-panel{border:1px solid #dbe3ee;border-radius:8px;background:#fff;box-shadow:0 8px 22px #1f2d3d0f}.gallery-sidebar{position:sticky;top:16px;min-width:0;max-height:calc(100vh - 120px);padding:16px;overflow:hidden}.gallery-detail-panel{min-height:560px;padding:20px}.gallery-sidebar-header,.gallery-selected-header{display:flex;align-items:flex-start;justify-content:space-between;gap:16px}.gallery-sidebar-header{margin-bottom:14px}.gallery-selected-header{padding-bottom:16px;border-bottom:1px solid #e7edf5}.gallery-eyebrow{margin:0 0 4px;color:#64748b;font-size:12px;font-weight:800;letter-spacing:.06em;text-transform:uppercase}.gallery-sidebar-header h3,.gallery-selected-header h3{margin:0;font-size:20px}.gallery-selected-date{margin:6px 0 0;color:#64748b;font-size:14px}.gallery-count-badge{display:inline-flex;align-items:center;justify-content:center;min-width:34px;height:34px;padding:0 10px;border-radius:999px;color:#075985;background:#e0f2fe;font-weight:800}.gallery-search{box-sizing:border-box;display:block;width:100%;max-width:100%;min-height:42px;padding:10px 16px;margin-bottom:14px;border:1px solid #d8e1ed;border-radius:999px;font-size:15px;outline:none}.gallery-search:focus{border-color:#38bdf8;box-shadow:0 0 0 3px #38bdf82e}.workshop-list{display:flex;max-height:calc(100vh - 245px);flex-direction:column;gap:10px;overflow-y:auto;padding-right:4px}.workshop-item{width:100%;padding:12px;border:1px solid #e3e9f2;border-radius:8px;color:inherit;background:#fff;cursor:pointer;text-align:left;transition:border-color .16s ease,background .16s ease,box-shadow .16s ease}.workshop-item:hover,.workshop-item:focus-visible,.workshop-item.hovered,.workshop-item.active{border-color:#0ea5e9;background:#e0f2fe;box-shadow:inset 0 0 0 1px #0ea5e938;outline:none}.workshop-card-topline{display:flex;align-items:flex-start;justify-content:space-between;gap:10px}.workshop-card-title{min-width:0;font-size:15px;font-weight:800;line-height:1.35}.workshop-card-date,.workshop-card-team{display:block;margin-top:7px;color:#64748b;font-size:13px}.workshop-card-meta{display:flex;flex-wrap:wrap;gap:6px;margin-top:10px}.workshop-card-meta span{padding:4px 8px;border-radius:999px;color:#334155;background:#f1f5f9;font-size:12px;font-weight:700}.gallery-status-badge{flex:0 0 auto;padding:4px 8px;border-radius:999px;font-size:12px;font-weight:800}.gallery-status-badge.pending{color:#92400e;background:#fef3c7}.gallery-status-badge.done{color:#166534;background:#dcfce7}.gallery-summary-grid{display:grid;grid-template-columns:repeat(5,minmax(110px,1fr));gap:10px;margin:16px 0 22px}.gallery-summary-item{padding:12px;border:1px solid #e3e9f2;border-radius:8px;background:#f8fafc}.gallery-summary-item span{display:block;margin-bottom:6px;color:#64748b;font-size:12px;font-weight:800;text-transform:uppercase}.gallery-summary-item strong{font-size:20px}.images-section h3{margin:22px 0 10px;font-size:18px}.images-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:12px}.gallery-media-tile{position:relative;width:100%;aspect-ratio:1;padding:0;border:none;border-radius:8px;cursor:pointer;overflow:hidden;background:#111827;box-shadow:0 2px 6px #00000029}.gallery-media{display:block;width:100%;height:100%;object-fit:cover;background:#111827}.gallery-video-tile .gallery-media{object-fit:contain}.gallery-play-badge{position:absolute;inset:0;display:grid;place-items:center;color:#fff;font-size:42px;line-height:1;text-shadow:0 2px 10px rgba(0,0,0,.55);background:#1118272e}.gallery-download-btn{flex:0 0 auto;display:inline-flex;align-items:center;justify-content:center;gap:8px;min-height:40px;padding:10px 14px;border:none;border-radius:8px;color:#fff;background:#0284c7;cursor:pointer;font-weight:800}.gallery-selected-actions{display:flex;flex:0 0 auto;flex-wrap:wrap;justify-content:flex-end;gap:10px}.gallery-clear-selection-btn{min-height:40px;padding:10px 14px;border:1px solid #cbd5e1;border-radius:8px;color:#334155;background:#fff;cursor:pointer;font-weight:800}.gallery-clear-selection-btn:hover{border-color:#3b82f6;background:#60a5fa;color:#fff}.gallery-download-btn:hover{background:#0369a1}.gallery-download-btn:disabled{background:#94a3b8;cursor:not-allowed}.gallery-btn-spinner{width:16px;height:16px;border:2px solid rgba(255,255,255,.45);border-top-color:#fff;border-radius:999px;animation:gallery-spin .75s linear infinite}.gallery-download-feedback{margin-top:12px;padding:10px 12px;border-radius:8px;font-size:14px;font-weight:700}.gallery-download-feedback.success{color:#166534;background:#dcfce7}.gallery-download-feedback.error{color:#991b1b;background:#fee2e2}@keyframes gallery-spin{to{transform:rotate(360deg)}}.gallery-empty,.gallery-empty-state,.gallery-empty-selection{color:#64748b}.gallery-empty{margin:0;padding:18px;border:1px dashed #cbd5e1;border-radius:8px;background:#f8fafc}.gallery-empty-state{padding:24px 12px;text-align:center}.gallery-empty-state.error{color:#991b1b}.gallery-list-loading{display:flex;align-items:center;justify-content:center;gap:8px;min-height:120px;color:#075985;font-weight:700}.gallery-list-spinner{width:18px;height:18px;border:2px solid rgba(2,132,199,.25);border-top-color:#0284c7;border-radius:999px;animation:gallery-spin .75s linear infinite}.gallery-empty-selection{display:grid;min-height:420px;place-content:center;text-align:center}.gallery-empty-selection-image{display:block;width:min(620px,82%);max-width:100%;margin:0 auto}.gallery-preview-overlay{position:fixed;inset:0;z-index:1000;display:flex;align-items:center;justify-content:center;padding:24px;background:#0f172ac2}.gallery-preview-panel{position:relative;max-width:min(1100px,94vw);max-height:90vh;border-radius:8px;background:#0f172a;box-shadow:0 24px 80px #0006;overflow:hidden}.gallery-preview-media{display:block;max-width:min(1100px,94vw);max-height:90vh;object-fit:contain;background:#0f172a}.gallery-preview-close{position:absolute;top:10px;right:10px;z-index:2;display:grid;place-items:center;width:36px;height:36px;padding:0;border:none;border-radius:999px;color:#111827;background:#ffffffe6;font-size:24px;line-height:1;cursor:pointer}@media (max-width: 980px){.gallery-layout{grid-template-columns:1fr}.gallery-sidebar{position:static;max-height:none}.workshop-list{max-height:430px}.gallery-summary-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}@media (max-width: 640px){.gallery-container{padding:16px}.gallery-selected-header{flex-direction:column}.gallery-download-btn,.gallery-selected-actions{width:100%}.gallery-clear-selection-btn{flex:1 1 150px}.images-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}.toast{position:fixed;top:20px;right:20px;background-color:#ef4444;color:#fff;padding:12px 20px;border-radius:8px;box-shadow:0 4px 12px #0003;font-weight:500;z-index:200;animation:slide-in .3s ease}@keyframes slide-in{0%{transform:translateY(-20px);opacity:0}to{transform:translateY(0);opacity:1}}
