@import url('https://fonts.googleapis.com/css2?family=Syne:wght@600;700;800&family=Outfit:wght@300;400;500;600;700&family=Space+Mono:wght@400;700&display=swap');
/**
 * 1RoofMusic Platform — Frontend Stylesheet
 * Theme:  "Studio Neon" — futuristic full-width dark UI
 * Version: 2.1.0
 *
 * Design intent:
 *  - Self-contained: every plugin surface sets its OWN background + text colour,
 *    so text stays readable no matter what the host WordPress theme paints.
 *    (Fixes the "light theme, words not visible" problem by construction.)
 *  - Full-bleed hero sections for a true full-width website feel.
 *  - Brand gold kept as primary accent, paired with electric cyan + violet for
 *    the advanced-tech vibe. Glassmorphism, glows, gradient text, soft motion.
 *
 * @package 1RoofMusic
 */

/* ============================================================
   DESIGN TOKENS
   ============================================================ */
.oneroof-form-wrapper,
.oneroof-home-hero,
.oneroof-services-hub,
.oneroof-grid-wrapper,
.oneroof-profile-page-wrapper,
.oneroof-success-wrapper,
.oneroof-modal {
    --or-gold:        #E8C572;
    --or-gold-bright: #FFE7A0;
    --or-gold-deep:   #C9A84C;
    --or-cyan:        #4FD8E8;
    --or-violet:      #9A8BFF;
    --or-pink:        #FF7AC6;

    --or-bg:        #07070C;
    --or-bg-2:      #0B0B14;
    --or-surface:   rgba(255,255,255,0.045);
    --or-surface-2: rgba(255,255,255,0.07);
    --or-surface-3: rgba(255,255,255,0.10);
    --or-border:    rgba(255,255,255,0.10);
    --or-border-2:  rgba(255,255,255,0.16);
    --or-glow-gold: rgba(232,197,114,0.40);
    --or-glow-cyan: rgba(79,216,232,0.35);

    --or-text:      #F5F3EC;
    --or-text-soft: #CAC9D2;
    --or-text-mut:  #8B8A97;
    --or-success:   #46E5A0;
    --or-error:     #FF6B6B;

    --or-radius:    18px;
    --or-radius-sm: 12px;
    --or-radius-lg: 26px;
    --or-shadow:    0 18px 50px -20px rgba(0,0,0,0.85);
    --or-shadow-glow: 0 24px 60px -24px var(--or-glow-gold);

    --or-font-display: 'Syne', 'Trebuchet MS', sans-serif;
    --or-font-body:    'Outfit', -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
    --or-font-mono:    'Space Mono', ui-monospace, "SFMono-Regular", monospace;

    --or-grad-gold: linear-gradient(120deg, var(--or-gold-bright), var(--or-gold) 45%, var(--or-gold-deep));
    --or-grad-tech: linear-gradient(120deg, var(--or-gold) 0%, var(--or-cyan) 100%);
    --or-grad-aurora: linear-gradient(125deg, #FFE7A0 0%, #E8C572 30%, #9A8BFF 70%, #4FD8E8 100%);
}

/* Reset inside plugin scopes only — never touches the host theme */
.oneroof-form-wrapper *,
.oneroof-home-hero *,
.oneroof-services-hub *,
.oneroof-grid-wrapper *,
.oneroof-profile-page-wrapper *,
.oneroof-success-wrapper *,
.oneroof-modal * {
    box-sizing: border-box;
}

/* ============================================================
   FULL-BLEED SHELL  (edge-to-edge dark canvas)
   ============================================================ */
.oneroof-home-hero,
.oneroof-services-hub,
.oneroof-grid-wrapper,
.oneroof-profile-page-wrapper,
.oneroof-form-wrapper,
.oneroof-success-wrapper {
    position: relative;
    width: 100vw;
    left: 50%;
    right: 50%;
    margin-left: -50vw;
    margin-right: -50vw;
    background: var(--or-bg);
    color: var(--or-text);
    font-family: var(--or-font-body);
    line-height: 1.65;
    -webkit-font-smoothing: antialiased;
    overflow: hidden;
}

/* Atmospheric glow + faint engineering grid behind every section */
.oneroof-home-hero::before,
.oneroof-services-hub::before,
.oneroof-grid-wrapper::before,
.oneroof-profile-page-wrapper::before,
.oneroof-form-wrapper::before,
.oneroof-success-wrapper::before {
    content: "";
    position: absolute;
    inset: 0;
    background:
        radial-gradient(680px 420px at 12% -8%, rgba(232,197,114,0.16), transparent 60%),
        radial-gradient(720px 520px at 92% 4%, rgba(154,139,255,0.16), transparent 62%),
        radial-gradient(900px 600px at 50% 120%, rgba(79,216,232,0.10), transparent 60%),
        linear-gradient(180deg, var(--or-bg) 0%, var(--or-bg-2) 100%);
    z-index: 0;
}
.oneroof-home-hero::after,
.oneroof-services-hub::after,
.oneroof-grid-wrapper::after,
.oneroof-profile-page-wrapper::after,
.oneroof-form-wrapper::after,
.oneroof-success-wrapper::after {
    content: "";
    position: absolute;
    inset: 0;
    background-image:
        linear-gradient(rgba(255,255,255,0.035) 1px, transparent 1px),
        linear-gradient(90deg, rgba(255,255,255,0.035) 1px, transparent 1px);
    background-size: 56px 56px;
    -webkit-mask-image: radial-gradient(circle at 50% 30%, #000 0%, transparent 78%);
            mask-image: radial-gradient(circle at 50% 30%, #000 0%, transparent 78%);
    z-index: 0;
    pointer-events: none;
}

/* Inner content container (keeps readable line length on huge screens) */
.oneroof-home-hero-content,
.oneroof-services-hub > *,
.oneroof-grid-layout,
.oneroof-grid-header,
.oneroof-profile-page,
.oneroof-profile-breadcrumb,
.oneroof-form-wrapper > *,
.oneroof-success-wrapper > * {
    position: relative;
    z-index: 1;
}

/* Shared headings & links inside plugin scopes */
.oneroof-home-hero h1, .oneroof-home-hero h2, .oneroof-home-hero h3,
.oneroof-services-hub h1, .oneroof-services-hub h2, .oneroof-services-hub h3,
.oneroof-grid-wrapper h1, .oneroof-grid-wrapper h2, .oneroof-grid-wrapper h3,
.oneroof-profile-page-wrapper h1, .oneroof-profile-page-wrapper h2, .oneroof-profile-page-wrapper h3,
.oneroof-form-wrapper h1, .oneroof-form-wrapper h2, .oneroof-form-wrapper h3,
.oneroof-success-wrapper h1, .oneroof-success-wrapper h2, .oneroof-success-wrapper h3 {
    font-family: var(--or-font-display);
    color: var(--or-text);
    letter-spacing: -0.02em;
    margin: 0;
}
.oneroof-form-wrapper a,
.oneroof-profile-page-wrapper a,
.oneroof-grid-wrapper a {
    color: var(--or-gold);
    text-decoration: none;
}

/* Reusable gradient-text helper */
.oneroof-grad-text,
.oneroof-home-hero-title,
.oneroof-services-title,
.oneroof-form-header h1,
.oneroof-success-title {
    background: var(--or-grad-aurora);
    -webkit-background-clip: text;
            background-clip: text;
    -webkit-text-fill-color: transparent;
    color: var(--or-gold);
}

/* ============================================================
   PRIMARY BUTTONS  (shared)
   ============================================================ */
.oneroof-btn-primary,
.oneroof-submit-btn,
.oneroof-filter-apply-btn,
.oneroof-back-home-btn,
.oneroof-review-submit-btn {
    --b-fg: #0A0A0F;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 10px;
    font-family: var(--or-font-body);
    font-weight: 700;
    font-size: 1rem;
    letter-spacing: 0.01em;
    color: var(--b-fg);
    background: var(--or-grad-gold);
    border: none;
    border-radius: 999px;
    padding: 15px 32px;
    cursor: pointer;
    text-decoration: none;
    position: relative;
    overflow: hidden;
    box-shadow: 0 10px 30px -10px var(--or-glow-gold), inset 0 1px 0 rgba(255,255,255,0.5);
    transition: transform .25s cubic-bezier(.2,.8,.2,1), box-shadow .25s, filter .25s;
}
.oneroof-btn-primary::after,
.oneroof-submit-btn::after,
.oneroof-back-home-btn::after,
.oneroof-review-submit-btn::after {
    content: "";
    position: absolute;
    top: 0; left: -120%;
    width: 60%; height: 100%;
    background: linear-gradient(100deg, transparent, rgba(255,255,255,0.55), transparent);
    transform: skewX(-18deg);
    transition: left .6s ease;
}
.oneroof-btn-primary:hover,
.oneroof-submit-btn:hover,
.oneroof-filter-apply-btn:hover,
.oneroof-back-home-btn:hover,
.oneroof-review-submit-btn:hover {
    transform: translateY(-3px);
    box-shadow: 0 18px 44px -12px var(--or-glow-gold), inset 0 1px 0 rgba(255,255,255,0.6);
    filter: brightness(1.04);
}
.oneroof-btn-primary:hover::after,
.oneroof-submit-btn:hover::after,
.oneroof-back-home-btn:hover::after,
.oneroof-review-submit-btn:hover::after { left: 130%; }

.oneroof-btn-primary:disabled,
.oneroof-submit-btn:disabled,
.oneroof-review-submit-btn:disabled {
    opacity: .5; cursor: not-allowed; transform: none;
}

/* Secondary / ghost buttons */
.oneroof-filter-reset-btn,
.oneroof-back-link,
.oneroof-profile-bottom-back,
.oneroof-review-toggle-btn {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    font-family: var(--or-font-body);
    font-weight: 600;
    color: var(--or-text-soft);
    background: var(--or-surface);
    border: 1px solid var(--or-border-2);
    border-radius: 999px;
    padding: 12px 24px;
    cursor: pointer;
    text-decoration: none;
    transition: border-color .2s, color .2s, background .2s, transform .2s;
}
.oneroof-filter-reset-btn:hover,
.oneroof-back-link:hover,
.oneroof-profile-bottom-back:hover,
.oneroof-review-toggle-btn:hover {
    color: var(--or-gold);
    border-color: var(--or-glow-gold);
    background: var(--or-surface-2);
    transform: translateY(-2px);
}

/* ============================================================
   HOME HERO  (two-button)
   ============================================================ */
.oneroof-home-hero {
    min-height: 92vh;
    display: flex;
    align-items: center;
    padding: 80px 24px;
}
.oneroof-home-hero-content {
    max-width: 1180px;
    margin: 0 auto;
    width: 100%;
    text-align: center;
}
.oneroof-home-hero-tagline {
    display: inline-flex;
    align-items: center;
    gap: 9px;
    font-family: var(--or-font-mono);
    font-size: .8rem;
    letter-spacing: .22em;
    text-transform: uppercase;
    color: var(--or-gold);
    background: var(--or-surface);
    border: 1px solid var(--or-glow-gold);
    border-radius: 999px;
    padding: 9px 20px;
    margin-bottom: 30px;
    animation: orFade .8s ease both;
}
.oneroof-home-hero-tagline::before {
    content: "";
    width: 8px; height: 8px; border-radius: 50%;
    background: var(--or-gold);
    box-shadow: 0 0 12px 2px var(--or-glow-gold);
    animation: orPulse 2s infinite;
}
.oneroof-home-hero-title {
    font-family: var(--or-font-display);
    font-weight: 800;
    font-size: clamp(2.6rem, 6.5vw, 5.4rem);
    line-height: 1.02;
    margin-bottom: 22px;
    animation: orRise .9s .05s ease both;
}
.oneroof-home-hero > .oneroof-home-hero-content > p,
.oneroof-home-hero-content > .oneroof-home-sub {
    color: var(--or-text-soft);
    font-size: clamp(1.05rem, 2vw, 1.3rem);
    max-width: 620px;
    margin: 0 auto 46px;
    animation: orRise .9s .12s ease both;
}
.oneroof-home-hero-buttons {
    display: grid;
    grid-template-columns: repeat(2, minmax(0,1fr));
    gap: 26px;
    max-width: 920px;
    margin: 0 auto;
    animation: orRise .9s .2s ease both;
}
.oneroof-home-btn {
    position: relative;
    display: flex;
    align-items: center;
    gap: 20px;
    text-align: left;
    padding: 34px 30px;
    border-radius: var(--or-radius-lg);
    background: var(--or-surface);
    border: 1px solid var(--or-border-2);
    backdrop-filter: blur(14px);
    -webkit-backdrop-filter: blur(14px);
    text-decoration: none;
    color: var(--or-text);
    overflow: hidden;
    transition: transform .3s cubic-bezier(.2,.8,.2,1), border-color .3s, box-shadow .3s;
}
.oneroof-home-btn::before {
    content: "";
    position: absolute; inset: 0;
    background: radial-gradient(420px 200px at 0% 0%, rgba(232,197,114,0.18), transparent 60%);
    opacity: 0; transition: opacity .35s;
}
.oneroof-home-btn-taker::before {
    background: radial-gradient(420px 200px at 100% 0%, rgba(79,216,232,0.18), transparent 60%);
}
.oneroof-home-btn:hover {
    transform: translateY(-6px);
    border-color: var(--or-glow-gold);
    box-shadow: var(--or-shadow-glow);
}
.oneroof-home-btn-taker:hover { box-shadow: 0 24px 60px -24px var(--or-glow-cyan); border-color: rgba(79,216,232,0.5); }
.oneroof-home-btn:hover::before { opacity: 1; }
.oneroof-home-btn-icon {
    font-size: 2.6rem;
    line-height: 1;
    flex-shrink: 0;
    filter: drop-shadow(0 4px 14px var(--or-glow-gold));
}
.oneroof-home-btn-content { position: relative; z-index: 1; flex: 1; }
.oneroof-home-btn-title {
    font-family: var(--or-font-display);
    font-weight: 700;
    font-size: 1.4rem;
    margin: 0 0 6px;
    color: var(--or-text);
}
.oneroof-home-btn-subtitle { color: var(--or-text-mut); font-size: .98rem; margin: 0; }
.oneroof-home-btn-arrow {
    font-size: 1.4rem;
    color: var(--or-gold);
    transition: transform .3s;
}
.oneroof-home-btn:hover .oneroof-home-btn-arrow { transform: translateX(6px); }

.oneroof-home-hero-features {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    gap: 14px 30px;
    margin-top: 50px;
    animation: orFade 1s .35s ease both;
}
.oneroof-home-feature {
    display: inline-flex;
    align-items: center;
    gap: 9px;
    color: var(--or-text-soft);
    font-size: .94rem;
    font-weight: 500;
}
.oneroof-home-feature::before {
    content: "◆";
    color: var(--or-gold);
    font-size: .7rem;
}

/* ============================================================
   SERVICES HUB  (categories grid)
   ============================================================ */
.oneroof-services-hub { padding: 90px 24px 100px; }
.oneroof-services-hero {
    max-width: 820px;
    margin: 0 auto 60px;
    text-align: center;
}
.oneroof-services-title {
    font-family: var(--or-font-display);
    font-weight: 800;
    font-size: clamp(2.2rem, 5vw, 3.8rem);
    margin-bottom: 16px;
}
.oneroof-services-subtitle { color: var(--or-text-soft); font-size: 1.15rem; }

.oneroof-services-group { max-width: 1200px; margin: 0 auto 56px; }
.oneroof-services-group-title {
    font-family: var(--or-font-mono);
    text-transform: uppercase;
    letter-spacing: .18em;
    font-size: .82rem;
    color: var(--or-gold);
    margin: 0 0 22px;
    display: flex;
    align-items: center;
    gap: 14px;
}
.oneroof-services-group-title::after {
    content: "";
    flex: 1; height: 1px;
    background: linear-gradient(90deg, var(--or-glow-gold), transparent);
}
.oneroof-services-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(230px, 1fr));
    gap: 20px;
}
.oneroof-service-tile {
    position: relative;
    display: block;
    padding: 30px 26px;
    border-radius: var(--or-radius);
    background: var(--or-surface);
    border: 1px solid var(--or-border);
    backdrop-filter: blur(12px);
    -webkit-backdrop-filter: blur(12px);
    text-decoration: none;
    color: var(--or-text);
    overflow: hidden;
    transition: transform .3s cubic-bezier(.2,.8,.2,1), border-color .3s, box-shadow .3s;
}
.oneroof-service-tile::before {
    content: "";
    position: absolute; left: 0; top: 0; height: 3px; width: 100%;
    background: var(--or-grad-tech);
    transform: scaleX(0); transform-origin: left;
    transition: transform .35s;
}
.oneroof-service-tile:hover {
    transform: translateY(-6px);
    border-color: var(--or-glow-gold);
    box-shadow: var(--or-shadow-glow);
    background: var(--or-surface-2);
}
.oneroof-service-tile:hover::before { transform: scaleX(1); }
.oneroof-service-tile-icon {
    font-size: 2.3rem;
    margin-bottom: 16px;
    display: block;
    filter: drop-shadow(0 4px 12px var(--or-glow-gold));
}
.oneroof-service-tile-name {
    font-family: var(--or-font-display);
    font-weight: 700;
    font-size: 1.18rem;
    margin: 0 0 8px;
    color: var(--or-text);
}
.oneroof-service-tile-desc { color: var(--or-text-mut); font-size: .92rem; margin: 0 0 14px; }
.oneroof-service-tile-cta {
    font-family: var(--or-font-mono);
    font-size: .8rem;
    color: var(--or-gold);
    letter-spacing: .05em;
    display: inline-flex; align-items: center; gap: 6px;
}
.oneroof-service-tile:hover .oneroof-service-tile-cta { gap: 11px; }

.oneroof-services-cta {
    max-width: 880px;
    margin: 20px auto 0;
    text-align: center;
    padding: 46px 30px;
    border-radius: var(--or-radius-lg);
    background: linear-gradient(135deg, rgba(232,197,114,0.10), rgba(154,139,255,0.08));
    border: 1px solid var(--or-border-2);
}
.oneroof-services-cta h2, .oneroof-services-cta h3 { margin-bottom: 12px; }
.oneroof-services-cta p { color: var(--or-text-soft); margin: 0 0 24px; }

/* ============================================================
   CATEGORY GRID PAGE + FILTERS SIDEBAR
   ============================================================ */
.oneroof-grid-wrapper { padding: 70px 24px 90px; }
.oneroof-grid-header {
    max-width: 1240px;
    margin: 0 auto 36px;
    text-align: center;
}
.oneroof-grid-icon {
    font-size: 3rem;
    display: block;
    margin-bottom: 12px;
    filter: drop-shadow(0 6px 16px var(--or-glow-gold));
}
.oneroof-grid-header h1 {
    font-family: var(--or-font-display);
    font-weight: 800;
    font-size: clamp(2rem, 4.5vw, 3.2rem);
    margin-bottom: 10px;
    color: var(--or-text);
}
.oneroof-grid-count {
    font-family: var(--or-font-mono);
    color: var(--or-gold);
    font-size: .9rem;
    letter-spacing: .05em;
}
.oneroof-grid-desc { color: var(--or-text-soft); max-width: 640px; margin: 12px auto 0; }

.oneroof-grid-layout {
    max-width: 1240px;
    margin: 0 auto;
    display: grid;
    grid-template-columns: 280px 1fr;
    gap: 30px;
    align-items: start;
}

.oneroof-filters-toggle {
    display: none;
    width: 100%;
    margin-bottom: 16px;
    font-family: var(--or-font-body);
    font-weight: 600;
    color: var(--or-text);
    background: var(--or-surface);
    border: 1px solid var(--or-border-2);
    border-radius: var(--or-radius-sm);
    padding: 14px 18px;
    cursor: pointer;
}
.oneroof-filters {
    position: sticky;
    top: 24px;
    background: var(--or-surface);
    border: 1px solid var(--or-border);
    border-radius: var(--or-radius);
    padding: 26px 22px;
    backdrop-filter: blur(12px);
    -webkit-backdrop-filter: blur(12px);
}
.oneroof-filter-group { margin-bottom: 24px; }
.oneroof-filter-group:last-child { margin-bottom: 0; }
.oneroof-filter-label {
    display: block;
    font-family: var(--or-font-mono);
    font-size: .76rem;
    text-transform: uppercase;
    letter-spacing: .14em;
    color: var(--or-gold);
    margin-bottom: 10px;
}
.oneroof-filter-input,
.oneroof-filter-select {
    width: 100%;
    font-family: var(--or-font-body);
    font-size: .95rem;
    color: var(--or-text) !important;
    background: rgba(0,0,0,0.35) !important;
    border: 1px solid var(--or-border-2);
    border-radius: var(--or-radius-sm);
    padding: 12px 14px;
    transition: border-color .2s, box-shadow .2s;
}
.oneroof-filter-input::placeholder { color: var(--or-text-mut); }
.oneroof-filter-input:focus,
.oneroof-filter-select:focus {
    outline: none;
    border-color: var(--or-gold);
    box-shadow: 0 0 0 3px var(--or-glow-gold);
}
.oneroof-filter-select option { background: #0E0E18; color: var(--or-text); }

.oneroof-filter-cats-list { display: flex; flex-direction: column; gap: 6px; max-height: 320px; overflow-y: auto; }
.oneroof-filter-cats-list a,
.oneroof-filter-cats-list li {
    display: flex; align-items: center; gap: 10px;
    padding: 9px 12px;
    border-radius: 10px;
    color: var(--or-text-soft);
    text-decoration: none;
    font-size: .92rem;
    transition: background .2s, color .2s;
    list-style: none;
}
.oneroof-filter-cats-list a:hover { background: var(--or-surface-2); color: var(--or-text); }
.oneroof-filter-cats-list .is-active,
.oneroof-filter-cats-list a.is-active {
    background: linear-gradient(90deg, rgba(232,197,114,0.18), transparent);
    color: var(--or-gold);
    font-weight: 600;
}
.oneroof-filter-cat-icon { font-size: 1.05rem; }
.oneroof-filter-apply-btn { width: 100%; margin-bottom: 10px; padding: 13px; }
.oneroof-filter-reset-btn { width: 100%; justify-content: center; }

/* ============================================================
   PROFILE CARD GRID
   ============================================================ */
.oneroof-grid-main { min-width: 0; }
.oneroof-card-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(270px, 1fr));
    gap: 24px;
}

