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

/* ----------------------------------------------------------------
   Tokens (shared with rest of site)
   ---------------------------------------------------------------- */
:root {
	--ac-pink:        #e8457a;
	--ac-pink-light:  #f472a8;
	--ac-pink-dark:   #c2305f;
	--ac-black:       #111111;
	--ac-dark:        #1a1a2e;
	--ac-dark2:       #252540;
	--ac-gray:        #6b7280;
	--ac-gray-light:  #f3f4f6;
	--ac-white:       #ffffff;
	--ac-radius:      14px;
	--ac-radius-lg:   24px;
	--ac-shadow:      0 8px 32px rgba(232, 69, 122, .15);
	--ac-shadow-md:   0 4px 20px rgba(0, 0, 0, .10);
	--ac-shadow-dark: 0 8px 40px rgba(0, 0, 0, .35);
}

/* ----------------------------------------------------------------
   Layout helpers
   ---------------------------------------------------------------- */
.rif-ac-full-w {
	width:        100vw;
	position:     relative;
	left:         50%;
	right:        50%;
	margin-left:  -50vw;
	margin-right: -50vw;
}

.rif-ac-container {
	max-width:      1200px;
	margin-inline:  auto;
	padding-inline: clamp(1.25rem, 5vw, 3rem);
}

/* ----------------------------------------------------------------
   Scroll reveal
   ---------------------------------------------------------------- */
.rif-ac-reveal {
	opacity:    0;
	transform:  translateY(32px);
	transition: opacity .65s ease, transform .65s ease;
}
.rif-ac-reveal--right  { transform: translateX(32px); }
.rif-ac-reveal--delay1 { transition-delay: .15s; }
.rif-ac-reveal--delay2 { transition-delay: .30s; }
.rif-ac-reveal.is-visible { opacity: 1; transform: none; }

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

.rif-ac-section-title {
	font-size:   clamp(1.75rem, 3.5vw, 2.75rem);
	font-weight: 800;
	color:       var(--ac-black);
	line-height: 1.2;
	margin:      0 0 1rem;
}
.rif-ac-section-title em {
	font-style: normal;
	color:      var(--ac-pink);
}

.rif-ac-section-sub {
	font-size:   1rem;
	color:       var(--ac-gray);
	max-width:   560px;
	line-height: 1.7;
	margin:      0;
}

.rif-ac-body-lg {
	font-size:   1.1rem;
	line-height: 1.75;
	color:       var(--ac-dark);
	margin:      0 0 1rem;
}
.rif-ac-body {
	font-size:   .97rem;
	line-height: 1.75;
	color:       var(--ac-gray);
	margin:      0 0 1.5rem;
}

.rif-ac-section-header {
	text-align:    center;
	margin-bottom: 3.5rem;
}
.rif-ac-section-header .rif-ac-section-sub { margin-inline: auto; }

/* ----------------------------------------------------------------
   Buttons
   ---------------------------------------------------------------- */
.rif-ac-btn {
	display:         inline-flex;
	align-items:     center;
	gap:             .5rem;
	padding:         .85rem 2rem;
	border-radius:   50px;
	font-weight:     700;
	font-size:       .95rem;
	font-family:     inherit;
	cursor:          pointer;
	text-decoration: none;
	transition:      background .2s, color .2s, transform .15s, box-shadow .2s;
	border:          2px solid transparent;
	line-height:     1;
}
.rif-ac-btn--lg { padding: 1rem 2.5rem; font-size: 1rem; }
.rif-ac-btn:active { transform: scale(.97); }

.rif-ac-btn--primary {
	background: var(--ac-pink);
	color:      var(--ac-white);
	box-shadow: var(--ac-shadow);
}
.rif-ac-btn--primary:hover {
	background: var(--ac-pink-dark);
	box-shadow: 0 12px 40px rgba(232,69,122,.35);
	color:      var(--ac-white);
}

.rif-ac-btn--ghost {
	background:   transparent;
	color:        var(--ac-white);
	border-color: rgba(255,255,255,.4);
}
.rif-ac-btn--ghost:hover {
	background:   rgba(255,255,255,.12);
	border-color: rgba(255,255,255,.7);
	color:        var(--ac-white);
}

