/* ================================================================
   Rooted in Faith NC — FAQs Page
   All selectors namespaced .rif-fq-* to avoid conflicts.
   ================================================================ */

:root {
	--fq-pink:       #e8457a;
	--fq-pink-light: #f472a8;
	--fq-pink-dark:  #c2305f;
	--fq-black:      #111111;
	--fq-dark:       #1a1a2e;
	--fq-dark2:      #252540;
	--fq-gray:       #6b7280;
	--fq-gray-light: #f3f4f6;
	--fq-white:      #ffffff;
	--fq-radius:     14px;
	--fq-radius-lg:  22px;
	--fq-shadow:     0 8px 32px rgba(232,69,122,.15);
	--fq-shadow-md:  0 4px 20px rgba(0,0,0,.10);
}

/* ----------------------------------------------------------------
   Layout
   ---------------------------------------------------------------- */
.rif-fq-full-w {
	width:        100vw;
	position:     relative;
	left:         50%;
	right:        50%;
	margin-left:  -50vw;
	margin-right: -50vw;
}
.rif-fq-container {
	max-width:      1100px;
	margin-inline:  auto;
	padding-inline: clamp(1.25rem, 5vw, 3rem);
}

/* ----------------------------------------------------------------
   Scroll reveal
   ---------------------------------------------------------------- */
.rif-fq-reveal {
	opacity:    0;
	transform:  translateY(24px);
	transition: opacity .6s ease, transform .6s ease;
}
.rif-fq-reveal.is-visible   { opacity: 1; transform: none; }
.rif-fq-reveal--delay1      { transition-delay: .12s; }
.rif-fq-reveal--delay2      { transition-delay: .24s; }

/* ----------------------------------------------------------------
   Typography
   ---------------------------------------------------------------- */
.rif-fq-eyebrow {
	display:        block;
	font-size:      .78rem;
	font-weight:    700;
	letter-spacing: .12em;
	text-transform: uppercase;
	color:          var(--fq-pink);
	margin-bottom:  .75rem;
}
.rif-fq-eyebrow--light { color: rgba(255,255,255,.7); }

/* ----------------------------------------------------------------
   Buttons
   ---------------------------------------------------------------- */
.rif-fq-btn {
	display:         inline-flex;
	align-items:     center;
	gap:             .5rem;
	padding:         .9rem 2.2rem;
	border-radius:   50px;
	font-weight:     700;
	font-size:       .95rem;
	cursor:          pointer;
	text-decoration: none;
	transition:      background .2s, color .2s, transform .15s;
	border:          2px solid transparent;
	line-height:     1;
}
.rif-fq-btn:active { transform: scale(.97); }
.rif-fq-btn--white {
	background: var(--fq-white); color: var(--fq-pink-dark); box-shadow: var(--fq-shadow-md);
}
.rif-fq-btn--white:hover { background: var(--fq-gray-light); color: var(--fq-pink-dark); }
.rif-fq-btn--ghost-white {
	background: transparent; color: var(--fq-white); border-color: rgba(255,255,255,.5);
}
.rif-fq-btn--ghost-white:hover {
	background: rgba(255,255,255,.15); border-color: var(--fq-white); color: var(--fq-white);
}

/* ================================================================
   HERO
   ================================================================ */
.rif-fq-hero {
	position:    relative;
	min-height:  68vh;
	display:     flex;
	align-items: flex-end;
	overflow:    hidden;
}
.rif-fq-hero__bg {
	position:            absolute;
	inset:               0;
	background-size:     cover;
	background-position: center 40%;
	background-repeat:   no-repeat;
	z-index:             0;
}
.rif-fq-hero__bg::before {
	content:    '';
	position:   absolute;
	inset:      0;
	background: linear-gradient(to bottom, rgba(26,26,46,.45) 0%, rgba(26,26,46,.82) 55%, rgba(26,26,46,.98) 100%);
}

.rif-fq-hero__inner {
	position:       relative;
	z-index:        1;
	padding-top:    9rem;
	padding-bottom: 4.5rem;
}
.rif-fq-hero__title {
	font-size:      clamp(2.5rem, 6vw, 4.5rem);
	font-weight:    900;
	color:          var(--fq-white);
	line-height:    1.1;
	margin:         0 0 1rem;
	letter-spacing: -.02em;
}
.rif-fq-hero__title em {
	font-style:  normal;
	background:  linear-gradient(135deg, var(--fq-pink-light), var(--fq-pink));
	-webkit-background-clip: text;
	-webkit-text-fill-color: transparent;
	background-clip: text;
}
.rif-fq-hero__sub {
	font-size:   1.05rem;
	color:       rgba(255,255,255,.72);
	line-height: 1.7;
	max-width:   520px;
	margin:      0 0 2rem;
}

