/* ================================================================
   Natu Furniture Plugin — Frontend CSS v2.1.0
   Fixes: SVG icon colour/size for both FA and Elementor SVG icons
   ================================================================ */

.nf-footer *, .nf-footer *::before, .nf-footer *::after { box-sizing: border-box; margin: 0; padding: 0; }
.nf-footer a  { text-decoration: none; transition: color .22s ease; }
.nf-footer ul { list-style: none; }

/* ── INFO CARDS STRIP ────────────────────────────────────────── */
.nf-strip {
    background-color: #2a0a0a;
    padding: 24px 40px;
}
.nf-strip__inner {
    display: flex;
    align-items: stretch;
    gap: 1px;
    max-width: 1280px;
    margin: 0 auto;
}
.nf-strip__divider {
    width: 1px;
    background-color: rgba(255,255,255,0.12);
    flex-shrink: 0;
    margin: 8px 0;
}
.nf-card {
    flex: 1 1 0;
    min-width: 0;
    border: 1px solid rgba(255,255,255,0.08);
    border-radius: 8px;
    background-color: rgba(255,255,255,0.04);
    padding: 20px 24px;
    margin: 0 4px;
    transition: background-color .22s ease, border-color .22s ease;
}
.nf-card:hover {
    background-color: rgba(184,118,58,0.08);
    border-color: rgba(184,118,58,0.25);
}
.nf-card__inner {
    display: flex;
    align-items: flex-start;
    gap: 16px;
}

/* ── Card Icon — FA + SVG fix ───────────────────────────────── */
.nf-card__icon {
    color: #B8763A;
    font-size: 22px;
    flex-shrink: 0;
    margin-top: 2px;
    display: flex;
    align-items: center;
    justify-content: center;
    min-width: 26px;
    line-height: 1;
}
/* Font Awesome <i> */
.nf-card__icon i {
    color: inherit !important;
    font-size: inherit;
    display: block;
    line-height: 1;
}
/* Elementor SVG wrapper span */
.nf-card__icon > span,
.nf-card__icon .elementor-icon {
    display: flex;
    align-items: center;
    color: inherit;
    font-size: inherit;
}
/* SVG element itself */
.nf-card__icon svg,
.nf-card__icon span svg,
.nf-card__icon .elementor-icon svg {
    display: block;
    width: 1em;
    height: 1em;
    fill: currentColor !important;
    stroke: none;
    color: inherit;
}