.rif-ac-btn--white {
	background: var(--ac-white);
	color:      var(--ac-pink-dark);
	box-shadow: var(--ac-shadow-md);
}
.rif-ac-btn--white:hover { background: var(--ac-gray-light); color: var(--ac-pink-dark); }

.rif-ac-btn--ghost-white {
	background:   transparent;
	color:        var(--ac-white);
	border-color: rgba(255,255,255,.5);
}
.rif-ac-btn--ghost-white:hover {
	background:   rgba(255,255,255,.15);
	border-color: var(--ac-white);
	color:        var(--ac-white);
}

.rif-ac-link-arrow {
	display:         inline-flex;
	align-items:     center;
	gap:             .4rem;
	color:           var(--ac-pink);
	font-weight:     700;
	font-size:       .9rem;
	text-decoration: none;
	margin-top:      auto;
	transition:      gap .2s, color .2s;
}
.rif-ac-link-arrow svg { width: 16px; height: 16px; transition: transform .2s; }
.rif-ac-link-arrow:hover { color: var(--ac-pink-dark); }
.rif-ac-link-arrow:hover svg { transform: translateX(4px); }
.rif-ac-link-arrow--light { color: rgba(255,255,255,.85); }
.rif-ac-link-arrow--light:hover { color: var(--ac-white); }

/* ================================================================
   HERO
   ================================================================ */
.rif-ac-hero {
	position:    relative;
	min-height:  100vh;
	display:     flex;
	align-items: center;
	overflow:    hidden;
}

.rif-ac-hero__bg {
	position:            absolute;
	inset:               0;
	background-size:     cover;
	background-position: center 25%;
	background-repeat:   no-repeat;
	z-index:             0;
}
.rif-ac-hero__bg::before {
	content:    '';
	position:   absolute;
	inset:      0;
	background: linear-gradient(
		120deg,
		rgba(26, 26, 46, .90) 0%,
		rgba(26, 26, 46, .65) 55%,
		rgba(26, 26, 46, .40) 100%
	);
}
.rif-ac-hero__bg::after {
	content:    '';
	position:   absolute;
	bottom:     0;
	left:       0;
	right:      0;
	height:     35%;
	background: linear-gradient(to top, rgba(26, 26, 46, .6), transparent);
}

.rif-ac-hero__inner {
	position:      relative;
	z-index:       1;
	padding-block: 8rem;
	max-width:     750px;
}

.rif-ac-hero__title {
	font-size:      clamp(2.8rem, 7vw, 5rem);
	font-weight:    900;
	color:          var(--ac-white);
	line-height:    1.05;
	margin:         0 0 1.25rem;
	letter-spacing: -.02em;
}
.rif-ac-hero__title em {
	font-style:  normal;
	background:  linear-gradient(135deg, var(--ac-pink-light), var(--ac-pink));
	-webkit-background-clip: text;
	-webkit-text-fill-color: transparent;
	background-clip: text;
}

.rif-ac-hero__sub {
	font-size:   1.15rem;
	color:       rgba(255,255,255,.78);
	line-height: 1.7;
	margin:      0 0 2.5rem;
	max-width:   500px;
}

.rif-ac-hero__cta {
	display:     flex;
	gap:         1rem;
	flex-wrap:   wrap;
	align-items: center;
}

.rif-ac-hero__scroll {
	position:  absolute;
	bottom:    2.5rem;
	left:      50%;
	transform: translateX(-50%);
	z-index:   1;
}
.rif-ac-hero__scroll span {
	display:       block;
	width:         24px;
	height:        40px;
	border:        2px solid rgba(255,255,255,.3);
	border-radius: 12px;
	position:      relative;
}
.rif-ac-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:     ac-scroll 1.6s ease infinite;
}
@keyframes ac-scroll {
	0%   { opacity:1; transform:translateX(-50%) translateY(0); }
	100% { opacity:0; transform:translateX(-50%) translateY(14px); }
}

/* ================================================================
   FEATURES BAR
   ================================================================ */
