.section-title{
  font-size:2.1rem;
  text-align:center;
  color:var(--primary-dark);
  margin-bottom:32px;
  position:relative;
  display:inline-block;
  width:100%;
}

.section-title::after{
  content:'';
  position:absolute;
  bottom:-12px;
  left:50%;
  transform:translateX(-50%);
  width:80px;
  height:4px;
  background:var(--accent-color);
  border-radius:2px;
}

/* ===== Competencies ===== */
.executive-competencies{
  padding:64px 0;
  background: linear-gradient(180deg, var(--neutral-50) 0%, var(--neutral-100) 100%);
}

.executive-competencies .container{
  max-width:1100px;
  margin:0 auto;
  padding:0 30px;
}

.competency-grid{
  display:grid;
  grid-template-columns:repeat(auto-fit, minmax(300px, 1fr));
  gap:20px;
}

.competency-card{
  position:relative;
  border-radius:16px;
  overflow:hidden;
  padding:22px 20px;
  background: linear-gradient(180deg, rgba(255,255,255,.36), rgba(255,255,255,.22));
  border:1px solid rgba(255,255,255,.45);
  box-shadow: 0 18px 36px rgba(0,0,0,.10), inset 0 1px 0 rgba(255,255,255,.35);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
  transition: var(--transition);
  display:flex;
  flex-direction:column;
  height:100%;
  animation: fadeInSoft .5s ease both;
}

.competency-card::before{
  content:'';
  position:absolute;
  top:0;
  left:0;
  width:100%;
  height:4px;
  background: linear-gradient(90deg, var(--primary-color), var(--primary-light));
}

.competency-card:hover{
  transform: translateY(-6px);
  box-shadow: 0 22px 44px rgba(0,0,0,.12);
}

.card-header{
  display:flex;
  align-items:center;
  gap:12px;
  margin-bottom:12px;
}

.card-icon{
  width:54px;
  height:54px;
  border-radius:50%;
  display:flex;
  align-items:center;
  justify-content:center;
  background: rgba(93,64,55,.10);
  color: var(--primary-color);
  font-size:1.4rem;
  flex-shrink:0;
}

.competency-card h3{
  margin:0;
  font-size:1.18rem;
  line-height:1.28;
  color:var(--primary-dark);
}

.card-content{ flex-grow:1; }

.card-content p{
  margin:0;
  color: var(--text-color);
  line-height:1.7;
  font-size:.96rem;
  letter-spacing:.2px;
}

/* ===== Tools (polished 4-up) ===== */
.executive-tools{
  background: var(--neutral-50);
  padding: 64px 0;
}

.executive-tools .container{
  max-width:1200px;              /* wider so labels don’t wrap */
  margin:0 auto;
  padding:0 30px;
}

.tools-grid{
  display:grid;
  grid-template-columns: repeat(4, minmax(240px,1fr)); /* 4 cards in one line */
  gap:22px;
  align-items:stretch;
}

.toolkit-card{
  background: var(--card-bg);
  border:1px solid var(--neutral-150);
  border-radius:14px;
  padding:22px;
  box-shadow: var(--card-shadow);
  transition: var(--transition);
  animation: fadeInSoft .55s ease both;
  display:flex;
  flex-direction:column;
  min-height:100%;
}

.toolkit-card:hover{
  transform: translateY(-6px);
  box-shadow: 0 18px 36px rgba(0,0,0,.12);
}

.toolkit-head{
  display:flex;
  align-items:center;
  gap:12px;
  margin-bottom:14px;
  min-height:56px;               /* stabilizes multi-line headings */
}

.toolkit-icon{
  width:50px;
  height:50px;
  border-radius:50%;
  display:flex;
  align-items:center;
  justify-content:center;
  background: rgba(93,64,55,.10);
  color: var(--primary-color);
  font-size:1.3rem;
  flex-shrink:0;
}

.toolkit-head h3{
  margin:0;
  font-size:1.16rem;
  color: var(--primary-dark);
  line-height:1.2;
  word-break: keep-all;          /* avoid awkward splits */
}

.tools-list{
  display:grid;
  grid-template-columns: 1fr;
  gap:10px;
  margin-top:auto;               /* keeps card heights even */
}

.tool-item{
  background: var(--card-bg);
  border:1px solid var(--neutral-150);
  border-radius:10px;
  padding:12px 12px;
  display:flex;
  align-items:center;
  gap:10px;
  transition: var(--transition);
  width:100%;
}

.tool-item i{
  width:22px;
  text-align:center;
  font-size:1.15rem;
  color: var(--primary-color);
  flex-shrink:0;
}

.tool-item span{
  color: var(--text-color);
  font-weight:600;
  font-size:.95rem;
  letter-spacing:.2px;
  white-space:nowrap;            /* one line on desktop */
  overflow:hidden;
  text-overflow:ellipsis;
}

.tool-item:hover{
  transform: translateY(-3px);
  box-shadow: 0 10px 20px rgba(0,0,0,.10);
}

/* ===== Footer  ===== */
.footer .social-links{ display:block; }
.footer .social-links a{ display:block; margin-bottom:8px; }

/* ===== Animations ===== */
@keyframes fadeInUp{ from{opacity:0; transform:translateY(18px)} to{opacity:1; transform:translateY(0)} }
@keyframes fadeInSoft{ from{opacity:0; transform:translateY(10px)} to{opacity:1; transform:translateY(0)} }

@media (prefers-reduced-motion: reduce){
  .competency-card,
  .toolkit-card{ animation:none }
}

/* ===== Responsive ===== */
@media (max-width: 992px){
  .section-title{ font-size:1.95rem }
  .tools-grid{ grid-template-columns: repeat(2, 1fr); } /* 2-up tablets */
}

@media (max-width: 768px){
  .executive-competencies .container,
  .executive-tools .container{ padding:0 20px }
  .card-icon{ width:50px; height:50px; font-size:1.25rem }
  .competency-card{ padding:20px }
  .toolkit-card{ padding:20px }
  .card-content p{ font-size:.95rem }
}

@media (max-width: 640px){
  .tools-grid{ grid-template-columns: 1fr; } /* stack on phones */
  .tool-item span{ white-space: normal; }    /* allow wrapping on small */
}

@media (max-width: 576px){
  .section-title{ font-size:1.75rem }
}