.nf-card__content {
    display: flex;
    flex-direction: column;
    gap: 4px;
    min-width: 0;
}
.nf-card__title {
    display: block;
    color: #B8763A;
    font-size: 15px;
    font-weight: 700;
    line-height: 1.3;
}
.nf-card__text {
    display: block;
    color: rgba(255,255,255,0.70);
    font-size: 14px;
    line-height: 1.5;
}
.nf-card__text a { color: rgba(255,255,255,0.70); }
.nf-card__text a:hover, .nf-card__link:hover { color: #B8763A; }
.nf-card__link {
    color: rgba(255,255,255,0.70);
    font-size: 13px;
    text-decoration: underline;
    text-underline-offset: 2px;
}

/* ── FOOTER BODY ─────────────────────────────────────────────── */
.nf-body {
    background-color: #1a0505;
    padding: 64px 40px 56px;
}
.nf-body__divider {
    border: none;
    border-top: 1px solid rgba(255,255,255,0.10);
    margin-bottom: 56px;
    max-width: 1280px;
    margin-left: auto;
    margin-right: auto;
}
.nf-body__grid {
    display: grid;
    grid-template-columns: 1.8fr 1fr 1.2fr 1fr;
    gap: 48px;
    max-width: 1280px;
    margin: 0 auto;
    align-items: start;
}

/* ── NEWSLETTER ──────────────────────────────────────────────── */
.nf-nl { display: flex; flex-direction: column; gap: 0; }
.nf-nl__heading {
    color: #B8763A;
    font-size: 28px;
    font-weight: 700;
    line-height: 1.2;
    margin-bottom: 10px;
}
.nf-nl__subtext {
    color: rgba(255,255,255,0.75);
    font-size: 14px;
    line-height: 1.55;
    margin-bottom: 20px;
}
.nf-nl__form { margin-bottom: 14px; }
.nf-nl__row {
    display: flex;
    align-items: center;
    background: #f5f0ea;
    border-radius: 50px;
    overflow: hidden;
    padding: 4px 4px 4px 20px;
}
.nf-nl__input {
    flex: 1 1 auto;
    border: none;
    background: transparent;
    color: #1a0505;
    font-size: 14px;
    outline: none;
    padding: 10px 0;
    min-width: 0;
}
.nf-nl__input::placeholder { color: rgba(26,5,5,0.45); }
.nf-nl__btn {
    flex-shrink: 0;
    background-color: #f5f0ea;
    color: #1a0505;
    border: none;
    border-radius: 50px;
    padding: 11px 22px;
    font-size: 14px;
    font-weight: 600;
    cursor: pointer;
    transition: background-color .22s ease, color .22s ease;
    white-space: nowrap;
    box-shadow: -2px 0 0 0 rgba(0,0,0,0.08);
}
.nf-nl__btn:hover { background-color: #B8763A; color: #ffffff; }
.nf-nl__disclaimer {
    color: rgba(255,255,255,0.45);
    font-size: 12px;
    line-height: 1.6;
}
.nf-nl__disclaimer a {
    color: rgba(255,255,255,0.70);
    text-decoration: underline;
    text-underline-offset: 2px;
}
.nf-nl__disclaimer a:hover { color: #B8763A; }

/* ── LINK COLUMNS ────────────────────────────────────────────── */
.nf-col__title {
    color: #B8763A;
    font-size: 15px;
    font-weight: 700;
    letter-spacing: 0.02em;
    margin-bottom: 20px;
    line-height: 1.3;
}
.nf-col__links { display: flex; flex-direction: column; gap: 13px; }
.nf-col__links a {
    color: rgba(255,255,255,0.72);
    font-size: 14px;
    line-height: 1.4;
    display: inline-block;
}
.nf-col__links a:hover { color: #B8763A; }

/* ── SOCIAL ICONS — FA + SVG fix ────────────────────────────── */
.nf-body__social-row {
    display: flex;
    justify-content: flex-end;
    align-items: center;
    max-width: 1280px;
    margin: 48px auto 0;
}
.nf-social {
    display: flex;
    align-items: center;
    flex-wrap: wrap;
    gap: 10px;
}

/* The circle link */
.nf-social a {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 46px;
    height: 46px;
    border-radius: 50%;
    border: 1px solid rgba(255,255,255,0.25);
    background-color: transparent;
    /* icon colour via color + fill both */
    color: rgba(255,255,255,0.80) !important;
    font-size: 15px;
    transition: background-color .22s ease, color .22s ease, border-color .22s ease, transform .22s ease;
    text-decoration: none;
}
.nf-social a:hover {
    background-color: #B8763A !important;
    border-color: #B8763A !important;
    color: #ffffff !important;
    transform: translateY(-2px);
}

/* Font Awesome <i> inside social link */
.nf-social a i {
    color: inherit !important;
    font-size: inherit;
    display: block;
    line-height: 1;
    /* prevent FA from adding its own sizing */
    font-size: 1em;
}

/* Elementor SVG wrapper inside social link */
.nf-social a > span,
.nf-social a .elementor-icon {
    display: flex;
    align-items: center;
    justify-content: center;
    color: inherit;
    width: 100%;
    height: 100%;
}

/* SVG element inside social link */
.nf-social a svg,
.nf-social a span svg,
.nf-social a .elementor-icon svg {
    display: block;
    /* size relative to the font-size set on the <a> */
    width: 1em;
    height: 1em;
    /* CRITICAL: override any hardcoded fill on SVG paths */
    fill: currentColor !important;
    stroke: none !important;
    color: inherit;
}

/* Also override fill on child path/circle/rect elements */
.nf-social a svg path,
.nf-social a svg circle,
.nf-social a svg rect,
.nf-social a svg polygon {
    fill: currentColor !important;
    stroke: none !important;
}

/* Elementor icon size control — target the wrapper */
.nf-social a .eicon,
.nf-social a [class^="eicon-"],
.nf-social a [class*=" eicon-"] {
    font-size: inherit;
    color: inherit !important;
}

/* ── BOTTOM BAR ──────────────────────────────────────────────── */
.nf-bottom { background-color: #120303; padding: 16px 40px; }
.nf-bottom__inner {
    max-width: 1280px;
    margin: 0 auto;
    display: flex;
    align-items: center;
}
.nf-bottom__copy {
    color: rgba(255,255,255,0.40);
    font-size: 13px;
    line-height: 1.5;
}

/* ═══════════════════════════════════════════════════════════════
   RESPONSIVE — TABLET ≤900px
═══════════════════════════════════════════════════════════════ */
@media (max-width: 900px) {
    .nf-strip { padding: 20px 24px; }
    .nf-strip__inner { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; }
    .nf-strip__divider { display: none; }
    .nf-card { margin: 0; }
    .nf-body { padding: 48px 24px 40px; }
    .nf-body__grid { grid-template-columns: 1fr 1fr; gap: 36px; }
    .nf-nl { grid-column: 1 / -1; }
    .nf-body__social-row { justify-content: center; margin-top: 40px; }
    .nf-bottom { padding: 14px 24px; }
}

/* ═══════════════════════════════════════════════════════════════
   RESPONSIVE — MOBILE ≤600px
═══════════════════════════════════════════════════════════════ */
@media (max-width: 600px) {
    .nf-strip { padding: 16px; }
    .nf-strip__inner { grid-template-columns: 1fr; gap: 10px; }
    .nf-card { padding: 16px; }
    .nf-body { padding: 40px 16px 36px; }
    .nf-body__grid { grid-template-columns: 1fr; gap: 28px; }
    .nf-nl { grid-column: auto; }
    .nf-nl__heading { font-size: 24px; }
    .nf-body__social-row { justify-content: center; margin-top: 36px; }
    .nf-social a { width: 40px; height: 40px; font-size: 14px; }
    .nf-bottom { padding: 14px 16px; }
    .nf-bottom__inner { justify-content: center; text-align: center; }
}