/* Search bar */
.rif-fq-hero__search-wrap {
	position:  relative;
	max-width: 520px;
}
.rif-fq-hero__search {
	width:            100%;
	padding:          1rem 1.25rem 1rem 3rem;
	border-radius:    50px;
	border:           2px solid rgba(255,255,255,.15);
	background:       rgba(255,255,255,.1);
	backdrop-filter:  blur(10px);
	color:            var(--fq-white);
	font-size:        .97rem;
	font-family:      inherit;
	outline:          none;
	transition:       border-color .2s, background .2s;
	box-sizing:       border-box;
}
.rif-fq-hero__search::placeholder { color: rgba(255,255,255,.45); }
.rif-fq-hero__search:focus {
	border-color: var(--fq-pink);
	background:   rgba(255,255,255,.15);
}
.rif-fq-hero__search-icon {
	position:  absolute;
	left:      1rem;
	top:       50%;
	transform: translateY(-50%);
	width:     18px;
	height:    18px;
	color:     rgba(255,255,255,.5);
	pointer-events: none;
}

.rif-fq-hero__scroll {
	position:  absolute;
	bottom:    1.75rem;
	left:      50%;
	transform: translateX(-50%);
	z-index:   1;
}
.rif-fq-hero__scroll span {
	display: block; width: 24px; height: 40px;
	border: 2px solid rgba(255,255,255,.3); border-radius: 12px; position: relative;
}
.rif-fq-hero__scroll span::before {
	content: ''; position: absolute; top: 6px; left: 50%; transform: translateX(-50%);
	width: 4px; height: 8px; background: rgba(255,255,255,.6); border-radius: 2px;
	animation: fq-scroll 1.6s ease infinite;
}
@keyframes fq-scroll {
	0%   { opacity:1; transform:translateX(-50%) translateY(0); }
	100% { opacity:0; transform:translateX(-50%) translateY(14px); }
}

/* ================================================================
   STATS BAR
   ================================================================ */
.rif-fq-stats {
	background: var(--fq-dark);
}
.rif-fq-stats__grid {
	display:               grid;
	grid-template-columns: repeat(4,1fr);
	gap:                   1px;
	background:            rgba(255,255,255,.07);
}
.rif-fq-stat {
	background:  var(--fq-dark);
	padding:     2rem 1.5rem;
	text-align:  center;
	transition:  background .2s;
}
.rif-fq-stat:hover { background: var(--fq-dark2); }
.rif-fq-stat__num {
	font-size:   2.5rem;
	font-weight: 900;
	line-height: 1;
	background:  linear-gradient(135deg,var(--fq-white),rgba(255,255,255,.65));
	-webkit-background-clip: text;
	-webkit-text-fill-color: transparent;
	background-clip: text;
	margin-bottom: .3rem;
}
.rif-fq-stat__lbl {
	font-size:      .78rem;
	font-weight:    600;
	letter-spacing: .06em;
	text-transform: uppercase;
	color:          rgba(255,255,255,.42);
}

/* ================================================================
   FAQ BODY
   ================================================================ */
.rif-fq-body {
	background:    var(--fq-gray-light);
	padding-block: clamp(3rem, 6vw, 5.5rem);
}

.rif-fq-body__inner {
	display:   grid;
	grid-template-columns: 1fr;
	gap:       2.5rem;
}

/* ---- Category tabs ---- */
.rif-fq-tabs {
	display:     flex;
	flex-wrap:   wrap;
	gap:         .5rem;
	padding:     1.5rem 2rem;
	background:  var(--fq-white);
	border-radius: var(--fq-radius-lg);
	box-shadow:  var(--fq-shadow-md);
	position:    sticky;
	top:         80px;
	z-index:     10;
}
.rif-fq-tab {
	padding:        .5rem 1.1rem;
	border-radius:  50px;
	border:         2px solid transparent;
	background:     transparent;
	color:          var(--fq-gray);
	font-size:      .85rem;
	font-weight:    700;
	font-family:    inherit;
	cursor:         pointer;
	transition:     background .2s, color .2s, border-color .2s;
	white-space:    nowrap;
}
.rif-fq-tab:hover { background: var(--fq-gray-light); color: var(--fq-black); }
.rif-fq-tab.is-active {
	background:   var(--fq-pink);
	color:        var(--fq-white);
	border-color: var(--fq-pink);
}

