:root{--bg-color: #0b101b;--card-bg: #151b2b;--primary-text: #ffffff;--secondary-text: #8b9bb4;--accent-color: #00d1b2;--active-btn-bg: #10b981;--inactive-btn-bg: #232d42;--input-bg: #1e2536;--input-border: #2a3449;--highlight-blue: #3b82f6;--divider-color: #2a3449}body{margin:0;padding:0;background-color:var(--bg-color);font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Open Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;color:var(--primary-text);min-height:100vh}#root{width:100%;min-height:100vh;display:flex;flex-direction:column}a{color:var(--accent-color);text-decoration:none}a:hover{text-decoration:underline}.app-container{width:100%;max-width:600px;margin:0 auto;padding:1rem;box-sizing:border-box;flex:1;display:flex;flex-direction:column}.highlight-role{color:var(--accent-color);font-weight:700;text-transform:capitalize}.cancel-btn{width:100%;padding:.8rem;background-color:#ef44441a;border:1px solid #ef4444;color:#ef4444;border-radius:8px;font-weight:600;cursor:pointer;transition:all .2s;margin-top:1rem}.cancel-btn:hover{background-color:#ef4444;color:#fff}.empty-state{text-align:center;color:var(--secondary-text);margin-top:2rem;display:flex;flex-direction:column;align-items:center;gap:1rem}.login-container{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:100vh;width:100%;padding:1rem;box-sizing:border-box;position:relative;overflow:hidden}.login-content{position:relative;z-index:2;width:100%;max-width:600px;display:flex;flex-direction:column;align-items:center}.login-content h2{color:var(--accent-color);font-size:2rem;margin-bottom:.5rem}.login-subtitle{color:var(--secondary-text);font-size:1.2rem;margin-top:0;margin-bottom:2rem;font-style:italic}.login-form{display:flex;flex-direction:column;gap:1.2rem;width:100%;max-width:400px;padding:2rem;background-color:var(--card-bg);border:1px solid var(--divider-color);border-radius:16px;box-shadow:0 4px 20px #0003;color:var(--primary-text);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px)}@media (max-width: 768px){.login-form{background-color:#151b2b99;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px)}}.form-actions{display:flex;justify-content:flex-end;margin-top:-.5rem}.text-link{background:none;border:none;color:var(--accent-color);cursor:pointer;font-size:.9rem;padding:0;text-decoration:none}.text-link:hover{text-decoration:underline}.login-btn,.google-btn{padding:.9rem;border:none;border-radius:8px;cursor:pointer;font-weight:600;font-size:1rem;margin-top:.5rem;transition:opacity .2s}.login-btn{background-color:var(--accent-color);color:#000}.login-btn:hover{opacity:.9}.login-btn:disabled,.google-btn:disabled,.outline-btn:disabled{opacity:.6;cursor:not-allowed}.divider{margin:1.5rem 0;font-weight:700;color:var(--secondary-text);position:relative;width:100%;max-width:400px;text-align:center}.divider:before,.divider:after{content:"";position:absolute;top:50%;width:45%;height:1px;background-color:var(--divider-color)}.divider:before{left:0}.divider:after{right:0}.google-btn{background-color:#fff;color:#333;display:flex;align-items:center;justify-content:center;gap:.5rem;width:100%;max-width:400px}.google-btn:hover{background-color:#f1f1f1}.join-section{margin-top:2rem;display:flex;flex-direction:column;align-items:center;gap:.5rem;width:100%;max-width:400px}.join-section p{color:var(--secondary-text);margin:0}.outline-btn{background:transparent;border:2px solid var(--accent-color);color:var(--accent-color);padding:.8rem;border-radius:8px;cursor:pointer;font-weight:600;font-size:1rem;width:100%;transition:all .2s}.outline-btn:hover{background-color:#00d1b21a}.registration-container{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:100vh;width:100%;padding:1rem;box-sizing:border-box;position:relative;overflow:hidden}.video-background{position:absolute;top:0;left:0;width:100%;height:100%;z-index:0;overflow:hidden;display:none}.video-background video{min-width:100%;min-height:100%;width:auto;height:auto;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);object-fit:cover}.video-overlay{position:absolute;top:0;left:0;width:100%;height:100%;background-color:#0b101bb3;z-index:1}@media (max-width: 768px){.video-background{display:block}}.registration-content{position:relative;z-index:2;width:100%;max-width:600px;display:flex;flex-direction:column;align-items:center}.registration-header{display:flex;align-items:center;gap:1rem;width:100%;max-width:400px;margin-bottom:2rem}.registration-header h2{color:var(--accent-color);font-size:2rem;margin:0}.registration-form{display:flex;flex-direction:column;gap:1.2rem;width:100%;max-width:400px;padding:2rem;background-color:var(--card-bg);border:1px solid var(--divider-color);border-radius:16px;box-shadow:0 4px 20px #0003;color:var(--primary-text);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px)}@media (max-width: 768px){.registration-form{background-color:#151b2b99;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px)}}.form-group{display:flex;flex-direction:column;text-align:left}.form-group label{margin-bottom:.5rem;font-weight:500;color:var(--secondary-text)}.form-group input{padding:.8rem;background-color:var(--input-bg);border:1px solid var(--input-border);border-radius:8px;color:var(--primary-text);font-size:1rem;transition:border-color .2s}.form-group input:focus{outline:none;border-color:var(--accent-color)}.form-group input.error{border-color:#ef4444}.error-message{color:#ef4444;font-size:.85rem;margin-top:.25rem}.hint-message{color:var(--secondary-text);font-size:.85rem;margin-top:.25rem}.register-btn{background-color:var(--accent-color);color:#000;padding:.9rem;border:none;border-radius:8px;cursor:pointer;font-weight:600;font-size:1rem;margin-top:.5rem;transition:opacity .2s}.register-btn:hover{opacity:.9}.register-btn:disabled{opacity:.6;cursor:not-allowed}.error-banner{background-color:#ef44441a;border:1px solid #ef4444;color:#ef4444;padding:.8rem;border-radius:8px;font-size:.9rem;margin-bottom:1rem}.sidebar-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#0009;z-index:999;opacity:0;visibility:hidden;transition:all .3s ease-in-out;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.sidebar-overlay.open{opacity:1;visibility:visible}.sidebar-container{position:fixed;top:0;right:0;bottom:0;width:280px;background-color:var(--card-bg);z-index:1000;transform:translate(100%);transition:transform .3s cubic-bezier(.4,0,.2,1);display:flex;flex-direction:column;border-left:1px solid var(--divider-color);box-shadow:-4px 0 24px #0006}.sidebar-container.open{transform:translate(0)}.sidebar-header{padding:1.5rem;display:flex;justify-content:space-between;align-items:center;border-bottom:1px solid var(--divider-color)}.sidebar-title{margin:0;font-size:1.5rem;color:var(--accent-color)}.close-btn{background:none;border:none;color:var(--secondary-text);cursor:pointer;padding:.5rem;display:flex;align-items:center;justify-content:center;border-radius:50%;transition:all .2s}.close-btn:hover{background-color:var(--inactive-btn-bg);color:var(--primary-text)}.sidebar-nav{flex:1;padding:1.5rem 1rem;display:flex;flex-direction:column;gap:.5rem}.nav-item{display:flex;align-items:center;gap:1rem;padding:1rem;background:none;border:none;color:var(--primary-text);font-size:1.1rem;cursor:pointer;border-radius:8px;transition:all .2s;text-align:left;width:100%}.nav-item:hover{background-color:var(--inactive-btn-bg);color:var(--accent-color)}.nav-divider{height:1px;background-color:var(--divider-color);margin:1rem 0}.icon-wrapper{position:relative;display:flex;align-items:center;justify-content:center}.notification-badge{position:absolute;top:-6px;right:-6px;background-color:#ef4444;color:#fff;font-size:.65rem;font-weight:700;min-width:16px;height:16px;border-radius:50%;display:flex;align-items:center;justify-content:center;padding:0 2px;border:2px solid var(--card-bg);box-shadow:0 1px 2px #0003}.admin-section{padding:1.5rem 1rem;border-top:1px solid var(--divider-color);border-bottom:1px solid var(--divider-color);background-color:#00d1b20d}.admin-header{display:flex;align-items:center;gap:.5rem;margin-bottom:1rem;padding-bottom:.5rem;border-bottom:1px solid var(--divider-color)}.admin-label{font-weight:600;color:var(--accent-color);font-size:.9rem;text-transform:uppercase;letter-spacing:.5px}.admin-nav{display:flex;flex-direction:column;gap:.3rem}.admin-item{font-size:1rem;padding:.8rem;color:var(--secondary-text)}.admin-item:hover{background-color:#00d1b21a;color:var(--accent-color)}.sidebar-footer{padding:1.5rem 1rem;border-top:1px solid var(--divider-color)}.logout-btn{color:#ef4444}.logout-btn:hover{background-color:#ef44441a;color:#ef4444}.app-header{display:flex;justify-content:space-between;align-items:flex-start;padding:1rem .5rem;margin-bottom:1rem}.social-links-container{display:flex;flex-wrap:wrap;gap:.5rem;align-items:center}.social-btn{display:flex;align-items:center;gap:.4rem;padding:.4rem .8rem;border-radius:20px;font-size:.85rem;font-weight:600;text-decoration:none;transition:transform .2s,opacity .2s;color:#fff}.social-btn:hover{opacity:.9;transform:translateY(-2px)}.social-btn.whatsapp{background-color:#25d366}.social-btn.telegram{background-color:#08c}.social-btn.instagram{background:linear-gradient(45deg,#f09433,#e6683c,#dc2743,#cc2366,#bc1888)}.social-btn span{display:inline-block}@media (max-width: 400px){.social-btn span{display:none}.social-btn{padding:.4rem}}.icon-btn{background:none;border:none;color:var(--secondary-text);cursor:pointer;padding:.5rem;display:flex;align-items:center;justify-content:center}.icon-btn:hover{color:var(--primary-text)}.content-wrapper{flex:1;display:flex;flex-direction:column;align-items:center}.title-section{text-align:center;margin-bottom:2rem}.page-title{font-size:2.5rem;font-weight:800;color:#22d3ee;margin:0;margin-bottom:.5rem;letter-spacing:-.5px}.smaller-title{font-size:1.8rem}.subtitle{color:var(--secondary-text);font-size:1.1rem;margin:.5rem 0}.date-range{color:#22d3ee;font-weight:600;font-size:1.1rem;margin:.5rem 0}.cards-container{width:100%;display:flex;flex-direction:column;gap:1.5rem}.class-card{background-color:var(--card-bg);border-radius:16px;padding:1.5rem;border:1px solid #2a3449;box-shadow:0 4px 20px #0003}.card-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:1.5rem}.day-text{font-size:1.4rem;font-weight:700;margin:0 0 .25rem}.date-text{color:var(--secondary-text);font-size:.9rem;margin:0}.class-info-right{text-align:right}.class-type{font-size:1rem;font-weight:600;color:#22d3ee;margin:0 0 .25rem}.class-card:nth-child(2) .class-type{color:#22d3ee}.time-text{color:var(--secondary-text);font-size:.9rem;margin:0}.poll-container{display:flex;flex-direction:column;gap:1.25rem}.poll-option-row{display:flex;flex-direction:column;gap:.5rem;cursor:pointer;transition:opacity .2s}.poll-option-row:hover{opacity:.9}.poll-header{display:flex;align-items:center;gap:.75rem}.poll-checkbox{width:20px;height:20px;border-radius:50%;border:2px solid var(--secondary-text);display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:all .2s}.poll-checkbox.checked{border-color:var(--accent-color);background-color:var(--accent-color)}.checkmark{color:#000;font-size:.8rem;font-weight:900}.poll-title{font-size:1rem;color:var(--primary-text);font-weight:500}.poll-bar-section{display:flex;align-items:center;gap:1rem;padding-left:2rem}.poll-bar-bg{flex:1;height:8px;background-color:var(--inactive-btn-bg);border-radius:4px;overflow:hidden}.poll-bar-fill{height:100%;border-radius:4px;transition:width .5s ease-out}.poll-bar-fill.leader{background-color:var(--accent-color)}.poll-bar-fill.follower{background-color:#f59e0b}.poll-bar-fill.not-coming{background-color:#ef4444}.poll-stats{display:flex;align-items:center;gap:.75rem}.avatar-stack{display:flex}.mini-avatar{width:20px;height:20px;border-radius:50%;border:1px solid var(--card-bg);margin-left:-6px}.mini-avatar:first-child{margin-left:0}.more-avatars{width:20px;height:20px;border-radius:50%;background-color:var(--inactive-btn-bg);color:var(--secondary-text);font-size:.6rem;display:flex;align-items:center;justify-content:center;margin-left:-6px;border:1px solid var(--card-bg)}.vote-count{color:var(--secondary-text);font-size:.85rem;font-weight:600;min-width:1.5rem;text-align:right}.poll-footer{margin-top:.5rem;text-align:center;border-top:1px solid var(--divider-color);padding-top:1rem}.view-votes-btn{background:none;border:none;color:var(--accent-color);font-size:.95rem;cursor:pointer;padding:.5rem 1rem;border-radius:20px;transition:background-color .2s}.view-votes-btn:hover{background-color:#00d1b21a}.app-footer{margin-top:2rem;text-align:center;color:#4b5563;font-size:.8rem;padding-bottom:1rem}.heart-icon{color:#ef4444;vertical-align:middle;margin:0 2px}.country-select-wrapper{position:relative;width:100%}.country-select-trigger{width:100%;border:1px solid var(--input-border);background-color:var(--input-bg);color:var(--primary-text);border-radius:8px;padding:.85rem 1rem;display:flex;align-items:center;justify-content:space-between;cursor:pointer;transition:border-color .2s,box-shadow .2s;position:relative;font-size:1rem}.country-select-trigger:hover,.country-select-trigger:focus-visible{border-color:var(--accent-color);box-shadow:0 0 0 2px #22d3ee26;outline:none}.country-select-trigger.has-value{color:var(--primary-text)}.country-select-label{flex:1;text-align:left}.country-select-label.placeholder{color:var(--secondary-text)}.country-select-trigger-icon{margin-left:.5rem;color:var(--secondary-text);transition:transform .2s}.country-select-trigger-icon.open{transform:rotate(180deg)}.country-select-trigger-clear{background:none;border:none;color:var(--secondary-text);padding:.2rem;border-radius:4px;margin-right:.5rem;cursor:pointer;display:flex;align-items:center;justify-content:center}.country-select-trigger-clear:hover{color:var(--primary-text);background-color:var(--inactive-btn-bg)}.country-select-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background-color:#00000080;z-index:1500}.country-dropdown{position:absolute;top:calc(100% + .5rem);left:0;right:0;background-color:var(--card-bg);border:1px solid var(--divider-color);border-radius:12px;box-shadow:0 20px 45px #00000073;z-index:2000;max-height:340px;display:flex;flex-direction:column}.country-search-row{display:flex;align-items:center;gap:.5rem;padding:.9rem 1rem;border-bottom:1px solid var(--divider-color)}.country-search-icon{color:var(--secondary-text)}.country-search-input{flex:1;padding:.55rem .75rem;background-color:var(--input-bg);border:1px solid var(--input-border);border-radius:8px;color:var(--primary-text)}.country-search-input:focus{outline:none;border-color:var(--accent-color)}.country-dropdown-list{overflow-y:auto;max-height:280px;-webkit-overflow-scrolling:touch}.country-option{padding:.85rem 1.1rem;border-bottom:1px solid var(--divider-color);color:var(--primary-text);cursor:pointer;transition:background-color .15s,color .15s}.country-option:last-child{border-bottom:none}.country-option.highlighted,.country-option:hover{background-color:#ffffff0a;color:var(--accent-color)}.country-option.selected{background-color:#22d3ee1f;color:var(--accent-color);font-weight:600}.country-dropdown-empty{padding:1.5rem;text-align:center;color:var(--secondary-text);font-style:italic}.country-hidden-input{position:absolute;opacity:0;pointer-events:none;height:0;width:0}@media (max-width: 768px){.country-dropdown{position:fixed;left:1rem;right:1rem;bottom:1rem;top:auto;max-height:70vh;border-radius:16px;overflow:hidden;animation:slideUp .2s ease-out}.country-option{padding:1rem 1.3rem;font-size:1.05rem}}@keyframes slideUp{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}select{width:100%;padding:.8rem 2.5rem .8rem .8rem;background-color:var(--input-bg);border:1px solid var(--input-border);border-radius:8px;color:var(--primary-text);font-size:1rem;cursor:pointer;transition:border-color .2s;box-sizing:border-box;-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%23ffffff' d='M6 9L1 4h10z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right .8rem center}.join-container{min-height:100vh;background-color:var(--bg-color);color:var(--primary-text);display:flex;flex-direction:column;width:100%;max-width:600px;margin:0 auto;padding:1rem;box-sizing:border-box}.join-header{display:flex;align-items:center;gap:1rem;margin-bottom:2rem;padding-bottom:1rem;border-bottom:1px solid var(--divider-color)}.join-header h1{font-size:1.8rem;margin:0;color:var(--accent-color)}.join-form{display:flex;flex-direction:column;gap:2rem}.form-section{display:flex;flex-direction:column;gap:1rem;background-color:var(--card-bg);padding:1.5rem;border-radius:12px;border:1px solid var(--divider-color)}.form-section h3{margin:0 0 .5rem;color:var(--accent-color);font-size:1.2rem;border-bottom:1px solid var(--divider-color);padding-bottom:.5rem}.row-group{display:flex;gap:1rem}.row-group .form-group{flex:1}.radio-group{display:flex;flex-direction:column;gap:.8rem}.radio-label,.checkbox-label{display:flex;align-items:center;gap:.8rem;cursor:pointer;font-size:.95rem;color:var(--primary-text)}.radio-label input,.checkbox-label input{accent-color:var(--accent-color);width:18px;height:18px}.group-label{color:var(--secondary-text);font-weight:500;margin-bottom:.5rem;display:block}.checkbox-group{display:flex;flex-wrap:wrap;gap:1.5rem;margin-bottom:1rem}.input-with-unit{display:flex;gap:.5rem}.input-with-unit input{flex:1}.input-with-unit select{background-color:var(--input-bg);border:1px solid var(--input-border);color:var(--primary-text);border-radius:8px;padding:0 1rem}textarea{width:100%;padding:.8rem;background-color:var(--input-bg);border:1px solid var(--input-border);border-radius:8px;color:var(--primary-text);font-family:inherit;font-size:1rem;resize:vertical;box-sizing:border-box}select{width:100%;padding:.8rem 2.5rem .8rem .8rem;background-color:var(--input-bg);border:1px solid var(--input-border);border-radius:8px;color:var(--primary-text);font-size:1rem;cursor:pointer;transition:border-color .2s;box-sizing:border-box;-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%23ffffff' d='M6 9L1 4h10z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right .8rem center}select:focus{outline:none;border-color:var(--accent-color)}select option{background-color:var(--input-bg);color:var(--primary-text)}.role-choices{flex-direction:row;flex-wrap:wrap;gap:.75rem}.radio-label.pill{gap:.35rem;padding:.2rem .4rem;border-radius:999px;background-color:var(--inactive-btn-bg);border:1px solid transparent}.radio-label.pill span{display:inline-block;padding:.35rem .75rem}.radio-label.pill input{margin:0}.radio-label.pill input:checked+span{font-weight:600;color:var(--accent-color);background-color:#22d3ee1f;border-radius:999px}.consent-item{margin-bottom:.8rem}.photo-consent-special{background-color:#00d1b21a;padding:1rem;border-radius:8px;border:1px dashed var(--accent-color);margin-top:1rem}.icon-text{display:flex;align-items:center;gap:.5rem;font-weight:600}.camera-icon{color:var(--accent-color)}.consent-help{margin:.5rem 0 0 2.2rem;font-size:.85rem;color:var(--secondary-text)}.submit-btn{background-color:var(--accent-color);color:#000;font-weight:700;padding:1rem;border:none;border-radius:8px;font-size:1.1rem;cursor:pointer;margin-bottom:2rem;transition:opacity .2s}.submit-btn:hover{opacity:.9}.submit-btn:disabled{opacity:.6;cursor:not-allowed}.form-error{color:#ef4444;font-size:.9rem;margin:0 0 1rem;text-align:center}.loading-message{text-align:center;color:var(--secondary-text);margin:4rem 0}.loading-state{min-height:100vh;display:flex;align-items:center;justify-content:center}.admin-content{width:100%;max-width:600px;margin:0 auto;padding-bottom:4rem}.admin-info-message{text-align:center;color:var(--secondary-text);margin-top:2rem}.no-results{text-align:center;padding:3rem 1rem;color:var(--secondary-text);background-color:#ffffff05;border-radius:12px;border:1px dashed var(--divider-color)}.admin-error-banner{background-color:#ef44441a;border:1px solid rgba(239,68,68,.3);color:#ef4444;padding:1rem;border-radius:8px;margin-bottom:1.5rem;display:flex;align-items:center;justify-content:space-between;gap:1rem}.admin-error-banner button{background-color:#ef444433;border:none;color:#ef4444;padding:.25rem .75rem;border-radius:4px;font-weight:600;cursor:pointer}.search-section{margin-bottom:1.5rem}.search-input-wrapper{position:relative;display:flex;align-items:center}.search-icon{position:absolute;left:1rem;color:var(--secondary-text)}.search-input{width:100%;padding:.8rem 1rem .8rem 2.8rem;background-color:var(--card-bg);border:1px solid var(--divider-color);border-radius:12px;color:var(--primary-text);font-size:1rem;transition:border-color .2s}.search-input:focus{border-color:var(--accent-color);outline:none}.clear-search-btn{position:absolute;right:.8rem;background:none;border:none;color:var(--secondary-text);font-size:1.2rem;cursor:pointer;padding:.2rem;display:flex;align-items:center;justify-content:center}.controls-row{display:flex;flex-wrap:wrap;gap:1rem;justify-content:space-between;align-items:flex-end;margin-bottom:1rem}.filter-section{flex:1;min-width:200px}.filter-label{display:block;color:var(--secondary-text);font-size:.9rem;margin-bottom:.5rem}.filter-buttons{display:flex;gap:.5rem;overflow-x:auto;padding-bottom:.2rem}.filter-btn{background-color:var(--inactive-btn-bg);border:1px solid transparent;color:var(--secondary-text);padding:.5rem .8rem;border-radius:20px;font-size:.85rem;cursor:pointer;white-space:nowrap;transition:all .2s}.filter-btn.active{background-color:#22d3ee26;color:var(--accent-color);border-color:#22d3ee4d}.sort-section{min-width:150px}.sort-select-wrapper{position:relative}.sort-select{width:100%;padding:.5rem 1rem;background-color:var(--card-bg);border:1px solid var(--divider-color);border-radius:8px;color:var(--primary-text);font-size:.9rem;cursor:pointer;outline:none}.sort-select:focus{border-color:var(--accent-color)}.filter-count{font-size:.8rem;color:var(--secondary-text);text-align:right;margin-bottom:1rem}.users-list{display:flex;flex-direction:column;gap:1rem}.user-card{background-color:#ffffff05;border:1px solid var(--divider-color);border-radius:12px;padding:1rem;display:flex;justify-content:space-between;align-items:center;gap:1rem}.user-info{flex:1;display:flex;flex-direction:column;gap:.25rem}.user-name-role{display:flex;align-items:center;gap:.5rem;flex-wrap:wrap}.user-name{font-size:1.1rem;font-weight:600;color:var(--primary-text);margin:0}.role-badge{font-size:.75rem;padding:.15rem .5rem;border-radius:12px;font-weight:600;text-transform:uppercase}.role-badge.leader{background-color:#3b82f633;color:#60a5fa}.role-badge.follower{background-color:#ec489933;color:#f472b6}.user-email{font-size:.9rem;color:var(--secondary-text);margin:0}.user-dates{display:flex;flex-wrap:wrap;gap:.8rem;margin-top:.25rem}.user-joined,.user-active{font-size:.8rem;color:#6b7280;margin:0;display:flex;align-items:center}.user-active{color:var(--accent-color)}.user-actions{display:flex;gap:.5rem}.icon-action-btn{width:36px;height:36px;border-radius:50%;border:none;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s;background-color:var(--inactive-btn-bg);color:var(--primary-text)}.icon-action-btn:hover{transform:translateY(-2px)}.info-btn{color:#3b82f6;background-color:#3b82f61a}.whatsapp-btn-icon{color:#22c55e;background-color:#22c55e1a}.whatsapp-btn-icon:disabled{opacity:.5;cursor:not-allowed;filter:grayscale(1)}.request-card{background-color:#ffffff05;border:1px solid var(--divider-color);border-radius:12px;padding:1.5rem;transition:all .3s ease;display:flex;flex-direction:column;gap:1rem;overflow:hidden}.request-card:hover{background-color:#ffffff0a;border-color:var(--accent-color)}.request-card.expanded{background-color:#ffffff0d;border-color:var(--accent-color)}.request-main-content{display:flex;justify-content:space-between;align-items:flex-start;gap:1rem;width:100%}.request-info{display:flex;flex-direction:column;gap:.5rem;flex:1}.request-detail{margin:0;color:var(--primary-text);font-size:.95rem}.request-detail strong{color:var(--secondary-text);font-weight:500;margin-right:.5rem}.request-actions{display:flex;flex-direction:column;gap:.75rem}.action-btn{display:flex;align-items:center;justify-content:center;gap:.5rem;padding:.6rem 1rem;border-radius:8px;border:none;font-size:.9rem;font-weight:600;cursor:pointer;transition:all .2s;width:100%}.approve-btn{background-color:#22c55e26;color:#22c55e;border:1px solid rgba(34,197,94,.3)}.approve-btn:hover{background-color:#22c55e40;border-color:#22c55e}.reject-btn{background-color:#ef444426;color:#ef4444;border:1px solid rgba(239,68,68,.3)}.reject-btn:hover{background-color:#ef444440;border-color:#ef4444}.show-more-btn{width:100%;background:none;border:none;border-top:1px solid var(--divider-color);color:var(--accent-color);padding-top:1rem;margin-top:.5rem;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:.5rem;font-size:.9rem;font-weight:500;transition:all .2s}.show-more-btn:hover{color:#00b8a9;background-color:#ffffff05}.request-expanded-details{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1.5rem;padding:1rem 0;border-top:1px solid var(--divider-color);animation:fadeIn .3s ease-out}@keyframes fadeIn{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.detail-section h4{color:var(--accent-color);font-size:.9rem;text-transform:uppercase;letter-spacing:.5px;margin:0 0 .75rem;border-bottom:1px solid var(--divider-color);padding-bottom:.25rem}.detail-section p{margin:.4rem 0;font-size:.9rem;line-height:1.4}.consents-grid{display:flex;gap:.5rem;flex-wrap:wrap}.consent-tag{padding:.25rem .6rem;border-radius:4px;font-size:.8rem;font-weight:600}.consent-tag.agreed{background-color:#22c55e26;color:#22c55e;border:1px solid rgba(34,197,94,.3)}.consent-tag.not-agreed{background-color:#ef444426;color:#ef4444;border:1px solid rgba(239,68,68,.3)}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#000000d9;display:flex;align-items:center;justify-content:center;padding:1rem;z-index:1000;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.modal-content{background-color:var(--card-bg);width:100%;max-width:500px;max-height:85vh;border-radius:16px;border:1px solid var(--divider-color);overflow-y:auto;position:relative;box-shadow:0 20px 25px -5px #00000080}.modal-header{position:sticky;top:0;background-color:var(--card-bg);padding:1rem 1.5rem;border-bottom:1px solid var(--divider-color);display:flex;justify-content:space-between;align-items:center;z-index:10}.modal-header h2{margin:0;font-size:1.25rem;color:var(--primary-text)}.modal-close-btn{background:none;border:none;color:var(--secondary-text);cursor:pointer;padding:.5rem;display:flex;align-items:center;justify-content:center;transition:color .2s}.modal-close-btn:hover{color:var(--primary-text)}.modal-body{padding:1.5rem}.modal-section{margin-bottom:1.5rem}.modal-section:last-child{margin-bottom:0}.modal-section h3{color:var(--accent-color);font-size:.95rem;text-transform:uppercase;letter-spacing:.5px;margin:0 0 .75rem;border-bottom:1px solid var(--divider-color);padding-bottom:.5rem}.modal-section p{margin:.5rem 0;line-height:1.5;font-size:.95rem}.modal-section strong{color:var(--secondary-text);margin-right:.5rem;font-weight:500}.clickable-link{color:var(--accent-color);cursor:pointer;text-decoration:underline;text-decoration-color:#22d3ee4d;text-underline-offset:2px}.clickable-link:hover{color:#fff}.interests-tags{display:flex;flex-wrap:wrap;gap:.5rem;margin-top:.5rem}.interest-tag{background-color:var(--inactive-btn-bg);padding:.25rem .75rem;border-radius:12px;font-size:.85rem;color:var(--primary-text)}.confirm-modal{background-color:var(--card-bg);border-radius:16px;max-width:400px;width:90%;border:1px solid var(--divider-color);box-shadow:0 20px 25px -5px #00000080,0 10px 10px -5px #0003;overflow:hidden}.confirm-header{padding:1.5rem 1.5rem .5rem;display:flex;justify-content:space-between;align-items:flex-start;border:none}.confirm-title{display:flex;flex-direction:column;gap:.75rem;align-items:center;width:100%;text-align:center}.warning-icon-wrapper{width:48px;height:48px;border-radius:50%;background-color:#ef44441a;display:flex;align-items:center;justify-content:center;margin-bottom:.5rem}.warning-icon{color:#ef4444;width:24px;height:24px}.confirm-title h2{margin:0;font-size:1.25rem;color:var(--primary-text);font-weight:600}.confirm-message{font-size:1rem;color:var(--primary-text);margin-bottom:.5rem;line-height:1.5}.confirm-subtext{color:var(--secondary-text);font-size:.9rem;margin-bottom:1.5rem;line-height:1.4}.modal-actions{display:flex;gap:.75rem;margin-top:1.5rem;width:100%}.modal-actions .action-btn,.modal-actions .cancel-btn,.modal-actions .confirm-reject-btn{flex:1 1 0;width:100%;max-width:none}.cancel-btn{background-color:transparent;border:1px solid var(--divider-color);color:var(--primary-text)}.cancel-btn:hover{background-color:var(--inactive-btn-bg)}.confirm-reject-btn{background-color:#ef4444;color:#fff;box-shadow:0 4px 6px -1px #ef44444d}.confirm-reject-btn:hover{background-color:#dc2626;box-shadow:0 6px 8px -1px #ef444466;transform:translateY(-1px)}.confirm-reject-btn:active{transform:translateY(0)}@media (max-width: 600px){.request-main-content{flex-direction:column}.request-actions{width:100%;flex-direction:row}.request-actions .action-btn{flex:1}.request-expanded-details{grid-template-columns:1fr;gap:1rem}.controls-row{flex-direction:column;align-items:flex-start}.filter-section,.sort-section{width:100%}}