.oneroof-card {
    position: relative;
    border-radius: var(--or-radius);
    background: var(--or-surface);
    border: 1px solid var(--or-border);
    overflow: hidden;
    backdrop-filter: blur(12px);
    -webkit-backdrop-filter: blur(12px);
    transition: transform .3s cubic-bezier(.2,.8,.2,1), border-color .3s, box-shadow .3s;
    color: var(--or-text);
}
.oneroof-card-active:hover {
    transform: translateY(-7px);
    border-color: var(--or-glow-gold);
    box-shadow: var(--or-shadow-glow);
}
.oneroof-card-featured {
    border-color: rgba(232,197,114,0.45);
    box-shadow: 0 0 0 1px rgba(232,197,114,0.25), var(--or-shadow);
}
.oneroof-card-featured::before {
    content: "";
    position: absolute; inset: 0;
    padding: 1px;
    border-radius: var(--or-radius);
    background: var(--or-grad-aurora);
    -webkit-mask: linear-gradient(#000 0 0) content-box, linear-gradient(#000 0 0);
    -webkit-mask-composite: xor; mask-composite: exclude;
    opacity: .55;
    pointer-events: none;
}
.oneroof-card-link { text-decoration: none; color: inherit; display: block; }

.oneroof-card-photo-wrap {
    position: relative;
    aspect-ratio: 4 / 3;
    overflow: hidden;
    background: linear-gradient(135deg, #14141F, #0C0C16);
}
.oneroof-card-photo { width: 100%; height: 100%; object-fit: cover; transition: transform .5s ease; }
.oneroof-card-active:hover .oneroof-card-photo { transform: scale(1.06); }
.oneroof-card-photo-placeholder {
    width: 100%; height: 100%;
    display: flex; align-items: center; justify-content: center;
    font-size: 3rem; color: rgba(255,255,255,0.18);
    background: radial-gradient(circle at 50% 40%, rgba(232,197,114,0.12), transparent 70%);
}
.oneroof-card-cat-pill {
    position: absolute; top: 12px; left: 12px; z-index: 2;
    font-family: var(--or-font-mono);
    font-size: .68rem; letter-spacing: .06em;
    color: var(--or-text);
    background: rgba(8,8,14,0.7);
    border: 1px solid var(--or-border-2);
    backdrop-filter: blur(6px);
    padding: 5px 11px; border-radius: 999px;
}
.oneroof-card-ribbon {
    position: absolute; top: 12px; right: 12px; z-index: 2;
    font-family: var(--or-font-mono);
    font-size: .66rem; font-weight: 700; letter-spacing: .08em;
    text-transform: uppercase;
    color: #0A0A0F;
    background: var(--or-grad-gold);
    padding: 5px 12px; border-radius: 999px;
    box-shadow: 0 4px 14px -4px var(--or-glow-gold);
}

.oneroof-card-content { padding: 20px 20px 22px; }
.oneroof-card-name {
    font-family: var(--or-font-display);
    font-weight: 700;
    font-size: 1.22rem;
    margin: 0 0 4px;
    color: var(--or-text);
    display: flex; align-items: center; gap: 8px;
}
.oneroof-card-verified { color: var(--or-cyan); font-size: 1rem; filter: drop-shadow(0 0 6px var(--or-glow-cyan)); }
.oneroof-card-tagline { color: var(--or-text-mut); font-size: .92rem; margin: 0 0 16px; min-height: 1.2em; }
.oneroof-card-meta { display: flex; flex-wrap: wrap; gap: 8px 14px; margin-bottom: 16px; }
.oneroof-card-meta-item {
    display: inline-flex; align-items: center; gap: 6px;
    color: var(--or-text-soft); font-size: .86rem;
}
.oneroof-card-rating {
    display: inline-flex; align-items: center; gap: 5px;
    color: var(--or-gold); font-weight: 600; font-size: .88rem;
}
.oneroof-card-price {
    display: flex; align-items: baseline; gap: 7px;
    padding-top: 16px; margin-bottom: 16px;
    border-top: 1px solid var(--or-border);
}
.oneroof-card-price-label { color: var(--or-text-mut); font-size: .78rem; font-family: var(--or-font-mono); }
.oneroof-card-price-value {
    font-family: var(--or-font-mono);
    font-weight: 700; font-size: 1.25rem;
    color: var(--or-gold);
}
.oneroof-card-whatsapp-btn {
    display: flex; align-items: center; justify-content: center; gap: 9px;
    width: 100%;
    font-family: var(--or-font-body); font-weight: 700; font-size: .98rem;
    color: #07140C;
    background: linear-gradient(120deg, #4FE39A, #25C16E);
    border: none; border-radius: 999px;
    padding: 13px 18px; cursor: pointer; text-decoration: none;
    box-shadow: 0 10px 26px -10px rgba(37,193,110,0.6);
    transition: transform .25s, box-shadow .25s, filter .25s;
}
.oneroof-card-whatsapp-btn:hover { transform: translateY(-2px); filter: brightness(1.06); box-shadow: 0 16px 34px -12px rgba(37,193,110,0.7); }

/* ============================================================
   BLURRED CARD  (inactive / unpaid)
   ============================================================ */
.oneroof-card-blurred { position: relative; }
.oneroof-blur-img { filter: blur(9px) saturate(.6) brightness(.7); transform: scale(1.05); }
.oneroof-shimmer {
    background: linear-gradient(90deg, rgba(255,255,255,0.05) 25%, rgba(255,255,255,0.14) 50%, rgba(255,255,255,0.05) 75%);
    background-size: 200% 100%;
    animation: orShimmer 1.6s infinite;
    border-radius: 6px;
}
.oneroof-shimmer-name { height: 22px; width: 60%; margin: 0 auto 10px; }
.oneroof-shimmer-tagline { height: 13px; width: 80%; margin: 0 auto 8px; }
.oneroof-shimmer-meta { height: 13px; width: 45%; margin: 0 auto; }
.oneroof-card-cat-pill-blurred { opacity: .8; }
.oneroof-card-blur-overlay {
    position: absolute; inset: 0; z-index: 3;
    display: flex; flex-direction: column; align-items: center; justify-content: center;
    text-align: center; gap: 10px; padding: 24px;
    background: linear-gradient(180deg, rgba(7,7,12,0.45), rgba(7,7,12,0.82));
    backdrop-filter: blur(2px);
}
.oneroof-card-lock-icon {
    font-size: 2.2rem;
    filter: drop-shadow(0 0 14px var(--or-glow-gold));
}
.oneroof-card-lock-text { color: var(--or-text-soft); font-size: .9rem; max-width: 200px; }
.oneroof-card-blurred-cta {
    margin-top: 6px;
    font-family: var(--or-font-mono); font-size: .8rem; font-weight: 700;
    color: #0A0A0F; background: var(--or-grad-gold);
    padding: 9px 18px; border-radius: 999px; text-decoration: none;
    box-shadow: 0 8px 22px -8px var(--or-glow-gold);
    transition: transform .25s;
}
.oneroof-card-blurred-cta:hover { transform: translateY(-2px); }

/* ============================================================
   LOAD MORE + EMPTY STATE
   ============================================================ */
.oneroof-load-more-wrapper { text-align: center; margin-top: 44px; }
.oneroof-load-more-btn {
    font-family: var(--or-font-body); font-weight: 600;
    color: var(--or-text);
    background: var(--or-surface-2);
    border: 1px solid var(--or-border-2);
    border-radius: 999px; padding: 14px 36px; cursor: pointer;
    transition: border-color .25s, transform .25s, color .25s;
}
.oneroof-load-more-btn:hover { border-color: var(--or-glow-gold); color: var(--or-gold); transform: translateY(-2px); }
.oneroof-loading-indicator { display: flex; align-items: center; justify-content: center; gap: 12px; color: var(--or-text-mut); padding: 30px; }
.oneroof-spinner {
    width: 22px; height: 22px; border-radius: 50%;
    border: 2.5px solid rgba(255,255,255,0.15);
    border-top-color: var(--or-gold);
    animation: orSpin .8s linear infinite;
}
.oneroof-grid-empty {
    grid-column: 1 / -1;
    text-align: center; padding: 70px 24px;
    background: var(--or-surface);
    border: 1px dashed var(--or-border-2);
    border-radius: var(--or-radius);
    color: var(--or-text-soft);
}
.oneroof-grid-empty-icon { font-size: 3.2rem; margin-bottom: 14px; opacity: .8; }

/* ============================================================
   PROFILE FULL PAGE
   ============================================================ */
.oneroof-profile-page-wrapper { padding: 60px 24px 90px; }
.oneroof-profile-page { max-width: 1080px; margin: 0 auto; }
.oneroof-profile-breadcrumb { max-width: 1080px; margin: 0 auto 22px; }
.oneroof-back-link { font-size: .9rem; }

.oneroof-profile-hero {
    position: relative;
    border-radius: var(--or-radius-lg);
    background: var(--or-surface);
    border: 1px solid var(--or-border);
    padding: 36px;
    overflow: hidden;
    backdrop-filter: blur(14px);
    -webkit-backdrop-filter: blur(14px);
}
.oneroof-profile-hero.is-featured::before {
    content: ""; position: absolute; inset: 0; padding: 1px; border-radius: var(--or-radius-lg);
    background: var(--or-grad-aurora);
    -webkit-mask: linear-gradient(#000 0 0) content-box, linear-gradient(#000 0 0);
    -webkit-mask-composite: xor; mask-composite: exclude; opacity: .6; pointer-events: none;
}
.oneroof-profile-hero-grid {
    display: grid;
    grid-template-columns: 220px 1fr;
    gap: 32px;
    align-items: center;
    position: relative; z-index: 1;
}
.oneroof-profile-hero-photo {
    aspect-ratio: 1; border-radius: var(--or-radius);
    overflow: hidden; border: 1px solid var(--or-border-2);
    background: linear-gradient(135deg, #14141F, #0C0C16);
}
.oneroof-profile-photo-img { width: 100%; height: 100%; object-fit: cover; }
.oneroof-profile-photo-placeholder {
    width: 100%; height: 100%; display: flex; align-items: center; justify-content: center;
    font-size: 4rem; color: rgba(255,255,255,0.18);
}
.oneroof-profile-hero-ribbon {
    display: inline-flex; align-items: center; gap: 7px;
    font-family: var(--or-font-mono); font-size: .72rem; font-weight: 700;
    letter-spacing: .08em; text-transform: uppercase;
    color: #0A0A0F; background: var(--or-grad-gold);
    padding: 5px 13px; border-radius: 999px; margin-bottom: 14px;
}
.oneroof-profile-name {
    font-family: var(--or-font-display); font-weight: 800;
    font-size: clamp(1.9rem, 4vw, 3rem);
    margin: 0 0 14px; color: var(--or-text);
}
.oneroof-profile-categories { display: flex; flex-wrap: wrap; gap: 8px; margin-bottom: 22px; }
.oneroof-profile-cat-chip {
    font-family: var(--or-font-mono); font-size: .76rem;
    color: var(--or-gold);
    background: rgba(232,197,114,0.10);
    border: 1px solid var(--or-glow-gold);
    padding: 5px 13px; border-radius: 999px;
}
.oneroof-profile-whatsapp-btn {
    display: inline-flex; align-items: center; gap: 10px;
    font-family: var(--or-font-body); font-weight: 700; font-size: 1.02rem;
    color: #07140C;
    background: linear-gradient(120deg, #4FE39A, #25C16E);
    border: none; border-radius: 999px; padding: 15px 30px;
    cursor: pointer; text-decoration: none;
    box-shadow: 0 12px 30px -10px rgba(37,193,110,0.6);
    transition: transform .25s, filter .25s;
}
.oneroof-profile-whatsapp-btn:hover { transform: translateY(-3px); filter: brightness(1.06); }

.oneroof-profile-bio {
    margin: 34px 0;
    color: var(--or-text-soft);
    font-size: 1.05rem; line-height: 1.8;
}
.oneroof-profile-details-grid {
    display: grid; grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
    gap: 14px; margin: 30px 0;
}
.oneroof-detail-row {
    display: flex; flex-direction: column; gap: 5px;
    background: var(--or-surface); border: 1px solid var(--or-border);
    border-radius: var(--or-radius-sm); padding: 16px 18px;
}
.oneroof-detail-label {
    font-family: var(--or-font-mono); font-size: .72rem;
    text-transform: uppercase; letter-spacing: .12em; color: var(--or-text-mut);
}
.oneroof-detail-value { color: var(--or-text); font-weight: 600; }
.oneroof-detail-chip {
    display: inline-block; margin: 2px 4px 2px 0;
    font-size: .82rem; color: var(--or-text-soft);
    background: var(--or-surface-2); border: 1px solid var(--or-border);
    padding: 4px 11px; border-radius: 999px;
}
.oneroof-yes { color: var(--or-success); font-weight: 600; }
.oneroof-no  { color: var(--or-text-mut); }

.oneroof-profile-audio { width: 100%; margin: 10px 0; }
.oneroof-profile-audio audio { width: 100%; }
.oneroof-profile-image-sample {
    border-radius: var(--or-radius-sm); overflow: hidden;
    border: 1px solid var(--or-border); margin: 10px 0;
}
.oneroof-profile-image-sample img { width: 100%; display: block; }
.oneroof-profile-file-link {
    display: inline-flex; align-items: center; gap: 9px;
    color: var(--or-gold); font-weight: 600; text-decoration: none;
    background: var(--or-surface); border: 1px solid var(--or-glow-gold);
    padding: 11px 18px; border-radius: var(--or-radius-sm); margin: 8px 0;
    transition: background .2s, transform .2s;
}
.oneroof-profile-file-link:hover { background: var(--or-surface-2); transform: translateY(-2px); }

.oneroof-profile-bottom-cta {
    display: flex; flex-wrap: wrap; gap: 14px; align-items: center; justify-content: center;
    margin-top: 44px; padding: 36px;
    border-radius: var(--or-radius-lg);
    background: linear-gradient(135deg, rgba(232,197,114,0.10), rgba(154,139,255,0.08));
    border: 1px solid var(--or-border-2);
}

/* Section headings inside profile */
.oneroof-profile-page h2, .oneroof-profile-page h3 {
    font-family: var(--or-font-display); color: var(--or-text);
    margin: 36px 0 16px; font-size: 1.5rem;
    display: flex; align-items: center; gap: 12px;
}
.oneroof-profile-page h2::before {
    content: ""; width: 4px; height: 1.1em; border-radius: 4px;
    background: var(--or-grad-gold);
}

/* ============================================================
   MODAL  (quick view on card click)
   ============================================================ */
.oneroof-modal {
    position: fixed; inset: 0; z-index: 99999;
    display: none; align-items: flex-start; justify-content: center;
    padding: 40px 20px; overflow-y: auto;
}
.oneroof-modal.is-open { display: flex; }
.oneroof-modal-overlay {
    position: fixed; inset: 0;
    background: rgba(4,4,9,0.78);
    backdrop-filter: blur(8px); -webkit-backdrop-filter: blur(8px);
    animation: orFade .25s ease both;
}
.oneroof-modal-body {
    position: relative; z-index: 1;
    width: 100%; max-width: 920px;
    background: var(--or-bg-2);
    border: 1px solid var(--or-border-2);
    border-radius: var(--or-radius-lg);
    box-shadow: var(--or-shadow);
    padding: 30px;
    animation: orRise .35s ease both;
    color: var(--or-text);
}
.oneroof-modal-close {
    position: absolute; top: 16px; right: 16px; z-index: 2;
    width: 40px; height: 40px; border-radius: 50%;
    display: flex; align-items: center; justify-content: center;
    font-size: 1.2rem; color: var(--or-text);
    background: var(--or-surface-2); border: 1px solid var(--or-border-2);
    cursor: pointer; transition: background .2s, transform .2s, color .2s;
}
.oneroof-modal-close:hover { background: var(--or-error); color: #fff; transform: rotate(90deg); }
.oneroof-modal-loading { display: flex; align-items: center; justify-content: center; gap: 12px; padding: 60px; color: var(--or-text-mut); }
/* Inside the modal, the profile page sheds its full-bleed shell */
.oneroof-modal-body .oneroof-profile-page-wrapper {
    width: auto; left: auto; right: auto; margin: 0; padding: 0; background: transparent; overflow: visible;
}
.oneroof-modal-body .oneroof-profile-page-wrapper::before,
.oneroof-modal-body .oneroof-profile-page-wrapper::after { display: none; }

/* ============================================================
   SUBMISSION FORM
   ============================================================ */
.oneroof-form-wrapper { padding: 70px 24px 90px; }
.oneroof-form-wrapper > * { max-width: 920px; margin-left: auto; margin-right: auto; }

.oneroof-form-error {
    background: rgba(255,107,107,0.12);
    border: 1px solid rgba(255,107,107,0.4);
    border-left: 4px solid var(--or-error);
    color: #FFB4B4;
    padding: 16px 20px; border-radius: var(--or-radius-sm);
    margin-bottom: 26px; font-weight: 500;
}

.oneroof-form-header { text-align: center; margin-bottom: 44px; }
.oneroof-form-header h1 {
    font-family: var(--or-font-display); font-weight: 800;
    font-size: clamp(2rem, 4.5vw, 3.2rem); margin-bottom: 12px;
}
.oneroof-form-subtitle { color: var(--or-text-soft); font-size: 1.1rem; }

/* Plan tier preview */
.oneroof-tiers-preview {
    display: grid; grid-template-columns: repeat(3, 1fr);
    gap: 16px; margin-bottom: 44px;
}
.oneroof-tier {
    background: var(--or-surface); border: 1px solid var(--or-border);
    border-radius: var(--or-radius); padding: 22px; text-align: center;
    transition: border-color .3s, transform .3s;
}
.oneroof-tier:hover { transform: translateY(-4px); border-color: var(--or-glow-gold); }
.oneroof-tier-name { font-family: var(--or-font-display); font-weight: 700; color: var(--or-text); margin: 0 0 8px; }
.oneroof-tier-price { font-family: var(--or-font-mono); font-weight: 700; font-size: 1.5rem; color: var(--or-gold); margin: 0 0 6px; }
.oneroof-tier-detail { color: var(--or-text-mut); font-size: .85rem; margin: 2px 0; }
.oneroof-tier-note { color: var(--or-text-soft); font-size: .8rem; margin-top: 10px; }

.oneroof-form-section {
    background: var(--or-surface);
    border: 1px solid var(--or-border);
    border-radius: var(--or-radius-lg);
    padding: 32px;
    margin-bottom: 26px;
    backdrop-filter: blur(12px); -webkit-backdrop-filter: blur(12px);
}
.oneroof-section-title {
    font-family: var(--or-font-display); font-weight: 700;
    font-size: 1.4rem; color: var(--or-text);
    margin: 0 0 8px; display: flex; align-items: center; gap: 14px;
}
.oneroof-step-num {
    width: 36px; height: 36px; flex-shrink: 0;
    display: inline-flex; align-items: center; justify-content: center;
    font-family: var(--or-font-mono); font-weight: 700; font-size: .95rem;
    color: #0A0A0F; background: var(--or-grad-gold);
    border-radius: 50%; box-shadow: 0 6px 16px -6px var(--or-glow-gold);
}
.oneroof-section-desc { color: var(--or-text-mut); margin: 0 0 22px; padding-left: 50px; }

/* Category picker tiles */
.oneroof-category-tiles {
    display: grid; grid-template-columns: repeat(auto-fill, minmax(150px, 1fr));
    gap: 12px; margin-top: 8px;
}
.oneroof-cat-tile { position: relative; cursor: pointer; }
.oneroof-cat-checkbox { position: absolute; opacity: 0; pointer-events: none; }
.oneroof-cat-tile-label,
.oneroof-cat-tile > label,
.oneroof-cat-tile span {
    display: block;
}
.oneroof-cat-tile {
    display: flex; flex-direction: column; align-items: center; gap: 8px;
    text-align: center;
    background: rgba(0,0,0,0.3);
    border: 1px solid var(--or-border-2);
    border-radius: var(--or-radius-sm);
    padding: 18px 12px;
    transition: border-color .25s, background .25s, transform .25s;
}
.oneroof-cat-tile:hover { border-color: var(--or-glow-gold); transform: translateY(-3px); }
.oneroof-cat-checkbox:checked + .oneroof-cat-tile,
.oneroof-cat-tile:has(.oneroof-cat-checkbox:checked) {
    border-color: var(--or-gold);
    background: linear-gradient(135deg, rgba(232,197,114,0.18), rgba(154,139,255,0.10));
    box-shadow: 0 0 0 2px var(--or-glow-gold);
}
.oneroof-cat-tile-icon { font-size: 1.8rem; }
.oneroof-cat-tile-name { font-size: .88rem; font-weight: 600; color: var(--or-text); }

/* Fields */
.oneroof-fields-grid {
    display: grid; grid-template-columns: repeat(2, 1fr);
    gap: 18px;
}
.oneroof-field { display: flex; flex-direction: column; gap: 8px; }
.oneroof-field-full { grid-column: 1 / -1; }
.oneroof-field label,
.oneroof-group-title,
.oneroof-checkbox-line label {
    font-family: var(--or-font-body); font-weight: 600; font-size: .92rem;
    color: var(--or-text-soft);
}
.oneroof-req { color: var(--or-error); margin-left: 3px; }

.oneroof-field input,
.oneroof-field select,
.oneroof-field textarea,
.oneroof-profile-form input[type="text"],
.oneroof-profile-form input[type="email"],
.oneroof-profile-form input[type="tel"],
.oneroof-profile-form input[type="number"],
.oneroof-profile-form input[type="url"],
.oneroof-profile-form select,
.oneroof-profile-form textarea,
.oneroof-review-form input,
.oneroof-review-form textarea {
    width: 100%;
    font-family: var(--or-font-body); font-size: .98rem;
    color: var(--or-text) !important;
    background: rgba(0,0,0,0.35) !important;
    border: 1px solid var(--or-border-2);
    border-radius: var(--or-radius-sm);
    padding: 13px 15px;
    transition: border-color .2s, box-shadow .2s, background .2s;
    -webkit-text-fill-color: var(--or-text);
}
.oneroof-field textarea,
.oneroof-profile-form textarea,
.oneroof-review-form textarea { min-height: 130px; resize: vertical; line-height: 1.6; }
.oneroof-field input::placeholder,
.oneroof-field textarea::placeholder,
.oneroof-profile-form input::placeholder,
.oneroof-profile-form textarea::placeholder,
.oneroof-review-form input::placeholder,
.oneroof-review-form textarea::placeholder { color: var(--or-text-mut); opacity: 1; }
.oneroof-field input:focus,
.oneroof-field select:focus,
.oneroof-field textarea:focus,
.oneroof-profile-form input:focus,
.oneroof-profile-form select:focus,
.oneroof-profile-form textarea:focus,
.oneroof-review-form input:focus,
.oneroof-review-form textarea:focus {
    outline: none;
    border-color: var(--or-gold);
    background: rgba(0,0,0,0.5) !important;
    box-shadow: 0 0 0 3px var(--or-glow-gold);
}
.oneroof-field select option,
.oneroof-profile-form select option { background: #0E0E18; color: var(--or-text); }
/* File inputs */
.oneroof-field input[type="file"] {
    padding: 11px 14px; cursor: pointer; color: var(--or-text-soft) !important;
}
.oneroof-field input[type="file"]::file-selector-button {
    font-family: var(--or-font-body); font-weight: 600;
    color: #0A0A0F; background: var(--or-grad-gold);
    border: none; border-radius: 999px; padding: 8px 16px; margin-right: 12px;
    cursor: pointer;
}

/* Chip group (multi-select) */
.oneroof-chip-group { display: flex; flex-wrap: wrap; gap: 9px; }
.oneroof-chip {
    display: inline-flex; align-items: center; gap: 7px;
    cursor: pointer; user-select: none;
    color: var(--or-text-soft); font-size: .9rem;
    background: rgba(0,0,0,0.3); border: 1px solid var(--or-border-2);
    padding: 9px 16px; border-radius: 999px;
    transition: border-color .2s, color .2s, background .2s;
}
.oneroof-chip:hover { border-color: var(--or-glow-gold); color: var(--or-text); }
.oneroof-chip input { accent-color: var(--or-gold); }
.oneroof-chip:has(input:checked) {
    border-color: var(--or-gold); color: var(--or-gold);
    background: rgba(232,197,114,0.12);
}

/* Dynamic per-category block */
.oneroof-specific-cat-block {
    margin-top: 18px; padding-top: 18px;
    border-top: 1px dashed var(--or-border-2);
}
.oneroof-group-title {
    display: block; margin-bottom: 14px;
    font-family: var(--or-font-mono); font-size: .8rem;
    text-transform: uppercase; letter-spacing: .12em; color: var(--or-gold);
}

/* Disclosure / terms box */
.oneroof-disclosure {
    background: rgba(0,0,0,0.25);
    border: 1px solid var(--or-border);
    border-radius: var(--or-radius-sm);
    padding: 18px 20px; color: var(--or-text-soft); font-size: .92rem;
}
.oneroof-disclosure summary { cursor: pointer; color: var(--or-gold); font-weight: 600; }
.oneroof-checkbox-line {
    display: flex; align-items: flex-start; gap: 11px;
    margin-top: 18px; color: var(--or-text-soft);
}
.oneroof-checkbox-line input { margin-top: 3px; accent-color: var(--or-gold); width: 18px; height: 18px; }

.oneroof-submit-btn { width: 100%; padding: 17px; font-size: 1.1rem; margin-top: 8px; }

/* ============================================================
   SUCCESS / THANK-YOU PAGE
   ============================================================ */
.oneroof-success-wrapper {
    min-height: 80vh; display: flex; align-items: center;
    padding: 70px 24px;
}
.oneroof-success-wrapper > * { max-width: 680px; margin-left: auto; margin-right: auto; }
.oneroof-success-wrapper { text-align: center; }
.oneroof-success-icon {
    font-size: 4.5rem; margin-bottom: 20px;
    filter: drop-shadow(0 0 24px var(--or-glow-gold));
    animation: orPop .6s cubic-bezier(.2,1.4,.4,1) both;
}
.oneroof-success-title {
    font-family: var(--or-font-display); font-weight: 800;
    font-size: clamp(2rem, 5vw, 3rem); margin-bottom: 14px;
}
.oneroof-success-message { color: var(--or-text-soft); font-size: 1.12rem; margin-bottom: 18px; }
.oneroof-success-id {
    display: inline-block; font-family: var(--or-font-mono);
    color: var(--or-gold); background: var(--or-surface);
    border: 1px solid var(--or-glow-gold);
    padding: 8px 18px; border-radius: 999px; margin-bottom: 36px;
}
.oneroof-next-steps {
    text-align: left; margin: 0 auto 36px; max-width: 520px;
    display: flex; flex-direction: column; gap: 16px;
}
.oneroof-step {
    display: flex; align-items: flex-start; gap: 16px;
    background: var(--or-surface); border: 1px solid var(--or-border);
    border-radius: var(--or-radius); padding: 18px 20px;
}
.oneroof-step-num-circle {
    width: 34px; height: 34px; flex-shrink: 0;
    display: flex; align-items: center; justify-content: center;
    font-family: var(--or-font-mono); font-weight: 700;
    color: #0A0A0F; background: var(--or-grad-gold); border-radius: 50%;
}
.oneroof-step-content { color: var(--or-text-soft); }
.oneroof-step-content strong { color: var(--or-text); display: block; margin-bottom: 3px; }
.oneroof-success-cta { display: flex; gap: 14px; justify-content: center; flex-wrap: wrap; }

/* ============================================================
   REVIEWS
   ============================================================ */
.oneroof-reviews-section { max-width: 1080px; margin: 50px auto 0; }
.oneroof-reviews-summary,
.oneroof-reviews-avg {
    display: flex; align-items: center; gap: 22px;
    background: var(--or-surface); border: 1px solid var(--or-border);
    border-radius: var(--or-radius); padding: 24px 28px; margin-bottom: 26px;
    flex-wrap: wrap;
}
.oneroof-reviews-avg-num,
.oneroof-rating-num {
    font-family: var(--or-font-display); font-weight: 800;
    font-size: 2.8rem; color: var(--or-gold); line-height: 1;
}
.oneroof-reviews-avg-meta, .oneroof-reviews-avg-text { color: var(--or-text-soft); }
.oneroof-reviews-count, .oneroof-rating-count { color: var(--or-text-mut); font-size: .9rem; }
.oneroof-stars, .oneroof-review-stars, .oneroof-star-selector { display: inline-flex; gap: 3px; }
.oneroof-star { color: var(--or-gold); font-size: 1.05rem; filter: drop-shadow(0 0 6px var(--or-glow-gold)); }
.oneroof-star.is-empty, .oneroof-star.empty { color: rgba(255,255,255,0.18); filter: none; }

.oneroof-reviews-list { display: flex; flex-direction: column; gap: 16px; }
.oneroof-review {
    background: var(--or-surface); border: 1px solid var(--or-border);
    border-radius: var(--or-radius); padding: 22px 24px;
}
.oneroof-review-header { display: flex; align-items: center; gap: 14px; margin-bottom: 12px; }
.oneroof-review-avatar {
    width: 46px; height: 46px; flex-shrink: 0; border-radius: 50%;
    display: flex; align-items: center; justify-content: center;
    font-family: var(--or-font-display); font-weight: 700; font-size: 1.1rem;
    color: #0A0A0F; background: var(--or-grad-gold);
}
.oneroof-review-meta { flex: 1; }
.oneroof-review-name { font-weight: 700; color: var(--or-text); display: flex; align-items: center; gap: 8px; }
.oneroof-review-verified-badge { color: var(--or-success); font-size: .85rem; display: inline-flex; align-items: center; gap: 4px; }
.oneroof-review-city, .oneroof-review-date { color: var(--or-text-mut); font-size: .82rem; }
.oneroof-review-text, .oneroof-review-text-cell { color: var(--or-text-soft); line-height: 1.7; }

.oneroof-reviews-empty {
    text-align: center; padding: 40px; color: var(--or-text-mut);
    background: var(--or-surface); border: 1px dashed var(--or-border-2);
    border-radius: var(--or-radius);
}

/* Review submission form */
.oneroof-review-toggle { text-align: center; margin: 26px 0; }
.oneroof-review-form-wrap,
.oneroof-review-form {
    background: var(--or-surface); border: 1px solid var(--or-border);
    border-radius: var(--or-radius-lg); padding: 30px; margin-top: 20px;
    backdrop-filter: blur(12px); -webkit-backdrop-filter: blur(12px);
}
.oneroof-review-sub { color: var(--or-text-mut); margin-bottom: 20px; }
.oneroof-review-form-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 16px; }
.oneroof-review-form-field { display: flex; flex-direction: column; gap: 8px; }
.oneroof-review-form-field.full { grid-column: 1 / -1; }
.oneroof-review-rating { margin: 6px 0 16px; }
.oneroof-star-pick {
    cursor: pointer; font-size: 1.9rem; color: rgba(255,255,255,0.2);
    transition: color .15s, transform .15s; background: none; border: none; padding: 0 2px;
}
.oneroof-star-pick:hover, .oneroof-star-pick.is-active, .oneroof-star-pick.active {
    color: var(--or-gold); transform: scale(1.12);
    filter: drop-shadow(0 0 8px var(--or-glow-gold));
}
.oneroof-review-submit-btn { margin-top: 10px; }
.oneroof-review-form-message, .oneroof-msg-success, .oneroof-msg-error {
    border-radius: var(--or-radius-sm); padding: 14px 18px; margin-top: 16px; font-weight: 500;
}
.oneroof-msg-success, .oneroof-review-form-message.success {
    background: rgba(70,229,160,0.12); border: 1px solid rgba(70,229,160,0.4); color: #9CF3CE;
}
.oneroof-msg-error, .oneroof-review-form-message.error {
    background: rgba(255,107,107,0.12); border: 1px solid rgba(255,107,107,0.4); color: #FFB4B4;
}

/* Review tabs/table (if used) */
.oneroof-review-tabs { display: flex; gap: 8px; margin-bottom: 18px; flex-wrap: wrap; }

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media (max-width: 1024px) {
    .oneroof-grid-layout { grid-template-columns: 1fr; }
    .oneroof-filters-toggle { display: block; }
    .oneroof-filters { position: static; display: none; }
    .oneroof-filters.is-open { display: block; }
    .oneroof-profile-hero-grid { grid-template-columns: 160px 1fr; gap: 24px; }
}

@media (max-width: 768px) {
    .oneroof-home-hero-buttons { grid-template-columns: 1fr; }
    .oneroof-tiers-preview { grid-template-columns: 1fr; }
    .oneroof-fields-grid,
    .oneroof-review-form-grid { grid-template-columns: 1fr; }
    .oneroof-form-section { padding: 24px 20px; }
    .oneroof-section-desc { padding-left: 0; }
    .oneroof-profile-hero { padding: 24px; }
    .oneroof-profile-hero-grid { grid-template-columns: 1fr; text-align: center; }
    .oneroof-profile-hero-photo { max-width: 200px; margin: 0 auto; }
    .oneroof-profile-categories { justify-content: center; }
}

@media (max-width: 640px) {
    .oneroof-home-hero,
    .oneroof-services-hub,
    .oneroof-grid-wrapper,
    .oneroof-profile-page-wrapper,
    .oneroof-form-wrapper,
    .oneroof-success-wrapper { padding-left: 16px; padding-right: 16px; }
    .oneroof-card-grid { grid-template-columns: 1fr; }
    .oneroof-home-btn { flex-direction: column; text-align: center; align-items: center; }
    .oneroof-modal { padding: 16px; }
    .oneroof-modal-body { padding: 22px 18px; }
}

/* Respect reduced motion */
@media (prefers-reduced-motion: reduce) {
    .oneroof-form-wrapper *, .oneroof-home-hero *, .oneroof-services-hub *,
    .oneroof-grid-wrapper *, .oneroof-profile-page-wrapper *, .oneroof-success-wrapper *,
    .oneroof-modal * { animation: none !important; transition: none !important; }
}

/* ============================================================
   KEYFRAMES
   ============================================================ */
@keyframes orRise   { from { opacity: 0; transform: translateY(22px); } to { opacity: 1; transform: none; } }
@keyframes orFade   { from { opacity: 0; } to { opacity: 1; } }
@keyframes orPop    { from { opacity: 0; transform: scale(.5); } to { opacity: 1; transform: scale(1); } }
@keyframes orSpin   { to { transform: rotate(360deg); } }
@keyframes orPulse  { 0%,100% { transform: scale(1); opacity: 1; } 50% { transform: scale(1.5); opacity: .5; } }
@keyframes orShimmer{ 0% { background-position: 200% 0; } 100% { background-position: -200% 0; } }

/* ============================================================
   v2.1 — ENHANCED FUTURISTIC FLAIR + NEW ELEMENTS
   ============================================================ */

/* Living glow + slowly panning grid behind the hero */
.oneroof-home-hero::before { animation: orDrift 22s ease-in-out infinite alternate; }
.oneroof-home-hero::after  { animation: orGridPan 40s linear infinite; }

/* Eyebrow pill (small label above the headline) */
.oneroof-home-hero-eyebrow {
    display: inline-flex;
    align-items: center;
    gap: 9px;
    font-family: var(--or-font-mono);
    font-size: .78rem;
    letter-spacing: .26em;
    text-transform: uppercase;
    color: var(--or-gold);
    background: var(--or-surface);
    border: 1px solid var(--or-glow-gold);
    border-radius: 999px;
    padding: 8px 18px;
    margin-bottom: 26px;
    animation: orFade .8s ease both;
}
.oneroof-home-hero-eyebrow::before {
    content: "";
    width: 8px; height: 8px; border-radius: 50%;
    background: var(--or-gold);
    box-shadow: 0 0 12px 2px var(--or-glow-gold);
    animation: orPulse 2s infinite;
}

/* Tagline is now a plain subtitle sentence — override the old pill look */
.oneroof-home-hero-tagline {
    display: block;
    background: none;
    border: none;
    border-radius: 0;
    padding: 0;
    margin: 0 auto 46px;
    max-width: 660px;
    font-family: var(--or-font-body);
    font-size: clamp(1.05rem, 2vw, 1.32rem);
    letter-spacing: normal;
    text-transform: none;
    color: var(--or-text-soft);
    animation: orRise .9s .12s ease both;
}
.oneroof-home-hero-tagline::before { content: none; }

/* Animated aurora headline — guarded so it can NEVER become invisible text
   if background-clip:text is unsupported (the title stays solid light then). */
@supports ((-webkit-background-clip: text) or (background-clip: text)) {
    .oneroof-home-hero-title {
        background: var(--or-grad-aurora);
        background-size: 240% auto;
        -webkit-background-clip: text;
                background-clip: text;
        -webkit-text-fill-color: transparent;
        animation: orRise .9s .05s ease both, orHue 9s ease-in-out infinite;
    }
}

/* Slim trust line (replaces the three feature pills) */
.oneroof-home-hero > .oneroof-home-hero-content > .oneroof-home-hero-trust {
    margin: 46px auto 0;
    max-width: 720px;
    font-family: var(--or-font-mono);
    font-size: .82rem;
    letter-spacing: .12em;
    color: var(--or-text-mut);
    animation: orFade 1s .35s ease both;
}

/* Floating hero icons + a light sheen that sweeps across buttons on hover */
.oneroof-home-btn-icon { animation: orFloat 5s ease-in-out infinite; }
.oneroof-home-btn-taker .oneroof-home-btn-icon { animation-delay: .6s; }
.oneroof-home-btn::after {
    content: "";
    position: absolute;
    top: 0; bottom: 0;
    left: -60%;
    width: 40%;
    background: linear-gradient(100deg, transparent, rgba(255,255,255,0.14), transparent);
    transform: skewX(-18deg);
    opacity: 0;
    z-index: 1;
    pointer-events: none;
}
.oneroof-home-btn:hover::after {
    opacity: 1;
    animation: orSheen 1.1s ease forwards;
}

/* Free-to-list reassurance card on the submission form */
.oneroof-form-reassure {
    position: relative;
    z-index: 1;
    max-width: 760px;
    margin: 0 auto 34px;
    text-align: center;
    background: var(--or-surface);
    border: 1px solid var(--or-border-2);
    border-radius: var(--or-radius);
    padding: 22px 26px;
    backdrop-filter: blur(12px);
    -webkit-backdrop-filter: blur(12px);
    animation: orRise .8s .1s ease both;
}
.oneroof-form-reassure-badge {
    display: inline-block;
    font-family: var(--or-font-mono);
    font-size: .74rem;
    letter-spacing: .2em;
    text-transform: uppercase;
    color: #0A0A0F;
    background: var(--or-grad-gold);
    border-radius: 999px;
    padding: 6px 16px;
    margin-bottom: 12px;
    box-shadow: 0 8px 24px -10px var(--or-glow-gold);
}
.oneroof-form-reassure-text {
    margin: 0;
    color: var(--or-text-soft);
    font-size: 1.02rem;
    line-height: 1.6;
}

/* Plans & pricing block on the success (next) page */
.oneroof-success-plans {
    position: relative;
    z-index: 1;
    margin: 40px auto 10px;
    max-width: 920px;
    text-align: center;
}
.oneroof-success-plans h3 {
    font-family: var(--or-font-display);
    font-weight: 700;
    font-size: 1.5rem;
    color: var(--or-text);
    margin: 0 0 6px;
}
.oneroof-success-plans-sub {
    color: var(--or-text-mut);
    font-size: .96rem;
    margin: 0 0 24px;
}

/* Tier cards: lift + glow on hover (adds life to the pricing) */
.oneroof-tier {
    transition: transform .3s cubic-bezier(.2,.8,.2,1), border-color .3s, box-shadow .3s;
}
.oneroof-tier:hover {
    transform: translateY(-6px);
    border-color: var(--or-glow-gold);
    box-shadow: var(--or-shadow-glow);
}

/* New keyframes for the flair above */
@keyframes orDrift {
    0%   { transform: translate3d(0, 0, 0) scale(1); }
    100% { transform: translate3d(0, -2%, 0) scale(1.06); }
}
@keyframes orGridPan {
    0%   { background-position: 0 0, 0 0; }
    100% { background-position: 56px 56px, 56px 56px; }
}
@keyframes orHue {
    0%, 100% { background-position: 0% 50%; }
    50%      { background-position: 100% 50%; }
}
@keyframes orFloat {
    0%, 100% { transform: translateY(0); }
    50%      { transform: translateY(-7px); }
}
@keyframes orSheen {
    0%   { left: -60%; }
    100% { left: 130%; }
}

/* ============================================================
   v2.3 — PROFILE PAGE: fill in the 20 unstyled classes that
   were causing "glued"/cramped pages, + creative enhancements
   ============================================================ */

/* Section rhythm — the main fix for sections butting together */
.oneroof-profile-section,
.oneroof-reviews-section {
    position: relative;
    margin-top: 40px;
    padding: 30px 32px;
    background: var(--or-surface);
    border: 1px solid var(--or-border);
    border-radius: var(--or-radius-lg);
    backdrop-filter: blur(12px);
    -webkit-backdrop-filter: blur(12px);
    animation: orRise .7s ease both;
}

/* Section titles with a gradient accent bar to the left */
.oneroof-profile-section-title {
    position: relative;
    font-family: var(--or-font-display);
    font-weight: 700;
    font-size: 1.35rem;
    color: var(--or-text);
    margin: 0 0 20px;
    padding-left: 16px;
}
.oneroof-profile-section-title::before {
    content: "";
    position: absolute;
    left: 0; top: 50%;
    transform: translateY(-50%);
    width: 5px; height: 1.1em;
    border-radius: 3px;
    background: var(--or-grad-gold);
    box-shadow: 0 0 14px -1px var(--or-glow-gold);
}

/* Hero info column + tagline + rating spacing */
.oneroof-profile-hero-info { min-width: 0; }
.oneroof-profile-tagline {
    margin: 0 0 18px;
    font-size: 1.08rem;
    line-height: 1.6;
    color: var(--or-text-soft);
}
.oneroof-profile-rating { margin: 0 0 22px; }

/* Verified badge next to the name */
.oneroof-profile-verified-badge {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    vertical-align: middle;
    margin-left: 10px;
    font-family: var(--or-font-mono);
    font-size: .66rem;
    font-weight: 700;
    letter-spacing: .1em;
    text-transform: uppercase;
    color: var(--or-cyan);
    background: rgba(79,216,232,0.10);
    border: 1px solid var(--or-glow-cyan);
    padding: 4px 11px;
    border-radius: 999px;
}

/* QUICK STATS — was rendering as unstyled inline text. Now glass tiles. */
.oneroof-profile-stats {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(150px, 1fr));
    gap: 14px;
    margin: 26px 0;
}
.oneroof-stat {
    display: flex;
    align-items: center;
    gap: 13px;
    padding: 15px 17px;
    background: var(--or-surface-2);
    border: 1px solid var(--or-border);
    border-radius: var(--or-radius-sm);
    transition: transform .25s, border-color .25s, box-shadow .25s;
}
.oneroof-stat:hover {
    transform: translateY(-3px);
    border-color: var(--or-glow-gold);
    box-shadow: var(--or-shadow-glow);
}
.oneroof-stat-icon {
    flex-shrink: 0;
    font-size: 1.5rem;
    line-height: 1;
    width: 44px; height: 44px;
    display: flex; align-items: center; justify-content: center;
    border-radius: 12px;
    background: rgba(232,197,114,0.08);
    border: 1px solid var(--or-glow-gold);
}
.oneroof-stat-content { display: flex; flex-direction: column; gap: 3px; min-width: 0; }
.oneroof-stat-label {
    font-family: var(--or-font-mono);
    font-size: .68rem;
    letter-spacing: .1em;
    text-transform: uppercase;
    color: var(--or-text-mut);
}
.oneroof-stat-value {
    font-weight: 600;
    color: var(--or-text);
    font-size: 1rem;
    line-height: 1.3;
}
.oneroof-stat-price .oneroof-stat-value { color: var(--or-gold); }
.oneroof-stat-price .oneroof-stat-icon {
    background: var(--or-grad-gold);
    border-color: transparent;
}

/* WhatsApp note under the CTA */
.oneroof-profile-whatsapp-note {
    margin: 12px 0 0;
    font-size: .85rem;
    color: var(--or-text-mut);
}

/* Large WhatsApp button (bottom CTA) */
.oneroof-profile-whatsapp-btn-large {
    display: inline-flex;
    align-items: center;
    gap: 11px;
    font-family: var(--or-font-body);
    font-weight: 700;
    font-size: 1.1rem;
    color: #07140C;
    background: linear-gradient(120deg, #4FE39A, #25C16E);
    border: none;
    border-radius: 999px;
    padding: 17px 38px;
    cursor: pointer;
    text-decoration: none;
    box-shadow: 0 14px 34px -10px rgba(37,193,110,0.6);
    transition: transform .25s, filter .25s;
}
.oneroof-profile-whatsapp-btn-large:hover { transform: translateY(-3px); filter: brightness(1.06); }

/* Bottom CTA + back-link block spacing */
.oneroof-profile-bottom-cta { text-align: center; margin-top: 40px; }
.oneroof-profile-bottom-back { text-align: center; margin-top: 26px; }

/* Review form fields — these are referenced by ID in the markup, not class */
#oneroof-rev-name,
#oneroof-rev-city,
#oneroof-rev-email,
#oneroof-rev-whatsapp,
#oneroof-rev-text {
    width: 100%;
    background: var(--or-surface-2);
    border: 1px solid var(--or-border-2);
    border-radius: var(--or-radius-sm);
    padding: 12px 14px;
    color: var(--or-text);
    font-family: var(--or-font-body);
    font-size: .98rem;
}
#oneroof-rev-name:focus,
#oneroof-rev-city:focus,
#oneroof-rev-email:focus,
#oneroof-rev-whatsapp:focus,
#oneroof-rev-text:focus {
    outline: none;
    border-color: var(--or-glow-gold);
    box-shadow: 0 0 0 3px rgba(232,197,114,0.12);
}
#oneroof-rev-text { min-height: 120px; resize: vertical; line-height: 1.6; }

/* Mobile: stack the hero so photo + info don't cramp */
@media (max-width: 768px) {
    .oneroof-profile-hero-grid { grid-template-columns: 1fr; gap: 22px; }
    .oneroof-profile-hero-photo { max-width: 200px; margin: 0 auto; }
    .oneroof-profile-section,
    .oneroof-reviews-section { padding: 24px 20px; }
}

/* Grid classes that were missing styles */
.oneroof-grid-title {
    font-family: var(--or-font-display);
    font-weight: 800;
    font-size: clamp(1.6rem, 3.5vw, 2.4rem);
    color: var(--or-text);
    margin: 0 0 6px;
}
.oneroof-filters-form { display: flex; flex-direction: column; gap: 16px; }
.oneroof-filters-toggle-icon { transition: transform .25s; }
.oneroof-filter-cat-name { line-height: 1.3; }
.oneroof-modal-content {
    background: var(--or-surface);
    border: 1px solid var(--or-border-2);
    border-radius: var(--or-radius-lg);
    max-width: 600px;
    width: 100%;
    max-height: 85vh;
    overflow-y: auto;
    padding: 28px;
    box-shadow: var(--or-shadow-glow);
    backdrop-filter: blur(16px);
    -webkit-backdrop-filter: blur(16px);
}

/* Provider button accent (taker already had one) + form classes */
.oneroof-home-btn-provider:hover {
    box-shadow: 0 24px 60px -24px var(--or-glow-gold);
    border-color: rgba(232,197,114,0.5);
}
.oneroof-category-picker {
    display: flex;
    flex-direction: column;
    gap: 18px;
    margin-top: 8px;
}
.oneroof-category-group {
    background: var(--or-surface-2);
    border: 1px solid var(--or-border);
    border-radius: var(--or-radius-sm);
    padding: 16px 18px;
}
.oneroof-submit-note {
    margin: 14px 0 0;
    font-size: .86rem;
    color: var(--or-text-mut);
    text-align: center;
}

/* ============================================================
   v2.4 — PROFILE COMPLETION BAR (submission form)
   ============================================================ */
.orm-progress{
    position:sticky;
    top:12px;
    z-index:20;
    margin:0 0 26px;
    padding:16px 18px;
    background:var(--or-surface);
    border:1px solid var(--or-border-2);
    border-radius:var(--or-radius-sm);
    backdrop-filter:blur(14px);
    -webkit-backdrop-filter:blur(14px);
    box-shadow:0 10px 30px -16px rgba(0,0,0,.6);
}
.orm-progress-head{
    display:flex;
    align-items:center;
    justify-content:space-between;
    margin-bottom:10px;
}
.orm-progress-label{
    font-family:var(--or-font-mono);
    font-size:.72rem;
    letter-spacing:.14em;
    text-transform:uppercase;
    color:var(--or-text-mut);
}
.orm-progress-pct{
    font-family:var(--or-font-display);
    font-weight:800;
    font-size:1.15rem;
    color:var(--or-text);
}
.orm-progress-track{
    height:10px;
    border-radius:999px;
    background:rgba(255,255,255,.07);
    overflow:hidden;
}
.orm-progress-fill{
    height:100%;
    width:0;
    border-radius:999px;
    background:linear-gradient(90deg,#E87C4F,#E8A24F);
    transition:width .4s cubic-bezier(.2,.8,.2,1), background .4s ease;
}
.orm-progress-hint{
    margin-top:9px;
    font-size:.8rem;
    color:var(--or-text-soft);
    line-height:1.5;
}
@media (prefers-reduced-motion: reduce){
    .orm-progress-fill{ transition:none; }
}

/* ============================================================
   v2.4.1 — BULLETPROOF FORM TEXT VISIBILITY
   Highly-specific rules so no host theme can override them and
   make typed text invisible. Covers BOTH static and JS-injected
   category fields. Targets the form by id + wrapper.
   ============================================================ */
#oneroof-profile-form input,
#oneroof-profile-form select,
#oneroof-profile-form textarea,
.oneroof-form-wrapper input,
.oneroof-form-wrapper select,
.oneroof-form-wrapper textarea,
.oneroof-profile-form .oneroof-field input,
.oneroof-profile-form .oneroof-field select,
.oneroof-profile-form .oneroof-field textarea {
    color: #EDEDF2 !important;
    -webkit-text-fill-color: #EDEDF2 !important;
    background-color: rgba(0,0,0,0.35) !important;
    opacity: 1 !important;
    caret-color: #E8C572;
}
/* Dropdown option list (some browsers render on white) */
#oneroof-profile-form select option,
.oneroof-form-wrapper select option {
    color: #EDEDF2 !important;
    background-color: #0E0E18 !important;
}
/* Placeholders readable but dimmer */
#oneroof-profile-form input::placeholder,
#oneroof-profile-form textarea::placeholder,
.oneroof-form-wrapper input::placeholder,
.oneroof-form-wrapper textarea::placeholder {
    color: #8C8CA0 !important;
    -webkit-text-fill-color: #8C8CA0 !important;
    opacity: 1 !important;
}
/* Labels + helper text + section titles must stay light too */
.oneroof-form-wrapper label,
.oneroof-form-wrapper .oneroof-field small,
.oneroof-form-wrapper .oneroof-section-desc,
.oneroof-form-wrapper .oneroof-group-title,
.oneroof-form-wrapper .oneroof-cat-tile-name,
.oneroof-form-wrapper .oneroof-specific-cat-block-title {
    color: #EDEDF2 !important;
}
/* Autofill (Chrome paints its own near-white bg + dark text) */
#oneroof-profile-form input:-webkit-autofill,
#oneroof-profile-form textarea:-webkit-autofill,
.oneroof-form-wrapper input:-webkit-autofill {
    -webkit-text-fill-color: #EDEDF2 !important;
    -webkit-box-shadow: 0 0 0 1000px #0E0E18 inset !important;
    caret-color: #E8C572;
}
