:root{--color-primary: #00a651;--color-primary-light: #00c965;--color-accent: #00a651;--color-accent-light: #00c965;--color-background: #fafaf9;--color-surface: #ffffff;--color-text: #0a0a0a;--color-text-light: #2d2d2d;--color-text-heading: #000000;--color-white: #ffffff;--color-border: #e7e5e4;--font-sans: "Inter", system-ui, -apple-system, sans-serif;--font-serif: "Playfair Display", serif;--spacing-xs: .25rem;--spacing-sm: .5rem;--spacing-md: 1rem;--spacing-lg: 1.5rem;--spacing-xl: 2rem;--spacing-2xl: 3rem;--shadow-sm: 0 1px 2px 0 rgb(0 0 0 / .05);--shadow-md: 0 4px 6px -1px rgb(0 0 0 / .1), 0 2px 4px -2px rgb(0 0 0 / .1);--shadow-lg: 0 10px 15px -3px rgb(0 0 0 / .1), 0 4px 6px -4px rgb(0 0 0 / .1);--transition-base: all .2s ease-in-out}*{box-sizing:border-box;margin:0;padding:0}body{font-family:var(--font-sans);background-color:var(--color-background);color:var(--color-text);line-height:1.6;-webkit-font-smoothing:antialiased;font-weight:500}h1,h2,h3,h4,h5,h6{color:var(--color-text-heading);font-weight:700;line-height:1.2;margin-bottom:var(--spacing-md)}h1{font-size:2.5rem}h2{font-size:2rem}h3{font-size:1.75rem}a{color:var(--color-primary);text-decoration:none;transition:var(--transition-base)}a:hover{color:var(--color-accent)}button{cursor:pointer;font-family:inherit}.container{max-width:1200px;margin:0 auto;padding:0 var(--spacing-md)}.btn{display:inline-flex;align-items:center;justify-content:center;padding:.75rem 1.5rem;border-radius:.5rem;font-weight:600;transition:var(--transition-base);border:none}.btn-primary{background-color:var(--color-primary);color:var(--color-white)}.btn-primary:hover{background-color:var(--color-primary-light);transform:translateY(-1px)}.btn-accent{background-color:var(--color-accent);color:var(--color-white)}.btn-accent:hover{background-color:var(--color-accent-light);transform:translateY(-1px)}.text-center{text-align:center}.flex{display:flex}.items-center{align-items:center}.justify-between{justify-content:space-between}.gap-md{gap:var(--spacing-md)}.header{background:linear-gradient(135deg,var(--color-primary) 0%,var(--color-primary-light) 100%);box-shadow:0 4px 20px #0000004d;position:sticky;top:0;z-index:100;padding:1rem 0;width:100%;animation:slideDown .5s ease-out}@keyframes slideDown{0%{transform:translateY(-100%);opacity:0}to{transform:translateY(0);opacity:1}}.header-container{max-width:1400px;margin:0 auto;padding:0 1rem;display:flex;align-items:center;gap:1.5rem}.sidebar-toggle{display:flex;flex-direction:column;gap:4px;background:none;border:none;cursor:pointer;padding:.5rem}.sidebar-toggle span{width:25px;height:3px;background-color:var(--color-white);border-radius:2px;transition:var(--transition-base)}.sidebar-toggle:hover span{background-color:var(--color-white)}.logo{display:flex;align-items:center;gap:.5rem;font-size:1.5rem;font-weight:700;color:var(--color-white);text-decoration:none;z-index:101;transition:transform .3s ease;animation:fadeIn .8s ease-out}.logo:hover{transform:scale(1.05)}@keyframes fadeIn{0%{opacity:0;transform:translate(-20px)}to{opacity:1;transform:translate(0)}}.logo-badge{background-color:var(--color-white);color:var(--color-primary);padding:.25rem .75rem;border-radius:4px;font-weight:800;animation:pulse 2s ease-in-out infinite}@keyframes pulse{0%,to{transform:scale(1)}50%{transform:scale(1.05)}}.logo-text{color:var(--color-white)}.search-bar{display:flex;align-items:center;background-color:var(--color-white);border-radius:.5rem;overflow:hidden;flex:1;max-width:500px;transition:all .3s ease;animation:fadeIn .8s ease-out .2s both}.search-bar:focus-within{transform:scale(1.02);box-shadow:0 4px 12px #fff3}.search-bar input{flex:1;padding:.7rem 1rem;border:none;outline:none;font-size:.95rem;color:var(--color-text);transition:all .3s ease}.search-bar button{padding:.7rem 1rem;background-color:var(--color-white);color:var(--color-primary);border:none;cursor:pointer;font-size:1.2rem;transition:all .3s ease}.search-bar button:hover{background-color:var(--color-primary);color:var(--color-white);transform:scale(1.05)}.auth-buttons{display:flex;gap:1rem;align-items:center}.btn{display:inline-flex;align-items:center;justify-content:center;padding:.7rem 1.5rem;border-radius:.5rem;font-weight:600;transition:all .3s ease;border:none;text-decoration:none;font-size:.95rem;position:relative;overflow:hidden}.btn:before{content:"";position:absolute;top:50%;left:50%;width:0;height:0;border-radius:50%;background:#ffffff4d;transform:translate(-50%,-50%);transition:width .6s,height .6s}.btn:hover:before{width:300px;height:300px}.btn-outline{color:var(--color-white);border:2px solid var(--color-white);background:transparent}.btn-outline:hover{background-color:var(--color-white);color:var(--color-primary);transform:translateY(-2px);box-shadow:0 4px 12px #ffffff4d}.btn-primary{background-color:var(--color-accent);color:var(--color-white);font-weight:700}.btn-primary:hover{background-color:var(--color-accent-light);transform:translateY(-3px);box-shadow:0 6px 20px #0006}.sidebar{position:fixed;top:0;left:0;width:280px;height:100vh;background:linear-gradient(135deg,var(--color-primary) 0%,var(--color-primary-light) 100%);box-shadow:2px 0 10px #0000001a;transform:translate(-100%);transition:transform .3s ease;z-index:200;display:flex;flex-direction:column}.sidebar-open{transform:translate(0)}.sidebar-header{display:flex;justify-content:space-between;align-items:center;padding:1.5rem;background-color:#ffffff1a;color:var(--color-white);border-bottom:2px solid rgba(255,255,255,.2)}.sidebar-header h3{margin:0;font-size:1.5rem;color:var(--color-white)}.sidebar-close{background:none;border:none;color:var(--color-white);font-size:2rem;cursor:pointer;padding:0;width:40px;height:40px;display:flex;align-items:center;justify-content:center;border-radius:50%;transition:var(--transition-base)}.sidebar-close:hover{background-color:#fff3}.sidebar-nav{flex:1;padding:1rem 0;overflow-y:auto}.sidebar-nav a{display:flex;align-items:center;gap:1rem;padding:1rem 1.5rem;color:var(--color-white);text-decoration:none;font-weight:500;transition:var(--transition-base);border-left:3px solid transparent}.sidebar-nav a:hover{background-color:#ffffff26;border-left-color:var(--color-white);color:var(--color-white)}.nav-icon{width:24px;height:24px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.nav-icon svg{width:100%;height:100%;transition:var(--transition-base)}.sidebar-nav a:nth-child(1) .nav-icon svg{stroke:#fff}.sidebar-nav a:nth-child(2) .nav-icon svg{stroke:#fff}.sidebar-nav a:nth-child(3) .nav-icon svg{stroke:#fff}.sidebar-nav a:nth-child(4) .nav-icon svg{fill:#fff}.sidebar-nav a:nth-child(5) .nav-icon svg{stroke:#fff}.sidebar-nav a:hover .nav-icon svg{transform:scale(1.1);filter:brightness(1.2)}.sidebar-overlay{position:fixed;top:0;left:0;width:100%;height:100%;background-color:#00000080;z-index:150;animation:fadeIn .3s ease}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@media(max-width:768px){.search-bar{max-width:200px}.auth-buttons{display:none}}@media(max-width:480px){.logo{font-size:1.25rem}.search-bar{display:none}.sidebar{width:85%;max-width:300px}}.home{width:100%}.hero{background:linear-gradient(135deg,#00a651d9,#00c965d9),url(/image.webp) center 20% / 110% auto no-repeat;color:var(--color-white);padding:5rem 1rem;text-align:center;position:relative}.hero-title{font-size:3rem;margin-bottom:1.5rem;color:var(--color-white);line-height:1.2;font-weight:800;text-shadow:2px 2px 8px rgba(0,0,0,.3)}.hero-accent{color:var(--color-white);font-weight:900;text-shadow:3px 3px 10px rgba(0,0,0,.5)}.hero-description{font-size:1.15rem;max-width:800px;margin:0 auto 2.5rem;color:#fffffff2;line-height:1.7}.hero-buttons{display:flex;gap:1rem;justify-content:center;flex-wrap:wrap}.btn-large{font-size:1.1rem;padding:1rem 2.5rem}.btn-accent{background-color:var(--color-accent);color:var(--color-white);font-weight:700}.btn-accent:hover{background-color:var(--color-accent-light);transform:translateY(-2px);box-shadow:0 6px 20px #d9770666}.btn-outline-white{background:transparent;border:2px solid var(--color-white);color:var(--color-white)}.btn-outline-white:hover{background-color:var(--color-white);color:var(--color-primary)}.mission{padding:5rem 1rem;background-color:var(--color-background)}.mission-grid{display:grid;grid-template-columns:1fr 1fr;gap:4rem;align-items:center}.mission-content h2{color:var(--color-primary);margin-bottom:1.5rem;font-size:2.5rem}.mission-content p{margin-bottom:1.5rem;font-size:1.1rem;line-height:1.8;color:var(--color-text)}.link-accent{color:var(--color-accent);font-weight:700;display:inline-flex;align-items:center;gap:.5rem;font-size:1.1rem}.link-accent:hover{color:var(--color-accent-light)}.mission-image{width:100%}.mission-img{width:100%;height:400px;object-fit:cover;border-radius:1rem;box-shadow:var(--shadow-lg)}.stats{background:linear-gradient(135deg,var(--color-primary) 0%,var(--color-primary-light) 100%);color:var(--color-white);padding:4rem 1rem}.stats-title{text-align:center;font-size:2rem;color:var(--color-white);margin-bottom:3rem}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:2rem;text-align:center}.stat-card{padding:1.5rem;background:#ffffff1a;border-radius:1rem;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.2);transition:var(--transition-base)}.stat-card:hover{transform:translateY(-5px);background:#ffffff26}.stat-number{font-size:3rem;font-weight:700;color:var(--color-accent);margin-bottom:.5rem;animation:pulse 2s ease-in-out infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.8}}.stat-label{font-size:1.1rem;color:#000;font-weight:700;margin-bottom:.5rem;line-height:1.3;max-width:100%;word-wrap:break-word}.stat-live{font-size:.85rem;color:var(--color-accent);font-weight:600;animation:blink 2s ease-in-out infinite}@keyframes blink{0%,to{opacity:1}50%{opacity:.5}}.services{padding:5rem 1rem;background-color:var(--color-white)}.section-title{text-align:center;font-size:2.5rem;color:var(--color-primary);margin-bottom:3rem}.services-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:2rem}.service-card{background-color:var(--color-background);padding:2rem;border-radius:1rem;text-align:center;transition:var(--transition-base);border:2px solid transparent}.service-card:hover{transform:translateY(-5px);box-shadow:var(--shadow-lg);border-color:var(--color-accent)}.service-icon{font-size:3rem;margin-bottom:1rem}.service-card h3{color:var(--color-primary);margin-bottom:1rem;font-size:1.5rem}.service-card p{color:var(--color-text);line-height:1.6}.partners{padding:5rem 1rem;background-color:var(--color-background)}.partners-subtitle{text-align:center;font-size:1.1rem;color:var(--color-text-light);max-width:600px;margin:-1.5rem auto 3rem}.partners-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:2rem}.partner-card{background-color:var(--color-white);padding:2rem;border-radius:1rem;text-align:center;transition:var(--transition-base);border:2px solid var(--color-border);display:flex;flex-direction:column;align-items:center}.partner-card:hover{transform:translateY(-8px);box-shadow:var(--shadow-lg);border-color:var(--color-accent)}.partner-logo{width:80px;height:80px;background:linear-gradient(135deg,var(--color-accent) 0%,var(--color-accent-light) 100%);border-radius:50%;display:flex;align-items:center;justify-content:center;margin-bottom:1.5rem;transition:var(--transition-base)}.partner-card:hover .partner-logo{transform:scale(1.1) rotate(5deg)}.partner-initial{font-size:2rem;font-weight:700;color:var(--color-white)}.partner-name{color:var(--color-primary);margin-bottom:.75rem;font-size:1.25rem}.partner-description{color:var(--color-text-light);font-size:.95rem;line-height:1.6}@media(max-width:768px){.hero{padding:3rem 1rem}.hero-title{font-size:2rem}.hero-description{font-size:1rem}.btn-large{font-size:1rem;padding:.875rem 1.75rem}.mission{padding:3rem 1rem}.mission-grid{grid-template-columns:1fr;gap:2rem}.mission-content h2{font-size:2rem}.mission-content p{font-size:1rem}.mission-img{height:250px}.stats{padding:3rem 1rem}.stats-title{font-size:1.5rem}.stats-grid{grid-template-columns:repeat(2,1fr);gap:1.5rem}.stat-number{font-size:2.5rem}.stat-label{font-size:.95rem}.services{padding:3rem 1rem}.section-title{font-size:2rem}.services-grid{grid-template-columns:1fr;gap:1.5rem}}@media(max-width:480px){.hero-title{font-size:1.75rem}.stats-grid{grid-template-columns:1fr}}.formations-container{padding:4rem 0}.formations-header{text-align:center;margin-bottom:3rem}.formations-header h1{margin-bottom:1rem;font-size:2.5rem;color:var(--color-text)}.formations-header p{color:var(--color-text-light);max-width:600px;margin:0 auto;font-size:1.1rem}.formations-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:2rem}.formation-card{background-color:var(--color-white);border-radius:1rem;overflow:hidden;box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f;transition:all .3s ease;display:flex;flex-direction:column;border:1px solid rgba(0,0,0,.05)}.formation-card:hover{transform:translateY(-5px);box-shadow:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a}.formation-image-wrapper{position:relative;height:200px;overflow:hidden;cursor:pointer}.formation-image-cover{width:100%;height:100%;object-fit:cover;transition:transform .5s ease}.formation-card:hover .formation-image-cover{transform:scale(1.05)}.formation-status-badge{position:absolute;top:1rem;right:1rem;padding:.4rem 1rem;border-radius:2rem;font-size:.85rem;font-weight:600;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);box-shadow:0 2px 4px #0000001a}.status-disponible{background-color:#dcfce7e6;color:#166534}.status-bientot{background-color:#fef9c3e6;color:#854d0e}.status-complet{background-color:#fee2e2e6;color:#991b1b}.formation-content{padding:1.5rem;display:flex;flex-direction:column;flex:1}.formation-main-info{cursor:pointer}.formation-title{font-size:1.25rem;font-weight:700;color:var(--color-text);margin:0 0 .5rem}.formation-description{color:var(--color-text-light);font-size:.95rem;line-height:1.5;margin:0 0 1.5rem}.formation-footer{margin-top:auto;display:flex;gap:1rem;padding-top:1.5rem;border-top:1px solid var(--color-border)}.btn-expand{flex:1;padding:.6rem;background-color:transparent;border:1px solid var(--color-border);color:var(--color-text);border-radius:.5rem;font-weight:500;cursor:pointer;transition:all .2s}.btn-expand:hover{background-color:var(--color-background);border-color:var(--color-text-light)}.btn-register{flex:1;padding:.6rem;background-color:var(--color-primary);color:#fff;border:none;border-radius:.5rem;font-weight:600;cursor:pointer;transition:all .2s}.btn-register:hover:not(:disabled){background-color:var(--color-primary-dark);transform:translateY(-1px)}.btn-register:disabled{background-color:#e5e7eb;color:#9ca3af;cursor:not-allowed}.modal-overlay{position:fixed;inset:0;background-color:#000000b3;display:flex;align-items:center;justify-content:center;z-index:1000;padding:1rem}.modal-content{background-color:var(--color-white);border-radius:1rem;max-width:600px;width:100%;max-height:90vh;overflow-y:auto;box-shadow:0 20px 60px #0000004d}.modal-header{padding:1.5rem 2rem;border-bottom:1px solid var(--color-border);display:flex;justify-content:space-between;align-items:center;background-color:var(--color-primary);color:var(--color-white);border-radius:1rem 1rem 0 0}.modal-header h2{margin:0;font-size:1.5rem}.modal-close{background:none;border:none;font-size:2rem;color:var(--color-white);cursor:pointer;padding:0;width:40px;height:40px;display:flex;align-items:center;justify-content:center;border-radius:50%;transition:var(--transition-base)}.modal-close:hover{background-color:#fff3}.modal-body{padding:2rem}.formation-info-modal{background-color:#00a6510d;padding:1.5rem;border-radius:.75rem;margin-bottom:2rem;border:1px solid rgba(0,166,81,.2)}.formation-info-modal h3{margin:0 0 .5rem;color:var(--color-primary)}.formation-info-modal p{margin:0;color:var(--color-text)}.enrollment-form{display:flex;flex-direction:column;gap:1.5rem}.enrollment-form .form-group{display:flex;flex-direction:column;gap:.5rem}.enrollment-form label{font-weight:600;color:var(--color-text)}.enrollment-form input,.enrollment-form textarea{padding:.75rem;border:1px solid var(--color-border);border-radius:.5rem;font-size:1rem;font-family:inherit;transition:var(--transition-base)}.enrollment-form input:focus,.enrollment-form textarea:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px #00a6511a}.enrollment-form textarea{resize:vertical}.modal-actions{display:flex;gap:1rem;justify-content:flex-end;margin-top:1rem}.btn-secondary{background-color:var(--color-border);color:var(--color-text)}.btn-secondary:hover{background-color:var(--color-text-light);color:var(--color-white)}@media(max-width:768px){.formations-grid{grid-template-columns:1fr}.formation-footer{flex-direction:column;align-items:stretch}.btn-register{width:100%}}.dons-page{padding:3rem 0;min-height:calc(100vh - 200px);background-color:var(--color-background)}.dons-header{text-align:center;margin-bottom:3rem}.dons-header h1{color:var(--color-primary);margin-bottom:.5rem;font-size:2.5rem}.dons-subtitle{color:var(--color-text-light);font-size:1.1rem;max-width:600px;margin:0 auto}.dons-container{max-width:700px;margin:0 auto;background-color:var(--color-white);border-radius:1rem;padding:2.5rem;box-shadow:var(--shadow-lg)}.dons-section{margin-bottom:2.5rem}.dons-section h2{color:var(--color-primary);font-size:1.5rem;margin-bottom:1.5rem}.currency-selector{display:grid;grid-template-columns:1fr 1fr;gap:1rem}.currency-btn{padding:1.25rem;border:2px solid var(--color-border);background-color:var(--color-white);border-radius:.75rem;cursor:pointer;transition:var(--transition-base);display:flex;align-items:center;gap:.75rem;font-size:1rem}.currency-btn:hover{border-color:var(--color-primary);transform:translateY(-2px);box-shadow:var(--shadow-md)}.currency-btn.active{border-color:var(--color-primary);background-color:#00a6510d;box-shadow:var(--shadow-md)}.currency-symbol{font-size:1.5rem;font-weight:700;color:var(--color-primary)}.amount-buttons{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem}.amount-btn{padding:1rem;border:2px solid var(--color-border);background-color:var(--color-white);border-radius:.5rem;font-size:1.1rem;font-weight:600;color:var(--color-text);cursor:pointer;transition:var(--transition-base)}.amount-btn:hover{border-color:var(--color-primary);background-color:#00a6510d}.amount-btn.active{border-color:var(--color-primary);background-color:var(--color-primary);color:var(--color-white)}.custom-amount{margin-top:1rem}.custom-amount input{width:100%;padding:.75rem;border:2px solid var(--color-primary);border-radius:.5rem;font-size:1rem}.custom-amount input:focus{outline:none;box-shadow:0 0 0 3px #00a6511a}.payment-methods{display:grid;grid-template-columns:repeat(2,1fr);gap:1rem}.payment-method-btn{padding:1.25rem;border:2px solid var(--color-border);background-color:var(--color-white);border-radius:.75rem;cursor:pointer;transition:var(--transition-base);display:flex;flex-direction:column;align-items:center;gap:.5rem}.payment-method-btn:hover{border-color:var(--color-primary);transform:translateY(-2px);box-shadow:var(--shadow-md)}.payment-method-btn.active{border-color:var(--color-primary);background-color:#00a6510d;box-shadow:var(--shadow-md)}.payment-icon{font-size:2rem}.payment-method-btn span:last-child{font-weight:600;color:var(--color-text);font-size:.95rem}.payment-form{margin-top:2rem}.payment-fields{background-color:var(--color-background);padding:1.5rem;border-radius:.75rem;margin-bottom:2rem}.payment-fields h3{color:var(--color-primary);font-size:1.2rem;margin-bottom:1.5rem}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem;margin-bottom:1rem}.form-row:last-child{margin-bottom:0}.form-group.full-width{grid-column:1 / -1}.form-group label{font-weight:600;color:var(--color-text);font-size:.9rem}.form-group input,.form-group textarea{padding:.75rem;border:1px solid var(--color-border);border-radius:.5rem;font-size:1rem;font-family:inherit;transition:var(--transition-base)}.form-group input:focus,.form-group textarea:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px #00a6511a}.form-group textarea{resize:vertical}.donor-info{background-color:#00a65108;padding:1.5rem;border-radius:.75rem;margin-bottom:2rem}.donor-info h3{color:var(--color-primary);font-size:1.1rem;margin-bottom:1.5rem}.btn-donate{width:100%;padding:1.25rem;font-size:1.2rem;font-weight:700;margin-bottom:1rem}.btn-donate:disabled{opacity:.5;cursor:not-allowed}.security-note{text-align:center;color:var(--color-text-light);font-size:.9rem;padding:1rem;background-color:var(--color-background);border-radius:.5rem}@media(max-width:768px){.dons-page{padding:2rem 0}.dons-container{padding:1.5rem}.dons-header h1{font-size:2rem}.amount-buttons{grid-template-columns:repeat(2,1fr)}.payment-methods,.form-row{grid-template-columns:1fr}.form-group.full-width{grid-column:1}}@media(max-width:480px){.amount-buttons{grid-template-columns:1fr}}.admin-dashboard{min-height:100vh;background-color:#f5f5f5}.admin-header{background:linear-gradient(135deg,var(--color-primary) 0%,var(--color-primary-light) 100%);color:var(--color-white);padding:1.5rem 0;box-shadow:0 2px 10px #0000001a}.admin-header-content{max-width:1400px;margin:0 auto;padding:0 2rem;display:flex;justify-content:space-between;align-items:center}.admin-branding h1{margin:0 0 .5rem;font-size:1.75rem;color:var(--color-white)}.admin-role-badge{display:inline-block;padding:.25rem .75rem;border-radius:1rem;font-size:.85rem;font-weight:600;margin:0}.admin-role-badge[data-role=admin]{background-color:#dc2626}.admin-role-badge[data-role=drh]{background-color:#2563eb}.admin-role-badge[data-role=trainer]{background-color:#16a34a}.admin-user-info{display:flex;align-items:center;gap:1rem}.admin-user-name{font-weight:600}.btn-logout{background-color:#fff3;color:var(--color-white);border:1px solid rgba(255,255,255,.3)}.btn-logout:hover{background-color:#ffffff4d}.admin-container{max-width:1400px;margin:0 auto;padding:2rem}.stats-container{margin-bottom:2rem}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:1.5rem;margin-bottom:1.5rem}.stat-card{background-color:var(--color-white);padding:1.5rem;border-radius:.75rem;box-shadow:0 2px 8px #0000000d;display:flex;align-items:center;gap:1rem;transition:var(--transition-base);border:1px solid var(--color-border)}.stat-card:hover{transform:translateY(-3px);box-shadow:0 4px 12px #0000001a}.stat-icon{width:50px;height:50px;border-radius:12px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.stat-icon svg{width:24px;height:24px}.icon-blue{background-color:#eff6ff;color:#3b82f6}.icon-gray{background-color:#f3f4f6;color:#6b7280}.icon-red{background-color:#fef2f2;color:#ef4444}.icon-orange{background-color:#fff7ed;color:#f97316}.icon-green{background-color:#f0fdf4;color:#22c55e}.icon-purple{background-color:#faf5ff;color:#a855f7}.icon-indigo{background-color:#eef2ff;color:#6366f1}.icon-pink{background-color:#fdf2f8;color:#ec4899}.stat-content h3{margin:0;font-size:1.5rem;color:var(--color-text);font-weight:700}.stat-content p{margin:.25rem 0 0;color:var(--color-text-light);font-size:.9rem}.stats-pagination{display:flex;justify-content:center;align-items:center;gap:1rem;margin-top:1rem}.btn-pagination{padding:.5rem 1rem;background-color:var(--color-white);border:1px solid var(--color-border);border-radius:.5rem;color:var(--color-text);cursor:pointer;transition:all .2s;font-weight:500}.btn-pagination:hover:not(:disabled){background-color:var(--color-background);border-color:var(--color-primary);color:var(--color-primary)}.btn-pagination:disabled{opacity:.5;cursor:not-allowed}.pagination-info{font-size:.9rem;color:var(--color-text-light);font-weight:500}.dashboard-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1.5rem}.admin-section{background-color:var(--color-white);border-radius:.75rem;padding:2rem;margin-bottom:0;box-shadow:0 2px 8px #0000001a;height:100%}.admin-section.full-width{grid-column:1 / -1}.admin-section h2{margin:0 0 1.5rem;color:var(--color-primary);font-size:1.5rem}.financial-section{background:linear-gradient(135deg,#00a6510d,#00a65105);border:2px solid rgba(0,166,81,.2)}.financial-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:1.5rem}.financial-card{background-color:var(--color-white);padding:2rem;border-radius:.75rem;box-shadow:0 4px 12px #0000001a;display:flex;align-items:center;gap:1.5rem;transition:var(--transition-base);border-left:4px solid}.transaction-form{background-color:var(--color-background);padding:1.5rem;border-radius:.75rem;border:1px solid var(--color-border)}.form-row{display:flex;gap:1.5rem;margin-bottom:1rem}.form-group{flex:1;display:flex;flex-direction:column;gap:.5rem}.form-group.full-width{flex:100%}.form-select,.form-input{padding:.75rem;border:1px solid var(--color-border);border-radius:.5rem;font-size:1rem}.btn-submit-transaction{width:100%;margin-top:1rem;padding:.75rem;font-weight:600}.text-success{color:#16a34a;font-weight:600}.text-danger{color:#dc2626;font-weight:600}.btn-icon{background:none;border:none;cursor:pointer;font-size:1.2rem;padding:.25rem;transition:transform .2s}.btn-icon:hover{transform:scale(1.1)}.financial-card:hover{transform:translateY(-3px);box-shadow:0 6px 16px #00000026}.financial-card.income{border-left-color:#16a34a}.financial-card.expense{border-left-color:#dc2626}.financial-card.balance{border-left-color:#2563eb}.financial-icon{font-size:3rem;width:70px;height:70px;display:flex;align-items:center;justify-content:center;border-radius:.75rem}.financial-card.income .financial-icon{background-color:#16a34a1a}.financial-card.expense .financial-icon{background-color:#dc26261a}.financial-card.balance .financial-icon{background-color:#2563eb1a}.financial-content h3{margin:0;font-size:2.25rem;font-weight:700}.financial-card.income .financial-content h3{color:#16a34a}.financial-card.expense .financial-content h3{color:#dc2626}.financial-card.balance .financial-content h3.positive{color:#2563eb}.financial-card.balance .financial-content h3.negative{color:#dc2626}.financial-content p{margin:.5rem 0 0;color:var(--color-text-light);font-size:.95rem;font-weight:600}.table-container{overflow-x:auto}.admin-table{width:100%;border-collapse:collapse}.admin-table thead{background-color:var(--color-background)}.admin-table th{padding:1rem;text-align:left;font-weight:600;color:var(--color-text);border-bottom:2px solid var(--color-border)}.admin-table td{padding:1rem;border-bottom:1px solid var(--color-border);color:var(--color-text)}.admin-table tbody tr:hover{background-color:#00a65105}.status-badge{display:inline-block;padding:.25rem .75rem;border-radius:1rem;font-size:.85rem;font-weight:600}.status-pending{background-color:#fef3c7;color:#92400e}.status-approved,.status-accepted{background-color:#d1fae5;color:#065f46}.status-rejected{background-color:#fee2e2;color:#991b1b}.action-buttons{display:flex;gap:.5rem}.btn-sm{padding:.4rem .8rem;font-size:.85rem}.btn-success{background-color:#16a34a;color:#fff}.btn-success:hover{background-color:#15803d}.btn-danger{background-color:#dc2626;color:#fff}.btn-danger:hover{background-color:#b91c1c}.access-code{font-family:Courier New,monospace;background-color:var(--color-background);padding:.25rem .5rem;border-radius:.25rem;font-size:.85rem;font-weight:600;color:var(--color-primary)}.loading-screen{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:100vh;gap:1rem}.spinner{width:50px;height:50px;border:4px solid var(--color-border);border-top-color:var(--color-primary);border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}@media(max-width:768px){.admin-header-content{flex-direction:column;gap:1rem;text-align:center}.admin-container{padding:1rem}.stats-grid,.dashboard-grid{grid-template-columns:1fr}.admin-section{padding:1rem}.admin-table{font-size:.85rem}.admin-table th,.admin-table td{padding:.5rem}.action-buttons{flex-direction:column}.btn-sm{width:100%}}.admin-login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,var(--color-primary) 0%,var(--color-primary-light) 100%);padding:2rem}.admin-login-container{width:100%;max-width:500px}.admin-login-card{background-color:var(--color-white);border-radius:1rem;box-shadow:0 20px 60px #0000004d;overflow:hidden}.admin-login-header{background:linear-gradient(135deg,var(--color-primary) 0%,var(--color-primary-light) 100%);color:var(--color-white);padding:3rem 2rem;text-align:center}.admin-icon{font-size:4rem;margin-bottom:1rem}.admin-login-header h1{margin:0 0 .5rem;font-size:2rem;color:var(--color-white)}.admin-login-header p{margin:0;opacity:.9;font-size:1.1rem}.admin-login-form{padding:2.5rem 2rem;display:flex;flex-direction:column;gap:1.5rem}.admin-login-form .form-group{display:flex;flex-direction:column;gap:.5rem}.admin-login-form label{font-weight:600;color:var(--color-text);font-size:.95rem}.admin-login-form input{padding:.875rem;border:2px solid var(--color-border);border-radius:.5rem;font-size:1rem;transition:var(--transition-base);width:100%}.password-input-wrapper{position:relative;display:flex;align-items:center}.password-input-wrapper input{padding-right:3rem}.btn-toggle-password{position:absolute;right:.75rem;background:none;border:none;cursor:pointer;color:var(--color-text-light);display:flex;align-items:center;justify-content:center;padding:.25rem;transition:color .2s}.btn-toggle-password:hover{color:var(--color-primary)}.admin-login-form input:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px #00a6511a}.admin-login-form input:disabled{background-color:var(--color-background);cursor:not-allowed}.error-message{background-color:#fee;color:#c33;padding:.875rem;border-radius:.5rem;border:1px solid #fcc;font-size:.95rem}.btn-login{width:100%;padding:1rem;font-size:1.1rem;font-weight:700;margin-top:.5rem}.btn-login:disabled{opacity:.6;cursor:not-allowed}.admin-login-footer{background-color:var(--color-background);padding:1.5rem 2rem;border-top:1px solid var(--color-border)}.test-credentials{font-size:.85rem}.test-credentials strong{display:block;margin-bottom:.75rem;color:var(--color-text)}.credential-item{display:flex;align-items:center;gap:.75rem;margin-bottom:.5rem}.role-badge{padding:.25rem .5rem;border-radius:.25rem;font-size:.75rem;font-weight:600;text-transform:uppercase;min-width:80px;text-align:center}.role-badge.admin{background-color:#dc2626;color:#fff}.role-badge.drh{background-color:#2563eb;color:#fff}.role-badge.trainer{background-color:#16a34a;color:#fff}.credential-item code{background-color:var(--color-white);padding:.25rem .5rem;border-radius:.25rem;font-family:Courier New,monospace;font-size:.8rem;border:1px solid var(--color-border)}@media(max-width:768px){.admin-login-page{padding:1rem}.admin-login-header{padding:2rem 1.5rem}.admin-login-header h1{font-size:1.5rem}.admin-login-form{padding:2rem 1.5rem}.credential-item{flex-direction:column;align-items:flex-start;gap:.25rem}.role-badge{min-width:auto}}.gallery-page{padding:2rem 0;min-height:calc(100vh - 200px)}.gallery-page h1{text-align:center;color:var(--color-primary);margin-bottom:.5rem}.gallery-subtitle{text-align:center;color:var(--color-text-light);margin-bottom:3rem;font-size:1.1rem}.access-denied{background-color:var(--color-white);padding:3rem;border-radius:1rem;box-shadow:var(--shadow-lg);text-align:center;max-width:600px;margin:3rem auto}.access-denied h1{color:var(--color-accent);margin-bottom:1.5rem}.access-denied ul{list-style:none;padding:0;margin:1.5rem 0}.access-denied li{padding:.5rem 0;color:var(--color-text)}.upload-section{background-color:var(--color-white);padding:2rem;border-radius:1rem;box-shadow:var(--shadow-md);margin-bottom:3rem;border:2px solid var(--color-accent)}.upload-section h2{color:var(--color-primary);margin-bottom:.5rem}.upload-note{color:var(--color-accent);font-weight:600;margin-bottom:1.5rem;font-size:.95rem}.upload-form{display:flex;flex-direction:column;gap:1.5rem}.file-input-wrapper{display:flex;justify-content:center}.file-input-label{display:inline-flex;align-items:center;gap:.5rem;padding:1rem 2rem;background-color:var(--color-primary);color:var(--color-white);border-radius:.5rem;cursor:pointer;font-weight:600;transition:var(--transition-base)}.file-input-label:hover{background-color:var(--color-primary-light);transform:translateY(-2px)}.file-input{display:none}.preview-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:1rem}.preview-item{position:relative;aspect-ratio:1;border-radius:.5rem;overflow:hidden;box-shadow:var(--shadow-sm)}.preview-item img,.preview-video{width:100%;height:100%;object-fit:cover}.form-group{display:flex;flex-direction:column;gap:.5rem}.form-group label{font-weight:600;color:var(--color-text)}.form-group textarea{padding:.75rem;border:1px solid var(--color-border);border-radius:.5rem;font-family:inherit;font-size:1rem;resize:vertical}.form-group textarea:focus{outline:none;border-color:var(--color-primary)}.upload-progress{text-align:center}.progress-bar{width:100%;height:30px;background-color:var(--color-border);border-radius:15px;overflow:hidden;margin-bottom:.5rem}.progress-fill{height:100%;background:linear-gradient(90deg,var(--color-primary),var(--color-accent));transition:width .3s ease;display:flex;align-items:center;justify-content:center;color:#fff;font-weight:700}.upload-progress p{color:var(--color-primary);font-weight:600}.btn-upload{width:100%;padding:1rem;font-size:1.1rem}.btn-upload:disabled{opacity:.6;cursor:not-allowed}.gallery-section{margin-top:3rem}.gallery-section h2{color:var(--color-primary);margin-bottom:2rem}.no-publications{text-align:center;color:var(--color-text-light);padding:3rem;background-color:var(--color-background);border-radius:.5rem}.gallery-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:2rem}.gallery-item{background-color:var(--color-white);border-radius:1rem;overflow:hidden;box-shadow:var(--shadow-md);transition:var(--transition-base)}.gallery-item:hover{transform:translateY(-5px);box-shadow:var(--shadow-lg)}.gallery-media{width:100%;height:250px;object-fit:cover}.gallery-item-info{padding:1rem}.gallery-caption{font-weight:600;color:var(--color-text);margin-bottom:.5rem}.gallery-date{font-size:.9rem;color:var(--color-text-light);margin-bottom:1rem}.interaction-buttons{display:flex;gap:.5rem;flex-wrap:wrap}.interaction-btn{flex:1;min-width:90px;padding:.6rem 1rem;border:none;border-radius:.5rem;font-size:.9rem;font-weight:600;cursor:pointer;transition:var(--transition-base);display:flex;align-items:center;justify-content:center;gap:.3rem}.like-btn{background-color:#ffe5e5;color:#d32f2f}.like-btn:hover{background-color:#d32f2f;color:#fff;transform:scale(1.05)}.share-btn{background-color:#e3f2fd;color:#1976d2}.share-btn:hover{background-color:#1976d2;color:#fff;transform:scale(1.05)}.comment-btn{background-color:#f3e5f5;color:#7b1fa2}.comment-btn:hover{background-color:#7b1fa2;color:#fff;transform:scale(1.05)}@media(max-width:768px){.gallery-page{padding:1rem 0}.upload-section{padding:1.5rem}.preview-grid{grid-template-columns:repeat(auto-fill,minmax(100px,1fr))}.gallery-grid{grid-template-columns:1fr;gap:1.5rem}.gallery-media{height:200px}}