.rif-ac-features-bar {
	background:    var(--ac-dark);
	padding-block: 2rem;
	border-bottom: 1px solid rgba(255,255,255,.06);
}
.rif-ac-features-bar__grid {
	display:             grid;
	grid-template-columns: repeat(4, 1fr);
	gap:                 1px;
	background:          rgba(255,255,255,.07);
}
.rif-ac-feature-item {
	background:      var(--ac-dark);
	display:         flex;
	align-items:     center;
	gap:             1rem;
	padding:         1.5rem 1.75rem;
	font-size:       .9rem;
	font-weight:     700;
	color:           rgba(255,255,255,.75);
	transition:      background .2s, color .2s;
}
.rif-ac-feature-item:hover { background: var(--ac-dark2); color: var(--ac-white); }
.rif-ac-feature-item__icon {
	width:           44px;
	height:          44px;
	flex-shrink:     0;
	background:      rgba(232,69,122,.15);
	border-radius:   10px;
	display:         flex;
	align-items:     center;
	justify-content: center;
	color:           var(--ac-pink);
}
.rif-ac-feature-item__icon svg { width: 20px; height: 20px; }

/* ================================================================
   VALUE PROPOSITION
   ================================================================ */
.rif-ac-value {
	background:    var(--ac-white);
	padding-block: clamp(4rem, 8vw, 7rem);
}
.rif-ac-value__grid {
	display:               grid;
	grid-template-columns: 1fr 1fr;
	gap:                   4rem;
	align-items:           center;
}

.rif-ac-check-list {
	list-style:    none;
	padding:       0;
	margin:        0 0 .5rem;
	display:       flex;
	flex-direction: column;
	gap:           .7rem;
}
.rif-ac-check-list li {
	display:     flex;
	align-items: center;
	gap:         .65rem;
	font-size:   .95rem;
	font-weight: 600;
	color:       var(--ac-dark);
}
.rif-ac-check-list svg {
	width:      18px;
	height:     18px;
	color:      var(--ac-pink);
	flex-shrink: 0;
}

.rif-ac-value__media { position: relative; }
.rif-ac-value__img-wrap {
	border-radius: var(--ac-radius-lg);
	overflow:      hidden;
	aspect-ratio:  4/5;
	box-shadow:    var(--ac-shadow-dark);
}
.rif-ac-value__img-wrap img { width: 100%; height: 100%; object-fit: cover; display: block; }

.rif-ac-value__stat-card {
	position:      absolute;
	bottom:        -1.5rem;
	left:          -1.5rem;
	background:    var(--ac-pink);
	border-radius: var(--ac-radius);
	padding:       1.25rem 1.75rem;
	box-shadow:    var(--ac-shadow);
	text-align:    center;
}
.rif-ac-value__stat-num {
	font-size:   2.25rem;
	font-weight: 900;
	color:       var(--ac-white);
	line-height: 1;
}
.rif-ac-value__stat-lbl {
	font-size:   .75rem;
	font-weight: 700;
	color:       rgba(255,255,255,.8);
	text-transform: uppercase;
	letter-spacing: .06em;
	margin-top:  .2rem;
}

/* ================================================================
   PROGRAMS
   ================================================================ */
.rif-ac-programs {
	background:    var(--ac-gray-light);
	padding-block: clamp(4rem, 8vw, 7rem);
}

.rif-ac-programs__grid {
	display:               grid;
	grid-template-columns: repeat(3, 1fr);
	gap:                   1.5rem;
	align-items:           start;
}

.rif-ac-program-card {
	background:     var(--ac-white);
	border-radius:  var(--ac-radius-lg);
	padding:        2.5rem 2rem;
	display:        flex;
	flex-direction: column;
	gap:            1rem;
	box-shadow:     var(--ac-shadow-md);
	transition:     transform .25s, box-shadow .25s;
	border:         1.5px solid transparent;
	position:       relative;
}
.rif-ac-program-card:hover {
	transform:    translateY(-6px);
	box-shadow:   0 16px 48px rgba(0,0,0,.12);
	border-color: rgba(232,69,122,.2);
}