/* ---- FAQ Groups ---- */
.rif-fq-groups { display: flex; flex-direction: column; gap: 1.5rem; }

.rif-fq-group {
	background:    var(--fq-white);
	border-radius: var(--fq-radius-lg);
	overflow:      hidden;
	box-shadow:    var(--fq-shadow-md);
	border:        1.5px solid rgba(0,0,0,.05);
	transition:    opacity .3s, transform .3s;
}
.rif-fq-group.is-hidden {
	display: none;
}

.rif-fq-group__header {
	display:     flex;
	align-items: center;
	gap:         1rem;
	padding:     1.5rem 2rem;
	border-bottom: 1px solid rgba(0,0,0,.06);
	background:  rgba(232,69,122,.03);
}
.rif-fq-group__icon {
	width:           42px;
	height:          42px;
	flex-shrink:     0;
	background:      rgba(232,69,122,.1);
	border-radius:   10px;
	display:         flex;
	align-items:     center;
	justify-content: center;
	color:           var(--fq-pink);
}
.rif-fq-group__icon svg { width: 20px; height: 20px; }
.rif-fq-group__title {
	font-size:   1.1rem;
	font-weight: 800;
	color:       var(--fq-black);
	margin:      0;
	flex:        1;
}
.rif-fq-group__count {
	font-size:      .72rem;
	font-weight:    700;
	letter-spacing: .06em;
	text-transform: uppercase;
	color:          var(--fq-pink);
	background:     rgba(232,69,122,.1);
	padding:        .25rem .7rem;
	border-radius:  50px;
}

/* ---- Accordion items ---- */
.rif-fq-accordion { padding: .5rem 0; }

.rif-fq-item { border-bottom: 1px solid rgba(0,0,0,.055); }
.rif-fq-item:last-child { border-bottom: none; }
.rif-fq-item.is-search-hidden { display: none; }

.rif-fq-item__q {
	width:        100%;
	display:      flex;
	align-items:  center;
	justify-content: space-between;
	gap:          1rem;
	padding:      1.25rem 2rem;
	background:   transparent;
	border:       none;
	cursor:       pointer;
	text-align:   left;
	font-family:  inherit;
	font-size:    .98rem;
	font-weight:  700;
	color:        var(--fq-black);
	transition:   color .2s, background .2s;
}
.rif-fq-item__q:hover { color: var(--fq-pink); background: rgba(232,69,122,.03); }
.rif-fq-item__q[aria-expanded="true"] { color: var(--fq-pink); }

.rif-fq-item__chevron {
	width:       28px;
	height:      28px;
	flex-shrink: 0;
	background:  var(--fq-gray-light);
	border-radius: 50%;
	display:     flex;
	align-items: center;
	justify-content: center;
	transition:  background .2s, transform .3s;
}
.rif-fq-item__chevron svg { width: 14px; height: 14px; }
.rif-fq-item__q[aria-expanded="true"] .rif-fq-item__chevron {
	background: var(--fq-pink);
	color:      var(--fq-white);
	transform:  rotate(180deg);
}

/* Answer panel */
.rif-fq-item__a {
	overflow:   hidden;
	max-height: 0;
	transition: max-height .35s ease;
}
.rif-fq-item__a:not([hidden]) { max-height: 500px; }
.rif-fq-item__a[hidden]       { display: block !important; max-height: 0; }

.rif-fq-item__a-inner {
	padding:     0 2rem 1.5rem;
	font-size:   .95rem;
	line-height: 1.75;
	color:       var(--fq-gray);
}
.rif-fq-item__a-inner p { margin: 0 0 .5rem; }
.rif-fq-item__a-inner p:last-child { margin-bottom: 0; }

/* No results */
.rif-fq-no-results {
	text-align:  center;
	padding:     4rem 2rem;
	color:       var(--fq-gray);
}
.rif-fq-no-results svg { width: 48px; height: 48px; margin-bottom: 1rem; opacity: .4; }
.rif-fq-no-results p { font-size: .97rem; line-height: 1.7; margin: 0; }
.rif-fq-no-results a { color: var(--fq-pink); font-weight: 700; text-decoration: none; }
.rif-fq-no-results a:hover { text-decoration: underline; }

