/*
Theme Name: Rumu
Theme URI: https://rumu.in
Author: ICPG Technologies Pvt Ltd
Author URI: https://iconicpages.com
Description: A high-performance WordPress theme for high-ticket real estate lead generation. Features a modern dark design with glassmorphism effects, particle animations, and full WordPress integration.
Version: 1.0.0
Requires at least: 6.0
Tested up to: 6.4
Requires PHP: 7.4
License: GNU General Public License v2 or later
License URI: http://www.gnu.org/licenses/gpl-2.0.html
Text Domain: rumu
Tags: dark, real-estate, lead-generation, performance-marketing, modern, responsive, custom-menu, featured-images, translation-ready
*/

@import url('https://fonts.googleapis.com/css2?family=Outfit:wght@300;400;500;600;700&display=swap');

body {
    font-family: 'Outfit', sans-serif;
    background-color: #000000;
    color: #ffffff;
    overflow-x: hidden;
}

.text-gradient {
    background: linear-gradient(135deg, #FFD700 0%, #FDB931 100%);
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
}

.glass-card {
    background: rgba(255, 255, 255, 0.03);
    backdrop-filter: blur(10px);
    border: 1px solid rgba(255, 255, 255, 0.05);
}

.glass-panel {
    background: rgba(255, 255, 255, 0.03);
    backdrop-filter: blur(12px);
    -webkit-backdrop-filter: blur(12px);
    border: 1px solid rgba(247, 218, 242, 0.1);
    box-shadow: 0 4px 6px -1px rgba(0, 0, 0, 0.3), 0 2px 4px -1px rgba(0, 0, 0, 0.06);
}

.glass-btn {
    background: rgba(255, 255, 255, 0.05);
    backdrop-filter: blur(8px);
    border: 1px solid rgba(255, 255, 255, 0.1);
    transition: all 0.3s ease;
}

.glass-btn:hover {
    background: rgba(255, 255, 255, 0.1);
    border-color: rgba(247, 218, 242, 0.3);
    transform: translateY(-1px);
}

.text-glow {
    text-shadow: 0 0 20px rgba(111, 1, 89, 0.6);
}

.blob {
    position: absolute;
    border-radius: 50%;
    filter: blur(80px);
    z-index: -1;
    opacity: 0.4;
}

/* Mobile Menu Animation */
#mobile-menu {
    max-height: 0;
    overflow: hidden;
    transition: max-height 0.3s ease-in-out, opacity 0.3s ease-in-out;
    opacity: 0;
}

#mobile-menu:not(.hidden) {
    opacity: 1;
}

/* Smooth scroll for anchor links */
html {
    scroll-behavior: smooth;
}

.hero-overlay {
    background: radial-gradient(circle at top right, rgba(253, 186, 49, 0.1) 0%, transparent 40%),
        radial-gradient(circle at bottom left, rgba(56, 189, 248, 0.05) 0%, transparent 40%);
}

.preserve-3d {
    transform-style: preserve-3d;
}

/* Custom Scrollbar */
::-webkit-scrollbar {
    width: 8px;
}

::-webkit-scrollbar-track {
    background: #000000;
}

::-webkit-scrollbar-thumb {
    background: #334155;
    border-radius: 4px;
}

::-webkit-scrollbar-thumb:hover {
    background: #475569;
}

/* FluentForm Theme Styling */
.fluentform-wrapper {
    width: 100%;
    font-family: 'Outfit', sans-serif !important;
}

/* Form Container */
.fluentform-wrapper form {
    font-family: 'Outfit', sans-serif !important;
}

/* All Input Fields */
.fluentform-wrapper .ff-el-form-control,
.fluentform-wrapper input[type="text"],
.fluentform-wrapper input[type="email"],
.fluentform-wrapper input[type="tel"],
.fluentform-wrapper input[type="number"],
.fluentform-wrapper input[type="date"],
.fluentform-wrapper input[type="time"],
.fluentform-wrapper input[type="url"],
.fluentform-wrapper input[type="password"],
.fluentform-wrapper textarea,
.fluentform-wrapper select {
    width: 100% !important;
    background: rgba(0, 0, 0, 0.4) !important;
    border: 1px solid rgba(255, 255, 255, 0.1) !important;
    border-radius: 0.75rem !important;
    padding: 1rem 1.5rem !important;
    color: #ffffff !important;
    font-family: 'Outfit', sans-serif !important;
    font-size: 1rem !important;
    font-weight: 400 !important;
    transition: all 0.3s ease !important;
    line-height: 1.5 !important;
}

