/* ==========================================================================
   HCP Chamber Theme — Main Stylesheet
   Palette: #223e92 (navy primary), #e5fffd (mint accent)
   RTL-first, Arabic typography
   ========================================================================== */

/* ---------- Tokens ---------- */
:root {
    --c-primary: #223e92;
    --c-primary-700: #1a2f70;
    --c-primary-800: #142455;
    --c-primary-900: #0e1a40;
    --c-primary-50: #eef1fa;
    --c-primary-100: #d8dff3;
    --c-primary-200: #b4bfe6;

    --c-mint: #e5fffd;
    --c-mint-200: #b8f5f0;
    --c-mint-300: #7ee5dc;
    --c-mint-500: #2dc9bd;
    --c-mint-700: #0d8a82;

    --c-accent: var(--c-mint-500);

    --c-text: #0f172a;
    --c-text-2: #334155;
    --c-text-3: #64748b;
    --c-muted: #94a3b8;

    --c-bg: #ffffff;
    --c-bg-2: #f8fafc;
    --c-bg-3: #f1f5f9;
    --c-border: #e2e8f0;
    --c-border-2: #cbd5e1;

    --c-success: #10b981;
    --c-warning: #f59e0b;
    --c-danger: #ef4444;

    --shadow-xs: 0 1px 2px rgba(15,23,42,.04);
    --shadow-sm: 0 2px 6px rgba(15,23,42,.06), 0 1px 2px rgba(15,23,42,.04);
    --shadow-md: 0 6px 18px rgba(15,23,42,.08), 0 2px 4px rgba(15,23,42,.04);
    --shadow-lg: 0 18px 40px rgba(15,23,42,.10), 0 4px 10px rgba(15,23,42,.05);
    --shadow-primary: 0 12px 28px rgba(34,62,146,.25);
    --shadow-mint: 0 12px 28px rgba(45,201,189,.20);

    --radius-sm: 8px;
    --radius: 14px;
    --radius-lg: 22px;
    --radius-xl: 28px;
    --radius-full: 9999px;

    --container: 1240px;
    --container-narrow: 880px;

    --space-2: .5rem;
    --space-3: .75rem;
    --space-4: 1rem;
    --space-5: 1.25rem;
    --space-6: 1.5rem;
    --space-8: 2rem;
    --space-10: 2.5rem;
    --space-12: 3rem;
    --space-16: 4rem;
    --space-20: 5rem;
    --space-24: 6rem;

    --font-sans: 'Cairo', 'Tajawal', -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif;
    --font-display: 'Cairo', 'Tajawal', sans-serif;
}

/* ---------- Reset / Base ---------- */
*, *::before, *::after { box-sizing: border-box; }
html { scroll-behavior: smooth; -webkit-text-size-adjust: 100%; }
body {
    margin: 0;
    font-family: var(--font-sans);
    font-size: 16px;
    line-height: 1.7;
    color: var(--c-text);
    background: var(--c-bg);
    direction: rtl;
    text-align: right;
    -webkit-font-smoothing: antialiased;
}
img, svg, video { max-width: 100%; height: auto; display: block; }
a { color: var(--c-primary); text-decoration: none; transition: color .2s ease; }
a:hover { color: var(--c-primary-700); }
button { font-family: inherit; cursor: pointer; }
ul, ol { padding-inline-start: 1.25rem; }

h1, h2, h3, h4, h5, h6 {
    font-family: var(--font-display);
    color: var(--c-primary-900);
    font-weight: 800;
    line-height: 1.25;
    margin: 0 0 .75rem;
}
h1 { font-size: clamp(2rem, 4vw, 3.25rem); }
h2 { font-size: clamp(1.6rem, 3vw, 2.4rem); }
h3 { font-size: clamp(1.25rem, 2vw, 1.55rem); }
h4 { font-size: 1.15rem; }

p { margin: 0 0 1rem; color: var(--c-text-2); }
.lead { font-size: 1.15rem; color: var(--c-text-2); }

