/**
 * Tenant Referral Program - Signup Form Styles
 * Extracted and adapted from template-referral-signup-test.php
 */

:root {
    --trp-red: #E60000; 
    --trp-dark-red: #C00000; 
    --trp-text-light: #ffffff;
    --trp-text-dark: #333333;
    --trp-border-color: #dddddd;
    --trp-input-bg: #f9f9f9;
    --trp-success-bg: #d4edda;
    --trp-success-text: #155724;
    --trp-success-border: #c3e6cb;
    --trp-error-bg: #f8d7da;
    --trp-error-text: #721c24;
    --trp-error-border: #f5c6cb;
    --trp-warning-bg: #fff3cd;
    --trp-warning-text: #856404;
    --trp-warning-border: #ffeeba;
    --trp-info-bg: #d1ecf1;
    --trp-info-text: #0c5460;
    --trp-info-border: #bee5eb;
}

.trp-signup-form-container {
    max-width: 600px; 
    margin: 40px auto; 
    padding: 20px 30px 30px;
    background-color: #ffffff; 
    border: 1px solid var(--trp-border-color);
    border-radius: 8px; 
    box-shadow: 0 4px 12px rgba(0,0,0,0.08);
    font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Helvetica, Arial, sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol";
}

.trp-signup-form-container .trp-form-title {
    color: var(--trp-red); 
    text-align: center; 
    margin-bottom: 25px;
    font-size: 2em; 
    font-weight: bold;
}

.trp-signup-form p, 
.trp-signup-form div.trp-form-field {
    margin-bottom: 15px;
}

.trp-signup-form label {
    display: block; 
    margin-bottom: 5px; 
    font-weight: bold; 
    color: var(--trp-text-dark);
}

.trp-signup-form label .required-star {
    color: var(--trp-red); 
    font-weight: bold;
}

.trp-signup-form input[type="email"],
.trp-signup-form input[type="password"],
.trp-signup-form input[type="text"],
.trp-signup-form input[type="tel"],
.trp-signup-form select {
    width: 100%; 
    padding: 10px; 
    border: 1px solid var(--trp-border-color);
    border-radius: 4px; 
    box-sizing: border-box; 
    background-color: var(--trp-input-bg);
    transition: border-color 0.3s ease, box-shadow 0.3s ease; 
    font-size: 1rem;
}

.trp-signup-form input[type="email"]:focus,
.trp-signup-form input[type="password"]:focus,
.trp-signup-form input[type="text"]:focus,
.trp-signup-form input[type="tel"]:focus,
.trp-signup-form select:focus {
    border-color: var(--trp-red); 
    outline: none;
    box-shadow: 0 0 0 3px rgba(230, 0, 0, 0.25);
}

.trp-signup-form .trp-checkbox-group {
    margin-bottom: 10px;
}

.trp-signup-form .trp-checkbox-group input[type="checkbox"] {
    margin-right: 8px; 
    vertical-align: middle;
}

.trp-signup-form .trp-checkbox-group label {
    display: inline; 
    font-weight: normal; 
    margin-bottom: 0;
}

.trp-signup-form-container .trp-signup-form input[type="submit"],
.trp-signup-form-container .trp-signup-form button[type="submit"] {
    display: block; 
    width: 100%; 
    padding: 12px 15px;
    background-color: var(--trp-red) !important; 
    color: var(--trp-text-light) !important;     
    border: none !important; 
    border-radius: 4px; 
    cursor: pointer;
    font-size: 1.1em; 
    font-weight: bold;
    transition: background-color 0.3s ease; 
    text-transform: uppercase;
}

.trp-signup-form-container .trp-signup-form input[type="submit"]:hover,
.trp-signup-form-container .trp-signup-form button[type="submit"]:hover {
    background-color: var(--trp-dark-red) !important;
}

/* Message feedback styles */
.trp-signup-feedback p {
    padding: 12px 15px; 
    margin-bottom: 15px; 
    border-radius: 4px;
    border-width: 1px; 
    border-style: solid; 
    font-size: 0.95em;
}

.trp-signup-feedback .trp-message-type-error { 
    color: var(--trp-error-text); 
    background-color: var(--trp-error-bg); 
    border-color: var(--trp-error-border); 
}

.trp-signup-feedback .trp-message-type-success { 
    color: var(--trp-success-text); 
    background-color: var(--trp-success-bg); 
    border-color: var(--trp-success-border); 
}

.trp-signup-feedback .trp-message-type-warning { 
    color: var(--trp-warning-text); 
    background-color: var(--trp-warning-bg); 
    border-color: var(--trp-warning-border); 
}

.trp-signup-feedback .trp-message-type-info { 
    color: var(--trp-info-text); 
    background-color: var(--trp-info-bg); 
    border-color: var(--trp-info-border); 
}

/* Referral code notice styles */
#trp-referral-code-applied-notice {
    margin-bottom: 15px; 
    font-style: italic; 
    color: #555;
}

/* Manual referral code area styles */
#trp-manual-referral-code-area {
    display: none; 
    margin-bottom: 15px; 
    padding: 10px; 
    border: 1px solid var(--trp-border-color); 
    border-radius: 4px; 
    background-color: #f9f9f9;
}

#trp-manual-referral-code-area label {
    display: block; 
    margin-bottom: 5px; 
    font-weight: normal; 
    color: #333;
}

#trp-manual-referral-code-area .trp-manual-code-input-group {
    display: flex;
}

#trp-manual-ref-code-input {
    flex-grow: 1; 
    padding: 8px; 
    border: 1px solid var(--trp-border-color); 
    border-radius: 4px 0 0 4px;
}

#trp-apply-manual-ref-code-button {
    padding: 8px 12px; 
    border: 1px solid var(--trp-red); 
    border-left: none; 
    background-color: var(--trp-red); 
    color: white; 
    border-radius: 0 4px 4px 0; 
    cursor: pointer;
}

#trp-apply-manual-ref-code-button:hover {
    background-color: var(--trp-dark-red);
}

#trp-manual-ref-code-feedback {
    font-size: 0.9em; 
    margin-top: 5px;
}

/* Loading states */
.trp-signup-form.trp-loading input,
.trp-signup-form.trp-loading button {
    opacity: 0.6;
    pointer-events: none;
}

.trp-signup-form.trp-loading button[type="submit"]:after {
    content: " ...";
}

/* Responsive design */
@media (max-width: 768px) {
    .trp-signup-form-container {
        margin: 20px auto;
        padding: 15px 20px 25px;
    }
    
    .trp-signup-form-container .trp-form-title {
        font-size: 1.5em;
        margin-bottom: 20px;
    }
    
    #trp-manual-referral-code-area .trp-manual-code-input-group {
        flex-direction: column;
    }
    
    #trp-manual-ref-code-input {
        border-radius: 4px;
        margin-bottom: 8px;
    }
    
    #trp-apply-manual-ref-code-button {
        border: 1px solid var(--trp-red);
        border-radius: 4px;
    }
}

/* Accessibility improvements */
.trp-signup-form input:focus,
.trp-signup-form button:focus {
    outline: 2px solid var(--trp-red);
    outline-offset: 2px;
}

.trp-signup-form .required-star {
    speak: literal;
}

/* Screen reader only text */
.trp-sr-only {
    position: absolute;
    width: 1px;
    height: 1px;
    padding: 0;
    margin: -1px;
    overflow: hidden;
    clip: rect(0, 0, 0, 0);
    white-space: nowrap;
    border: 0;
} 