.rif-ac-program-card--featured {
	background:  linear-gradient(145deg, var(--ac-dark) 0%, #2d1b3d 100%);
	border-color: transparent;
}
.rif-ac-program-card--featured .rif-ac-program-card__title { color: var(--ac-white); }
.rif-ac-program-card--featured .rif-ac-program-card__desc  { color: rgba(255,255,255,.7); }
.rif-ac-program-card--featured .rif-ac-program-card__features li { color: rgba(255,255,255,.75); border-color: rgba(255,255,255,.1); }
.rif-ac-program-card--featured .rif-ac-program-card__icon {
	background: rgba(232,69,122,.2);
	color:      var(--ac-pink-light);
}
.rif-ac-program-card--featured:hover {
	border-color: rgba(232,69,122,.4);
	box-shadow:   0 16px 48px rgba(0,0,0,.3);
}

.rif-ac-program-card__badge {
	position:      absolute;
	top:           -12px;
	left:          50%;
	transform:     translateX(-50%);
	background:    var(--ac-pink);
	color:         var(--ac-white);
	font-size:     .72rem;
	font-weight:   800;
	letter-spacing: .08em;
	text-transform: uppercase;
	padding:       .3rem .9rem;
	border-radius: 50px;
	white-space:   nowrap;
}

.rif-ac-program-card__icon {
	width:           52px;
	height:          52px;
	background:      rgba(232,69,122,.1);
	border-radius:   14px;
	display:         flex;
	align-items:     center;
	justify-content: center;
	color:           var(--ac-pink);
	flex-shrink:     0;
}
.rif-ac-program-card__icon svg { width: 24px; height: 24px; }

.rif-ac-program-card__title {
	font-size:   1.2rem;
	font-weight: 800;
	color:       var(--ac-black);
	margin:      0;
	line-height: 1.3;
}

.rif-ac-program-card__desc {
	font-size:   .92rem;
	line-height: 1.7;
	color:       var(--ac-gray);
	margin:      0;
	flex:        1;
}

.rif-ac-program-card__features {
	list-style:    none;
	padding:       0;
	margin:        0;
	display:       flex;
	flex-direction: column;
	gap:           .5rem;
}
.rif-ac-program-card__features li {
	font-size:    .86rem;
	color:        var(--ac-gray);
	padding:      .45rem 0;
	border-top:   1px solid rgba(0,0,0,.06);
}
.rif-ac-program-card__features li::before {
	content: '✓ ';
	color:   var(--ac-pink);
	font-weight: 700;
}

/* ================================================================
   WHY CHOOSE US
   ================================================================ */
.rif-ac-why {
	background:    var(--ac-white);
	padding-block: clamp(4rem, 8vw, 7rem);
}
.rif-ac-why__grid {
	display:               grid;
	grid-template-columns: 1fr 1fr;
	gap:                   4.5rem;
	align-items:           center;
}

.rif-ac-why__media {
	position:      relative;
	border-radius: var(--ac-radius-lg);
	overflow:      hidden;
	aspect-ratio:  3/4;
	box-shadow:    var(--ac-shadow-dark);
}
.rif-ac-why__media img { width: 100%; height: 100%; object-fit: cover; display: block; }

.rif-ac-why__quote-card {
	position:      absolute;
	bottom:        1.5rem;
	left:          1.5rem;
	right:         1.5rem;
	background:    rgba(26, 26, 46, .92);
	backdrop-filter: blur(12px);
	border-radius: var(--ac-radius);
	padding:       1.25rem 1.5rem;
	border-left:   3px solid var(--ac-pink);
}
.rif-ac-why__quote-icon {
	width:  22px;
	height: 18px;
	color:  var(--ac-pink);
	margin-bottom: .6rem;
	display: block;
}
.rif-ac-why__quote-card p {
	font-size:   .88rem;
	line-height: 1.6;
	color:       rgba(255,255,255,.85);
	margin:      0 0 .5rem;
	font-style:  italic;
}
.rif-ac-why__quote-card span {
	font-size:   .76rem;
	font-weight: 700;
	color:       var(--ac-pink);
	text-transform: uppercase;
	letter-spacing: .06em;
}

.rif-ac-why__benefits {
	display:        flex;
	flex-direction: column;
	gap:            1.5rem;
	margin-top:     1.5rem;
}
.rif-ac-benefit {
	display:     flex;
	align-items: flex-start;
	gap:         1rem;
}
.rif-ac-benefit__icon {
	width:           46px;
	height:          46px;
	flex-shrink:     0;
	background:      rgba(232,69,122,.1);
	border-radius:   12px;
	display:         flex;
	align-items:     center;
	justify-content: center;
	color:           var(--ac-pink);
}
.rif-ac-benefit__icon svg { width: 20px; height: 20px; }
.rif-ac-benefit__title {
	display:     block;
	font-size:   .97rem;
	font-weight: 800;
	color:       var(--ac-black);
	margin-bottom: .25rem;
}
.rif-ac-benefit__desc {
	font-size:   .88rem;
	line-height: 1.6;
	color:       var(--ac-gray);
	margin:      0;
}

/* ================================================================
   STATS BAR
   ================================================================ */
.rif-ac-stats-bar {
	background:    var(--ac-dark);
	padding-block: clamp(2.5rem, 5vw, 4rem);
}
.rif-ac-stats-bar__grid {
	display:               grid;
	grid-template-columns: repeat(4, 1fr);
	gap:                   1px;
	background:            rgba(255,255,255,.07);
	border-radius:         var(--ac-radius);
	overflow:              hidden;
}
.rif-ac-stat-item {
	background:  var(--ac-dark);
	padding:     2.25rem 1.5rem;
	text-align:  center;
	transition:  background .25s;
}
.rif-ac-stat-item:hover { background: var(--ac-dark2); }
.rif-ac-stat-item__num {
	font-size:   2.75rem;
	font-weight: 900;
	color:       var(--ac-white);
	line-height: 1;
	margin-bottom: .3rem;
	background:  linear-gradient(135deg, var(--ac-white), rgba(255,255,255,.7));
	-webkit-background-clip: text;
	-webkit-text-fill-color: transparent;
	background-clip: text;
}
.rif-ac-stat-item__label {
	font-size:      .8rem;
	font-weight:    600;
	letter-spacing: .06em;
	text-transform: uppercase;
	color:          rgba(255,255,255,.45);
}

/* ================================================================
   JOIN THE CLASS
   ================================================================ */
.rif-ac-join {
	background:    var(--ac-gray-light);
	padding-block: clamp(4rem, 8vw, 7rem);
}
.rif-ac-join__grid {
	display:               grid;
	grid-template-columns: 1fr 1fr;
	gap:                   4rem;
	align-items:           center;
}

.rif-ac-join__media {
	border-radius: var(--ac-radius-lg);
	overflow:      hidden;
	aspect-ratio:  4/3;
	box-shadow:    var(--ac-shadow-dark);
}
.rif-ac-join__media img { width: 100%; height: 100%; object-fit: cover; display: block; }

.rif-ac-join__actions {
	display:     flex;
	align-items: center;
	gap:         1.5rem;
	flex-wrap:   wrap;
	margin-top:  2rem;
}

.rif-ac-join__phone {
	display:         flex;
	align-items:     center;
	gap:             .85rem;
	text-decoration: none;
	transition:      opacity .2s;
}
.rif-ac-join__phone:hover { opacity: .8; }
.rif-ac-join__phone-icon {
	width:           46px;
	height:          46px;
	background:      rgba(232,69,122,.12);
	border-radius:   50%;
	display:         flex;
	align-items:     center;
	justify-content: center;
	color:           var(--ac-pink);
	flex-shrink:     0;
}
.rif-ac-join__phone-icon svg { width: 20px; height: 20px; }
.rif-ac-join__phone span {
	display:    block;
	font-size:  .75rem;
	color:      var(--ac-gray);
	font-weight: 600;
	text-transform: uppercase;
	letter-spacing: .06em;
}
.rif-ac-join__phone strong {
	display:     block;
	font-size:   1rem;
	font-weight: 800;
	color:       var(--ac-black);
}

/* ================================================================
   TEAM
   ================================================================ */
.rif-ac-team {
	background:    var(--ac-white);
	padding-block: clamp(4rem, 8vw, 7rem);
}
.rif-ac-team__grid {
	display:               grid;
	grid-template-columns: repeat(3, 1fr);
	gap:                   2rem;
}

.rif-ac-coach {
	border-radius: var(--ac-radius-lg);
	overflow:      hidden;
	box-shadow:    var(--ac-shadow-md);
	background:    var(--ac-white);
	border:        1.5px solid var(--ac-gray-light);
	transition:    transform .25s, box-shadow .25s;
}
.rif-ac-coach:hover {
	transform:  translateY(-6px);
	box-shadow: 0 20px 56px rgba(0,0,0,.13);
}

.rif-ac-coach__photo {
	position:     relative;
	aspect-ratio: 1/1;
	overflow:     hidden;
	background:   var(--ac-dark);
}
.rif-ac-coach__photo img { width: 100%; height: 100%; object-fit: cover; display: block; transition: transform .4s; }
.rif-ac-coach:hover .rif-ac-coach__photo img { transform: scale(1.05); }

.rif-ac-coach__overlay {
	position:   absolute;
	inset:      0;
	background: linear-gradient(to top, rgba(232,69,122,.9) 0%, rgba(26,26,46,.5) 100%);
	display:    flex;
	align-items: flex-end;
	padding:    1.5rem;
	opacity:    0;
	transition: opacity .3s;
}
.rif-ac-coach:hover .rif-ac-coach__overlay { opacity: 1; }
.rif-ac-coach__bio-hover {
	font-size:   .85rem;
	line-height: 1.6;
	color:       var(--ac-white);
	margin:      0;
}

.rif-ac-coach__body { padding: 1.25rem 1.5rem; }
.rif-ac-coach__name {
	font-size:   1.05rem;
	font-weight: 800;
	color:       var(--ac-black);
	margin:      0 0 .2rem;
}
.rif-ac-coach__role {
	display:        block;
	font-size:      .78rem;
	font-weight:    700;
	color:          var(--ac-pink);
	text-transform: uppercase;
	letter-spacing: .08em;
}

/* ================================================================
   TESTIMONIALS
   ================================================================ */
.rif-ac-testimonials {
	background:    var(--ac-dark);
	padding-block: clamp(4rem, 8vw, 7rem);
}

.rif-ac-testi__grid {
	display:               grid;
	grid-template-columns: repeat(3, 1fr);
	gap:                   1.5rem;
}

.rif-ac-testi-card {
	background:     rgba(255,255,255,.05);
	border:         1.5px solid rgba(255,255,255,.08);
	border-radius:  var(--ac-radius-lg);
	padding:        2rem;
	display:        flex;
	flex-direction: column;
	gap:            1.25rem;
	transition:     background .25s, border-color .25s, transform .25s;
}
.rif-ac-testi-card:hover {
	background:   rgba(232,69,122,.08);
	border-color: rgba(232,69,122,.3);
	transform:    translateY(-4px);
}
.rif-ac-testi-card__q {
	width:   28px;
	height:  22px;
	color:   var(--ac-pink);
	opacity: .7;
}
.rif-ac-testi-card__text {
	font-size:   .97rem;
	line-height: 1.75;
	color:       rgba(255,255,255,.8);
	margin:      0;
	flex:        1;
	font-style:  italic;
}
.rif-ac-testi-card__author {
	display:     flex;
	align-items: center;
	gap:         .85rem;
}
.rif-ac-testi-card__avatar {
	width:           44px;
	height:          44px;
	border-radius:   50%;
	background:      linear-gradient(135deg, var(--ac-pink), var(--ac-pink-dark));
	color:           var(--ac-white);
	font-weight:     800;
	font-size:       .9rem;
	display:         flex;
	align-items:     center;
	justify-content: center;
	flex-shrink:     0;
}
.rif-ac-testi-card__name {
	display:     block;
	font-size:   .92rem;
	font-weight: 700;
	color:       var(--ac-white);
}
.rif-ac-testi-card__loc {
	display:    block;
	font-size:  .78rem;
	color:      rgba(255,255,255,.45);
	margin-top: .1rem;
}

/* ================================================================
   RECENT POSTS
   ================================================================ */
.rif-ac-posts {
	background:    var(--ac-white);
	padding-block: clamp(4rem, 8vw, 7rem);
}
.rif-ac-posts__grid {
	display:               grid;
	grid-template-columns: repeat(3, 1fr);
	gap:                   1.75rem;
}

.rif-ac-post-card {
	border-radius:  var(--ac-radius-lg);
	overflow:       hidden;
	background:     var(--ac-white);
	box-shadow:     var(--ac-shadow-md);
	border:         1.5px solid rgba(0,0,0,.05);
	display:        flex;
	flex-direction: column;
	transition:     transform .25s, box-shadow .25s;
}
.rif-ac-post-card:hover {
	transform:  translateY(-5px);
	box-shadow: 0 16px 48px rgba(0,0,0,.1);
}

.rif-ac-post-card__img-wrap {
	display:      block;
	aspect-ratio: 16/10;
	overflow:     hidden;
}
.rif-ac-post-card__img-wrap img { width: 100%; height: 100%; object-fit: cover; display: block; transition: transform .4s; }
.rif-ac-post-card:hover .rif-ac-post-card__img-wrap img { transform: scale(1.04); }
.rif-ac-post-card__img-placeholder { width: 100%; height: 100%; background: linear-gradient(135deg, var(--ac-dark) 0%, #3a1a50 100%); }

.rif-ac-post-card__body {
	padding:        1.5rem;
	display:        flex;
	flex-direction: column;
	gap:            .6rem;
	flex:           1;
}
.rif-ac-post-card__date {
	font-size:      .75rem;
	font-weight:    700;
	color:          var(--ac-pink);
	text-transform: uppercase;
	letter-spacing: .06em;
}
.rif-ac-post-card__title {
	font-size:   1.05rem;
	font-weight: 800;
	line-height: 1.35;
	margin:      0;
}
.rif-ac-post-card__title a {
	color:           var(--ac-black);
	text-decoration: none;
	transition:      color .2s;
}
.rif-ac-post-card__title a:hover { color: var(--ac-pink); }
.rif-ac-post-card__excerpt {
	font-size:   .88rem;
	line-height: 1.65;
	color:       var(--ac-gray);
	margin:      0;
	flex:        1;
}

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

/* ================================================================
   RESPONSIVE
   ================================================================ */
@media (max-width: 1024px) {
	.rif-ac-value__grid  { gap: 2.5rem; }
	.rif-ac-why__grid    { gap: 2.5rem; }
	.rif-ac-join__grid   { gap: 2.5rem; }
	.rif-ac-stats-bar__grid { grid-template-columns: repeat(2, 1fr); }
	.rif-ac-features-bar__grid { grid-template-columns: repeat(2, 1fr); }
}

@media (max-width: 768px) {
	.rif-ac-hero__inner       { padding-block: 6rem; }
	.rif-ac-hero__title       { font-size: clamp(2.2rem, 9vw, 3.2rem); }
	.rif-ac-value__grid       { grid-template-columns: 1fr; }
	.rif-ac-value__stat-card  { bottom: -1rem; left: 1rem; }
	.rif-ac-why__grid         { grid-template-columns: 1fr; }
	.rif-ac-join__grid        { grid-template-columns: 1fr; }
	.rif-ac-programs__grid    { grid-template-columns: 1fr; max-width: 480px; margin-inline: auto; }
	.rif-ac-team__grid        { grid-template-columns: 1fr; max-width: 380px; margin-inline: auto; }
	.rif-ac-testi__grid       { grid-template-columns: 1fr; }
	.rif-ac-posts__grid       { grid-template-columns: 1fr; max-width: 480px; margin-inline: auto; }
	.rif-ac-stats-bar__grid   { grid-template-columns: repeat(2, 1fr); }
	.rif-ac-features-bar__grid { grid-template-columns: repeat(2, 1fr); }
}

@media (max-width: 480px) {
	.rif-ac-hero__cta    { flex-direction: column; align-items: flex-start; }
	.rif-ac-cta__actions { flex-direction: column; align-items: center; }
	.rif-ac-join__actions { flex-direction: column; align-items: flex-start; }
	.rif-ac-stats-bar__grid { grid-template-columns: 1fr 1fr; }
	.rif-ac-features-bar__grid { grid-template-columns: 1fr 1fr; }
}
