:root {
  --maroon:       #800020;
  --maroon-deep:  #5c0016;
  --maroon-mid:   #9b0027;
  --gold:         #c9a84c;
  --gold-lt:      #dbb96a;
  --gold-pale:    #f0dfa0;
  --ink:          #0d0608;
  --ink-2:        #181012;
  --ink-3:        #261619;
  --cream:        #f7f3ee;
  --cream-2:      #ede8e1;
  --white:        #ffffff;
  --muted:        #4a4547;
  --border:       rgba(0,0,0,0.09);
  --ease:         cubic-bezier(0.22,0.61,0.36,1);
  --tr:           0.4s var(--ease);
}
*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
html{font-size:16px;scroll-behavior:smooth}
body{font-family:'DM Sans',sans-serif;color:#111010;background:var(--white);overflow-x:hidden;-webkit-font-smoothing:antialiased}
img{max-width:100%;height:auto;display:block}
a{text-decoration:none;color:inherit;transition:var(--tr)}
ul{list-style:none}
button{font-family:inherit;cursor:pointer;border:none;background:none}

h1,h2,h3,h4{font-family:'Cormorant Garamond',serif;line-height:1.05}
h1{font-size:clamp(4.2rem,10vw,9.5rem);font-weight:300;letter-spacing:-0.025em}
h2{font-size:clamp(2.6rem,5.5vw,5rem);font-weight:300;letter-spacing:-0.015em}
h3{font-size:clamp(1.6rem,3vw,2.4rem);font-weight:400}
p{line-height:1.85;color:#3d3a3b}

.mono{font-family:'DM Mono',monospace;font-size:0.7rem;letter-spacing:0.22em;text-transform:uppercase;color:var(--gold);display:block}
.wrap{max-width:1320px;margin:0 auto;padding:0 3rem}
.sec{padding:10rem 0}

.btn{display:inline-flex;align-items:center;gap:0.65rem;font-family:'DM Sans',sans-serif;font-weight:600;font-size:0.78rem;letter-spacing:0.13em;text-transform:uppercase;padding:1.05rem 2.4rem;position:relative;overflow:hidden;transition:var(--tr);cursor:pointer}
.btn-primary{background:var(--maroon);color:#fff}
.btn-primary:hover{background:var(--maroon-deep);transform:translateY(-2px);box-shadow:0 16px 40px rgba(128,0,32,0.35)}
.btn-gold{background:var(--gold);color:#fff}
.btn-gold:hover{background:var(--gold-lt);transform:translateY(-2px);box-shadow:0 16px 40px rgba(201,168,76,0.35)}
.btn-ghost{background:transparent;color:#fff;border:1px solid rgba(255,255,255,0.38)}
.btn-ghost:hover{background:#fff;color:var(--ink)}
.btn-outline{background:transparent;color:var(--maroon);border:1.5px solid var(--maroon)}
.btn-outline:hover{background:var(--maroon);color:#fff}
.btn i{transition:transform 0.35s var(--ease)}
.btn:hover i{transform:translateX(5px)}

.nav{position:fixed;top:0;left:0;right:0;z-index:1000;padding:2rem 0;transition:padding 0.5s var(--ease),background 0.5s ease,box-shadow 0.4s ease}
.nav.scrolled{background:rgba(10,5,7,0.96);backdrop-filter:blur(24px);-webkit-backdrop-filter:blur(24px);padding:1.1rem 0;box-shadow:0 1px 0 rgba(255,255,255,0.04)}
.nav-inner{display:flex;align-items:center;justify-content:space-between;max-width:1320px;margin:0 auto;padding:0 3rem}
.logo{display:flex;align-items:center;gap:0.9rem;margin-right:4rem}
.logo-img{height:90px;width:auto;display:block;flex-shrink:0;background:#fff;padding:5px 10px;border-radius:5px;box-shadow:0 2px 12px rgba(0,0,0,0.25)}
.logo-text{font-family:'Cormorant Garamond',serif;font-weight:700;font-size:1.85rem;color:#fff;line-height:1.05;letter-spacing:0.02em}
.logo-sub{font-family:'DM Mono',monospace;font-size:0.6rem;letter-spacing:0.28em;text-transform:uppercase;color:rgba(255,255,255,0.55);display:block;margin-top:3px}
.logo-gem{width:36px;height:36px;flex-shrink:0;background:var(--gold);clip-path:polygon(50% 0%,100% 25%,100% 75%,50% 100%,0% 75%,0% 25%)}
.nav-links{display:flex;align-items:center;gap:2.8rem}
.nav-links a{color:rgba(255,255,255,0.68);font-size:0.77rem;font-weight:500;letter-spacing:0.1em;text-transform:uppercase;position:relative;padding-bottom:3px}
.nav-links a::after{content:'';position:absolute;bottom:-1px;left:0;width:0;height:1px;background:var(--gold);transition:width 0.35s var(--ease)}
.nav-links a:hover,.nav-links a.active{color:#fff}
.nav-links a:hover::after,.nav-links a.active::after{width:100%}
.nav-cta{background:var(--gold)!important;color:#fff!important;padding:0.65rem 1.5rem;font-size:0.73rem!important}
.nav-cta:hover{background:var(--gold-lt)!important}
.nav-cta::after{display:none!important}
.ham{display:none;flex-direction:column;gap:5px;z-index:1100}
.ham span{display:block;width:22px;height:1.5px;background:#fff;transition:var(--tr)}
.ham.open span:nth-child(1){transform:rotate(45deg) translate(4.5px,5px)}
.ham.open span:nth-child(2){opacity:0;transform:scaleX(0)}
.ham.open span:nth-child(3){transform:rotate(-45deg) translate(4.5px,-5px)}
.mob-menu{display:none;position:fixed;inset:0;background:var(--ink);flex-direction:column;justify-content:center;align-items:center;gap:2.8rem;z-index:1000}
.mob-menu.open{display:flex}
.mob-menu a{font-family:'Cormorant Garamond',serif;font-size:2.6rem;font-weight:300;color:#fff}
.mob-menu a:hover{color:var(--gold)}

.hero{position:relative;min-height:100vh;display:flex;flex-direction:column;justify-content:flex-end;overflow:hidden}
.hero-img{position:absolute;inset:0;background:url('assets/hero-mining.png') center 30%/120% auto no-repeat;will-change:transform}
.hero-img-2{display:none}
.hero-fade{position:absolute;inset:0;background:linear-gradient(to right,rgba(8,3,5,0.72) 0%,rgba(8,3,5,0.3) 50%,rgba(8,3,5,0.08) 100%),linear-gradient(to top,rgba(8,3,5,0.85) 0%,rgba(8,3,5,0.0) 45%),linear-gradient(150deg,rgba(100,8,20,0.45) 0%,transparent 55%)}
.hero-grain{position:absolute;inset:0;pointer-events:none;opacity:0.45;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='300' height='300'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='300' height='300' filter='url(%23n)' opacity='0.06'/%3E%3C/svg%3E")}
.hero-body{position:relative;z-index:2;max-width:1320px;margin:0 auto;width:100%;padding:9rem 3rem 7.5rem}
.hero-kicker{font-family:'DM Mono',monospace;font-size:0.68rem;letter-spacing:0.38em;text-transform:uppercase;color:var(--gold);display:flex;align-items:center;gap:1rem;margin-bottom:2.2rem;opacity:0;animation:riseUp 0.9s var(--ease) 0.25s forwards}
.hero-kicker::before{content:'';width:32px;height:1px;background:var(--gold)}
.hero-h1{font-family:'Cormorant Garamond',serif;font-weight:300;font-size:clamp(3.5rem,8vw,7.5rem);line-height:0.95;letter-spacing:-0.025em;color:#fff;margin-bottom:3rem;opacity:0;animation:riseUp 1.1s var(--ease) 0.45s forwards}
.hero-h1 em{font-style:italic;color:var(--gold-pale)}
.hero-row{display:flex;align-items:flex-end;gap:4.5rem;flex-wrap:wrap;opacity:0;animation:fadeUp 1s ease 1s forwards}
.hero-desc{font-size:1rem;font-weight:300;color:rgba(255,255,255,0.65);line-height:1.9;max-width:480px}
.hero-btns{display:flex;gap:1rem;flex-wrap:wrap;margin-left:auto}
.hero-scroll{position:absolute;right:3.5rem;bottom:7rem;z-index:3;display:flex;flex-direction:column;align-items:center;gap:1.2rem;opacity:0;animation:fadeUp 1s ease 1.5s forwards}
.hero-scroll span{font-family:'DM Mono',monospace;font-size:0.58rem;letter-spacing:0.32em;text-transform:uppercase;color:rgba(255,255,255,0.32);writing-mode:vertical-rl;transform:rotate(180deg)}
.scroll-rod{width:1px;height:75px;background:rgba(255,255,255,0.12);position:relative;overflow:hidden}
.scroll-fill{position:absolute;top:-100%;left:0;width:100%;height:100%;background:linear-gradient(to bottom,transparent,var(--gold));animation:rodScroll 2.6s ease-in-out infinite}
.hero-band{position:absolute;bottom:0;left:0;right:0;z-index:3;background:rgba(0,0,0,0.42);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border-top:1px solid rgba(255,255,255,0.06)}
.hero-band-inner{max-width:1320px;margin:0 auto;padding:0 3rem;height:58px;display:flex;align-items:center;justify-content:space-between}
.cred{display:flex;align-items:center;gap:0.7rem;font-family:'DM Mono',monospace;font-size:0.63rem;letter-spacing:0.16em;text-transform:uppercase;color:rgba(255,255,255,0.32)}
.cred i{color:var(--gold);font-size:0.7rem}
.cred-divider{width:1px;height:20px;background:rgba(255,255,255,0.1)}

.ticker{background:var(--ink-2);overflow:hidden;border-bottom:1px solid rgba(201,168,76,0.15)}
.ticker-track{display:flex;align-items:center;padding:0.9rem 0;animation:tickerScroll 28s linear infinite;white-space:nowrap;width:max-content}
.ticker-item{font-family:'DM Mono',monospace;font-size:0.68rem;letter-spacing:0.14em;text-transform:uppercase;color:var(--gold);padding-right:3.5rem;display:flex;align-items:center;gap:1rem}
.ticker-dot{width:4px;height:4px;background:var(--maroon);border-radius:50%;flex-shrink:0}
.ticker-track:hover{animation-play-state:paused}

.stats{background:var(--maroon)}
.stats-grid{display:grid;grid-template-columns:repeat(4,1fr);max-width:1320px;margin:0 auto;border-left:1px solid rgba(255,255,255,0.1)}
.stat{padding:4rem 3rem;border-right:1px solid rgba(255,255,255,0.1);position:relative;overflow:hidden;transition:background 0.4s ease}
.stat:hover{background:rgba(0,0,0,0.18)}
.stat::after{content:'';position:absolute;bottom:0;left:0;width:0;height:3px;background:var(--gold);transition:width 0.7s var(--ease)}
.stat:hover::after{width:100%}
.stat-bg-num{position:absolute;right:1.5rem;top:1rem;font-family:'Cormorant Garamond',serif;font-size:7rem;font-weight:700;color:rgba(255,255,255,0.04);line-height:1;pointer-events:none}
.stat-n{font-family:'Cormorant Garamond',serif;font-size:clamp(2.8rem,5vw,4.2rem);font-weight:600;color:#fff;line-height:1;display:block;margin-bottom:0.6rem}
.stat-l{font-family:'DM Mono',monospace;font-size:0.65rem;letter-spacing:0.18em;text-transform:uppercase;color:rgba(255,255,255,0.45)}

.about{background:var(--white)}
.about-grid{display:grid;grid-template-columns:1fr 1fr;gap:5rem;align-items:center}
.about-visual{position:relative}
.about-img-main{width:100%;height:600px;object-fit:cover;display:block}
.about-img-thumb{position:absolute;bottom:-3.5rem;right:-3rem;width:52%;height:260px;object-fit:cover;display:block;border:7px solid #fff;box-shadow:0 30px 70px rgba(0,0,0,0.2)}
.about-corner{position:absolute;top:-1.8rem;left:-1.8rem;width:120px;height:120px;border:1px solid var(--maroon);opacity:0.22;pointer-events:none}
.about-badge{position:absolute;top:3rem;right:-2rem;z-index:2;background:var(--gold);color:#fff;width:112px;height:112px;border-radius:50%;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;box-shadow:0 20px 50px rgba(201,168,76,0.4)}
.about-badge strong{font-family:'Cormorant Garamond',serif;font-size:2rem;font-weight:700;line-height:1}
.about-badge span{font-family:'DM Mono',monospace;font-size:0.56rem;letter-spacing:0.1em;text-transform:uppercase;margin-top:2px}
.about-text .mono{margin-bottom:1.2rem}
.about-text h2{margin-bottom:2rem}
.about-text h2 span{color:var(--maroon);font-style:italic}
.about-lead{font-size:1.1rem;color:#222;line-height:1.85;margin-bottom:1.2rem}
.about-text>p{margin-bottom:1rem}
.feat-grid{display:grid;grid-template-columns:1fr 1fr;border:1px solid var(--border);margin:2.8rem 0}
.feat-cell{padding:1.5rem 1.8rem;border-right:1px solid var(--border);border-bottom:1px solid var(--border);display:flex;align-items:flex-start;gap:1rem;transition:background 0.3s ease}
.feat-cell:nth-child(even){border-right:none}
.feat-cell:nth-child(3),.feat-cell:nth-child(4){border-bottom:none}
.feat-cell:hover{background:var(--cream)}
.feat-ico{width:38px;height:38px;flex-shrink:0;border:1px solid rgba(128,0,32,0.25);display:flex;align-items:center;justify-content:center;color:var(--maroon);font-size:0.9rem;transition:var(--tr)}
.feat-cell:hover .feat-ico{background:var(--maroon);color:#fff;border-color:var(--maroon)}
.feat-name{display:block;font-weight:600;font-size:0.87rem;color:#1c1a1b;margin-bottom:0.2rem}
.feat-desc{font-size:0.78rem;color:var(--muted)}

.ops{background:var(--ink);padding:10rem 0 0;position:relative;overflow:hidden}
.ops-head{display:grid;grid-template-columns:1fr 1fr;gap:5rem;align-items:end;margin-bottom:6rem}
.ops-head h2{color:#fff}
.ops-head .sub{color:rgba(255,255,255,0.72);margin-top:0}
.ops-cards{display:grid;grid-template-columns:repeat(4,1fr);border-top:1px solid rgba(255,255,255,0.07);background:linear-gradient(to bottom,rgba(107,10,26,0.95),rgba(77,7,19,0.98))}
.op-card{padding:4rem 2.8rem 3.5rem;border-right:1px solid rgba(255,255,255,0.07);position:relative;overflow:hidden;transition:background 0.4s ease;background:transparent}
.op-card:last-child{border-right:none}
.op-card:hover{background:rgba(128,0,32,0.2)}
.op-card::before{content:'';position:absolute;bottom:0;left:0;width:0;height:2px;background:var(--gold);transition:width 0.6s var(--ease)}
.op-card:hover::before{width:100%}
.op-bg-n{position:absolute;top:1.5rem;right:2rem;font-family:'Cormorant Garamond',serif;font-size:9rem;font-weight:700;color:rgba(255,255,255,0.03);line-height:1;pointer-events:none}
.op-icon{width:54px;height:54px;border:1px solid rgba(201,168,76,0.3);display:flex;align-items:center;justify-content:center;color:var(--gold);font-size:1.25rem;margin-bottom:2.5rem;transition:var(--tr)}
.op-card:hover .op-icon{background:var(--gold);color:#fff;border-color:var(--gold)}
.op-card h3{color:#fff;font-size:1.7rem;margin-bottom:1rem}
.op-card p{color:rgba(255,255,255,0.80);font-size:0.88rem;line-height:1.85}
.op-list{margin-top:2.2rem;padding-top:2rem;border-top:1px solid rgba(255,255,255,0.06)}
.op-list li{font-family:'DM Mono',monospace;font-size:0.67rem;letter-spacing:0.08em;color:rgba(255,255,255,0.70);padding:0.5rem 0;border-bottom:1px solid rgba(255,255,255,0.08);display:flex;align-items:center;gap:0.7rem}
.op-list li::before{content:'';width:4px;height:4px;background:var(--gold);border-radius:50%;flex-shrink:0;opacity:0.6}
.ops-facts{display:grid;grid-template-columns:repeat(3,1fr);border-top:1px solid rgba(255,255,255,0.07);background:linear-gradient(to right,rgba(77,7,19,0.98),rgba(60,5,15,1))}
.ops-fact{padding:3rem;border-right:1px solid rgba(255,255,255,0.07);text-align:center;background:rgba(128,0,32,0.12);transition:background 0.3s ease}
.ops-fact:hover{background:rgba(128,0,32,0.22)}
.ops-fact:last-child{border-right:none}
.ops-fact strong{font-family:'Cormorant Garamond',serif;font-size:2.5rem;font-weight:600;color:var(--gold);display:block;line-height:1;margin-bottom:0.5rem}
.ops-fact span{font-family:'DM Mono',monospace;font-size:0.62rem;letter-spacing:0.16em;text-transform:uppercase;color:rgba(255,255,255,0.68)}

.editorial{position:relative;overflow:hidden;min-height:680px;display:flex;align-items:center}
.ed-photo{position:absolute;inset:0;background:center/cover no-repeat;transition:transform 10s ease}
.editorial:hover .ed-photo{transform:scale(1.03)}
.ed-veil{position:absolute;inset:0;background:linear-gradient(105deg,rgba(8,3,5,0.93) 0%,rgba(80,8,20,0.6) 50%,rgba(8,3,5,0.35) 100%)}
.ed-body{position:relative;z-index:2;max-width:1320px;margin:0 auto;padding:9rem 3rem;width:100%}
.ed-body h2{color:#fff;max-width:680px;margin:1.2rem 0 2rem;font-size:clamp(2.8rem,6.5vw,6.2rem)}
.ed-body h2 em{color:var(--gold-pale);font-style:italic}
.ed-body p{color:rgba(255,255,255,0.6);max-width:500px;font-size:1.05rem;margin-bottom:3rem}
.ed-stats{display:flex;gap:4.5rem;flex-wrap:wrap;margin-top:4.5rem}
.ed-stat{border-left:2px solid var(--gold);padding-left:1.6rem}
.ed-stat strong{font-family:'Cormorant Garamond',serif;font-size:2.8rem;font-weight:600;color:#fff;display:block;line-height:1;margin-bottom:0.35rem}
.ed-stat span{font-family:'DM Mono',monospace;font-size:0.64rem;letter-spacing:0.16em;text-transform:uppercase;color:rgba(255,255,255,0.4)}

.news{background:var(--cream)}
.news-hdr{display:flex;justify-content:space-between;align-items:flex-end;margin-bottom:4rem}
.news-grid{display:grid;grid-template-columns:1.7fr 1fr;gap:1px;background:rgba(0,0,0,0.08);align-items:stretch}
.news-card{background:var(--white);overflow:hidden;display:flex;flex-direction:column;transition:box-shadow 0.4s ease}
.news-card:hover{box-shadow:0 24px 64px rgba(0,0,0,0.14);z-index:1}
.news-thumb{position:relative;overflow:hidden}
.news-thumb img{width:100%;height:420px;object-fit:cover;object-position:center;display:block;transition:transform 0.8s var(--ease)}
.news-card:hover .news-thumb img{transform:scale(1.04)}
.news-card.featured .news-thumb{flex:1;min-height:300px}
.news-card.featured .news-thumb img{height:100%;width:100%;object-fit:cover;display:block;min-height:300px}
.news-tag{position:absolute;top:1.2rem;left:1.2rem;background:var(--maroon);color:#fff;font-family:'DM Mono',monospace;font-size:0.6rem;letter-spacing:0.14em;text-transform:uppercase;padding:0.3rem 0.75rem}
.news-body{padding:2.2rem 2.2rem 2.8rem;flex:1;display:flex;flex-direction:column;border-top:1px solid var(--border)}
.news-date{font-family:'DM Mono',monospace;font-size:0.63rem;letter-spacing:0.12em;text-transform:uppercase;color:var(--muted);margin-bottom:0.9rem;display:flex;align-items:center;gap:0.5rem}
.news-card h3{font-family:'Cormorant Garamond',serif;font-weight:600;font-size:1.45rem;line-height:1.28;color:#0d0608;margin-bottom:0.8rem}
.news-card.featured h3{font-size:1.8rem}
.news-card p{font-size:0.9rem;flex:1;color:#2e2a2b}
.news-more{display:inline-flex;align-items:center;gap:0.5rem;font-family:'DM Mono',monospace;font-size:0.63rem;letter-spacing:0.15em;text-transform:uppercase;color:var(--maroon);margin-top:1.8rem}
.news-more i{transition:transform 0.3s var(--ease)}
.news-more:hover i{transform:translateX(5px)}
.news-side{display:flex;flex-direction:column;gap:1px;background:rgba(0,0,0,0.08);align-self:stretch}
.news-side .news-card{flex:1}
.news-side .news-thumb img{height:160px}

.community{position:relative;overflow:hidden}
.comm-photo{position:absolute;inset:0;background:center/cover;filter:brightness(0.28) saturate(0.6)}
.comm-inner{position:relative;z-index:2;padding:11rem 0}
.comm-grid{display:grid;grid-template-columns:1fr 1fr;gap:8rem;align-items:center;max-width:1320px;margin:0 auto;padding:0 3rem}
.comm-text .mono{color:var(--gold)}
.comm-text h2{color:#fff;margin:1.2rem 0 1.8rem}
.comm-text p{color:rgba(255,255,255,0.82);margin-bottom:1.2rem}
.comm-quote{border-left:2px solid var(--gold);padding:1.5rem 0 1.5rem 2rem;margin:2.5rem 0 3rem}
.comm-quote p{font-family:'Cormorant Garamond',serif;font-style:italic;font-size:1.4rem;font-weight:300;color:rgba(255,255,255,0.7);line-height:1.55}
.comm-quote cite{font-family:'DM Mono',monospace;font-size:0.62rem;letter-spacing:0.14em;text-transform:uppercase;color:var(--gold);display:block;margin-top:0.8rem}
.impact-grid{display:grid;grid-template-columns:1fr 1fr;gap:2px;background:rgba(255,255,255,0.07)}
.impact-cell{background:rgba(255,255,255,0.05);padding:2.5rem 2rem;text-align:center}
.impact-n{font-family:'Cormorant Garamond',serif;font-size:3rem;font-weight:600;color:var(--gold);display:block;line-height:1;margin-bottom:0.5rem}
.impact-l{font-family:'DM Mono',monospace;font-size:0.6rem;letter-spacing:0.16em;text-transform:uppercase;color:rgba(255,255,255,0.35)}

.partners{background:var(--cream-2);padding:4rem 0;border-top:1px solid var(--border);border-bottom:1px solid var(--border)}
.partners p{font-family:'DM Mono',monospace;font-size:0.65rem;letter-spacing:0.18em;text-transform:uppercase;color:var(--muted);text-align:center;margin-bottom:2rem}
.partners-row{display:flex;align-items:center;justify-content:center;flex-wrap:wrap;gap:0;border-top:1px solid var(--border);border-bottom:1px solid var(--border)}
.partner-name{font-family:'Cormorant Garamond',serif;font-weight:600;font-size:1.1rem;color:#888;padding:0.8rem 2.2rem;border-right:1px solid var(--border);transition:color 0.3s ease;cursor:default;white-space:nowrap}
.partner-name:last-child{border-right:none}
.partner-name:hover{color:var(--maroon)}

.cta-strip{background:linear-gradient(to right, #ffffff 0%, #ffffff 38%, #f5eaec 48%, #800020 58%, #6b0a1a 100%);padding:12rem 0;text-align:center;position:relative;overflow:hidden}
.cta-bg-text{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);font-family:'Cormorant Garamond',serif;font-size:20rem;font-weight:700;color:rgba(255,255,255,0.025);white-space:nowrap;pointer-events:none;letter-spacing:-0.04em}
.cta-strip h2{color:var(--ink);margin-bottom:1.2rem}
.cta-strip p{color:rgba(20,5,8,0.7);max-width:540px;margin:0 auto 3rem;font-size:1.05rem}
.cta-btns{display:flex;gap:1rem;justify-content:center;flex-wrap:wrap}

.contact-info-list{display:flex;flex-direction:column;gap:1.2rem}
.ci-row{display:flex;align-items:flex-start;gap:1rem}
.ci-row i{color:var(--maroon);font-size:0.9rem;margin-top:3px;flex-shrink:0;width:20px}
.ci-row strong{display:block;font-size:0.85rem;color:#1c1a1b;margin-bottom:2px}
.ci-row p{font-size:0.88rem;color:var(--muted);line-height:1.6;margin:0}
.ci-row a{color:var(--maroon)}
.contact-form{background:#fff;padding:3rem;box-shadow:0 20px 60px rgba(0,0,0,0.08)}
.cf-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem}
.cf-group{display:flex;flex-direction:column;gap:0.45rem;margin-bottom:1.2rem}
.cf-group label{font-family:'DM Mono',monospace;font-size:0.65rem;letter-spacing:0.14em;text-transform:uppercase;color:var(--muted)}
.cf-group input,.cf-group textarea{padding:0.85rem 1rem;border:1px solid var(--border);background:#faf8f5;font-family:'DM Sans',sans-serif;font-size:0.95rem;color:#1c1a1b;outline:none;transition:border-color 0.3s;width:100%}
.cf-group input:focus,.cf-group textarea:focus{border-color:var(--maroon);background:#fff}
.cf-group textarea{resize:vertical}
.cf-success{display:none;margin-top:1rem;padding:0.85rem 1rem;background:rgba(26,107,60,0.08);border-left:3px solid #1a6b3c;font-size:0.88rem;color:#1a6b3c;font-weight:500}
.cf-error{display:none;margin-top:1rem;padding:0.85rem 1rem;background:rgba(128,0,32,0.08);border-left:3px solid var(--maroon);font-size:0.88rem;color:var(--maroon)}
.cf-success.show,.cf-error.show{display:block}

footer{background:var(--ink);padding-top:6.5rem}
.footer-grid{display:grid;grid-template-columns:2fr 1fr 1fr 1.6fr;gap:5.5rem;padding-bottom:5rem;border-bottom:1px solid rgba(255,255,255,0.06)}
.footer-gem{width:46px;height:46px;background:var(--gold);clip-path:polygon(50% 0%,100% 25%,100% 75%,50% 100%,0% 75%,0% 25%);margin-bottom:1.8rem}
.footer-about{font-size:0.88rem;color:rgba(255,255,255,0.62);line-height:1.9;max-width:320px;margin-bottom:2rem}
.footer-tagline{font-family:'Cormorant Garamond',serif;font-style:italic;font-size:1.4rem;color:rgba(201,168,76,0.5);margin-bottom:2rem}
.socials{display:flex;gap:0.75rem}
.soc{width:38px;height:38px;border:1px solid rgba(255,255,255,0.1);display:flex;align-items:center;justify-content:center;color:rgba(255,255,255,0.38);font-size:0.85rem;transition:var(--tr)}
.soc-x-img{width:16px;height:16px;object-fit:contain;opacity:0.55;filter:brightness(10);transition:opacity 0.25s}
.soc:hover .soc-x-img{opacity:1}
.soc:hover{background:var(--gold);border-color:var(--gold);color:#fff;transform:translateY(-2px)}
.footer-col h5{font-family:'DM Mono',monospace;font-size:0.62rem;letter-spacing:0.22em;text-transform:uppercase;color:rgba(255,255,255,0.55);margin-bottom:2rem}
.footer-col ul li{margin-bottom:0.9rem}
.footer-col ul a{font-size:0.88rem;color:rgba(255,255,255,0.65)}
.footer-col ul a:hover{color:var(--gold);padding-left:5px}
.contact-row{display:flex;gap:1rem;margin-bottom:1.3rem}
.contact-row i{color:var(--gold);font-size:0.82rem;flex-shrink:0;margin-top:3px}
.contact-row p{font-size:0.84rem;color:rgba(255,255,255,0.35);line-height:1.65}
.contact-row a{color:rgba(255,255,255,0.35)}
.contact-row a:hover{color:var(--gold)}

.reveal{opacity:0;transform:translateY(55px);transition:opacity 0.85s var(--ease),transform 0.85s var(--ease)}
.reveal.in{opacity:1;transform:translateY(0)}
.rev-l{opacity:1;transform:translateX(0);transition:opacity 0.85s var(--ease),transform 0.85s var(--ease)}
.rev-l.in{opacity:1;transform:translateX(0)}
.rev-r{opacity:1;transform:translateX(0);transition:opacity 0.85s var(--ease),transform 0.85s var(--ease)}
.rev-r.in{opacity:1;transform:translateX(0)}
.d1{transition-delay:.1s}.d2{transition-delay:.2s}.d3{transition-delay:.3s}.d4{transition-delay:.4s}.d5{transition-delay:.5s}

@keyframes riseUp{from{opacity:0;transform:translateY(42px)}to{opacity:1;transform:translateY(0)}}
@keyframes fadeUp{from{opacity:0;transform:translateY(22px)}to{opacity:1;transform:translateY(0)}}
@keyframes rodScroll{0%{top:-100%}60%{top:100%}100%{top:100%}}
@keyframes tickerScroll{from{transform:translateX(0)}to{transform:translateX(-50%)}}

.page-hero{position:relative;min-height:520px;display:flex;align-items:flex-end;overflow:hidden;background:#111;padding-top:90px}
.page-hero-bg{position:absolute;inset:0;background:center/cover no-repeat;opacity:1}
.page-hero-gradient{position:absolute;inset:0;background:linear-gradient(to right,rgba(255,255,255,0.97) 0%,rgba(255,255,255,0.92) 38%,rgba(255,255,255,0.3) 58%,rgba(128,0,32,0.88) 100%)}
.page-hero-veil{display:block;position:absolute;inset:0;background:rgba(8,3,5,0.45)}
.page-hero-body{position:relative;z-index:2;padding:8rem 0 5rem;display:grid;grid-template-columns:1fr 1fr;align-items:center;gap:4rem}
.page-hero-left{padding-right:2rem}
.page-hero-right{display:flex;flex-direction:column;align-items:flex-end;text-align:right}
.page-hero-right .ph-quote{font-family:'Cormorant Garamond',serif;font-style:italic;font-size:1.4rem;color:rgba(255,255,255,0.85);line-height:1.5;margin-bottom:2rem}
.page-hero-stats{display:flex;gap:3rem;justify-content:flex-end}
.ph-stat-n{display:block;font-family:'Cormorant Garamond',serif;font-size:2.8rem;font-weight:600;color:#fff;line-height:1}
.ph-stat-l{font-family:'DM Mono',monospace;font-size:0.58rem;letter-spacing:0.14em;text-transform:uppercase;color:rgba(255,255,255,0.55)}
.post-content{font-size:1.05rem;line-height:1.9;color:#252223;max-width:780px;text-align:left}
.post-content h3{font-family:'Cormorant Garamond',serif;font-size:1.9rem;font-weight:600;color:var(--ink);margin:2.5rem 0 1rem}
.post-content p{margin-bottom:1.5rem;color:#252223}
.post-content ul{padding-left:1.5rem;margin-bottom:1.5rem}
.post-content li{margin-bottom:0.5rem;line-height:1.75}
.post-content blockquote{border-left:3px solid var(--maroon);padding:1rem 1.5rem;margin:2rem 0;font-style:italic;color:#555;font-size:1.1rem}
.post-sidebar{position:sticky;top:7rem}
.post-sidebar h4{font-family:'DM Mono',monospace;font-size:0.65rem;letter-spacing:0.18em;text-transform:uppercase;color:var(--muted);margin-bottom:1.5rem;padding-bottom:0.75rem;border-bottom:1px solid var(--border)}
.sp-card{display:block;padding:1rem 0;border-bottom:1px solid var(--border);transition:padding-left 0.3s}
.sp-card:hover{padding-left:0.5rem}
.sp-cat{font-family:'DM Mono',monospace;font-size:0.6rem;letter-spacing:0.12em;text-transform:uppercase;color:var(--maroon);margin-bottom:0.3rem}
.sp-title{font-family:'Cormorant Garamond',serif;font-weight:600;font-size:1rem;color:var(--ink);line-height:1.4;margin-bottom:0.2rem}
.sp-date{font-family:'DM Mono',monospace;font-size:0.6rem;color:var(--muted)}

.job-filter-bar{display:flex;gap:0.5rem;flex-wrap:wrap;margin-bottom:2.5rem}
.jf-btn{font-family:'DM Mono',monospace;font-size:0.65rem;letter-spacing:0.12em;text-transform:uppercase;padding:0.55rem 1.2rem;border:1px solid var(--border);background:var(--white);color:var(--muted);cursor:pointer;transition:all 0.3s}
.jf-btn:hover,.jf-btn.active{border-color:var(--maroon);color:var(--maroon)}
.jf-btn.active{background:var(--maroon);color:#fff}
.job-card{display:grid;grid-template-columns:1fr auto;gap:2rem;align-items:center;background:var(--white);padding:2rem 2.5rem;border-bottom:1px solid var(--border);transition:background 0.3s;cursor:pointer;border-left:3px solid transparent}
.job-card:hover{background:var(--cream);border-left-color:var(--maroon)}
.jc-dept{font-family:'DM Mono',monospace;font-size:0.62rem;letter-spacing:0.14em;text-transform:uppercase;color:var(--maroon);margin-bottom:0.4rem}
.jc-title{font-family:'Cormorant Garamond',serif;font-size:1.5rem;font-weight:600;color:var(--ink);margin-bottom:0.5rem}
.jc-tags{display:flex;gap:0.5rem;flex-wrap:wrap}
.jc-tag{font-family:'DM Mono',monospace;font-size:0.6rem;letter-spacing:0.08em;text-transform:uppercase;color:var(--muted);background:rgba(0,0,0,0.04);padding:0.2rem 0.6rem;border:1px solid var(--border)}
.jc-deadline{font-family:'DM Mono',monospace;font-size:0.62rem;color:var(--muted);text-align:right;margin-bottom:0.5rem}

.modal-overlay{position:fixed;inset:0;background:rgba(5,2,3,0.78);backdrop-filter:blur(4px);z-index:2000;display:none;align-items:center;justify-content:center}
.modal-overlay.open{display:flex}
.modal-box{background:#fff;width:90%;max-width:700px;max-height:88vh;overflow-y:auto;position:relative;animation:modalIn 0.4s var(--ease)}
.modal-box.wide{max-width:880px}
@keyframes modalIn{from{opacity:0;transform:translateY(30px) scale(0.97)}to{opacity:1;transform:none}}
.modal-close{position:absolute;top:1.2rem;right:1.2rem;width:36px;height:36px;border-radius:50%;background:rgba(0,0,0,0.06);display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:0.9rem;transition:background 0.3s;border:none}
.modal-close:hover{background:var(--maroon);color:#fff}
.modal-inner{padding:3rem}
.modal-dept{font-family:'DM Mono',monospace;font-size:0.62rem;letter-spacing:0.14em;text-transform:uppercase;color:var(--maroon);margin-bottom:0.5rem}
.modal-title{font-family:'Cormorant Garamond',serif;font-size:2rem;font-weight:600;color:var(--ink);margin-bottom:1rem}
.modal-meta{display:flex;gap:1.5rem;flex-wrap:wrap;padding-bottom:1.5rem;border-bottom:1px solid var(--border);margin-bottom:2rem}
.mm-item{font-family:'DM Mono',monospace;font-size:0.62rem;text-transform:uppercase;letter-spacing:0.08em;color:var(--muted)}
.mm-item strong{color:var(--ink);display:block;margin-bottom:2px}
.modal-section{margin-bottom:1.8rem}
.modal-section h4{font-family:'DM Mono',monospace;font-size:0.65rem;letter-spacing:0.16em;text-transform:uppercase;color:var(--maroon);margin-bottom:0.75rem}
.modal-section p{font-size:0.95rem;color:#444;line-height:1.75}
.modal-section ul{padding-left:1.25rem}
.modal-section li{font-size:0.9rem;color:#444;margin-bottom:0.4rem;line-height:1.65}

@media(max-width:1100px){
  .wrap{padding:0 2rem}
  .about-grid,.comm-grid,.ops-head{grid-template-columns:1fr;gap:4rem}
  .about-img-thumb{right:0;bottom:-2.5rem;width:46%}
  .ops-cards{grid-template-columns:1fr 1fr}
  .op-card:nth-child(2){border-right:none}
  .op-card:nth-child(3){border-right:1px solid rgba(255,255,255,0.07)}
  .news-grid{grid-template-columns:1fr}
  .footer-grid{grid-template-columns:1fr 1fr;gap:3rem}
  .stats-grid{grid-template-columns:1fr 1fr}
  .stat:nth-child(2){border-right:none}
  .stat:nth-child(3){border-top:1px solid rgba(255,255,255,0.1)}
}
@media(max-width:768px){
  .nav-links{display:none}
  .ham{display:flex}
  .hero-scroll{display:none}
  .hero-band-inner{flex-wrap:wrap;height:auto;padding:0.8rem 1.5rem;gap:0.5rem}
  .cred:nth-child(3),.cred:nth-child(5){display:none}
  .hero-row{flex-direction:column;gap:2rem}
  .hero-btns{margin-left:0}
  .ops-cards{grid-template-columns:1fr}
  .op-card{border-right:none;border-bottom:1px solid rgba(255,255,255,0.07)}
  .ops-facts{grid-template-columns:1fr}
  .ops-fact{border-right:none;border-bottom:1px solid rgba(255,255,255,0.07)}
  .impact-grid{grid-template-columns:1fr}
  .footer-grid{grid-template-columns:1fr;gap:2.5rem}
  .footer-bottom{flex-direction:column;gap:0.8rem;text-align:center}
  .footer-links{gap:1.5rem}
  .cf-row{grid-template-columns:1fr}
}
@media(max-width:480px){
  .wrap{padding:0 1.25rem}
  .nav-inner{padding:0 1.25rem}
  .hero-body{padding:0 1.25rem 8rem}
  .stats-grid{grid-template-columns:1fr}
  .stat{border-right:none;border-bottom:1px solid rgba(255,255,255,0.1)}
  .feat-grid{grid-template-columns:1fr}
  .feat-cell{border-right:none}
  .feat-cell:nth-child(3){border-bottom:1px solid var(--border)}
}

.footer-logo-img{height:72px;width:auto;display:block;opacity:1;margin-bottom:1.5rem;background:#fff;padding:6px 12px;border-radius:5px}
.news-card.featured{display:flex;flex-direction:column}
.news-card.featured .news-body{flex:1;min-height:0}

.post-content p { text-align: justify; }
.news-excerpt   { text-align: justify; }

.partners-row   { display:flex;align-items:center;justify-content:center;flex-wrap:wrap;gap:0;border-top:1px solid var(--border);border-bottom:1px solid var(--border) }
.partner-item   { display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.55rem;padding:1.6rem 2rem;border-right:1px solid var(--border);min-width:140px;transition:background .2s;text-decoration:none;cursor:pointer }
.partner-item:last-child { border-right:none }
.partner-item:hover { background:var(--cream) }
.partner-logo   { height:52px;width:auto;max-width:120px;object-fit:contain;filter:grayscale(30%);transition:filter .3s }
.partner-item:hover .partner-logo { filter:grayscale(0%) }
.partner-label  { font-family:'DM Mono',monospace;font-size:.6rem;letter-spacing:.12em;text-transform:uppercase;color:var(--muted);text-align:center;line-height:1.3 }

.bg-white  { background:#fff }
.bg-maroon { background:var(--maroon);color:#fff }

.apply-wrap { max-width:800px;margin:0 auto;padding:4rem 2rem 6rem }
.apply-card { background:#fff;border:1px solid #e8ddd4;border-radius:8px;padding:2.5rem 3rem }
.af-group   { margin-bottom:1.4rem }
.af-group label { display:block;font-size:.82rem;font-weight:600;color:#1a0a0e;margin-bottom:.45rem }
.af-group input[type=text],
.af-group input[type=email],
.af-group input[type=tel],
.af-group select,
.af-group textarea { width:100%;padding:.65rem .9rem;border:1px solid #d5c5b0;border-radius:4px;font-family:'DM Sans',sans-serif;font-size:.88rem;color:#1a0a0e;background:#faf8f5;transition:border .2s }
.af-group input:focus,
.af-group select:focus,
.af-group textarea:focus { outline:none;border-color:#800020;background:#fff }
.af-required { color:#c0392b;margin-left:2px }
.af-note { font-size:.75rem;color:#888;margin-top:.3rem }
.af-upload-box { border:2px dashed #d5c5b0;border-radius:4px;padding:1.2rem;text-align:center;background:#faf8f5;cursor:pointer;transition:border .2s }
.af-upload-box:hover { border-color:#800020 }
.af-upload-box input[type=file] { display:none }
.af-upload-box label { cursor:pointer;font-size:.85rem;color:#555 }
.af-upload-box i { font-size:1.5rem;color:#c4913a;display:block;margin-bottom:.4rem }
.af-submit { width:100%;padding:.85rem;background:#800020;color:#fff;border:none;border-radius:4px;font-size:.9rem;font-weight:700;letter-spacing:.04em;cursor:pointer;transition:background .2s }
.af-submit:hover { background:#9a1228 }
.af-success { display:none;text-align:center;padding:3rem 2rem }
.af-success .ref-box { background:#f5f0eb;border:2px solid #c4913a;border-radius:8px;padding:1.5rem;margin:1.5rem 0;display:inline-block }
.af-success .ref-num { font-family:'DM Mono',monospace;font-size:1.6rem;font-weight:700;color:#800020;letter-spacing:.08em }
.af-counter { font-family:'DM Mono',monospace;font-size:.72rem;color:#888;letter-spacing:.06em;text-transform:uppercase;margin-top:.3rem }
@media(max-width:680px){ .apply-card{padding:1.5rem 1.2rem} }

h2{color:#0d0608}
h3{color:#0d0608}
h4{color:#1a1517}
.about-text>p{color:#2e2a2b;line-height:1.9}
.sec p{color:#2e2a2b}
.news-body p{color:#2e2a2b}
.about-lead{color:#1e1a1b!important}
/* Consistent section padding and wrap */
.sec .wrap>p,.about-text>p{max-width:720px}
/* Stats section labels */
.hero-band .stat-label,.hero-band .cred{color:rgba(255,255,255,0.75)}
/* Ops section improvements */
.op-title{color:#fff!important}
.op-body{color:rgba(255,255,255,0.75)!important}
/* Careers page text */
.jc-title{color:#0d0608}
.jc-meta span{color:#4a4547}
/* News page */
.news-list-card h3{color:#0d0608}
.news-list-card p{color:#2e2a2b}
/* Post page */
.post-header h1{color:#fff}
.post-content h3{color:#0d0608!important}
.post-content p{color:#252223!important}
.post-content li{color:#252223}
/* Contact info */
.ci-row p{color:#2e2a2b}
/* Consistent text block max width for readability */
.comm-text p{max-width:500px}
/* Ticker dots visibility */
.ticker-dot{background:var(--gold)!important}

.ops-sofax-word{
  position:absolute;
  top:50%;left:50%;
  transform:translate(-50%,-50%);
  display:flex;align-items:center;
  pointer-events:none;overflow:visible;
  z-index:1;
  white-space:nowrap;
}
.ops-sofax-left,.ops-sofax-right{
  font-family:'Cormorant Garamond',serif;
  font-size:22rem;font-weight:700;line-height:1;
  letter-spacing:-0.04em;user-select:none;
  display:block;
}
/* Maroon-coloured ghost on the white-left side */
.ops-sofax-left{
  color:rgba(128,0,32,0.06);
  /* clip to left half */
  clip-path:inset(0 50% 0 0);
  position:absolute;left:50%;transform:translateX(-50%);
}
/* White ghost on the maroon-right side */
.ops-sofax-right{
  color:rgba(255,255,255,0.05);
  /* clip to right half */
  clip-path:inset(0 0 0 50%);
  position:absolute;left:50%;transform:translateX(-50%);
}
/* On smaller screens reduce watermark size */
@media(max-width:900px){
  .ops-sofax-left,.ops-sofax-right{font-size:10rem}
}

.footer-bottom{display:flex;justify-content:space-between;align-items:center;padding:1.8rem 0;font-family:'DM Mono',monospace;font-size:0.6rem;letter-spacing:0.12em;text-transform:uppercase;color:rgba(255,255,255,0.45);border-top:1px solid rgba(255,255,255,0.06);margin-top:0}
.footer-bottom a{color:rgba(255,255,255,0.45);transition:color 0.2s}
.footer-bottom a:hover{color:var(--gold)}
.footer-links{display:flex;gap:2.5rem}

/* Philosophy grid (About — Vision/Mission/Strategy) */
.philosophy-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.2rem;margin-top:2rem}
.phil-card{background:#fff;border:1px solid rgba(128,0,32,0.12);border-top:3px solid var(--maroon);padding:1.4rem 1.2rem;border-radius:2px}
.phil-ico{font-size:1.2rem;color:var(--maroon);margin-bottom:0.6rem}
.phil-card h4{font-family:'DM Mono',monospace;font-size:0.65rem;letter-spacing:0.16em;text-transform:uppercase;color:#0d0608;margin-bottom:0.5rem}
.phil-card p{font-size:0.82rem;color:#666;line-height:1.65;margin:0}

/* Opportunities section */
.opps-grid{display:grid;grid-template-columns:1fr 1fr;gap:3rem}
.opp-card{background:#fff;border:1px solid rgba(0,0,0,0.08);border-top:4px solid var(--maroon);padding:3rem 2.5rem;box-shadow:0 4px 24px rgba(0,0,0,0.06)}
.opp-icon{width:56px;height:56px;background:var(--maroon);color:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:1.3rem;margin-bottom:1.5rem}
.opp-card h3{font-family:'Cormorant Garamond',serif;font-size:1.8rem;color:#0d0608;margin-bottom:1rem}
.opp-card p{color:#555;line-height:1.85;margin-bottom:1.5rem;font-size:0.95rem}
.opp-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:0.6rem}
.opp-list li{display:flex;align-items:center;gap:0.7rem;font-size:0.88rem;color:#444}
.opp-list li i{color:var(--maroon);font-size:0.85rem;flex-shrink:0}

/* Sustainability blocks */
.sust-block{background:rgba(255,255,255,0.08);border-left:3px solid var(--gold);padding:1.2rem 1.4rem;margin:1.5rem 0;border-radius:0 2px 2px 0}
.sust-block h4{font-size:0.88rem;font-weight:600;color:#fff;margin-bottom:0.5rem;display:flex;align-items:center;gap:0.5rem}
.sust-block p{font-size:0.85rem;color:rgba(255,255,255,0.7);line-height:1.7;margin:0}
.sust-block p em{color:rgba(255,255,255,0.45)}

/* Contact addresses */
.contact-addresses{display:flex;flex-direction:column;gap:0.3rem}
.ci-section-label{font-family:'DM Mono',monospace;font-size:0.6rem;letter-spacing:0.2em;text-transform:uppercase;color:var(--maroon);margin-top:1rem;margin-bottom:0.5rem}
.ci-office-card{background:#fff;border:1px solid rgba(128,0,32,0.12);padding:1rem 1.2rem;border-radius:2px;margin-bottom:0.5rem}
.ci-office-head{display:flex;align-items:center;gap:0.7rem;margin-bottom:0.4rem}
.ci-office-head i{color:var(--maroon);font-size:0.9rem;flex-shrink:0}
.ci-office-head strong{font-size:0.88rem;color:#0d0608}
.ci-office-card p{font-size:0.85rem;color:#555;line-height:1.65;margin:0;padding-left:1.6rem}

/* Social strip in news section */
.social-strip{margin-top:3rem;padding:2.5rem;background:var(--maroon);display:flex;align-items:center;flex-wrap:wrap;gap:2rem}
.social-strip .mono{color:rgba(255,255,255,0.6);display:block}
.social-strip p{color:rgba(255,255,255,0.85);font-size:0.92rem;margin:0;flex:1;min-width:200px}
.social-pill{display:inline-flex;align-items:center;gap:0.5rem;background:rgba(255,255,255,0.12);color:#fff;border:1px solid rgba(255,255,255,0.25);padding:0.5rem 1.2rem;font-size:0.82rem;font-family:'DM Mono',monospace;letter-spacing:0.08em;transition:background 0.2s;text-decoration:none}
.social-pill:hover{background:rgba(255,255,255,0.22)}

@media(max-width:900px){
  .philosophy-grid{grid-template-columns:1fr}
  .opps-grid{grid-template-columns:1fr}
  .opp-card{padding:2rem 1.5rem}
}

.sofax-way{margin-top:2.5rem;border:1px solid rgba(128,0,32,0.15);padding:2rem;background:#fff}
.sw-label{font-family:'DM Mono',monospace;font-size:0.65rem;letter-spacing:0.18em;text-transform:uppercase;color:var(--maroon);margin-bottom:1.4rem;display:flex;align-items:center;gap:0.5rem}
.sw-grid{display:flex;flex-direction:column;gap:0.8rem}
.sw-item{display:flex;align-items:flex-start;gap:1rem}
.sw-letter{font-family:'Cormorant Garamond',serif;font-size:2rem;font-weight:700;color:var(--maroon);line-height:1;flex-shrink:0;width:2rem;text-align:center}
.sw-item div{display:flex;flex-direction:column;padding-top:0.2rem}
.sw-item strong{font-size:0.88rem;color:#0d0608;font-weight:600}
.sw-item span{font-size:0.82rem;color:#666;line-height:1.5}

/* About — left side facts strip */
.about-facts-strip{display:flex;gap:0;margin-top:4rem;border:1px solid rgba(128,0,32,0.15);overflow:hidden}
.afs-item{flex:1;padding:1.2rem 1rem;text-align:center;border-right:1px solid rgba(128,0,32,0.1)}
.afs-item:last-child{border-right:none}
.afs-n{display:block;font-family:'Cormorant Garamond',serif;font-size:1.8rem;font-weight:700;color:var(--maroon);line-height:1}
.afs-l{font-family:'DM Mono',monospace;font-size:0.58rem;letter-spacing:0.14em;text-transform:uppercase;color:#888;margin-top:3px;display:block}

/* Dark news section */
.news-dark{background:#fff;padding:8rem 0}
.news-grid-dark{display:grid;grid-template-columns:1.6fr 1fr;gap:2px;background:rgba(255,255,255,0.08)}

/* Featured dark news card */
.ndc-featured{background:rgba(255,255,255,0.05);display:flex;flex-direction:column;overflow:hidden}
.ndc-photo{position:relative;height:320px;background:var(--maroon) center/cover no-repeat;flex-shrink:0}
.ndc-photo-fade{position:absolute;inset:0;background:linear-gradient(to top,rgba(5,2,3,0.5),transparent 60%)}
.ndc-body{padding:2.5rem;display:flex;flex-direction:column;flex:1;gap:0.8rem}
.ndc-body h3{font-family:'Cormorant Garamond',serif;font-size:1.7rem;font-weight:600;color:#fff;line-height:1.25}
.ndc-body p{font-size:0.9rem;color:rgba(255,255,255,0.65);line-height:1.75;flex:1}
.ndc-date{font-family:'DM Mono',monospace;font-size:0.62rem;letter-spacing:0.1em;text-transform:uppercase;color:rgba(255,255,255,0.4)}

/* Side dark cards */
.ndc-side{display:flex;flex-direction:column;gap:2px;background:rgba(255,255,255,0.08)}
.ndc-card{background:rgba(255,255,255,0.04);display:flex;flex-direction:column;overflow:hidden;flex:1}
.ndc-card-photo{height:140px;background:var(--maroon) center/cover no-repeat;position:relative;flex-shrink:0}
.ndc-card-body{padding:1.5rem;display:flex;flex-direction:column;gap:0.5rem;flex:1}
.ndc-card-body h4{font-family:'Cormorant Garamond',serif;font-size:1.1rem;font-weight:600;color:#fff;line-height:1.3;flex:1}
.ndc-more{font-family:'DM Mono',monospace;font-size:0.6rem;letter-spacing:0.12em;text-transform:uppercase;color:var(--gold);display:flex;align-items:center;gap:0.4rem;margin-top:0.5rem}
.ndc-more:hover{opacity:0.75}
.ndc-tag{position:absolute;top:1rem;left:1rem;z-index:2;background:var(--maroon);color:#fff;font-family:'DM Mono',monospace;font-size:0.58rem;letter-spacing:0.1em;text-transform:uppercase;padding:0.25rem 0.7rem}

/* Careers page responsive */
@media(max-width:900px){
  .page-hero-body{grid-template-columns:1fr}
  .page-hero-right{display:none}
  .about-facts-strip{flex-wrap:wrap}
  .news-grid-dark{grid-template-columns:1fr}
}

.news-page-hero{position:relative;min-height:420px;display:flex;align-items:center;overflow:hidden;background:var(--ink-2)}
.nph-bg{position:absolute;inset:0;background:center/cover no-repeat;opacity:0.55}
.nph-veil{position:absolute;inset:0;background:linear-gradient(to right,rgba(10,4,6,0.85) 0%,rgba(10,4,6,0.5) 55%,rgba(10,4,6,0.15) 100%),linear-gradient(to top,rgba(10,4,6,0.7) 0%,transparent 50%)}
.nph-body{position:relative;z-index:2;padding:8rem 0 5rem}
.nph-left{max-width:600px}
.nph-left h1{font-family:'Cormorant Garamond',serif;font-size:clamp(3rem,7vw,5.5rem);font-weight:300;color:#fff;line-height:0.95;margin-bottom:1.2rem}
.nph-left h1 em{font-style:italic;color:var(--gold-pale)}
.nph-left p{color:rgba(255,255,255,0.6);font-size:0.95rem;line-height:1.8;max-width:460px}

.news-grid-dark{display:grid;grid-template-columns:1.6fr 1fr;gap:2px;background:rgba(0,0,0,0.07)}
.ndc-featured{background:#fff;display:flex;flex-direction:column;overflow:hidden;border:1px solid rgba(0,0,0,0.07)}
.ndc-side{display:flex;flex-direction:column;gap:2px}
.ndc-card{background:#fff;border:1px solid rgba(0,0,0,0.07);display:flex;flex-direction:column;overflow:hidden;flex:1}
.ndc-photo{position:relative;height:380px;background:var(--maroon) center/cover no-repeat;flex-shrink:0}
.ndc-photo-fade{position:absolute;inset:0;background:linear-gradient(to top,rgba(5,2,3,0.35),transparent 60%)}
.ndc-card-photo{height:160px;background:var(--maroon) center/cover no-repeat;position:relative;flex-shrink:0}
.ndc-body{padding:2rem 2.2rem;display:flex;flex-direction:column;flex:1;gap:0.7rem;background:#fff}
.ndc-card-body{padding:1.2rem 1.4rem;display:flex;flex-direction:column;gap:0.4rem;flex:1;background:#fff}
.ndc-body h3{font-family:'Cormorant Garamond',serif;font-size:1.6rem;font-weight:600;color:#0d0608;line-height:1.25;flex:1}
.ndc-card-body h4{font-family:'Cormorant Garamond',serif;font-size:1.05rem;font-weight:600;color:#0d0608;line-height:1.3;flex:1}
.ndc-body p{font-size:0.9rem;color:#666;line-height:1.75}
.ndc-date{font-family:'DM Mono',monospace;font-size:0.62rem;letter-spacing:0.1em;text-transform:uppercase;color:#bbb}
.ndc-more{font-family:'DM Mono',monospace;font-size:0.6rem;letter-spacing:0.12em;text-transform:uppercase;color:var(--maroon);display:flex;align-items:center;gap:0.4rem;margin-top:0.5rem}
.ndc-more:hover{opacity:0.7}
.ndc-tag{position:absolute;top:1rem;left:1rem;z-index:2;background:var(--maroon);color:#fff;font-family:'DM Mono',monospace;font-size:0.58rem;letter-spacing:0.1em;text-transform:uppercase;padding:0.25rem 0.7rem}

@media(max-width:768px){
  .news-grid-dark{grid-template-columns:1fr}
  .nph-body{padding:7rem 0 4rem}
}

.careers-hero{
  position:relative;
  min-height:100vh;
  display:flex;
  align-items:center;
  overflow:hidden;
}
/* Full-bleed background photo */
.ch-photo{
  position:absolute;
  inset:0;
  background:center/cover no-repeat;
  z-index:0;
}
/* Gradient overlay on top of photo: white-left fading to burgundy-right */
.ch-overlay{
  position:absolute;
  inset:0;
  z-index:1;
  background:
    linear-gradient(to right,
      rgba(255,255,255,0.97) 0%,
      rgba(255,255,255,0.88) 30%,
      rgba(255,255,255,0.30) 52%,
      rgba(128,0,32,0.72) 68%,
      rgba(128,0,32,0.92) 100%
    );
}
/* SOFAX watermark — sits on the right half */
.ch-watermark{
  position:absolute;
  right:-0.04em;
  top:50%;
  transform:translateY(-50%);
  z-index:2;
  font-family:'Cormorant Garamond',serif;
  font-size:clamp(8rem,20vw,18rem);
  font-weight:700;
  color:rgba(255,255,255,0.07);
  letter-spacing:-0.03em;
  line-height:1;
  pointer-events:none;
  user-select:none;
  white-space:nowrap;
}
/* Content grid */
.ch-body{
  position:relative;
  z-index:3;
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:6rem;
  align-items:center;
  padding:10rem 0 6rem;
}
/* Left text */
.ch-left-inner{max-width:480px}
.ch-h1{
  font-family:'Cormorant Garamond',serif;
  font-size:clamp(3.2rem,5.5vw,5rem);
  font-weight:300;
  color:#0d0608;
  line-height:0.95;
  margin:0.8rem 0 1.5rem;
}
.ch-h1 em{font-style:italic;color:var(--maroon);display:block}
.ch-desc{color:#444;font-size:0.95rem;line-height:1.85;max-width:400px;margin-bottom:2.5rem}
.ch-btns{display:flex;gap:1rem;flex-wrap:wrap}
/* Right text */
.ch-right-inner{text-align:right}
.ch-quote{
  font-family:'Cormorant Garamond',serif;
  font-style:italic;
  font-size:clamp(1.15rem,1.8vw,1.5rem);
  color:rgba(255,255,255,0.88);
  line-height:1.6;
  margin-bottom:3rem;
}
.ch-stats{display:flex;gap:2.5rem;justify-content:flex-end}
.ch-stat-n{
  display:block;
  font-family:'Cormorant Garamond',serif;
  font-size:clamp(2rem,4vw,3rem);
  font-weight:600;
  color:#fff;
  line-height:1;
}
.ch-stat-l{
  font-family:'DM Mono',monospace;
  font-size:0.58rem;
  letter-spacing:0.16em;
  text-transform:uppercase;
  color:rgba(255,255,255,0.45);
  display:block;
  margin-top:4px;
}

@media(max-width:900px){
  .ch-body{grid-template-columns:1fr;gap:3rem;padding:8rem 0 5rem}
  .ch-right-inner{text-align:left}
  .ch-stats{justify-content:flex-start}
  .ch-watermark{display:none}
}

.nav.nav-solid,
.nav.nav-solid.scrolled {
  background: rgba(10,5,7,0.97) !important;
  backdrop-filter: blur(24px);
  -webkit-backdrop-filter: blur(24px);
  padding: 1.1rem 0 !important;
  box-shadow: 0 1px 0 rgba(255,255,255,0.06);
}
.nav.nav-solid .logo-text { color: #fff !important; }
.nav.nav-solid .logo-sub  { color: rgba(255,255,255,0.55) !important; }
.nav.nav-solid .nav-links a { color: rgba(255,255,255,0.72) !important; }
.nav.nav-solid .nav-links a:hover,
.nav.nav-solid .nav-links a.active { color: #fff !important; }
.nav.nav-solid .ham span { background: #fff !important; }

.about p, .ops p, .community p,
.sec p, .opp-card p, .phil-card p,
.sust-block p, .comm-text p,
.post-content p, .news-body p,
.ndc-body p, .footer-col p,
.hero-desc {
  text-indent: 1.5em;
}
/* Don't indent first paragraph or elements that shouldn't be */
.about-lead,
.mono + p,
h2 + p, h3 + p,
.cf-group p,
.footer-about,
.ops-head p.sub {
  text-indent: 0;
}
/* Post content (Quill-rendered) */
.ql-editor p, .post-content p { text-indent: 1.5em; }

/* Global paragraph indentation */
p { text-indent: 1.5em; }

/* Elements that must NOT indent */
.mono, .mono + p,
nav p, .ticker p,
h1 + p, h2 + p, h3 + p, h4 + p,
.hero-kicker, .hero-desc,
.about-lead,
.stat-l, .stat-n,
.feat-desc, .feat-name,
.cf-group p, .cf-success, .cf-error,
.footer-about, .footer-tagline,
.social-strip p, .social-pill,
.opp-list li, .op-list li,
.sw-item span, .phil-card p:first-child,
.ndc-date, .news-date, .ops-head p,
.afs-l, .ch-stat-l, .ch-desc,
.at-role, .ac-sub, .ef-note,
.adm-alert, .empty-row,
.ci-office-card p,
.partner-label, .footer-col li,
.editor-card p, .lr-inner > p,
.comm-quote p,
.impact-l, .sust-block p:first-of-type,
.lf-flagged-block p,
input, textarea, select, button, label,
.ql-editor p:first-child { text-indent: 0; }

/* Post / news body paragraphs always indent */
.post-content p,
.ql-editor p { text-indent: 1.5em; }
.post-content p:first-of-type,
.ql-editor p:first-of-type { text-indent: 0; }
/* ── MOBILE OVERFLOW & LAYOUT FIXES ─────────── */
html, body {
  overflow-x: hidden;
  max-width: 100%;
}

@media (max-width: 768px) {
  /* Fix all grids collapsing to single column */
  .about-grid,
  .ops-head,
  .opps-grid,
  .news-grid-dark,
  .settings-grid,
  .footer-grid,
  .cf-row,
  .phil-card,
  .philosophy-grid {
    grid-template-columns: 1fr !important;
    gap: 2rem !important;
  }

  /* Contact section two-col grid */
  #contact > .wrap > div[style*="grid-template-columns"] {
    display: flex !important;
    flex-direction: column !important;
    gap: 3rem !important;
  }

  /* Hero fixes */
  .hero-body { padding: 7rem 1.5rem 2rem; }
  .hero-h1 { font-size: clamp(3.5rem, 14vw, 6rem); }
  .hero-row { flex-direction: column; gap: 1.5rem; }
  .hero-btns { flex-direction: column; }
  .hero-band-inner { flex-direction: column; gap: 0.75rem; padding: 1rem 1.5rem; }
  .cred-divider { display: none; }

  /* Nav */
  .nav-inner { padding: 0 1.25rem; }
  .logo { margin-right: 0; }
  .logo-text { font-size: 1.3rem; }

  /* Stats */
  .stats-grid { grid-template-columns: 1fr 1fr !important; }

  /* Operations cards */
  .ops-cards { flex-direction: column; padding: 0 1.5rem; gap: 1.5rem; }
  .op-card { width: 100%; }

  /* News dark grid */
  .ndc-featured, .ndc-side { width: 100%; }
  .ndc-side { flex-direction: column; }

  /* Careers hero */
  .ch-body { grid-template-columns: 1fr !important; gap: 0 !important; padding: 8rem 1.5rem 4rem; }
  .ch-right-inner { text-align: left; }
  .ch-stats { justify-content: flex-start; gap: 2rem; }
  .ch-watermark { display: none; }

  /* Partners */
  .partners-row { flex-wrap: wrap; gap: 1.5rem; justify-content: center; }

  /* Wrap padding */
  .wrap { padding: 0 1.25rem; }

  /* Section padding */
  .sec { padding: 5rem 0 !important; }

  /* Sofax Way */
  .sw-grid { gap: 1rem; }

  /* About facts strip */
  .about-facts-strip { flex-wrap: wrap; }
  .afs-item { flex: 1 1 30%; }

  /* Footer */
  .footer-grid { grid-template-columns: 1fr !important; gap: 2.5rem !important; }
  .footer-bottom { flex-direction: column; gap: 0.75rem; text-align: center; }
  .footer-links { justify-content: center; }

  /* Community/Sustainability */
  .comm-grid { grid-template-columns: 1fr !important; }
  .impact-grid { grid-template-columns: 1fr 1fr !important; }

  /* Fix any element wider than screen */
  * { max-width: 100%; box-sizing: border-box; }
  img { max-width: 100%; height: auto; }

  /* Ticker */
  .ticker { overflow: hidden; }

  /* Social strip */
  .social-strip { flex-direction: column; align-items: flex-start; }
}

/* Contact section responsive grid */
.contact-grid {
  display: grid;
  grid-template-columns: 1fr 1.4fr;
  gap: 6rem;
  align-items: start;
}
@media (max-width: 768px) {
  .contact-grid {
    grid-template-columns: 1fr !important;
    gap: 3rem !important;
  }
}

/* Mobile nav and logo fixes */
@media (max-width: 768px) {
  .logo-img {
    height: 44px !important;
    width: 44px !important;
  }
  .logo-text {
    font-size: 1.15rem !important;
  }
  .logo-sub {
    font-size: 0.5rem !important;
  }
  .nav {
    padding: 0.75rem 0 !important;
  }
  .nav.scrolled {
    padding: 0.6rem 0 !important;
  }
  .hero-body {
    padding-top: 9rem !important;
  }
  .hero-kicker {
    font-size: 0.6rem !important;
  }
}

/* ═══════════════════════════════════════════════════════════════
   COMPREHENSIVE MOBILE OVERHAUL — Phone-first responsive fixes
   ═══════════════════════════════════════════════════════════════ */

/* ── SMALL PHONES (up to 480px) ─────────────────────────────── */
@media (max-width: 480px) {

  /* ── General spacing ── */
  .wrap { padding: 0 1rem; }
  .nav-inner { padding: 0 1rem; }
  .sec { padding: 4rem 0 !important; }

  /* ── Nav / Logo ── */
  .logo-img { height: 38px !important; width: auto !important; padding: 3px 6px !important; }
  .logo-text { font-size: 1.05rem !important; }
  .logo-sub { display: none; }
  .nav { padding: 0.6rem 0 !important; }

  /* ── Hero ── */
  .hero-body { padding: 8rem 1rem 3rem !important; }
  .hero-h1 { font-size: clamp(3rem, 16vw, 4.5rem) !important; margin-bottom: 1.5rem; }
  .hero-kicker { font-size: 0.55rem !important; letter-spacing: 0.22em; margin-bottom: 1.4rem; }
  .hero-desc { font-size: 0.9rem; }
  .hero-btns { flex-direction: column; width: 100%; }
  .hero-btns .btn { width: 100%; justify-content: center; }
  .hero-band { display: none; } /* too cramped — hide on tiny screens */

  /* ── Stats ── */
  .stats-grid { grid-template-columns: 1fr 1fr !important; }
  .stat { padding: 2rem 1.2rem; }
  .stat-bg-num { font-size: 4rem; }

  /* ── About ── */
  .about-grid { grid-template-columns: 1fr !important; gap: 2rem !important; }
  .about-img-main { height: 260px !important; }
  .about-img-thumb { display: none; }  /* overlapping on small screen */
  .about-badge { width: 80px; height: 80px; top: 1.5rem; right: 0.5rem; }
  .about-badge strong { font-size: 1.4rem; }
  .about-facts-strip { flex-wrap: wrap; }
  .afs-item { flex: 1 1 33%; padding: 0.8rem 0.5rem; }
  .afs-n { font-size: 1.3rem; }

  /* ── Philosophy/Vision/Mission cards ── */
  .philosophy-grid { grid-template-columns: 1fr !important; gap: 0.8rem !important; }

  /* ── Operations ── */
  .ops { padding: 4rem 0 0 !important; }
  .ops-head { grid-template-columns: 1fr !important; gap: 2rem !important; margin-bottom: 3rem; }
  .ops-cards { display: flex !important; flex-direction: column; padding: 0; }
  .op-card { padding: 2.5rem 1.5rem; border-right: none !important; border-bottom: 1px solid rgba(255,255,255,0.07); }
  .ops-facts { grid-template-columns: 1fr !important; }
  .ops-fact { border-right: none; border-bottom: 1px solid rgba(255,255,255,0.07); padding: 1.8rem 1.5rem; }

  /* ── Opportunities ── */
  .opps-grid { grid-template-columns: 1fr !important; gap: 1.5rem !important; }
  .opp-card { padding: 2rem 1.5rem; }

  /* ── Editorial (EPC signing strip) ── */
  .ed-body { padding: 5rem 1rem 4rem !important; }
  .ed-body h2 { font-size: clamp(2rem, 9vw, 3rem) !important; }
  .ed-stats { gap: 1.8rem; flex-wrap: wrap; margin-top: 2.5rem; }
  .ed-stat strong { font-size: 1.8rem; }

  /* ── NEWS SECTION (the main problem area) ── */
  .news-hdr { flex-direction: column; align-items: flex-start; gap: 1.2rem; margin-bottom: 2rem; }
  .news-hdr .btn { width: 100%; justify-content: center; }

  /* Stack news grid to single column */
  .news-grid-dark {
    display: flex !important;
    flex-direction: column !important;
    gap: 0 !important;
    background: transparent !important;
  }

  /* Featured article — full width, not squeezed */
  .ndc-featured {
    width: 100% !important;
    border-radius: 0;
    margin-bottom: 2px;
  }
  .ndc-photo { height: 220px !important; }
  .ndc-body { padding: 1.5rem !important; gap: 0.6rem !important; }
  .ndc-body h3 { font-size: 1.35rem !important; line-height: 1.3; }
  .ndc-body p { font-size: 0.88rem !important; }
  .ndc-body .btn { width: 100%; justify-content: center; margin-top: 0.5rem; }

  /* Side news cards — stack vertically, full width */
  .ndc-side {
    display: flex !important;
    flex-direction: column !important;
    width: 100% !important;
    gap: 2px !important;
  }
  .ndc-card {
    width: 100% !important;
    flex-direction: row !important;  /* horizontal layout: image left, text right */
    min-height: 110px;
    align-items: stretch;
  }
  .ndc-card-photo {
    width: 120px !important;
    min-width: 120px !important;
    height: auto !important;
    flex-shrink: 0;
    position: relative;
  }
  .ndc-card-body {
    padding: 1rem !important;
    justify-content: center;
    gap: 0.3rem !important;
  }
  .ndc-card-body h4 { font-size: 0.92rem !important; line-height: 1.3; }
  .ndc-tag { font-size: 0.52rem !important; padding: 0.2rem 0.5rem !important; }

  /* ── Social strip ── */
  .social-strip { padding: 1.5rem 1rem; gap: 1rem; }
  .social-strip p { font-size: 0.85rem; min-width: unset; }

  /* ── Sustainability / Community ── */
  .comm-inner { padding: 5rem 0; }
  .comm-grid { grid-template-columns: 1fr !important; gap: 3rem !important; }
  .comm-quote p { font-size: 1.1rem; }
  .impact-grid { grid-template-columns: 1fr 1fr !important; }
  .impact-n { font-size: 2.2rem; }

  /* ── Partners ── */
  .partners { padding: 3rem 0; }
  .partners-row { gap: 0; flex-wrap: wrap; }
  .partner-item {
    min-width: calc(50% - 1px);
    padding: 1.2rem 1rem;
    border-right: 1px solid var(--border);
    border-bottom: 1px solid var(--border);
  }
  .partner-item:nth-child(even) { border-right: none; }
  .partner-logo { height: 40px; max-width: 90px; }

  /* ── Contact form ── */
  .contact-grid { grid-template-columns: 1fr !important; gap: 2.5rem !important; }
  .contact-form { padding: 1.8rem 1.2rem; }
  .cf-row { grid-template-columns: 1fr !important; }

  /* ── Footer ── */
  .footer-grid { grid-template-columns: 1fr !important; gap: 2rem !important; }
  .footer-bottom { flex-direction: column; gap: 0.75rem; text-align: center; }
  .footer-links { justify-content: center; gap: 1.5rem; }
  footer { padding-top: 4rem; }

  /* ── Buttons ── */
  .btn { font-size: 0.72rem; padding: 0.9rem 1.8rem; }

  /* ── Sofax Way ── */
  .sofax-way { padding: 1.5rem 1rem; }

  /* ── Feature grid (about section) ── */
  .feat-grid { grid-template-columns: 1fr !important; }
  .feat-cell { border-right: none !important; border-bottom: 1px solid var(--border) !important; }
  .feat-cell:last-child { border-bottom: none !important; }

  /* ── News page hero ── */
  .nph-body { padding: 6rem 0 3rem; }
  .nph-left h1 { font-size: clamp(2.5rem, 12vw, 4rem); }

  /* ── Post page ── */
  .post-content { font-size: 0.95rem; }

  /* ── Careers page ── */
  .ch-body { padding: 7rem 1rem 3rem !important; gap: 0 !important; }
  .ch-right-inner { display: none; }
  .ch-h1 { font-size: clamp(2.6rem, 10vw, 3.5rem) !important; }
}

/* ── MEDIUM PHONES (481px – 768px) ──────────────────────────── */
@media (min-width: 481px) and (max-width: 768px) {

  .wrap { padding: 0 1.5rem; }
  .sec { padding: 5rem 0 !important; }

  /* ── News grid — the key fix ── */
  .news-grid-dark {
    display: flex !important;
    flex-direction: column !important;
    gap: 2px !important;
  }
  .ndc-featured { width: 100% !important; }
  .ndc-photo { height: 240px !important; }
  .ndc-body { padding: 1.8rem !important; }
  .ndc-body h3 { font-size: 1.5rem !important; }

  /* Side cards: horizontal card layout */
  .ndc-side {
    display: flex !important;
    flex-direction: column !important;
    width: 100% !important;
    gap: 2px !important;
  }
  .ndc-card {
    flex-direction: row !important;
    min-height: 120px;
    align-items: stretch;
  }
  .ndc-card-photo {
    width: 140px !important;
    min-width: 140px !important;
    height: auto !important;
  }
  .ndc-card-body { padding: 1.2rem !important; }
  .ndc-card-body h4 { font-size: 1rem !important; }

  /* ── Stats ── */
  .stats-grid { grid-template-columns: 1fr 1fr !important; }
  .stat { padding: 2.5rem 2rem; }

  /* ── About ── */
  .about-img-main { height: 340px !important; }
  .about-img-thumb { display: none; }
  .philosophy-grid { grid-template-columns: 1fr !important; }

  /* ── Operations ── */
  .ops-head { grid-template-columns: 1fr !important; gap: 2rem !important; }
  .ops-cards { display: flex !important; flex-direction: column; }
  .op-card { border-right: none !important; border-bottom: 1px solid rgba(255,255,255,0.07); }
  .ops-facts { grid-template-columns: 1fr 1fr !important; }

  /* ── Hero ── */
  .hero-btns { flex-direction: column; }
  .hero-btns .btn { width: 100%; justify-content: center; }

  /* ── Opportunities ── */
  .opps-grid { grid-template-columns: 1fr !important; }

  /* ── Contact ── */
  .contact-grid { grid-template-columns: 1fr !important; gap: 3rem !important; }
  .cf-row { grid-template-columns: 1fr !important; }

  /* ── Partners ── */
  .partner-item { min-width: calc(33% - 1px); }

  /* ── Impact grid ── */
  .impact-grid { grid-template-columns: 1fr 1fr !important; }

  /* ── Footer ── */
  .footer-grid { grid-template-columns: 1fr 1fr !important; gap: 2.5rem !important; }
}

/* ── Ticker — prevent overflow on all phones ─────────────────── */
@media (max-width: 768px) {
  .ticker-track { animation-duration: 20s; }
  .ticker-item { font-size: 0.62rem; padding-right: 2.5rem; }
}

/* ── Mob menu — ensure full-screen overlay works ─────────────── */
@media (max-width: 768px) {
  .mob-menu { padding: 2rem; }
  .mob-menu a { font-size: 2rem; }
}

/* ═══════════════════════════════════════════════════════
   NEWS PAGE — 3-col grid with proper mobile override
   ═══════════════════════════════════════════════════════ */

.news-list-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 1px;
  background: rgba(0,0,0,0.08);
}

/* 2 columns on tablets */
@media (max-width: 900px) {
  .news-list-grid {
    grid-template-columns: repeat(2, 1fr);
  }
}

/* 1 column on phones — full width cards, nothing squeezed */
@media (max-width: 600px) {
  .news-list-grid {
    grid-template-columns: 1fr !important;
    gap: 2px;
    background: transparent;
  }

  .news-list-grid .news-card {
    border-bottom: 1px solid rgba(0,0,0,0.08);
  }

  /* Horizontal card layout on mobile: image left, text right */
  .news-list-grid .news-card {
    display: flex !important;
    flex-direction: row !important;
    align-items: stretch;
    min-height: 130px;
    background: #fff;
  }

  .news-list-grid .news-thumb {
    width: 130px !important;
    min-width: 130px !important;
    height: auto !important;
    flex-shrink: 0;
    overflow: hidden;
    position: relative;
  }

  .news-list-grid .news-thumb img {
    width: 100% !important;
    height: 100% !important;
    object-fit: cover;
  }

  .news-list-grid .news-body {
    padding: 1rem 1.1rem !important;
    border-top: none !important;
    border-left: 1px solid rgba(0,0,0,0.06);
    justify-content: center;
    gap: 0.3rem;
    flex: 1;
    min-width: 0; /* prevent overflow */
  }

  .news-list-grid .news-body h3 {
    font-size: 1rem !important;
    line-height: 1.3;
    white-space: normal;
    overflow: hidden;
    display: -webkit-box;
    -webkit-line-clamp: 3;
    -webkit-box-orient: vertical;
  }

  /* Hide excerpt on mobile — title + date + link is enough */
  .news-list-grid .news-body > p {
    display: none !important;
  }

  .news-list-grid .news-date {
    font-size: 0.58rem !important;
    margin-bottom: 0.3rem;
  }

  .news-list-grid .news-tag {
    font-size: 0.5rem !important;
    padding: 0.15rem 0.5rem !important;
    top: 0.5rem !important;
    left: 0.5rem !important;
  }

  .news-list-grid .news-more {
    font-size: 0.58rem !important;
    margin-top: 0.5rem;
  }
}

/* ═══════════════════════════════════════════════════════
   NAV LOGO — fix oversized logo box on mobile
   ═══════════════════════════════════════════════════════ */
@media (max-width: 768px) {
  .logo-img {
    height: 46px !important;
    width: auto !important;
    padding: 4px 8px !important;
  }
  .logo {
    gap: 0.6rem;
    margin-right: 0;
  }
  .logo-text {
    font-size: 1.2rem !important;
    line-height: 1.1;
  }
  .logo-sub {
    font-size: 0.48rem !important;
    letter-spacing: 0.22em;
  }
  .nav {
    padding: 0.5rem 0 !important;
  }
  .nav.scrolled {
    padding: 0.5rem 0 !important;
  }
  .nav.nav-solid {
    padding: 0.5rem 0 !important;
  }
}

/* ═══════════════════════════════════════════════════════
   POST PAGE HERO — clean, properly padded, full-width
   ═══════════════════════════════════════════════════════ */
.post-hero {
  position: relative;
  height: 65vh;
  min-height: 420px;
  display: flex;
  align-items: flex-end;
  overflow: hidden;
}
.post-hero-bg {
  position: absolute;
  inset: 0;
  background: center/cover no-repeat;
}
.post-hero-veil {
  position: absolute;
  inset: 0;
  background: linear-gradient(
    to top,
    rgba(8,3,5,0.88) 0%,
    rgba(8,3,5,0.55) 40%,
    rgba(8,3,5,0.25) 100%
  );
}
.post-hero-body {
  position: relative;
  z-index: 2;
  padding-bottom: 3.5rem;
  padding-top: 2rem;
}
.post-hero-title {
  color: #fff !important;
  font-size: clamp(2rem, 4vw, 3.8rem) !important;
  max-width: 860px;
  line-height: 1.1;
  margin-top: 0.5rem;
  font-weight: 400;
}
.post-hero-date {
  color: rgba(255,255,255,0.55) !important;
  font-family: 'DM Mono', monospace;
  font-size: 0.7rem !important;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  margin-top: 1rem;
  text-indent: 0 !important;
}

/* ── Post content layout ── */
.post-layout {
  display: grid;
  grid-template-columns: 1fr 300px;
  gap: 6rem;
  align-items: start;
}
@media (max-width: 900px) {
  .post-layout {
    grid-template-columns: 1fr;
    gap: 3rem;
  }
  .post-sidebar {
    position: static;
  }
}
@media (max-width: 600px) {
  .post-hero { height: 55vh; min-height: 320px; }
  .post-hero-title { font-size: clamp(1.6rem, 7vw, 2.4rem) !important; }
  .post-hero-body { padding-bottom: 2rem; }
}

/* ═══════════════════════════════════════════════════════
   NEWS LIST GRID — 3 col desktop, 2 col tablet, 1 col phone
   (overrides the earlier conflicting rules with high specificity)
   ═══════════════════════════════════════════════════════ */
.news-list-grid {
  display: grid !important;
  grid-template-columns: repeat(3, 1fr) !important;
  gap: 1px !important;
  background: rgba(0,0,0,0.08) !important;
}

/* Tablet: 2 columns */
@media (max-width: 1024px) {
  .news-list-grid {
    grid-template-columns: repeat(2, 1fr) !important;
  }
}

/* Phone: 1 column, horizontal card layout */
@media (max-width: 600px) {
  .news-list-grid {
    grid-template-columns: 1fr !important;
    gap: 2px !important;
    background: transparent !important;
  }
  .news-list-grid .news-card {
    display: flex !important;
    flex-direction: row !important;
    align-items: stretch;
    background: #fff;
    border-bottom: 1px solid rgba(0,0,0,0.07);
    min-height: 120px;
  }
  .news-list-grid .news-thumb {
    width: 120px !important;
    min-width: 120px !important;
    height: auto !important;
    flex-shrink: 0;
  }
  .news-list-grid .news-thumb img {
    width: 100% !important;
    height: 100% !important;
    object-fit: cover;
  }
  .news-list-grid .news-body {
    padding: 0.9rem 1rem !important;
    border-top: none !important;
    border-left: 1px solid rgba(0,0,0,0.06);
    flex: 1;
    min-width: 0;
    justify-content: center;
  }
  .news-list-grid .news-body h3 {
    font-size: 0.95rem !important;
    line-height: 1.3;
    display: -webkit-box;
    -webkit-line-clamp: 3;
    -webkit-box-orient: vertical;
    overflow: hidden;
  }
  .news-list-grid .news-body > p { display: none !important; }
  .news-list-grid .news-date { font-size: 0.57rem !important; margin-bottom: 0.25rem; }
  .news-list-grid .news-tag { font-size: 0.5rem !important; padding: 0.15rem 0.45rem !important; }
  .news-list-grid .news-more { font-size: 0.57rem !important; margin-top: 0.4rem; }
}

/* ═══════════════════════════════════════════════════════
   POST PAGE — photo below nav, title in white section below
   ═══════════════════════════════════════════════════════ */
.post-photo-hero {
  position: relative;
  height: 55vh;
  min-height: 380px;
  overflow: hidden;
  margin-top: 0; /* nav is fixed so no push needed */
}
.post-photo-bg {
  position: absolute;
  inset: 0;
  background: center/cover no-repeat;
}
.post-photo-veil {
  position: absolute;
  inset: 0;
  background: linear-gradient(to bottom, rgba(8,3,5,0.18) 0%, rgba(8,3,5,0.52) 100%);
}

.post-title-block {
  background: #fff;
  padding: 2.5rem 0 0;
  border-bottom: 1px solid var(--border);
}
.post-title-h1 {
  color: #0d0608 !important;
  font-size: clamp(1.8rem, 3.5vw, 3.2rem) !important;
  max-width: 860px;
  line-height: 1.12;
  margin-top: 0.6rem;
  font-weight: 400;
}
.post-title-date {
  font-family: 'DM Mono', monospace;
  font-size: 0.68rem !important;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: #999 !important;
  margin-top: 0.8rem;
  padding-bottom: 2rem;
  text-indent: 0 !important;
}

@media (max-width: 768px) {
  .post-photo-hero { height: 40vh; min-height: 240px; }
  .post-title-h1 { font-size: clamp(1.5rem, 6vw, 2.2rem) !important; }
  .post-title-block { padding: 1.8rem 0 0; }
}

/* ═══════════════════════════════════════════════
   POST PAGE — photo below nav, black title below
   ═══════════════════════════════════════════════ */

/* Nav height on post page is fixed ~90px, so push photo down */
.post-img-block {
  position: relative;
  height: 55vh !important;
  min-height: 360px !important;
  margin-top: 90px;
  overflow: hidden;
  width: 100%;
  display: block;
}
.post-img-bg {
  position: absolute;
  inset: 0;
  background: center / cover no-repeat;
}
.post-img-veil {
  position: absolute;
  inset: 0;
  background: linear-gradient(to bottom, rgba(0,0,0,0.08) 0%, rgba(0,0,0,0.35) 100%);
}
.post-img-cat {
  position: absolute;
  top: 1.5rem;
  left: 3rem;
  z-index: 2;
  color: var(--gold) !important;
}

/* Title strip — white background, black text */
.post-title-wrap {
  background: #fff;
  padding: 2.2rem 0 1.8rem;
  border-bottom: 1px solid var(--border);
}
.post-title-h1 {
  font-family: 'Cormorant Garamond', serif !important;
  font-size: clamp(1.8rem, 3vw, 3rem) !important;
  font-weight: 400 !important;
  color: #0d0608 !important;
  line-height: 1.15 !important;
  max-width: 860px;
  margin: 0 !important;
}
.post-title-meta {
  font-family: 'DM Mono', monospace;
  font-size: 0.68rem !important;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: #999 !important;
  margin-top: 0.8rem !important;
  text-indent: 0 !important;
}

@media (max-width: 768px) {
  .post-img-block { margin-top: 70px; height: 42vh; min-height: 240px; }
  .post-img-cat { left: 1.25rem; }
  .post-title-wrap { padding: 1.5rem 0 1.2rem; }
}
