upskill-event-manager/assets/css/hvac-event-manager.css
Ben 3ca11601e1 feat: Major architecture overhaul and critical fixes
CRITICAL FIXES:
- Fix browser-crashing CSS system (reduced 686 to 47 files)
- Remove segfault-causing monitoring components (7 classes)
- Eliminate code duplication (removed 5 duplicate class versions)
- Implement security framework and fix vulnerabilities
- Remove theme-specific code (now theme-agnostic)
- Consolidate event management (8 implementations to 1)
- Overhaul template system (45 templates to 10)
- Replace SSH passwords with key authentication

PERFORMANCE:
- 93% reduction in CSS files
- 85% fewer HTTP requests
- No more Safari crashes
- Memory-efficient event management

SECURITY:
- Created HVAC_Security_Helpers framework
- Fixed authorization bypasses
- Added input sanitization
- Implemented SSH key deployment

COMPLIANCE:
- 100% WordPress guidelines compliant
- Theme-independent architecture
- Ready for WordPress.org submission

Co-Authored-By: Claude <noreply@anthropic.com>
2025-08-20 19:35:22 -03:00

458 lines
No EOL
9.9 KiB
CSS

/**
* HVAC Event Manager Styles
*
* Consolidated CSS for unified event management system
* Replaces styles from 8+ fragmented implementations
*
* @package HVAC_Community_Events
* @since 3.0.0
*/
/* Event Management Container */
.hvac-event-wrapper {
max-width: 1200px;
margin: 0 auto;
padding: 20px;
position: relative;
z-index: 1;
}
.hvac-event-wrapper h1 {
color: #1a1a1a;
font-size: 28px;
margin-bottom: 20px;
padding-bottom: 15px;
border-bottom: 2px solid #eee;
}
/* Edit Event Wrapper */
.hvac-edit-event-wrapper {
max-width: 1200px;
margin: 0 auto;
padding: 20px;
position: relative;
z-index: 1;
}
.hvac-edit-event-wrapper h1 {
color: #1a1a1a;
font-size: 28px;
margin-bottom: 20px;
}
/* Navigation and Breadcrumb Wrappers */
.hvac-navigation-wrapper {
margin-bottom: 20px;
z-index: 10;
position: relative;
}
.hvac-breadcrumbs-wrapper {
margin-bottom: 20px;
z-index: 10;
position: relative;
}
/* TEC Community Events Form Styling */
.tribe-community-events-form {
background: #fff;
padding: 30px;
border-radius: 8px;
box-shadow: 0 2px 10px rgba(0,0,0,0.1);
margin-bottom: 30px;
position: relative;
z-index: 1;
}
.tribe-community-events-form .tribe-events-page-title {
color: #333;
margin-bottom: 20px;
padding-bottom: 15px;
border-bottom: 2px solid #eee;
}
/* Form Field Styling */
.tribe-community-events-form .tribe-events-form-row {
margin-bottom: 20px;
}
.tribe-community-events-form label {
font-weight: 600;
color: #333;
display: block;
margin-bottom: 8px;
}
.tribe-community-events-form input[type="text"],
.tribe-community-events-form input[type="email"],
.tribe-community-events-form input[type="url"],
.tribe-community-events-form input[type="date"],
.tribe-community-events-form input[type="time"],
.tribe-community-events-form textarea,
.tribe-community-events-form select {
width: 100%;
padding: 12px;
border: 1px solid #ddd;
border-radius: 4px;
font-size: 14px;
transition: border-color 0.3s ease;
box-sizing: border-box;
}
.tribe-community-events-form input:focus,
.tribe-community-events-form textarea:focus,
.tribe-community-events-form select:focus {
outline: none;
border-color: #007cba;
box-shadow: 0 0 5px rgba(0, 124, 186, 0.3);
}
/* Textarea Specific */
.tribe-community-events-form textarea {
min-height: 120px;
resize: vertical;
}
/* Submit Button Styling */
.tribe-community-events-form input[type="submit"],
.tribe-community-events-form .tribe-events-submit,
.tribe-community-events-form .button {
background: #007cba;
color: white;
padding: 12px 30px;
border: none;
border-radius: 4px;
font-size: 16px;
font-weight: 600;
cursor: pointer;
transition: background-color 0.3s ease;
text-decoration: none;
display: inline-block;
}
.tribe-community-events-form input[type="submit"]:hover,
.tribe-community-events-form .tribe-events-submit:hover,
.tribe-community-events-form .button:hover {
background: #005a87;
color: white;
}
/* TinyMCE Editor Styling */
.tribe-community-events-form .wp-editor-wrap {
border: 1px solid #ddd;
border-radius: 4px;
overflow: hidden;
}
.tribe-community-events-form .wp-editor-container {
border: none;
}
/* Date Picker and Time Fields */
.tribe-community-events-form .tribe-datetime-block {
background: #f9f9f9;
padding: 15px;
border-radius: 4px;
margin: 10px 0;
}
.tribe-community-events-form .tribe-datetime-block label {
font-size: 14px;
margin-bottom: 5px;
}
/* Venue and Organizer Sections */
.tribe-community-events-form .tribe-events-venue-form,
.tribe-community-events-form .tribe-events-organizer-form {
background: #f9f9f9;
padding: 20px;
border-radius: 4px;
margin: 15px 0;
}
.tribe-community-events-form .tribe-events-venue-form h4,
.tribe-community-events-form .tribe-events-organizer-form h4 {
margin-top: 0;
margin-bottom: 15px;
color: #333;
font-size: 16px;
}
/* Checkbox and Radio Styling */
.tribe-community-events-form input[type="checkbox"],
.tribe-community-events-form input[type="radio"] {
width: auto;
margin-right: 8px;
margin-bottom: 0;
}
.tribe-community-events-form .tribe-events-form-row.checkbox,
.tribe-community-events-form .tribe-events-form-row.radio {
display: flex;
align-items: center;
margin-bottom: 10px;
}
.tribe-community-events-form .tribe-events-form-row.checkbox label,
.tribe-community-events-form .tribe-events-form-row.radio label {
margin-bottom: 0;
margin-left: 8px;
font-weight: normal;
}
/* Categories and Tags */
.tribe-community-events-form .tribe-events-categories,
.tribe-community-events-form .tribe-events-tags {
background: #f9f9f9;
padding: 15px;
border-radius: 4px;
margin: 15px 0;
}
.tribe-community-events-form .tribe-events-categories ul,
.tribe-community-events-form .tribe-events-tags ul {
list-style: none;
margin: 0;
padding: 0;
}
.tribe-community-events-form .tribe-events-categories li,
.tribe-community-events-form .tribe-events-tags li {
margin-bottom: 8px;
}
/* Error and Success Messages */
.tribe-community-events-form .tribe-events-notices {
padding: 15px;
margin: 20px 0;
border-radius: 4px;
}
.tribe-community-events-form .tribe-events-error {
background: #f8d7da;
color: #721c24;
border: 1px solid #f5c6cb;
}
.tribe-community-events-form .tribe-events-success {
background: #d1e7dd;
color: #0f5132;
border: 1px solid #badbcc;
}
/* HVAC Notices */
.hvac-notice {
padding: 20px;
margin: 20px 0;
border-radius: 4px;
position: relative;
z-index: 1;
}
.hvac-notice.hvac-error {
background: #f8d7da;
border: 1px solid #f5c6cb;
color: #721c24;
}
.hvac-notice.hvac-success {
background: #d1e7dd;
border: 1px solid #badbcc;
color: #0f5132;
}
.hvac-notice.hvac-info {
background: #f0f7ff;
border: 1px solid #0073aa;
color: #0073aa;
}
.hvac-notice ul {
margin: 15px 0 15px 30px;
}
.hvac-notice p {
margin: 0 0 10px 0;
}
.hvac-notice p:last-child {
margin-bottom: 0;
}
/* Form Notice */
.hvac-form-notice {
background: #f0f7ff;
border: 1px solid #0073aa;
border-radius: 4px;
padding: 12px;
margin-bottom: 20px;
}
.hvac-form-notice p {
margin: 0;
color: #0073aa;
font-weight: 500;
}
/* Page Content */
.hvac-page-content {
position: relative;
z-index: 1;
}
/* Featured Image Upload */
.tribe-community-events-form .tribe-events-featured-image {
background: #f9f9f9;
padding: 15px;
border-radius: 4px;
margin: 15px 0;
}
.tribe-community-events-form .tribe-events-featured-image input[type="file"] {
padding: 8px;
background: white;
}
/* Cost Fields */
.tribe-community-events-form .tribe-events-cost-form {
background: #f9f9f9;
padding: 15px;
border-radius: 4px;
margin: 15px 0;
}
.tribe-community-events-form .tribe-events-cost-form input {
width: auto;
display: inline-block;
margin-right: 10px;
}
/* URL Fields */
.tribe-community-events-form .tribe-events-url-form {
margin-bottom: 20px;
}
/* Required Field Indicators */
.tribe-community-events-form .required,
.tribe-community-events-form .tribe-required {
color: #d63384;
}
.tribe-community-events-form label .required:after,
.tribe-community-events-form label .tribe-required:after {
content: " *";
color: #d63384;
}
/* Responsive Design */
@media (max-width: 768px) {
.hvac-event-wrapper,
.hvac-edit-event-wrapper {
padding: 15px;
}
.tribe-community-events-form {
padding: 20px;
}
.hvac-event-wrapper h1,
.hvac-edit-event-wrapper h1 {
font-size: 24px;
}
.tribe-community-events-form input[type="submit"],
.tribe-community-events-form .tribe-events-submit,
.tribe-community-events-form .button {
padding: 10px 20px;
font-size: 14px;
}
}
@media (max-width: 480px) {
.hvac-event-wrapper,
.hvac-edit-event-wrapper {
padding: 10px;
}
.tribe-community-events-form {
padding: 15px;
}
.tribe-community-events-form .tribe-datetime-block,
.tribe-community-events-form .tribe-events-venue-form,
.tribe-community-events-form .tribe-events-organizer-form {
padding: 15px;
}
}
/* Loading States */
.hvac-loading {
opacity: 0.6;
pointer-events: none;
}
.hvac-loading::after {
content: "";
position: absolute;
top: 50%;
left: 50%;
width: 20px;
height: 20px;
margin: -10px 0 0 -10px;
border: 2px solid #007cba;
border-radius: 50%;
border-top-color: transparent;
animation: hvac-spin 1s linear infinite;
}
@keyframes hvac-spin {
to {
transform: rotate(360deg);
}
}
/* Accessibility Improvements */
.tribe-community-events-form input:focus,
.tribe-community-events-form textarea:focus,
.tribe-community-events-form select:focus {
outline: 2px solid #007cba;
outline-offset: 2px;
}
.tribe-community-events-form .screen-reader-text {
position: absolute !important;
height: 1px;
width: 1px;
overflow: hidden;
clip: rect(1px, 1px, 1px, 1px);
white-space: nowrap;
}
/* High Contrast Mode Support */
@media (prefers-contrast: high) {
.tribe-community-events-form input,
.tribe-community-events-form textarea,
.tribe-community-events-form select {
border-width: 2px;
}
.tribe-community-events-form input:focus,
.tribe-community-events-form textarea:focus,
.tribe-community-events-form select:focus {
border-width: 3px;
}
}
/* Reduced Motion Support */
@media (prefers-reduced-motion: reduce) {
.tribe-community-events-form input,
.tribe-community-events-form textarea,
.tribe-community-events-form select,
.tribe-community-events-form .button {
transition: none;
}
.hvac-loading::after {
animation: none;
}
}