.fluentform-wrapper .ff-el-form-control:focus,
.fluentform-wrapper input:focus,
.fluentform-wrapper textarea:focus,
.fluentform-wrapper select:focus {
    outline: none !important;
    border-color: #6f0159 !important;
    box-shadow: 0 0 0 1px #6f0159 !important;
    background: rgba(0, 0, 0, 0.5) !important;
}

.fluentform-wrapper .ff-el-form-control::placeholder,
.fluentform-wrapper input::placeholder,
.fluentform-wrapper textarea::placeholder {
    color: #6b7280 !important;
    font-family: 'Outfit', sans-serif !important;
    opacity: 1 !important;
}

.fluentform-wrapper .ff-el-form-control option,
.fluentform-wrapper select option {
    background: #000000 !important;
    color: #ffffff !important;
    font-family: 'Outfit', sans-serif !important;
}

/* Form Groups */
.fluentform-wrapper .ff-el-group {
    margin-bottom: 1.5rem !important;
}

.fluentform-wrapper .ff-el-group:last-child {
    margin-bottom: 0 !important;
}

/* Labels */
.fluentform-wrapper .ff-el-input--label,
.fluentform-wrapper .ff-el-field--label,
.fluentform-wrapper label {
    display: block !important;
    color: #ffffff !important;
    font-family: 'Outfit', sans-serif !important;
    font-size: 0.875rem !important;
    font-weight: 500 !important;
    margin-bottom: 0.5rem !important;
    line-height: 1.5 !important;
}

.fluentform-wrapper .ff-el-input--label .ff-el-required,
.fluentform-wrapper .ff-el-field--label .ff-el-required,
.fluentform-wrapper label .ff-el-required {
    color: #6f0159 !important;
    margin-left: 2px !important;
}

/* Textarea */
.fluentform-wrapper .ff-el-form-control[type="textarea"],
.fluentform-wrapper textarea.ff-el-form-control,
.fluentform-wrapper textarea {
    min-height: 120px !important;
    resize: vertical !important;
    font-family: 'Outfit', sans-serif !important;
}

/* Submit Button */
.fluentform-wrapper .ff_submit_btn_wrapper {
    margin-top: 1.5rem !important;
}

.fluentform-wrapper .ff-btn-submit,
.fluentform-wrapper button[type="submit"],
.fluentform-wrapper input[type="submit"],
.fluentform-wrapper .ff-btn.ff-btn-primary {
    width: 100% !important;
    padding: 1rem 2rem !important;
    font-size: 1rem !important;
    font-weight: 700 !important;
    font-family: 'Outfit', sans-serif !important;
    color: #ffffff !important;
    background: #6f0159 !important;
    border: none !important;
    border-radius: 9999px !important;
    cursor: pointer !important;
    transition: all 0.3s ease !important;
    box-shadow: 0 0 25px rgba(111, 1, 89, 0.4) !important;
    text-transform: none !important;
    letter-spacing: normal !important;
}

.fluentform-wrapper .ff-btn-submit:hover,
.fluentform-wrapper button[type="submit"]:hover,
.fluentform-wrapper input[type="submit"]:hover,
.fluentform-wrapper .ff-btn.ff-btn-primary:hover {
    background: #8a026f !important;
    box-shadow: 0 0 40px rgba(111, 1, 89, 0.6) !important;
    transform: translateY(-4px) !important;
}

/* Checkboxes and Radio Buttons */
.fluentform-wrapper .ff-el-form-check-input,
.fluentform-wrapper input[type="checkbox"],
.fluentform-wrapper input[type="radio"] {
    background: rgba(0, 0, 0, 0.4) !important;
    border: 1px solid rgba(255, 255, 255, 0.1) !important;
    width: 18px !important;
    height: 18px !important;
    cursor: pointer !important;
}

.fluentform-wrapper .ff-el-form-check-input:checked,
.fluentform-wrapper input[type="checkbox"]:checked,
.fluentform-wrapper input[type="radio"]:checked {
    background: #6f0159 !important;
    border-color: #6f0159 !important;
}

.fluentform-wrapper .ff-el-form-check-label,
.fluentform-wrapper .ff-el-radio-option label,
.fluentform-wrapper label {
    color: #ffffff !important;
    font-family: 'Outfit', sans-serif !important;
    font-weight: 400 !important;
    cursor: pointer !important;
}

/* Radio Options */
.fluentform-wrapper .ff-el-radio-option {
    margin-bottom: 0.75rem !important;
}

.fluentform-wrapper .ff-el-radio-option label {
    display: flex !important;
    align-items: center !important;
    gap: 0.5rem !important;
    color: #ffffff !important;
    font-family: 'Outfit', sans-serif !important;
}