::selection { background: var(--c-primary); color: #fff; }

.screen-reader-text {
    position: absolute !important;
    width: 1px; height: 1px;
    padding: 0; margin: -1px;
    overflow: hidden;
    clip: rect(0,0,0,0);
    white-space: nowrap; border: 0;
}
.skip-link {
    position: absolute; top: -40px; right: 1rem;
    background: var(--c-primary); color: #fff;
    padding: .5rem 1rem; z-index: 100;
}
.skip-link:focus { top: 1rem; }

/* ---------- Layout ---------- */
.container {
    width: 100%;
    max-width: var(--container);
    margin: 0 auto;
    padding: 0 1.25rem;
}
.container--narrow { max-width: var(--container-narrow); }

.section { padding: clamp(3rem, 7vw, 6rem) 0; }
.section--lg { padding: clamp(4.5rem, 9vw, 8rem) 0; }
.section--sm { padding: clamp(2rem, 4vw, 3rem) 0; }
.section--alt { background: var(--c-bg-2); }
.section--mint {
    background: linear-gradient(180deg, var(--c-mint) 0%, #f4fffe 60%, #ffffff 100%);
}
.section--primary {
    background: linear-gradient(135deg, var(--c-primary) 0%, var(--c-primary-700) 100%);
    color: #fff;
}
.section--primary h1, .section--primary h2, .section--primary h3, .section--primary h4 { color: #fff; }
.section--primary p { color: rgba(255,255,255,.85); }

.text-center { text-align: center; }

.section-head { max-width: 760px; margin: 0 auto 2.5rem; text-align: center; }
.section-head .eyebrow {
    display: inline-block;
    color: var(--c-primary);
    background: var(--c-primary-50);
    padding: .35rem .9rem;
    font-size: .85rem;
    font-weight: 700;
    border-radius: var(--radius-full);
    margin-bottom: .9rem;
    letter-spacing: .02em;
}
.section-head h2 { margin-bottom: .6rem; }
.section-head p { color: var(--c-text-3); font-size: 1.05rem; }

/* ---------- Grid ---------- */
.grid { display: grid; gap: 1.5rem; }
.grid-2 { grid-template-columns: repeat(2, 1fr); }
.grid-3 { grid-template-columns: repeat(3, 1fr); }
.grid-4 { grid-template-columns: repeat(4, 1fr); }
@media (max-width: 960px) {
    .grid-3, .grid-4 { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 640px) {
    .grid-2, .grid-3, .grid-4 { grid-template-columns: 1fr; }
}

/* ---------- Buttons ---------- */
.btn {
    display: inline-flex;
    align-items: center;
    gap: .5rem;
    padding: .85rem 1.5rem;
    border-radius: var(--radius-full);
    font-weight: 700;
    font-size: .95rem;
    border: 2px solid transparent;
    transition: all .25s ease;
    cursor: pointer;
    line-height: 1;
    white-space: nowrap;
}
.btn-sm { padding: .6rem 1.1rem; font-size: .85rem; }
.btn-lg { padding: 1.05rem 2rem; font-size: 1rem; }
.btn .icon { transition: transform .25s ease; }
.btn:hover .icon { transform: translateX(4px); }

.btn-primary { background: var(--c-primary); color: #fff !important; box-shadow: var(--shadow-primary); }
.btn-primary:hover { background: var(--c-primary-700); transform: translateY(-2px); box-shadow: 0 18px 36px rgba(34,62,146,.32); }

.btn-mint { background: var(--c-mint); color: var(--c-primary) !important; border-color: var(--c-mint-200); }
.btn-mint:hover { background: var(--c-mint-200); transform: translateY(-2px); }

.btn-light { background: #fff; color: var(--c-primary) !important; }
.btn-light:hover { background: var(--c-mint); transform: translateY(-2px); }

.btn-ghost { background: transparent; color: var(--c-primary) !important; border-color: var(--c-primary-100); }
.btn-ghost:hover { background: var(--c-primary-50); border-color: var(--c-primary-200); }

.btn-ghost-light { background: transparent; color: #fff !important; border-color: rgba(255,255,255,.5); }
.btn-ghost-light:hover { background: rgba(255,255,255,.1); border-color: #fff; }

.btn-outline-primary { background: transparent; color: var(--c-primary) !important; border-color: var(--c-primary); }
.btn-outline-primary:hover { background: var(--c-primary); color: #fff !important; }

/* ---------- Topbar ---------- */
.topbar {
    background: var(--c-primary-900);
    color: rgba(255,255,255,.85);
    font-size: .82rem;
    padding: .5rem 0;
    border-bottom: 1px solid rgba(255,255,255,.08);
}
.topbar__inner { display: flex; align-items: center; justify-content: space-between; gap: 1rem; flex-wrap: wrap; }
.topbar__info { display: flex; gap: 1.5rem; flex-wrap: wrap; }
.topbar__item { display: inline-flex; align-items: center; gap: .4rem; color: rgba(255,255,255,.85); }
.topbar__item:hover { color: var(--c-mint); }
.topbar__social { display: flex; gap: .35rem; }
.topbar__social .social-link {
    width: 28px; height: 28px;
    display: inline-flex; align-items: center; justify-content: center;
    background: rgba(255,255,255,.08);
    border-radius: var(--radius-full);
    color: #fff;
    transition: all .2s;
}
.topbar__social .social-link:hover { background: var(--c-mint); color: var(--c-primary); }
.topbar__social .icon { width: 14px; height: 14px; }
@media (max-width: 720px) {
    .topbar { display: none; }
}

/* ---------- Header ---------- */
.site-header {
    background: #fff;
    border-bottom: 1px solid var(--c-border);
    position: sticky;
    top: 0;
    z-index: 50;
    transition: box-shadow .25s;
}
.site-header.is-stuck { box-shadow: var(--shadow-md); }
.site-header__inner {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
    min-height: 72px;
    padding: .5rem 1rem;
}
.site-branding { flex-shrink: 0; }
.custom-logo, .site-logo__img {
    display: block;
    max-height: 56px;
    width: auto;
    object-fit: contain;
}
.site-logo { display: inline-flex; align-items: center; }
@media (min-width: 1280px) {
    .custom-logo, .site-logo__img { max-height: 64px; }
}
.site-logo-text {
    display: flex; align-items: center; gap: .55rem;
}
.site-logo-mark {
    width: 42px; height: 42px;
    display: inline-flex; align-items: center; justify-content: center;
    background: linear-gradient(135deg, var(--c-primary), var(--c-primary-700));
    color: var(--c-mint);
    font-weight: 900;
    font-size: .9rem;
    border-radius: 11px;
    letter-spacing: .04em;
    box-shadow: var(--shadow-primary);
    flex-shrink: 0;
}
.site-logo-name { display: flex; flex-direction: column; line-height: 1.15; max-width: 220px; }
.site-logo-name strong { color: var(--c-primary-900); font-size: .85rem; font-weight: 800; }
.site-logo-name small { color: var(--c-text-3); font-size: .65rem; font-weight: 500; letter-spacing: .01em; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }

.primary-nav { min-width: 0; }
.primary-nav .primary-menu {
    list-style: none;
    margin: 0;
    padding: 0;
    display: flex;
    align-items: center;
    gap: 0;
    flex-wrap: nowrap;
}
.primary-menu a {
    display: block;
    padding: .5rem .65rem;
    color: var(--c-text);
    font-weight: 600;
    font-size: .82rem;
    border-radius: var(--radius-sm);
    transition: all .2s;
    position: relative;
    white-space: nowrap;
}
@media (min-width: 1280px) {
    .primary-menu a { padding: .55rem .85rem; font-size: .88rem; }
    .site-logo-name strong { font-size: .92rem; }
    .site-logo-name small { font-size: .7rem; }
}
.primary-menu a:hover,
.primary-menu .current-menu-item > a,
.primary-menu .current_page_item > a {
    color: var(--c-primary);
    background: var(--c-mint);
}
.primary-menu li { position: relative; }
.primary-menu .sub-menu {
    position: absolute; top: 100%; right: 0;
    background: #fff;
    border: 1px solid var(--c-border);
    border-radius: var(--radius);
    box-shadow: var(--shadow-lg);
    padding: .5rem;
    min-width: 220px;
    list-style: none;
    margin: 0;
    opacity: 0; visibility: hidden;
    transform: translateY(8px);
    transition: all .2s ease;
    z-index: 10;
}
.primary-menu li:hover > .sub-menu {
    opacity: 1; visibility: visible; transform: translateY(0);
}

.header-actions { display: flex; align-items: center; gap: .5rem; flex-shrink: 0; }
.header-cta { padding: .55rem .9rem; font-size: .82rem; }
.menu-toggle {
    display: none;
    width: 44px; height: 44px;
    background: var(--c-mint);
    color: var(--c-primary);
    border: none;
    border-radius: var(--radius-sm);
    align-items: center; justify-content: center;
}
.menu-toggle__icon-close { display: none; }

@media (max-width: 1100px) {
    .header-cta { display: none; }
    .menu-toggle { display: inline-flex; }
    .primary-nav {
        position: fixed;
        inset: 72px 0 0 0;
        background: #fff;
        padding: 1.5rem;
        overflow-y: auto;
        transform: translateX(-100%);
        transition: transform .3s ease;
        border-top: 1px solid var(--c-border);
    }
    .primary-nav.is-open { transform: translateX(0); }
    .primary-menu { flex-direction: column; align-items: stretch; gap: .15rem; flex-wrap: nowrap; }
    .primary-menu a { padding: .85rem 1rem; font-size: .98rem; }
    .primary-menu .sub-menu {
        position: static;
        opacity: 1; visibility: visible; transform: none;
        box-shadow: none; border: none;
        background: var(--c-bg-2);
        padding: 0 0 0 1rem;
    }
    body.menu-open .menu-toggle__icon-open { display: none; }
    body.menu-open .menu-toggle__icon-close { display: inline-flex; }
    body.menu-open { overflow: hidden; }
}

/* ---------- Hero (Home) — modern image-based ---------- */
.hero {
    position: relative;
    overflow: hidden;
    background:
        radial-gradient(ellipse at 80% -10%, rgba(45,201,189,.18), transparent 50%),
        radial-gradient(ellipse at -10% 100%, rgba(229,255,253,.12), transparent 55%),
        linear-gradient(135deg, var(--c-primary-900) 0%, var(--c-primary-800) 50%, var(--c-primary) 100%);
    color: #fff;
    padding: clamp(3.5rem, 7vw, 5.5rem) 0 clamp(5rem, 9vw, 7rem);
}
.hero::before {
    content: ""; position: absolute; inset: 0;
    background-image:
        radial-gradient(circle 2px at 20% 30%, rgba(229,255,253,.4), transparent 100%),
        radial-gradient(circle 1.5px at 75% 60%, rgba(229,255,253,.5), transparent 100%),
        radial-gradient(circle 2px at 40% 80%, rgba(229,255,253,.3), transparent 100%),
        radial-gradient(circle 1px at 90% 20%, rgba(229,255,253,.6), transparent 100%);
    pointer-events: none;
    opacity: .8;
}
.hero::after {
    content: ""; position: absolute; left: 0; right: 0; bottom: -1px;
    height: 80px;
    background: radial-gradient(60% 100% at 50% 100%, var(--c-bg) 50%, transparent 51%);
    z-index: 1;
}
.hero__inner {
    position: relative;
    z-index: 2;
    display: grid;
    grid-template-columns: 1.05fr 1fr;
    gap: clamp(2rem, 4vw, 4rem);
    align-items: center;
}
.hero__badge {
    display: inline-flex;
    align-items: center;
    gap: .5rem;
    background: rgba(229,255,253,.10);
    border: 1px solid rgba(229,255,253,.22);
    color: var(--c-mint);
    padding: .45rem 1rem .45rem .85rem;
    border-radius: var(--radius-full);
    font-size: .82rem;
    font-weight: 600;
    margin-bottom: 1.5rem;
    backdrop-filter: blur(8px);
}
.hero__badge .dot {
    width: 8px; height: 8px;
    border-radius: 50%;
    background: var(--c-mint);
    box-shadow: 0 0 0 4px rgba(229,255,253,.18);
    animation: pulseDot 2s ease-in-out infinite;
}
@keyframes pulseDot {
    0%,100% { box-shadow: 0 0 0 4px rgba(229,255,253,.18); }
    50%     { box-shadow: 0 0 0 8px rgba(229,255,253,.0); }
}
.hero__title {
    color: #fff;
    font-size: clamp(2.1rem, 4.6vw, 3.6rem);
    font-weight: 900;
    line-height: 1.15;
    margin: 0 0 1.25rem;
    letter-spacing: -.02em;
}
.hero__title .accent {
    color: var(--c-mint);
    display: inline-block;
    position: relative;
    padding: 0 .15em;
}
.hero__title .accent::after {
    content: ""; position: absolute; left: 0; right: 0; bottom: -.05em;
    height: 14px;
    background: linear-gradient(90deg, transparent 0%, var(--c-mint-500) 30%, var(--c-mint) 70%, transparent 100%);
    opacity: .35;
    border-radius: 4px;
    z-index: -1;
}
.hero__subtitle {
    font-size: 1.08rem;
    line-height: 1.75;
    color: rgba(255,255,255,.82);
    margin-bottom: 2rem;
    max-width: 560px;
}
.hero__actions { display: flex; flex-wrap: wrap; gap: .85rem; margin-bottom: 2.5rem; }
.hero__trust {
    display: flex;
    align-items: center;
    gap: 1.25rem;
    padding-top: 1.5rem;
    border-top: 1px solid rgba(255,255,255,.1);
    flex-wrap: wrap;
}
.hero__trust-item { display: flex; align-items: center; gap: .55rem; color: rgba(255,255,255,.78); font-size: .85rem; }
.hero__trust-item .icon-wrap {
    width: 36px; height: 36px;
    border-radius: 10px;
    background: rgba(229,255,253,.08);
    color: var(--c-mint);
    display: inline-flex; align-items: center; justify-content: center;
}
.hero__trust-item strong { color: #fff; display: block; font-size: .98rem; line-height: 1; margin-bottom: .15rem; }

/* Visual / image side */
.hero__visual {
    position: relative;
    aspect-ratio: 1/1.05;
    max-width: 540px;
    justify-self: center;
    width: 100%;
}
.hero__image {
    position: absolute;
    inset: 6% 12% 6% 0;
    border-radius: 28px 28px 28px 90px;
    overflow: hidden;
    box-shadow:
        0 30px 60px rgba(0,0,0,.35),
        0 0 0 1px rgba(229,255,253,.15);
    z-index: 2;
}
.hero__image img {
    width: 100%; height: 100%;
    object-fit: cover;
    object-position: center;
    transition: transform .8s ease;
}
.hero:hover .hero__image img { transform: scale(1.05); }
.hero__image::after {
    content: ""; position: absolute; inset: 0;
    background: linear-gradient(180deg, transparent 50%, rgba(20,36,85,.4) 100%);
    pointer-events: none;
}

/* Decorative shapes */
.hero__shape {
    position: absolute;
    border-radius: 28px;
    z-index: 1;
}
.hero__shape--mint {
    inset: 0 0 auto auto;
    width: 45%;
    height: 45%;
    background: linear-gradient(135deg, var(--c-mint) 0%, var(--c-mint-200) 100%);
    border-radius: 90px 28px 28px 28px;
    opacity: .9;
}
.hero__shape--ring {
    inset: auto auto 8% 4%;
    width: 110px; height: 110px;
    border: 3px dashed rgba(229,255,253,.3);
    border-radius: 50%;
    background: transparent;
    animation: spinSlow 30s linear infinite;
}
@keyframes spinSlow { to { transform: rotate(360deg); } }

/* Floating stat cards */
.hero__stat {
    position: absolute;
    background: rgba(255,255,255,.97);
    backdrop-filter: blur(12px);
    border-radius: 18px;
    padding: 1rem 1.15rem;
    box-shadow: 0 18px 40px rgba(0,0,0,.18), 0 2px 6px rgba(0,0,0,.06);
    color: var(--c-primary-900);
    z-index: 5;
    display: flex; align-items: center; gap: .75rem;
    min-width: 180px;
    border: 1px solid rgba(229,255,253,.5);
    animation: floatY 4s ease-in-out infinite;
}
.hero__stat .icon-wrap {
    width: 44px; height: 44px;
    border-radius: 12px;
    background: linear-gradient(135deg, var(--c-mint) 0%, var(--c-mint-200) 100%);
    color: var(--c-primary);
    display: inline-flex; align-items: center; justify-content: center;
    flex-shrink: 0;
}
.hero__stat strong { display: block; font-size: 1.25rem; line-height: 1; color: var(--c-primary); font-weight: 900; margin-bottom: .15rem; }
.hero__stat small { color: var(--c-text-3); font-size: .78rem; font-weight: 600; }
.hero__stat--top { top: 4%; right: 0; animation-delay: 0s; }
.hero__stat--bottom { bottom: 12%; left: -2%; animation-delay: 1s; }
.hero__stat--mid {
    top: 48%; right: -4%;
    background: var(--c-primary);
    color: #fff;
    border-color: rgba(229,255,253,.3);
    animation-delay: 2s;
}
.hero__stat--mid strong { color: var(--c-mint); }
.hero__stat--mid small { color: rgba(255,255,255,.7); }
.hero__stat--mid .icon-wrap {
    background: rgba(229,255,253,.15);
    color: var(--c-mint);
}

@keyframes floatY {
    0%,100% { transform: translateY(0); }
    50%     { transform: translateY(-10px); }
}

@media (max-width: 980px) {
    .hero__inner { grid-template-columns: 1fr; gap: 2.5rem; }
    .hero__visual { max-width: 460px; }
    .hero__stat--mid { display: none; }
}
@media (max-width: 600px) {
    .hero__visual { aspect-ratio: 4/4.4; max-width: 360px; }
    .hero__stat { min-width: 0; padding: .75rem .85rem; }
    .hero__stat strong { font-size: 1rem; }
    .hero__stat small { font-size: .7rem; }
    .hero__stat .icon-wrap { width: 36px; height: 36px; }
    .hero__stat .icon-wrap .icon { width: 18px; height: 18px; }
    .hero__shape--ring { display: none; }
    .hero__trust { gap: .85rem; }
}

/* ---------- Stats ---------- */
.stats {
    background: #fff;
    border-radius: var(--radius-xl);
    box-shadow: var(--shadow-lg);
    padding: 2.25rem 2rem;
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 1rem;
    margin-top: -4rem;
    position: relative;
    z-index: 5;
}
.stat { text-align: center; padding: .5rem 1rem; border-left: 1px solid var(--c-border); }
.stat:first-child { border-left: none; }
.stat__value { font-size: clamp(1.75rem, 3vw, 2.6rem); font-weight: 900; color: var(--c-primary); line-height: 1; margin-bottom: .35rem; font-family: var(--font-display); }
.stat__value .plus { color: var(--c-mint-500); font-size: .8em; }
.stat__label { color: var(--c-text-3); font-size: .92rem; font-weight: 600; }
@media (max-width: 720px) {
    .stats { grid-template-columns: repeat(2, 1fr); margin-top: -3rem; padding: 1.5rem; }
    .stat:nth-child(odd) { border-left: 1px solid var(--c-border); }
    .stat:nth-child(2n) { border-left: none; }
    .stat:nth-child(-n+2) { border-bottom: 1px solid var(--c-border); padding-bottom: 1rem; }
    .stat:nth-last-child(-n+2) { padding-top: 1rem; }
}

/* ---------- Cards ---------- */
.card {
    background: #fff;
    border: 1px solid var(--c-border);
    border-radius: var(--radius-lg);
    overflow: hidden;
    transition: all .3s ease;
    display: flex;
    flex-direction: column;
}
.card:hover { transform: translateY(-4px); box-shadow: var(--shadow-lg); border-color: var(--c-mint-300); }
.card__media { display: block; aspect-ratio: 16/10; overflow: hidden; background: var(--c-bg-3); }
.card__media img { width: 100%; height: 100%; object-fit: cover; transition: transform .5s; }
.card:hover .card__media img { transform: scale(1.05); }
.card__body { padding: 1.5rem; flex: 1; display: flex; flex-direction: column; }
.card__meta { font-size: .82rem; color: var(--c-text-3); margin-bottom: .5rem; display: flex; gap: .75rem; flex-wrap: wrap; }
.card__meta .tag { background: var(--c-mint); color: var(--c-primary); padding: .15rem .65rem; border-radius: var(--radius-full); font-weight: 700; font-size: .75rem; }
.card__title { font-size: 1.2rem; margin-bottom: .5rem; }
.card__title a { color: var(--c-primary-900); }
.card__title a:hover { color: var(--c-primary); }
.card__excerpt { color: var(--c-text-3); margin-bottom: 1rem; flex: 1; }
.card__more { display: inline-flex; align-items: center; gap: .35rem; color: var(--c-primary); font-weight: 700; font-size: .9rem; }
.card__more:hover { gap: .65rem; }

/* ---------- Service card ---------- */
.service-card {
    background: #fff;
    border: 1px solid var(--c-border);
    border-radius: var(--radius-lg);
    padding: 2rem 1.75rem;
    transition: all .3s ease;
    position: relative;
    overflow: hidden;
}
.service-card::before {
    content: ""; position: absolute; inset: auto -40px -40px auto;
    width: 160px; height: 160px;
    background: radial-gradient(circle, var(--c-mint) 0%, transparent 70%);
    opacity: 0;
    transition: opacity .4s;
}
.service-card:hover { transform: translateY(-6px); box-shadow: var(--shadow-lg); border-color: var(--c-mint-300); }
.service-card:hover::before { opacity: 1; }
.service-card__icon {
    width: 64px; height: 64px;
    border-radius: 18px;
    background: linear-gradient(135deg, var(--c-mint) 0%, var(--c-mint-200) 100%);
    color: var(--c-primary);
    display: inline-flex; align-items: center; justify-content: center;
    margin-bottom: 1.25rem;
    transition: all .3s;
}
.service-card__icon .icon { width: 30px; height: 30px; }
.service-card:hover .service-card__icon {
    background: linear-gradient(135deg, var(--c-primary) 0%, var(--c-primary-700) 100%);
    color: var(--c-mint);
    transform: rotate(-6deg) scale(1.05);
}
.service-card__title { font-size: 1.25rem; margin-bottom: .5rem; position: relative; }
.service-card__num {
    position: absolute; left: 0; top: 0;
    font-size: 3rem; font-weight: 900;
    color: var(--c-primary-50);
    line-height: 1;
    z-index: -1;
}
.service-card__desc { color: var(--c-text-3); font-size: .95rem; position: relative; }
.service-card__more { display: inline-flex; align-items: center; gap: .35rem; color: var(--c-primary); font-weight: 700; font-size: .9rem; margin-top: 1rem; position: relative; }

/* ---------- Service detail ---------- */
.service-detail { background: #fff; border-radius: var(--radius-xl); padding: 2.5rem; box-shadow: var(--shadow-sm); border: 1px solid var(--c-border); margin-bottom: 1.5rem; }
.service-detail__head { display: flex; gap: 1.25rem; align-items: flex-start; margin-bottom: 1.5rem; padding-bottom: 1.5rem; border-bottom: 1px dashed var(--c-border); }
.service-detail__icon {
    flex-shrink: 0;
    width: 72px; height: 72px;
    border-radius: 20px;
    background: linear-gradient(135deg, var(--c-primary) 0%, var(--c-primary-700) 100%);
    color: var(--c-mint);
    display: inline-flex; align-items: center; justify-content: center;
}
.service-detail__icon .icon { width: 34px; height: 34px; }
.service-detail h3 { margin-bottom: .25rem; }
.service-detail__desc { color: var(--c-text-2); font-size: 1rem; }
.service-detail__cols { display: grid; grid-template-columns: 1fr 1fr; gap: 2rem; }
.service-detail__col h4 {
    font-size: .9rem;
    color: var(--c-primary);
    text-transform: uppercase;
    letter-spacing: .05em;
    margin-bottom: .75rem;
    font-weight: 700;
}
.service-detail__col ul { list-style: none; padding: 0; margin: 0; }
.service-detail__col li {
    display: flex; gap: .5rem; align-items: flex-start;
    padding: .35rem 0;
    color: var(--c-text-2);
    font-size: .95rem;
}
.service-detail__col li::before {
    content: "";
    width: 6px; height: 6px;
    border-radius: 50%;
    background: var(--c-mint-500);
    margin-top: .65rem;
    flex-shrink: 0;
}
.service-detail__cta { margin-top: 1.5rem; padding-top: 1.5rem; border-top: 1px dashed var(--c-border); }
@media (max-width: 720px) {
    .service-detail { padding: 1.5rem; }
    .service-detail__cols { grid-template-columns: 1fr; gap: 1.25rem; }
}

/* ---------- Page hero ---------- */
.page-hero {
    position: relative;
    overflow: hidden;
    background: linear-gradient(135deg, var(--c-primary) 0%, var(--c-primary-800) 100%);
    color: #fff;
    padding: clamp(4rem, 8vw, 6rem) 0 clamp(3.5rem, 6vw, 5rem);
    text-align: center;
}
.page-hero::after {
    content: ""; position: absolute; left: 0; right: 0; bottom: -1px;
    height: 60px;
    background: radial-gradient(60% 100% at 50% 100%, var(--c-bg) 50%, transparent 51%);
}
.page-hero__bg { position: absolute; inset: 0; pointer-events: none; }
.page-hero__bg .blob {
    position: absolute;
    border-radius: 50%;
    filter: blur(60px);
    opacity: .25;
}
.page-hero__bg .blob-1 { top: -10%; right: -8%; width: 320px; height: 320px; background: var(--c-mint); }
.page-hero__bg .blob-2 { bottom: -20%; left: -5%; width: 280px; height: 280px; background: var(--c-mint-300); }
.page-hero__title { color: #fff; font-size: clamp(2rem, 4.5vw, 3rem); position: relative; z-index: 2; margin-bottom: .75rem; }
.page-hero__subtitle { color: rgba(255,255,255,.85); font-size: 1.1rem; max-width: 680px; margin: 0 auto; position: relative; z-index: 2; }

.ghorfa-breadcrumb {
    background: var(--c-bg-2);
    padding: .85rem 0;
    border-bottom: 1px solid var(--c-border);
    font-size: .85rem;
}
.ghorfa-breadcrumb ol { list-style: none; margin: 0; padding: 0; display: flex; flex-wrap: wrap; gap: .5rem; }
.ghorfa-breadcrumb li { display: flex; align-items: center; gap: .5rem; color: var(--c-text-3); }
.ghorfa-breadcrumb li:not(:last-child)::after { content: "›"; color: var(--c-muted); }
.ghorfa-breadcrumb a { color: var(--c-primary); }
.ghorfa-breadcrumb .current { color: var(--c-text); }

/* ---------- About / value cards ---------- */
.value-card {
    background: #fff;
    border-radius: var(--radius-lg);
    padding: 1.75rem;
    border: 1px solid var(--c-border);
    text-align: center;
    transition: all .3s;
}
.value-card:hover { border-color: var(--c-mint-300); box-shadow: var(--shadow-md); transform: translateY(-3px); }
.value-card__icon {
    width: 56px; height: 56px;
    border-radius: 16px;
    background: var(--c-mint);
    color: var(--c-primary);
    display: inline-flex; align-items: center; justify-content: center;
    margin-bottom: 1rem;
}
.value-card__icon .icon { width: 26px; height: 26px; }

/* ---------- Vision/Mission/Values cards ---------- */
.vmv-card {
    background: #fff;
    border-radius: var(--radius-lg);
    padding: 2rem;
    border: 1px solid var(--c-border);
    position: relative;
    overflow: hidden;
}
.vmv-card::before {
    content: ""; position: absolute; right: 0; top: 0; bottom: 0; width: 4px;
    background: linear-gradient(180deg, var(--c-mint-500), var(--c-primary));
}
.vmv-card h3 { display: flex; align-items: center; gap: .65rem; }
.vmv-card h3 .icon-wrap {
    width: 44px; height: 44px;
    background: var(--c-mint);
    color: var(--c-primary);
    border-radius: 12px;
    display: inline-flex; align-items: center; justify-content: center;
}
.vmv-card ul { list-style: none; padding: 0; margin: .75rem 0 0; }
.vmv-card ul li { padding: .35rem 0; color: var(--c-text-2); display: flex; gap: .5rem; align-items: flex-start; }
.vmv-card ul li::before { content: "✓"; color: var(--c-mint-500); font-weight: 900; }

/* ---------- Objectives list ---------- */
.objectives-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 1rem; }
@media (max-width: 720px) { .objectives-grid { grid-template-columns: 1fr; } }
.objective-item {
    display: flex; gap: 1rem;
    padding: 1.1rem 1.25rem;
    background: #fff;
    border-radius: var(--radius);
    border: 1px solid var(--c-border);
    transition: all .25s;
}
.objective-item:hover { border-color: var(--c-mint-300); transform: translateX(-4px); box-shadow: var(--shadow-sm); }
.objective-item__num {
    width: 38px; height: 38px;
    flex-shrink: 0;
    border-radius: 12px;
    background: linear-gradient(135deg, var(--c-mint) 0%, var(--c-mint-200) 100%);
    color: var(--c-primary);
    font-weight: 900;
    display: inline-flex; align-items: center; justify-content: center;
}
.objective-item p { margin: 0; color: var(--c-text-2); font-size: .98rem; line-height: 1.6; }

/* ---------- Board members ---------- */
.board-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 1.25rem; }
@media (max-width: 1024px) { .board-grid { grid-template-columns: repeat(3, 1fr); } }
@media (max-width: 720px) { .board-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 480px) { .board-grid { grid-template-columns: 1fr; } }
.board-card {
    background: #fff;
    border: 1px solid var(--c-border);
    border-radius: var(--radius-lg);
    padding: 1.5rem;
    text-align: center;
    transition: all .3s;
    position: relative;
    overflow: hidden;
}
.board-card::before {
    content: ""; position: absolute; left: 0; right: 0; top: 0; height: 80px;
    background: linear-gradient(135deg, var(--c-primary) 0%, var(--c-primary-700) 100%);
}
.board-card__avatar {
    position: relative; z-index: 2;
    width: 96px; height: 96px;
    border-radius: 50%;
    margin: 0 auto 1rem;
    background: var(--c-mint);
    border: 4px solid #fff;
    overflow: hidden;
    display: flex; align-items: center; justify-content: center;
    color: var(--c-primary);
    font-weight: 900;
    font-size: 2rem;
}
.board-card__avatar img { width: 100%; height: 100%; object-fit: cover; }
.board-card.is-chair { box-shadow: 0 0 0 2px var(--c-mint-500), var(--shadow-md); }
.board-card__role { display: inline-block; background: var(--c-mint); color: var(--c-primary); font-size: .72rem; font-weight: 700; padding: .2rem .65rem; border-radius: var(--radius-full); margin-bottom: .5rem; }
.board-card__name { color: var(--c-primary-900); font-size: 1rem; font-weight: 800; margin: 0 0 .25rem; }
.board-card__org { color: var(--c-text-3); font-size: .85rem; margin: 0; }

/* ---------- Chairman block ---------- */
.chairman {
    background: linear-gradient(135deg, #fff 0%, var(--c-mint) 100%);
    border-radius: var(--radius-xl);
    padding: clamp(1.75rem, 4vw, 3rem);
    display: grid;
    grid-template-columns: 240px 1fr;
    gap: 2.5rem;
    align-items: center;
    position: relative;
    overflow: hidden;
    border: 1px solid var(--c-mint-200);
}
.chairman__photo {
    width: 240px; height: 240px;
    border-radius: 50%;
    background: var(--c-primary);
    display: flex; align-items: center; justify-content: center;
    color: var(--c-mint);
    font-weight: 900;
    font-size: 4rem;
    overflow: hidden;
    border: 6px solid #fff;
    box-shadow: var(--shadow-lg);
}
.chairman__photo img { width: 100%; height: 100%; object-fit: cover; }
.chairman__quote {
    font-size: 1.05rem;
    line-height: 1.85;
    color: var(--c-text-2);
    position: relative;
    padding-right: 2rem;
}
.chairman__quote::before {
    content: "“"; position: absolute; right: 0; top: -1.5rem;
    font-size: 5rem; color: var(--c-primary); opacity: .15;
    font-family: serif; line-height: 1;
}
.chairman__sig { display: flex; flex-direction: column; margin-top: 1rem; }
.chairman__sig strong { color: var(--c-primary-900); font-size: 1.05rem; }
.chairman__sig small { color: var(--c-text-3); }
@media (max-width: 720px) {
    .chairman { grid-template-columns: 1fr; text-align: center; }
    .chairman__photo { margin: 0 auto; width: 180px; height: 180px; }
    .chairman__quote { padding-right: 0; }
    .chairman__sig { align-items: center; }
}

/* ---------- About teaser ---------- */
.about-teaser {
    display: grid;
    grid-template-columns: 1fr 1.1fr;
    gap: 3rem;
    align-items: stretch;
}
.about-teaser__visual {
    position: relative;
    display: flex;
    flex-direction: column;
    justify-content: flex-end;
    gap: 1rem;
    padding: 2.25rem;
    min-height: 360px;
    color: #fff;
    border-radius: var(--radius-xl);
    background: linear-gradient(135deg, var(--c-primary) 0%, var(--c-primary-700) 100%);
    box-shadow: var(--shadow-lg);
    overflow: hidden;
    isolation: isolate;
}
.about-teaser__visual::before {
    content: "";
    position: absolute;
    inset: 0;
    z-index: -1;
    background-image:
        radial-gradient(circle at 30% 25%, rgba(229,255,253,.22), transparent 45%),
        radial-gradient(circle at 80% 85%, rgba(229,255,253,.15), transparent 45%);
}
.about-teaser__chip {
    align-self: flex-start;
    background: var(--c-mint);
    color: var(--c-primary);
    padding: .35rem .85rem;
    border-radius: var(--radius-full);
    font-size: .78rem;
    font-weight: 700;
}
.about-teaser__visual-title {
    color: #fff;
    font-size: 1.55rem;
    line-height: 1.35;
    margin: 0;
}
.about-teaser__visual-text {
    color: rgba(255,255,255,.85);
    margin: 0;
    font-size: .95rem;
    line-height: 1.6;
}
.about-teaser__stat {
    margin-top: 1rem;
    padding-top: 1.25rem;
    border-top: 1px solid rgba(255,255,255,.18);
    display: flex;
    align-items: baseline;
    gap: .85rem;
    color: #fff;
}
.about-teaser__stat strong {
    font-size: 2.25rem;
    font-weight: 800;
    line-height: 1;
    color: var(--c-mint);
}
.about-teaser__stat small {
    font-size: .9rem;
    font-weight: 600;
    color: rgba(255,255,255,.85);
}
.about-teaser__text {
    display: flex;
    flex-direction: column;
    align-items: flex-start;
}
.about-teaser__text h2 { margin: 0 0 1rem; }
.about-teaser__eyebrow {
    display: inline-block;
    color: var(--c-primary);
    background: var(--c-primary-50);
    padding: .35rem .9rem;
    font-size: .85rem;
    font-weight: 700;
    border-radius: var(--radius-full);
    margin-bottom: .9rem;
}
.about-teaser__prose { margin: 0; }
.about-teaser__feature-list {
    list-style: none;
    padding: 0;
    margin: 1.5rem 0;
    display: grid;
    gap: .25rem;
    width: 100%;
}
.about-teaser__feature-list li {
    display: flex;
    gap: .65rem;
    padding: .5rem 0;
    color: var(--c-text-2);
}
.about-teaser__feature-list li .icon {
    color: var(--c-mint-500);
    flex-shrink: 0;
    margin-top: .15rem;
}
@media (max-width: 900px) {
    .about-teaser { grid-template-columns: 1fr; gap: 2rem; }
    .about-teaser__visual { min-height: 280px; padding: 1.75rem; }
    .about-teaser__visual-title { font-size: 1.35rem; }
}

/* ---------- News card ---------- */
.news-card .card__media { aspect-ratio: 16/9; }

/* ---------- Forms ---------- */
.form-grid { display: grid; gap: 1rem; grid-template-columns: 1fr 1fr; }
@media (max-width: 600px) { .form-grid { grid-template-columns: 1fr; } }
.form-row { display: flex; flex-direction: column; }
.form-row.full { grid-column: 1/-1; }
.form-row label { font-weight: 600; font-size: .9rem; margin-bottom: .35rem; color: var(--c-text); }
.form-row input,
.form-row select,
.form-row textarea {
    width: 100%;
    padding: .85rem 1rem;
    border: 1px solid var(--c-border-2);
    border-radius: var(--radius);
    background: #fff;
    font-family: inherit;
    font-size: .95rem;
    color: var(--c-text);
    transition: all .2s;
}
.form-row input:focus,
.form-row select:focus,
.form-row textarea:focus {
    outline: none;
    border-color: var(--c-primary);
    box-shadow: 0 0 0 4px rgba(34,62,146,.1);
}
.form-row textarea { min-height: 120px; resize: vertical; }
.form-row .req { color: var(--c-danger); }

/* CF7 styling */
.wpcf7 form .wpcf7-form-control-wrap { display: block; }
.wpcf7 form input:not([type=submit]),
.wpcf7 form select,
.wpcf7 form textarea {
    width: 100%;
    padding: .85rem 1rem;
    border: 1px solid var(--c-border-2);
    border-radius: var(--radius);
    background: #fff;
    font-family: inherit;
    font-size: .95rem;
    margin-top: .35rem;
}
.wpcf7 form input:not([type=submit]):focus,
.wpcf7 form select:focus,
.wpcf7 form textarea:focus {
    outline: none;
    border-color: var(--c-primary);
    box-shadow: 0 0 0 4px rgba(34,62,146,.1);
}
.wpcf7 form textarea { min-height: 130px; }
.wpcf7 form p { margin: 0 0 1rem; font-weight: 600; color: var(--c-text); }
.wpcf7 form .wpcf7-submit {
    background: var(--c-primary);
    color: #fff;
    padding: .9rem 2rem;
    border: none;
    border-radius: var(--radius-full);
    font-weight: 700;
    cursor: pointer;
    box-shadow: var(--shadow-primary);
    transition: all .25s;
}
.wpcf7 form .wpcf7-submit:hover { background: var(--c-primary-700); transform: translateY(-2px); }
.wpcf7-not-valid-tip { color: var(--c-danger); font-size: .85rem; }
.wpcf7 form.invalid .wpcf7-response-output,
.wpcf7 form.failed .wpcf7-response-output { border-color: var(--c-danger); color: var(--c-danger); }
.wpcf7 form.sent .wpcf7-response-output { border-color: var(--c-success); background: #ecfdf5; color: var(--c-success); border-radius: var(--radius); padding: 1rem; }

/* ---------- CTA band ---------- */
.cta-band {
    background: linear-gradient(135deg, var(--c-primary) 0%, var(--c-primary-700) 100%);
    color: #fff;
    padding: clamp(2.5rem, 5vw, 4rem) 0;
    position: relative;
    overflow: hidden;
}
.cta-band::before {
    content: ""; position: absolute; inset: 0;
    background-image:
        radial-gradient(circle at 0% 100%, rgba(229,255,253,.15), transparent 35%),
        radial-gradient(circle at 100% 0%, rgba(229,255,253,.10), transparent 35%);
}
.cta-band__inner {
    position: relative;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 2rem;
    flex-wrap: wrap;
}
.cta-band__title { color: #fff; margin: 0 0 .5rem; font-size: clamp(1.5rem, 3vw, 2rem); }
.cta-band__sub { color: rgba(255,255,255,.85); margin: 0; max-width: 580px; }
.cta-band__actions { display: flex; flex-wrap: wrap; gap: .85rem; }

/* ---------- Footer ---------- */
.site-footer {
    background: var(--c-primary-900);
    color: rgba(255,255,255,.78);
    padding: 4rem 0 0;
    margin-top: auto;
}
.footer-grid { display: grid; grid-template-columns: 2fr 1fr 1fr 1.5fr; gap: 3rem; padding-bottom: 3rem; border-bottom: 1px solid rgba(255,255,255,.08); }
@media (max-width: 900px) { .footer-grid { grid-template-columns: 1fr 1fr; gap: 2rem; } }
@media (max-width: 540px) { .footer-grid { grid-template-columns: 1fr; } }

.footer-brand { display: flex; gap: 1rem; align-items: center; margin-bottom: 1rem; }
.footer-logo {
    max-height: 72px;
    width: auto;
    background: #fff;
    padding: .5rem .75rem;
    border-radius: 12px;
    object-fit: contain;
}
.footer-mark {
    width: 56px; height: 56px;
    border-radius: 14px;
    background: linear-gradient(135deg, var(--c-mint) 0%, var(--c-mint-200) 100%);
    color: var(--c-primary);
    font-weight: 900;
    display: inline-flex; align-items: center; justify-content: center;
    flex-shrink: 0;
}
.footer-brand strong { color: #fff; display: block; font-size: 1rem; line-height: 1.3; }
.footer-brand small { color: rgba(255,255,255,.6); font-size: .78rem; }

.footer-tagline { font-size: .92rem; line-height: 1.7; }
.footer-social { display: flex; gap: .5rem; margin-top: 1rem; }
.footer-social .social-link {
    width: 38px; height: 38px;
    background: rgba(255,255,255,.08);
    border-radius: 12px;
    display: inline-flex; align-items: center; justify-content: center;
    color: #fff;
    transition: all .2s;
}
.footer-social .social-link:hover { background: var(--c-mint); color: var(--c-primary); transform: translateY(-2px); }

.footer-title { color: #fff; font-size: .98rem; font-weight: 800; margin-bottom: 1rem; }
.footer-menu, .footer-contact { list-style: none; padding: 0; margin: 0; }
.footer-menu li, .footer-contact li { margin-bottom: .55rem; }
.footer-menu a { color: rgba(255,255,255,.78); font-size: .92rem; }
.footer-menu a:hover { color: var(--c-mint); padding-right: .25rem; }
.footer-contact li { display: flex; gap: .65rem; align-items: flex-start; font-size: .9rem; line-height: 1.6; }
.footer-contact .icon { color: var(--c-mint-300); flex-shrink: 0; margin-top: .2rem; }
.footer-contact a { color: inherit; }
.footer-contact a:hover { color: var(--c-mint); }

.footer-bottom { padding: 1.5rem 0; text-align: center; font-size: .85rem; color: rgba(255,255,255,.5); }

/* ---------- News/Events archive ---------- */
.archive-toolbar {
    background: #fff;
    border: 1px solid var(--c-border);
    border-radius: var(--radius-lg);
    padding: 1.25rem;
    margin-bottom: 2rem;
    display: flex;
    gap: 1rem;
    align-items: center;
    flex-wrap: wrap;
    justify-content: space-between;
}
.archive-filters { display: flex; gap: .5rem; flex-wrap: wrap; }
.archive-filter {
    padding: .5rem 1rem;
    border: 1px solid var(--c-border-2);
    background: #fff;
    border-radius: var(--radius-full);
    font-weight: 600;
    font-size: .85rem;
    color: var(--c-text-2);
    cursor: pointer;
    transition: all .2s;
}
.archive-filter:hover { border-color: var(--c-primary); color: var(--c-primary); }
.archive-filter.is-active { background: var(--c-primary); color: #fff; border-color: var(--c-primary); }

/* ---------- Pagination ---------- */
.pagination, .nav-links { margin-top: 3rem; display: flex; justify-content: center; }
.page-numbers {
    display: inline-flex; align-items: center; justify-content: center;
    min-width: 40px; height: 40px;
    border: 1px solid var(--c-border);
    border-radius: var(--radius);
    color: var(--c-text);
    font-weight: 700;
    margin: 0 .15rem;
    padding: 0 .65rem;
    transition: all .2s;
}
.page-numbers:hover { background: var(--c-mint); border-color: var(--c-mint-300); color: var(--c-primary); }
.page-numbers.current { background: var(--c-primary); color: #fff; border-color: var(--c-primary); }

/* ---------- Knowledge / docs grid ---------- */
.doc-card {
    background: #fff;
    border: 1px solid var(--c-border);
    border-radius: var(--radius-lg);
    padding: 1.5rem;
    display: flex;
    gap: 1rem;
    align-items: flex-start;
    transition: all .25s;
}
.doc-card:hover { border-color: var(--c-mint-300); box-shadow: var(--shadow-md); transform: translateY(-2px); }
.doc-card__icon {
    width: 56px; height: 56px;
    border-radius: 14px;
    background: var(--c-mint);
    color: var(--c-primary);
    display: flex; align-items: center; justify-content: center;
    flex-shrink: 0;
}
.doc-card__title { font-size: 1.05rem; margin-bottom: .25rem; color: var(--c-primary-900); }
.doc-card__meta { color: var(--c-text-3); font-size: .82rem; margin-bottom: .65rem; }
.doc-card__download {
    display: inline-flex; align-items: center; gap: .35rem;
    color: var(--c-primary); font-weight: 700; font-size: .88rem;
}
.doc-card__download:hover { gap: .55rem; }

/* ---------- Membership ---------- */
.benefits-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 1.5rem; }
@media (max-width: 900px) { .benefits-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 600px) { .benefits-grid { grid-template-columns: 1fr; } }

.steps-list { counter-reset: steps; display: grid; gap: 1rem; grid-template-columns: repeat(3, 1fr); }
@media (max-width: 900px) { .steps-list { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 600px) { .steps-list { grid-template-columns: 1fr; } }
.step-item {
    counter-increment: steps;
    background: #fff;
    border: 1px solid var(--c-border);
    border-radius: var(--radius-lg);
    padding: 1.5rem;
    position: relative;
    padding-right: 3.5rem;
    transition: all .25s;
}
.step-item::before {
    content: counter(steps, decimal);
    position: absolute;
    right: 1rem; top: 1rem;
    width: 36px; height: 36px;
    background: var(--c-mint);
    color: var(--c-primary);
    border-radius: 50%;
    display: flex; align-items: center; justify-content: center;
    font-weight: 900;
    font-size: .95rem;
}
.step-item:hover { border-color: var(--c-mint-300); transform: translateY(-3px); box-shadow: var(--shadow-md); }
.step-item h4 { margin-bottom: .35rem; font-size: 1rem; }
.step-item p { margin: 0; color: var(--c-text-3); font-size: .9rem; }

.member-types { display: grid; grid-template-columns: repeat(4, 1fr); gap: 1rem; }
@media (max-width: 900px) { .member-types { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 480px) { .member-types { grid-template-columns: 1fr; } }
.member-type {
    background: #fff;
    border: 1px solid var(--c-border);
    border-radius: var(--radius-lg);
    padding: 1.25rem;
    display: flex; align-items: center; gap: .75rem;
    transition: all .25s;
    font-weight: 600;
    color: var(--c-primary-900);
}
.member-type .icon { color: var(--c-primary); flex-shrink: 0; }
.member-type:hover { background: var(--c-mint); border-color: var(--c-mint-300); }

/* ---------- Tabs ---------- */
.tabs-nav { display: flex; gap: .5rem; flex-wrap: wrap; justify-content: center; margin-bottom: 2rem; }
.tab-btn {
    padding: .65rem 1.25rem;
    border: 1px solid var(--c-border-2);
    background: #fff;
    border-radius: var(--radius-full);
    font-weight: 700;
    font-size: .9rem;
    color: var(--c-text-2);
    cursor: pointer;
    transition: all .2s;
}
.tab-btn.is-active { background: var(--c-primary); color: #fff; border-color: var(--c-primary); }
.tab-panel { display: none; }
.tab-panel.is-active { display: block; }

/* ---------- Contact ---------- */
.contact-grid { display: grid; grid-template-columns: 1.1fr .9fr; gap: 2.5rem; }
@media (max-width: 900px) { .contact-grid { grid-template-columns: 1fr; } }
.contact-info {
    background: linear-gradient(135deg, var(--c-primary) 0%, var(--c-primary-700) 100%);
    color: #fff;
    border-radius: var(--radius-xl);
    padding: 2.5rem;
    position: relative;
    overflow: hidden;
}
.contact-info::before {
    content: ""; position: absolute; inset: -50% -50% auto auto;
    width: 300px; height: 300px;
    background: radial-gradient(circle, rgba(229,255,253,.2), transparent 60%);
    pointer-events: none;
}
.contact-info h3 { color: #fff; margin-bottom: 1rem; }
.contact-info p { color: rgba(255,255,255,.85); }
.contact-info__list { list-style: none; padding: 0; margin: 2rem 0 0; position: relative; }
.contact-info__list li { display: flex; gap: 1rem; padding: 1rem 0; border-top: 1px solid rgba(255,255,255,.1); }
.contact-info__list li:first-child { border-top: none; }
.contact-info__list .icon-wrap {
    flex-shrink: 0;
    width: 44px; height: 44px;
    background: var(--c-mint);
    color: var(--c-primary);
    border-radius: 12px;
    display: flex; align-items: center; justify-content: center;
}
.contact-info__list strong { display: block; color: #fff; font-size: .85rem; margin-bottom: .15rem; }
.contact-info__list span, .contact-info__list a { color: rgba(255,255,255,.85); font-size: .95rem; line-height: 1.6; }
.contact-info__list a:hover { color: var(--c-mint); }

.contact-form-wrap {
    background: #fff;
    border-radius: var(--radius-xl);
    padding: 2.5rem;
    border: 1px solid var(--c-border);
    box-shadow: var(--shadow-sm);
}

/* ---------- Empty / 404 ---------- */
.error-404__code {
    font-size: clamp(6rem, 18vw, 12rem);
    font-weight: 900;
    background: linear-gradient(135deg, var(--c-primary) 0%, var(--c-mint-500) 100%);
    -webkit-background-clip: text;
    background-clip: text;
    color: transparent;
    line-height: 1;
    margin-bottom: 1rem;
}
.empty-state { text-align: center; padding: 3rem 1rem; }
.actions { display: flex; gap: 1rem; justify-content: center; flex-wrap: wrap; margin-top: 1.5rem; }

/* ---------- Prose ---------- */
.prose { max-width: 720px; margin: 0 auto; line-height: 1.85; color: var(--c-text-2); }
.prose h2, .prose h3, .prose h4 { margin-top: 2rem; }
.prose ul, .prose ol { padding-inline-start: 1.5rem; }
.prose ul li, .prose ol li { padding: .25rem 0; }
.prose a { color: var(--c-primary); text-decoration: underline; text-decoration-color: var(--c-mint-300); text-underline-offset: 4px; }
.prose blockquote {
    border-right: 4px solid var(--c-mint-500);
    background: var(--c-mint);
    padding: 1rem 1.5rem;
    border-radius: var(--radius);
    color: var(--c-primary-900);
    margin: 1.5rem 0;
}

/* ---------- Media gallery ---------- */
.gallery-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 1rem; }
@media (max-width: 720px) { .gallery-grid { grid-template-columns: repeat(2, 1fr); } }
.gallery-item {
    aspect-ratio: 1/1;
    border-radius: var(--radius);
    overflow: hidden;
    background: var(--c-bg-3);
    display: block;
}
.gallery-item img { width: 100%; height: 100%; object-fit: cover; transition: transform .4s; }
.gallery-item:hover img { transform: scale(1.05); }

/* ---------- Misc utilities ---------- */
.mb-0 { margin-bottom: 0 !important; }
.mb-2 { margin-bottom: .75rem !important; }
.mb-4 { margin-bottom: 1.5rem !important; }
.mb-6 { margin-bottom: 2.5rem !important; }
.mt-4 { margin-top: 1.5rem !important; }
.mt-6 { margin-top: 2.5rem !important; }

/* Animation */
@keyframes fadeInUp {
    from { opacity: 0; transform: translateY(20px); }
    to   { opacity: 1; transform: translateY(0); }
}
.fade-in { animation: fadeInUp .6s ease-out both; }

/* Print */
@media print {
    .topbar, .site-header, .site-footer, .cta-band, .menu-toggle { display: none !important; }
    body { color: #000; }
}
