/* ============================================================
   EXTRA — SEP Theme supplementary styles
   ============================================================ */

/* ---- Logo ---- */
.sep-logo-mark { font-size:24px;font-weight:900;letter-spacing:1px;color:#fff;font-family:'Montserrat',sans-serif; }
.sep-logo-mark span,.sep-logo-mark em { color:var(--primary);font-style:normal; }
.sep-logo-sub { display:block;font-size:10px;letter-spacing:2px;color:rgba(255,255,255,0.6);text-transform:uppercase; }
.navbar__logo { display:flex;align-items:center;line-height:1; }
.navbar__logo-img { height:52px;width:auto;display:block; }

/* ---- Hero ---- */
.sep-hero { position:relative;min-height:100vh;display:flex;align-items:center;justify-content:center;text-align:center;color:#fff;overflow:hidden; }
.hero__bg-img { position:absolute;inset:0;z-index:0; }
.hero__bg-img img { width:100%;height:100%;object-fit:cover;object-position:right center; }
.hero__overlay { position:absolute;inset:0;z-index:1;background:linear-gradient(135deg,rgba(11,46,58,0.93) 0%,rgba(19,144,146,0.62) 100%); }
.hero__content { position:relative;z-index:2;padding:20px; }
.sep-hero-logo { margin-bottom:20px; }
.sep-hero-mark { font-size:72px;font-weight:900;letter-spacing:10px;color:#fff;font-family:'Montserrat',sans-serif;line-height:1; }
.sep-hero-mark em { color:var(--primary);font-style:normal; }
.hero__title { font-size:clamp(28px,5vw,56px);font-weight:800;letter-spacing:4px;text-transform:uppercase;line-height:1.1;margin-bottom:16px; }
.hero__tagline { font-size:18px;color:rgba(255,255,255,0.85);letter-spacing:1px;margin-bottom:10px; }
.hero__subtitle { font-size:13px;letter-spacing:4px;text-transform:uppercase;color:rgba(255,255,255,0.6);margin-bottom:36px; }
.hero__scroll-hint { position:absolute;bottom:36px;left:50%;transform:translateX(-50%);z-index:2; }
.hero__scroll-hint span { display:block;width:22px;height:36px;border:2px solid rgba(255,255,255,0.4);border-radius:12px;position:relative; }
.hero__scroll-hint span::after { content:'';display:block;width:4px;height:8px;background:rgba(255,255,255,0.5);border-radius:2px;margin:5px auto;animation:bounce 1.5s infinite; }

/* ---- Stats bar ---- */
.stats-bar__grid { grid-template-columns:repeat(5,1fr) !important; }
.stats-bar__item { position:relative; }
.stat-suf { font-size:22px;font-weight:800;color:var(--primary);vertical-align:super;margin-left:2px; }

/* ---- Overview ---- */
.overview-photo-wrap { position:relative;border-radius:12px;overflow:hidden;box-shadow:0 20px 60px rgba(0,0,0,0.18); }
.overview-photo { width:100%;height:auto;display:block; }
.overview-photo-caption { position:absolute;bottom:0;left:0;right:0;background:rgba(11,46,58,0.85);color:#fff;text-align:center;font-size:12px;letter-spacing:1.5px;text-transform:uppercase;padding:12px 16px; }

/* ---- Timeline ---- */
.timeline { position:relative;padding:20px 0 10px; }
.timeline::before { content:'';position:absolute;left:50%;top:0;bottom:0;width:2px;background:var(--border);transform:translateX(-50%); }
.timeline-item { display:grid;grid-template-columns:1fr 80px 1fr;gap:0;align-items:start;margin-bottom:40px; }
.timeline-item:nth-child(odd) .timeline-card { grid-column:1;grid-row:1;text-align:right;padding-right:36px; }
.timeline-item:nth-child(odd) .timeline-year-wrap { grid-column:2;grid-row:1;display:flex;flex-direction:column;align-items:center;padding-top:12px; }
.timeline-item:nth-child(even) .timeline-year-wrap { grid-column:2;grid-row:1;display:flex;flex-direction:column;align-items:center;padding-top:12px; }
.timeline-item:nth-child(even) .timeline-card { grid-column:3;grid-row:1;padding-left:36px; }
.timeline-item:nth-child(odd) .timeline-card { grid-column:1; }
.timeline-year { font-size:13px;font-weight:800;color:var(--primary);letter-spacing:1px;text-transform:uppercase;margin-bottom:8px;text-align:center; }
.timeline-dot { width:16px;height:16px;border-radius:50%;background:#fff;border:3px solid var(--border); }
.timeline-dot--primary { border-color:var(--primary);background:var(--primary); }
.timeline-card { background:#fff;border-radius:10px;padding:20px 24px;box-shadow:var(--shadow);border-top:3px solid var(--border);transition:var(--transition); }
.timeline-card--highlight { border-top-color:var(--primary); }
.timeline-card h4 { font-size:15px;font-weight:700;color:var(--dark);margin-bottom:8px; }
.timeline-card p { font-size:13px;color:var(--text-muted);line-height:1.7;margin:0; }

/* ---- Vision / Mission cards ---- */
.vm-grid { display:grid;grid-template-columns:1fr 1fr;gap:28px;margin-bottom:48px; }
.vm-card { border-radius:16px;padding:36px 32px;color:#fff;position:relative;overflow:hidden; }
.vm-card--vision { background:linear-gradient(135deg,var(--dark) 0%,#0f3d4e 100%); }
.vm-card--mission { background:linear-gradient(135deg,var(--primary) 0%,#0d7274 100%); }
.vm-card__header { display:flex;align-items:center;justify-content:space-between;padding-bottom:18px;margin-bottom:18px;border-bottom:1px solid rgba(255,255,255,0.15); }
.vm-card__icon { font-size:34px;display:flex;align-items:center;justify-content:center;flex-shrink:0;width:56px;height:56px;background:rgba(255,255,255,0.12);border-radius:12px;backdrop-filter:blur(4px); }
.vm-card h3 { font-size:22px;font-weight:800;letter-spacing:2px;margin-bottom:0;text-transform:uppercase; }
.vm-card p { font-size:15px;line-height:1.85;color:rgba(255,255,255,0.88);margin:0; }

/* ---- Values grid ---- */
.values-grid { display:grid;grid-template-columns:repeat(4,1fr);gap:22px; }
.value-card { position:relative;background:#fff;border-radius:12px;padding:22px 20px 22px 22px;box-shadow:var(--shadow);text-align:left;border-bottom:3px solid var(--primary);transition:var(--transition); }
.value-card:hover { transform:translateY(-4px);box-shadow:0 16px 40px rgba(0,0,0,0.1); }
.value-card__icon { position:absolute;top:16px;right:16px;font-size:22px;display:flex;align-items:center;justify-content:center;width:44px;height:44px;background:rgba(19,144,146,0.1);border-radius:10px; }
.value-card h4 { font-size:14px;font-weight:800;color:var(--dark);margin-bottom:10px;line-height:1.3;letter-spacing:0.3px;padding-right:62px; }
.value-card p { font-size:13px;color:var(--text-muted);line-height:1.75;margin:0;padding-right:62px; }

/* ---- Leadership ---- */
.leaders-row { display:grid;grid-template-columns:1fr 1fr;gap:30px;margin-bottom:60px; }
.leader-card { display:grid;grid-template-columns:180px 1fr;gap:28px;background:#fff;border-radius:12px;padding:32px;box-shadow:0 8px 40px rgba(0,0,0,0.08);border-left:4px solid var(--primary);align-items:start;transition:var(--transition); }
.leader-card:hover { box-shadow:0 16px 60px rgba(0,0,0,0.12);transform:translateY(-3px); }
.leader-card__photo-wrap { text-align:center; }
.leader-card__photo { width:160px;height:160px;border-radius:50%;object-fit:cover;border:4px solid var(--primary);display:block;margin:0 auto; }
.leader-card__role-tag { display:inline-block;background:var(--primary);color:#fff;font-size:10px;font-weight:700;letter-spacing:2px;text-transform:uppercase;padding:4px 12px;border-radius:20px;margin-bottom:10px; }
.leader-card__name { font-size:20px;font-weight:800;color:var(--dark);margin-bottom:4px; }
.leader-card__title { font-size:13px;color:var(--primary);font-weight:600;letter-spacing:0.5px;margin-bottom:14px;text-transform:uppercase; }
.leader-card__bio { font-size:13.5px;color:var(--text-muted);line-height:1.8;margin:0; }

/* ---- Section divider heading ---- */
.section-divider { text-align:center;margin:60px 0 36px;position:relative; }
.section-divider::before { content:'';display:block;height:1px;background:var(--border);position:absolute;top:50%;left:0;right:0; }
.section-divider h3 { display:inline-block;background:var(--light-bg);padding:0 24px;position:relative;font-size:18px;font-weight:700;color:var(--dark);letter-spacing:1px; }

/* ---- Directors grid ---- */
.directors-grid { display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-bottom:60px; }
.director-card { background:#fff;border-radius:10px;padding:24px;box-shadow:var(--shadow);text-align:center;transition:var(--transition); }
.director-card:hover { transform:translateY(-3px);box-shadow:0 12px 36px rgba(0,0,0,0.1); }
.director-card__photo { width:100px;height:100px;border-radius:50%;object-fit:cover;border:3px solid var(--primary);margin:0 auto 16px; }
.director-card__info h4 { font-size:16px;font-weight:700;color:var(--dark);margin-bottom:4px; }
.director-card__info span { font-size:12px;font-weight:600;color:var(--primary);text-transform:uppercase;letter-spacing:0.5px;display:block;margin-bottom:12px; }
.director-card__info p { font-size:13px;color:var(--text-muted);line-height:1.7;margin:0; }

/* ---- LEED Leader ---- */
.leed-leader { display:grid;grid-template-columns:300px 1fr;gap:40px;background:linear-gradient(135deg,var(--dark) 0%,#0f3d4e 100%);border-radius:14px;padding:40px;color:#fff;align-items:start; }
.leed-leader__visual { width:100%;border-radius:10px;display:block;object-fit:cover;max-height:280px; }
.leed-leader__body h3 { font-size:24px;font-weight:800;color:#fff;margin-bottom:6px; }
.leed-leader__creds { font-size:13px;color:var(--primary);font-weight:700;letter-spacing:2px;text-transform:uppercase;margin-bottom:16px; }
.leed-leader__body > p { font-size:14px;color:rgba(255,255,255,0.85);line-height:1.8;margin-bottom:18px; }
.leed-leader__points { padding-left:18px;margin:0; }
.leed-leader__points li { font-size:13px;color:rgba(255,255,255,0.8);line-height:1.7;margin-bottom:6px; }

/* ---- Team capabilities ---- */
.capabilities-grid { display:grid;grid-template-columns:repeat(3,1fr);gap:22px;margin-bottom:50px; }
.capability-card { background:#fff;border-radius:10px;padding:26px 22px;box-shadow:var(--shadow);border-top:3px solid var(--primary);transition:var(--transition); }
.capability-card:hover { transform:translateY(-3px);box-shadow:0 12px 36px rgba(0,0,0,0.1); }
.capability-card__icon { font-size:32px;margin-bottom:12px;display:block; }
.capability-card h4 { font-size:15px;font-weight:700;color:var(--dark);margin-bottom:10px; }
.capability-card p { font-size:13px;color:var(--text-muted);line-height:1.7;margin:0; }

/* ---- Office row ---- */
.team-offices { display:grid;grid-template-columns:1fr auto 1fr auto 2fr;gap:0;background:#fff;border-radius:12px;padding:32px;box-shadow:var(--shadow);align-items:center; }
.team-office { text-align:center;padding:0 20px; }
.team-office__label { font-size:10px;letter-spacing:2.5px;text-transform:uppercase;color:var(--primary);font-weight:700;margin-bottom:6px; }
.team-office__city { font-size:18px;font-weight:800;color:var(--dark);margin-bottom:10px;line-height:1.3; }
.team-office p { font-size:13px;color:var(--text-muted);line-height:1.6;margin:0; }
.team-office-divider { width:1px;height:80px;background:var(--border); }

/* ---- Services photos ---- */
.services-photos { display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-top:50px; }
.service-photo-item { position:relative;border-radius:10px;overflow:hidden;aspect-ratio:4/3; }
.service-photo-item img { width:100%;height:100%;object-fit:cover;transition:transform 0.4s ease; }
.service-photo-item:hover img { transform:scale(1.05); }
.service-photo-caption { position:absolute;bottom:0;left:0;right:0;background:linear-gradient(transparent,rgba(11,46,58,0.9));color:#fff;text-align:center;padding:28px 12px 12px;font-size:12px;font-weight:700;letter-spacing:1px;text-transform:uppercase; }

/* ---- Slide images (kept for organogram) ---- */
.slide-img { width:100%;height:auto;display:block; }
.slide-img.rounded { border-radius:10px; }
.slide-img.shadow { box-shadow:0 8px 40px rgba(0,0,0,0.15); }
.slide-full { margin:0 auto; }

/* ---- BIM & Accreditations ---- */
.bim-grid { display:grid;grid-template-columns:1fr 400px;gap:50px;align-items:center;margin-bottom:60px; }
.bim-text h3 { font-size:22px;font-weight:800;color:var(--dark);margin-bottom:16px; }
.bim-text > p { font-size:14px;color:var(--text-muted);line-height:1.8;margin-bottom:18px; }
.bim-points { padding-left:20px;margin-bottom:0; }
.bim-points li { font-size:14px;color:var(--text-muted);line-height:1.8;margin-bottom:8px; }
.bim-points li strong { color:var(--dark); }
.bim-photo { width:100%;border-radius:12px;box-shadow:0 12px 40px rgba(0,0,0,0.15);display:block; }
.accred-section { text-align:center; }
.accred-heading { font-size:22px;font-weight:800;color:var(--dark);margin-bottom:12px; }
.accred-intro { font-size:14px;color:var(--text-muted);max-width:640px;margin:0 auto 28px;line-height:1.8; }
.accred-chips { display:flex;flex-wrap:wrap;gap:12px;justify-content:center; }
.accred-chip { background:var(--dark);color:#fff;padding:10px 20px;border-radius:30px;font-size:13px;font-weight:600;transition:var(--transition); }
.accred-chip:hover { background:var(--primary); }

/* ---- Market ---- */
.market-grid { display:grid;grid-template-columns:1fr 1.2fr;gap:50px;align-items:start; }
.market-stats { display:flex;flex-direction:column;gap:0; }
.market-stat-item { display:flex;align-items:baseline;gap:14px;padding:18px 0;border-bottom:1px solid var(--border); }
.market-stat-item:first-child { padding-top:0; }
.market-stat-number { font-size:36px;font-weight:900;color:var(--primary);font-family:'Montserrat',sans-serif;min-width:80px; }
.market-stat-label { font-size:14px;color:var(--dark);font-weight:600; }
.market-sectors { background:#fff;border-radius:10px;padding:22px 24px;box-shadow:var(--shadow);margin-top:24px; }
.market-sectors h4 { font-size:13px;font-weight:800;text-transform:uppercase;letter-spacing:1.5px;color:var(--dark);margin-bottom:14px; }
.market-sectors ul { padding-left:0;list-style:none;margin:0; }
.market-sectors ul li { font-size:13px;color:var(--text-muted);padding:5px 0;border-bottom:1px solid var(--border); }
.market-sectors ul li:last-child { border-bottom:none; }
.market-map { width:100%;border-radius:12px;box-shadow:0 12px 40px rgba(0,0,0,0.12);display:block;margin-bottom:16px; }
.market-offices { display:flex;flex-wrap:wrap;gap:8px; }
.market-office-badge { background:var(--dark);color:#fff;font-size:12px;font-weight:600;padding:6px 14px;border-radius:20px; }

/* ---- Clients ---- */
.clients-section { text-align:center; }
.clients-heading { font-size:22px;font-weight:700;color:var(--dark);margin-bottom:28px;letter-spacing:1px; }
.clients-grid { display:flex;flex-wrap:wrap;gap:12px;justify-content:center; }
.client-chip { background:var(--dark);color:#fff;padding:12px 24px;border-radius:40px;font-size:14px;font-weight:500;transition:var(--transition);cursor:default;display:flex;align-items:center;gap:8px; }
.client-chip:hover { background:var(--primary);transform:translateY(-2px); }

/* ---- Services grid ---- */
.services-grid { display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-bottom:20px; }
.service-card { background:#fff;border-radius:8px;padding:28px 24px;box-shadow:var(--shadow);border-top:4px solid var(--primary);transition:var(--transition); }
.service-card:hover { transform:translateY(-4px);box-shadow:0 16px 40px rgba(0,0,0,0.1); }
.service-card__icon { font-size:32px;margin-bottom:14px; }
.service-card h3 { font-size:16px;font-weight:700;color:var(--dark);margin-bottom:14px; }
.service-card ul { padding-left:16px; }
.service-card ul li { font-size:13px;color:var(--text-muted);margin-bottom:6px;line-height:1.5; }

/* ---- Portfolio tags ---- */
.project-tag-grid { display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin-top:30px; }
.project-tag-item { background:#fff;border:1px solid var(--border);border-left:3px solid var(--primary);border-radius:6px;padding:12px 16px;font-size:14px;font-weight:600;color:var(--dark);transition:var(--transition); }
.project-tag-item:hover { border-color:var(--primary);box-shadow:0 4px 16px rgba(19,144,146,0.1);transform:translateY(-2px); }
.project-tag-item span { display:block;font-size:12px;color:var(--text-muted);font-weight:400;margin-top:4px; }

/* ---- Section intro ---- */
.section-intro { text-align:center;max-width:700px;margin:-20px auto 36px;color:var(--text-muted);font-size:15px;line-height:1.8; }

/* ---- SEP Projects ---- */
.current-projects__grid { display:grid;grid-template-columns:repeat(3,1fr);gap:22px; }
.current-project-card { background:#fff;border-radius:10px;padding:24px;box-shadow:var(--shadow);border-top:4px solid var(--primary);position:relative;transition:var(--transition); }
.current-project-card:hover { transform:translateY(-4px);box-shadow:0 16px 40px rgba(0,0,0,0.12); }
.current-project-card__badge { position:absolute;top:16px;right:16px;background:var(--primary);color:#fff;font-size:10px;font-weight:700;letter-spacing:1.5px;text-transform:uppercase;padding:4px 10px;border-radius:20px; }
.current-project-card h3 { font-size:16px;font-weight:700;color:var(--dark);margin-bottom:12px;padding-right:55px; }
.current-project-card__area { margin-bottom:12px; }
.area-label { display:block;font-size:10px;letter-spacing:2px;text-transform:uppercase;color:var(--text-muted); }
.area-value { font-size:18px;font-weight:800;color:var(--primary); }
.current-project-card p { font-size:13px;color:var(--text-muted);line-height:1.7;margin-bottom:14px; }
.current-project-card__services { display:flex;flex-wrap:wrap;gap:6px; }
.current-project-card__services span { font-size:11px;font-weight:600;color:var(--dark);background:var(--light-bg);border-radius:4px;padding:3px 9px; }

/* ---- Contact ---- */
.contact-section { background:var(--dark); }
.contact__grid { display:grid;grid-template-columns:1fr 1.2fr;gap:60px;align-items:start; }
.contact-info h3 { font-size:24px;font-weight:800;color:#fff;margin-bottom:14px; }
.contact-info > p { color:rgba(255,255,255,0.7);margin-bottom:28px;line-height:1.8; }
.contact-detail { display:flex;align-items:flex-start;gap:14px;margin-bottom:18px; }
.contact-detail__icon { width:42px;height:42px;background:var(--primary);border-radius:8px;display:flex;align-items:center;justify-content:center;font-size:18px;flex-shrink:0; }
.contact-detail strong { display:block;font-size:11px;letter-spacing:2px;text-transform:uppercase;color:var(--primary); }
.contact-detail p { color:rgba(255,255,255,0.85);font-size:13px;margin-top:3px; }
.contact-form { background:#fff;border-radius:12px;padding:36px; }
.form-group { margin-bottom:16px; }
.form-group--row { display:grid;grid-template-columns:1fr 1fr;gap:14px; }
.form-field { display:flex;flex-direction:column; }
.form-field label { font-size:11px;font-weight:700;letter-spacing:1px;text-transform:uppercase;color:var(--text-muted);margin-bottom:6px; }
.form-field input,.form-group textarea,.form-group select { width:100%;padding:11px 14px;border:2px solid var(--border);border-radius:6px;font-size:14px;outline:none;transition:var(--transition);font-family:inherit;color:var(--text);background:#fff; }
.form-field input:focus,.form-group textarea:focus,.form-group select:focus { border-color:var(--primary);box-shadow:0 0 0 3px rgba(19,144,146,0.1); }
.form-group textarea { resize:vertical;min-height:110px; }
.btn--full { width:100%;text-align:center;margin-top:8px; }
.btn--nav { background:var(--primary) !important;color:#fff !important;padding:8px 16px !important;border-radius:4px; }

/* ---- Footer ---- */
.sep-logo-mark.footer-sep { font-size:28px; }
.footer__logo { display:flex;align-items:center;gap:14px;margin-bottom:16px; }

/* ---- Responsive ---- */
@media (max-width:1200px) {
    .leaders-row { grid-template-columns:1fr; }
    .leader-card { grid-template-columns:140px 1fr; }
    .leed-leader { grid-template-columns:220px 1fr; }
    .market-grid { grid-template-columns:1fr; }
}
@media (max-width:1024px) {
    .stats-bar__grid { grid-template-columns:repeat(3,1fr) !important; }
    .services-grid { grid-template-columns:repeat(2,1fr); }
    .project-tag-grid { grid-template-columns:repeat(3,1fr); }
    .current-projects__grid { grid-template-columns:repeat(2,1fr); }
    .contact__grid { grid-template-columns:1fr;gap:36px; }
    .vm-grid { grid-template-columns:1fr; }
    .values-grid { grid-template-columns:repeat(2,1fr); }
    .directors-grid { grid-template-columns:repeat(2,1fr); }
    .capabilities-grid { grid-template-columns:repeat(2,1fr); }
    .bim-grid { grid-template-columns:1fr;gap:32px; }
    .bim-grid .bim-visual { display:none; }
    .services-photos { grid-template-columns:repeat(2,1fr); }
    .team-offices { grid-template-columns:1fr;gap:20px; }
    .team-office-divider { width:100%;height:1px; }
}
@media (max-width:768px) {
    .stats-bar__grid { grid-template-columns:repeat(2,1fr) !important; }
    .services-grid { grid-template-columns:1fr; }
    .project-tag-grid { grid-template-columns:repeat(2,1fr); }
    .current-projects__grid { grid-template-columns:1fr; }
    .form-group--row { grid-template-columns:1fr; }
    .sep-hero-mark { font-size:48px; }
    .values-grid { grid-template-columns:1fr; }
    .directors-grid { grid-template-columns:1fr; }
    .capabilities-grid { grid-template-columns:1fr; }
    .leader-card { grid-template-columns:1fr;text-align:center; }
    .leader-card__photo { margin-bottom:16px; }
    .leed-leader { grid-template-columns:1fr; }
    .timeline::before { left:28px; }
    .timeline-item { grid-template-columns:56px 1fr !important;grid-template-rows:auto !important; }
    .timeline-item:nth-child(odd) .timeline-year-wrap,
    .timeline-item:nth-child(even) .timeline-year-wrap { grid-column:1 !important;grid-row:1 !important; }
    .timeline-item:nth-child(odd) .timeline-card,
    .timeline-item:nth-child(even) .timeline-card { grid-column:2 !important;grid-row:1 !important;padding:16px 18px;text-align:left; }
    .services-photos { grid-template-columns:1fr 1fr; }
}
@media (max-width:480px) {
    .stats-bar__grid { grid-template-columns:1fr !important; }
    .project-tag-grid { grid-template-columns:1fr; }
    .services-photos { grid-template-columns:1fr; }
}

/* ============================================================
   FIXES & ENHANCEMENTS
   ============================================================ */

/* ---- Stats bar: HTML uses .stat-number / .stat-label, CSS only had .stats-bar__num / .stats-bar__label ---- */
.stat-number {
    display: inline-block;
    font-size: 52px;
    font-weight: 900;
    color: var(--dark);
    line-height: 1;
    font-family: 'Montserrat', sans-serif;
    letter-spacing: -1px;
}
.stat-label {
    display: block;
    margin-top: 12px;
    font-size: 11px;
    font-weight: 700;
    color: var(--text-muted);
    text-transform: uppercase;
    letter-spacing: 1.5px;
    line-height: 1.5;
}
.stats-bar__item:hover .stat-number { color: var(--primary); transition: color 0.3s ease; }

/* ---- Section label + decorative line (used in front-page.php but were unstyled) ---- */
.section-label {
    display: block;
    font-size: 11px;
    font-weight: 700;
    color: var(--primary);
    letter-spacing: 4px;
    text-transform: uppercase;
    margin-bottom: 10px;
}
.title-line {
    width: 48px;
    height: 3px;
    background: var(--primary);
    margin: 14px auto 0;
    border-radius: 2px;
}

/* ---- Alternate section background (section--alt used throughout template but was unstyled) ---- */
.section--alt { background: var(--light-bg); }

/* ---- Overview restructure: full-width intro + 2-col lower ---- */
#overview { padding: 52px 0; }
#overview .section-title { margin-bottom: 28px; }
.overview__intro {
    max-width: 860px;
    margin: 0 auto 24px;
    text-align: center;
}
.overview__intro p {
    color: var(--text-muted);
    font-size: 15px;
    line-height: 1.8;
    margin-bottom: 10px;
}
.overview__lower {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 36px;
    align-items: stretch;
}
/* Highlight items — icon aligned right of heading */
.overview__highlights { display:flex;flex-direction:column;gap:12px;margin-top:0; }
.highlight-item {
    padding: 16px 20px;
    background: var(--light-bg);
    border-radius: 8px;
    border-left: 3px solid var(--primary);
    flex: 1;
}
.highlight-item__header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin-bottom: 8px;
}
.highlight-item__header strong {
    font-size: 14px;
    font-weight: 700;
    color: var(--dark);
    line-height: 1.3;
}
.highlight-icon {
    font-size: 20px;
    flex-shrink: 0;
    width: 38px;
    height: 38px;
    display: flex;
    align-items: center;
    justify-content: center;
    background: rgba(19,144,146,0.1);
    border-radius: 8px;
}
.highlight-item p {
    font-size: 13px;
    color: var(--text-muted);
    margin: 0;
    line-height: 1.65;
}
.overview__visual { display: block !important; }
.overview-photo-wrap { width: 100%; border-radius: 12px; overflow: hidden; box-shadow: 0 20px 60px rgba(0,0,0,0.18); }
.overview-photo { width: 100%; height: auto; display: block; }

/* ---- Navbar logo mark polish ---- */
.sep-logo-mark { letter-spacing: 2px; }
.sep-logo-sub { letter-spacing: 1.5px; font-size: 9px; }

/* ---- Tabs: gap below tab buttons before content ---- */
.tabs { display:flex; gap:10px; flex-wrap:wrap; margin-bottom:28px; }
.tab-pane { margin-top: 0; }

/* ---- Timeline icons — beside the title using CSS grid ---- */
.timeline-card {
    display: grid;
    grid-template-columns: auto 1fr;
    grid-template-rows: auto auto;
    column-gap: 14px;
    align-items: center;
}
.timeline-card__icon {
    grid-column: 1;
    grid-row: 1;
    width: 44px;
    height: 44px;
    background: var(--light-bg);
    border: 2px solid var(--border);
    border-radius: 10px;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 22px;
    flex-shrink: 0;
}
.timeline-card__icon--primary {
    background: rgba(19,144,146,0.1);
    border-color: var(--primary);
}
.timeline-card h4 {
    grid-column: 2;
    grid-row: 1;
    margin-bottom: 0;
}
.timeline-card p {
    grid-column: 1 / -1;
    grid-row: 2;
    margin-top: 10px;
    margin-bottom: 0;
}

/* Odd cards: right-aligned text → icon on the RIGHT of the title */
.timeline-item:nth-child(odd) .timeline-card {
    grid-template-columns: 1fr auto;
}
.timeline-item:nth-child(odd) .timeline-card__icon {
    grid-column: 2;
    grid-row: 1;
}
.timeline-item:nth-child(odd) .timeline-card h4 {
    grid-column: 1;
    grid-row: 1;
}

/* ---- Navbar CTA button glow ---- */
.btn--nav {
    box-shadow: 0 4px 16px rgba(19,144,146,0.4) !important;
    letter-spacing: 1px !important;
    font-size: 12px !important;
}
.navbar__menu .btn--nav:hover {
    background: #0f7475 !important;
    box-shadow: 0 6px 22px rgba(19,144,146,0.55) !important;
    transform: translateY(-1px);
    color: #fff !important;
    border-bottom-color: transparent !important;
    border-radius: 4px !important;
}

/* ============================================================
   HERO SPLIT LAYOUT + SLIDER
   ============================================================ */
.sep-hero {
    min-height: 100vh;
    display: flex !important;
    flex-direction: row !important;
    align-items: stretch !important;
    justify-content: flex-start !important;
    text-align: left !important;
    overflow: hidden;
}
.hero__bg-img,
.hero__overlay { display: none; }

.hero__left {
    flex: 0 0 50%;
    background: linear-gradient(160deg, #0b2e3a 0%, #0f3d4e 65%, #139092 100%);
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 80px 52px;
    position: relative;
    z-index: 2;
}
.hero__right {
    flex: 0 0 50%;
    position: relative;
    overflow: hidden;
    min-height: 100vh;
}

/* Hero logo card — replaces text SEP mark */
.hero__logo-card {
    background: #ffffff;
    border-radius: 14px;
    padding: 24px 40px;
    display: flex;
    align-items: center;
    justify-content: center;
    box-shadow: 0 8px 36px rgba(0,0,0,0.28);
    margin-bottom: 28px;
}
.hero__logo-img { height: 84px; width: auto; display: block; }
.sep-hero .hero__tagline { text-align: center; }
.hero__btns { justify-content: center; }
.hero__scroll-hint { left: 25%; }

/* ---- Hero Slider ---- */
.hero-slider { position: relative; width: 100%; height: 100%; }

.hero-slide {
    position: absolute;
    inset: 0;
    opacity: 0;
    transition: opacity 0.8s ease;
    z-index: 1;
}
.hero-slide.active {
    opacity: 1;
    z-index: 2;
}
.hero-slide img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: center;
    display: block;
}

.hero-slider__dots {
    position: absolute;
    bottom: 22px;
    left: 50%;
    transform: translateX(-50%);
    display: flex;
    gap: 8px;
    z-index: 5;
}
.hero-slider__dot {
    width: 10px;
    height: 10px;
    border-radius: 50%;
    background: rgba(255,255,255,0.4);
    border: 2px solid rgba(255,255,255,0.6);
    cursor: pointer;
    transition: background 0.3s;
    padding: 0;
}
.hero-slider__dot.active { background: #fff; }

@media (max-width: 900px) {
    .sep-hero { flex-direction: column !important; }
    .hero__left { flex: none; width: 100%; padding: 60px 28px; text-align: center !important; min-height: 55vh; }
    .hero__right { flex: none; width: 100%; min-height: 280px; height: 280px; }
    .hero__btns { justify-content: center !important; }
    .hero__scroll-hint { left: 50%; }
    .hero__tagline { text-align: center; }
}

/* ============================================================
   LEED LEAD CARD — REDESIGN
   ============================================================ */
.leed-lead-card {
    display: grid;
    grid-template-columns: 280px 1fr;
    gap: 0;
    border-radius: 14px;
    overflow: hidden;
    box-shadow: 0 8px 36px rgba(0,0,0,0.18);
    background: var(--dark);
    color: #fff;
    margin-top: 28px;
}
.leed-lead-card__photo { position: relative; background: #0f3d4e; }
.leed-lead-card__photo img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: top center;
    min-height: 340px;
    display: block;
}
.leed-lead-card__body {
    padding: 42px 46px;
    display: flex;
    flex-direction: column;
    gap: 10px;
    background: linear-gradient(140deg, #0f3d4e 0%, #0b2e3a 100%);
}
.leed-lead-card__tag {
    display: inline-block;
    background: var(--primary);
    color: #fff;
    font-size: 11px;
    font-weight: 700;
    letter-spacing: 2px;
    text-transform: uppercase;
    padding: 5px 16px;
    border-radius: 20px;
    align-self: flex-start;
    margin-bottom: 4px;
}
.leed-lead-card__name { font-size: 28px; font-weight: 800; color: #fff; margin: 0; }
.leed-lead-card__creds {
    font-size: 12px;
    color: var(--primary);
    font-weight: 700;
    letter-spacing: 1px;
    text-transform: uppercase;
    line-height: 1.7;
}
.leed-lead-card__title { font-size: 14px; color: rgba(255,255,255,0.6); font-style: italic; }
.leed-lead-card__bio { font-size: 14px; color: rgba(255,255,255,0.82); line-height: 1.8; margin: 4px 0; }
.leed-lead-card__points { padding: 0; list-style: none; display: flex; flex-direction: column; gap: 6px; margin-top: 6px; }
.leed-lead-card__points li { font-size: 13px; color: rgba(255,255,255,0.8); line-height: 1.6; }

@media (max-width: 768px) {
    .leed-lead-card { grid-template-columns: 1fr; }
    .leed-lead-card__photo img { min-height: 220px; }
    .leed-lead-card__body { padding: 28px 24px; }
}

/* ============================================================
   SERVICE CARD WITH PHOTO
   ============================================================ */
.service-card {
    position: relative;
    padding: 26px 24px !important;
    overflow: visible;
    display: block;
}
.service-card__photo {
    height: 165px;
    overflow: hidden;
    border-radius: 6px;
    margin-bottom: 14px;
}
.service-card__photo img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: center;
    transition: transform 0.4s ease;
    display: block;
}
.service-card:hover .service-card__photo img { transform: scale(1.05); }
.service-card .service-card__icon { position: absolute; top: 20px; right: 20px; font-size: 26px; display: flex; align-items: center; justify-content: center; width: 48px; height: 48px; background: rgba(19,144,146,0.1); border-radius: 10px; margin: 0; }
.service-card h3 { font-size: 15px; padding: 0 0 10px 0; padding-right: 66px; }
.service-card ul { padding-left: 16px; padding-right: 66px; }
.service-card ul li { margin-bottom: 5px; font-size: 13px; color: var(--text-muted); line-height: 1.5; }
.service-card > p { font-size: 13px; color: var(--text-muted); line-height: 1.7; margin: 0; padding-right: 66px; }