/* Search highlight */
.rif-fq-highlight {
	background:    rgba(232,69,122,.18);
	border-radius: 3px;
	padding:       0 2px;
}

/* ================================================================
   CONTACT STRIP
   ================================================================ */
.rif-fq-contact {
	background:    var(--fq-white);
	padding-block: clamp(4rem, 7vw, 6rem);
}
.rif-fq-contact__grid {
	display:               grid;
	grid-template-columns: repeat(3,1fr);
	gap:                   1.5rem;
}

.rif-fq-contact-card {
	background:     var(--fq-gray-light);
	border-radius:  var(--fq-radius-lg);
	padding:        2.25rem 2rem;
	text-align:     center;
	display:        flex;
	flex-direction: column;
	align-items:    center;
	gap:            .75rem;
	border:         1.5px solid transparent;
	transition:     transform .25s, box-shadow .25s, border-color .25s, background .25s;
}
.rif-fq-contact-card:hover {
	transform:    translateY(-5px);
	box-shadow:   var(--fq-shadow-md);
	border-color: rgba(232,69,122,.2);
	background:   var(--fq-white);
}
.rif-fq-contact-card__icon {
	width:           54px;
	height:          54px;
	background:      rgba(232,69,122,.1);
	border-radius:   14px;
	display:         flex;
	align-items:     center;
	justify-content: center;
	color:           var(--fq-pink);
	margin-bottom:   .25rem;
}
.rif-fq-contact-card__icon svg { width: 24px; height: 24px; }
.rif-fq-contact-card h3 { font-size:1.05rem; font-weight:800; color:var(--fq-black); margin:0; }
.rif-fq-contact-card p  { font-size:.88rem; line-height:1.65; color:var(--fq-gray); margin:0; }
.rif-fq-contact-card__link {
	margin-top:      auto;
	display:         inline-flex;
	align-items:     center;
	gap:             .35rem;
	font-weight:     700;
	font-size:       .88rem;
	color:           var(--fq-pink);
	text-decoration: none;
	transition:      color .2s;
	padding-top:     .5rem;
}
.rif-fq-contact-card__link:hover { color: var(--fq-pink-dark); }

/* ================================================================
   CTA
   ================================================================ */
.rif-fq-cta { position: relative; overflow: hidden; }
.rif-fq-cta__bg {
	position:   absolute;
	inset:      0;
	background: linear-gradient(135deg, var(--fq-pink-dark) 0%, var(--fq-pink) 55%, var(--fq-pink-light) 100%);
	z-index:    0;
}
.rif-fq-cta__bg::before {
	content:       '';
	position:      absolute;
	top:           -50%;
	right:         -20%;
	width:         70%;
	height:        200%;
	background:    radial-gradient(ellipse, rgba(255,255,255,.13) 0%, transparent 60%);
	border-radius: 50%;
}
.rif-fq-cta__inner {
	position:      relative;
	z-index:       1;
	text-align:    center;
	padding-block: clamp(5rem, 10vw, 8rem);
}
.rif-fq-cta__title {
	font-size:      clamp(2rem, 4.5vw, 3.5rem);
	font-weight:    900;
	color:          var(--fq-white);
	line-height:    1.15;
	margin:         0 0 1rem;
	letter-spacing: -.02em;
}
.rif-fq-cta__sub {
	font-size:   1.05rem;
	color:       rgba(255,255,255,.82);
	line-height: 1.7;
	margin:      0 auto 2.5rem;
	max-width:   480px;
}
.rif-fq-cta__actions { display:flex; gap:1rem; flex-wrap:wrap; justify-content:center; }

/* ================================================================
   RESPONSIVE
   ================================================================ */
@media (max-width: 900px) {
	.rif-fq-contact__grid { grid-template-columns: 1fr; max-width: 460px; margin-inline: auto; }
	.rif-fq-stats__grid   { grid-template-columns: repeat(2,1fr); }
}
@media (max-width: 600px) {
	.rif-fq-item__q        { padding: 1.1rem 1.25rem; font-size: .92rem; }
	.rif-fq-item__a-inner  { padding: 0 1.25rem 1.25rem; }
	.rif-fq-group__header  { padding: 1.25rem; }
	.rif-fq-tabs           { padding: 1rem 1.25rem; gap: .4rem; }
	.rif-fq-cta__actions   { flex-direction: column; align-items: center; }
	.rif-fq-stats__grid    { grid-template-columns: repeat(2,1fr); }
}
