/* ================================================================
   CAREER-PAGES.CSS — 20 Microns Careers Module
   hero, tabs, sidebar, sections, jobs, apply form, connect
   ================================================================ */

/* -----------------------------------------------------------------------
   GLOBAL OVERRIDES (to fix sticky positioning)
----------------------------------------------------------------------- */
html:has(body.page-careers) { overflow-x:clip; }
body.page-careers { overflow-x:clip; }

/* -----------------------------------------------------------------------
   1. HERO — PREMIUM DARK (85vh) matching company-pages.css
----------------------------------------------------------------------- */
.cr-hero {
    position:relative; overflow:hidden;
    min-height:85vh; display:flex; align-items:center;
    background:linear-gradient(145deg, #07111a 0%, #0C1B26 45%, #111d28 100%);
    padding:120px 0 60px;
}
.cr-hero-sub { min-height:72vh; }
.cr-hero-grid-bg {
    position:absolute; inset:0;
    background-image:
        linear-gradient(rgba(127,166,155,0.04) 1px, transparent 1px),
        linear-gradient(90deg, rgba(127,166,155,0.04) 1px, transparent 1px);
    background-size:56px 56px;
    animation:crGridDrift 22s linear infinite;
}
@keyframes crGridDrift { from{transform:translate(0,0)} to{transform:translate(-56px,-56px)} }
.cr-hero-orb {
    position:absolute; border-radius:50%; filter:blur(70px); opacity:0.6; pointer-events:none;
}
.cr-orb-1 { width:500px; height:500px; top:-160px; left:-120px; background:radial-gradient(circle,rgba(127,166,155,0.18),transparent 70%); }
.cr-orb-2 { width:380px; height:380px; right:-60px; top:50px; background:radial-gradient(circle,rgba(127,166,155,0.14),transparent 70%); }
.cr-orb-3 { width:320px; height:320px; bottom:-80px; right:25%; background:radial-gradient(circle,rgba(127,166,155,0.10),transparent 70%); }
.cr-hero-particles {
    position:absolute; inset:0; pointer-events:none;
}
.cr-hero-particles span {
    position:absolute; width:3px; height:3px; border-radius:50%;
    background:rgba(127,166,155,0.5);
    animation:crParticleFloat 8s ease-in-out infinite;
}
.cr-hero-particles span:nth-child(1) { top:15%; left:10%; animation-delay:0s; }
.cr-hero-particles span:nth-child(2) { top:25%; left:80%; animation-delay:1s; animation-duration:10s; }
.cr-hero-particles span:nth-child(3) { top:55%; left:20%; animation-delay:2s; animation-duration:7s; }
.cr-hero-particles span:nth-child(4) { top:70%; left:65%; animation-delay:0.5s; }
.cr-hero-particles span:nth-child(5) { top:40%; left:45%; animation-delay:3s; animation-duration:9s; }
.cr-hero-particles span:nth-child(6) { top:85%; left:30%; animation-delay:1.5s; }
.cr-hero-particles span:nth-child(7) { top:20%; left:60%; animation-delay:4s; animation-duration:11s; }
.cr-hero-particles span:nth-child(8) { top:60%; left:85%; animation-delay:2.5s; }
@keyframes crParticleFloat {
    0%,100% { transform:translateY(0) scale(1); opacity:0.4; }
    50% { transform:translateY(-30px) scale(1.5); opacity:0.8; }
}
.cr-hero-bg-img {
    position:absolute; inset:0;
    background-size:cover; background-position:center;
    opacity:0.12;
}
.cr-hero .container { position:relative; z-index:2; }
.cr-hero-layout {
    display:grid; grid-template-columns:1fr 1fr;
    gap:48px; align-items:center;
}
.cr-hero-layout-sub { grid-template-columns:1.1fr 0.9fr; }
.cr-hero-breadcrumb {
    display:flex; align-items:center; gap:10px;
    margin-bottom:16px; font-size:0.78rem; color:rgba(255,255,255,0.4);
}
.cr-hero-breadcrumb a { color:rgba(255,255,255,0.6); text-decoration:none; }
.cr-hero-breadcrumb a:hover { color:#7FA69B; }
.cr-hero-breadcrumb i { font-size:0.6rem; }
.cr-hero-badge {
    display:inline-flex; align-items:center; gap:8px;
    font-size:0.74rem; font-weight:700; text-transform:uppercase; letter-spacing:0.12em;
    color:#9BC0B4; padding:8px 16px; border-radius:999px;
    background:rgba(127,166,155,0.12); border:1px solid rgba(127,166,155,0.22);
    margin-bottom:18px;
}
.cr-hero-title {
    font-family:'Exo 2',sans-serif;
    font-size:clamp(2rem, 4vw, 3.4rem); font-weight:300; line-height:1.12;
    color:#fff; margin-bottom:18px; letter-spacing:-0.02em;
}
.cr-hero-title span, .cr-hero-title .accent {
    font-weight:700;
    background:linear-gradient(135deg, #7FA69B, #D7EFE8);
    -webkit-background-clip:text; -webkit-text-fill-color:transparent; background-clip:text;
}
.cr-hero-subtitle {
    max-width:560px; font-size:1rem; line-height:1.78;
    color:rgba(255,255,255,0.58); margin-bottom:28px;
}
.cr-hero-actions { display:flex; flex-wrap:wrap; gap:12px; }

/* Buttons */
.cr-btn {
    display:inline-flex; align-items:center; justify-content:center; gap:10px;
    padding:14px 24px; border-radius:999px;
    font-size:0.88rem; font-weight:600; text-decoration:none;
    transition:all 0.3s ease; cursor:pointer; border:none;
}
.cr-btn-primary {
    background:linear-gradient(135deg, #7FA69B, #6B9186); color:#fff;
    box-shadow:0 12px 28px rgba(127,166,155,0.24);
}
.cr-btn-primary:hover { transform:translateY(-2px); box-shadow:0 18px 34px rgba(127,166,155,0.32); }
.cr-btn-ghost {
    border:1px solid rgba(255,255,255,0.14); background:rgba(255,255,255,0.05); color:rgba(255,255,255,0.84);
}
.cr-btn-ghost:hover { background:rgba(127,166,155,0.12); border-color:rgba(127,166,155,0.28); color:#fff; }
.cr-btn-outline {
    border:1px solid rgba(127,166,155,0.22); background:#fff; color:#203331;
    box-shadow:0 10px 30px rgba(127,166,155,0.08);
}
.cr-btn-outline:hover {
    border-color:#7FA69B; color:#162423; transform:translateY(-2px);
    box-shadow:0 16px 34px rgba(127,166,155,0.14);
}
.cr-btn-sm { padding:10px 18px; font-size:0.82rem; }
.cr-btn-lg { padding:16px 32px; font-size:0.92rem; }

/* -----------------------------------------------------------------------
   Hero Visual — Orbit (overview page)
----------------------------------------------------------------------- */
.cr-hero-visual { display:flex; align-items:center; justify-content:center; }
.cr-orbit-wrap {
    position:relative; width:380px; height:380px; flex-shrink:0;
}
.cr-orbit-glow {
    position:absolute; width:260px; height:260px; top:50%; left:50%;
    transform:translate(-50%,-50%);
    background:radial-gradient(circle, rgba(127,166,155,0.30), transparent 70%);
    filter:blur(40px);
}
.cr-orbit-ring {
    position:absolute; top:50%; left:50%; border-radius:50%; transform:translate(-50%,-50%); pointer-events:none;
}
.cr-orbit-ring.ring-outer { width:360px; height:360px; border:1px dashed rgba(127,166,155,0.42); animation:crOrbit 35s linear infinite; }
.cr-orbit-ring.ring-mid { width:260px; height:260px; border:1px solid rgba(127,166,155,0.54); animation:crOrbitRev 24s linear infinite; }
.cr-orbit-ring.ring-inner { width:140px; height:140px; border:2px dashed rgba(127,166,155,0.66); animation:crOrbit 15s linear infinite; }
@keyframes crOrbit { from{transform:translate(-50%,-50%) rotate(0)} to{transform:translate(-50%,-50%) rotate(360deg)} }
@keyframes crOrbitRev { from{transform:translate(-50%,-50%) rotate(0)} to{transform:translate(-50%,-50%) rotate(-360deg)} }
.cr-orbit-core {
    position:absolute; top:50%; left:50%; transform:translate(-50%,-50%);
    width:68px; height:68px; border-radius:50%;
    background:linear-gradient(135deg, #7FA69B, #4A7C6F);
    display:flex; align-items:center; justify-content:center;
    box-shadow:0 8px 36px rgba(127,166,155,0.45); z-index:3;
}
.cr-orbit-core::before {
    content:''; position:absolute; width:100%; height:100%; border-radius:50%;
    border:2px solid rgba(127,166,155,0.4);
    animation:crPulse 3s ease-out infinite;
}
@keyframes crPulse { 0%{transform:scale(1);opacity:1} 100%{transform:scale(1.8);opacity:0} }
.cr-orbit-core i { font-size:1.6rem; color:#fff; }
.cr-orbit-card {
    position:absolute; background:rgba(127,166,155,0.07);
    border:1px solid rgba(127,166,155,0.38); border-radius:16px;
    padding:12px 14px; width:105px; text-align:center; z-index:4;
    box-shadow:0 8px 32px rgba(0,0,0,0.3);
    backdrop-filter:blur(10px);
    animation:crNodeFloat 4s ease-in-out infinite;
}
.cr-orbit-card.cv1 { top:2px; left:calc(50% - 52px); }
.cr-orbit-card.cv2 { right:2px; top:calc(50% - 42px); animation-delay:0.6s; }
.cr-orbit-card.cv3 { bottom:2px; left:calc(50% - 52px); animation-delay:1.2s; }
.cr-orbit-card.cv4 { left:2px; top:calc(50% - 42px); animation-delay:0.9s; }
@keyframes crNodeFloat { 0%,100%{transform:translateY(0)} 50%{transform:translateY(-6px)} }
.cr-orbit-card-icon {
    width:32px; height:32px; border-radius:8px;
    background:rgba(127,166,155,0.15); border:1px solid rgba(127,166,155,0.2);
    display:flex; align-items:center; justify-content:center;
    margin:0 auto 6px; color:#7FA69B; font-size:0.8rem;
}
.cr-orbit-card-val {
    font-family:'Exo 2',sans-serif; font-size:1.15rem; font-weight:700;
    color:#fff; line-height:1; margin-bottom:3px;
}
.cr-orbit-card-val span { color:#7FA69B; }
.cr-orbit-card-lbl { font-size:0.58rem; font-weight:700; text-transform:uppercase; letter-spacing:0.07em; color:rgba(255,255,255,0.35); }
.cr-orbit-dot {
    position:absolute; width:8px; height:8px; border-radius:50%;
    background:#7FA69B; box-shadow:0 0 12px rgba(127,166,155,0.7); z-index:3;
}
.cr-orbit-dot.od1 { top:20%; left:22%; animation:crNodeFloat 5.5s ease-in-out infinite; }
.cr-orbit-dot.od2 { top:18%; right:22%; animation:crNodeFloat 5s ease-in-out 0.8s infinite; }
.cr-orbit-dot.od3 { bottom:20%; right:28%; animation:crNodeFloat 4.5s ease-in-out 1.5s infinite; }

/* -----------------------------------------------------------------------
   Hero Visual — Sub-page Culture Visual
----------------------------------------------------------------------- */
.cr-hero-visual-sub { min-height:380px; }
.cr-hero-stage {
    position:relative; width:min(100%, 470px); min-height:430px;
}
.cr-hero-stage-dot {
    position:absolute; width:7px; height:7px; border-radius:50%;
    background:rgba(215,239,232,0.72); box-shadow:0 0 18px rgba(127,166,155,0.8);
    animation:crStarTwinkle 3s ease-in-out infinite;
}
.cr-hero-stage-dot.dot-1 { top:20px; right:54px; }
.cr-hero-stage-dot.dot-2 { top:114px; left:10px; animation-delay:0.8s; }
.cr-hero-stage-dot.dot-3 { bottom:36px; right:18px; animation-delay:1.4s; }
.cr-hero-stage-panel {
    position:relative; min-height:430px; border-radius:32px;
    display:flex; align-items:center; justify-content:center;
    background:linear-gradient(180deg, rgba(7,17,26,0.58), rgba(12,27,38,0.22));
    border:1px solid rgba(255,255,255,0.09);
    box-shadow:0 28px 90px rgba(0,0,0,0.28);
    backdrop-filter:blur(14px); overflow:hidden;
}
.cr-hero-stage-panel::before {
    content:''; position:absolute; inset:0;
    background-image:
        linear-gradient(rgba(127,166,155,0.06) 1px, transparent 1px),
        linear-gradient(90deg, rgba(127,166,155,0.06) 1px, transparent 1px);
    background-size:42px 42px;
    mask-image:radial-gradient(circle at center, #000 34%, transparent 82%);
    opacity:0.5; pointer-events:none;
}
.cr-hero-stage-panel::after {
    content:''; position:absolute; inset:18px;
    border-radius:26px; border:1px solid rgba(127,166,155,0.08);
    pointer-events:none;
}
.cr-hero-stage-chip {
    position:absolute; z-index:4; min-width:160px; max-width:180px;
    padding:12px 14px; border-radius:16px;
    background:rgba(9,19,27,0.78); border:1px solid rgba(127,166,155,0.24);
    backdrop-filter:blur(12px); box-shadow:0 18px 36px rgba(0,0,0,0.2);
}
.cr-hero-stage-chip strong {
    display:block; font-size:0.82rem; font-weight:700; color:#fff; margin-bottom:3px;
}
.cr-hero-stage-chip span {
    display:block; font-size:0.74rem; line-height:1.5; color:rgba(215,239,232,0.72);
}
.cr-hero-stage-culture .chip-1 { top:22px; right:18px; }
.cr-hero-stage-culture .chip-2 { right:10px; bottom:54px; }
.cr-hero-stage-culture .chip-3 { left:18px; bottom:32px; }
.cr-hero-stage-grow .chip-1 { top:30px; left:16px; }
.cr-hero-stage-grow .chip-2 { right:18px; top:96px; }
.cr-hero-stage-grow .chip-3 { left:28px; bottom:34px; }
.cr-vis-culture {
    position:relative; width:340px; height:340px;
    display:flex; align-items:center; justify-content:center;
}
.cr-vis-culture::before {
    content:''; position:absolute; inset:24px; border-radius:50%;
    background:radial-gradient(circle, rgba(127,166,155,0.26), rgba(15,29,40,0.02) 72%);
    box-shadow:inset 0 0 0 1px rgba(127,166,155,0.14);
}
.cr-vis-culture::after {
    content:''; position:absolute; inset:56px; border-radius:50%;
    border:1px solid rgba(215,239,232,0.08);
}
.cr-vis-culture-ring {
    position:absolute; inset:10px; border-radius:50%;
    border:2px dashed rgba(127,166,155,0.26);
    animation:crOrbit 20s linear infinite;
}
.cr-vis-culture-ring.ring-2 {
    inset:54px; border-style:solid; border-color:rgba(127,166,155,0.18);
    animation:crOrbitRev 14s linear infinite;
}
.cr-vis-culture-core {
    position:absolute; top:50%; left:50%; transform:translate(-50%,-50%);
    width:86px; height:86px; border-radius:50%;
    background:linear-gradient(135deg, #7FA69B, #4A7C6F);
    display:flex; align-items:center; justify-content:center;
    box-shadow:0 16px 40px rgba(127,166,155,0.42); z-index:2;
}
.cr-vis-culture-core::before {
    content:''; position:absolute; inset:-14px; border-radius:50%;
    border:1px solid rgba(215,239,232,0.18);
}
.cr-vis-culture-core i { color:#fff; font-size:1.8rem; }
.cr-vis-culture-label {
    position:absolute; background:rgba(9,19,27,0.9);
    border:1px solid rgba(127,166,155,0.28); border-radius:14px;
    padding:10px 14px; font-size:0.78rem; font-weight:600; color:#c3ddd5;
    display:inline-flex; align-items:center; gap:6px; z-index:3;
    animation:crNodeFloat 4s ease-in-out infinite;
    backdrop-filter:blur(12px); box-shadow:0 16px 36px rgba(0,0,0,0.18);
}
.cr-vis-culture-label.lbl-1 { top:18px; left:50%; transform:translateX(-50%); }
.cr-vis-culture-label.lbl-2 { right:4px; top:50%; transform:translateY(-50%); animation-delay:0.5s; }
.cr-vis-culture-label.lbl-3 { bottom:18px; left:50%; transform:translateX(-50%); animation-delay:1s; }
.cr-vis-culture-label.lbl-4 { left:4px; top:50%; transform:translateY(-50%); animation-delay:1.5s; }
.cr-vis-culture-label i { font-size:0.75rem; color:#7FA69B; }

/* Hero Visual — Grow With Us (rocket) */
.cr-vis-grow {
    position:relative; width:340px; height:340px;
    display:flex; align-items:center; justify-content:center;
}
.cr-vis-grow-bg {
    position:absolute; width:240px; height:240px; border-radius:50%;
    background:radial-gradient(circle, rgba(127,166,155,0.22), transparent 72%);
    animation:crPulse 4s ease-out infinite;
}
.cr-vis-grow-rocket {
    position:relative; z-index:3;
    width:96px; height:96px; border-radius:50%;
    background:linear-gradient(135deg, #7FA69B, #4A7C6F);
    display:flex; align-items:center; justify-content:center;
    box-shadow:0 16px 44px rgba(127,166,155,0.44);
    animation:crRocketBob 3s ease-in-out infinite;
}
.cr-vis-grow-rocket i { color:#fff; font-size:2rem; transform:rotate(-45deg); }
@keyframes crRocketBob { 0%,100%{transform:translateY(0)} 50%{transform:translateY(-12px)} }
.cr-vis-grow-trail {
    position:absolute; bottom:62px; left:50%; width:4px; height:94px;
    transform:translateX(-50%);
    background:linear-gradient(to bottom, rgba(127,166,155,0.4), transparent);
    animation:crTrail 2s ease-in-out infinite;
    z-index:1;
}
@keyframes crTrail { 0%,100%{height:80px;opacity:0.3} 50%{height:120px;opacity:0.6} }
.cr-vis-grow-star {
    position:absolute; width:4px; height:4px; border-radius:50%;
    background:#D7EFE8; z-index:2;
    animation:crStarTwinkle 2s ease-in-out infinite;
}
.cr-vis-grow-star.s1 { top:30%; left:25%; animation-delay:0s; }
.cr-vis-grow-star.s2 { top:20%; right:30%; animation-delay:0.7s; }
.cr-vis-grow-star.s3 { bottom:35%; right:25%; animation-delay:1.3s; }
@keyframes crStarTwinkle { 0%,100%{opacity:0.3;transform:scale(1)} 50%{opacity:1;transform:scale(2)} }
.cr-vis-grow-label {
    position:absolute; background:rgba(9,19,27,0.9);
    border:1px solid rgba(127,166,155,0.28); border-radius:14px;
    padding:10px 14px; font-size:0.76rem; font-weight:600; color:#c3ddd5;
    display:inline-flex; align-items:center; gap:6px; z-index:4;
    animation:crNodeFloat 4s ease-in-out infinite;
    backdrop-filter:blur(12px); box-shadow:0 16px 36px rgba(0,0,0,0.18);
}
.cr-vis-grow-label.lbl-1 { top:18%; right:8%; animation-delay:0.3s; }
.cr-vis-grow-label.lbl-2 { bottom:18%; left:8%; animation-delay:0.8s; }
.cr-vis-grow-label i { font-size:0.7rem; color:#7FA69B; }

/* -----------------------------------------------------------------------
   2. PAGE TABS — Sticky navigation
----------------------------------------------------------------------- */
.cr-page-tabs {
    background:#0C1B26; border-bottom:1px solid rgba(127,166,155,0.14);
    position:sticky; top:55px; z-index:100;
    backdrop-filter:blur(20px);
}
.cr-page-tabs-inner {
    display:flex; align-items:center;
    max-width:1280px; margin:0 auto; padding:0 28px;
    gap:2px; overflow-x:auto; scrollbar-width:none;
}
.cr-page-tabs-inner::-webkit-scrollbar { display:none; }
.cr-tab-link {
    display:inline-flex; align-items:center; gap:8px;
    padding:15px 18px; font-size:0.78rem; font-weight:500;
    letter-spacing:0.05em; text-transform:uppercase;
    color:rgba(244,248,247,0.45); text-decoration:none;
    border-bottom:2px solid transparent;
    transition:all 0.35s; white-space:nowrap; flex-shrink:0;
}
.cr-tab-link:hover { color:#99BFB3; border-bottom-color:rgba(127,166,155,0.3); }
.cr-tab-link.active { color:#B8D4CB; border-bottom-color:#7FA69B; }
.cr-tab-link i { font-size:0.72rem; }

/* -----------------------------------------------------------------------
   3. CONTAINERS
----------------------------------------------------------------------- */
.cr-pages .container,
.cr-why .container,
.cr-content-area .container { max-width:1280px; margin:0 auto; padding:0 28px; }

/* -----------------------------------------------------------------------
   4. SECTION HEADERS
----------------------------------------------------------------------- */
.cr-section-header { text-align:center; margin-bottom:56px; }
.cr-section-badge {
    display:inline-flex; align-items:center; gap:10px;
    background:linear-gradient(135deg, rgba(127,166,155,0.12), rgba(127,166,155,0.05));
    border:1px solid rgba(127,166,155,0.25);
    padding:10px 22px; border-radius:50px;
    font-size:0.8rem; font-weight:600; color:#5C6E6A;
    letter-spacing:1.5px; text-transform:uppercase; margin-bottom:16px;
    position:relative; overflow:hidden;
}
.cr-section-badge::after {
    content:''; position:absolute; top:0; left:-100%; width:100%; height:100%;
    background:linear-gradient(90deg, transparent, rgba(127,166,155,0.3), transparent);
    animation:crBadgeGlow 4s ease-in-out infinite;
}
@keyframes crBadgeGlow { 0%{left:-100%} 50%{left:100%} 100%{left:100%} }
.cr-section-badge i { font-size:0.72rem; color:#7FA69B; }
.cr-section-title {
    font-family:'Exo 2',sans-serif;
    font-size:clamp(1.8rem, 3.2vw, 2.8rem); font-weight:700;
    color:#1a2a28; margin-bottom:12px; letter-spacing:-0.022em; line-height:1.15;
}
.cr-section-title .accent {
    background:linear-gradient(135deg, #7FA69B, #5C6E6A);
    -webkit-background-clip:text; -webkit-text-fill-color:transparent; background-clip:text;
}
.cr-section-subtitle {
    font-size:1.05rem; color:#5C6E6A; max-width:600px; margin:0 auto; line-height:1.7;
}

/* -----------------------------------------------------------------------
   5. PAGES GRID — career.php overview cards
----------------------------------------------------------------------- */
.cr-pages {
    padding:96px 0;
    background:linear-gradient(180deg, #f8faf9, #f0f5f3);
    position:relative; overflow:hidden;
}
.cr-pages::before {
    content:''; position:absolute; inset:0;
    background-image:
        linear-gradient(rgba(127,166,155,0.03) 1px, transparent 1px),
        linear-gradient(90deg, rgba(127,166,155,0.03) 1px, transparent 1px);
    background-size:60px 60px; pointer-events:none;
}
.cr-pages-grid {
    display:grid; grid-template-columns:repeat(auto-fill, minmax(340px, 1fr));
    gap:28px; position:relative; z-index:1;
}
.cr-page-card {
    position:relative; display:block; border-radius:20px; overflow:hidden;
    text-decoration:none; color:inherit; background:#fff;
    box-shadow:0 4px 16px rgba(127,166,155,0.08);
    border:1px solid rgba(127,166,155,0.12);
    transition:transform 0.5s cubic-bezier(0.23,1,0.32,1), box-shadow 0.5s;
    animation:crFadeUp 0.6s cubic-bezier(0.23,1,0.32,1) calc(var(--card-delay,0s)) both;
}
@keyframes crFadeUp { from{opacity:0;transform:translateY(24px)} to{opacity:1;transform:none} }
.cr-page-card:hover {
    transform:translateY(-10px) scale(1.01);
    box-shadow:0 20px 60px rgba(127,166,155,0.18);
}
.cr-card-image {
    position:relative; height:220px; overflow:hidden;
    background:linear-gradient(135deg, #e8f0ed, #d1dfd8);
}
.cr-card-image img {
    width:100%; height:100%; object-fit:cover;
    transition:transform 0.7s cubic-bezier(0.23,1,0.32,1);
}
.cr-page-card:hover .cr-card-image img { transform:scale(1.1); }
.cr-card-overlay {
    position:absolute; inset:0;
    background:linear-gradient(to bottom, transparent, rgba(26,42,40,0.08) 50%, rgba(26,42,40,0.35));
}
.cr-card-number {
    position:absolute; top:12px; right:14px;
    font-family:'Exo 2',sans-serif; font-size:0.68rem; font-weight:700;
    color:#fff; background:rgba(127,166,155,0.6);
    backdrop-filter:blur(8px); border:1px solid rgba(255,255,255,0.2);
    padding:3px 11px; border-radius:20px; z-index:2;
}
.cr-card-body { padding:24px; position:relative; }
.cr-card-body::before {
    content:''; position:absolute; top:0; left:24px; right:24px; height:1px;
    background:linear-gradient(90deg, transparent, var(--card-accent, #7FA69B) 50%, transparent);
    opacity:0.25;
}
.cr-card-icon {
    width:46px; height:46px; border-radius:14px;
    display:flex; align-items:center; justify-content:center;
    font-size:1.1rem; margin-bottom:14px;
    transition:transform 0.45s cubic-bezier(0.34,1.56,0.64,1);
}
.cr-page-card:hover .cr-card-icon { transform:scale(1.18) rotate(6deg); }
.cr-card-title {
    font-family:'Exo 2',sans-serif; font-size:1.16rem; font-weight:700;
    color:#1a2a28; margin-bottom:7px;
}
.cr-card-desc {
    font-size:0.84rem; color:#5C6E6A; line-height:1.62;
    display:-webkit-box; line-clamp:3; -webkit-line-clamp:3; -webkit-box-orient:vertical;
    overflow:hidden; margin-bottom:14px;
}
.cr-card-link {
    display:inline-flex; align-items:center; gap:7px;
    font-size:0.81rem; font-weight:700; color:var(--card-accent, #7FA69B);
    transition:gap 0.3s;
}
.cr-page-card:hover .cr-card-link { gap:13px; }
.cr-card-link i { font-size:0.73rem; transition:transform 0.3s; }
.cr-page-card:hover .cr-card-link i { transform:translateX(3px); }

/* -----------------------------------------------------------------------
   6. WHY JOIN — Features (overview page)
----------------------------------------------------------------------- */
.cr-why {
    padding:96px 0; background:#fff;
    position:relative; overflow:hidden;
}
.cr-why::before {
    content:''; position:absolute; inset:0;
    background-image:
        linear-gradient(rgba(127,166,155,0.025) 1px, transparent 1px),
        linear-gradient(90deg, rgba(127,166,155,0.025) 1px, transparent 1px);
    background-size:60px 60px; pointer-events:none;
}
.cr-why-grid {
    display:grid; grid-template-columns:1fr 1fr;
    gap:72px; align-items:center; position:relative; z-index:1;
}
.cr-why-content > p { font-size:1.05rem; color:#5C6E6A; line-height:1.8; margin-bottom:34px; }
.cr-why-features { display:flex; flex-direction:column; gap:14px; }
.cr-why-feature {
    display:flex; align-items:flex-start; gap:16px;
    padding:18px 20px; background:linear-gradient(135deg, #f8faf9, #f0f5f3);
    border-radius:16px; border:1px solid rgba(127,166,155,0.1);
    transition:all 0.35s;
}
.cr-why-feature:hover {
    background:#fff; border-color:rgba(127,166,155,0.25);
    transform:translateX(7px); box-shadow:0 8px 30px rgba(127,166,155,0.12);
}
.cr-feature-icon {
    width:44px; height:44px; min-width:44px; border-radius:12px;
    background:linear-gradient(135deg, #7FA69B, #5C6E6A); color:#fff;
    display:flex; align-items:center; justify-content:center; font-size:1rem;
    box-shadow:0 6px 20px rgba(127,166,155,0.3);
}
.cr-why-feature strong { display:block; font-size:0.9rem; font-weight:700; color:#1a2a28; margin-bottom:3px; }
.cr-why-feature span { font-size:0.82rem; color:#5C6E6A; line-height:1.55; }

/* Why Visual — Orbit viz with dark circular backdrop */
.cr-why-visual { display:flex; align-items:center; justify-content:center; padding:20px 0; }
.cr-why-vis {
    position:relative; width:400px; height:400px; flex-shrink:0;
    background:linear-gradient(145deg, #07111a 0%, #0C1B26 52%, #0d1e2a 100%);
    border-radius:50%;
    box-shadow:0 20px 72px rgba(7,17,26,0.32), 0 0 0 1px rgba(127,166,155,0.12),
               0 0 0 8px rgba(127,166,155,0.03);
}
.cr-why-vis-glow {
    position:absolute; width:280px; height:280px; top:50%; left:50%;
    transform:translate(-50%,-50%);
    background:radial-gradient(circle, rgba(127,166,155,0.28), transparent 70%);
    filter:blur(44px); pointer-events:none;
}
.cr-why-vis-ring {
    position:absolute; top:50%; left:50%; border-radius:50%;
    transform:translate(-50%,-50%); pointer-events:none;
}
.cr-why-vis-ring.ring-outer { width:370px; height:370px; border:1px dashed rgba(127,166,155,0.40); animation:crOrbit 35s linear infinite; }
.cr-why-vis-ring.ring-mid { width:260px; height:260px; border:1px solid rgba(127,166,155,0.52); animation:crOrbitRev 24s linear infinite; }
.cr-why-vis-ring.ring-inner { width:140px; height:140px; border:2px dashed rgba(127,166,155,0.65); animation:crOrbit 15s linear infinite; }
.cr-why-vis-core {
    position:absolute; top:50%; left:50%; transform:translate(-50%,-50%);
    width:70px; height:70px; border-radius:50%;
    background:linear-gradient(135deg, #7FA69B, #4A7C6F);
    display:flex; align-items:center; justify-content:center;
    box-shadow:0 8px 36px rgba(127,166,155,0.45); z-index:3;
}
.cr-why-vis-core i { font-size:1.6rem; color:#fff; }
.cr-why-vis-card {
    position:absolute; background:rgba(127,166,155,0.07);
    border:1px solid rgba(127,166,155,0.38); border-radius:16px;
    padding:12px 14px; width:108px; text-align:center; z-index:4;
    box-shadow:0 8px 32px rgba(0,0,0,0.3);
    backdrop-filter:blur(10px);
    animation:crNodeFloat 4s ease-in-out infinite;
}
.cr-why-vis-card.cv1 { top:4px; left:calc(50% - 54px); }
.cr-why-vis-card.cv2 { right:4px; top:calc(50% - 46px); animation-delay:0.6s; }
.cr-why-vis-card.cv3 { bottom:4px; left:calc(50% - 54px); animation-delay:1.2s; }
.cr-why-vis-card.cv4 { left:4px; top:calc(50% - 46px); animation-delay:0.9s; }
.cr-why-vis-card-icon {
    width:34px; height:34px; border-radius:9px;
    background:rgba(127,166,155,0.15); border:1px solid rgba(127,166,155,0.2);
    display:flex; align-items:center; justify-content:center;
    margin:0 auto 7px; color:#7FA69B; font-size:0.85rem;
}
.cr-why-vis-card-val {
    font-family:'Exo 2',sans-serif; font-size:1.2rem; font-weight:700;
    color:#fff; line-height:1; margin-bottom:3px;
}
.cr-why-vis-card-val span { color:#7FA69B; }
.cr-why-vis-card-lbl { font-size:0.58rem; font-weight:700; text-transform:uppercase; letter-spacing:0.07em; color:rgba(255,255,255,0.35); }
.cr-why-vis-dot {
    position:absolute; width:9px; height:9px; border-radius:50%;
    background:#7FA69B; box-shadow:0 0 12px rgba(127,166,155,0.7); z-index:3;
}
.cr-why-vis-dot.dv1 { top:20%; left:22%; animation:crNodeFloat 5.5s ease-in-out infinite; }
.cr-why-vis-dot.dv2 { top:18%; right:22%; animation:crNodeFloat 5s ease-in-out 0.8s infinite; }
.cr-why-vis-dot.dv3 { bottom:20%; right:28%; animation:crNodeFloat 4.5s ease-in-out 1.5s infinite; }

/* -----------------------------------------------------------------------
   7. CONTENT AREA + SIDEBAR (career-page.php)
----------------------------------------------------------------------- */
[data-cr-reveal] {
    opacity:0; transform:translateY(18px);
    transition:opacity 0.55s cubic-bezier(0.4,0,0.2,1), transform 0.55s cubic-bezier(0.4,0,0.2,1);
}
[data-cr-reveal].cr-revealed { opacity:1; transform:none; }

.cr-content-area {
    padding:40px 0 72px; background:#f4f7f6; position:relative;
}
.cr-content-area::before {
    content:''; position:absolute; inset:0;
    background-image:
        linear-gradient(rgba(127,166,155,0.02) 1px, transparent 1px),
        linear-gradient(90deg, rgba(127,166,155,0.02) 1px, transparent 1px);
    background-size:48px 48px; pointer-events:none;
}
.cr-layout {
    display:grid; grid-template-columns:270px minmax(0, 1fr);
    gap:34px; align-items:start; position:relative; z-index:1;
}
.cr-sidebar {
    position:sticky; top:120px; align-self:start;
    z-index:10;
}
.cr-sidebar-shell {
    --cr-sidebar-shift:0px;
    position:relative; transform:translateY(var(--cr-sidebar-shift));
    transition:transform 0.26s ease-out, box-shadow 0.3s ease;
    padding:20px 18px 18px; border-radius:24px;
    background:rgba(255,255,255,0.82); border:1px solid rgba(127,166,155,0.14);
    box-shadow:0 24px 52px rgba(15,35,32,0.08); backdrop-filter:blur(16px);
    will-change:transform;
}
.cr-sidebar-shell::before {
    content:''; position:absolute; inset:12px; border-radius:18px;
    border:1px solid rgba(127,166,155,0.08); pointer-events:none;
}
.cr-sidebar-inner { position:relative; z-index:1; }
.cr-sidebar-title {
    display:flex; align-items:center; gap:10px;
    font-family:'Exo 2',sans-serif; font-size:0.78rem; font-weight:600;
    color:#2C3E3A; text-transform:uppercase; letter-spacing:0.08em;
    padding-bottom:14px; border-bottom:1px solid rgba(127,166,155,0.12); margin-bottom:14px;
}
.cr-sidebar-title i { color:#7FA69B; font-size:0.76rem; }
.cr-sidebar-divider {
    height:1px; margin:16px 0;
    background:linear-gradient(90deg, transparent, rgba(127,166,155,0.18), transparent);
}
.cr-sidebar-mini-title {
    margin-bottom:10px; font-size:0.72rem; font-weight:700; text-transform:uppercase;
    letter-spacing:0.11em; color:#7FA69B;
}
.cr-sidebar-nav { display:flex; flex-direction:column; gap:1px; }
.cr-sidebar-link {
    display:flex; align-items:center; gap:10px;
    padding:10px 14px; font-size:0.82rem; font-weight:500;
    color:#5C6E6A; text-decoration:none; border-radius:10px;
    border-left:3px solid transparent;
    transition:all 0.25s;
}
.cr-sidebar-link i { font-size:0.72rem; width:16px; text-align:center; opacity:0.6; transition:opacity 0.25s; }
.cr-sidebar-link:hover { background:rgba(127,166,155,0.06); color:#2C3E3A; border-left-color:rgba(127,166,155,0.3); }
.cr-sidebar-link:hover i { opacity:1; }
.cr-sidebar-link.active {
    background:rgba(127,166,155,0.08); color:#2C3E3A; font-weight:600;
    border-left-color:#7FA69B;
}
.cr-sidebar-link.active i { opacity:1; color:#7FA69B; }
.cr-sidebar-link-section {
    font-size:0.78rem; padding:9px 12px;
}
.cr-sidebar-link.current {
    background:rgba(127,166,155,0.1); color:#203331; font-weight:600;
    border-left-color:#7FA69B;
}
.cr-sidebar-link.current i { opacity:1; color:#7FA69B; }
.cr-sidebar-gallery {
    width:100%; margin-top:16px; padding:12px 14px;
    display:inline-flex; align-items:center; justify-content:center; gap:8px;
    border-radius:14px; border:1px solid rgba(127,166,155,0.18);
    background:#f7fbfa; color:#2C3E3A; font:inherit; font-size:0.82rem; font-weight:600;
    cursor:pointer; transition:all 0.28s ease;
}
.cr-sidebar-gallery:hover {
    background:#fff; border-color:#7FA69B; transform:translateY(-2px);
    box-shadow:0 12px 24px rgba(127,166,155,0.12);
}
.cr-sidebar-cta {
    display:flex; align-items:center; justify-content:center; gap:8px;
    margin-top:18px; padding:12px 16px; border-radius:12px;
    background:linear-gradient(135deg, #7FA69B, #6B9186); color:#fff;
    font-size:0.82rem; font-weight:600; text-decoration:none;
    transition:all 0.3s;
}
.cr-sidebar-cta:hover { transform:translateY(-2px); box-shadow:0 8px 20px rgba(127,166,155,0.3); }

/* Main content */
.cr-main { padding-top:28px; min-height:400px; }
.cr-section { margin-bottom:44px; }
.cr-section-header-inner {
    margin-bottom:24px; padding-bottom:16px;
    border-bottom:1px solid rgba(127,166,155,0.10);
}
.cr-section-header-inner h2 {
    font-family:'Exo 2',sans-serif; font-size:1.5rem; font-weight:700;
    color:#1a2a28; margin-bottom:6px;
}
.cr-section-sub { font-size:0.88rem; color:#7FA69B; font-weight:600; }

/* -----------------------------------------------------------------------
   8. TEXT / IMAGE SECTIONS
----------------------------------------------------------------------- */
.cr-text-image { display:grid; gap:28px; }
.cr-section-text.has-media.layout-img-left .cr-text-image,
.cr-section-text.has-media.layout-img-right .cr-text-image { grid-template-columns:1fr 1fr; align-items:start; }
.cr-section-text.layout-img-left .cr-text-img-wrap { order:-1; }
.cr-section-text.no-media {
    padding:30px 32px; border-radius:28px;
    background:linear-gradient(145deg, rgba(255,255,255,0.94), rgba(248,250,249,0.88));
    border:1px solid rgba(127,166,155,0.12);
    box-shadow:0 20px 46px rgba(15,35,32,0.06);
}
.cr-section-text.no-media .cr-section-header-inner,
.cr-section-text.no-media .cr-text-body {
    max-width:880px;
}
.cr-section-text.no-media .cr-text-image {
    grid-template-columns:minmax(0, 1fr);
}
.cr-text-body { font-size:0.94rem; color:#5C6E6A; line-height:1.82; }
.cr-section-text.no-media .cr-text-body { font-size:1rem; }
.cr-text-body p { margin-bottom:14px; }
.cr-text-body p:last-child { margin-bottom:0; }
.cr-text-img-wrap {
    border-radius:16px; overflow:hidden;
    box-shadow:0 8px 32px rgba(127,166,155,0.1);
}
.cr-text-img-wrap img {
    width:100%; height:100%; object-fit:cover;
    border-radius:16px;
}

/* -----------------------------------------------------------------------
   9. CARDS GRID
----------------------------------------------------------------------- */
.cr-cards-grid {
    display:grid; grid-template-columns:repeat(2, minmax(0, 1fr));
    gap:18px;
}
.cr-cards-grid.is-three-up { grid-template-columns:repeat(3, minmax(0, 1fr)); }
.cr-cards-grid.is-two-up { grid-template-columns:repeat(2, minmax(0, 1fr)); }
.cr-card {
    padding:22px 20px; border-radius:16px;
    border:1px solid rgba(127,166,155,0.10);
    background:linear-gradient(145deg, #fff, #f8faf9);
    box-shadow:0 4px 16px rgba(127,166,155,0.06);
    transition:all 0.35s cubic-bezier(0.4,0,0.2,1);
    animation:crFadeUp 0.5s cubic-bezier(0.23,1,0.32,1) calc(var(--card-delay,0s)) both;
    min-height:218px;
}
.cr-card:hover {
    transform:translateY(-5px);
    box-shadow:0 12px 36px rgba(127,166,155,0.14);
    border-color:rgba(127,166,155,0.22);
}
.cr-card-icon-wrap {
    width:44px; height:44px; border-radius:12px;
    background:linear-gradient(135deg, rgba(127,166,155,0.12), rgba(127,166,155,0.05));
    display:flex; align-items:center; justify-content:center;
    font-size:1rem; color:#7FA69B; margin-bottom:14px;
    transition:transform 0.4s;
}
.cr-card:hover .cr-card-icon-wrap { transform:scale(1.15) rotate(6deg); }
.cr-card h3 { font-size:0.94rem; font-weight:700; color:#1a2a28; margin-bottom:8px; }
.cr-card p { font-size:0.84rem; color:#5C6E6A; line-height:1.65; }

/* -----------------------------------------------------------------------
   10. GALLERY
----------------------------------------------------------------------- */
.cr-gallery-toolbar {
    display:flex; align-items:flex-end; justify-content:space-between;
    gap:18px; margin-bottom:20px;
}
.cr-gallery-overview p {
    max-width:640px; font-size:0.9rem; line-height:1.72; color:#5C6E6A;
}
.cr-gallery-count {
    display:inline-flex; align-items:center; gap:8px; margin-bottom:8px;
    font-size:0.76rem; font-weight:700; letter-spacing:0.1em; text-transform:uppercase;
    color:#7FA69B;
}
.cr-albums-grid {
    display:grid; grid-template-columns:repeat(3, minmax(0, 1fr));
    gap:24px;
}
.cr-album-card {
    display:flex; flex-direction:column; gap:12px;
    border:none; background:transparent; padding:0; text-align:left; cursor:pointer;
    animation:crFadeUp 0.5s cubic-bezier(0.23,1,0.32,1) calc(var(--card-delay,0s)) both;
}
.cr-album-cover {
    position:relative; width:100%; aspect-ratio:4/3;
    border-radius:18px; overflow:hidden; background:#d9e6e1;
    box-shadow:0 12px 24px rgba(15,35,32,0.06);
}
.cr-album-cover img {
    width:100%; height:100%; object-fit:cover;
    transition:transform 0.6s cubic-bezier(0.23,1,0.32,1);
}
.cr-album-overlay {
    position:absolute; inset:0; background:rgba(15,35,32,0.25);
    display:flex; align-items:center; justify-content:center;
    opacity:0; transition:opacity 0.3s;
}
.cr-album-overlay i {
    color:#fff; font-size:2rem; transform:scale(0.8); transition:transform 0.3s;
    filter:drop-shadow(0 4px 8px rgba(0,0,0,0.3));
}
.cr-album-card:hover .cr-album-cover img { transform:scale(1.08); }
.cr-album-card:hover .cr-album-overlay { opacity:1; }
.cr-album-card:hover .cr-album-overlay i { transform:scale(1); }
.cr-album-info {
    padding:4px 8px;
}
.cr-album-info h4 {
    font-size:1.05rem; color:#1a2a28; margin-bottom:4px;
    font-weight:600; font-family:'Exo 2', sans-serif;
}
.cr-album-info span {
    font-size:0.8rem; color:#7FA69B; font-weight:600; letter-spacing:0.05em; text-transform:uppercase;
}
.cr-album-card:focus-visible .cr-album-cover {
    outline:3px solid rgba(127,166,155,0.6); outline-offset:4px;
}
body.cr-gallery-open { overflow:hidden; }
.cr-gallery-modal {
    position:fixed; inset:0; z-index:9999; display:none; flex-direction:column;
    background:rgba(0,0,0,0.92); backdrop-filter:blur(8px);
}
.cr-gallery-modal.active {
    display:flex;
}
.cr-gallery-backdrop {
    display:none; /* No longer needed as modal itself is the backdrop */
}
.cr-gallery-dialog {
    position:relative; z-index:1; width:100%; height:100%;
    display:flex; flex-direction:column; overflow:hidden;
}
.cr-gallery-modal-head {
    display:flex; align-items:flex-start; justify-content:space-between;
    padding:24px 32px; position:absolute; top:0; left:0; right:0; z-index:10;
    pointer-events:none; /* Let clicks pass through except on elements */
}
.cr-gallery-modal-kicker {
    display:block; margin-bottom:4px; font-size:0.85rem; font-weight:700;
    letter-spacing:0.15em; text-transform:uppercase; color:#fff; pointer-events:auto;
    text-shadow:0 2px 4px rgba(0,0,0,0.5);
}
.cr-gallery-modal-head h3 {
    font-family:'Exo 2',sans-serif; font-size:1.4rem; font-weight:400; color:#fff;
    pointer-events:auto; text-shadow:0 2px 4px rgba(0,0,0,0.5); margin:0;
}
.cr-gallery-close {
    border:none; background:transparent; color:#fff; font-size:2rem; cursor:pointer;
    pointer-events:auto; display:flex; align-items:center; justify-content:center;
    width:48px; height:48px; transition:transform 0.2s, opacity 0.2s; opacity:0.7;
}
.cr-gallery-close:hover {
    transform:scale(1.1); opacity:1;
}
.cr-gallery-modal-stage {
    flex:1; display:flex; align-items:center; justify-content:center;
    position:relative; padding:0; height:80vh; max-height:80vh; margin-top:5vh;
}
.cr-gallery-nav {
    position:absolute; top:50%; transform:translateY(-50%);
    background:transparent; border:none; color:#fff; font-size:3rem;
    cursor:pointer; padding:20px; z-index:5; opacity:0.5; transition:opacity 0.2s, transform 0.2s;
    display:flex; align-items:center; justify-content:center;
}
.cr-gallery-nav:hover { opacity:1; }
.cr-gallery-nav:first-child { left:20px; }
.cr-gallery-nav:last-child { right:20px; }
.cr-gallery-modal-frame {
    width:100%; height:100%; display:flex; align-items:center; justify-content:center;
    padding:0 80px; box-sizing:border-box;
}
.cr-gallery-modal-frame img {
    max-width:100%; max-height:100%; object-fit:contain; display:block;
    filter:drop-shadow(0 10px 30px rgba(0,0,0,0.3));
}
.cr-gallery-modal-foot {
    padding:20px 32px 32px; display:flex; flex-direction:column; align-items:center; gap:16px; z-index:10;
}
.cr-gallery-modal-caption {
    color:#fff; font-size:1rem; text-align:center; text-shadow:0 1px 3px rgba(0,0,0,0.8);
}
.cr-gallery-modal-counter {
    font-size:0.85rem; font-weight:600; color:rgba(255,255,255,0.6); letter-spacing:0.1em;
}
.cr-gallery-thumbs {
    display:flex; gap:12px; justify-content:center; max-width:800px;
    overflow-x:auto; padding-bottom:8px;
    scrollbar-width:none; /* Firefox */
}
.cr-gallery-thumbs::-webkit-scrollbar { display:none; }
.cr-gallery-thumb {
    border:2px solid transparent; padding:0; border-radius:8px; overflow:hidden;
    cursor:pointer; width:64px; height:64px; flex-shrink:0; opacity:0.4;
    transition:opacity 0.3s, border-color 0.3s, transform 0.3s;
}
.cr-gallery-thumb:hover { opacity:0.8; transform:translateY(-2px); }
.cr-gallery-thumb.active { border-color:#fff; opacity:1; }
.cr-gallery-thumb img {
    width:100%; height:100%; object-fit:cover; display:block;
}

/* -----------------------------------------------------------------------
   11. TESTIMONIALS
----------------------------------------------------------------------- */
.cr-testimonials-slider { position:relative; }
.cr-testimonial {
    display:none; padding:28px; border-radius:20px;
    background:#fff; border:1px solid rgba(127,166,155,0.08);
    box-shadow:0 4px 24px rgba(127,166,155,0.06);
    animation:crFadeIn 0.4s ease;
}
.cr-testimonial.active { display:block; }
@keyframes crFadeIn { from{opacity:0;transform:translateY(10px)} to{opacity:1;transform:none} }
.cr-testimonial-quote { position:relative; margin-bottom:20px; }
.cr-testimonial-quote i { color:rgba(127,166,155,0.25); font-size:1.6rem; margin-bottom:12px; display:block; }
.cr-testimonial-quote p { font-size:0.94rem; color:#5C6E6A; line-height:1.82; font-style:italic; }
.cr-testimonial-author { display:flex; align-items:center; gap:14px; }
.cr-testimonial-author img {
    width:52px; height:52px; border-radius:50%; object-fit:cover;
    border:3px solid rgba(127,166,155,0.18);
}
.cr-testimonial-avatar {
    width:52px; height:52px; border-radius:50%;
    background:linear-gradient(135deg, #e8f0ed, #d1dfd8);
    display:flex; align-items:center; justify-content:center;
    color:rgba(127,166,155,0.5); font-size:1.2rem;
}
.cr-testimonial-author strong { display:block; font-size:0.9rem; color:#1a2a28; }
.cr-testimonial-author span { font-size:0.78rem; color:#7FA69B; font-weight:600; }
.cr-testimonial-nav {
    display:flex; align-items:center; justify-content:center; gap:14px; margin-top:20px;
}
.cr-test-prev, .cr-test-next {
    width:36px; height:36px; border-radius:50%;
    background:#f8faf9; border:1px solid rgba(127,166,155,0.15);
    cursor:pointer; display:flex; align-items:center; justify-content:center;
    color:#5C6E6A; font-size:0.75rem; transition:all 0.2s;
}
.cr-test-prev:hover, .cr-test-next:hover { background:#7FA69B; color:#fff; }
.cr-test-dots { display:flex; gap:6px; }
.cr-test-dot {
    width:8px; height:8px; border-radius:50%;
    background:rgba(127,166,155,0.2); cursor:pointer; transition:all 0.3s;
}
.cr-test-dot.active { background:#7FA69B; width:24px; border-radius:4px; }

/* -----------------------------------------------------------------------
   12. JOB LISTINGS
----------------------------------------------------------------------- */
.cr-jobs-filters {
    display:flex; gap:12px; margin-bottom:20px; flex-wrap:wrap;
}
.cr-job-search, .cr-job-filter {
    padding:10px 16px; border:1px solid rgba(127,166,155,0.18);
    border-radius:10px; font-size:0.85rem; color:#2C3E3A;
    background:#fff; transition:border-color 0.3s; outline:none;
}
.cr-job-search { flex:1; min-width:200px; }
.cr-job-search:focus, .cr-job-filter:focus { border-color:#7FA69B; box-shadow:0 0 0 3px rgba(127,166,155,0.1); }
.cr-jobs-list { display:flex; flex-direction:column; gap:14px; }
.cr-job-card {
    background:#fff; border:1px solid rgba(127,166,155,0.10);
    border-radius:16px; overflow:hidden;
    box-shadow:0 2px 12px rgba(127,166,155,0.04);
    transition:all 0.35s; position:relative;
    animation:crFadeUp 0.5s cubic-bezier(0.23,1,0.32,1) calc(var(--card-delay,0s)) both;
}
.cr-job-card:hover {
    box-shadow:0 8px 28px rgba(127,166,155,0.1);
    border-color:rgba(127,166,155,0.2);
}
.cr-job-card.featured { border-left:3px solid #7FA69B; }
.cr-job-featured {
    position:absolute; top:14px; right:14px;
    font-size:0.68rem; font-weight:700; color:#7FA69B;
    background:rgba(127,166,155,0.1); border:1px solid rgba(127,166,155,0.2);
    padding:4px 10px; border-radius:20px;
}
.cr-job-featured i { font-size:0.6rem; margin-right:4px; }
.cr-job-header { padding:20px 22px 0; }
.cr-job-header h3 {
    font-family:'Exo 2',sans-serif; font-size:1.05rem; font-weight:700;
    color:#1a2a28; margin-bottom:10px; padding-right:100px;
}
.cr-job-meta { display:flex; flex-wrap:wrap; gap:10px; }
.cr-job-meta span {
    display:inline-flex; align-items:center; gap:5px;
    font-size:0.78rem; color:#5C6E6A;
}
.cr-job-meta i { color:#7FA69B; font-size:0.7rem; }
.cr-job-type {
    background:rgba(127,166,155,0.08); padding:2px 8px; border-radius:6px;
}
.cr-job-body { padding:14px 22px; }
.cr-job-desc {
    font-size:0.87rem; color:#5C6E6A; line-height:1.7;
    display:-webkit-box; line-clamp:2; -webkit-line-clamp:2; -webkit-box-orient:vertical;
    overflow:hidden;
}
.cr-job-toggle {
    background:none; border:none; cursor:pointer;
    color:#7FA69B; font-size:0.82rem; font-weight:600;
    padding:6px 0; display:flex; align-items:center; gap:6px;
    transition:color 0.2s;
}
.cr-job-toggle:hover { color:#5C6E6A; }
.cr-job-toggle .hide-text { display:none; }
.cr-job-card.expanded .cr-job-toggle .show-text { display:none; }
.cr-job-card.expanded .cr-job-toggle .hide-text { display:flex; align-items:center; gap:6px; }
.cr-job-details {
    max-height:0; overflow:hidden; transition:max-height 0.5s cubic-bezier(0.4,0,0.2,1);
}
.cr-job-card.expanded .cr-job-details { max-height:800px; }
.cr-job-detail-block { margin-top:16px; }
.cr-job-detail-block h4 {
    font-size:0.85rem; font-weight:700; color:#2C3E3A;
    margin-bottom:8px; display:flex; align-items:center; gap:8px;
}
.cr-job-detail-block h4 i { color:#7FA69B; font-size:0.8rem; }
.cr-job-detail-block p, .cr-job-detail-block div { font-size:0.85rem; color:#5C6E6A; line-height:1.72; }
.cr-job-detail-block ul { padding-left:18px; }
.cr-job-detail-block li { margin-bottom:6px; }
.cr-job-skills { display:flex; flex-wrap:wrap; gap:6px; }
.cr-skill-tag {
    padding:4px 12px; border-radius:8px; font-size:0.78rem; font-weight:600;
    background:rgba(127,166,155,0.08); color:#5C6E6A;
    border:1px solid rgba(127,166,155,0.12);
}
.cr-job-footer { padding:0 22px 18px; }

/* -----------------------------------------------------------------------
   13. APPLICATION FORM
----------------------------------------------------------------------- */
.cr-apply-form-wrap {
    background:#fff; border-radius:20px;
    border:1px solid rgba(127,166,155,0.10);
    padding:32px; box-shadow:0 4px 24px rgba(127,166,155,0.06);
}
.cr-apply-job-info {
    display:flex; align-items:center; gap:10px;
    padding:12px 16px; border-radius:10px;
    background:rgba(127,166,155,0.06); border:1px solid rgba(127,166,155,0.15);
    font-size:0.85rem; color:#2C3E3A; margin-bottom:20px;
}
.cr-apply-clear {
    margin-left:auto; background:none; border:none; cursor:pointer;
    color:#7FA69B; font-size:0.8rem;
}
.cr-form-grid {
    display:grid; grid-template-columns:1fr 1fr; gap:16px; margin-bottom:24px;
}
.cr-form-full { grid-column:1/-1; }
.cr-form-group label {
    display:block; font-size:0.82rem; font-weight:600; color:#2C3E3A; margin-bottom:6px;
}
.cr-form-group input,
.cr-form-group textarea,
.cr-form-group select {
    width:100%; padding:11px 14px; border:1px solid rgba(127,166,155,0.18);
    border-radius:10px; font-size:0.87rem; color:#2C3E3A;
    background:#f8faf9; transition:all 0.3s; outline:none;
    font-family:inherit;
}
.cr-form-group input:focus,
.cr-form-group textarea:focus { border-color:#7FA69B; background:#fff; box-shadow:0 0 0 3px rgba(127,166,155,0.08); }
.cr-file-upload {
    position:relative; border:2px dashed rgba(127,166,155,0.25);
    border-radius:14px; padding:28px; text-align:center;
    background:#f8faf9; transition:all 0.3s; cursor:pointer;
}
.cr-file-upload:hover { border-color:#7FA69B; background:rgba(127,166,155,0.03); }
.cr-file-upload input[type=file] {
    position:absolute; inset:0; opacity:0; cursor:pointer;
}
.cr-file-upload-label i { font-size:1.8rem; color:#7FA69B; margin-bottom:8px; display:block; }
.cr-file-upload-label span { display:block; font-size:0.88rem; color:#5C6E6A; font-weight:600; }
.cr-file-upload-label small { display:block; font-size:0.76rem; color:#9bb3ac; margin-top:4px; }
.cr-form-status { margin-top:16px; text-align:center; }
.cr-form-success { color:#22c55e; font-weight:600; }
.cr-form-error { color:#ef4444; font-weight:600; }
.cr-form-loading { color:#7FA69B; }
.cr-empty-note {
    text-align:center; padding:36px; color:#9bb3ac; font-size:0.92rem;
}
.cr-empty-note i { font-size:2rem; margin-bottom:12px; display:block; opacity:0.4; }

/* -----------------------------------------------------------------------
   14. CONNECT BANNER (matching company-pages)
----------------------------------------------------------------------- */
.cr-connect {
    position:relative; padding:64px 0;
    background:linear-gradient(145deg, #0a1a14 0%, #0C1B26 50%, #0e1d28 100%);
    overflow:hidden;
}
.cr-connect-glow {
    position:absolute; width:480px; height:300px; left:50%; top:50%;
    transform:translate(-50%,-50%);
    background:radial-gradient(ellipse, rgba(127,166,155,0.12), transparent 65%);
    filter:blur(50px); pointer-events:none;
}
.cr-connect-inner {
    display:grid; grid-template-columns:1fr auto 1fr;
    align-items:center; gap:40px;
    position:relative; z-index:2;
}
.cr-connect-headline {
    font-family:'Exo 2',sans-serif; font-size:1.7rem; font-weight:300;
    color:#fff; line-height:1.3;
}
.cr-connect-headline strong { font-weight:700; }
.cr-connect-headline .accent {
    background:linear-gradient(135deg,#7FA69B,#D7EFE8);
    -webkit-background-clip:text; -webkit-text-fill-color:transparent; background-clip:text;
}
.cr-connect-center { text-align:center; }
.cr-connect-center > i { font-size:1.5rem; color:#7FA69B; display:block; margin-bottom:10px; }
.cr-connect-name { display:block; font-size:0.82rem; font-weight:600; color:rgba(255,255,255,0.5); margin-bottom:4px; }
.cr-connect-email {
    display:block; font-size:0.95rem; font-weight:700; color:#9BC0B4; text-decoration:none;
}
.cr-connect-email:hover { text-decoration:underline; }
.cr-connect-social-wrap { text-align:right; }
.cr-connect-social-label { display:block; font-size:0.7rem; font-weight:700; text-transform:uppercase; letter-spacing:0.12em; color:rgba(255,255,255,0.3); margin-bottom:10px; }
.cr-connect-social { display:flex; gap:8px; justify-content:flex-end; }
.cr-connect-social a {
    width:36px; height:36px; border-radius:10px;
    background:rgba(127,166,155,0.1); border:1px solid rgba(127,166,155,0.18);
    display:flex; align-items:center; justify-content:center;
    color:#7FA69B; font-size:0.8rem; text-decoration:none;
    transition:all 0.3s;
}
.cr-connect-social a:hover { background:#7FA69B; color:#fff; transform:translateY(-3px); }

/* Footer wave override for dark career pages */
.page-careers .footer-wave-divider { background:#0C1B26; }

/* -----------------------------------------------------------------------
   15. RESPONSIVE
----------------------------------------------------------------------- */
@media (max-width:1200px) {
    .cr-hero-layout, .cr-hero-layout-sub { grid-template-columns:1fr; gap:32px; }
    .cr-hero-visual, .cr-hero-visual-sub { justify-content:center; }
    .cr-why-grid { grid-template-columns:1fr; gap:40px; }
    .cr-why-visual { display:none; }
    .cr-connect-inner { grid-template-columns:1fr; gap:24px; text-align:center; }
    .cr-connect-social-wrap { text-align:center; }
    .cr-connect-social { justify-content:center; }
    .cr-cards-grid.is-three-up { grid-template-columns:repeat(2, minmax(0, 1fr)); }
    .cr-albums-grid { grid-template-columns:repeat(2, minmax(0, 1fr)); }
}
@media (max-width:900px) {
    .cr-layout { grid-template-columns:1fr; }
    .cr-sidebar { display:none; }
    .cr-pages-grid { grid-template-columns:1fr; }
    .cr-cards-grid,
    .cr-cards-grid.is-two-up,
    .cr-cards-grid.is-three-up { grid-template-columns:repeat(2, minmax(0, 1fr)); }
    .cr-section-text.layout-img-left .cr-text-image,
    .cr-section-text.layout-img-right .cr-text-image { grid-template-columns:1fr; }
    .cr-gallery-toolbar,
    .cr-gallery-modal-foot { flex-direction:column; align-items:flex-start; }
    .cr-gallery-modal-caption { margin-left:0; }
    .cr-gallery-modal-stage { grid-template-columns:1fr; }
    .cr-gallery-nav { display:none; }
}
@media (max-width:640px) {
    .cr-hero { padding:100px 0 48px; min-height:auto; }
    .cr-hero-sub { min-height:auto; }
    .cr-hero-title { font-size:clamp(1.8rem, 7vw, 2.4rem); }
    .cr-hero-actions { flex-direction:column; }
    .cr-btn { width:100%; }
    .cr-orbit-wrap { width:280px; height:280px; }
    .cr-orbit-ring.ring-outer { width:260px; height:260px; }
    .cr-orbit-ring.ring-mid { width:190px; height:190px; }
    .cr-orbit-ring.ring-inner { width:100px; height:100px; }
    .cr-orbit-card { width:85px; padding:8px 10px; }
    .cr-orbit-card-val { font-size:0.95rem; }
    .cr-form-grid { grid-template-columns:1fr; }
    .cr-jobs-filters { flex-direction:column; }
    .cr-job-header h3 { padding-right:0; }
    .cr-albums-grid { grid-template-columns:1fr; }
    .cr-hero-stage { min-height:360px; }
    .cr-hero-stage-panel { min-height:360px; padding:22px; }
    .cr-hero-stage-chip {
        min-width:unset; max-width:none; width:calc(100% - 44px);
    }
    .cr-hero-stage-culture .chip-1,
    .cr-hero-stage-grow .chip-1 { top:14px; left:22px; right:22px; }
    .cr-hero-stage-culture .chip-2,
    .cr-hero-stage-grow .chip-2 { top:auto; right:22px; bottom:82px; left:22px; }
    .cr-hero-stage-culture .chip-3,
    .cr-hero-stage-grow .chip-3 { left:22px; right:22px; bottom:18px; }
    .cr-vis-culture, .cr-vis-grow { width:260px; height:260px; }
    .cr-vis-culture-label { font-size:0.7rem; padding:8px 10px; }
    .cr-cards-grid,
    .cr-cards-grid.is-two-up,
    .cr-cards-grid.is-three-up { grid-template-columns:1fr; }
    .cr-section-text.no-media { padding:24px 20px; }
    .cr-gallery-dialog { padding:18px; width:min(100%, calc(100% - 16px)); }
}
