 /* --- Premium, Smooth & Flat Theme --- */
        :root {
            /* Core Colors */
            --primary-color: #4a90e2; /* A professional, soft blue */
            --danger-color: #e74c3c;
            --text-dark: #3b424d;
            --text-light: #6c757d;
            --border-color: #dcdfe6; /* Soft border for inputs */
            
            /* Base */
            --bg-main: #f4f7f9; /* A very light, almost white cool gray */
            --bg-white: #ffffff;
            
            /* --- Soft, Muted Section Background Colors --- */
            --bg-section-1: #eef7fa;   /* Very light blue-gray */
            --text-section-1: #346894; /* Deeper blue for legend */
            
            --bg-section-2: #f6fdf6;   /* Very light green-gray */
            --text-section-2: #4a8d67; /* Deeper green for legend */

            --bg-section-3: #fffaf0;   /* Very light cream/peach */
            --text-section-3: #9e7b4f; /* Deeper orange-brown for legend */

            /* NEW: Replaced pink/purple with a soft periwinkle */
            --bg-section-4: #f1f3fa;   /* Light periwinkle */
            --text-section-4: #4a5b9e; /* Deep periwinkle */

            --bg-section-5: #effafc;   /* Very light teal-blue */
            --text-section-5: #4a8d8d; /* Deeper teal for legend */
        }

        body {
            /* NEW: Updated font stack as requested */
            font-family: system-ui, -apple-system, "Segoe UI", Roboto, "Helvetica Neue", "Noto Sans", "Liberation Sans", Arial, sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji";
            background-color: var(--bg-main); /* Soft neutral background */
            color: var(--text-dark);
            line-height: 1.6;
            margin: 0;
          padding: 2rem; 
            display: flex;
            justify-content: center;
            align-items: center;
            min-height: 100vh;
        }

         /* --- Form Container (Normal Shadow) --- */
        .online-form-container {
            max-width: 900px;
            width: 100%;
            margin: 2rem auto; /* Added margin for long form */
            background: var(--bg-white); /* Clean white card */
            border-radius: 12px;
            /* A single, soft, "normal" shadow */
            box-shadow: 0 8px 30px rgba(0, 0, 0, 0.06);
            padding: 2.5rem;
            border: 1px solid #eef2f5;
        }

        /* --- Headers & Instructions --- */
        h1 {
            text-align: center;
            color: var(--text-dark);
            margin-top: 0;
            margin-bottom: 0.5rem;
            font-size: 1.75rem;
        }
        .online-form-instructions {
            text-align: center;
            font-size: 0.95rem;
            color: var(--text-light);
            margin-bottom: 2rem;
            border-bottom: 1px solid #eef2f5;
            padding-bottom: 1.5rem;
        }
        .online-form-highlight-red { color: var(--danger-color); font-weight: 600; }
        .online-form-highlight-blue { color: var(--primary-color); font-weight: 600; }

        /* --- Fieldset & Legend (Colorful Sections) --- */
        fieldset {
            border: none;
            border-radius: 8px;
            padding: 1.5rem;
            margin-bottom: 1.5rem;
            transition: background-color 0.2s;
        }
        legend {
            font-weight: 600;
            font-size: 1.1rem;
            padding: 0.25rem 0.75rem;
            margin-left: 0.5rem;
            margin-bottom: 0.5rem;
            border-radius: 6px;
        }

        /* --- Applying Soft Section Background Colors --- */
        .online-form-fs-soft-blue { background-color: var(--bg-section-1); }
        .online-form-fs-soft-blue legend { color: var(--text-section-1); }
        
        .online-form-fs-soft-green { background-color: var(--bg-section-2); }
        .online-form-fs-soft-green legend { color: var(--text-section-2); }

        .online-form-fs-soft-orange { background-color: var(--bg-section-3); }
        .online-form-fs-soft-orange legend { color: var(--text-section-3); }

        .online-form-fs-soft-periwinkle { background-color: var(--bg-section-4); }
        .online-form-fs-soft-periwinkle legend { color: var(--text-section-4); }

        .online-form-fs-soft-teal { background-color: var(--bg-section-5); }
        .online-form-fs-soft-teal legend { color: var(--text-section-5); }

         /* --- Form Grid & Layout --- */
        .online-form-row { display: grid; gap: 1.25rem; }
        .online-form-grid-2 { grid-template-columns: 1fr 1fr; }
        .online-form-grid-3 { grid-template-columns: 1fr 1fr 1fr; }
        .online-form-grid-city-state-zip { grid-template-columns: 2fr 1fr 1fr; }

        /* --- Form Groups (Label + Input) --- */
        .online-form-group { display: flex; flex-direction: column; }
        .online-form-group label {
            margin-bottom: 0.5rem;
            font-weight: 500;
            font-size: 0.9rem;
            color: var(--text-light);
        }
        
        /* --- Mandatory Symbol --- */
        .online-form-mandatory {
            color: var(--danger-color);
            font-weight: 600;
            margin-left: 4px;
        }


        /* --- SMOOTH & NORMAL INPUT STYLE --- */
        .online-form-group input[type="text"],
        .online-form-group input[type="email"],
        .online-form-group input[type="tel"],
        .online-form-group input[type="date"],
        .online-form-group select, /* Added select styling */
        .online-form-group textarea {
            width: 100%;
            padding: 0.8rem;
            font-size: 1rem;
            border-radius: 6px;
            box-sizing: border-box;
            border: 1px solid var(--border-color);
            outline: none;
            background: var(--bg-white);
            color: var(--text-dark);
            transition: border-color 0.2s ease, box-shadow 0.2s ease;
            appearance: none; /* Remove default select arrow */
        }

         /* Style select specifically */
         .online-form-group select {
            background-image: url('data:image/svg+xml;charset=US-ASCII,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20width%3D%22292.4%22%20height%3D%22292.4%22%3E%3Cpath%20fill%3D%22%23007bff%22%20d%3D%22M287%2069.4a17.6%2017.6%200%200%200-13-5.4H18.4c-5%200-9.3%201.8-12.9%205.4A17.6%2017.6%200%200%200%200%2082.2c0%205%201.8%209.3%205.4%2012.9l128%20127.9c3.6%203.6%207.8%205.4%2012.8%205.4s9.2-1.8%2012.8-5.4L287%2095c3.5-3.5%205.4-7.8%205.4-12.8%200-5-1.9-9.2-5.5-12.8z%22%2F%3E%3C%2Fsvg%3E');
            background-repeat: no-repeat;
            background-position: right 0.7em top 50%, 0 0;
            background-size: 0.65em auto, 100%;
            padding-right: 2.5em; /* Make space for arrow */
        }

        /* --- SMOOTH & PREMIUM FOCUS STYLE --- */
        .online-form-group input:focus,
        .online-form-group select:focus, /* Added select focus */
        .online-form-group textarea:focus {
            border-color: var(--primary-color);
            /* This is the "normal" premium glow shadow */
            box-shadow: 0 0 0 3px rgba(74, 144, 226, 0.1);
        }

        /* --- VALIDATION STYLING --- */
        .online-form-group input.online-form-input-error,
        .online-form-group select.online-form-input-error, /* Added select error */
        .online-form-group textarea.online-form-input-error {
             border-color: var(--danger-color) !important;
             box-shadow: 0 0 0 3px rgba(231, 76, 60, 0.1);
        }

        .online-form-group textarea { min-height: 100px; resize: vertical; }

         /* --- PREMIUM ANIMATED Radio & Checkbox --- */
        .online-form-choice-group {
            display: flex;
            flex-wrap: wrap;
            gap: 1.5rem;
            padding-top: 0.5rem;
            align-items: baseline;
        }
        .online-form-choice-item {
            display: flex;
            align-items: baseline;
            cursor: pointer;
        }
        .online-form-choice-item label {
            margin-bottom: 0;
            font-weight: 500;
            color: var(--text-dark);
            cursor: pointer;
            display: flex;
            align-items: center;
            gap: 0.6rem;
        }


        /* Hide the default input */
        /*.online-form-choice-item input[type="radio"],
        .online-form-choice-item input[type="checkbox"] {
            display: none;
        }*/

        /* Create the custom control box */
        .online-form-control {
            display: inline-block;
            width: 20px;
            height: 20px;
            background: var(--bg-white);
            border: 2px solid var(--border-color);
            transition: all 0.2s ease;
            position: relative;
        }
        .online-form-control-radio {
            border-radius: 50%;
        }
        .online-form-control-checkbox {
            border-radius: 4px;
        }

        /* Create the inner dot/check (hidden by default) */
        .online-form-control::after {
            content: '';
            position: absolute;
            top: 50%;
            left: 50%;
            transform: translate(-50%, -50%) scale(0);
            opacity: 0;
            transition: all 0.2s ease;
        }
        
        /* Style for Radio Dot */
        .online-form-control-radio::after {
            width: 10px;
            height: 10px;
            background: var(--primary-color);
            border-radius: 50%;
        }
        
        /* Style for Checkbox Mark */
        .online-form-control-checkbox::after {
            width: 6px;
            height: 12px;
            border: solid var(--primary-color);
            border-width: 0 3px 3px 0;
            transform: translate(-50%, -60%) rotate(45deg) scale(0);
        }

        /* --- CHECKED STATE --- */
        .online-form-choice-item input:checked + .online-form-control {
            border-color: var(--primary-color);
        }
        .online-form-choice-item input:checked + .online-form-control::after {
            transform: translate(-50%, -50%) scale(1);
            opacity: 1;
        }
        .online-form-choice-item input:checked + .online-form-control-checkbox::after {
            transform: translate(-50%, -60%) rotate(45deg) scale(1);
            opacity: 1;
        }

        /* Special input field next to a choice */
        .online-form-choice-item input[type="text"] {
            width: 120px;
            padding: 0.5rem;
            margin-left: 0.25rem;
            border: 1px solid var(--border-color);
            outline: none;
            border-radius: 4px;
            background: var(--bg-white);
            transition: border-color 0.2s ease, box-shadow 0.2s ease;
        }
        .online-form-choice-item input[type="text"]:focus {
            border-color: var(--primary-color);
            box-shadow: 0 0 0 3px rgba(74, 144, 226, 0.1);
        }

        /* --- Pricing Grid (Complex Grid) --- */
        .online-form-pricing-grid {
            display: grid;
            grid-template-columns: 2fr 1fr 2fr 1fr;
            gap: 1.25rem 0.75rem;
            align-items: baseline;
        }
        .online-form-grid-header { font-weight: 600; font-size: 0.9rem; }
        .online-form-pricing-grid label {
            font-size: 0.9rem;
            font-weight: 500;
            padding-right: 0.5rem;
            color: var(--text-light);
        }
        .online-form-pricing-header-details { color: var(--danger-color); }
        .online-form-pricing-grid input {
            width: 100%;
            padding: 0.8rem;
            font-size: 1rem;
            border-radius: 6px;
            box-sizing: border-box;
            border: 1px solid var(--border-color);
            outline: none;
            background: var(--bg-white);
            transition: border-color 0.2s ease, box-shadow 0.2s ease;
        }
        .online-form-pricing-grid input:focus {
            border-color: var(--primary-color);
            box-shadow: 0 0 0 3px rgba(74, 144, 226, 0.1);
        }

        /* --- "Normal" Shadow SUBMIT BUTTON --- */
        .online-form-actions { text-align: right; margin-top: 2rem; }
        .online-form-submit-btn {
            background-color: var(--primary-color);
            color: white;
            border: none;
            padding: 0.9rem 1.8rem;
            font-size: 1.1rem;
            font-weight: 600;
            border-radius: 6px;
            cursor: pointer;
            /* A soft, "normal" shadow */
            box-shadow: 0 4px 12px rgba(74, 144, 226, 0.25);
            transition: all 0.2s ease;
        }
        .online-form-submit-btn:hover {
            transform: translateY(-2px);
            box-shadow: 0 6px 16px rgba(74, 144, 226, 0.3);
        }
        .online-form-submit-btn:active {
            transform: translateY(0px);
            box-shadow: 0 2px 8px rgba(74, 144, 226, 0.2);
        }

        /* --- Error Message Styling --- */
        .online-form-error-message {
            background-color: #fff0f0;
            color: var(--danger-color);
            border: 1px solid #f9c9c9;
            padding: 1rem 1.5rem;
            border-radius: 6px;
            margin-top: 1.5rem;
            text-align: left;
            font-weight: 500;
            display: none; /* Hidden by default */
        }
        .online-form-error-message ul {
            list-style-type: disc;
            padding-left: 20px;
            margin: 0;
        }
        .online-form-error-message li {
            margin-bottom: 0.5rem;
        }
        .online-form-error-message li:last-child {
            margin-bottom: 0;
        }

        /* --- Responsive Design --- */
        @media (max-width: 768px) {
            body { padding: 1rem; align-items: flex-start; }
            .online-form-container { padding: 1.5rem; margin: 1rem auto; }
            .online-form-row, .online-form-pricing-grid { grid-template-columns: 1fr !important; }
        }

.wpcf7-form fieldset {

padding: 1.5rem !important;

margin-bottom: 1.5rem !important;

}

input.wpcf7-form-control.wpcf7-text.wpcf7-validates-as-required.online-form-integer-input {
  height: 50px;
  border-radius: 6px;
  border: 1px solid var(--border-color);
  outline: none;
}
input.wpcf7-form-control.wpcf7-number.wpcf7-validates-as-required.wpcf7-validates-as-number.online-form-decimal-input {
    width: 100%;
    padding: 0.8rem;
    font-size: 1rem;
    border-radius: 6px;
    box-sizing: border-box;
    border: 1px solid var(--border-color);
    outline: none;
    background: var(--bg-white);
    color: var(--text-dark);
    transition: border-color 0.2s 
ease, box-shadow 0.2s 
ease;
    appearance: none;
}