/* Section Breaks */
.fluentform-wrapper .ff-el-section-break {
    color: #ffffff !important;
    font-family: 'Outfit', sans-serif !important;
}

.fluentform-wrapper .ff-el-section-title {
    color: #ffffff !important;
    font-family: 'Outfit', sans-serif !important;
    font-weight: 600 !important;
}

.fluentform-wrapper .ff-el-section-break-content {
    color: #9ca3af !important;
    font-family: 'Outfit', sans-serif !important;
}

/* Input Content Wrapper */
.fluentform-wrapper .ff-el-input--content {
    width: 100% !important;
}

/* Error Messages */
.fluentform-wrapper .ff-el-form-errors,
.fluentform-wrapper .ff-error,
.fluentform-wrapper .ff-el-is-error .ff-el-form-control {
    background: rgba(220, 38, 38, 0.1) !important;
    border: 1px solid rgba(220, 38, 38, 0.3) !important;
    border-radius: 0.5rem !important;
    padding: 0.75rem !important;
    margin-bottom: 1rem !important;
    color: #fca5a5 !important;
    font-family: 'Outfit', sans-serif !important;
}

.fluentform-wrapper .ff-el-is-error .ff-el-form-control {
    border-color: rgba(220, 38, 38, 0.5) !important;
}

/* Success Messages */
.fluentform-wrapper .ff-el-form-success,
.fluentform-wrapper .ff-success {
    background: rgba(34, 197, 94, 0.1) !important;
    border: 1px solid rgba(34, 197, 94, 0.3) !important;
    border-radius: 0.5rem !important;
    padding: 0.75rem !important;
    margin-bottom: 1rem !important;
    color: #86efac !important;
    font-family: 'Outfit', sans-serif !important;
}

/* Select Dropdown */
.fluentform-wrapper select.ff-el-form-control,
.fluentform-wrapper select {
    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") !important;
    background-repeat: no-repeat !important;
    background-position: right 1rem center !important;
    padding-right: 2.5rem !important;
    appearance: none !important;
    -webkit-appearance: none !important;
    -moz-appearance: none !important;
    cursor: pointer !important;
}

/* File Upload */
.fluentform-wrapper .ff-el-file-upload {
    background: rgba(0, 0, 0, 0.4) !important;
    border: 1px solid rgba(255, 255, 255, 0.1) !important;
    border-radius: 0.75rem !important;
    padding: 1rem 1.5rem !important;
    color: #ffffff !important;
    font-family: 'Outfit', sans-serif !important;
}

.fluentform-wrapper .ff-el-file-upload:focus {
    border-color: #6f0159 !important;
    box-shadow: 0 0 0 1px #6f0159 !important;
}

/* Address Fields */
.fluentform-wrapper .ff-el-address-line,
.fluentform-wrapper .ff-el-city,
.fluentform-wrapper .ff-el-state,
.fluentform-wrapper .ff-el-zip,
.fluentform-wrapper .ff-el-country {
    font-family: 'Outfit', sans-serif !important;
}

/* Date Picker */
.fluentform-wrapper .ff-el-date-field input {
    font-family: 'Outfit', sans-serif !important;
}

/* Helper Text */
.fluentform-wrapper .ff-el-help-text {
    color: #9ca3af !important;
    font-family: 'Outfit', sans-serif !important;
    font-size: 0.875rem !important;
    margin-top: 0.25rem !important;
}

/* Grid Layouts */
.fluentform-wrapper .ff-el-group--2 .ff-el-form-control,
.fluentform-wrapper .ff-el-group--3 .ff-el-form-control {
    font-family: 'Outfit', sans-serif !important;
}

/* Remove default FluentForm styles that conflict */
.fluentform-wrapper * {
    box-sizing: border-box !important;
}

.fluentform-wrapper .ff-el-form-control::-webkit-input-placeholder {
    color: #6b7280 !important;
    font-family: 'Outfit', sans-serif !important;
}

.fluentform-wrapper .ff-el-form-control::-moz-placeholder {
    color: #6b7280 !important;
    font-family: 'Outfit', sans-serif !important;
    opacity: 1 !important;
}

.fluentform-wrapper .ff-el-form-control:-ms-input-placeholder {
    color: #6b7280 !important;
    font-family: 'Outfit', sans-serif !important;
}

.fluentform-wrapper .ff-el-form-control:-moz-placeholder {
    color: #6b7280 !important;
    font-family: 'Outfit', sans-serif !important;
    opacity: 1 !important;
}

