:root {
      --navy:#071523;
      --navy-2:#0D2235;
      --navy-3:#101422;
      --ink:#172033;
      --muted:#667085;
      --line:#E6E9EE;
      --soft:#F6F8FA;
      --soft-green:#EAF5EF;
      --green:#0B7A3B;
      --green-dark:#075C2D;
      --blue:#1F78A6;
      --cream:#F7F3ED;
      --gold:#B79255;
      --white:#FFFFFF;
      --shadow:0 18px 45px rgba(7,21,35,.10);
      --shadow-soft:0 12px 28px rgba(7,21,35,.07);
      --radius:24px;
    }
    * { box-sizing:border-box; }
    html { scroll-behavior:smooth; }
    body { margin:0; font-family:Inter, "Segoe UI", Arial, Helvetica, sans-serif; background:#fff; color:var(--ink); line-height:1.55; }
    body.no-scroll { overflow:hidden; }
    a { color:inherit; }
    .wrap { width:min(1180px,92vw); margin:auto; }
    .skip { position:absolute; left:-999px; top:auto; width:1px; height:1px; overflow:hidden; }
    .skip:focus { left:12px; top:12px; width:auto; height:auto; z-index:999; background:#fff; color:#000; padding:10px 14px; border-radius:10px; }
    .top-strip { background:#F8FAFC; color:var(--navy); font-size:14px; border-bottom:1px solid var(--line); }
    .top-strip .wrap { min-height:34px; display:flex; justify-content:flex-end; align-items:center; gap:16px; }
    .top-strip button { border:0; color:var(--navy); background:transparent; font-weight:700; cursor:pointer; font-size:14px; padding:0; }
    .site-header { position:sticky; top:0; z-index:70; border-bottom:1px solid var(--line); background:rgba(255,255,255,.96); backdrop-filter:blur(16px); box-shadow:0 10px 25px rgba(7,21,35,.05); }
    .site-header.is-light { background:rgba(255,255,255,.96); border-bottom-color:var(--line); box-shadow:0 10px 25px rgba(7,21,35,.05); }
    .nav { display:flex; align-items:center; justify-content:space-between; gap:24px; height:94px; }
    .brand { display:flex; align-items:center; gap:13px; min-width:280px; text-decoration:none; }
    .brand-logo { width:86px; height:58px; object-fit:contain; background:#fff; border-radius:10px; padding:4px; box-shadow:0 4px 14px rgba(0,0,0,.12); }
    .brand-text { line-height:1.05; color:var(--navy); display:flex; flex-direction:column; gap:4px; }
    .site-header.is-light .brand-text { color:var(--navy); }
    .brand-title { font-family:Georgia,serif; font-size:26px; letter-spacing:-.02em; font-weight:800; }
    .brand-sub { font-size:10.5px; letter-spacing:.1em; text-transform:uppercase; opacity:.92; font-weight:800; }
    .brand-tag { font-size:9.5px; letter-spacing:.02em; color:#5B6878; font-weight:700; line-height:1.25; }
    .main-menu { display:flex; align-items:center; justify-content:center; gap:8px; flex:1; }
    .menu-item { position:relative; }
    .menu-link { color:var(--navy); text-decoration:none; text-transform:uppercase; font-weight:850; letter-spacing:.025em; padding:35px 13px; display:inline-flex; align-items:center; gap:6px; font-size:14px; }
    .menu-link:hover { color:var(--green); }
    .site-header.is-light .menu-link { color:var(--navy); }
    .chev { font-size:11px; opacity:.72; }
    .mega { opacity:0; visibility:hidden; transform:translateY(8px); position:absolute; top:88px; left:50%; width:520px; translate:-50% 0; background:#fff; color:var(--ink); border:1px solid var(--line); border-radius:0 0 22px 22px; box-shadow:var(--shadow); padding:26px; transition:.18s ease; }
    .menu-item:hover .mega, .menu-item:focus-within .mega { opacity:1; visibility:visible; transform:translateY(0); }
    .mega.wide { width:780px; }
    .mega h4 { margin:0 0 12px; color:var(--green); font-size:12px; letter-spacing:.12em; text-transform:uppercase; }
    .mega-grid { display:grid; grid-template-columns:repeat(2,1fr); gap:4px 26px; }
    .mega-grid.three { grid-template-columns:repeat(3,1fr); }
    .mega a { display:flex; justify-content:space-between; gap:16px; text-decoration:none; padding:10px 0; border-bottom:1px solid #F0F2F5; color:#263548; font-weight:700; font-size:14px; }
    .mega a:hover { color:var(--green); }
    .mega p { color:#667085; margin:14px 0 0; font-size:13px; }
    .nav-actions { display:flex; align-items:center; gap:12px; }
    .icon-btn { width:42px; height:42px; border:0; border-radius:50%; background:#F1F5F9; color:var(--navy); display:grid; place-items:center; cursor:pointer; font-size:18px; }
    .site-header.is-light .icon-btn { color:var(--navy); background:#F1F5F9; }
    .btn { display:inline-flex; align-items:center; justify-content:center; gap:8px; padding:12px 18px; border-radius:999px; text-decoration:none; font-weight:850; font-size:14px; border:1px solid transparent; cursor:pointer; transition:.18s ease; }
    .btn.primary { background:var(--green); color:#fff; }
    .btn.primary:hover { background:var(--green-dark); transform:translateY(-1px); }
    .btn.blue { background:var(--blue); color:#fff; }
    .btn.secondary { color:var(--navy); border-color:#C9D1DA; background:#fff; }
    .btn.dark { background:var(--navy); color:#fff; }
    .btn.ghost { background:transparent; color:#fff; border-color:rgba(255,255,255,.28); }
    .menu-toggle { display:none; }

    .hero { margin-top:-94px; padding-top:128px; background:
      linear-gradient(90deg, rgba(7,21,35,.92) 0%, rgba(7,21,35,.78) 44%, rgba(7,21,35,.35) 100%),
      radial-gradient(circle at 85% 10%, rgba(11,122,59,.22), transparent 34%),
      linear-gradient(135deg, #172B3A 0%, #1B3F50 48%, #81909A 100%); color:#fff; overflow:hidden; position:relative; }
    .hero:before { content:""; position:absolute; inset:0; opacity:.25; background-image:linear-gradient(120deg, transparent 0 8%, rgba(255,255,255,.15) 8.2% 8.5%, transparent 8.7% 19%), linear-gradient(90deg, transparent 0 12%, rgba(255,255,255,.12) 12.2% 12.4%, transparent 12.5% 28%); background-size:240px 460px; transform:skewX(-12deg) scale(1.08); }
    .hero-grid { position:relative; z-index:1; display:grid; grid-template-columns:1.02fr .98fr; gap:54px; align-items:end; min-height:560px; padding:80px 0 70px; }
    .eyebrow { display:inline-flex; gap:8px; align-items:center; padding:7px 12px; background:rgba(234,245,239,.12); color:#EAF5EF; border:1px solid rgba(234,245,239,.24); border-radius:999px; font-size:13px; font-weight:800; margin-bottom:22px; }
    .dot { width:8px; height:8px; background:#62C58D; border-radius:50%; }
    h1 { font-size:58px; line-height:1.02; margin:0; letter-spacing:-.055em; max-width:740px; }
    .lead { font-size:19px; color:#E7EDF2; max-width:640px; margin:24px 0 30px; }
    .hero-actions { display:flex; gap:14px; flex-wrap:wrap; }
    .quick-search { background:#fff; color:var(--ink); border-radius:var(--radius); padding:28px; box-shadow:0 22px 60px rgba(0,0,0,.28); margin-bottom:-36px; }
    .quick-search h3 { margin:0 0 12px; font-size:24px; color:var(--navy); letter-spacing:-.02em; }
    .search-row { display:flex; gap:10px; border:1px solid #D7DEE8; border-radius:16px; padding:8px; background:#FBFCFD; }
    .search-row input { flex:1; border:0; outline:0; background:transparent; font-size:15px; padding:9px 10px; }
    .mini-tabs { display:grid; grid-template-columns:repeat(3,1fr); gap:10px; margin-top:16px; }
    .mini-tabs a { text-decoration:none; border:1px solid var(--line); border-radius:14px; padding:12px; font-size:13px; font-weight:800; color:#344054; background:#fff; }
    .mini-tabs span { display:block; color:#667085; font-weight:600; font-size:12px; margin-top:3px; }

    section { padding:78px 0; }
    .section-title { display:flex; align-items:flex-end; justify-content:space-between; gap:28px; margin-bottom:34px; }
    .section-title h2 { margin:0; color:var(--navy); font-size:40px; line-height:1.08; letter-spacing:-.038em; }
    .section-title p { margin:0; color:var(--muted); max-width:560px; }
    .link-red { color:#BA0C2F; font-weight:900; text-decoration:none; }
    .insights { padding-top:94px; }
    .insight-label { display:flex; gap:12px; align-items:flex-end; color:#111; margin-bottom:14px; }
    .insight-label strong { font-size:32px; line-height:1; }
    .insight-label span { font-size:32px; font-family:Georgia,serif; letter-spacing:.02em; }
    .insight-grid { display:grid; grid-template-columns:.95fr 1.05fr; gap:30px; align-items:stretch; }
    .featured-insight { min-height:410px; color:#fff; padding:34px; border-radius:0; position:relative; overflow:hidden; background:
      linear-gradient(180deg, rgba(7,21,35,.20), rgba(7,21,35,.82)),
      linear-gradient(135deg, #214052, #0D2235); }
    .featured-insight:before { content:""; position:absolute; inset:-60px -80px; opacity:.45; background-image:linear-gradient(100deg, transparent 0 10%, rgba(255,255,255,.26) 10.2% 10.4%, transparent 10.6% 22%), linear-gradient(0deg, transparent 0 60%, rgba(255,255,255,.16) 60.4% 60.8%, transparent 61%); background-size:130px 180px; transform:perspective(500px) rotateX(54deg) rotateZ(-20deg); transform-origin:center; }
    .featured-insight > * { position:relative; z-index:1; }
    .kicker { text-transform:uppercase; letter-spacing:.08em; font-size:12px; font-weight:900; }
    .featured-insight h3 { margin:24px 0 0; font-size:44px; line-height:1.18; max-width:520px; letter-spacing:-.035em; }
    .insight-list { display:grid; gap:2px; align-content:start; }
    .insight-item { padding:0 0 26px; border-bottom:1px solid #ECEFF3; cursor:pointer; }
    .insight-item:not(:first-child) { padding-top:24px; }
    .insight-item small { display:block; text-transform:uppercase; color:#667085; font-weight:900; font-size:12px; letter-spacing:.02em; margin-bottom:10px; }
    .insight-item h3 { margin:0; color:#111827; font-size:26px; line-height:1.32; letter-spacing:-.02em; }
    .slider-line { display:flex; align-items:center; gap:12px; margin-top:22px; }
    .slider-dot { width:14px; height:14px; border-radius:50%; border:2px solid #111; }
    .slider-dot.active { background:#B00020; border-color:#B00020; }
    .slider-line:after { content:""; height:1px; background:#D2D6DC; flex:1; }

    .approach {
      background: linear-gradient(180deg,#F7FCF9 0%,#FFFFFF 100%);
      border-top: 1px solid #E4EFE8;
      border-bottom: 1px solid #E4EFE8;
    }

    .approach-shell {
      display: grid;
      grid-template-columns: .78fr 1.22fr;
      gap: 34px;
      align-items: start;
    }

    .approach-head {
      background: #fff;
      border: 1px solid #E3EFE8;
      border-radius: 26px;
      padding: 34px 30px;
      box-shadow: 0 14px 34px rgba(7,21,35,.05);
      position: sticky;
      top: 110px;
    }

    .approach-head h2 {
      margin: 14px 0 14px;
      color: var(--navy);
      font-size: 42px;
      line-height: 1.08;
      letter-spacing: -.04em;
    }

    .approach-head p {
      margin: 0;
      color: #475467;
      font-size: 17px;
      line-height: 1.7;
    }

    .approach-panels {
      display: grid;
      grid-template-columns: 1fr 1fr;
      gap: 24px;
    }

    .approach-panel {
      background: #fff;
      border: 1px solid #E3EFE8;
      border-radius: 28px;
      padding: 28px;
      box-shadow: 0 14px 34px rgba(7,21,35,.05);
      transition: transform .22s ease, box-shadow .22s ease, border-color .22s ease;
      position: relative;
      overflow: hidden;
    }

    .approach-panel::before {
      content: "";
      position: absolute;
      left: 0;
      top: 0;
      width: 100%;
      height: 6px;
      background: linear-gradient(90deg,#0B7A3B 0%,#8BC34A 100%);
    }

    .approach-panel:hover {
      transform: translateY(-6px);
      border-color: rgba(11,122,59,.45);
      box-shadow: 0 20px 44px rgba(11,122,59,.12);
    }

    .approach-meta {
      display: flex;
      align-items: center;
      gap: 14px;
      margin-bottom: 18px;
    }

    .approach-icon {
      width: 58px;
      height: 58px;
      border-radius: 18px;
      display: grid;
      place-items: center;
      background: #EAF5EF;
      color: var(--green);
      font-size: 24px;
      font-weight: 900;
      flex: 0 0 58px;
    }

    .approach-label {
      display: flex;
      flex-direction: column;
      gap: 4px;
    }

    .approach-label small {
      color: var(--green);
      font-weight: 900;
      font-size: 12px;
      letter-spacing: .16em;
      text-transform: uppercase;
    }

    .approach-label span {
      color: #667085;
      font-size: 14px;
      font-weight: 600;
    }

    .approach-panel h3 {
      margin: 0 0 14px;
      color: var(--navy);
      font-size: 34px;
      line-height: 1.08;
      letter-spacing: -.035em;
    }

    .approach-panel p {
      margin: 0 0 18px;
      color: #475467;
      font-size: 17px;
      line-height: 1.65;
    }

    .approach-points {
      display: grid;
      gap: 10px;
      margin: 0 0 22px;
      padding: 0;
      list-style: none;
    }

    .approach-points li {
      display: flex;
      gap: 10px;
      color: #344054;
      font-size: 14.5px;
      line-height: 1.5;
    }

    .approach-points li::before {
      content: "•";
      color: var(--green);
      font-weight: 900;
      line-height: 1.2;
    }

    .approach-panel .btn {
      margin-top: auto;
    }

    @media(max-width:1080px) {
      .approach-shell {
        grid-template-columns: 1fr;
      }
      .approach-head {
        position: static;
      }
    }

    @media(max-width:760px) {
      .approach-panels {
        grid-template-columns: 1fr;
      }
      .approach-head h2 {
        font-size: 34px;
      }
      .approach-panel h3 {
        font-size: 28px;
      }
    }

    .learn {
      background: linear-gradient(180deg,#FFFFFF 0%,#F8FCFA 100%);
    }

    .learn-layout {
      display: grid;
      grid-template-columns: .9fr 1.1fr;
      gap: 30px;
      align-items: start;
    }

    .learn-overview {
      background: #fff;
      border: 1px solid #E3EFE8;
      border-radius: 28px;
      padding: 30px;
      box-shadow: 0 14px 34px rgba(7,21,35,.05);
      position: sticky;
      top: 110px;
    }

    .learn-overview h2 {
      margin: 12px 0 16px;
      color: var(--navy);
      font-size: 38px;
      line-height: 1.08;
      letter-spacing: -.04em;
    }

    .learn-overview p {
      margin: 0;
      color: #475467;
      font-size: 17px;
      line-height: 1.68;
    }

    .learn-overview .mini-accent {
      width: 72px;
      height: 4px;
      border-radius: 999px;
      background: var(--green);
      margin-top: 8px;
    }

    .service-mini-grid {
      display: grid;
      grid-template-columns: 1fr 1fr;
      gap: 18px;
    }

    .service-mini-card {
      background: #fff;
      border: 1px solid #E3EFE8;
      border-radius: 24px;
      padding: 24px;
      box-shadow: 0 12px 28px rgba(7,21,35,.05);
      transition: transform .22s ease, box-shadow .22s ease, border-color .22s ease;
      min-height: 240px;
      display: flex;
      flex-direction: column;
    }

    .service-mini-card:hover {
      transform: translateY(-6px);
      border-color: rgba(11,122,59,.45);
      box-shadow: 0 20px 44px rgba(11,122,59,.12);
    }

    .service-mini-top {
      display: flex;
      align-items: center;
      gap: 12px;
      margin-bottom: 16px;
    }

    .service-mini-icon {
      width: 48px;
      height: 48px;
      border-radius: 16px;
      display: grid;
      place-items: center;
      background: #EAF5EF;
      color: var(--green);
      font-size: 22px;
      font-weight: 900;
      flex: 0 0 48px;
    }

    .service-mini-card h3 {
      margin: 0;
      color: var(--navy);
      font-size: 24px;
      line-height: 1.12;
      letter-spacing: -.025em;
    }

    .service-mini-card p {
      margin: 0 0 16px;
      color: #475467;
      font-size: 15.5px;
      line-height: 1.62;
      flex: 1;
    }

    .service-mini-card a {
      color: var(--green);
      text-decoration: none;
      font-weight: 900;
      font-size: 14px;
    }

    .service-mini-card a:hover {
      text-decoration: underline;
    }

    @media(max-width:1080px) {
      .learn-layout {
        grid-template-columns: 1fr;
      }

      .learn-overview {
        position: static;
      }
    }

    @media(max-width:760px) {
      .service-mini-grid {
        grid-template-columns: 1fr;
      }

      .learn-overview h2 {
        font-size: 32px;
      }
    }

    .products { background:#fff; }
    .product-head { display:flex; justify-content:space-between; align-items:center; margin-bottom:28px; }
    .product-head h2 { margin:0; font-size:44px; letter-spacing:-.04em; }
    .product-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:28px; }
    .product-card { background:#EAF2F3; overflow:hidden; min-height:520px; display:flex; flex-direction:column; text-decoration:none; color:inherit; transition:.18s ease; }
    .product-card:hover { transform:translateY(-3px); box-shadow:var(--shadow-soft); }
    .product-img { height:250px; background:linear-gradient(135deg,#133242,#1C6077 55%, #ABC4C8); position:relative; overflow:hidden; }
    .product-img.city:before { content:""; position:absolute; inset:auto 0 0; height:75%; background:repeating-linear-gradient(90deg, rgba(255,255,255,.18) 0 10px, rgba(255,255,255,.05) 10px 14px, transparent 14px 28px); opacity:.55; }
    .product-img.pattern { background:linear-gradient(135deg,#173B4A,#27637B); }
    .product-img.pattern:before { content:""; position:absolute; inset:-20px; background:repeating-linear-gradient(145deg, transparent 0 38px, rgba(255,255,255,.18) 39px 41px), repeating-linear-gradient(45deg, rgba(255,255,255,.08) 0 2px, transparent 2px 10px); }
    .product-img.green { background:radial-gradient(circle at 25% 30%, rgba(255,255,255,.30), transparent 12%), radial-gradient(circle at 70% 24%, rgba(255,255,255,.24), transparent 11%), radial-gradient(circle at 55% 66%, rgba(255,255,255,.23), transparent 13%), linear-gradient(135deg,#082E1C,#0B5D31 60%,#88AB89); }
    .product-body { padding:24px; }
    .product-body small { display:block; text-transform:uppercase; letter-spacing:.14em; font-weight:900; font-size:12px; color:#0A1724; margin-bottom:10px; }
    .product-body h3 { margin:0 0 16px; color:#030712; font-size:26px; line-height:1.18; letter-spacing:-.022em; }
    .product-body p { margin:0; color:#111827; font-size:19px; line-height:1.45; }

    .product-slider { position:relative; overflow:hidden; padding:4px 0 18px; }
    .product-track { display:flex; gap:28px; width:max-content; animation:productSlide 54s linear infinite; }
    .product-slider:hover .product-track { animation-play-state:paused; }
    .product-track .product-card { width:360px; flex:0 0 360px; }
    .slider-controls { display:flex; gap:10px; align-items:center; flex-wrap:wrap; }
    .slider-btn { width:42px; height:42px; border:1px solid var(--line); background:#fff; border-radius:50%; font-size:22px; font-weight:900; color:var(--navy); cursor:pointer; display:grid; place-items:center; }
    .slider-btn:hover { background:var(--soft-green); color:var(--green); }
    @keyframes productSlide { 0% { transform:translateX(0); } 100% { transform:translateX(calc(-1 * (360px + 28px) * 13)); } }
    .service-directory { display:grid; grid-template-columns:repeat(3,1fr); gap:20px; }
    .service-directory .product-card { min-height:430px; border:1px solid var(--line); border-radius:22px; }

    .board-intro { background:linear-gradient(135deg,#F7FCF9,#FFFFFF); border:1px solid #DDEFE5; border-radius:28px; padding:36px; box-shadow:var(--shadow-soft); margin-bottom:30px; position:relative; overflow:hidden; }
    .board-intro:after { content:""; position:absolute; right:-70px; top:-70px; width:220px; height:220px; border-radius:50%; background:rgba(11,122,59,.08); }
    .board-intro h2 { margin:0 0 10px; color:var(--navy); font-size:42px; letter-spacing:-.04em; }
    .board-intro p { margin:0; color:#475467; font-size:18px; max-width:860px; }
    .director-grid { display:grid; grid-template-columns:repeat(4,1fr); gap:22px; }
    .director-card { background:#fff; border:1px solid #E1EFE7; border-radius:24px; overflow:hidden; box-shadow:var(--shadow-soft); transition:.18s ease; }
    .director-card:hover { transform:translateY(-4px); box-shadow:var(--shadow); }
    .director-photo { height:285px; background:#F6F8FA; overflow:hidden; }
    .director-photo img { width:100%; height:100%; object-fit:cover; object-position:center top; display:block; }
    .director-placeholder { height:285px; background:linear-gradient(135deg,#EAF5EF,#FFFFFF); color:var(--green); display:grid; place-items:center; font-size:54px; font-weight:900; }
    .director-body { padding:22px; }
    .director-role { color:var(--green); text-transform:uppercase; letter-spacing:.12em; font-size:12px; font-weight:900; margin-bottom:8px; }
    .director-body h3 { margin:0 0 10px; color:var(--navy); font-size:21px; line-height:1.18; letter-spacing:-.02em; }
    .director-body p { margin:0; color:#667085; font-size:14px; line-height:1.45; }
    .board-note { margin-top:22px; padding:16px 18px; background:var(--soft-green); border:1px solid #CFE9D9; border-radius:18px; color:#075C2D; font-weight:700; }

    .service-detail { display:grid; gap:24px; }
    .service-hero-detail { border:1px solid var(--line); border-radius:28px; overflow:hidden; background:linear-gradient(135deg,#F7FAF8,#fff); box-shadow:var(--shadow-soft); }
    .service-hero-inner { display:grid; grid-template-columns:1fr .62fr; gap:30px; align-items:stretch; }
    .service-copy { padding:42px; }
    .service-copy .eyebrow-dark { display:inline-flex; padding:7px 12px; border-radius:999px; background:var(--soft-green); color:var(--green-dark); font-size:12px; font-weight:900; text-transform:uppercase; letter-spacing:.08em; margin-bottom:18px; }
    .service-copy h2 { color:var(--navy); font-size:46px; line-height:1.04; letter-spacing:-.045em; margin:0 0 16px; }
    .service-copy p { font-size:18px; color:#475467; max-width:720px; }
    .service-visual { min-height:360px; background:radial-gradient(circle at 75% 20%,rgba(11,122,59,.18),transparent 28%),linear-gradient(135deg,#F2F8F4,#EAF5EF); position:relative; overflow:hidden; }
    .service-visual:before { content:""; position:absolute; inset:-30px; opacity:.55; background-image:linear-gradient(120deg, transparent 0 9%, rgba(11,122,59,.22) 9.2% 9.6%, transparent 9.8% 22%), linear-gradient(30deg, transparent 0 15%, rgba(7,21,35,.12) 15.2% 15.4%, transparent 15.6% 34%); background-size:150px 210px; transform:skewX(-14deg); }
    .service-visual.city { background:linear-gradient(135deg,#EEF7F2,#DDEDE8); }
    .service-visual.pattern { background:linear-gradient(135deg,#F8FAFC,#EAF5EF); }
    .service-visual.green { background:radial-gradient(circle at 25% 30%,rgba(255,255,255,.70),transparent 13%),radial-gradient(circle at 70% 24%,rgba(255,255,255,.58),transparent 12%),linear-gradient(135deg,#EAF5EF,#CFE8D8); }
    .service-quote { position:absolute; left:28px; right:28px; bottom:28px; padding:22px; background:rgba(255,255,255,.86); backdrop-filter:blur(10px); border:1px solid rgba(11,122,59,.16); border-radius:22px; color:var(--green-dark); font-weight:900; font-size:21px; line-height:1.25; box-shadow:var(--shadow-soft); }
    .service-actions { display:flex; gap:12px; flex-wrap:wrap; margin-top:26px; }
    .service-section-grid { display:grid; grid-template-columns:1fr 1fr; gap:22px; }
    .fresh-card { border:1px solid var(--line); border-radius:24px; background:#fff; padding:28px; box-shadow:0 10px 24px rgba(7,21,35,.04); }
    .fresh-card h3 { margin:0 0 14px; color:var(--navy); font-size:28px; letter-spacing:-.03em; }
    .fresh-card p { color:#475467; font-size:17px; }
    .fresh-card ul { margin:0; padding-left:20px; color:#475467; }
    .fresh-card li { margin:10px 0; }
    .benefit-grid { display:grid; grid-template-columns:repeat(4,1fr); gap:14px; }
    .benefit-card { background:#F8FBF9; border:1px solid #DDEFE4; border-radius:18px; padding:18px; color:#263548; font-weight:800; min-height:112px; }
    .benefit-card:before { content:"✓"; display:inline-grid; place-items:center; width:26px; height:26px; border-radius:50%; background:var(--soft-green); color:var(--green); margin-bottom:12px; font-weight:900; }
    .approach-steps { display:grid; grid-template-columns:repeat(4,1fr); gap:14px; counter-reset:step; }
    .step-card { border:1px solid var(--line); border-radius:20px; padding:20px; background:#fff; position:relative; }
    .step-card:before { counter-increment:step; content:"0" counter(step); display:block; color:var(--green); font-weight:900; letter-spacing:.06em; margin-bottom:12px; }
    .step-card b { display:block; color:var(--navy); font-size:18px; margin-bottom:6px; }
    .step-card span { color:#667085; font-size:14px; }
    .case-card { background:linear-gradient(135deg,#075C2D,#0B7A3B); color:#fff; border-radius:26px; padding:34px; display:grid; grid-template-columns:1fr auto; gap:24px; align-items:center; }
    .case-card h3 { margin:0 0 10px; font-size:30px; letter-spacing:-.03em; }
    .case-card p { margin:0; color:#EAF5EF; font-size:17px; }
    .case-badge { width:96px; height:96px; border-radius:50%; display:grid; place-items:center; background:rgba(255,255,255,.16); border:1px solid rgba(255,255,255,.22); font-size:34px; }
    .deliverables { display:flex; flex-wrap:wrap; gap:10px; }
    .deliverables span { padding:9px 13px; border-radius:999px; background:#F8FAFC; border:1px solid var(--line); color:#334155; font-weight:800; font-size:13px; }
    .service-mini-nav { display:flex; flex-wrap:wrap; gap:8px; margin-top:16px; }
    .service-mini-nav a { text-decoration:none; padding:8px 11px; border-radius:999px; background:#F8FAFC; border:1px solid var(--line); color:#334155; font-size:12px; font-weight:900; }
    .service-mini-nav a:hover { background:var(--soft-green); color:var(--green-dark); }

    /* Redesigned Inside Credit and Contact sections */
    .inside-credit {
      background: linear-gradient(135deg,#F7FCF9 0%,#FFFFFF 100%);
      color: var(--ink);
      padding: 88px 0;
      border-top: 1px solid #E4EFE8;
      border-bottom: 1px solid #E4EFE8;
      text-align: left;
      overflow: hidden;
      position: relative;
    }

    .inside-credit::before {
      content: "";
      position: absolute;
      right: -120px;
      top: -120px;
      width: 330px;
      height: 330px;
      border-radius: 50%;
      background: rgba(11,122,59,.08);
    }

    .inside-credit::after {
      content: "";
      position: absolute;
      left: -90px;
      bottom: -110px;
      width: 260px;
      height: 260px;
      border-radius: 50%;
      background: rgba(31,120,166,.07);
    }

    .inside-credit-grid {
      position: relative;
      z-index: 1;
      display: grid;
      grid-template-columns: .9fr 1.1fr;
      gap: 34px;
      align-items: center;
    }

    .inside-credit-main {
      background: #fff;
      border: 1px solid #DDEFE5;
      border-radius: 30px;
      padding: 38px;
      box-shadow: 0 18px 45px rgba(7,21,35,.07);
    }

    .inside-credit-main h2 {
      margin: 14px 0 16px;
      color: var(--navy);
      font-size: 46px;
      line-height: 1.05;
      letter-spacing: -.045em;
    }

    .inside-credit-main h2::after {
      content: "";
      display: block;
      width: 72px;
      height: 4px;
      margin-top: 14px;
      border-radius: 999px;
      background: var(--green);
    }

    .inside-credit-main p {
      margin: 0 0 24px;
      max-width: 640px;
      color: #475467;
      font-size: 17px;
      line-height: 1.7;
    }

    .inside-credit-tags {
      display: flex;
      flex-wrap: wrap;
      gap: 10px;
      margin-bottom: 28px;
    }

    .inside-credit-tags span {
      background: #F2FBF6;
      color: var(--green-dark);
      border: 1px solid #DDEFE5;
      border-radius: 999px;
      padding: 8px 12px;
      font-size: 13px;
      font-weight: 900;
    }

    .inside-credit-main .btn {
      background: var(--green);
      color: #fff;
      border-radius: 999px;
      padding: 14px 22px;
      text-transform: none;
      letter-spacing: 0;
    }

    .inside-credit-main .btn:hover {
      background: var(--green-dark);
      color: #fff;
    }

    .inside-credit-cards {
      display: grid;
      grid-template-columns: 1fr 1fr;
      gap: 18px;
    }

    .insight-mini-card {
      background: #fff;
      border: 1px solid #E3EFE8;
      border-radius: 24px;
      padding: 24px;
      min-height: 188px;
      box-shadow: 0 12px 28px rgba(7,21,35,.05);
      transition: transform .22s ease, box-shadow .22s ease, border-color .22s ease;
    }

    .insight-mini-card:hover {
      transform: translateY(-6px);
      border-color: rgba(11,122,59,.45);
      box-shadow: 0 20px 44px rgba(11,122,59,.12);
    }

    .insight-mini-card small {
      display: block;
      color: var(--green);
      font-weight: 900;
      letter-spacing: .12em;
      text-transform: uppercase;
      font-size: 11px;
      margin-bottom: 12px;
    }

    .insight-mini-card h3 {
      margin: 0 0 10px;
      color: var(--navy);
      font-size: 22px;
      line-height: 1.18;
      letter-spacing: -.025em;
    }

    .insight-mini-card p {
      margin: 0;
      color: #667085;
      font-size: 14.5px;
      line-height: 1.55;
    }

    .contact-cta {
      background: #FFFFFF;
      color: var(--ink);
      padding: 88px 0;
      position: relative;
      overflow: hidden;
    }

    .contact-cta::before {
      content: "";
      position: absolute;
      inset: 0;
      background:
        radial-gradient(circle at 82% 18%,rgba(11,122,59,.10),transparent 28%),
        linear-gradient(135deg,#FFFFFF 0%,#F7FCF9 58%,#EAF5EF 100%);
    }

    .contact-panel {
      position: relative;
      z-index: 1;
      display: grid;
      grid-template-columns: .95fr 1.05fr;
      gap: 28px;
      align-items: stretch;
    }

    .contact-copy {
      background: linear-gradient(135deg,#075C2D 0%,#0B7A3B 66%,#0F9A50 100%);
      color: #fff;
      border-radius: 32px;
      padding: 46px;
      box-shadow: 0 22px 52px rgba(11,122,59,.22);
      min-height: 390px;
      display: flex;
      flex-direction: column;
      justify-content: center;
      position: relative;
      overflow: hidden;
    }

    .contact-copy::after {
      content: "";
      position: absolute;
      right: -90px;
      bottom: -100px;
      width: 260px;
      height: 260px;
      border-radius: 50%;
      background: rgba(255,255,255,.12);
    }

    .contact-copy .kicker {
      color: #FFFFFF;
      font-size: 13px;
      letter-spacing: .22em;
      text-transform: uppercase;
      font-weight: 900;
      margin-bottom: 18px;
    }

    .contact-copy h2 {
      font-size: 54px;
      font-weight: 700;
      line-height: 1.05;
      margin: 0 0 22px;
      letter-spacing: -.045em;
      max-width: 620px;
    }

    .contact-copy p {
      font-size: 18px;
      color: #ECFFF4;
      margin: 0 0 30px;
      max-width: 680px;
      line-height: 1.65;
    }

    .contact-copy .btn {
      align-self: flex-start;
      background: #fff;
      color: var(--green-dark);
      padding: 15px 24px;
      font-size: 15px;
      border-radius: 999px;
      box-shadow: 0 12px 28px rgba(0,0,0,.10);
    }

    .contact-copy .btn:hover {
      background: #F3FBF6;
      color: var(--green-dark);
    }

    .contact-actions {
      display: grid;
      grid-template-columns: 1fr 1fr;
      gap: 18px;
    }

    .contact-action-card {
      background: #fff;
      border: 1px solid #E3EFE8;
      border-radius: 26px;
      padding: 24px;
      box-shadow: 0 12px 28px rgba(7,21,35,.05);
      transition: transform .22s ease, box-shadow .22s ease, border-color .22s ease;
    }

    .contact-action-card:hover {
      transform: translateY(-6px);
      border-color: rgba(11,122,59,.45);
      box-shadow: 0 20px 44px rgba(11,122,59,.12);
    }

    .contact-action-icon {
      width: 52px;
      height: 52px;
      border-radius: 18px;
      background: #EAF5EF;
      color: var(--green);
      display: grid;
      place-items: center;
      font-size: 22px;
      font-weight: 900;
      margin-bottom: 18px;
    }

    .contact-action-card h3 {
      margin: 0 0 10px;
      color: var(--navy);
      font-size: 22px;
      line-height: 1.18;
    }

    .contact-action-card p {
      margin: 0 0 16px;
      color: #667085;
      font-size: 14.5px;
      line-height: 1.55;
    }

    .contact-action-card a {
      color: var(--green);
      text-decoration: none;
      font-weight: 900;
      font-size: 14px;
    }

    .contact-action-card a:hover {
      text-decoration: underline;
    }

    @media(max-width:1080px) {
      .inside-credit-grid,
      .contact-panel {
        grid-template-columns: 1fr;
      }
    }

    @media(max-width:760px) {
      .inside-credit-cards,
      .contact-actions {
        grid-template-columns: 1fr;
      }

      .inside-credit-main,
      .contact-copy {
        padding: 30px;
      }

      .inside-credit-main h2,
      .contact-copy h2 {
        font-size: 36px;
      }
    }

    .page-view { display:none; padding:70px 0 90px; background:#fff; }
    .page-view.active { display:block; }
    .page-hero { background:linear-gradient(135deg,#F6F8FA,#FFFFFF); border-bottom:1px solid var(--line); padding:70px 0; }
    .breadcrumb { color:#667085; font-weight:800; font-size:13px; margin-bottom:18px; }
    .page-hero h1 { color:var(--navy); font-size:56px; max-width:900px; }
    .page-hero p { color:#475467; font-size:20px; max-width:760px; margin:20px 0 0; }
    .content-grid { display:grid; grid-template-columns:.75fr 1.25fr; gap:40px; align-items:start; }
    .side-card { border:1px solid var(--line); border-radius:22px; padding:24px; background:#fff; box-shadow:var(--shadow-soft); position:sticky; top:120px; }
    .side-card h3 { margin:0 0 14px; color:var(--navy); }
    .side-card a { display:block; padding:11px 0; color:#334155; text-decoration:none; border-bottom:1px solid #F0F2F5; font-weight:800; }
    .side-card a:hover { color:var(--green); }
    .body-card { border:1px solid var(--line); border-radius:22px; padding:28px; margin-bottom:20px; background:#fff; }
    .body-card h2 { margin:0 0 12px; color:var(--navy); font-size:32px; letter-spacing:-.03em; }
    .body-card p { color:#475467; margin:0 0 18px; font-size:17px; }
    .body-card ul { color:#475467; margin:0; padding-left:22px; }
    .body-card li { margin:8px 0; }
    .table-card { border:1px solid var(--line); border-radius:22px; overflow:hidden; margin:18px 0; }
    table { width:100%; border-collapse:collapse; font-size:14px; }
    th,td { padding:14px 16px; text-align:left; border-bottom:1px solid var(--line); vertical-align:top; }
    th { background:#F8FAFC; color:#667085; text-transform:uppercase; letter-spacing:.05em; font-size:12px; }
    td b { color:var(--navy); }
    .chips { display:flex; flex-wrap:wrap; gap:10px; margin:18px 0; }
    .chip { border:1px solid var(--line); background:#fff; color:#344054; border-radius:999px; padding:8px 12px; font-weight:800; font-size:13px; }
    .form { display:grid; gap:14px; }
    .form input, .form textarea, .form select { width:100%; border:1px solid #D0D5DD; border-radius:14px; padding:13px 14px; font-size:15px; outline-color:var(--green); font-family:inherit; }
    .form textarea { min-height:120px; resize:vertical; }
    .notice { display:none; margin-top:12px; border:1px solid rgba(11,122,59,.25); background:var(--soft-green); color:var(--green-dark); padding:12px 14px; border-radius:14px; font-weight:800; }
    .notice.show { display:block; }

    footer { background:#030406; color:#D0D7DE; padding:46px 0 26px; }
    .footer-grid { display:grid; grid-template-columns:1.2fr repeat(3,1fr) 1.45fr; gap:28px; }
    footer h4 { color:#fff; margin:0 0 14px; }
    footer p { color:#AAB6C2; margin:0; }
    footer a { color:#D0D7DE; text-decoration:none; display:block; margin:8px 0; font-size:14px; }
    footer a:hover { color:#fff; }
    .footer-bottom { display:flex; justify-content:space-between; gap:20px; flex-wrap:wrap; border-top:1px solid rgba(255,255,255,.12); margin-top:28px; padding-top:20px; font-size:14px; color:#fff; }
    .disclaimer { color:#9AA8B6; font-size:13px; margin-top:14px; max-width:980px; }

    .modal-backdrop { position:fixed; inset:0; background:rgba(3,4,6,.65); display:none; align-items:center; justify-content:center; padding:24px; z-index:100; }
    .modal-backdrop.show { display:flex; }
    .modal { width:min(620px,100%); background:#fff; color:var(--ink); border-radius:24px; box-shadow:0 26px 70px rgba(0,0,0,.35); padding:28px; max-height:90vh; overflow:auto; }
    .modal-head { display:flex; justify-content:space-between; align-items:flex-start; gap:20px; margin-bottom:18px; }
    .modal h2 { margin:0; color:var(--navy); letter-spacing:-.03em; }
    .close { border:0; background:#F1F5F9; border-radius:50%; width:38px; height:38px; cursor:pointer; font-size:20px; }
    .mobile-panel { display:none; position:fixed; inset:0; background:#fff; z-index:90; padding:20px; overflow:auto; }
    .mobile-panel.show { display:block; }
    .mobile-panel a { display:block; padding:15px 0; border-bottom:1px solid var(--line); text-decoration:none; font-weight:900; color:var(--navy); }
    .mobile-close { float:right; border:0; background:#F1F5F9; border-radius:999px; padding:10px 14px; font-weight:900; }

    @media(max-width:1040px) {
      .main-menu, .nav-actions .contact-btn, .nav-actions .icon-btn { display:none; }
      .menu-toggle { display:grid; place-items:center; width:44px; height:44px; border:0; border-radius:50%; background:#F1F5F9; color:var(--navy); cursor:pointer; }
      .nav { height:80px; }
      .brand-title { font-size:21px; }
      .hero { margin-top:-80px; padding-top:112px; }
      .hero-grid,.insight-grid,.approach-wrap,.learn-grid,.content-grid { grid-template-columns:1fr; }
      .quick-search { margin-bottom:0; }
      .product-grid { grid-template-columns:1fr; }
      .footer-grid { grid-template-columns:1fr 1fr; }
      h1,.page-hero h1 { font-size:44px; }
      .contact-cta h2 { font-size:52px; }
    }
    @media(max-width:640px) {
      .top-strip .wrap { justify-content:center; }
      .brand { min-width:0; }
      .brand-logo { width:68px; height:48px; }
      .brand-title { font-size:18px; }
      .brand-sub { display:none; }
      .hero-grid { padding:52px 0 48px; min-height:auto; }
      h1,.page-hero h1 { font-size:36px; }
      .lead { font-size:17px; }
      section { padding:54px 0; }
      .insights { padding-top:64px; }
      .section-title,.product-head { display:block; }
      .slider-controls { margin-top:16px; }
      .learn-cards { grid-template-columns:1fr; gap:28px; }
      .learn-card { grid-template-columns:54px 1fr; }
      .approach-card { padding:34px 26px; }
      .approach-card h3 { font-size:34px; }
      .approach-card p,.learn-intro p,.learn-card p,.product-body p { font-size:17px; }
      .featured-insight h3 { font-size:34px; }
      .product-img { height:190px; }
      .inside-credit h2 { font-size:38px; }
      .contact-cta h2 { font-size:40px; }
      .footer-grid { grid-template-columns:1fr; }
      .director-grid { grid-template-columns:1fr; }
      .mini-tabs { grid-template-columns:1fr; }

      .service-directory { grid-template-columns:1fr; }
      .director-grid { grid-template-columns:repeat(2,1fr); }
      .product-track .product-card { width:300px; flex-basis:300px; }
      @keyframes productSlide { 0% { transform:translateX(0); } 100% { transform:translateX(calc(-1 * (300px + 28px) * 13)); } }
      .service-hero-inner,.service-section-grid,.benefit-grid,.approach-steps,.case-card { grid-template-columns:1fr; }
      .service-copy { padding:28px; }
      .service-copy h2 { font-size:34px; }
      .service-visual { min-height:260px; }
    }
  
    
    .site-header.is-light .menu-link:hover {
      color: var(--green) !important;
    }

    /* Green hover refinements */
    .menu-link:hover,
    .mega a:hover,
    footer a:hover,
    .side a:hover,
    .link-red:hover {
      color: var(--green) !important;
    }

    .btn.blue:hover,
    .btn.primary:hover,
    .contact-btn:hover,
    .slider-btn:hover {
      background: var(--green) !important;
      border-color: var(--green) !important;
      color: #fff !important;
      transform: translateY(-2px);
      box-shadow: 0 12px 28px rgba(11,122,59,.18);
    }

    .product-card,
    .director-card {
      transition: transform .22s ease, box-shadow .22s ease, border-color .22s ease, background .22s ease;
    }

    .product-card:hover,
    .director-card:hover {
      transform: translateY(-8px);
      border-color: rgba(11,122,59,.45) !important;
      box-shadow: 0 22px 48px rgba(11,122,59,.18) !important;
      background: linear-gradient(180deg,#FFFFFF 0%,#F2FBF6 100%) !important;
    }

    .product-card:hover .product-body h3,
    .director-card:hover h3 {
      color: var(--green) !important;
    }

    .director-card:hover .director-role {
      background: var(--green) !important;
      color: #fff !important;
    }

  
    /* Green-focused text highlighting */
    ::selection {
      background: #0B7A3B;
      color: #FFFFFF;
    }

    ::-moz-selection {
      background: #0B7A3B;
      color: #FFFFFF;
    }

    .eyebrow,
    .kicker,
    .label strong,
    .brand-title,
    .section-accent,
    .green-focus,
    .product-body small,
    .body-card h2,
    .learn-card h3:hover,
    .insight-item:hover h3,
    .page-hero h1,
    .side h3,
    .modal h2 {
      color: var(--green) !important;
    }

    .feature .kicker,
    .approach-card .kicker,
    .cta .kicker {
      color: #DFF8E9 !important;
    }

    .body-card h2,
    .page-hero h1 {
      position: relative;
    }

    .body-card h2::after,
    .page-hero h1::after {
      content: "";
      display: block;
      width: 72px;
      height: 4px;
      margin-top: 12px;
      border-radius: 999px;
      background: var(--green);
    }

    .link-red,
    .tag,
    .director-role {
      color: var(--green) !important;
    }

    mark,
    .highlight {
      background: var(--greenSoft);
      color: var(--green-dark);
      border-radius: 8px;
      padding: 0 .28em;
      font-weight: 800;
    }

    input:focus,
    textarea:focus,
    select:focus {
      outline: 3px solid rgba(11,122,59,.16) !important;
      border-color: var(--green) !important;
      box-shadow: 0 0 0 4px rgba(11,122,59,.08);
    }

  
    /* White text on green selection/hover */
    .mega a:hover,
    .side a:hover,
    footer a:hover {
      background: var(--green) !important;
      color: #fff !important;
      padding-left: 10px;
      border-radius: 10px;
    }

    .menu-link:hover {
      background: var(--green) !important;
      color: #fff !important;
      border-radius: 999px;
    }

  
    /* Fix: menu hover is text-green only, while text selection remains green with white letters */
    .menu-link:hover,
    .site-header.is-light .menu-link:hover {
      background: transparent !important;
      color: var(--green) !important;
      border-radius: 0 !important;
      box-shadow: none !important;
    }

    .mega a:hover,
    .side a:hover,
    footer a:hover {
      background: transparent !important;
      color: var(--green) !important;
      padding-left: 0 !important;
      border-radius: 0 !important;
      box-shadow: none !important;
    }

    ::selection {
      background: #0B7A3B !important;
      color: #FFFFFF !important;
    }

    ::-moz-selection {
      background: #0B7A3B !important;
      color: #FFFFFF !important;
    }

  
    /* Rating Services detail layout */
    .rating-service-wrap {
      display: grid;
      gap: 22px;
    }

    .rating-service-hero {
      background: linear-gradient(135deg,#F4FBF7 0%,#FFFFFF 72%);
      border: 1px solid #DDEFE5;
      border-radius: 28px;
      padding: 34px;
      box-shadow: 0 14px 34px rgba(7,21,35,.06);
    }

    .rating-service-hero h2 {
      margin: 0 0 14px;
      color: var(--navy);
      font-size: 42px;
      line-height: 1.08;
      letter-spacing: -.035em;
    }

    .rating-service-hero p {
      margin: 0;
      max-width: 880px;
      color: #475467;
      font-size: 18px;
    }

    .rating-service-grid {
      display: grid;
      grid-template-columns: repeat(auto-fit,minmax(260px,1fr));
      gap: 18px;
    }

    .rating-service-card {
      background: #fff;
      border: 1px solid #E3EFE8;
      border-radius: 24px;
      padding: 22px;
      box-shadow: 0 12px 28px rgba(7,21,35,.06);
      transition: transform .22s ease, box-shadow .22s ease, border-color .22s ease;
    }

    .rating-service-card:hover {
      transform: translateY(-6px);
      border-color: rgba(11,122,59,.45);
      box-shadow: 0 20px 44px rgba(11,122,59,.14);
    }

    .rating-service-no {
      display: inline-grid;
      place-items: center;
      width: 42px;
      height: 42px;
      border-radius: 14px;
      background: var(--green);
      color: #fff;
      font-weight: 900;
      margin-bottom: 16px;
    }

    .rating-service-card h3 {
      margin: 0 0 10px;
      color: var(--navy);
      font-size: 22px;
      line-height: 1.18;
    }

    .rating-service-card:hover h3 {
      color: var(--green);
    }

    .rating-service-card p {
      margin: 0;
      color: #667085;
      font-size: 15px;
    }

    .rating-service-note {
      border-left: 5px solid var(--green);
      background: #F4FBF7;
      border-radius: 18px;
      padding: 22px 24px;
      color: #344054;
    }

  
    /* Rating process page */
    .process-page-wrap {
      display: grid;
      gap: 24px;
    }

    .process-intro-card {
      background: linear-gradient(135deg,#F4FBF7 0%,#FFFFFF 72%);
      border: 1px solid #DDEFE5;
      border-radius: 28px;
      padding: 34px;
      box-shadow: 0 14px 34px rgba(7,21,35,.06);
    }

    .process-intro-card h2 {
      margin: 0 0 14px;
      color: var(--navy);
      font-size: 42px;
      line-height: 1.08;
      letter-spacing: -.035em;
    }

    .process-intro-card p {
      margin: 0;
      color: #475467;
      font-size: 17px;
      max-width: 920px;
    }

    .process-steps {
      display: grid;
      gap: 16px;
      counter-reset: ratingProcess;
    }

    .process-step-card {
      display: grid;
      grid-template-columns: 78px 1fr;
      gap: 20px;
      align-items: start;
      background: #fff;
      border: 1px solid #E3EFE8;
      border-radius: 24px;
      padding: 22px;
      box-shadow: 0 12px 28px rgba(7,21,35,.06);
      transition: transform .22s ease, border-color .22s ease, box-shadow .22s ease;
    }

    .process-step-card:hover {
      transform: translateY(-5px);
      border-color: rgba(11,122,59,.45);
      box-shadow: 0 20px 44px rgba(11,122,59,.14);
    }

    .process-step-no {
      display: grid;
      place-items: center;
      width: 58px;
      height: 58px;
      border-radius: 18px;
      background: var(--green);
      color: #fff;
      font-weight: 900;
      font-size: 18px;
    }

    .process-step-content h3 {
      margin: 0 0 8px;
      color: var(--navy);
      font-size: 23px;
      line-height: 1.18;
    }

    .process-step-card:hover h3 {
      color: var(--green);
    }

    .process-step-content p {
      margin: 0;
      color: #667085;
      font-size: 15.5px;
    }

    .process-note {
      border-left: 5px solid var(--green);
      background: #F4FBF7;
      border-radius: 18px;
      padding: 22px 24px;
      color: #344054;
    }

    @media(max-width:640px) {
      .process-step-card { grid-template-columns: 1fr; }
    }

  
    /* Website flowchart for rating process */
    .process-flow-wrap {
      display: grid;
      gap: 24px;
    }

    .process-flow-intro {
      background: linear-gradient(135deg,#F4FBF7 0%,#FFFFFF 72%);
      border: 1px solid #DDEFE5;
      border-radius: 28px;
      padding: 34px;
      box-shadow: 0 14px 34px rgba(7,21,35,.06);
    }

    .process-flow-intro h2 {
      margin: 0 0 14px;
      color: var(--navy);
      font-size: 42px;
      line-height: 1.08;
      letter-spacing: -.035em;
    }

    .process-flow-intro p {
      margin: 0;
      color: #475467;
      font-size: 17px;
      max-width: 920px;
    }

    .process-flowchart {
      background: #F8FAFC;
      border: 1px solid #DDE3EA;
      border-radius: 28px;
      padding: 28px 22px 28px;
      box-shadow: 0 14px 34px rgba(7,21,35,.05);
    }

    .flowchart-title {
      display: inline-flex;
      align-items: center;
      justify-content: center;
      padding: 12px 24px;
      border-radius: 999px;
      background: var(--green);
      color: #fff;
      font-weight: 900;
      font-size: 20px;
      margin: 0 auto 24px;
    }

    .flowchart-title-wrap {
      text-align: center;
    }

    .flow-columns {
      display: grid;
      grid-template-columns: 1fr 1.25fr 1fr;
      gap: 22px;
      align-items: start;
    }

    .flow-col-head {
      text-align: center;
      padding: 10px 14px;
      border: 1px solid #8FB0C7;
      background: #fff;
      color: #1D2939;
      font-weight: 800;
      border-radius: 10px;
      margin-bottom: 12px;
      min-height: 48px;
      display: grid;
      place-items: center;
    }

    .flow-stack {
      display: grid;
      gap: 8px;
    }

    .flow-node {
      background: #fff;
      border: 1px solid #8FB0C7;
      border-radius: 8px;
      padding: 10px 12px;
      font-size: 14px;
      line-height: 1.35;
      color: #344054;
      text-align: center;
      box-shadow: 0 8px 18px rgba(7,21,35,.04);
    }

    .flow-node strong {
      color: var(--navy);
    }

    .flow-arrow {
      text-align: center;
      color: #2B6D99;
      font-size: 24px;
      line-height: 1;
      margin: 1px 0;
      font-weight: 700;
    }

    .flow-node:hover {
      border-color: rgba(11,122,59,.55);
      box-shadow: 0 14px 28px rgba(11,122,59,.10);
    }

    .decision-zone {
      display: grid;
      grid-template-columns: 260px 1fr;
      gap: 22px;
      align-items: center;
      margin-top: 20px;
    }

    .decision-wrap {
      display: grid;
      justify-items: center;
      gap: 10px;
    }

    .decision-label {
      font-size: 12px;
      letter-spacing: .14em;
      text-transform: uppercase;
      color: var(--green);
      font-weight: 900;
    }

    .decision-diamond {
      width: 146px;
      height: 146px;
      transform: rotate(45deg);
      border: 1px solid #8FB0C7;
      background: #fff;
      display: grid;
      place-items: center;
      box-shadow: 0 8px 18px rgba(7,21,35,.04);
    }

    .decision-diamond span {
      transform: rotate(-45deg);
      display: block;
      width: 84px;
      text-align: center;
      color: #1D2939;
      font-weight: 800;
      line-height: 1.18;
      font-size: 16px;
    }

    .decision-paths {
      display: grid;
      grid-template-columns: 1fr 1fr;
      gap: 18px;
      align-items: start;
    }

    .path-card {
      background: #fff;
      border: 1px solid #8FB0C7;
      border-radius: 16px;
      padding: 16px 18px;
      min-height: 124px;
    }

    .path-card .path-tag {
      display: inline-block;
      padding: 5px 10px;
      border-radius: 999px;
      background: #EAF5EF;
      color: var(--green);
      font-size: 12px;
      font-weight: 900;
      letter-spacing: .1em;
      text-transform: uppercase;
      margin-bottom: 10px;
    }

    .path-card h4 {
      margin: 0 0 8px;
      color: var(--navy);
      font-size: 18px;
      line-height: 1.2;
    }

    .path-card p {
      margin: 0;
      color: #667085;
      font-size: 14px;
      line-height: 1.4;
    }

    .process-flow-note {
      border-left: 5px solid var(--green);
      background: #F4FBF7;
      border-radius: 18px;
      padding: 22px 24px;
      color: #344054;
    }

    @media(max-width:980px) {
      .flow-columns,
      .decision-zone,
      .decision-paths {
        grid-template-columns: 1fr;
      }
      .decision-wrap {
        margin-bottom: 14px;
      }
    }

  
    /* Rating methodology library */
    .methodology-wrap {
      display: grid;
      gap: 24px;
    }

    .methodology-hero {
      background: linear-gradient(135deg,#F4FBF7 0%,#FFFFFF 72%);
      border: 1px solid #DDEFE5;
      border-radius: 28px;
      padding: 34px;
      box-shadow: 0 14px 34px rgba(7,21,35,.06);
    }

    .methodology-hero h2 {
      margin: 0 0 14px;
      color: var(--navy);
      font-size: 42px;
      line-height: 1.08;
      letter-spacing: -.035em;
    }

    .methodology-hero p {
      margin: 0;
      color: #475467;
      font-size: 17px;
      max-width: 920px;
    }

    .methodology-grid {
      display: grid;
      grid-template-columns: repeat(auto-fit,minmax(260px,1fr));
      gap: 18px;
    }

    .methodology-card {
      background: #fff;
      border: 1px solid #E3EFE8;
      border-radius: 24px;
      padding: 22px;
      box-shadow: 0 12px 28px rgba(7,21,35,.06);
      transition: transform .22s ease, border-color .22s ease, box-shadow .22s ease;
    }

    .methodology-card:hover {
      transform: translateY(-6px);
      border-color: rgba(11,122,59,.45);
      box-shadow: 0 20px 44px rgba(11,122,59,.14);
    }

    .methodology-code {
      display: inline-flex;
      align-items: center;
      justify-content: center;
      min-width: 44px;
      height: 36px;
      padding: 0 12px;
      border-radius: 999px;
      background: var(--green);
      color: #fff;
      font-weight: 900;
      font-size: 13px;
      margin-bottom: 16px;
    }

    .methodology-card h3 {
      margin: 0 0 10px;
      color: var(--navy);
      font-size: 22px;
      line-height: 1.18;
    }

    .methodology-card:hover h3 {
      color: var(--green);
    }

    .methodology-card p {
      margin: 0 0 16px;
      color: #667085;
      font-size: 15px;
      line-height: 1.45;
    }

    .methodology-card .btn {
      padding: 10px 14px;
      font-size: 13px;
    }

    .methodology-note {
      border-left: 5px solid var(--green);
      background: #F4FBF7;
      border-radius: 18px;
      padding: 22px 24px;
      color: #344054;
    }

  
    /* Rating symbol tables */
    .symbol-wrap {
      display: grid;
      gap: 24px;
    }

    .symbol-hero {
      background: linear-gradient(135deg,#F4FBF7 0%,#FFFFFF 72%);
      border: 1px solid #DDEFE5;
      border-radius: 28px;
      padding: 34px;
      box-shadow: 0 14px 34px rgba(7,21,35,.06);
    }

    .symbol-hero h2 {
      margin: 0 0 14px;
      color: var(--navy);
      font-size: 42px;
      line-height: 1.08;
      letter-spacing: -.035em;
    }

    .symbol-hero p {
      margin: 0;
      color: #475467;
      font-size: 17px;
      max-width: 920px;
    }

    .symbol-section {
      background: #fff;
      border: 1px solid #E3EFE8;
      border-radius: 24px;
      box-shadow: 0 12px 28px rgba(7,21,35,.06);
      overflow: hidden;
    }

    .symbol-head {
      background: linear-gradient(135deg,#F4FBF7 0%,#FFFFFF 78%);
      color: var(--navy);
      font-weight: 900;
      letter-spacing: -.02em;
      padding: 22px 24px 14px;
      font-size: 25px;
      border-bottom: 1px solid #E3EFE8;
      position: relative;
    }

    .symbol-head::after {
      content: "";
      display: block;
      width: 72px;
      height: 4px;
      margin-top: 12px;
      border-radius: 999px;
      background: var(--green);
    }

    .symbol-subhead {
      background: #FFFFFF;
      color: var(--green);
      font-weight: 900;
      padding: 18px 24px 10px;
      font-size: 17px;
      border-top: 0;
      letter-spacing: -.01em;
    }

    .symbol-subhead::before {
      content: "";
      display: inline-block;
      width: 10px;
      height: 10px;
      border-radius: 999px;
      background: var(--green);
      margin-right: 10px;
      vertical-align: 1px;
    }

    .symbol-table {
      width: 100%;
      border-collapse: collapse;
    }

    .symbol-table th,
    .symbol-table td {
      border-bottom: 1px solid #E7ECEF;
      padding: 12px 16px;
      text-align: left;
      vertical-align: top;
      font-size: 14px;
    }

    .symbol-table th {
      background: #F8FCFA;
      color: #344054;
      font-size: 12px;
      text-transform: uppercase;
      letter-spacing: .08em;
      border-bottom: 1px solid #E3EFE8;
    }

    .symbol-table td:first-child {
      width: 140px;
      font-weight: 900;
      color: var(--navy);
      white-space: nowrap;
    }

    .symbol-table tr:hover td {
      background: #F7FCF9;
    }

    .symbol-note {
      border-left: 5px solid var(--green);
      background: #F4FBF7;
      border-radius: 18px;
      padding: 22px 24px;
      color: #344054;
    }

  
    /* Refined WCRCL services learning section */
    .learn-intro h2 {
      color: var(--navy);
    }

    .learn-intro h2::after {
      content: "";
      display: block;
      width: 72px;
      height: 4px;
      margin-top: 14px;
      border-radius: 999px;
      background: var(--green);
    }

    .learn-card .line-icon {
      color: var(--green);
      font-weight: 900;
      font-size: 24px;
    }

    .learn-card h3 {
      color: var(--navy);
    }

    .learn-card:hover h3 {
      color: var(--green);
    }

  
    /* Board of Directors final layout - spacious actual section */
    .director-grid {
      display: grid !important;
      grid-template-columns: 1fr !important;
      gap: 26px !important;
      align-items: stretch !important;
    }

    .director-card {
      display: grid !important;
      grid-template-columns: 300px 1fr !important;
      min-height: 300px !important;
      border-radius: 28px !important;
      overflow: hidden !important;
      background: #fff !important;
      border: 1px solid #E1EFE7 !important;
      box-shadow: 0 14px 34px rgba(7,21,35,.07) !important;
    }

    .director-photo,
    .director-placeholder {
      height: 100% !important;
      min-height: 300px !important;
    }

    .director-photo img {
      height: 100% !important;
      object-fit: cover !important;
      object-position: center top !important;
    }

    .director-body {
      display: flex !important;
      flex-direction: column !important;
      justify-content: center !important;
      padding: 34px 40px !important;
    }

    .director-role {
      align-self: flex-start !important;
      background: #EAF5EF !important;
      color: var(--green) !important;
      border-radius: 999px !important;
      padding: 7px 13px !important;
      margin-bottom: 14px !important;
      font-size: 12px !important;
      letter-spacing: .12em !important;
    }

    .director-card h3 {
      font-size: 28px !important;
      line-height: 1.15 !important;
      margin: 0 0 12px !important;
      color: var(--navy) !important;
    }

    .director-card p {
      max-width: 760px !important;
      font-size: 16px !important;
      line-height: 1.55 !important;
      color: #667085 !important;
      margin: 0 !important;
    }

    .director-card:hover {
      transform: translateY(-5px) !important;
      border-color: rgba(11,122,59,.45) !important;
      box-shadow: 0 22px 48px rgba(11,122,59,.14) !important;
    }

    .director-card:hover h3 {
      color: var(--green) !important;
    }

    .director-card:hover .director-role {
      background: var(--green) !important;
      color: #fff !important;
    }

    @media(max-width:860px) {
      .director-card {
        grid-template-columns: 1fr !important;
      }

      .director-photo,
      .director-placeholder {
        min-height: 320px !important;
        height: 320px !important;
      }

      .director-body {
        padding: 26px !important;
      }

      .director-card h3 {
        font-size: 24px !important;
      }
    }

  
    /* Who We Are professional content */
    .who-profile-card {
      background: linear-gradient(135deg,#F7FCF9 0%,#FFFFFF 76%);
      border: 1px solid #DDEFE5;
      border-radius: 28px;
      padding: 38px;
      box-shadow: 0 14px 34px rgba(7,21,35,.06);
    }

    .who-profile-card h2 {
      margin: 0 0 16px;
      color: var(--navy);
      font-size: 42px;
      line-height: 1.08;
      letter-spacing: -.035em;
    }

    .who-profile-card h2::after {
      content: "";
      display: block;
      width: 72px;
      height: 4px;
      margin-top: 14px;
      border-radius: 999px;
      background: var(--green);
    }

    .who-profile-card p {
      margin: 0 0 18px;
      color: #475467;
      font-size: 17px;
      line-height: 1.75;
    }

    .who-profile-card p:last-child {
      margin-bottom: 0;
    }

    .who-focus-grid {
      display: grid;
      grid-template-columns: repeat(3,1fr);
      gap: 16px;
      margin-top: 24px;
    }

    .who-focus-card {
      border: 1px solid #E3EFE8;
      background: #fff;
      border-radius: 20px;
      padding: 18px;
      box-shadow: 0 10px 22px rgba(7,21,35,.04);
    }

    .who-focus-card b {
      display: block;
      color: var(--green);
      margin-bottom: 6px;
      font-size: 15px;
    }

    .who-focus-card span {
      color: #667085;
      font-size: 14px;
      line-height: 1.45;
    }

    @media(max-width:820px) {
      .who-focus-grid { grid-template-columns: 1fr; }
      .who-profile-card { padding: 28px; }
      .who-profile-card h2 { font-size: 34px; }
    }

  
    /* History section - horizontal timeline style */
    .history-page {
      display: grid;
      gap: 28px;
    }

    .history-summary {
      background: linear-gradient(135deg,#F7FCF9 0%,#FFFFFF 76%);
      border: 1px solid #DDEFE5;
      border-radius: 28px;
      padding: 36px;
      box-shadow: 0 14px 34px rgba(7,21,35,.06);
    }

    .history-summary h2 {
      margin: 0 0 16px;
      color: var(--navy);
      font-size: 42px;
      line-height: 1.08;
      letter-spacing: -.035em;
    }

    .history-summary h2::after {
      content: "";
      display: block;
      width: 72px;
      height: 4px;
      margin-top: 14px;
      border-radius: 999px;
      background: var(--green);
    }

    .history-summary p {
      margin: 0 0 16px;
      color: #475467;
      font-size: 17px;
      line-height: 1.72;
    }

    .history-summary p:last-child {
      margin-bottom: 0;
    }

    .history-timeline-shell {
      position: relative;
      padding: 22px 8px 10px;
    }

    .history-timeline-shell::before {
      content: "";
      position: absolute;
      left: 0;
      right: 0;
      top: 50%;
      height: 4px;
      background: #C9D4DC;
      border-radius: 999px;
      transform: translateY(-50%);
    }

    .history-track {
      display: grid;
      grid-template-columns: repeat(4, minmax(0,1fr));
      gap: 22px;
      position: relative;
      z-index: 1;
    }

    .history-milestone {
      display: grid;
      grid-template-rows: minmax(180px,auto) 92px minmax(180px,auto);
      align-items: center;
      text-align: center;
    }

    .history-card {
      background: #fff;
      border: 1px solid #E3EFE8;
      border-radius: 22px;
      padding: 22px 20px;
      box-shadow: 0 12px 28px rgba(7,21,35,.06);
      transition: transform .22s ease, box-shadow .22s ease, border-color .22s ease;
    }

    .history-card:hover {
      transform: translateY(-5px);
      border-color: rgba(11,122,59,.45);
      box-shadow: 0 22px 48px rgba(11,122,59,.14);
    }

    .history-card h3 {
      margin: 0 0 8px;
      color: var(--navy);
      font-size: 22px;
      line-height: 1.18;
    }

    .history-card:hover h3 {
      color: var(--green);
    }

    .history-card p {
      margin: 0;
      color: #667085;
      font-size: 15px;
      line-height: 1.6;
    }

    .history-card.top {
      align-self: end;
      margin-bottom: 10px;
    }

    .history-card.bottom {
      align-self: start;
      margin-top: 10px;
    }

    .history-connector {
      position: relative;
      display: grid;
      place-items: center;
      height: 92px;
    }

    .history-connector::before {
      content: "";
      position: absolute;
      width: 2px;
      background: #A8B8C5;
      top: 0;
      bottom: 0;
      left: 50%;
      transform: translateX(-50%);
    }

    .history-node {
      position: relative;
      z-index: 2;
      width: 24px;
      height: 24px;
      border-radius: 50%;
      background: var(--green);
      border: 5px solid #EAF5EF;
      box-shadow: 0 0 0 4px rgba(11,122,59,.18);
    }

    .history-date {
      position: absolute;
      left: 50%;
      transform: translateX(-50%);
      background: #fff;
      color: var(--green);
      border: 1px solid #DDEFE5;
      padding: 8px 14px;
      border-radius: 999px;
      font-size: 14px;
      font-weight: 900;
      white-space: nowrap;
      box-shadow: 0 10px 24px rgba(7,21,35,.05);
    }

    .history-date.top {
      top: 6px;
    }

    .history-date.bottom {
      bottom: 6px;
    }

    .history-empty {
      visibility: hidden;
    }

    .history-note {
      border-left: 5px solid var(--green);
      background: #F4FBF7;
      border-radius: 18px;
      padding: 22px 24px;
      color: #344054;
      font-size: 16px;
      line-height: 1.7;
    }

    @media(max-width:1100px) {
      .history-track {
        grid-template-columns: repeat(2, minmax(0,1fr));
      }
      .history-timeline-shell::before {
        display: none;
      }
      .history-milestone {
        grid-template-rows: auto auto auto;
      }
      .history-card.top,
      .history-card.bottom {
        margin: 0;
      }
      .history-connector {
        height: 86px;
      }
      .history-date.top {
        top: auto;
        bottom: 6px;
      }
    }

    @media(max-width:700px) {
      .history-track {
        grid-template-columns: 1fr;
      }
      .history-summary {
        padding: 28px;
      }
      .history-summary h2 {
        font-size: 34px;
      }
    }
}
}

  
    /* Footer layout with contact in the same row */
    .footer-grid {
      display: grid;
      grid-template-columns: 1.25fr 0.9fr 1fr 0.9fr 1fr 1.15fr;
      gap: 28px;
      align-items: start;
    }

    .footer-contact-col h4 {
      margin-bottom: 16px;
    }

    .footer-contact-stack {
      display: grid;
      gap: 16px;
    }

    .footer-contact-box {
      padding: 0;
    }

    .footer-contact-box b {
      display: block;
      color: #fff;
      font-size: 12px;
      letter-spacing: .08em;
      text-transform: uppercase;
      margin-bottom: 6px;
    }

    .footer-contact-box a,
    .footer-contact-box span {
      color: #D0D7DE;
      text-decoration: none;
      font-size: 14px;
      line-height: 1.65;
      word-break: break-word;
    }

    .footer-contact-box a:hover {
      color: #7BE0A4;
      text-decoration: underline;
    }

    @media(max-width:1280px) {
      .footer-grid {
        grid-template-columns: 1.15fr 0.9fr 0.95fr 0.9fr 0.95fr 1.1fr;
      }
    }

    @media(max-width:1080px) {
      .footer-grid {
        grid-template-columns: 1.15fr 1fr 1fr;
      }
    }

    @media(max-width:760px) {
      .footer-grid {
        grid-template-columns: 1fr 1fr;
      }
    }

    @media(max-width:560px) {
      .footer-grid {
        grid-template-columns: 1fr;
      }
    }

  
    /* Magazine section enhancements */
    .magazine-layout { display:grid; grid-template-columns:280px 1fr; gap:28px; align-items:start; }
    .magazine-sidebar { position:sticky; top:112px; background:#fff; border:1px solid #E3EFE8; border-radius:24px; padding:22px; box-shadow:0 12px 28px rgba(7,21,35,.06); }
    .magazine-sidebar h3 { margin:0 0 14px; color:var(--navy); font-size:22px; }
    .magazine-sidebar a { display:block; text-decoration:none; color:#344054; font-weight:800; padding:10px 0; border-bottom:1px solid #F0F2F5; font-size:14px; }
    .magazine-sidebar a:hover { color:var(--green); }
    .magazine-main { display:grid; gap:22px; }
    .magazine-hero-card { background:linear-gradient(135deg,#F4FBF7 0%,#FFFFFF 72%); border:1px solid #DDEFE5; border-radius:28px; padding:34px; box-shadow:0 14px 34px rgba(7,21,35,.06); display:grid; grid-template-columns:.9fr 1.1fr; gap:26px; align-items:center; }
    .magazine-cover { background:linear-gradient(135deg,#0B7A3B 0%,#0D2235 100%); min-height:320px; border-radius:24px; color:#fff; padding:28px; display:flex; flex-direction:column; justify-content:space-between; box-shadow:0 22px 48px rgba(7,21,35,.16); position:relative; overflow:hidden; }
    .magazine-cover::after { content:""; position:absolute; right:-60px; bottom:-70px; width:190px; height:190px; border-radius:50%; background:rgba(255,255,255,.12); }
    .magazine-cover small { position:relative; z-index:1; text-transform:uppercase; letter-spacing:.16em; font-weight:900; color:#DFF8E9; }
    .magazine-cover h3 { position:relative; z-index:1; margin:0; font-size:38px; line-height:1.05; letter-spacing:-.04em; }
    .magazine-cover span { position:relative; z-index:1; color:#E7F8EE; font-weight:800; }
    .magazine-hero-copy h2 { margin:0 0 14px; color:var(--navy); font-size:42px; line-height:1.08; letter-spacing:-.04em; }
    .magazine-hero-copy h2::after { content:""; display:block; width:72px; height:4px; margin-top:14px; border-radius:999px; background:var(--green); }
    .magazine-hero-copy p { color:#475467; font-size:17px; line-height:1.7; margin:0 0 20px; }
    .magazine-actions { display:flex; flex-wrap:wrap; gap:12px; }
    .magazine-search-panel { background:#fff; border:1px solid #E3EFE8; border-radius:24px; padding:22px; box-shadow:0 12px 28px rgba(7,21,35,.05); }
    .magazine-search-row { display:grid; grid-template-columns:1.4fr repeat(3,.75fr) auto; gap:12px; align-items:center; }
    .magazine-search-row input,.magazine-search-row select { width:100%; border:1px solid #D0D5DD; border-radius:14px; padding:12px 13px; font-size:14px; font-family:inherit; background:#fff; }
    .magazine-quick-links { display:grid; grid-template-columns:repeat(3,1fr); gap:14px; }
    .magazine-quick-links a { background:#fff; border:1px solid #E3EFE8; border-radius:20px; padding:18px; text-decoration:none; color:var(--navy); font-weight:900; box-shadow:0 10px 22px rgba(7,21,35,.04); transition:.18s ease; }
    .magazine-quick-links a span { display:block; color:#667085; font-size:13px; line-height:1.45; font-weight:600; margin-top:6px; }
    .magazine-quick-links a:hover { border-color:rgba(11,122,59,.45); color:var(--green); transform:translateY(-3px); }
    .magazine-section-card { background:#fff; border:1px solid #E3EFE8; border-radius:24px; padding:24px; box-shadow:0 12px 28px rgba(7,21,35,.05); }
    .magazine-section-card h2 { margin:0 0 16px; color:var(--navy); font-size:28px; letter-spacing:-.025em; }
    .magazine-article-grid,.magazine-category-grid,.magazine-enhancement-grid,.magazine-archive-grid { display:grid; gap:16px; }
    .magazine-article-grid { grid-template-columns:repeat(3,1fr); }
    .magazine-category-grid { grid-template-columns:repeat(3,1fr); }
    .magazine-enhancement-grid { grid-template-columns:repeat(2,1fr); }
    .magazine-archive-grid { grid-template-columns:repeat(4,1fr); }
    .magazine-item { border:1px solid #E8EEF2; border-radius:18px; padding:18px; background:#fff; transition:.18s ease; }
    .magazine-item:hover { transform:translateY(-4px); border-color:rgba(11,122,59,.45); box-shadow:0 16px 32px rgba(11,122,59,.10); }
    .magazine-item small { display:block; color:var(--green); font-weight:900; letter-spacing:.1em; text-transform:uppercase; font-size:11px; margin-bottom:10px; }
    .magazine-item h3 { margin:0 0 10px; color:var(--navy); font-size:20px; line-height:1.2; }
    .magazine-item p { margin:0 0 14px; color:#667085; font-size:14px; line-height:1.55; }
    .magazine-item a,.magazine-download-link { color:var(--green); font-weight:900; text-decoration:none; font-size:14px; }
    .magazine-item a:hover,.magazine-download-link:hover { text-decoration:underline; }
    .magazine-pill-row { display:flex; flex-wrap:wrap; gap:9px; }
    .magazine-pill { background:#F2FBF6; color:var(--green-dark); border:1px solid #DDEFE5; border-radius:999px; padding:7px 11px; font-weight:900; font-size:12px; }
    .magazine-download-list { display:grid; gap:12px; }
    .magazine-download-row { display:grid; grid-template-columns:1fr auto auto; gap:12px; align-items:center; border:1px solid #E8EEF2; border-radius:16px; padding:14px 16px; }
    .magazine-download-row b { color:var(--navy); }
    .magazine-download-row span { color:#667085; font-size:13px; }
    @media(max-width:1180px) { .magazine-layout,.magazine-hero-card { grid-template-columns:1fr; } .magazine-sidebar { position:static; } .magazine-search-row { grid-template-columns:1fr 1fr; } .magazine-article-grid,.magazine-category-grid,.magazine-enhancement-grid,.magazine-archive-grid { grid-template-columns:repeat(2,1fr); } }
    @media(max-width:720px) { .magazine-search-row,.magazine-article-grid,.magazine-category-grid,.magazine-enhancement-grid,.magazine-archive-grid,.magazine-quick-links,.magazine-download-row { grid-template-columns:1fr; } .magazine-hero-copy h2 { font-size:34px; } }

  
    /* Research page with row-wise product/service list */
    .research-page-wrap {
      display: grid;
      gap: 24px;
    }

    .research-overview-card {
      background: linear-gradient(135deg,#F4FBF7 0%,#FFFFFF 72%);
      border: 1px solid #DDEFE5;
      border-radius: 28px;
      padding: 34px;
      box-shadow: 0 14px 34px rgba(7,21,35,.06);
    }

    .research-overview-card h2 {
      margin: 0 0 14px;
      color: var(--navy);
      font-size: 42px;
      line-height: 1.08;
      letter-spacing: -.04em;
    }

    .research-overview-card h2::after {
      content: "";
      display: block;
      width: 72px;
      height: 4px;
      margin-top: 14px;
      border-radius: 999px;
      background: var(--green);
    }

    .research-overview-card p {
      margin: 0;
      color: #475467;
      font-size: 17px;
      line-height: 1.7;
      max-width: 930px;
    }

    .research-row-list {
      display: grid;
      gap: 14px;
    }

    .research-service-row {
      display: grid;
      grid-template-columns: 72px 1fr 170px;
      gap: 20px;
      align-items: center;
      background: #fff;
      border: 1px solid #E3EFE8;
      border-radius: 22px;
      padding: 18px 20px;
      box-shadow: 0 10px 24px rgba(7,21,35,.05);
      transition: transform .22s ease, box-shadow .22s ease, border-color .22s ease;
    }

    .research-service-row:hover {
      transform: translateY(-4px);
      border-color: rgba(11,122,59,.45);
      box-shadow: 0 18px 38px rgba(11,122,59,.12);
    }

    .research-row-no {
      width: 52px;
      height: 52px;
      display: grid;
      place-items: center;
      border-radius: 18px;
      background: #EAF5EF;
      color: var(--green);
      font-weight: 900;
      font-size: 15px;
    }

    .research-service-row h3 {
      margin: 0 0 7px;
      color: var(--navy);
      font-size: 22px;
      line-height: 1.18;
      letter-spacing: -.02em;
    }

    .research-service-row:hover h3 {
      color: var(--green);
    }

    .research-service-row p {
      margin: 0;
      color: #667085;
      font-size: 14.5px;
      line-height: 1.55;
    }

    .research-row-action {
      justify-self: end;
      white-space: nowrap;
    }

    .research-row-action a {
      display: inline-flex;
      align-items: center;
      justify-content: center;
      text-decoration: none;
      color: var(--green);
      font-weight: 900;
      border: 1px solid #DDEFE5;
      border-radius: 999px;
      padding: 10px 14px;
      font-size: 13px;
      background: #F8FCFA;
    }

    .research-row-action a:hover {
      background: var(--green);
      color: #fff !important;
      text-decoration: none;
    }

    .research-support-grid {
      display: grid;
      grid-template-columns: repeat(3,1fr);
      gap: 16px;
    }

    .research-support-card {
      background: #fff;
      border: 1px solid #E3EFE8;
      border-radius: 22px;
      padding: 22px;
      box-shadow: 0 10px 24px rgba(7,21,35,.05);
    }

    .research-support-card h3 {
      margin: 0 0 10px;
      color: var(--navy);
      font-size: 21px;
      line-height: 1.18;
    }

    .research-support-card p {
      margin: 0;
      color: #667085;
      font-size: 14.5px;
      line-height: 1.55;
    }

    .research-support-card:hover h3 {
      color: var(--green);
    }

    @media(max-width:880px) {
      .research-service-row {
        grid-template-columns: 56px 1fr;
      }
      .research-row-action {
        grid-column: 2;
        justify-self: start;
      }
      .research-support-grid {
        grid-template-columns: 1fr;
      }
    }

    @media(max-width:560px) {
      .research-service-row {
        grid-template-columns: 1fr;
      }
      .research-row-action {
        grid-column: auto;
      }
    }

  
    .service-mini-grid-three {
      grid-template-columns: repeat(3, 1fr);
    }

    @media(max-width:980px) {
      .service-mini-grid-three {
        grid-template-columns: 1fr;
      }
    }

  
    /* Alignment fix for Learn More About WCRCL Services section */
    .service-mini-grid-three {
      grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
      align-items: stretch !important;
    }

    .service-mini-grid-three .service-mini-card {
      min-height: 285px;
      height: 100%;
      display: flex !important;
      flex-direction: column !important;
      justify-content: flex-start !important;
    }

    .service-mini-grid-three .service-mini-top {
      min-height: 72px;
      align-items: flex-start !important;
      margin-bottom: 14px !important;
    }

    .service-mini-grid-three .service-mini-card h3 {
      min-height: 54px;
      display: flex;
      align-items: center;
      margin: 0 !important;
    }

    .service-mini-grid-three .service-mini-card p {
      flex: 1 1 auto;
      margin-bottom: 18px !important;
    }

    .service-mini-grid-three .service-mini-card a {
      margin-top: auto;
      align-self: flex-start;
    }

    @media(max-width:980px) {
      .service-mini-grid-three {
        grid-template-columns: 1fr !important;
      }

      .service-mini-grid-three .service-mini-card {
        min-height: auto;
      }

      .service-mini-grid-three .service-mini-card h3 {
        min-height: auto;
      }

      .service-mini-grid-three .service-mini-top {
        min-height: auto;
      }
    }

  
    /* Final spacing fix for WCRCL services cards */
    .learn-layout {
      grid-template-columns: 1fr !important;
      gap: 24px !important;
      align-items: stretch !important;
    }

    .learn-overview {
      position: static !important;
      max-width: none !important;
      padding: 34px 36px !important;
    }

    .learn-overview h2 {
      max-width: 760px;
    }

    .learn-overview p {
      max-width: 960px;
    }

    .service-mini-grid-three {
      display: grid !important;
      grid-template-columns: repeat(3, minmax(300px, 1fr)) !important;
      gap: 24px !important;
      align-items: stretch !important;
    }

    .service-mini-grid-three .service-mini-card {
      min-height: 300px !important;
      padding: 28px !important;
      border-radius: 26px !important;
    }

    .service-mini-grid-three .service-mini-top {
      display: grid !important;
      grid-template-columns: 54px 1fr !important;
      gap: 16px !important;
      align-items: start !important;
      min-height: 0 !important;
      margin-bottom: 18px !important;
    }

    .service-mini-grid-three .service-mini-icon {
      width: 54px !important;
      height: 54px !important;
      border-radius: 18px !important;
    }

    .service-mini-grid-three .service-mini-card h3 {
      min-height: 0 !important;
      display: block !important;
      font-size: 25px !important;
      line-height: 1.14 !important;
      margin: 0 !important;
      word-break: normal !important;
      overflow-wrap: normal !important;
      hyphens: none !important;
    }

    .service-mini-grid-three .service-mini-card p {
      font-size: 15.5px !important;
      line-height: 1.65 !important;
    }

    @media(max-width:1100px) {
      .service-mini-grid-three {
        grid-template-columns: 1fr !important;
      }
      .service-mini-grid-three .service-mini-card {
        min-height: auto !important;
      }
    }

  
    /* Simplified monthly magazine page */
    .magazine-simple-layout {
      display: grid;
      grid-template-columns: 280px 1fr;
      gap: 28px;
      align-items: start;
    }

    .magazine-simple-sidebar {
      position: sticky;
      top: 112px;
      background: #fff;
      border: 1px solid #E3EFE8;
      border-radius: 24px;
      padding: 24px;
      box-shadow: 0 12px 28px rgba(7,21,35,.06);
    }

    .magazine-simple-sidebar h3 {
      margin: 0 0 14px;
      color: var(--navy);
      font-size: 22px;
    }

    .magazine-simple-sidebar a {
      display: block;
      text-decoration: none;
      color: #344054;
      font-weight: 800;
      padding: 12px 0;
      border-bottom: 1px solid #F0F2F5;
      font-size: 15px;
    }

    .magazine-simple-sidebar a:hover {
      color: var(--green);
    }

    .magazine-simple-main {
      display: grid;
      gap: 22px;
    }

    .magazine-latest-card {
      background: linear-gradient(135deg,#F4FBF7 0%,#FFFFFF 76%);
      border: 1px solid #DDEFE5;
      border-radius: 28px;
      padding: 34px;
      box-shadow: 0 14px 34px rgba(7,21,35,.06);
      display: grid;
      grid-template-columns: 340px 1fr;
      gap: 28px;
      align-items: center;
    }

    .magazine-latest-cover {
      min-height: 380px;
      border-radius: 24px;
      padding: 28px;
      background: linear-gradient(145deg,#0B7A3B 0%,#0D2235 100%);
      color: #fff;
      display: flex;
      flex-direction: column;
      justify-content: space-between;
      box-shadow: 0 22px 48px rgba(7,21,35,.16);
      position: relative;
      overflow: hidden;
    }

    .magazine-latest-cover::after {
      content: "";
      position: absolute;
      right: -70px;
      bottom: -90px;
      width: 220px;
      height: 220px;
      border-radius: 50%;
      background: rgba(255,255,255,.14);
    }

    .magazine-latest-cover small,
    .magazine-latest-cover h3,
    .magazine-latest-cover span {
      position: relative;
      z-index: 1;
    }

    .magazine-latest-cover small {
      text-transform: uppercase;
      letter-spacing: .16em;
      font-weight: 900;
      color: #DFF8E9;
    }

    .magazine-latest-cover h3 {
      margin: 0;
      font-size: 38px;
      line-height: 1.05;
      letter-spacing: -.04em;
    }

    .magazine-latest-cover span {
      color: #EAF8EF;
      font-weight: 800;
    }

    .magazine-latest-copy h2 {
      margin: 0 0 14px;
      color: var(--navy);
      font-size: 42px;
      line-height: 1.08;
      letter-spacing: -.04em;
    }

    .magazine-latest-copy h2::after {
      content: "";
      display: block;
      width: 72px;
      height: 4px;
      margin-top: 14px;
      border-radius: 999px;
      background: var(--green);
    }

    .magazine-latest-copy p {
      margin: 0 0 18px;
      color: #475467;
      font-size: 17px;
      line-height: 1.7;
      max-width: 760px;
    }

    .magazine-meta {
      display: flex;
      flex-wrap: wrap;
      gap: 10px;
      margin: 0 0 22px;
    }

    .magazine-meta span {
      background: #F2FBF6;
      color: var(--green-dark);
      border: 1px solid #DDEFE5;
      border-radius: 999px;
      padding: 7px 11px;
      font-weight: 900;
      font-size: 12px;
    }

    .magazine-latest-actions {
      display: flex;
      flex-wrap: wrap;
      gap: 12px;
    }

    .magazine-archive-section,
    .magazine-search-section {
      background: #fff;
      border: 1px solid #E3EFE8;
      border-radius: 24px;
      padding: 24px;
      box-shadow: 0 12px 28px rgba(7,21,35,.05);
    }

    .magazine-archive-head,
    .magazine-search-head {
      margin-bottom: 18px;
    }

    .magazine-archive-head h2,
    .magazine-search-head h2 {
      margin: 0 0 8px;
      color: var(--navy);
      font-size: 28px;
      letter-spacing: -.025em;
    }

    .magazine-archive-head p,
    .magazine-search-head p {
      margin: 0;
      color: #667085;
      font-size: 15px;
      line-height: 1.6;
    }

    .magazine-month-grid {
      display: grid;
      grid-template-columns: repeat(3, minmax(0,1fr));
      gap: 16px;
    }

    .magazine-month-card {
      background: #fff;
      border: 1px solid #E8EEF2;
      border-radius: 20px;
      padding: 20px;
      transition: transform .18s ease, box-shadow .18s ease, border-color .18s ease;
    }

    .magazine-month-card:hover {
      transform: translateY(-4px);
      border-color: rgba(11,122,59,.45);
      box-shadow: 0 16px 32px rgba(11,122,59,.10);
    }

    .magazine-month-card small {
      display: inline-block;
      margin-bottom: 12px;
      color: var(--green);
      font-weight: 900;
      letter-spacing: .1em;
      text-transform: uppercase;
      font-size: 11px;
    }

    .magazine-month-card h3 {
      margin: 0 0 10px;
      color: var(--navy);
      font-size: 22px;
      line-height: 1.16;
    }

    .magazine-month-card p {
      margin: 0 0 14px;
      color: #667085;
      font-size: 14.5px;
      line-height: 1.55;
    }

    .magazine-month-tags {
      display: flex;
      flex-wrap: wrap;
      gap: 8px;
      margin: 0 0 16px;
    }

    .magazine-month-tags span {
      background: #F7FAF8;
      border: 1px solid #E3EFE8;
      color: #475467;
      border-radius: 999px;
      padding: 6px 10px;
      font-size: 12px;
      font-weight: 800;
    }

    .magazine-month-actions {
      display: flex;
      gap: 10px;
      flex-wrap: wrap;
    }

    .magazine-month-actions a {
      text-decoration: none;
      color: var(--green);
      font-weight: 900;
      font-size: 14px;
    }

    .magazine-month-actions a:hover {
      text-decoration: underline;
    }

    .magazine-filter-row {
      display: grid;
      grid-template-columns: 1.4fr repeat(3, .8fr) auto;
      gap: 12px;
      align-items: center;
    }

    .magazine-filter-row input,
    .magazine-filter-row select {
      width: 100%;
      border: 1px solid #D0D5DD;
      border-radius: 14px;
      padding: 12px 13px;
      font-size: 14px;
      font-family: inherit;
      background: #fff;
    }

    .magazine-search-result-note {
      margin-top: 14px;
      color: #667085;
      font-size: 13px;
    }

    @media(max-width:1180px) {
      .magazine-simple-layout,
      .magazine-latest-card {
        grid-template-columns: 1fr;
      }
      .magazine-simple-sidebar {
        position: static;
      }
      .magazine-month-grid {
        grid-template-columns: repeat(2, minmax(0,1fr));
      }
      .magazine-filter-row {
        grid-template-columns: 1fr 1fr;
      }
    }

    @media(max-width:760px) {
      .magazine-month-grid,
      .magazine-filter-row {
        grid-template-columns: 1fr;
      }
      .magazine-latest-copy h2 {
        font-size: 34px;
      }
    }

  
    /* Header logo update */
    .brand {
      min-width: 210px !important;
      gap: 12px !important;
    }

    .brand-logo {
      width: 92px !important;
      height: 66px !important;
      object-fit: contain !important;
      background: transparent !important;
      border-radius: 0 !important;
      padding: 0 !important;
      box-shadow: none !important;
    }

    .brand-text {
      line-height: 1 !important;
      display: flex !important;
      align-items: center !important;
    }

    .brand-title {
      font-family: Georgia, serif !important;
      font-size: 30px !important;
      letter-spacing: -.02em !important;
      font-weight: 800 !important;
      color: var(--green) !important;
    }

    .brand-sub,
    .brand-tag {
      display: none !important;
    }

  
    /* Brand subtitle under WASO */
    .brand-text {
      line-height: 1.05 !important;
      display: flex !important;
      flex-direction: column !important;
      align-items: flex-start !important;
      justify-content: center !important;
      gap: 4px !important;
    }

    .brand-title {
      font-family: Georgia, serif !important;
      font-size: 30px !important;
      letter-spacing: -.02em !important;
      font-weight: 800 !important;
      color: var(--green) !important;
    }

    .brand-sub {
      display: block !important;
      font-size: 10px !important;
      line-height: 1.2 !important;
      letter-spacing: .08em !important;
      text-transform: uppercase !important;
      font-weight: 800 !important;
      color: var(--navy) !important;
      white-space: nowrap !important;
    }

  
    /* Compact header height */
    .top-strip {
      display: none !important;
    }

    .site-header {
      min-height: 82px !important;
    }

    .nav {
      min-height: 82px !important;
      padding-top: 4px !important;
      padding-bottom: 4px !important;
    }

    .brand {
      min-width: 330px !important;
      gap: 10px !important;
      align-items: center !important;
    }

    .brand-logo {
      width: 72px !important;
      height: 52px !important;
      object-fit: contain !important;
    }

    .brand-title {
      font-size: 25px !important;
      line-height: 1 !important;
    }

    .brand-sub {
      font-size: 8.8px !important;
      line-height: 1.1 !important;
      letter-spacing: .075em !important;
    }

    .menu-link {
      padding-top: 26px !important;
      padding-bottom: 26px !important;
      font-size: 13.5px !important;
    }

    .mega {
      top: 76px !important;
    }

    .icon-btn {
      width: 38px !important;
      height: 38px !important;
      font-size: 16px !important;
    }

    .contact-btn {
      padding: 12px 18px !important;
      min-height: 44px !important;
    }

    @media(max-width: 980px) {
      .brand {
        min-width: 260px !important;
      }

      .brand-logo {
        width: 62px !important;
        height: 46px !important;
      }

      .brand-title {
        font-size: 22px !important;
      }

      .brand-sub {
        font-size: 8px !important;
        white-space: normal !important;
      }
    }

  
    /* Moody-inspired green header */
    .top-strip {
      display: none !important;
    }

    .site-header.moody-green-style {
      top: 0;
      background: transparent !important;
      border-bottom: 0 !important;
      box-shadow: 0 10px 24px rgba(7,21,35,.10) !important;
      backdrop-filter: none !important;
    }

    .site-header.moody-green-style .header-top-bar {
      background: linear-gradient(135deg, #0B7A3B 0%, #0A6933 100%);
      padding: 14px 0;
      border-bottom: 1px solid rgba(255,255,255,.10);
    }

    .site-header.moody-green-style .header-top-inner {
      display: grid;
      grid-template-columns: auto minmax(300px, 620px) auto;
      align-items: center;
      gap: 22px;
    }

    .site-header.moody-green-style .header-brand-group {
      display: flex;
      align-items: center;
      gap: 14px;
      min-width: 0;
    }

    .site-header.moody-green-style .header-burger {
      width: 48px;
      height: 48px;
      border: 0;
      border-radius: 14px;
      background: rgba(255,255,255,.12);
      color: #fff;
      font-size: 26px;
      line-height: 1;
      display: grid;
      place-items: center;
      cursor: pointer;
      transition: background .18s ease, transform .18s ease;
    }

    .site-header.moody-green-style .header-burger:hover {
      background: rgba(255,255,255,.20);
      transform: translateY(-1px);
    }

    .site-header.moody-green-style .mobile-burger {
      display: none;
    }

    .site-header.moody-green-style .brand {
      min-width: 0 !important;
      gap: 12px !important;
      text-decoration: none;
    }

    .site-header.moody-green-style .brand-logo {
      width: 76px !important;
      height: 54px !important;
      object-fit: contain !important;
      background: transparent !important;
      border-radius: 0 !important;
      padding: 0 !important;
      box-shadow: none !important;
    }

    .site-header.moody-green-style .brand-title {
      color: #fff !important;
      font-size: 27px !important;
      line-height: 1 !important;
      letter-spacing: -.02em !important;
    }

    .site-header.moody-green-style .brand-sub {
      display: block !important;
      color: rgba(255,255,255,.92) !important;
      font-size: 9px !important;
      letter-spacing: .09em !important;
      line-height: 1.15 !important;
    }

    .site-header.moody-green-style .top-search-pill {
      width: 100%;
      border: 1px solid rgba(255,255,255,.20);
      border-radius: 999px;
      background: rgba(255,255,255,.10);
      color: #fff;
      min-height: 58px;
      padding: 0 22px;
      display: flex;
      align-items: center;
      gap: 16px;
      cursor: pointer;
      text-align: left;
      box-shadow: inset 0 1px 0 rgba(255,255,255,.05);
    }

    .site-header.moody-green-style .top-search-pill:hover {
      background: rgba(255,255,255,.14);
    }

    .site-header.moody-green-style .top-search-icon {
      font-size: 30px;
      line-height: 1;
      opacity: .95;
    }

    .site-header.moody-green-style .top-search-text {
      font-size: 17px;
      font-weight: 700;
      letter-spacing: -.01em;
      white-space: nowrap;
      overflow: hidden;
      text-overflow: ellipsis;
    }

    .site-header.moody-green-style .header-top-actions {
      display: flex;
      align-items: center;
      justify-content: flex-end;
      gap: 14px;
    }

    .site-header.moody-green-style .top-contact-pill {
      display: inline-flex;
      align-items: center;
      justify-content: center;
      min-height: 58px;
      padding: 0 28px;
      border-radius: 999px;
      background: #fff;
      color: #0B7A3B;
      text-decoration: none;
      font-weight: 900;
      font-size: 16px;
      letter-spacing: -.01em;
      box-shadow: 0 8px 20px rgba(7,21,35,.12);
    }

    .site-header.moody-green-style .top-contact-pill:hover {
      background: #F3FAF6;
      color: #095D2E;
    }

    .site-header.moody-green-style .header-bottom-bar {
      background: rgba(255,255,255,.98);
      border-bottom: 1px solid #E8EDF2;
    }

    .site-header.moody-green-style .header-bottom-inner {
      display: flex;
      align-items: center;
      min-height: 72px;
    }

    .site-header.moody-green-style .main-menu {
      width: 100%;
      justify-content: flex-start !important;
      gap: 26px !important;
    }

    .site-header.moody-green-style .menu-link {
      color: var(--navy) !important;
      text-transform: none !important;
      font-size: 17px !important;
      letter-spacing: -.01em !important;
      font-weight: 500 !important;
      padding: 22px 4px !important;
    }

    .site-header.moody-green-style .menu-link:hover {
      color: var(--green) !important;
    }

    .site-header.moody-green-style .chev {
      font-size: 12px !important;
      opacity: .85 !important;
      margin-left: 2px;
    }

    .site-header.moody-green-style .mega {
      top: 64px !important;
      border-radius: 0 0 22px 22px !important;
    }

    .site-header.moody-green-style .nav-actions,
    .site-header.moody-green-style .menu-toggle {
      display: none !important;
    }

    body {
      scroll-padding-top: 146px;
    }

    @media (max-width: 1180px) {
      .site-header.moody-green-style .header-top-inner {
        grid-template-columns: minmax(0, 1fr) minmax(220px, 1fr) auto;
        gap: 16px;
      }

      .site-header.moody-green-style .top-search-text {
        font-size: 15px;
      }

      .site-header.moody-green-style .main-menu {
        gap: 16px !important;
      }

      .site-header.moody-green-style .menu-link {
        font-size: 15px !important;
      }
    }

    @media (max-width: 980px) {
      .site-header.moody-green-style .header-top-inner {
        grid-template-columns: 1fr auto;
        gap: 14px;
      }

      .site-header.moody-green-style .top-search-pill {
        grid-column: 1 / -1;
        order: 3;
      }

      .site-header.moody-green-style .desktop-burger {
        display: none;
      }

      .site-header.moody-green-style .mobile-burger {
        display: grid;
      }

      .site-header.moody-green-style .header-bottom-bar {
        display: none;
      }

      body {
        scroll-padding-top: 108px;
      }
    }

    @media (max-width: 640px) {
      .site-header.moody-green-style .header-top-bar {
        padding: 10px 0;
      }

      .site-header.moody-green-style .brand-logo {
        width: 62px !important;
        height: 46px !important;
      }

      .site-header.moody-green-style .brand-title {
        font-size: 22px !important;
      }

      .site-header.moody-green-style .brand-sub {
        font-size: 8px !important;
      }

      .site-header.moody-green-style .top-contact-pill {
        min-height: 48px;
        padding: 0 18px;
        font-size: 14px;
      }

      .site-header.moody-green-style .header-burger {
        width: 42px;
        height: 42px;
        font-size: 22px;
      }

      .site-header.moody-green-style .top-search-pill {
        min-height: 50px;
        padding: 0 16px;
      }

      .site-header.moody-green-style .top-search-text {
        font-size: 14px;
      }
    }

  
    /* Compact green header + improved menu drawer */
    .site-header.moody-green-style .header-top-bar {
      padding: 8px 0 !important;
    }

    .site-header.moody-green-style .header-top-inner {
      grid-template-columns: auto minmax(280px, 1fr) auto !important;
      gap: 18px !important;
    }

    .site-header.moody-green-style .header-brand-group {
      gap: 10px !important;
    }

    .site-header.moody-green-style .header-burger {
      width: 42px !important;
      height: 42px !important;
      border-radius: 12px !important;
      font-size: 22px !important;
      background: rgba(255,255,255,.13) !important;
    }

    .site-header.moody-green-style .brand-logo {
      width: 68px !important;
      height: 48px !important;
    }

    .site-header.moody-green-style .brand-title {
      font-size: 23px !important;
    }

    .site-header.moody-green-style .brand-sub {
      font-size: 8px !important;
      letter-spacing: .08em !important;
    }

    .site-header.moody-green-style .top-search-pill {
      min-height: 44px !important;
      padding: 0 18px !important;
      gap: 12px !important;
    }

    .site-header.moody-green-style .top-search-icon {
      font-size: 24px !important;
    }

    .site-header.moody-green-style .top-search-text {
      font-size: 14px !important;
      font-weight: 700 !important;
    }

    .site-header.moody-green-style .top-contact-pill {
      min-height: 44px !important;
      padding: 0 22px !important;
      font-size: 14px !important;
    }

    .site-header.moody-green-style .header-bottom-inner {
      min-height: 58px !important;
    }

    .site-header.moody-green-style .main-menu {
      gap: 22px !important;
    }

    .site-header.moody-green-style .menu-link {
      padding: 16px 2px !important;
      font-size: 15px !important;
    }

    .site-header.moody-green-style .mega {
      top: 52px !important;
    }

    body {
      scroll-padding-top: 118px !important;
    }

    .mobile-panel {
      display: block !important;
      position: fixed !important;
      inset: 0 !important;
      background: rgba(7, 21, 35, .45) !important;
      z-index: 120 !important;
      opacity: 0 !important;
      visibility: hidden !important;
      pointer-events: none !important;
      transition: opacity .22s ease, visibility .22s ease !important;
      padding: 0 !important;
    }

    .mobile-panel.show {
      opacity: 1 !important;
      visibility: visible !important;
      pointer-events: auto !important;
    }

    .mobile-drawer {
      width: min(390px, 92vw);
      height: 100vh;
      background: #FFFFFF;
      box-shadow: 24px 0 60px rgba(7, 21, 35, .18);
      transform: translateX(-100%);
      transition: transform .26s ease;
      display: flex;
      flex-direction: column;
      overflow: hidden;
    }

    .mobile-panel.show .mobile-drawer {
      transform: translateX(0);
    }

    .mobile-drawer-head {
      display: flex;
      align-items: flex-start;
      justify-content: space-between;
      gap: 16px;
      padding: 24px 22px 18px;
      background: linear-gradient(135deg, #0B7A3B 0%, #0A6933 100%);
      color: #fff;
    }

    .mobile-kicker {
      display: inline-block;
      font-size: 11px;
      text-transform: uppercase;
      letter-spacing: .14em;
      font-weight: 800;
      opacity: .82;
      margin-bottom: 8px;
    }

    .mobile-drawer-head h2 {
      margin: 0;
      font-size: 28px;
      line-height: 1.05;
      letter-spacing: -.03em;
      color: #fff;
    }

    .mobile-close {
      border: 0 !important;
      width: 40px !important;
      height: 40px !important;
      border-radius: 12px !important;
      background: rgba(255,255,255,.16) !important;
      color: #fff !important;
      font-size: 26px !important;
      line-height: 1 !important;
      cursor: pointer;
      display: grid;
      place-items: center;
      padding: 0 !important;
      flex: 0 0 auto;
    }

    .mobile-drawer-body {
      overflow: auto;
      padding: 18px 18px 26px;
      background: #F8FBF9;
    }

    .mobile-nav-group {
      background: #fff;
      border: 1px solid #E3EFE8;
      border-radius: 18px;
      padding: 12px 16px;
      box-shadow: 0 10px 22px rgba(7,21,35,.04);
    }

    .mobile-nav-group + .mobile-nav-group {
      margin-top: 14px;
    }

    .mobile-nav-group h3 {
      margin: 4px 0 8px;
      color: var(--green);
      font-size: 13px;
      text-transform: uppercase;
      letter-spacing: .12em;
    }

    .mobile-nav-group a {
      display: flex !important;
      align-items: center;
      justify-content: space-between;
      gap: 12px;
      padding: 11px 0 !important;
      border-bottom: 1px solid #F0F2F5 !important;
      text-decoration: none !important;
      font-weight: 750 !important;
      color: var(--navy) !important;
      font-size: 14px;
    }

    .mobile-nav-group a::after {
      content: "›";
      color: var(--green);
      font-weight: 900;
    }

    .mobile-nav-group a:last-child {
      border-bottom: 0 !important;
    }

    .mobile-nav-group a:hover {
      color: var(--green) !important;
    }

    @media (max-width: 980px) {
      .site-header.moody-green-style .header-top-inner {
        grid-template-columns: 1fr auto !important;
        gap: 12px !important;
      }

      .site-header.moody-green-style .top-search-pill {
        grid-column: 1 / -1;
        order: 3;
      }

      .site-header.moody-green-style .mobile-burger {
        display: grid !important;
      }

      .site-header.moody-green-style .desktop-burger {
        display: none !important;
      }

      body {
        scroll-padding-top: 106px !important;
      }
    }

    @media (max-width: 640px) {
      .site-header.moody-green-style .header-top-bar {
        padding: 7px 0 !important;
      }

      .site-header.moody-green-style .brand-logo {
        width: 58px !important;
        height: 42px !important;
      }

      .site-header.moody-green-style .brand-title {
        font-size: 20px !important;
      }

      .site-header.moody-green-style .top-contact-pill {
        padding: 0 16px !important;
        min-height: 40px !important;
      }

      .site-header.moody-green-style .top-search-pill {
        min-height: 40px !important;
      }

      .site-header.moody-green-style .top-search-text {
        font-size: 13px !important;
      }

      .mobile-drawer-head {
        padding: 20px 18px 16px;
      }

      .mobile-drawer-head h2 {
        font-size: 24px;
      }
    }

  
    /* White logo on green header for better contrast */
    .site-header.moody-green-style .brand-logo {
      filter: brightness(0) invert(1) !important;
      opacity: 0.98 !important;
    }

  
    /* Fixed desktop submenu behavior and alignment */
    .site-header.moody-green-style {
      overflow: visible !important;
    }

    .site-header.moody-green-style .header-bottom-bar,
    .site-header.moody-green-style .header-bottom-inner,
    .site-header.moody-green-style .main-menu {
      overflow: visible !important;
    }

    .site-header.moody-green-style .header-bottom-inner {
      position: relative !important;
    }

    .site-header.moody-green-style .main-menu .menu-item {
      position: static !important;
    }

    .site-header.moody-green-style .mega {
      position: absolute !important;
      top: calc(100% - 2px) !important;
      left: 0 !important;
      right: auto !important;
      translate: 0 0 !important;
      transform: translateY(10px) !important;
      width: min(760px, calc(100vw - 48px)) !important;
      max-height: min(70vh, 560px) !important;
      overflow: auto !important;
      background: #fff !important;
      border: 1px solid #E3EFE8 !important;
      border-top: 4px solid var(--green) !important;
      border-radius: 0 0 26px 26px !important;
      box-shadow: 0 28px 70px rgba(7,21,35,.18) !important;
      padding: 26px 30px !important;
      opacity: 0 !important;
      visibility: hidden !important;
      pointer-events: none !important;
      transition: opacity .18s ease, transform .18s ease, visibility .18s ease !important;
      z-index: 160 !important;
    }

    .site-header.moody-green-style .mega.wide {
      width: min(860px, calc(100vw - 48px)) !important;
    }

    .site-header.moody-green-style .menu-item:hover > .mega,
    .site-header.moody-green-style .menu-item:focus-within > .mega,
    .site-header.moody-green-style .menu-item.open > .mega {
      opacity: 1 !important;
      visibility: visible !important;
      pointer-events: auto !important;
      transform: translateY(0) !important;
    }

    .site-header.moody-green-style .mega h4 {
      color: var(--green) !important;
      font-size: 12px !important;
      letter-spacing: .14em !important;
      text-transform: uppercase !important;
      margin: 0 0 14px !important;
    }

    .site-header.moody-green-style .mega-grid {
      display: grid !important;
      grid-template-columns: repeat(2, minmax(220px, 1fr)) !important;
      gap: 0 28px !important;
    }

    .site-header.moody-green-style .mega-grid.three {
      grid-template-columns: repeat(3, minmax(180px, 1fr)) !important;
    }

    .site-header.moody-green-style .mega a {
      display: flex !important;
      justify-content: space-between !important;
      align-items: center !important;
      gap: 18px !important;
      color: #253347 !important;
      text-decoration: none !important;
      font-size: 14px !important;
      font-weight: 800 !important;
      line-height: 1.35 !important;
      padding: 12px 0 !important;
      border-bottom: 1px solid #EEF2F5 !important;
      background: transparent !important;
    }

    .site-header.moody-green-style .mega a:hover {
      color: var(--green) !important;
      padding-left: 0 !important;
      background: transparent !important;
    }

    .site-header.moody-green-style .mega p {
      color: #667085 !important;
      margin: 16px 0 0 !important;
      font-size: 13.5px !important;
      line-height: 1.55 !important;
      max-width: 680px !important;
    }

    .site-header.moody-green-style .menu-link[aria-expanded="true"] {
      color: var(--green) !important;
    }

    @media(max-width: 980px) {
      .site-header.moody-green-style .mega {
        display: none !important;
      }
    }

    @media(max-width: 760px) {
      .site-header.moody-green-style .mega-grid,
      .site-header.moody-green-style .mega-grid.three {
        grid-template-columns: 1fr !important;
      }
    }

  
    /* Extra spacing for submenu items */
    .site-header.moody-green-style .mega {
      padding: 32px 36px !important;
    }

    .site-header.moody-green-style .mega-grid {
      gap: 0 40px !important;
    }

    .site-header.moody-green-style .mega-grid.three {
      gap: 0 32px !important;
    }

    .site-header.moody-green-style .mega a {
      padding: 16px 0 !important;
      line-height: 1.5 !important;
      font-size: 15px !important;
    }

    .site-header.moody-green-style .mega h4 {
      margin: 0 0 18px !important;
    }

    .site-header.moody-green-style .mega p {
      margin: 20px 0 0 !important;
    }

    @media(max-width: 760px) {
      .site-header.moody-green-style .mega {
        padding: 24px 22px !important;
      }
    }

  
    /* Header search is now a real input, not a popup button */
    .site-header.moody-green-style .header-search-form {
      cursor: text !important;
    }

    .site-header.moody-green-style .top-search-input {
      flex: 1;
      min-width: 0;
      border: 0;
      outline: 0;
      background: transparent;
      color: #fff;
      font-size: 14px;
      font-weight: 700;
      font-family: inherit;
      letter-spacing: -.01em;
    }

    .site-header.moody-green-style .top-search-input::placeholder {
      color: rgba(255,255,255,.88);
      opacity: 1;
    }

    .site-header.moody-green-style .top-search-input::-webkit-search-cancel-button {
      filter: brightness(0) invert(1);
      opacity: .85;
      cursor: pointer;
    }

  
    /* Better spacing for top menu items */
    .site-header.moody-green-style .main-menu {
      gap: 42px !important;
      padding-left: 6px !important;
    }

    .site-header.moody-green-style .menu-item {
      margin-right: 0 !important;
    }

    .site-header.moody-green-style .menu-link {
      padding: 16px 6px !important;
      font-size: 15.5px !important;
      letter-spacing: -.01em !important;
    }

    .site-header.moody-green-style .chev {
      margin-left: 6px !important;
    }

    @media (max-width: 1180px) {
      .site-header.moody-green-style .main-menu {
        gap: 28px !important;
      }

      .site-header.moody-green-style .menu-link {
        padding: 15px 4px !important;
        font-size: 15px !important;
      }
    }

  
    /* Hero text position adjustment */
    .hero {
      padding-top: 0 !important;
    }

    .hero-grid {
      align-items: start !important;
      padding-top: 38px !important;
      padding-bottom: 64px !important;
      min-height: 520px !important;
    }

    .hero-copy {
      padding-top: 0 !important;
      margin-top: 0 !important;
    }

    .hero .eyebrow {
      margin-top: 0 !important;
      margin-bottom: 22px !important;
    }

    @media(max-width: 980px) {
      .hero-grid {
        padding-top: 34px !important;
        min-height: auto !important;
      }
    }

    @media(max-width: 640px) {
      .hero-grid {
        padding-top: 28px !important;
        padding-bottom: 46px !important;
      }
    }

  
    /* Refreshed hero layout and cleaner first-screen spacing */
    .hero {
      margin-top: 0 !important;
      padding-top: 0 !important;
      background:
        linear-gradient(100deg, rgba(7,21,35,.96) 0%, rgba(8,31,49,.90) 42%, rgba(10,46,68,.62) 100%),
        radial-gradient(circle at 82% 18%, rgba(20,148,72,.22), transparent 28%),
        linear-gradient(135deg, #0D2235 0%, #113349 45%, #375A6A 100%) !important;
      overflow: hidden !important;
    }

    .hero::before {
      opacity: .14 !important;
      background-size: 260px 520px !important;
      transform: skewX(-12deg) scale(1.06) !important;
    }

    .hero-grid {
      grid-template-columns: minmax(0, 1.08fr) minmax(360px, .92fr) !important;
      align-items: center !important;
      gap: 52px !important;
      min-height: 610px !important;
      padding: 56px 0 72px !important;
    }

    .hero-grid > :first-child {
      max-width: 760px !important;
    }

    .hero .eyebrow {
      display: inline-flex !important;
      align-items: center !important;
      gap: 12px !important;
      padding: 12px 18px !important;
      border-radius: 999px !important;
      font-size: 15px !important;
      font-weight: 800 !important;
      margin: 0 0 22px !important;
      color: #DDF6E8 !important;
      background: rgba(255,255,255,.08) !important;
      border: 1px solid rgba(255,255,255,.18) !important;
      box-shadow: 0 10px 30px rgba(0,0,0,.12) !important;
      backdrop-filter: blur(10px) !important;
    }

    .hero .dot {
      width: 10px !important;
      height: 10px !important;
      background: #6FE2A1 !important;
      box-shadow: 0 0 0 6px rgba(111,226,161,.14) !important;
    }

    .hero h1 {
      font-size: clamp(56px, 5vw, 88px) !important;
      line-height: .98 !important;
      letter-spacing: -.065em !important;
      max-width: 860px !important;
      margin: 0 !important;
      text-wrap: balance;
    }

    .hero .lead {
      font-size: 18px !important;
      line-height: 1.62 !important;
      color: rgba(240,246,250,.94) !important;
      max-width: 760px !important;
      margin: 26px 0 30px !important;
    }

    .hero-actions {
      gap: 16px !important;
      margin-top: 8px !important;
    }

    .hero-actions .btn {
      min-height: 52px !important;
      padding: 0 28px !important;
      border-radius: 999px !important;
      font-size: 16px !important;
      font-weight: 900 !important;
      letter-spacing: -.01em !important;
      box-shadow: none !important;
    }

    .hero-actions .btn.primary {
      box-shadow: 0 14px 30px rgba(11,122,59,.26) !important;
    }

    .hero-actions .btn.ghost {
      color: #fff !important;
      border-color: rgba(255,255,255,.22) !important;
      background: rgba(255,255,255,.04) !important;
    }

    .quick-search {
      margin: 0 !important;
      align-self: center !important;
      width: 100% !important;
      max-width: 560px !important;
      margin-left: auto !important;
      padding: 34px !important;
      border-radius: 34px !important;
      background: rgba(255,255,255,.96) !important;
      border: 1px solid rgba(232,238,242,.9) !important;
      box-shadow: 0 28px 70px rgba(7,21,35,.28) !important;
      position: relative !important;
    }

    .quick-search::before {
      content: "";
      position: absolute;
      inset: 0;
      border-radius: 34px;
      pointer-events: none;
      background: linear-gradient(180deg, rgba(255,255,255,.55), rgba(255,255,255,0));
      opacity: .55;
    }

    .quick-search > * {
      position: relative;
      z-index: 1;
    }

    .quick-search h3 {
      margin: 0 0 16px !important;
      font-size: 38px !important;
      line-height: 1.04 !important;
      color: var(--navy) !important;
      letter-spacing: -.04em !important;
      text-wrap: balance;
    }

    .search-row {
      gap: 12px !important;
      border-radius: 18px !important;
      padding: 10px !important;
      background: #FBFCFD !important;
      border: 1px solid #DDE4EC !important;
      box-shadow: inset 0 1px 0 rgba(255,255,255,.7) !important;
    }

    .search-row input {
      font-size: 17px !important;
      padding: 12px 16px !important;
      color: var(--navy) !important;
    }

    .search-row .btn.primary {
      min-height: 52px !important;
      padding: 0 30px !important;
      border-radius: 16px !important;
      flex: 0 0 auto !important;
    }

    .mini-tabs {
      margin-top: 18px !important;
      gap: 12px !important;
    }

    .mini-tabs a {
      border-radius: 18px !important;
      padding: 16px 16px 15px !important;
      background: #fff !important;
      border: 1px solid #E3EAF0 !important;
      font-size: 14px !important;
      font-weight: 900 !important;
      color: var(--navy) !important;
      transition: transform .18s ease, box-shadow .18s ease, border-color .18s ease !important;
    }

    .mini-tabs a:hover {
      transform: translateY(-2px) !important;
      border-color: rgba(11,122,59,.35) !important;
      box-shadow: 0 14px 28px rgba(7,21,35,.08) !important;
      color: var(--green) !important;
    }

    .mini-tabs span {
      font-size: 12px !important;
      line-height: 1.45 !important;
      margin-top: 6px !important;
    }

    .site-header.moody-green-style .header-bottom-bar {
      box-shadow: 0 1px 0 rgba(7,21,35,.06) !important;
    }

    .site-header.moody-green-style .main-menu {
      gap: 44px !important;
    }

    .site-header.moody-green-style .menu-link {
      padding-top: 18px !important;
      padding-bottom: 18px !important;
    }

    @media (max-width: 1180px) {
      .hero-grid {
        grid-template-columns: 1fr !important;
        gap: 28px !important;
        min-height: auto !important;
        padding: 44px 0 54px !important;
      }

      .quick-search {
        max-width: 100% !important;
        margin-left: 0 !important;
      }

      .hero h1 {
        max-width: 740px !important;
      }
    }

    @media (max-width: 760px) {
      .hero-grid {
        padding: 34px 0 42px !important;
      }

      .hero .eyebrow {
        font-size: 13px !important;
        padding: 10px 14px !important;
      }

      .hero h1 {
        font-size: clamp(42px, 13vw, 58px) !important;
      }

      .hero .lead {
        font-size: 16px !important;
      }

      .quick-search {
        padding: 24px !important;
        border-radius: 26px !important;
      }

      .quick-search h3 {
        font-size: 30px !important;
      }

      .search-row {
        flex-direction: column !important;
      }

      .search-row .btn.primary {
        width: 100% !important;
      }

      .mini-tabs {
        grid-template-columns: 1fr !important;
      }
    }

  
    /* Rating Updates archive and moving Rating News section */
    .rating-news-section {
      background: linear-gradient(180deg,#FFFFFF 0%,#F7FCF9 100%);
      padding: 64px 0 72px !important;
      border-top: 1px solid #E4EFE8;
      border-bottom: 1px solid #E4EFE8;
      overflow: hidden;
    }

    .rating-news-head {
      display: flex;
      justify-content: space-between;
      gap: 24px;
      align-items: flex-end;
      margin-bottom: 24px;
    }

    .rating-news-head h2 {
      margin: 0;
      color: var(--navy);
      font-size: 40px;
      line-height: 1.08;
      letter-spacing: -.04em;
    }

    .rating-news-head p {
      margin: 8px 0 0;
      color: #667085;
      max-width: 680px;
      line-height: 1.6;
    }

    .rating-news-link {
      color: var(--green);
      font-weight: 900;
      text-decoration: none;
      white-space: nowrap;
    }

    .rating-news-link:hover { text-decoration: underline; }

    .rating-news-window {
      overflow: hidden;
      mask-image: linear-gradient(90deg, transparent 0%, #000 7%, #000 93%, transparent 100%);
      -webkit-mask-image: linear-gradient(90deg, transparent 0%, #000 7%, #000 93%, transparent 100%);
    }

    .rating-news-track {
      display: flex;
      gap: 18px;
      width: max-content;
      animation: ratingNewsMove 34s linear infinite;
    }

    .rating-news-window:hover .rating-news-track { animation-play-state: paused; }

    @keyframes ratingNewsMove {
      0% { transform: translateX(0); }
      100% { transform: translateX(-50%); }
    }

    .rating-news-card {
      width: 340px;
      flex: 0 0 auto;
      background: #fff;
      border: 1px solid #E3EFE8;
      border-radius: 22px;
      padding: 20px;
      box-shadow: 0 12px 28px rgba(7,21,35,.06);
    }

    .rating-news-card small {
      display: block;
      color: var(--green);
      font-size: 11px;
      font-weight: 900;
      letter-spacing: .11em;
      text-transform: uppercase;
      margin-bottom: 10px;
    }

    .rating-news-card h3 {
      margin: 0 0 8px;
      color: var(--navy);
      font-size: 20px;
      line-height: 1.18;
    }

    .rating-news-card p {
      margin: 0 0 14px;
      color: #667085;
      font-size: 14px;
      line-height: 1.55;
    }

    .rating-news-meta {
      display: flex;
      flex-wrap: wrap;
      gap: 8px;
    }

    .rating-news-meta span,
    .rating-badge {
      background: #EAF5EF;
      color: var(--green-dark);
      border: 1px solid #DDEFE5;
      border-radius: 999px;
      padding: 6px 10px;
      font-size: 12px;
      font-weight: 900;
      white-space: nowrap;
    }

    .rating-updates-wrap { display: grid; gap: 24px; }

    .rating-updates-hero,
    .rating-upload-panel,
    .rating-table-panel {
      background: #fff;
      border: 1px solid #E3EFE8;
      border-radius: 24px;
      padding: 24px;
      box-shadow: 0 12px 28px rgba(7,21,35,.05);
    }

    .rating-updates-hero {
      background: linear-gradient(135deg,#F4FBF7 0%,#FFFFFF 72%);
      border-radius: 28px;
      padding: 34px;
    }

    .rating-updates-hero h2 {
      margin: 0 0 14px;
      color: var(--navy);
      font-size: 42px;
      line-height: 1.08;
      letter-spacing: -.04em;
    }

    .rating-updates-hero h2::after {
      content: "";
      display: block;
      width: 72px;
      height: 4px;
      margin-top: 14px;
      border-radius: 999px;
      background: var(--green);
    }

    .rating-updates-hero p {
      margin: 0;
      color: #475467;
      font-size: 17px;
      line-height: 1.7;
      max-width: 940px;
    }

    .rating-upload-grid {
      display: grid;
      grid-template-columns: 1fr 1.1fr;
      gap: 22px;
      align-items: start;
    }

    .rating-upload-box {
      border: 2px dashed #CFE6D8;
      background: #F8FCFA;
      border-radius: 22px;
      padding: 24px;
      text-align: center;
    }

    .rating-upload-box input {
      width: 100%;
      border: 1px solid #D0D5DD;
      border-radius: 14px;
      padding: 12px;
      background: #fff;
      margin: 14px 0;
      font-family: inherit;
    }

    .rating-upload-note {
      color: #667085;
      font-size: 14px;
      line-height: 1.6;
      margin: 0;
    }

    .rating-column-list {
      display: grid;
      grid-template-columns: repeat(2, minmax(0,1fr));
      gap: 10px;
      margin-top: 14px;
    }

    .rating-column-list span {
      background: #F2FBF6;
      color: var(--green-dark);
      border: 1px solid #DDEFE5;
      border-radius: 999px;
      padding: 8px 11px;
      font-size: 12px;
      font-weight: 900;
    }

    .rating-filter-row {
      display: grid;
      grid-template-columns: 1.3fr repeat(3,.75fr) auto;
      gap: 12px;
      margin-bottom: 18px;
    }

    .rating-filter-row input,
    .rating-filter-row select {
      width: 100%;
      border: 1px solid #D0D5DD;
      border-radius: 14px;
      padding: 12px 13px;
      font-size: 14px;
      font-family: inherit;
      background: #fff;
    }

    .rating-updates-table-wrap {
      overflow: auto;
      border: 1px solid #E8EEF2;
      border-radius: 18px;
    }

    .rating-updates-table {
      width: 100%;
      min-width: 980px;
      border-collapse: collapse;
      background: #fff;
    }

    .rating-updates-table th,
    .rating-updates-table td {
      padding: 14px 16px;
      border-bottom: 1px solid #EEF2F5;
      text-align: left;
      vertical-align: top;
      font-size: 14px;
    }

    .rating-updates-table th {
      background: #F8FCFA;
      color: var(--navy);
      font-size: 12px;
      font-weight: 900;
      letter-spacing: .08em;
      text-transform: uppercase;
    }

    .rating-updates-table tr:hover td { background: #FBFEFC; }

    .rating-table-status {
      color: #667085;
      font-size: 13px;
      margin-top: 12px;
    }

    @media(max-width: 980px) {
      .rating-news-head { display: grid; }
      .rating-upload-grid { grid-template-columns: 1fr; }
      .rating-filter-row { grid-template-columns: 1fr 1fr; }
      .rating-news-card { width: 300px; }
    }

    @media(max-width: 640px) {
      .rating-news-head h2,
      .rating-updates-hero h2 { font-size: 32px; }

      .rating-filter-row,
      .rating-column-list { grid-template-columns: 1fr; }
    }

/* Dynamic image support. */
.product-img img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  position: relative;
  z-index: 1;
}

.product-img:has(img)::before {
  display: none !important;
}

.rating-updates-table .rating-news-link {
  color: var(--green) !important;
  font-weight: 900;
  text-decoration: none;
}

.rating-updates-table .rating-news-link:hover {
  text-decoration: underline;
}

/* Extra rendering support */
.service-visual img,
.director-photo img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}
.admin-bar .site-header.moody-green-style {
  top: 32px;
}
@media(max-width: 782px) {
  .admin-bar .site-header.moody-green-style { top: 46px; }
}

@media print {
  .site-header,
  .top-strip,
  footer,
  .page-hero,
  .no-print,
  .side-card,
  .mobile-panel,
  .modal-backdrop {
    display: none !important;
  }
  body {
    background: #fff !important;
    color: #000 !important;
  }
  section,
  .page-view {
    padding: 0 !important;
  }
  .wrap {
    width: 100% !important;
    max-width: none !important;
  }
  .published-report-sheet {
    border: 0 !important;
    box-shadow: none !important;
    padding: 0 !important;
    border-radius: 0 !important;
  }
  .published-ratings-table-wrap {
    overflow: visible !important;
    border: 0 !important;
  }
  .published-ratings-table {
    min-width: 0 !important;
    width: 100% !important;
    font-size: 10px !important;
  }
  .published-ratings-table th,
  .published-ratings-table td {
    padding: 4px 5px !important;
    border: 1px solid #000 !important;
  }
}


/* V5 published ratings source tracing */
.published-source-links {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  align-items: center;
}
.published-source-links a {
  color: var(--green);
  font-weight: 900;
  text-decoration: none;
  white-space: nowrap;
}
.published-source-links a:hover {
  text-decoration: underline;
}
.single-rating-archive-page .published-source-links {
  justify-content: center;
}
@media print {
  .published-source-links a:not(:first-child) {
    display: none !important;
  }
}

/* V9: Simple Rating Reports file library */
.rating-reports-wrap {
  display: grid;
  gap: 24px;
}

.rating-report-list {
  display: grid;
  gap: 16px;
}

.rating-report-card {
  background: #fff;
  border: 1px solid #E3EFE8;
  border-radius: 22px;
  padding: 20px;
  box-shadow: 0 10px 24px rgba(7,21,35,.05);
  transition: transform .18s ease, box-shadow .18s ease, border-color .18s ease;
}

.rating-report-card:hover {
  transform: translateY(-3px);
  border-color: rgba(11,122,59,.45);
  box-shadow: 0 16px 34px rgba(11,122,59,.10);
}

.rating-report-card-main {
  display: grid;
  grid-template-columns: 1fr auto;
  gap: 18px;
  align-items: center;
}

.rating-report-card small {
  display: block;
  color: var(--green);
  font-weight: 900;
  letter-spacing: .12em;
  text-transform: uppercase;
  font-size: 11px;
  margin-bottom: 10px;
}

.rating-report-card h3 {
  margin: 0 0 8px;
  color: var(--navy);
  font-size: 24px;
  line-height: 1.16;
  letter-spacing: -.025em;
}

.rating-report-card p {
  margin: 0 0 14px;
  color: #667085;
  font-size: 14.5px;
  line-height: 1.55;
}

.rating-report-meta {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}

.rating-report-meta span {
  background: #EAF5EF;
  color: var(--green-dark);
  border: 1px solid #DDEFE5;
  border-radius: 999px;
  padding: 6px 10px;
  font-size: 12px;
  font-weight: 900;
}

.rating-report-actions {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  gap: 10px;
  flex-wrap: wrap;
  min-width: 220px;
}

.rating-report-preview {
  margin-top: 18px;
  border: 1px solid #DDEFE5;
  border-radius: 18px;
  overflow: hidden;
  background: #F8FCFA;
}

.rating-report-preview iframe {
  display: block;
  width: 100%;
  min-height: 720px;
  border: 0;
  background: #fff;
}

.rating-report-filter-row {
  grid-template-columns: 1.5fr repeat(4, minmax(135px,.75fr)) auto;
}

.rating-reports-section {
  background: #fff;
  border: 1px solid #E3EFE8;
  border-radius: 24px;
  padding: 24px;
  box-shadow: 0 12px 28px rgba(7,21,35,.05);
}

.rating-report-file-box {
  margin-top: 18px;
  padding: 20px;
  border: 1px solid #DDEFE5;
  border-radius: 18px;
  background: #F8FCFA;
}

.single-actions {
  justify-content: flex-start;
  margin: 20px 0;
}

.single-preview iframe {
  min-height: 820px;
}

@media(max-width: 1080px) {
  .rating-report-card-main,
  .rating-report-filter-row {
    grid-template-columns: 1fr;
  }
  .rating-report-actions {
    justify-content: flex-start;
    min-width: 0;
  }
  .rating-report-preview iframe {
    min-height: 560px;
  }
}

@media print {
  .site-header,
  footer,
  .side-card,
  .rating-filter-row,
  .rating-report-actions,
  .no-print {
    display: none !important;
  }
  .content-grid {
    display: block !important;
  }
  .rating-report-card {
    break-inside: avoid;
    box-shadow: none !important;
  }
}

/* V12: one public Rating Updates & Archive page */
.rating-updates-file-page .rating-reports-wrap {
  gap: 26px;
}

.rating-report-section-head small {
  display: inline-block;
  margin-bottom: 8px;
  color: var(--green);
  font-weight: 900;
  letter-spacing: .14em;
  text-transform: uppercase;
  font-size: 11px;
}

.rating-updates-pdf-section {
  background: linear-gradient(135deg,#F7FCF9 0%,#FFFFFF 78%);
}

.rating-archive-section {
  background: #FFFFFF;
}

.rating-update-report-list {
  display: grid;
  gap: 18px;
}

.rating-archive-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 16px;
}

.rating-archive-grid .rating-report-card {
  padding: 18px;
}

.rating-archive-grid .rating-report-card-main {
  grid-template-columns: 1fr;
  align-items: start;
}

.rating-archive-grid .rating-report-actions {
  justify-content: flex-start;
  min-width: 0;
}

.rating-archive-grid .rating-report-card h3 {
  font-size: 20px;
}

.rating-archive-grid .rating-report-preview iframe {
  min-height: 520px;
}

@media(max-width: 1180px) {
  .rating-archive-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media(max-width: 720px) {
  .rating-archive-grid {
    grid-template-columns: 1fr;
  }
}


/* V13: clean public rating file cards and rating news separation */
.rating-updates-file-page .rating-updates-hero p,
.rating-report-section-head p {
  max-width: 860px;
}

.rating-report-card h3 {
  margin-bottom: 0 !important;
}

.rating-report-card-main {
  align-items: flex-start !important;
}

.rating-report-card .rating-report-meta,
.rating-report-card p {
  display: none !important;
}

.rating-archive-grid {
  display: grid !important;
  grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
  gap: 20px !important;
}

.rating-archive-grid .rating-report-card {
  min-height: 260px !important;
}

.rating-archive-grid .rating-report-card-main {
  min-height: 220px !important;
}

@media(max-width:980px) {
  .rating-archive-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  }
}

@media(max-width:640px) {
  .rating-archive-grid {
    grid-template-columns: 1fr !important;
  }
}

/* V16 simplified public controls */
.rating-updates-file-page .rating-report-filter-row {
  grid-template-columns: repeat(3, minmax(160px, .9fr)) auto !important;
  align-items: center;
}

.methodology-library-page .rating-updates-hero p,
.rating-updates-file-page .rating-updates-hero p {
  display: none !important;
}

.single-pdf-page-card .single-pdf-preview {
  margin-top: 18px;
}

.single-pdf-page-card .single-pdf-preview iframe {
  min-height: 780px;
}

@media(max-width: 900px) {
  .rating-updates-file-page .rating-report-filter-row {
    grid-template-columns: 1fr !important;
  }
}

/* V17 refreshed monthly magazine library */
.magazine-refresh-page {
  background: linear-gradient(180deg,#FFFFFF 0%,#F7FCF9 100%);
}

.magazine-refresh-wrap {
  display: grid;
  gap: 26px;
}

.magazine-featured-shell {
  display: grid;
  grid-template-columns: minmax(280px,.82fr) minmax(0,1.18fr);
  gap: 34px;
  align-items: stretch;
  background:
    radial-gradient(circle at 86% 12%, rgba(11,122,59,.12), transparent 28%),
    linear-gradient(135deg,#F4FBF7 0%,#FFFFFF 74%);
  border: 1px solid #DDEFE5;
  border-radius: 34px;
  padding: 34px;
  box-shadow: 0 20px 52px rgba(7,21,35,.08);
  overflow: hidden;
}

.magazine-featured-cover {
  min-height: 430px;
  border-radius: 30px;
  padding: 32px;
  color: #fff;
  background:
    radial-gradient(circle at 88% 78%, rgba(255,255,255,.18), transparent 34%),
    linear-gradient(145deg,#0B7A3B 0%,#084B2A 54%,#0D2235 100%);
  background-size: cover;
  background-position: center;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  position: relative;
  box-shadow: 0 26px 60px rgba(7,21,35,.18);
  overflow: hidden;
}

.magazine-featured-cover::after {
  content: "";
  position: absolute;
  right: -86px;
  bottom: -96px;
  width: 260px;
  height: 260px;
  border-radius: 50%;
  background: rgba(255,255,255,.16);
}

.magazine-featured-cover.has-image::before {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(180deg, rgba(4,33,21,.10), rgba(4,33,21,.54));
}

.magazine-cover-top,
.magazine-cover-main {
  position: relative;
  z-index: 1;
}

.magazine-cover-top {
  text-transform: uppercase;
  letter-spacing: .16em;
  font-size: 13px;
  font-weight: 900;
  color: #DFF8E9;
}

.magazine-cover-main h2 {
  margin: 0 0 18px;
  font-size: clamp(34px,4vw,58px);
  line-height: .98;
  letter-spacing: -.055em;
  color: #fff;
}

.magazine-cover-main span {
  font-weight: 900;
  color: #ECFFF4;
  font-size: 18px;
}

.magazine-featured-copy {
  align-self: center;
  padding: 10px 6px;
}

.magazine-featured-copy small {
  display: inline-flex;
  color: var(--green);
  font-weight: 900;
  letter-spacing: .14em;
  text-transform: uppercase;
  font-size: 12px;
  margin-bottom: 16px;
}

.magazine-featured-copy h2 {
  margin: 0 0 18px;
  color: var(--navy);
  font-size: clamp(38px,4.3vw,62px);
  line-height: 1.02;
  letter-spacing: -.055em;
  max-width: 780px;
}

.magazine-featured-copy h2::after {
  content: "";
  display: block;
  width: 82px;
  height: 4px;
  border-radius: 999px;
  background: var(--green);
  margin-top: 18px;
}

.magazine-featured-copy p {
  margin: 0 0 22px;
  color: #475467;
  font-size: 18px;
  line-height: 1.7;
  max-width: 760px;
}

.magazine-sector-tags {
  display: flex;
  flex-wrap: wrap;
  gap: 9px;
  margin: 0 0 22px;
}

.magazine-sector-tags span {
  background: #EAF5EF;
  color: var(--green-dark);
  border: 1px solid #DDEFE5;
  border-radius: 999px;
  padding: 8px 13px;
  font-weight: 900;
  font-size: 13px;
}

.magazine-filter-panel {
  border-radius: 28px;
  padding: 24px;
  background: rgba(255,255,255,.94);
  border: 1px solid #DDEFE5;
  box-shadow: 0 14px 34px rgba(7,21,35,.05);
}

.clean-magazine-filter {
  grid-template-columns: repeat(3, minmax(180px, 1fr)) auto !important;
}

.clean-magazine-filter select {
  min-height: 54px;
  border-radius: 18px !important;
  border-color: #D5E5DB !important;
  font-weight: 750;
}

.magazine-clean-archive {
  padding: 28px;
  border-radius: 30px;
  background: #fff;
  border: 1px solid #DDEFE5;
  box-shadow: 0 18px 45px rgba(7,21,35,.06);
}

.magazine-clean-grid {
  gap: 20px;
}

.magazine-clean-card {
  border-radius: 26px;
  padding: 24px;
  border: 1px solid #E3EFE8;
  box-shadow: 0 12px 28px rgba(7,21,35,.04);
  background: linear-gradient(180deg,#FFFFFF 0%,#FBFEFC 100%);
}

.magazine-card-image {
  margin: -4px -4px 20px;
  border-radius: 22px;
  overflow: hidden;
  height: 210px;
  background: #EAF5EF;
}

.magazine-card-image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

.magazine-clean-card h3 {
  font-size: 24px;
  line-height: 1.13;
  margin-bottom: 12px;
}

.magazine-preview-link {
  border: 0;
  padding: 0;
  background: transparent;
  color: var(--green);
  font-weight: 900;
  font-size: 14px;
  cursor: pointer;
}

.magazine-pdf-preview {
  grid-column: 1 / -1;
  margin-top: 22px;
  border: 1px solid #DDEFE5;
  border-radius: 24px;
  overflow: hidden;
  background: #F8FAFC;
  box-shadow: inset 0 1px 0 rgba(255,255,255,.72);
}

.magazine-pdf-preview iframe {
  display: block;
  width: 100%;
  min-height: 720px;
  border: 0;
}

.magazine-featured-preview {
  margin-top: 4px;
}

@media(max-width: 1080px) {
  .magazine-featured-shell {
    grid-template-columns: 1fr;
  }
  .magazine-featured-cover {
    min-height: 360px;
  }
  .clean-magazine-filter {
    grid-template-columns: 1fr 1fr !important;
  }
}

@media(max-width: 700px) {
  .magazine-featured-shell,
  .magazine-clean-archive,
  .magazine-filter-panel {
    padding: 22px;
    border-radius: 24px;
  }
  .magazine-featured-cover {
    min-height: 300px;
    padding: 24px;
  }
  .clean-magazine-filter {
    grid-template-columns: 1fr !important;
  }
  .magazine-pdf-preview iframe {
    min-height: 520px;
  }
}

/* V18 People section: customizable CEO, VP, FAVP, SFA, Management and Rating Committee */
.people-page {
  background: linear-gradient(180deg,#FFFFFF 0%,#F7FCF9 100%);
}

.people-hero-panel {
  display: grid;
  grid-template-columns: .78fr 1.22fr;
  gap: 28px;
  align-items: stretch;
  margin-bottom: 34px;
  border: 1px solid #DDEFE5;
  border-radius: 32px;
  overflow: hidden;
  background: #fff;
  box-shadow: 0 18px 45px rgba(7,21,35,.07);
}

.people-hero-copy {
  background: linear-gradient(135deg,#0B7A3B 0%,#075C2D 100%);
  color: #fff;
  padding: 42px;
  position: relative;
  overflow: hidden;
}

.people-hero-copy::after {
  content: "";
  position: absolute;
  right: -90px;
  bottom: -90px;
  width: 220px;
  height: 220px;
  border-radius: 50%;
  background: rgba(255,255,255,.12);
}

.people-hero-copy .kicker {
  color: #DFF8E9 !important;
  letter-spacing: .18em;
}

.people-hero-copy h2 {
  margin: 18px 0 16px;
  color: #fff;
  font-size: 48px;
  line-height: 1.05;
  letter-spacing: -.045em;
  position: relative;
  z-index: 1;
}

.people-hero-copy p {
  margin: 0;
  color: #ECFFF4;
  font-size: 17px;
  line-height: 1.7;
  position: relative;
  z-index: 1;
}

.people-hero-map {
  padding: 34px;
  display: grid;
  grid-template-columns: repeat(3, minmax(0,1fr));
  gap: 16px;
  align-content: center;
  background:
    radial-gradient(circle at 78% 20%,rgba(11,122,59,.10),transparent 28%),
    linear-gradient(135deg,#FFFFFF 0%,#F7FCF9 100%);
}

.people-hero-map span {
  min-height: 96px;
  border: 1px solid #DDEFE5;
  border-radius: 24px;
  display: grid;
  place-items: center;
  background: #fff;
  color: var(--green-dark);
  font-weight: 900;
  font-size: 18px;
  box-shadow: 0 12px 28px rgba(7,21,35,.05);
}

.people-section {
  margin: 30px 0;
  background: #fff;
  border: 1px solid #E3EFE8;
  border-radius: 30px;
  padding: 30px;
  box-shadow: 0 14px 34px rgba(7,21,35,.05);
}

.people-section-head {
  display: grid;
  gap: 8px;
  margin-bottom: 24px;
  max-width: 860px;
}

.people-section-head span {
  color: var(--green);
  font-size: 12px;
  letter-spacing: .16em;
  text-transform: uppercase;
  font-weight: 900;
}

.people-section-head h2 {
  margin: 0;
  color: var(--navy);
  font-size: 38px;
  line-height: 1.08;
  letter-spacing: -.04em;
}

.people-section-head h2::after {
  content: "";
  display: block;
  width: 72px;
  height: 4px;
  margin-top: 12px;
  border-radius: 999px;
  background: var(--green);
}

.people-section-head p {
  margin: 0;
  color: #667085;
  font-size: 16px;
  line-height: 1.65;
}

.people-grid {
  display: grid;
  gap: 24px;
}

.people-grid-standard,
.people-grid-compact {
  grid-template-columns: repeat(3, minmax(0,1fr));
}

.people-grid-featured {
  grid-template-columns: minmax(280px, .62fr) minmax(0, 1fr);
  align-items: center;
}

.people-card {
  position: relative;
  min-height: 330px;
  border: 1px solid #E3EFE8;
  border-radius: 28px;
  background: linear-gradient(180deg,#FFFFFF 0%,#F7FCF9 100%);
  overflow: hidden;
  box-shadow: 0 12px 28px rgba(7,21,35,.05);
  transition: transform .22s ease, box-shadow .22s ease, border-color .22s ease;
}

.people-card:hover {
  transform: translateY(-6px);
  border-color: rgba(11,122,59,.45);
  box-shadow: 0 22px 48px rgba(11,122,59,.14);
}

.people-photo-wrap {
  height: 205px;
  display: grid;
  place-items: center;
  background: radial-gradient(circle at 50% 48%, #EAF5EF 0 34%, transparent 35%), linear-gradient(135deg,#F8FCFA,#FFFFFF);
}

.people-photo {
  width: 188px;
  height: 188px;
  border-radius: 50%;
  object-fit: cover;
  object-position: center top;
  display: block;
  filter: grayscale(100%);
  box-shadow: 0 12px 28px rgba(7,21,35,.10);
}

.people-photo-placeholder {
  display: grid;
  place-items: center;
  background: #EAF5EF;
  color: var(--green);
  font-size: 58px;
  font-weight: 900;
  filter: none;
}

.people-info-card {
  width: calc(100% - 44px);
  margin: -36px auto 22px;
  background: rgba(255,255,255,.96);
  border: 1px solid #E3EFE8;
  border-radius: 20px;
  padding: 18px;
  position: relative;
  z-index: 2;
  box-shadow: 0 14px 30px rgba(7,21,35,.07);
}

.people-role-chip {
  display: inline-flex;
  margin-bottom: 10px;
  padding: 6px 10px;
  border-radius: 999px;
  background: #EAF5EF;
  color: var(--green-dark);
  font-size: 11px;
  font-weight: 900;
  letter-spacing: .12em;
  text-transform: uppercase;
}

.people-info-card h3 {
  margin: 0 0 6px;
  color: var(--navy);
  font-size: 22px;
  line-height: 1.15;
  letter-spacing: -.025em;
}

.people-designation {
  margin: 0 0 10px;
  color: var(--green);
  font-weight: 900;
  font-size: 14px;
}

.people-bio {
  margin: 0;
  color: #667085;
  font-size: 14.5px;
  line-height: 1.55;
}

.people-linkedin {
  display: inline-flex;
  margin-top: 14px;
  color: var(--green);
  text-decoration: none;
  font-weight: 900;
  font-size: 14px;
}

.people-linkedin:hover { text-decoration: underline; }

.people-card-featured {
  min-height: 380px;
  display: grid;
  grid-template-columns: 330px 1fr;
  align-items: center;
  background:
    radial-gradient(circle at 88% 12%, rgba(11,122,59,.12), transparent 26%),
    linear-gradient(135deg,#FFFFFF 0%,#F2FBF6 100%);
}

.people-card-featured .people-photo-wrap {
  height: 100%;
  min-height: 380px;
  background: linear-gradient(135deg,#0B7A3B,#075C2D);
}

.people-card-featured .people-photo {
  width: 230px;
  height: 230px;
  border: 8px solid rgba(255,255,255,.20);
}

.people-card-featured .people-info-card {
  width: auto;
  margin: 0;
  box-shadow: none;
  border: 0;
  background: transparent;
  padding: 34px;
}

.people-card-featured .people-info-card h3 {
  font-size: 34px;
}

.people-card-featured .people-bio {
  font-size: 16px;
  max-width: 720px;
}

.people-empty {
  padding: 20px;
  border: 1px dashed #CFE6D8;
  border-radius: 18px;
  color: #667085;
  background: #F8FCFA;
}

@media(max-width:1100px) {
  .people-hero-panel,
  .people-grid-featured,
  .people-card-featured {
    grid-template-columns: 1fr;
  }
  .people-grid-standard,
  .people-grid-compact,
  .people-hero-map {
    grid-template-columns: repeat(2, minmax(0,1fr));
  }
  .people-card-featured .people-photo-wrap {
    min-height: 300px;
  }
}

@media(max-width:720px) {
  .people-hero-copy,
  .people-hero-map,
  .people-section {
    padding: 24px;
  }
  .people-hero-copy h2,
  .people-section-head h2 {
    font-size: 32px;
  }
  .people-grid-standard,
  .people-grid-compact,
  .people-hero-map {
    grid-template-columns: 1fr;
  }
  .people-card-featured .people-info-card {
    padding: 24px;
  }
}

/* V19 People refinements: circular photos, clickable profile cards, LinkedIn icon and profile details */
.people-card {
  cursor: pointer;
}

.people-card:focus-visible {
  outline: 4px solid rgba(11,122,59,.18);
  outline-offset: 4px;
}

.people-photo-wrap {
  position: relative;
}

.people-photo {
  border-radius: 50% !important;
  filter: none !important;
  border: 7px solid #fff;
  background: #EAF5EF;
}

.people-card:hover .people-photo {
  transform: scale(1.03);
}

.people-linkedin-icon {
  position: absolute;
  right: 24px;
  bottom: 20px;
  width: 44px;
  height: 44px;
  border-radius: 50%;
  display: grid;
  place-items: center;
  background: #0A66C2;
  color: #fff;
  box-shadow: 0 12px 28px rgba(10,102,194,.22);
  z-index: 4;
  transition: transform .18s ease, box-shadow .18s ease;
}

.people-linkedin-icon:hover,
.people-mini-linkedin:hover,
.people-linkedin-button:hover {
  transform: translateY(-2px);
  box-shadow: 0 16px 34px rgba(10,102,194,.28);
}

.people-linkedin-icon svg,
.people-mini-linkedin svg,
.people-linkedin-button svg {
  width: 22px;
  height: 22px;
  fill: currentColor;
}

.people-card-actions {
  display: flex;
  align-items: center;
  gap: 10px;
  flex-wrap: wrap;
  margin-top: 16px;
  position: relative;
  z-index: 5;
}

.people-profile-link {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 999px;
  padding: 9px 13px;
  background: #F2FBF6;
  border: 1px solid #DDEFE5;
  color: var(--green-dark);
  font-weight: 900;
  font-size: 13px;
  text-decoration: none;
}

.people-profile-link:hover {
  background: var(--green);
  color: #fff !important;
  text-decoration: none;
}

.people-mini-linkedin {
  width: 38px;
  height: 38px;
  border-radius: 50%;
  display: inline-grid;
  place-items: center;
  background: #0A66C2;
  color: #fff;
  text-decoration: none;
}

.people-card-featured .people-linkedin-icon {
  right: 44px;
  bottom: 44px;
}

.people-profile-panel {
  display: grid;
  grid-template-columns: 360px 1fr;
  gap: 34px;
  align-items: center;
  background: linear-gradient(135deg,#FFFFFF 0%,#F7FCF9 100%);
  border: 1px solid #DDEFE5;
  border-radius: 34px;
  padding: 38px;
  box-shadow: 0 18px 45px rgba(7,21,35,.08);
}

.people-profile-photo-area {
  min-height: 360px;
  border-radius: 30px;
  display: grid;
  place-items: center;
  background:
    radial-gradient(circle at 50% 48%, #EAF5EF 0 38%, transparent 39%),
    linear-gradient(135deg,#F8FCFA,#FFFFFF);
  border: 1px solid #E3EFE8;
}

.people-profile-photo {
  width: 260px;
  height: 260px;
  border-radius: 50%;
  object-fit: cover;
  object-position: center top;
  border: 9px solid #fff;
  box-shadow: 0 18px 45px rgba(7,21,35,.12);
}

.people-profile-photo-placeholder {
  display: grid;
  place-items: center;
  background: #EAF5EF;
  color: var(--green);
  font-size: 76px;
  font-weight: 900;
}

.people-profile-copy h2 {
  margin: 14px 0 8px;
  color: var(--navy);
  font-size: 46px;
  line-height: 1.05;
  letter-spacing: -.045em;
}

.people-profile-designation {
  margin: 0 0 22px;
  color: var(--green);
  font-size: 19px;
  font-weight: 900;
}

.people-profile-content {
  color: #475467;
  font-size: 17px;
  line-height: 1.75;
  max-width: 760px;
}

.people-profile-content p {
  margin-top: 0;
}

.people-profile-actions {
  display: flex;
  gap: 12px;
  flex-wrap: wrap;
  margin-top: 26px;
}

.people-linkedin-button {
  display: inline-flex;
  align-items: center;
  gap: 9px;
  border-radius: 999px;
  padding: 12px 18px;
  background: #0A66C2;
  color: #fff;
  text-decoration: none;
  font-weight: 900;
}

.people-linkedin-button:hover {
  color: #fff !important;
  text-decoration: none;
}

@media(max-width:900px) {
  .people-profile-panel {
    grid-template-columns: 1fr;
    padding: 26px;
  }
  .people-profile-copy h2 {
    font-size: 34px;
  }
  .people-profile-photo-area {
    min-height: 300px;
  }
  .people-profile-photo {
    width: 220px;
    height: 220px;
  }
}

/* V20 People redesign: softer professional layout, visible circular photos, full job descriptions */
.people-page {
  background: linear-gradient(180deg, #FFFFFF 0%, #F8FCFA 100%) !important;
}

.people-hero-panel {
  grid-template-columns: 1fr !important;
  border-radius: 28px !important;
  background: linear-gradient(135deg, #FFFFFF 0%, #F7FCF9 100%) !important;
  border: 1px solid #DDEFE5 !important;
  box-shadow: 0 16px 40px rgba(7,21,35,.06) !important;
}

.people-hero-copy {
  background: transparent !important;
  color: var(--ink) !important;
  padding: 36px 38px 18px !important;
}

.people-hero-copy::after { display: none !important; }
.people-hero-copy .kicker { color: var(--green) !important; }
.people-hero-copy h2 {
  color: var(--navy) !important;
  font-size: 44px !important;
  margin: 12px 0 12px !important;
}
.people-hero-copy h2::after {
  content: "";
  display: block;
  width: 72px;
  height: 4px;
  margin-top: 14px;
  border-radius: 999px;
  background: var(--green);
}
.people-hero-copy p {
  color: #475467 !important;
  max-width: 880px !important;
}

.people-hero-map {
  padding: 0 38px 34px !important;
  grid-template-columns: repeat(6, minmax(0,1fr)) !important;
  gap: 12px !important;
  background: transparent !important;
}

.people-hero-map span {
  min-height: 62px !important;
  border-radius: 18px !important;
  background: #F2FBF6 !important;
  border: 1px solid #DDEFE5 !important;
  color: var(--green-dark) !important;
  font-size: 14px !important;
  box-shadow: none !important;
}

.people-section {
  border-radius: 28px !important;
  padding: 30px !important;
  background: #fff !important;
  border: 1px solid #E3EFE8 !important;
  box-shadow: 0 12px 30px rgba(7,21,35,.05) !important;
}

.people-grid-featured,
.people-grid-standard,
.people-grid-compact {
  grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
  gap: 24px !important;
  align-items: stretch !important;
}

.people-section-ceo .people-grid-featured {
  grid-template-columns: 1fr !important;
}

.people-card,
.people-card-featured {
  min-height: auto !important;
  display: grid !important;
  grid-template-columns: 1fr !important;
  align-items: start !important;
  border-radius: 26px !important;
  background: #FFFFFF !important;
  border: 1px solid #E1EFE7 !important;
  box-shadow: 0 12px 28px rgba(7,21,35,.055) !important;
  overflow: hidden !important;
  cursor: pointer !important;
}

.people-card:hover,
.people-card-featured:hover {
  transform: translateY(-5px) !important;
  border-color: rgba(11,122,59,.38) !important;
  box-shadow: 0 22px 44px rgba(11,122,59,.11) !important;
}

.people-section-ceo .people-card-featured {
  grid-template-columns: 260px 1fr !important;
  min-height: 310px !important;
  background: linear-gradient(135deg,#FFFFFF 0%,#F7FCF9 100%) !important;
}

.people-photo-wrap,
.people-card-featured .people-photo-wrap {
  height: 210px !important;
  min-height: 210px !important;
  display: grid !important;
  place-items: center !important;
  background:
    radial-gradient(circle at 50% 48%, #EAF5EF 0 36%, transparent 37%),
    linear-gradient(135deg,#F8FCFA,#FFFFFF) !important;
  position: relative !important;
}

.people-section-ceo .people-card-featured .people-photo-wrap {
  height: 100% !important;
  min-height: 310px !important;
}

.people-photo,
.people-card-featured .people-photo {
  width: 158px !important;
  height: 158px !important;
  border-radius: 50% !important;
  object-fit: cover !important;
  object-position: center top !important;
  border: 7px solid #fff !important;
  filter: none !important;
  box-shadow: 0 14px 34px rgba(7,21,35,.13) !important;
  transition: transform .2s ease !important;
}

.people-section-ceo .people-card-featured .people-photo {
  width: 190px !important;
  height: 190px !important;
}

.people-photo-placeholder {
  display: grid !important;
  place-items: center !important;
  background: #EAF5EF !important;
  color: var(--green) !important;
  font-size: 54px !important;
  font-weight: 900 !important;
}

.people-info-card,
.people-card-featured .people-info-card {
  width: auto !important;
  margin: 0 !important;
  padding: 24px !important;
  background: #fff !important;
  border: 0 !important;
  border-top: 1px solid #EFF4F1 !important;
  border-radius: 0 !important;
  box-shadow: none !important;
}

.people-section-ceo .people-card-featured .people-info-card {
  border-top: 0 !important;
  border-left: 1px solid #EFF4F1 !important;
  padding: 34px !important;
  display: flex !important;
  flex-direction: column !important;
  justify-content: center !important;
}

.people-role-chip {
  background: #EAF5EF !important;
  color: var(--green-dark) !important;
  border: 1px solid #DDEFE5 !important;
}

.people-info-card h3,
.people-card-featured .people-info-card h3 {
  color: var(--navy) !important;
  font-size: 23px !important;
  line-height: 1.15 !important;
  margin: 0 0 8px !important;
}

.people-section-ceo .people-card-featured .people-info-card h3 {
  font-size: 34px !important;
}

.people-designation {
  color: var(--green) !important;
  font-weight: 900 !important;
  margin-bottom: 12px !important;
}

.people-bio,
.people-card-featured .people-bio {
  color: #667085 !important;
  font-size: 15px !important;
  line-height: 1.65 !important;
  max-width: 760px !important;
}

.people-section-ceo .people-card-featured .people-bio {
  font-size: 16px !important;
}

.people-card-actions {
  margin-top: 18px !important;
}

.people-profile-link {
  background: #F8FCFA !important;
  color: var(--green-dark) !important;
  border-color: #DDEFE5 !important;
}

.people-profile-link:hover {
  background: var(--green) !important;
  color: #fff !important;
}

.people-linkedin-icon {
  right: 18px !important;
  bottom: 18px !important;
  width: 40px !important;
  height: 40px !important;
}

.people-section-ceo .people-card-featured .people-linkedin-icon {
  right: 22px !important;
  bottom: 22px !important;
}

.people-profile-panel {
  grid-template-columns: 330px minmax(0, 1fr) !important;
  align-items: start !important;
  background: #FFFFFF !important;
  border: 1px solid #DDEFE5 !important;
  box-shadow: 0 16px 40px rgba(7,21,35,.07) !important;
  border-radius: 30px !important;
  padding: 34px !important;
}

.people-profile-photo-area {
  position: sticky !important;
  top: 124px !important;
  min-height: 330px !important;
  border-radius: 26px !important;
  background:
    radial-gradient(circle at 50% 44%, #EAF5EF 0 37%, transparent 38%),
    linear-gradient(135deg,#F8FCFA,#FFFFFF) !important;
  border: 1px solid #E3EFE8 !important;
}

.people-profile-photo {
  width: 230px !important;
  height: 230px !important;
  border-radius: 50% !important;
  object-fit: cover !important;
  object-position: center top !important;
  border: 8px solid #fff !important;
  box-shadow: 0 18px 45px rgba(7,21,35,.13) !important;
}

.people-profile-copy h2 {
  font-size: 42px !important;
  margin-top: 12px !important;
  color: var(--navy) !important;
}

.people-profile-copy h2::after {
  content: "";
  display: block;
  width: 72px;
  height: 4px;
  margin-top: 14px;
  border-radius: 999px;
  background: var(--green);
}

.people-profile-designation {
  color: var(--green) !important;
  font-size: 18px !important;
}

.people-profile-content {
  max-width: 900px !important;
  color: #3F4B5F !important;
  font-size: 16.5px !important;
  line-height: 1.78 !important;
}

.people-profile-content p,
.people-profile-content li {
  margin-bottom: 12px !important;
}

.people-profile-content ul,
.people-profile-content ol {
  padding-left: 22px !important;
  margin-top: 0 !important;
}

.people-profile-actions .btn.secondary {
  background: #F8FCFA !important;
  color: var(--green-dark) !important;
  border-color: #DDEFE5 !important;
}

@media(max-width:1180px) {
  .people-hero-map { grid-template-columns: repeat(3, minmax(0,1fr)) !important; }
  .people-grid-featured,
  .people-grid-standard,
  .people-grid-compact { grid-template-columns: repeat(2, minmax(0,1fr)) !important; }
  .people-section-ceo .people-grid-featured,
  .people-section-ceo .people-card-featured { grid-template-columns: 1fr !important; }
  .people-section-ceo .people-card-featured .people-info-card { border-left: 0 !important; border-top: 1px solid #EFF4F1 !important; }
}

@media(max-width:900px) {
  .people-profile-panel { grid-template-columns: 1fr !important; padding: 24px !important; }
  .people-profile-photo-area { position: static !important; min-height: 280px !important; }
  .people-profile-copy h2 { font-size: 34px !important; }
}

@media(max-width:720px) {
  .people-hero-copy,
  .people-hero-map,
  .people-section { padding: 24px !important; }
  .people-hero-map,
  .people-grid-featured,
  .people-grid-standard,
  .people-grid-compact { grid-template-columns: 1fr !important; }
  .people-hero-copy h2,
  .people-section-head h2 { font-size: 32px !important; }
}

/* V21 Team restructuring: Senior Management, Core Operations, Business Support Services */
.people-page-v21 {
  background:
    radial-gradient(circle at 90% 6%, rgba(11,122,59,.08), transparent 24%),
    linear-gradient(180deg, #FFFFFF 0%, #F8FCFA 100%) !important;
}

.people-page-v21 .people-team-intro {
  padding: 38px 0 28px;
  max-width: 900px;
}

.people-page-v21 .people-team-intro .kicker {
  color: var(--green) !important;
  letter-spacing: .18em;
}

.people-page-v21 .people-team-intro h2 {
  margin: 12px 0 12px;
  color: var(--navy);
  font-size: clamp(42px, 5vw, 64px);
  line-height: 1.02;
  letter-spacing: -.055em;
}

.people-page-v21 .people-team-intro h2::after {
  content: "";
  display: block;
  width: 78px;
  height: 4px;
  margin-top: 16px;
  border-radius: 999px;
  background: var(--green);
}

.people-page-v21 .people-team-intro p {
  margin: 0;
  color: #5B6878;
  font-size: 18px;
  line-height: 1.7;
  max-width: 780px;
}

.people-cluster-section {
  border: 0 !important;
  border-radius: 0 !important;
  background: transparent !important;
  box-shadow: none !important;
  padding: 22px 0 34px !important;
  margin: 0 !important;
}

.people-cluster-head {
  display: grid;
  grid-template-columns: 56px 1fr;
  gap: 18px;
  align-items: center;
  margin: 4px 0 24px;
}

.people-cluster-icon {
  width: 56px;
  height: 56px;
  border-radius: 50%;
  display: grid;
  place-items: center;
  background: #EAF5EF;
  color: var(--green-dark);
  border: 1px solid #DDEFE5;
  font-weight: 900;
  font-size: 18px;
  box-shadow: 0 10px 24px rgba(7,21,35,.05);
}

.people-cluster-titleline {
  display: grid;
  grid-template-columns: auto 1fr;
  gap: 18px;
  align-items: center;
}

.people-cluster-titleline h2 {
  margin: 0 !important;
  color: var(--green-dark) !important;
  font-size: 28px !important;
  line-height: 1.15 !important;
  letter-spacing: -.025em !important;
  white-space: nowrap;
}

.people-cluster-titleline h2::after { display: none !important; }

.people-cluster-titleline span {
  height: 1px;
  background: #DDEFE5;
  min-width: 80px;
}

.people-cluster-titleline p {
  grid-column: 1 / -1;
  margin: -8px 0 0 !important;
  color: #667085 !important;
  font-size: 15.5px !important;
  line-height: 1.6 !important;
}

.people-grid-team-v21 {
  display: grid !important;
  grid-template-columns: repeat(4, minmax(0, 1fr)) !important;
  gap: 26px !important;
  align-items: stretch !important;
}

.people-page-v21 .people-card,
.people-page-v21 .people-card-featured {
  min-height: 430px !important;
  display: flex !important;
  flex-direction: column !important;
  background: linear-gradient(180deg, #FFFFFF 0%, #FBFEFC 100%) !important;
  border: 1px solid #DFEDE5 !important;
  border-radius: 28px !important;
  box-shadow: 0 14px 34px rgba(7,21,35,.055) !important;
  overflow: hidden !important;
}

.people-page-v21 .people-card:hover {
  transform: translateY(-6px) !important;
  border-color: rgba(11,122,59,.35) !important;
  box-shadow: 0 22px 46px rgba(11,122,59,.12) !important;
}

.people-page-v21 .people-photo-wrap,
.people-page-v21 .people-card-featured .people-photo-wrap {
  height: 190px !important;
  min-height: 190px !important;
  padding-top: 18px;
  background:
    radial-gradient(circle at 50% 54%, #EEF6F1 0 38%, transparent 39%),
    linear-gradient(135deg, #FBFEFC, #FFFFFF) !important;
  position: relative !important;
}

.people-page-v21 .people-photo,
.people-page-v21 .people-card-featured .people-photo {
  width: 148px !important;
  height: 148px !important;
  border-radius: 50% !important;
  object-fit: cover !important;
  object-position: center top !important;
  border: 7px solid #FFFFFF !important;
  box-shadow: 0 14px 32px rgba(7,21,35,.14) !important;
}

.people-page-v21 .people-linkedin-icon {
  right: 28px !important;
  bottom: 22px !important;
  width: 38px !important;
  height: 38px !important;
}

.people-page-v21 .people-info-card,
.people-page-v21 .people-card-featured .people-info-card {
  display: flex !important;
  flex-direction: column !important;
  flex: 1 1 auto !important;
  width: 100% !important;
  margin: 0 !important;
  padding: 24px !important;
  border: 0 !important;
  border-top: 1px solid #EEF4F1 !important;
  background: transparent !important;
  box-shadow: none !important;
}

.people-page-v21 .people-role-chip {
  align-self: flex-start;
  background: #EAF5EF !important;
  border: 1px solid #DDEFE5 !important;
  color: var(--green-dark) !important;
  margin-bottom: 14px !important;
}

.people-page-v21 .people-info-card h3 {
  font-size: 23px !important;
  line-height: 1.15 !important;
  margin: 0 0 8px !important;
  color: var(--navy) !important;
}

.people-page-v21 .people-designation {
  color: var(--green-dark) !important;
  font-size: 14px !important;
  font-weight: 900 !important;
  margin: 0 0 12px !important;
}

.people-page-v21 .people-bio {
  color: #667085 !important;
  font-size: 14.5px !important;
  line-height: 1.62 !important;
  margin: 0 !important;
  flex: 1 1 auto !important;
}

.people-page-v21 .people-card-actions {
  margin-top: 18px !important;
}

.people-page-v21 .people-profile-link {
  background: #F2FBF6 !important;
  border: 1px solid #DDEFE5 !important;
  color: var(--green-dark) !important;
}

.people-page-v21 .people-profile-link:hover {
  background: var(--green) !important;
  color: #fff !important;
}

@media(max-width: 1180px) {
  .people-grid-team-v21 { grid-template-columns: repeat(3, minmax(0,1fr)) !important; }
}

@media(max-width: 900px) {
  .people-grid-team-v21 { grid-template-columns: repeat(2, minmax(0,1fr)) !important; }
  .people-cluster-titleline { grid-template-columns: 1fr; gap: 8px; }
  .people-cluster-titleline h2 { white-space: normal; }
  .people-cluster-titleline span { width: 100%; }
}

@media(max-width: 640px) {
  .people-page-v21 .people-team-intro { padding: 28px 0 18px; }
  .people-cluster-head { grid-template-columns: 44px 1fr; gap: 12px; }
  .people-cluster-icon { width: 44px; height: 44px; font-size: 15px; }
  .people-cluster-titleline h2 { font-size: 23px !important; }
  .people-grid-team-v21 { grid-template-columns: 1fr !important; }
}

/* V22 People section: colorful professional abstract design (no plant/flower motifs) */
.people-page-v22 {
  position: relative !important;
  overflow: hidden !important;
  background:
    radial-gradient(circle at 7% 11%, rgba(11,122,59,.10), transparent 26%),
    radial-gradient(circle at 92% 20%, rgba(31,120,166,.10), transparent 24%),
    radial-gradient(circle at 60% 100%, rgba(183,146,85,.10), transparent 30%),
    linear-gradient(180deg, #FFFFFF 0%, #F7FCFA 52%, #F3FAF6 100%) !important;
}

.people-page-v22::before {
  content: "";
  position: absolute;
  inset: 0;
  pointer-events: none;
  opacity: .45;
  background-image:
    linear-gradient(135deg, rgba(11,122,59,.10) 0 1px, transparent 1px 34px),
    linear-gradient(45deg, rgba(31,120,166,.07) 0 1px, transparent 1px 42px);
  background-size: 220px 220px, 260px 260px;
  mask-image: linear-gradient(180deg, #000 0%, rgba(0,0,0,.66) 40%, transparent 100%);
  -webkit-mask-image: linear-gradient(180deg, #000 0%, rgba(0,0,0,.66) 40%, transparent 100%);
}

.people-page-v22 .wrap {
  position: relative;
  z-index: 1;
}

.people-page-v22 .people-team-intro {
  position: relative;
  max-width: none !important;
  margin: 28px 0 36px !important;
  padding: 46px 46px 44px !important;
  border: 1px solid rgba(11,122,59,.16);
  border-radius: 34px;
  background:
    radial-gradient(circle at 82% 22%, rgba(11,122,59,.16), transparent 21%),
    radial-gradient(circle at 94% 74%, rgba(31,120,166,.12), transparent 18%),
    linear-gradient(135deg, rgba(255,255,255,.96) 0%, rgba(244,251,247,.92) 100%);
  box-shadow: 0 26px 70px rgba(7,21,35,.08);
  overflow: hidden;
}

.people-page-v22 .people-team-intro::before {
  content: "";
  position: absolute;
  right: -120px;
  top: -130px;
  width: 360px;
  height: 360px;
  border-radius: 48% 52% 39% 61% / 42% 36% 64% 58%;
  background:
    linear-gradient(135deg, rgba(11,122,59,.15), rgba(31,120,166,.08));
  transform: rotate(-12deg);
}

.people-page-v22 .people-team-intro::after {
  content: "";
  position: absolute;
  right: 62px;
  top: 38px;
  width: 210px;
  height: 210px;
  opacity: .34;
  background:
    repeating-linear-gradient(135deg, rgba(11,122,59,.24) 0 2px, transparent 2px 17px);
  transform: skewX(-14deg) rotate(4deg);
  border-radius: 28px;
}

.people-page-v22 .people-team-intro > * {
  position: relative;
  z-index: 1;
}

.people-page-v22 .people-team-intro .kicker {
  display: inline-flex;
  padding: 9px 14px;
  border-radius: 999px;
  background: #EAF5EF;
  color: #075C2D !important;
  border: 1px solid #CFE9D9;
  box-shadow: 0 10px 22px rgba(11,122,59,.08);
}

.people-page-v22 .people-team-intro h2 {
  max-width: 760px;
  color: #071523 !important;
  text-shadow: 0 1px 0 rgba(255,255,255,.55);
}

.people-page-v22 .people-team-intro h2::after {
  width: 96px !important;
  height: 5px !important;
  background: linear-gradient(90deg, #0B7A3B 0%, #1F78A6 62%, #B79255 100%) !important;
}

.people-page-v22 .people-team-intro p {
  max-width: 700px !important;
  color: #475467 !important;
}

.people-page-v22 .people-cluster-section {
  position: relative !important;
  margin: 0 0 34px !important;
  padding: 30px 30px 34px !important;
  border: 1px solid rgba(11,122,59,.12) !important;
  border-radius: 34px !important;
  background:
    linear-gradient(180deg, rgba(255,255,255,.92) 0%, rgba(250,253,251,.82) 100%) !important;
  box-shadow: 0 18px 54px rgba(7,21,35,.06) !important;
  overflow: hidden;
}

.people-page-v22 .people-cluster-section::before {
  content: "";
  position: absolute;
  inset: 0;
  pointer-events: none;
  opacity: .75;
  background:
    radial-gradient(circle at 0 0, rgba(11,122,59,.08), transparent 18%),
    radial-gradient(circle at 100% 0, rgba(31,120,166,.07), transparent 20%);
}

.people-page-v22 .people-cluster-section::after {
  content: "";
  position: absolute;
  right: -80px;
  bottom: -90px;
  width: 230px;
  height: 230px;
  border-radius: 44% 56% 64% 36% / 62% 36% 64% 38%;
  background: rgba(11,122,59,.055);
  pointer-events: none;
}

.people-page-v22 .people-cluster-head,
.people-page-v22 .people-grid-team-v21,
.people-page-v22 .people-empty {
  position: relative;
  z-index: 1;
}

.people-page-v22 .people-cluster-head {
  margin-bottom: 28px !important;
}

.people-page-v22 .people-cluster-icon {
  color: #fff !important;
  border: 0 !important;
  background: linear-gradient(135deg, #0B7A3B 0%, #1F78A6 100%) !important;
  box-shadow: 0 15px 32px rgba(11,122,59,.20) !important;
}

.people-page-v22 .people-cluster-titleline h2 {
  font-size: 30px !important;
  color: #063D21 !important;
}

.people-page-v22 .people-cluster-titleline span {
  height: 2px !important;
  background: linear-gradient(90deg, rgba(11,122,59,.35), rgba(31,120,166,.12), transparent) !important;
}

.people-page-v22 .people-cluster-titleline p {
  color: #5B6878 !important;
}

.people-page-v22 .people-grid-team-v21 {
  gap: 24px !important;
}

.people-page-v22 .people-card,
.people-page-v22 .people-card-featured {
  position: relative !important;
  min-height: 446px !important;
  border: 1px solid rgba(11,122,59,.15) !important;
  border-radius: 30px !important;
  background:
    linear-gradient(180deg, #FFFFFF 0%, #FBFEFC 100%) !important;
  box-shadow: 0 16px 38px rgba(7,21,35,.065) !important;
  transition: transform .24s ease, box-shadow .24s ease, border-color .24s ease !important;
}

.people-page-v22 .people-card::before {
  content: "";
  position: absolute;
  inset: 0 0 auto 0;
  height: 7px;
  background: linear-gradient(90deg, #0B7A3B, #1F78A6, #B79255);
  opacity: .88;
  z-index: 2;
}

.people-page-v22 .people-card:nth-child(3n+2)::before {
  background: linear-gradient(90deg, #1F78A6, #0B7A3B, #9BBF68);
}

.people-page-v22 .people-card:nth-child(3n+3)::before {
  background: linear-gradient(90deg, #075C2D, #B79255, #1F78A6);
}

.people-page-v22 .people-card:hover {
  transform: translateY(-8px) !important;
  border-color: rgba(11,122,59,.34) !important;
  box-shadow: 0 28px 62px rgba(11,122,59,.13) !important;
}

.people-page-v22 .people-photo-wrap,
.people-page-v22 .people-card-featured .people-photo-wrap {
  height: 204px !important;
  min-height: 204px !important;
  padding-top: 24px !important;
  overflow: hidden !important;
  background:
    radial-gradient(circle at 50% 56%, rgba(255,255,255,.94) 0 33%, transparent 34%),
    radial-gradient(circle at 16% 20%, rgba(11,122,59,.10), transparent 28%),
    radial-gradient(circle at 88% 28%, rgba(31,120,166,.10), transparent 28%),
    linear-gradient(135deg, #F2FBF6 0%, #F9FCFB 100%) !important;
}

.people-page-v22 .people-photo-wrap::before {
  content: "";
  position: absolute;
  left: -44px;
  top: 20px;
  width: 150px;
  height: 150px;
  border-radius: 38% 62% 55% 45% / 50% 38% 62% 50%;
  background: rgba(11,122,59,.10);
  transform: rotate(18deg);
}

.people-page-v22 .people-photo-wrap::after {
  content: "";
  position: absolute;
  right: -36px;
  top: 30px;
  width: 130px;
  height: 130px;
  opacity: .45;
  border-radius: 24px;
  transform: rotate(-12deg) skewX(-12deg);
  background: repeating-linear-gradient(135deg, rgba(31,120,166,.20) 0 2px, transparent 2px 14px);
}

.people-page-v22 .people-photo,
.people-page-v22 .people-card-featured .people-photo {
  width: 152px !important;
  height: 152px !important;
  position: relative !important;
  z-index: 1 !important;
  border: 8px solid #FFFFFF !important;
  outline: 1px solid rgba(11,122,59,.18);
  box-shadow: 0 18px 40px rgba(7,21,35,.15) !important;
}

.people-page-v22 .people-linkedin-icon {
  z-index: 3 !important;
  right: 26px !important;
  bottom: 24px !important;
  background: linear-gradient(135deg, #0A66C2, #0B7A3B) !important;
  box-shadow: 0 12px 24px rgba(10,102,194,.22) !important;
}

.people-page-v22 .people-info-card,
.people-page-v22 .people-card-featured .people-info-card {
  padding: 25px 26px 26px !important;
  border-top: 1px solid rgba(11,122,59,.10) !important;
  background:
    radial-gradient(circle at 100% 100%, rgba(11,122,59,.055), transparent 34%) !important;
}

.people-page-v22 .people-role-chip {
  background: linear-gradient(135deg, #EAF5EF 0%, #F6FAF8 100%) !important;
  border: 1px solid #CFE9D9 !important;
  color: #075C2D !important;
  letter-spacing: .12em !important;
  box-shadow: 0 8px 16px rgba(11,122,59,.065);
}

.people-page-v22 .people-info-card h3 {
  font-size: 24px !important;
  letter-spacing: -.028em !important;
}

.people-page-v22 .people-designation {
  color: #0B7A3B !important;
}

.people-page-v22 .people-bio {
  color: #536174 !important;
}

.people-page-v22 .people-profile-link {
  border: 1px solid #CFE9D9 !important;
  background: #F4FBF7 !important;
  color: #075C2D !important;
  box-shadow: 0 8px 18px rgba(11,122,59,.06);
}

.people-page-v22 .people-profile-link:hover {
  background: linear-gradient(135deg, #0B7A3B, #075C2D) !important;
  color: #fff !important;
  box-shadow: 0 12px 24px rgba(11,122,59,.18);
}

.people-page-v22 .people-mini-linkedin {
  background: linear-gradient(135deg, #0A66C2, #0B7A3B) !important;
}

/* Softer, more professional single people profile page */
.people-single-page {
  background:
    radial-gradient(circle at 88% 8%, rgba(11,122,59,.08), transparent 25%),
    linear-gradient(180deg, #fff 0%, #F7FCFA 100%) !important;
}

.people-profile-panel {
  position: relative !important;
  overflow: hidden !important;
  border-radius: 34px !important;
  border: 1px solid rgba(11,122,59,.16) !important;
  background:
    radial-gradient(circle at 6% 12%, rgba(11,122,59,.08), transparent 24%),
    linear-gradient(135deg, #FFFFFF 0%, #F8FCFA 100%) !important;
  box-shadow: 0 26px 70px rgba(7,21,35,.08) !important;
}

.people-profile-panel::before {
  content: "";
  position: absolute;
  right: -120px;
  top: -110px;
  width: 320px;
  height: 320px;
  border-radius: 42% 58% 48% 52% / 54% 44% 56% 46%;
  background: rgba(11,122,59,.07);
}

.people-profile-photo-area {
  background:
    radial-gradient(circle at 50% 52%, #FFFFFF 0 35%, transparent 36%),
    linear-gradient(135deg, #EAF5EF, #F8FCFA) !important;
  border-radius: 28px !important;
  min-height: 360px !important;
}

.people-profile-photo {
  border-radius: 50% !important;
  border: 9px solid #fff !important;
  box-shadow: 0 20px 46px rgba(7,21,35,.18) !important;
}

.people-profile-copy h2 {
  color: #071523 !important;
}

.people-profile-copy h2::after {
  background: linear-gradient(90deg, #0B7A3B, #1F78A6, #B79255) !important;
}

@media(max-width: 760px) {
  .people-page-v22 .people-team-intro {
    padding: 32px 24px !important;
    border-radius: 26px !important;
  }
  .people-page-v22 .people-cluster-section {
    padding: 24px 18px 26px !important;
    border-radius: 26px !important;
  }
  .people-page-v22 .people-team-intro::after,
  .people-page-v22 .people-team-intro::before {
    opacity: .25;
  }
}

/* V24 Careers page - colorful abstract corporate design */
.career-hero {
  position: relative;
  overflow: hidden;
  padding: 96px 0 82px;
  background:
    radial-gradient(circle at 14% 12%, rgba(11,122,59,.18), transparent 26%),
    radial-gradient(circle at 88% 20%, rgba(31,120,166,.14), transparent 28%),
    linear-gradient(135deg,#F7FCF9 0%,#FFFFFF 48%,#EAF5EF 100%);
  border-bottom: 1px solid #DDEFE5;
}
.career-hero::before {
  content: "";
  position: absolute;
  right: -130px;
  top: -110px;
  width: 520px;
  height: 520px;
  border-radius: 50%;
  background: conic-gradient(from 130deg, rgba(11,122,59,.18), rgba(31,120,166,.12), rgba(183,146,85,.10), rgba(11,122,59,.18));
  filter: blur(.2px);
}
.career-hero::after {
  content: "";
  position: absolute;
  inset: 0;
  opacity: .22;
  background-image:
    linear-gradient(115deg, transparent 0 14%, rgba(11,122,59,.25) 14.15% 14.35%, transparent 14.55% 28%),
    radial-gradient(circle at 76% 66%, rgba(11,122,59,.16) 0 2px, transparent 2.5px);
  background-size: 220px 360px, 24px 24px;
  pointer-events: none;
}
.career-hero-inner {
  position: relative;
  z-index: 1;
  display: grid;
  grid-template-columns: 1.02fr .98fr;
  gap: 48px;
  align-items: center;
}
.career-eyebrow {
  display: inline-flex;
  align-items: center;
  gap: 9px;
  padding: 9px 14px;
  border-radius: 999px;
  background: #EAF5EF;
  color: var(--green-dark);
  border: 1px solid #CFE9D9;
  font-size: 12px;
  font-weight: 900;
  letter-spacing: .14em;
  text-transform: uppercase;
}
.career-eyebrow::before {
  content: "";
  width: 9px;
  height: 9px;
  border-radius: 50%;
  background: var(--green);
  box-shadow: 0 0 0 6px rgba(11,122,59,.10);
}
.career-hero h1 {
  color: var(--navy);
  font-size: clamp(48px, 6vw, 82px);
  line-height: .98;
  letter-spacing: -.065em;
  margin: 22px 0 22px;
  max-width: 760px;
}
.career-hero p {
  margin: 0;
  color: #475467;
  font-size: 19px;
  line-height: 1.7;
  max-width: 720px;
}
.career-hero-actions {
  display: flex;
  gap: 12px;
  flex-wrap: wrap;
  margin-top: 30px;
}
.career-hero-visual {
  position: relative;
  min-height: 430px;
  border-radius: 42px;
  border: 1px solid rgba(11,122,59,.18);
  background:
    linear-gradient(135deg, rgba(255,255,255,.86), rgba(255,255,255,.58)),
    radial-gradient(circle at 36% 28%, rgba(11,122,59,.25), transparent 26%),
    linear-gradient(135deg,#EAF5EF,#F8FCFA);
  box-shadow: 0 24px 70px rgba(7,21,35,.12);
  overflow: hidden;
}
.career-hero-visual::before {
  content: "";
  position: absolute;
  inset: 48px -80px auto auto;
  width: 520px;
  height: 180px;
  border-radius: 50%;
  border: 28px solid rgba(11,122,59,.12);
  transform: rotate(-18deg);
}
.career-hero-visual::after {
  content: "";
  position: absolute;
  left: -80px;
  bottom: -60px;
  width: 320px;
  height: 320px;
  border-radius: 50%;
  background: rgba(31,120,166,.10);
}
.career-orbit {
  position: absolute;
  border: 1px solid rgba(11,122,59,.20);
  border-radius: 50%;
}
.career-orbit-one { width: 240px; height: 240px; top: 58px; left: 58px; }
.career-orbit-two { width: 340px; height: 340px; right: -40px; bottom: -80px; }
.career-stat-card {
  position: absolute;
  z-index: 2;
  width: 210px;
  padding: 22px;
  background: rgba(255,255,255,.86);
  border: 1px solid rgba(227,239,232,.9);
  border-radius: 24px;
  box-shadow: 0 18px 42px rgba(7,21,35,.10);
  backdrop-filter: blur(12px);
}
.career-stat-card strong {
  display: block;
  color: var(--navy);
  font-size: 24px;
  line-height: 1.05;
  margin-bottom: 8px;
}
.career-stat-card span { color: #667085; font-weight: 700; font-size: 14px; }
.career-stat-card-one { top: 58px; right: 64px; }
.career-stat-card-two { left: 54px; bottom: 92px; }
.career-stat-card-three { right: 92px; bottom: 48px; }
.career-culture-section {
  padding: 58px 0 24px;
  background: #fff;
}
.career-culture-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0,1fr));
  gap: 18px;
}
.career-culture-card {
  position: relative;
  overflow: hidden;
  border: 1px solid #E3EFE8;
  border-radius: 28px;
  padding: 26px;
  background: #fff;
  box-shadow: 0 14px 34px rgba(7,21,35,.05);
}
.career-culture-card::after {
  content: "";
  position: absolute;
  right: -58px;
  top: -58px;
  width: 160px;
  height: 160px;
  border-radius: 50%;
  opacity: .28;
}
.career-culture-card.accent-green::after { background: var(--green); }
.career-culture-card.accent-teal::after { background: var(--blue); }
.career-culture-card.accent-gold::after { background: var(--gold); }
.career-culture-card span {
  display: inline-grid;
  place-items: center;
  width: 46px;
  height: 46px;
  border-radius: 16px;
  background: #EAF5EF;
  color: var(--green);
  font-weight: 900;
  margin-bottom: 18px;
}
.career-culture-card h3 {
  margin: 0 0 10px;
  color: var(--navy);
  font-size: 24px;
  letter-spacing: -.025em;
}
.career-culture-card p { margin: 0; color: #667085; line-height: 1.65; }
.career-openings-section {
  padding: 54px 0 90px;
  background:
    radial-gradient(circle at 0 30%, rgba(11,122,59,.08), transparent 24%),
    linear-gradient(180deg,#FFFFFF 0%,#F7FCF9 100%);
}
.career-section-title {
  display: flex;
  align-items: flex-end;
  justify-content: space-between;
  gap: 26px;
  margin-bottom: 24px;
}
.career-section-title h2 {
  margin: 8px 0 0;
  color: var(--navy);
  font-size: 42px;
  line-height: 1.08;
  letter-spacing: -.04em;
}
.career-section-title p { margin: 0; color: #667085; max-width: 560px; }
.career-filter-panel {
  display: grid;
  grid-template-columns: 1.4fr repeat(3, .85fr) auto;
  gap: 12px;
  background: #fff;
  border: 1px solid #DDEFE5;
  border-radius: 24px;
  padding: 18px;
  box-shadow: 0 14px 34px rgba(7,21,35,.05);
  margin-bottom: 22px;
}
.career-filter-panel input,
.career-filter-panel select {
  border: 1px solid #D0D5DD;
  border-radius: 16px;
  padding: 13px 14px;
  min-height: 48px;
  font-family: inherit;
  background: #fff;
  font-size: 14px;
}
.career-job-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0,1fr));
  gap: 22px;
}
.career-job-card,
.career-empty-card {
  position: relative;
  overflow: hidden;
  background: #fff;
  border: 1px solid #E3EFE8;
  border-radius: 28px;
  padding: 26px;
  box-shadow: 0 14px 34px rgba(7,21,35,.06);
  transition: transform .22s ease, box-shadow .22s ease, border-color .22s ease;
}
.career-job-card::before {
  content: "";
  position: absolute;
  inset: 0 0 auto 0;
  height: 7px;
  background: linear-gradient(90deg, var(--green), #4CAF7A, var(--blue));
}
.career-job-card::after {
  content: "";
  position: absolute;
  right: -54px;
  bottom: -68px;
  width: 180px;
  height: 180px;
  border-radius: 50%;
  background: rgba(11,122,59,.08);
}
.career-job-card:hover {
  transform: translateY(-6px);
  border-color: rgba(11,122,59,.42);
  box-shadow: 0 24px 54px rgba(11,122,59,.13);
}
.career-job-topline {
  position: relative;
  z-index: 1;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  margin-bottom: 18px;
}
.career-job-topline span,
.career-job-topline small {
  display: inline-flex;
  align-items: center;
  min-height: 30px;
  padding: 7px 11px;
  border-radius: 999px;
  background: #EAF5EF;
  color: var(--green-dark);
  border: 1px solid #DDEFE5;
  font-size: 12px;
  font-weight: 900;
}
.career-job-card h3 {
  position: relative;
  z-index: 1;
  margin: 0 0 12px;
  color: var(--navy);
  font-size: 26px;
  line-height: 1.15;
  letter-spacing: -.025em;
}
.career-job-card p {
  position: relative;
  z-index: 1;
  color: #667085;
  margin: 0 0 18px;
  line-height: 1.62;
}
.career-job-meta {
  position: relative;
  z-index: 1;
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-bottom: 22px;
}
.career-job-meta span {
  padding: 7px 10px;
  border-radius: 999px;
  background: #F8FCFA;
  border: 1px solid #E3EFE8;
  color: #344054;
  font-size: 12px;
  font-weight: 800;
}
.career-job-link {
  position: relative;
  z-index: 1;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 44px;
  padding: 0 18px;
  border-radius: 999px;
  background: var(--green);
  color: #fff;
  text-decoration: none;
  font-weight: 900;
}
.career-job-link:hover { background: var(--green-dark); color: #fff; }
.career-status { color: #667085; margin: 14px 0 0; }
.career-single-hero {
  padding: 76px 0;
  background:
    radial-gradient(circle at 80% 15%, rgba(11,122,59,.15), transparent 25%),
    linear-gradient(135deg,#F7FCF9,#FFFFFF 58%,#EAF5EF);
  border-bottom: 1px solid #DDEFE5;
}
.career-single-hero-inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 28px;
}
.career-single-hero h1 {
  color: var(--navy);
  font-size: clamp(42px,5vw,66px);
  line-height: 1.02;
  letter-spacing: -.055em;
  margin: 18px 0;
}
.career-single-hero p { color: #667085; font-size: 18px; max-width: 760px; margin: 0; }
.career-single-section { padding: 72px 0; background: #fff; }
.career-single-layout {
  display: grid;
  grid-template-columns: 340px 1fr;
  gap: 26px;
  align-items: start;
}
.career-single-sidebar {
  position: sticky;
  top: 130px;
  border: 1px solid #DDEFE5;
  border-radius: 28px;
  background: #fff;
  padding: 24px;
  box-shadow: 0 14px 34px rgba(7,21,35,.06);
  display: grid;
  gap: 16px;
}
.career-single-sidebar h3 { margin: 0; color: var(--navy); font-size: 24px; }
.career-summary-list { display: grid; gap: 10px; }
.career-summary-list span {
  display: grid;
  gap: 4px;
  padding-bottom: 10px;
  border-bottom: 1px solid #EEF2F5;
  color: #667085;
  font-size: 12px;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: .08em;
}
.career-summary-list strong {
  color: var(--navy);
  font-size: 15px;
  text-transform: none;
  letter-spacing: 0;
}
.career-single-content {
  font-size: 17px;
  line-height: 1.75;
}
.career-single-content h2,
.career-single-content h3 { color: var(--navy); }
@media(max-width: 1080px) {
  .career-hero-inner,
  .career-single-layout { grid-template-columns: 1fr; }
  .career-hero-visual { min-height: 340px; }
  .career-job-grid { grid-template-columns: repeat(2,minmax(0,1fr)); }
  .career-filter-panel { grid-template-columns: 1fr 1fr; }
  .career-single-sidebar { position: static; }
}
@media(max-width: 760px) {
  .career-hero { padding: 62px 0; }
  .career-culture-grid,
  .career-job-grid,
  .career-filter-panel { grid-template-columns: 1fr; }
  .career-section-title,
  .career-single-hero-inner { display: grid; }
  .career-stat-card { position: relative; inset: auto !important; width: auto; margin: 14px; }
  .career-hero-visual { min-height: auto; display: grid; padding: 18px; }
}

/* V25 public contact and careers cleanup */
.contact-public-section {
  padding: 78px 0;
  background:
    radial-gradient(circle at 85% 10%, rgba(11,122,59,.08), transparent 32%),
    linear-gradient(180deg,#FFFFFF 0%,#F7FCF9 100%);
}
.contact-public-grid {
  display: grid;
  grid-template-columns: 1.2fr 1fr 1fr;
  gap: 22px;
  align-items: stretch;
}
.contact-public-card {
  background: #fff;
  border: 1px solid #E3EFE8;
  border-radius: 28px;
  padding: 28px;
  box-shadow: 0 14px 34px rgba(7,21,35,.06);
}
.contact-public-main {
  grid-row: span 2;
  display: flex;
  flex-direction: column;
  justify-content: center;
  background:
    linear-gradient(135deg, rgba(11,122,59,.95), rgba(13,34,53,.92)),
    radial-gradient(circle at 78% 18%, rgba(255,255,255,.18), transparent 32%);
  color: #fff;
}
.contact-public-main .kicker { color: #DFF8E9 !important; }
.contact-public-main h2 {
  margin: 12px 0 16px;
  color: #fff;
  font-size: 44px;
  line-height: 1.05;
  letter-spacing: -.04em;
}
.contact-public-main p { color: #EAF8EF; font-size: 17px; line-height: 1.7; }
.contact-public-card h3 {
  margin: 0 0 10px;
  color: var(--navy);
  font-size: 24px;
}
.contact-public-card p { color: #667085; margin: 0 0 16px; }
.contact-public-card a:not(.btn) { color: var(--green); font-weight: 900; text-decoration: none; word-break: break-word; }
.contact-public-card a:not(.btn):hover { text-decoration: underline; }
.contact-public-extra { margin-top: 22px; }
.career-apply-note {
  margin: 16px 0;
  padding: 14px 16px;
  border-radius: 16px;
  background: #F2FBF6;
  border: 1px solid #DDEFE5;
  color: #344054;
  font-size: 14px;
  line-height: 1.5;
}
.career-apply-note a { color: var(--green); font-weight: 900; text-decoration: none; }
.career-apply-note a:hover { text-decoration: underline; }
@media(max-width:980px) {
  .contact-public-grid { grid-template-columns: 1fr; }
  .contact-public-main { grid-row: auto; }
}

/* ===== V26 About page redesign ===== */
.about-overview-page {
  background: linear-gradient(180deg, #F6FBF8 0%, #FFFFFF 18%, #F9FCFA 100%);
}
.about-hero-band {
  position: relative;
  overflow: hidden;
  color: #fff;
  background:
    radial-gradient(circle at 84% 18%, rgba(10, 166, 120, .22), transparent 32%),
    radial-gradient(circle at 14% 80%, rgba(20, 148, 96, .18), transparent 26%),
    linear-gradient(120deg, #051A2D 0%, #042545 46%, #0B5D45 100%);
}
.about-hero-band::before {
  content: "";
  position: absolute;
  inset: 0;
  background:
    linear-gradient(125deg, transparent 0 14%, rgba(255,255,255,.08) 14.3% 14.6%, transparent 15% 31%),
    linear-gradient(95deg, transparent 0 12%, rgba(255,255,255,.06) 12.15% 12.35%, transparent 12.5% 36%);
  background-size: 260px 260px, 340px 340px;
  opacity: .55;
}
.about-hero-grid {
  position: relative;
  z-index: 1;
  display: grid;
  grid-template-columns: 1.1fr .9fr;
  gap: 40px;
  align-items: center;
  padding: 72px 0 64px;
}
.about-kicker,
.section-kicker {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 9px 14px;
  border-radius: 999px;
  font-size: 12px;
  font-weight: 900;
  letter-spacing: .08em;
  text-transform: uppercase;
}
.about-kicker {
  color: #E6FFF0;
  background: rgba(234,245,239,.12);
  border: 1px solid rgba(234,245,239,.24);
  margin-bottom: 20px;
}
.section-kicker {
  color: var(--green);
  background: #EAF6EF;
  margin-bottom: 14px;
}
.about-hero-copy h1 {
  margin: 0 0 6px;
  font-size: 64px;
  line-height: .98;
  letter-spacing: -.05em;
  color: #fff;
}
.about-hero-copy h2 {
  margin: 0 0 18px;
  font-size: 28px;
  line-height: 1.1;
  color: #60DE8F;
  letter-spacing: -.03em;
}
.about-hero-copy p {
  margin: 0;
  max-width: 690px;
  font-size: 18px;
  line-height: 1.8;
  color: #E7EEF6;
}
.about-hero-stats {
  display: grid;
  grid-template-columns: repeat(2, minmax(0,1fr));
  gap: 16px;
  padding: 20px;
  border-radius: 30px;
  background: rgba(255,255,255,.06);
  border: 1px solid rgba(255,255,255,.12);
  box-shadow: 0 24px 50px rgba(3, 18, 36, .22);
  backdrop-filter: blur(10px);
}
.about-stat-card {
  min-height: 150px;
  border-radius: 22px;
  padding: 22px;
  background: rgba(255,255,255,.04);
  border: 1px solid rgba(255,255,255,.1);
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
}
.about-stat-label {
  display: block;
  margin-bottom: 12px;
  color: #CFEADF;
  font-size: 14px;
  line-height: 1.5;
}
.about-stat-card strong {
  display: block;
  font-size: 36px;
  line-height: 1.04;
  letter-spacing: -.04em;
  color: #fff;
}
.about-story-section,
.about-capability-section,
.about-timeline-section,
.about-values-section,
.about-final-cta {
  padding: 72px 0;
}
.about-story-grid {
  display: grid;
  grid-template-columns: 1fr .95fr;
  gap: 42px;
  align-items: center;
}
.about-story-copy h2,
.about-section-heading h2,
.about-final-cta h2 {
  margin: 0 0 16px;
  color: var(--navy);
  font-size: 44px;
  line-height: 1.05;
  letter-spacing: -.04em;
}
.about-story-copy p,
.about-final-cta p {
  margin: 0 0 18px;
  color: #475467;
  font-size: 17px;
  line-height: 1.8;
}
.about-story-visual {
  position: relative;
  min-height: 360px;
}
.about-visual-glow {
  position: absolute;
  inset: 20px 22px 34px;
  border-radius: 30px;
  background: radial-gradient(circle at 18% 18%, rgba(44, 181, 122, .35), transparent 34%), linear-gradient(135deg, rgba(8,35,60,.98) 0%, rgba(7,95,69,.88) 100%);
  box-shadow: var(--shadow);
}
.about-visual-card {
  position: absolute;
  inset: 0;
  border-radius: 30px;
  overflow: hidden;
  border: 1px solid #D7E8DE;
  background: linear-gradient(135deg, rgba(255,255,255,.08), rgba(255,255,255,.02));
}
.about-visual-card::before,
.about-visual-card::after {
  content: "";
  position: absolute;
  border-radius: 50%;
}
.about-visual-card::before {
  width: 240px;
  height: 240px;
  right: -40px;
  bottom: -46px;
  background: rgba(255,255,255,.09);
}
.about-visual-card::after {
  width: 130px;
  height: 130px;
  left: 24px;
  top: 28px;
  background: rgba(96,222,143,.16);
}
.about-visual-mini {
  position: absolute;
  left: 36px;
  right: 36px;
  top: 54px;
  height: 116px;
  border-radius: 22px;
  background: rgba(255,255,255,.12);
  border: 1px solid rgba(255,255,255,.16);
}
.about-visual-lines {
  position: absolute;
  left: 36px;
  right: 36px;
  bottom: 48px;
  height: 110px;
  border-radius: 20px;
  background:
    linear-gradient(180deg, rgba(255,255,255,.16) 0 12px, transparent 12px 100%),
    linear-gradient(90deg, rgba(255,255,255,.22) 0 36%, transparent 36% 40%, rgba(255,255,255,.16) 40% 100%);
  opacity: .88;
}
.about-visual-badge {
  position: absolute;
  top: 92px;
  left: 58px;
  padding: 10px 14px;
  border-radius: 999px;
  background: #EAF6EF;
  color: var(--green);
  font-size: 12px;
  font-weight: 900;
  letter-spacing: .12em;
}
.about-section-heading.center {
  text-align: center;
  margin-bottom: 28px;
}
.about-section-heading.center .section-kicker {
  margin-left: auto;
  margin-right: auto;
}
.about-capability-grid,
.about-values-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0,1fr));
  gap: 22px;
}
.about-capability-card,
.about-value-card {
  padding: 26px 24px;
  border-radius: 24px;
  background: #fff;
  border: 1px solid #E5EEE8;
  box-shadow: 0 8px 24px rgba(7,21,35,.05);
}
.about-capability-card h3,
.about-value-card h3 {
  margin: 0 0 12px;
  font-size: 22px;
  line-height: 1.15;
  color: var(--navy);
}
.about-capability-card p,
.about-value-card p {
  margin: 0;
  color: #667085;
  font-size: 15px;
  line-height: 1.7;
}
.about-timeline {
  position: relative;
  display: grid;
  grid-template-columns: repeat(4, minmax(0,1fr));
  gap: 24px;
}
.about-timeline::before {
  content: "";
  position: absolute;
  left: 6%;
  right: 6%;
  top: 23px;
  height: 3px;
  border-radius: 999px;
  background: linear-gradient(90deg, #A7D7BA 0%, #0B7A3B 50%, #A7D7BA 100%);
}
.about-timeline-item {
  position: relative;
  padding-top: 0;
  text-align: center;
}
.about-timeline-dot {
  width: 48px;
  height: 48px;
  margin: 0 auto 18px;
  border-radius: 50%;
  border: 6px solid #F1FBF5;
  background: linear-gradient(135deg, #0B7A3B 0%, #24A85E 100%);
  box-shadow: 0 0 0 1px #B7DEC5;
  position: relative;
  z-index: 1;
}
.about-timeline-date {
  display: inline-block;
  margin-bottom: 10px;
  color: var(--green);
  font-size: 13px;
  font-weight: 900;
  letter-spacing: .08em;
  text-transform: uppercase;
}
.about-timeline-item h3 {
  margin: 0 0 10px;
  color: var(--navy);
  font-size: 22px;
  line-height: 1.15;
}
.about-timeline-item p {
  margin: 0 auto;
  max-width: 260px;
  color: #667085;
  font-size: 15px;
  line-height: 1.7;
}
.about-final-cta {
  color: #fff;
}
.about-cta-shell {
  display: grid;
  grid-template-columns: 1.1fr .9fr;
  gap: 30px;
  align-items: center;
  padding: 38px 40px;
  border-radius: 30px;
  background:
    radial-gradient(circle at 88% 18%, rgba(42, 173, 123, .22), transparent 30%),
    linear-gradient(130deg, #06192B 0%, #072C4A 48%, #0B6147 100%);
  box-shadow: var(--shadow);
}
.about-final-cta h2,
.about-final-cta p { color: #fff; }
.about-final-cta p { color: #DCE8F3; margin-bottom: 0; }
.about-cta-actions {
  display: flex;
  justify-content: flex-end;
  gap: 14px;
  flex-wrap: wrap;
}
@media (max-width: 1100px) {
  .about-hero-grid,
  .about-story-grid,
  .about-cta-shell,
  .about-capability-grid,
  .about-values-grid,
  .about-timeline {
    grid-template-columns: 1fr 1fr;
  }
  .about-story-visual { min-height: 320px; }
}
@media (max-width: 760px) {
  .about-hero-grid,
  .about-story-grid,
  .about-capability-grid,
  .about-values-grid,
  .about-timeline,
  .about-cta-shell {
    grid-template-columns: 1fr;
  }
  .about-hero-copy h1 { font-size: 48px; }
  .about-story-copy h2,
  .about-section-heading h2,
  .about-final-cta h2 { font-size: 34px; }
  .about-timeline::before { display: none; }
  .about-story-section,
  .about-capability-section,
  .about-timeline-section,
  .about-values-section,
  .about-final-cta { padding: 54px 0; }
  .about-hero-stats { grid-template-columns: 1fr; }
  .about-story-visual { min-height: 280px; }
  .about-cta-actions { justify-content: flex-start; }
}

/* ===== V28 footer and rating symbol cleanup ===== */
.waso-simple-footer {
  background: #F2F8F4;
  color: var(--navy);
  padding: 44px 0 22px;
  border-top: 1px solid #DDEDE4;
}
.footer-contact-cards {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 24px;
  align-items: stretch;
}
.footer-contact-card {
  min-height: 172px;
  padding: 26px 24px;
  border-radius: 24px;
  background: linear-gradient(135deg, #0B7A3B 0%, #49B34F 100%);
  color: #fff;
  box-shadow: 0 16px 38px rgba(7, 92, 45, .16);
  text-align: center;
}
.footer-contact-card:nth-child(2) {
  background: linear-gradient(135deg, #087044 0%, #4CB65B 100%);
}
.footer-contact-card:nth-child(3) {
  background: linear-gradient(135deg, #0A6943 0%, #55B656 100%);
}
.footer-contact-icon {
  width: 52px;
  height: 52px;
  display: grid;
  place-items: center;
  margin: 0 auto 14px;
  border-radius: 16px;
  background: rgba(255,255,255,.18);
  color: #fff;
  font-size: 28px;
  font-weight: 900;
}
.footer-contact-card h4 {
  color: #fff;
  margin: 0 0 10px;
  font-size: 18px;
  line-height: 1.2;
}
.footer-contact-card p,
.footer-contact-card a,
.footer-contact-card span {
  color: #fff;
  margin: 4px 0;
  font-size: 14px;
  line-height: 1.55;
  text-decoration: none;
  display: block;
  word-break: break-word;
}
.footer-contact-card a:hover {
  color: #fff;
  text-decoration: underline;
}
.simple-footer-bottom {
  justify-content: center;
  color: #475467;
  border-top-color: #D6E8DD;
  margin-top: 24px;
  padding-top: 18px;
}
.waso-rating-symbol-table th:first-child,
.waso-rating-symbol-table td:first-child {
  width: 210px;
  text-align: center;
  font-weight: 900;
  color: var(--navy);
}
.symbol-head {
  text-align: center;
}
.symbol-table thead th {
  background: #C8DCA9;
  color: #071523;
}
.symbol-section .symbol-head {
  background: #4C7F31;
  color: #fff;
}
@media(max-width: 860px) {
  .footer-contact-cards { grid-template-columns: 1fr; }
}

/* ===== V29 footer and Rating Symbol refinements ===== */
.footer-contact-only-grid {
  grid-template-columns: 1.1fr 1.25fr 1fr 1.35fr;
}
.footer-contact-only-grid .footer-contact-box {
  background: rgba(255,255,255,.045);
  border-color: rgba(255,255,255,.09);
}
.footer-contact-only-grid .footer-contact-box b {
  color: #fff;
}
.footer-contact-only-grid .footer-contact-box span,
.footer-contact-only-grid .footer-contact-box a {
  color: #D0D7DE;
}
@media(max-width:980px) {
  .footer-contact-only-grid { grid-template-columns: 1fr 1fr; }
}
@media(max-width:720px) {
  .footer-contact-only-grid { grid-template-columns: 1fr; }
}

/* ===== V30 compact footer and clean rating symbol layout ===== */
.compact-footer {
  background: #030406;
  color: #D0D7DE;
  padding: 22px 0;
  border-top: 1px solid rgba(255,255,255,.08);
}
.compact-footer-inner {
  display: grid;
  grid-template-columns: 1.6fr .8fr 1fr;
  gap: 22px;
  align-items: start;
}
.compact-footer-item {
  min-width: 0;
}
.compact-footer-item strong {
  display: block;
  margin: 0 0 6px;
  color: #fff;
  font-size: 13px;
  line-height: 1.2;
  letter-spacing: .08em;
  text-transform: uppercase;
}
.compact-footer-item span,
.compact-footer-item a {
  display: block;
  margin: 2px 0;
  color: #D0D7DE;
  font-size: 14px;
  line-height: 1.55;
  text-decoration: none;
  word-break: break-word;
}
.compact-footer-item a:hover {
  color: #fff;
  text-decoration: underline;
}
.rating-symbol-clean-page .body-card {
  box-shadow: var(--shadow-soft);
}
.rating-symbol-card h2::after,
.rating-symbol-clean-page h2::after,
.rating-symbol-clean-page .page-hero h1::after {
  display: none !important;
  content: none !important;
}
.rating-symbol-table-card {
  border-radius: 18px;
  border: 1px solid var(--line);
  overflow: hidden;
  margin-top: 16px;
}
.rating-symbol-clean-table th {
  background: #F8FAFC !important;
  color: #344054 !important;
  font-size: 12px;
  letter-spacing: .06em;
  text-transform: uppercase;
}
.rating-symbol-clean-table th:first-child,
.rating-symbol-clean-table td:first-child {
  width: 210px;
  text-align: center;
  font-weight: 900;
  color: var(--navy);
}
.rating-symbol-clean-table tr:hover td {
  background: #F8FCFA;
}
@media(max-width: 860px) {
  .compact-footer-inner { grid-template-columns: 1fr; gap: 14px; }
  .compact-footer { padding: 20px 0; }
}

/* ===== V32 responsive polish and cleanup ===== */
img,
video,
iframe,
embed,
object {
  max-width: 100%;
}
iframe,
embed,
object {
  border: 0;
}
.pdf-preview iframe,
.report-pdf-preview iframe,
.magazine-pdf-preview iframe,
.methodology-pdf-preview iframe,
.page-pdf-embed iframe {
  width: 100%;
  min-height: 76vh;
  border-radius: 18px;
  background: #F8FAFC;
}
.table-card,
.symbol-section,
.rating-updates-table-wrap,
.report-list-table-wrap {
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
}
.table-card table,
.symbol-table,
.rating-updates-table {
  min-width: 720px;
}
.compact-footer {
  padding: 18px 0 !important;
}
.compact-footer-inner {
  align-items: start !important;
}
.compact-footer-item {
  min-width: 0;
}
.compact-footer-item span,
.compact-footer-item a {
  overflow-wrap: anywhere;
}
@media (max-width: 1280px) {
  .wrap {
    width: min(1120px, 94vw);
  }
  .site-header.moody-green-style .main-menu {
    gap: 24px !important;
  }
  .site-header.moody-green-style .menu-link {
    font-size: 14.5px !important;
  }
  .hero-grid,
  .about-hero-grid,
  .career-hero-inner {
    gap: 32px !important;
  }
}
@media (max-width: 1080px) {
  .section-title,
  .rating-news-head,
  .career-section-title {
    display: grid !important;
    align-items: start !important;
  }
  .hero-grid,
  .insight-grid,
  .service-hero-inner,
  .contact-panel,
  .inside-credit-grid,
  .about-hero-grid,
  .about-story-grid,
  .career-hero-inner,
  .career-culture-grid,
  .magazine-latest-card,
  .people-profile-layout,
  .contact-public-grid {
    grid-template-columns: 1fr !important;
  }
  .quick-search {
    max-width: 100% !important;
  }
  .product-grid,
  .service-directory,
  .research-support-grid,
  .magazine-month-grid,
  .career-job-grid,
  .people-grid,
  .rating-list-archive-grid,
  .methodology-grid,
  .about-capability-grid,
  .about-values-grid,
  .about-timeline {
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  }
  .director-card {
    grid-template-columns: 240px 1fr !important;
  }
  .magazine-filter-row,
  .career-filter-panel,
  .rating-filter-row {
    grid-template-columns: 1fr 1fr !important;
  }
  .compact-footer-inner {
    grid-template-columns: 1fr 1fr !important;
    gap: 14px 22px !important;
  }
}
@media (max-width: 860px) {
  .site-header.moody-green-style .top-contact-pill {
    display: none !important;
  }
  .site-header.moody-green-style .header-top-inner {
    grid-template-columns: 1fr auto !important;
  }
  .brand,
  .site-header.moody-green-style .brand {
    min-width: 0 !important;
  }
  .brand-title,
  .site-header.moody-green-style .brand-title {
    font-size: 20px !important;
  }
  .brand-sub,
  .site-header.moody-green-style .brand-sub {
    max-width: 210px;
    white-space: normal !important;
  }
  .hero h1,
  .about-hero-copy h1,
  .career-hero-copy h1,
  .page-hero h1 {
    font-size: clamp(36px, 9vw, 54px) !important;
    letter-spacing: -.04em !important;
  }
  .section-title h2,
  .product-head h2,
  .rating-news-head h2,
  .about-story-copy h2,
  .about-section-heading h2,
  .career-section-title h2,
  .page-hero h2,
  .service-copy h2 {
    font-size: clamp(30px, 7vw, 40px) !important;
  }
  .director-card,
  .people-featured-card {
    grid-template-columns: 1fr !important;
  }
  .director-photo,
  .director-placeholder {
    min-height: 260px !important;
    height: 260px !important;
  }
  .pdf-preview iframe,
  .report-pdf-preview iframe,
  .magazine-pdf-preview iframe,
  .methodology-pdf-preview iframe,
  .page-pdf-embed iframe {
    min-height: 64vh;
  }
}
@media (max-width: 640px) {
  .wrap {
    width: min(100% - 32px, 1180px);
  }
  section,
  .page-view,
  .about-story-section,
  .about-capability-section,
  .about-timeline-section,
  .about-values-section,
  .about-final-cta,
  .career-openings-section,
  .career-culture-section {
    padding: 46px 0 !important;
  }
  .hero-grid,
  .about-hero-grid,
  .career-hero-inner {
    padding: 38px 0 42px !important;
  }
  .hero-actions,
  .service-actions,
  .magazine-latest-actions,
  .career-hero-actions,
  .about-cta-actions {
    display: grid !important;
    grid-template-columns: 1fr !important;
    width: 100%;
  }
  .hero-actions .btn,
  .service-actions .btn,
  .magazine-latest-actions .btn,
  .career-hero-actions .btn,
  .about-cta-actions .btn {
    width: 100%;
  }
  .product-grid,
  .service-directory,
  .research-support-grid,
  .magazine-month-grid,
  .career-job-grid,
  .people-grid,
  .rating-list-archive-grid,
  .methodology-grid,
  .about-capability-grid,
  .about-values-grid,
  .about-timeline,
  .benefit-grid,
  .approach-steps,
  .service-section-grid,
  .magazine-filter-row,
  .career-filter-panel,
  .rating-filter-row,
  .contact-actions,
  .inside-credit-cards,
  .mini-tabs,
  .compact-footer-inner {
    grid-template-columns: 1fr !important;
  }
  .quick-search,
  .body-card,
  .fresh-card,
  .service-copy,
  .contact-copy,
  .inside-credit-main,
  .about-cta-shell,
  .career-job-card,
  .magazine-latest-card,
  .people-card,
  .rating-list-card {
    padding: 22px !important;
    border-radius: 22px !important;
  }
  .search-row {
    display: grid !important;
    grid-template-columns: 1fr !important;
  }
  .search-row .btn,
  .career-filter-panel .btn,
  .rating-filter-row .btn {
    width: 100% !important;
  }
  .product-track .product-card {
    width: calc(100vw - 64px) !important;
    flex-basis: calc(100vw - 64px) !important;
  }
  .rating-news-card {
    width: calc(100vw - 64px) !important;
  }
  .mobile-drawer {
    width: min(94vw, 390px) !important;
  }
  .footer-bottom,
  .compact-footer-inner {
    text-align: left;
  }
  .compact-footer-item {
    gap: 5px;
  }
  .pdf-preview iframe,
  .report-pdf-preview iframe,
  .magazine-pdf-preview iframe,
  .methodology-pdf-preview iframe,
  .page-pdf-embed iframe {
    min-height: 58vh;
    border-radius: 14px;
  }
}
@media (max-width: 420px) {
  .wrap {
    width: min(100% - 24px, 1180px);
  }
  .brand-logo,
  .site-header.moody-green-style .brand-logo {
    width: 50px !important;
    height: 38px !important;
  }
  .brand-title,
  .site-header.moody-green-style .brand-title {
    font-size: 18px !important;
  }
  .brand-sub,
  .site-header.moody-green-style .brand-sub {
    font-size: 7.3px !important;
    max-width: 170px;
  }
  .hero h1,
  .about-hero-copy h1,
  .career-hero-copy h1,
  .page-hero h1 {
    font-size: 34px !important;
  }
  .lead,
  .about-hero-copy p,
  .career-hero-copy p,
  .page-hero p {
    font-size: 15.5px !important;
  }
  .quick-search,
  .body-card,
  .fresh-card,
  .career-job-card,
  .people-card,
  .rating-list-card {
    padding: 18px !important;
  }
}


/* ===== V33 mobile content visibility fix =====
   Quick-link sidebars are useful on desktop, but on phones they can block the actual page content.
   Mobile visitors already have the header/mobile navigation, so sidebars are hidden below tablet width. */
@media (max-width: 1040px) {
  .content-grid {
    grid-template-columns: 1fr !important;
    gap: 24px !important;
  }
  .side-card {
    display: none !important;
  }
}
@media (max-width: 860px) {
  body {
    overflow-x: hidden;
  }
  .site-main,
  .page-view,
  .content-grid,
  .body-card,
  .rating-reports-wrap,
  .rating-symbol-clean-page,
  .methodology-page,
  .rating-updates-file-page {
    min-width: 0 !important;
    max-width: 100% !important;
  }
  .body-card,
  .fresh-card,
  .rating-symbol-clean-section,
  .rating-report-card,
  .methodology-card,
  .page-pdf-card {
    width: 100% !important;
  }
  .table-card,
  .rating-symbol-clean-table-wrap,
  .rating-list-table-wrap {
    max-width: 100%;
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
  }
}

/* ===== V34 premium homepage hero panel: replaces search box ===== */
.hero-premium-panel {
  position: relative;
  min-height: 360px;
  border-radius: 34px;
  overflow: hidden;
  padding: 28px;
  background:
    radial-gradient(circle at 80% 12%, rgba(91, 214, 143, .24), transparent 34%),
    radial-gradient(circle at 8% 96%, rgba(255, 255, 255, .16), transparent 28%),
    linear-gradient(135deg, rgba(255,255,255,.14), rgba(255,255,255,.045));
  border: 1px solid rgba(255,255,255,.18);
  box-shadow: 0 32px 80px rgba(0,0,0,.24);
  backdrop-filter: blur(12px);
  align-self: center;
}
.hero-premium-panel::before {
  content: "";
  position: absolute;
  inset: 0;
  background:
    linear-gradient(130deg, transparent 0 18%, rgba(255,255,255,.14) 18.2% 18.5%, transparent 19% 38%),
    linear-gradient(90deg, transparent 0 12%, rgba(255,255,255,.08) 12.2% 12.45%, transparent 12.8% 34%);
  background-size: 260px 260px, 330px 330px;
  opacity: .7;
}
.hero-premium-panel::after {
  content: "";
  position: absolute;
  right: -88px;
  top: -86px;
  width: 270px;
  height: 270px;
  border-radius: 50%;
  background: rgba(91,214,143,.12);
  border: 1px solid rgba(255,255,255,.16);
}
.hero-premium-orb {
  position: absolute;
  border-radius: 50%;
  filter: blur(.2px);
}
.hero-premium-orb-one {
  width: 130px;
  height: 130px;
  left: -28px;
  bottom: 44px;
  background: rgba(255,255,255,.08);
}
.hero-premium-orb-two {
  width: 72px;
  height: 72px;
  right: 78px;
  bottom: 88px;
  background: rgba(96,222,143,.16);
}
.hero-premium-card,
.hero-premium-metrics {
  position: relative;
  z-index: 2;
}
.hero-premium-card-main {
  max-width: 480px;
  padding: 30px;
  border-radius: 26px;
  background: rgba(255,255,255,.94);
  color: var(--navy);
  box-shadow: 0 22px 60px rgba(0,0,0,.18);
}
.hero-premium-label {
  display: inline-flex;
  margin-bottom: 16px;
  padding: 8px 12px;
  border-radius: 999px;
  background: #EAF6EF;
  color: var(--green);
  font-size: 12px;
  font-weight: 900;
  letter-spacing: .08em;
  text-transform: uppercase;
}
.hero-premium-card-main h3 {
  margin: 0 0 14px;
  color: var(--navy);
  font-size: 34px;
  line-height: 1.08;
  letter-spacing: -.04em;
}
.hero-premium-card-main p {
  margin: 0;
  color: #475467;
  font-size: 16px;
  line-height: 1.7;
}
.hero-premium-metrics {
  display: grid;
  grid-template-columns: repeat(3, minmax(0,1fr));
  gap: 12px;
  margin-top: 16px;
}
.hero-premium-metrics a {
  min-height: 92px;
  padding: 16px;
  border-radius: 20px;
  text-decoration: none;
  background: rgba(255,255,255,.13);
  border: 1px solid rgba(255,255,255,.18);
  color: #fff;
  transition: .18s ease;
}
.hero-premium-metrics a:hover {
  transform: translateY(-2px);
  background: rgba(255,255,255,.2);
}
.hero-premium-metrics strong {
  display: block;
  margin-bottom: 8px;
  font-size: 15px;
  line-height: 1.2;
}
.hero-premium-metrics span {
  display: block;
  color: #DDEEE5;
  font-size: 12px;
  line-height: 1.35;
}
@media (max-width: 980px) {
  .hero-premium-panel { min-height: auto; padding: 20px; }
  .hero-premium-card-main { max-width: none; }
  .hero-premium-metrics { grid-template-columns: 1fr; }
}
@media (max-width: 560px) {
  .hero-premium-card-main { padding: 22px; }
  .hero-premium-card-main h3 { font-size: 26px; }
  .hero-premium-card-main p { font-size: 15px; }
}

/* ===== V35 homepage image slider hero ===== */
.hero-slider-section.hero {
  margin-top: 0 !important;
  padding: 0 !important;
  background: #061726 !important;
  overflow: hidden !important;
}
.hero-slider-section.hero::before { display: none !important; }
.hero-slider {
  position: relative;
  width: 100%;
  min-height: min(760px, 56.25vw);
  height: clamp(520px, 56.25vw, 760px);
  background: #071523;
  overflow: hidden;
}
.hero-slide {
  position: absolute;
  inset: 0;
  opacity: 0;
  visibility: hidden;
  transform: scale(1.018);
  background-size: cover;
  background-position: center center;
  background-repeat: no-repeat;
  transition: opacity .75s ease, visibility .75s ease, transform 6.5s ease;
}
.hero-slide.is-active {
  opacity: 1;
  visibility: visible;
  transform: scale(1);
  z-index: 1;
}
.hero-slide.has-copy::before {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(90deg, rgba(5,20,34,.76) 0%, rgba(5,20,34,.42) 45%, rgba(5,20,34,.12) 100%);
}
.hero-slide-copy {
  position: relative;
  z-index: 2;
  min-height: 100%;
  display: flex;
  flex-direction: column;
  justify-content: center;
  color: #fff;
  max-width: 1200px;
}
.hero-slide-kicker {
  display: inline-flex;
  width: fit-content;
  margin-bottom: 20px;
  padding: 10px 15px;
  border-radius: 999px;
  background: rgba(255,255,255,.10);
  border: 1px solid rgba(255,255,255,.22);
  color: #B9F2C9;
  text-transform: uppercase;
  letter-spacing: .12em;
  font-size: 12px;
  font-weight: 900;
}
.hero-slide-copy h2 {
  margin: 0 0 20px;
  max-width: 760px;
  color: #fff;
  font-size: clamp(42px, 6vw, 86px);
  line-height: .98;
  letter-spacing: -.055em;
}
.hero-slide-copy p {
  margin: 0 0 28px;
  max-width: 650px;
  color: rgba(255,255,255,.9);
  font-size: 18px;
  line-height: 1.7;
}
.hero-slide-actions {
  display: flex;
  gap: 14px;
  flex-wrap: wrap;
}
.hero-slider-controls {
  position: absolute;
  left: 50%;
  bottom: 28px;
  z-index: 5;
  transform: translateX(-50%);
  display: inline-flex;
  align-items: center;
  gap: 14px;
  padding: 10px 12px;
  border-radius: 999px;
  background: rgba(3,17,29,.42);
  border: 1px solid rgba(255,255,255,.18);
  backdrop-filter: blur(10px);
  box-shadow: 0 14px 32px rgba(0,0,0,.2);
}
.hero-slider-arrow {
  width: 38px;
  height: 38px;
  border: 0;
  border-radius: 50%;
  background: rgba(255,255,255,.14);
  color: #fff;
  font-size: 28px;
  line-height: 1;
  cursor: pointer;
  display: grid;
  place-items: center;
  transition: .18s ease;
}
.hero-slider-arrow:hover,
.hero-slider-arrow:focus-visible {
  background: rgba(255,255,255,.26);
  outline: none;
}
.hero-slider-dots {
  display: inline-flex;
  align-items: center;
  gap: 8px;
}
.hero-slider-dot {
  width: 10px;
  height: 10px;
  border: 0;
  border-radius: 999px;
  background: rgba(255,255,255,.44);
  cursor: pointer;
  transition: width .18s ease, background .18s ease;
}
.hero-slider-dot.is-active {
  width: 34px;
  background: #88D66F;
}
@media (max-width: 980px) {
  .hero-slider { height: clamp(420px, 72vw, 560px); min-height: 420px; }
  .hero-slide { background-position: center center; }
}
@media (max-width: 640px) {
  .hero-slider { height: 460px; min-height: 460px; }
  .hero-slide { background-position: 48% center; }
  .hero-slider-controls { bottom: 16px; transform: translateX(-50%) scale(.9); }
  .hero-slide-copy { padding-top: 40px; padding-bottom: 74px; }
  .hero-slide-copy h2 { font-size: 40px; }
  .hero-slide-copy p { font-size: 15px; }
}

/* ===== V36 slider sizing and full-image display ===== */
.hero-slider-section.hero {
  background: #061726 !important;
}
.hero-slider {
  height: clamp(360px, 38vw, 560px) !important;
  min-height: 360px !important;
  max-height: 560px !important;
  background: #061726 !important;
}
.hero-slide {
  background-size: contain !important;
  background-position: center center !important;
  background-color: #061726 !important;
}
.hero-slider-controls {
  bottom: 20px !important;
}
.hero-slider-cta-strip {
  background: #061726;
  padding: 18px 0 26px;
}
.hero-slider-cta-inner {
  display: flex;
  align-items: center;
  gap: 14px;
}
.hero-slider-cta-strip .btn {
  min-width: 148px;
  height: 46px;
  font-size: 14px;
  box-shadow: 0 10px 24px rgba(0,0,0,.16);
}
.hero-slider-cta-strip .btn.ghost {
  color: #fff;
  border-color: rgba(255,255,255,.34);
  background: rgba(255,255,255,.04);
}
.hero-slider-cta-strip .btn.ghost:hover {
  background: rgba(255,255,255,.1);
  transform: translateY(-1px);
}
@media (min-width: 1440px) {
  .hero-slider { height: 520px !important; min-height: 520px !important; }
}
@media (max-width: 980px) {
  .hero-slider { height: clamp(300px, 50vw, 430px) !important; min-height: 300px !important; }
  .hero-slider-cta-strip { padding: 16px 0 22px; }
}
@media (max-width: 640px) {
  .hero-slider { height: 300px !important; min-height: 300px !important; }
  .hero-slider-controls { bottom: 12px !important; transform: translateX(-50%) scale(.82) !important; }
  .hero-slider-cta-inner { justify-content: center; flex-wrap: wrap; }
  .hero-slider-cta-strip .btn { min-width: 138px; height: 42px; font-size: 13px; }
}


/* ===== V37 hero slider alignment and overlay actions ===== */
.hero-slider-section.hero {
  background: #061726 !important;
  padding: 0 !important;
}
.hero-slider {
  position: relative !important;
  width: 100% !important;
  height: clamp(430px, 43vw, 610px) !important;
  min-height: 430px !important;
  max-height: 610px !important;
  background: #061726 !important;
  overflow: hidden !important;
}
.hero-slide {
  background-size: cover !important;
  background-position: center center !important;
  background-repeat: no-repeat !important;
}
.hero-slide.image-only::after {
  content: "";
  position: absolute;
  inset: auto 0 0 0;
  height: 32%;
  background: linear-gradient(180deg, rgba(6,23,38,0) 0%, rgba(6,23,38,.72) 100%);
  z-index: 2;
  pointer-events: none;
}
.hero-slider-inline-actions {
  position: absolute;
  left: max(32px, calc((100vw - 1180px) / 2 + 24px));
  bottom: 34px;
  z-index: 6;
  display: flex;
  align-items: center;
  gap: 14px;
  flex-wrap: wrap;
}
.hero-slider-inline-actions .btn {
  min-width: 150px;
  height: 48px;
  font-size: 14px;
  box-shadow: 0 14px 28px rgba(0,0,0,.22);
}
.hero-slider-inline-actions .btn.ghost {
  color: #fff;
  border-color: rgba(255,255,255,.44);
  background: rgba(6,23,38,.26);
  backdrop-filter: blur(8px);
}
.hero-slider-inline-actions .btn.ghost:hover {
  background: rgba(255,255,255,.12);
}
.hero-slider-controls {
  bottom: 34px !important;
  left: 50% !important;
  z-index: 7 !important;
}
.hero-slider-cta-strip {
  display: none !important;
}
@media (max-width: 1180px) {
  .hero-slider-inline-actions {
    left: 28px;
    bottom: 28px;
  }
  .hero-slider-controls {
    right: 28px !important;
    left: auto !important;
    transform: none !important;
    bottom: 28px !important;
  }
}
@media (max-width: 760px) {
  .hero-slider {
    height: clamp(340px, 72vw, 440px) !important;
    min-height: 340px !important;
  }
  .hero-slide {
    background-size: cover !important;
    background-position: center center !important;
  }
  .hero-slider-inline-actions {
    left: 18px;
    right: 18px;
    bottom: 20px;
    justify-content: center;
  }
  .hero-slider-inline-actions .btn {
    min-width: 138px;
    height: 42px;
    font-size: 13px;
  }
  .hero-slider-controls {
    bottom: 76px !important;
    left: 50% !important;
    right: auto !important;
    transform: translateX(-50%) scale(.84) !important;
  }
}
@media (max-width: 420px) {
  .hero-slider-inline-actions {
    gap: 10px;
  }
  .hero-slider-inline-actions .btn {
    min-width: 128px;
    padding-left: 14px;
    padding-right: 14px;
  }
}

/* ===== V38 split homepage hero: left copy + right slider ===== */
.hero-split-slider-section.hero {
  margin-top: 0 !important;
  padding: 0 !important;
  min-height: auto !important;
  color: #fff;
  background:
    radial-gradient(circle at 80% 12%, rgba(14, 131, 79, .26), transparent 30%),
    radial-gradient(circle at 18% 84%, rgba(12, 91, 60, .22), transparent 34%),
    linear-gradient(118deg, #051826 0%, #07283D 48%, #0C3C45 100%) !important;
  overflow: hidden !important;
  position: relative;
}
.hero-split-slider-section.hero::before {
  content: "" !important;
  display: block !important;
  position: absolute;
  inset: 0;
  background:
    linear-gradient(120deg, transparent 0 8%, rgba(255,255,255,.06) 8.2% 8.4%, transparent 8.8% 20%),
    radial-gradient(circle at 72% 38%, rgba(130, 214, 111, .12), transparent 22%);
  background-size: 220px 360px, auto;
  opacity: .78;
  transform: none !important;
  pointer-events: none;
}
.hero-split-inner {
  position: relative;
  z-index: 1;
  display: grid;
  grid-template-columns: minmax(0, .86fr) minmax(0, 1.14fr);
  align-items: center;
  gap: clamp(36px, 5vw, 78px);
  min-height: clamp(520px, 47vw, 680px);
  padding: clamp(54px, 6vw, 86px) 0;
}
.hero-split-copy {
  max-width: 560px;
}
.hero-split-copy .eyebrow {
  margin-bottom: 22px;
}
.hero-split-copy h1 {
  margin: 0;
  color: #fff;
  font-size: clamp(48px, 5.6vw, 86px);
  line-height: .98;
  letter-spacing: -.06em;
}
.hero-split-copy .lead {
  max-width: 560px;
  margin: 26px 0 30px;
  color: rgba(236, 246, 244, .92);
  font-size: clamp(16px, 1.25vw, 19px);
  line-height: 1.72;
}
.hero-split-actions {
  display: flex;
  gap: 16px;
  flex-wrap: wrap;
}
.hero-split-actions .btn {
  min-width: 152px;
  height: 48px;
  box-shadow: 0 14px 28px rgba(0,0,0,.22);
}
.hero-split-actions .btn.ghost {
  color: #fff;
  border-color: rgba(255,255,255,.4);
  background: rgba(255,255,255,.04);
  backdrop-filter: blur(8px);
}
.hero-side-slider-shell {
  position: relative;
  width: 100%;
  border-radius: 34px;
  padding: 14px;
  background: linear-gradient(135deg, rgba(255,255,255,.12), rgba(255,255,255,.035));
  border: 1px solid rgba(255,255,255,.16);
  box-shadow: 0 34px 80px rgba(0,0,0,.34);
}
.hero-side-slider-shell::before {
  content: "";
  position: absolute;
  inset: -28px -30px auto auto;
  width: 190px;
  height: 190px;
  border-radius: 50%;
  background: rgba(96, 222, 143, .14);
  filter: blur(1px);
  pointer-events: none;
}
.hero-side-slider-shell::after {
  content: "";
  position: absolute;
  inset: auto auto -24px -26px;
  width: 150px;
  height: 150px;
  border-radius: 50%;
  background: rgba(255,255,255,.06);
  pointer-events: none;
}
.hero-side-slider.hero-slider {
  position: relative !important;
  width: 100% !important;
  aspect-ratio: 16 / 9;
  height: auto !important;
  min-height: 0 !important;
  max-height: none !important;
  border-radius: 24px;
  overflow: hidden !important;
  background: #071523 !important;
  box-shadow: inset 0 0 0 1px rgba(255,255,255,.10);
}
.hero-side-slider .hero-slide {
  background-size: cover !important;
  background-position: center center !important;
  background-repeat: no-repeat !important;
}
.hero-side-slider .hero-slide.image-only::after {
  content: "";
  position: absolute;
  inset: auto 0 0 0;
  height: 38%;
  background: linear-gradient(180deg, rgba(5,18,31,0) 0%, rgba(5,18,31,.68) 100%);
  z-index: 2;
  pointer-events: none;
}
.hero-side-controls.hero-slider-controls {
  left: 50% !important;
  right: auto !important;
  bottom: 18px !important;
  transform: translateX(-50%) !important;
  z-index: 7 !important;
}
.hero-side-slider .hero-slider-dot.is-active {
  background: #8EDB75;
}
.hero-split-slider-section .hero-slider-inline-actions,
.hero-split-slider-section .hero-slider-cta-strip {
  display: none !important;
}
@media (min-width: 1500px) {
  .hero-split-inner {
    min-height: 660px;
  }
}
@media (max-width: 1120px) {
  .hero-split-inner {
    grid-template-columns: 1fr;
    gap: 34px;
    min-height: auto;
    padding: 54px 0 62px;
  }
  .hero-split-copy {
    max-width: 760px;
  }
  .hero-side-slider-shell {
    max-width: 900px;
  }
  .hero-split-copy h1 {
    max-width: 780px;
  }
}
@media (max-width: 760px) {
  .hero-split-inner {
    padding: 38px 0 48px;
    gap: 26px;
  }
  .hero-split-copy h1 {
    font-size: clamp(42px, 12vw, 58px);
  }
  .hero-split-copy .lead {
    margin: 20px 0 24px;
  }
  .hero-side-slider-shell {
    border-radius: 24px;
    padding: 9px;
  }
  .hero-side-slider.hero-slider {
    border-radius: 18px;
    aspect-ratio: 16 / 10;
  }
  .hero-side-controls.hero-slider-controls {
    bottom: 12px !important;
    transform: translateX(-50%) scale(.84) !important;
  }
  .hero-split-actions .btn {
    min-width: 138px;
    height: 44px;
    font-size: 13px;
  }
}
@media (max-width: 440px) {
  .hero-split-actions {
    gap: 10px;
  }
  .hero-split-actions .btn {
    min-width: 128px;
    padding-left: 14px;
    padding-right: 14px;
  }
  .hero-side-slider.hero-slider {
    aspect-ratio: 4 / 3;
  }
}

/* ===== V39 refined homepage hero slider ===== */
.hero-premium-slider-section.hero {
  margin-top: 0 !important;
  padding: 28px 0 30px !important;
  min-height: auto !important;
  overflow: hidden;
  background:
    radial-gradient(circle at 18% 24%, rgba(64, 178, 112, .13), transparent 28%),
    radial-gradient(circle at 86% 14%, rgba(16, 106, 76, .22), transparent 34%),
    linear-gradient(118deg, #061827 0%, #071F32 48%, #0A3D42 100%) !important;
  color: #fff;
}
.hero-premium-slider-section.hero::before {
  content: "";
  position: absolute;
  inset: 0;
  opacity: .28;
  background-image:
    linear-gradient(115deg, transparent 0 10%, rgba(255,255,255,.12) 10.15% 10.35%, transparent 10.5% 28%),
    radial-gradient(circle at 10% 30%, rgba(255,255,255,.16) 0 1px, transparent 1.2px);
  background-size: 260px 300px, 20px 20px;
  transform: skewX(-10deg) scale(1.04);
}
.hero-premium-stage {
  position: relative;
  z-index: 2;
  width: min(1280px, 94vw);
  margin: 0 auto;
}
.hero-premium-slider.hero-slider {
  position: relative;
  width: 100%;
  height: clamp(430px, 43vw, 560px) !important;
  min-height: 430px !important;
  border-radius: 0 !important;
  overflow: hidden;
  border: 1px solid rgba(255,255,255,.14);
  background: rgba(2, 13, 24, .72);
  box-shadow: 0 28px 70px rgba(0,0,0,.28);
}
.hero-premium-slide.hero-slide {
  position: absolute;
  inset: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: clamp(14px, 2.2vw, 28px);
  background: transparent !important;
  opacity: 0;
  visibility: hidden;
  transition: opacity .75s ease, visibility .75s ease;
}
.hero-premium-slide.hero-slide.is-active {
  opacity: 1;
  visibility: visible;
}
.hero-premium-slide .hero-slide-blur {
  position: absolute;
  inset: 0;
  background-size: cover;
  background-position: center;
  filter: blur(14px) saturate(1.04);
  transform: scale(1.06);
  opacity: .35;
}
.hero-premium-slide::before {
  content: "";
  position: absolute;
  inset: 0;
  background:
    linear-gradient(90deg, rgba(2,13,24,.18) 0%, rgba(2,13,24,.02) 45%, rgba(2,13,24,.22) 100%),
    linear-gradient(0deg, rgba(2,13,24,.38) 0%, transparent 30%, transparent 68%, rgba(2,13,24,.14) 100%);
  z-index: 1;
}
.hero-slide-img {
  position: relative;
  z-index: 2;
  width: 100%;
  height: 100%;
  object-fit: contain;
  object-position: center;
  display: block;
  border-radius: 0;
  filter: drop-shadow(0 18px 26px rgba(0,0,0,.18));
}
.hero-premium-actions.hero-slider-inline-actions {
  position: absolute;
  z-index: 5;
  left: clamp(22px, 4vw, 56px) !important;
  bottom: clamp(22px, 3vw, 38px) !important;
  display: flex !important;
  align-items: center;
  gap: 14px;
  transform: none !important;
}
.hero-premium-actions .btn {
  height: 46px;
  padding-inline: 22px;
  font-size: 14px;
  box-shadow: 0 10px 22px rgba(0,0,0,.18);
}
.hero-premium-actions .btn.ghost {
  color: #fff;
  border-color: rgba(255,255,255,.55);
  background: rgba(3, 18, 30, .38);
  backdrop-filter: blur(10px);
}
.hero-premium-actions .btn.ghost:hover {
  background: rgba(255,255,255,.12);
}
.hero-premium-controls.hero-slider-controls {
  z-index: 5;
  left: 50% !important;
  right: auto !important;
  bottom: clamp(20px, 3vw, 34px) !important;
  transform: translateX(-50%) !important;
  background: rgba(3, 18, 30, .55) !important;
  border: 1px solid rgba(255,255,255,.22);
  backdrop-filter: blur(12px);
}
.hero-premium-slider .hero-slider-dot.is-active {
  background: #9ADE7B !important;
}
@media (max-width: 980px) {
  .hero-premium-slider-section.hero {
    padding: 20px 0 24px !important;
  }
  .hero-premium-stage {
    width: min(760px, 94vw);
  }
  .hero-premium-slider.hero-slider {
    height: clamp(330px, 60vw, 450px) !important;
    min-height: 330px !important;
  }
  .hero-premium-actions.hero-slider-inline-actions {
    left: 20px !important;
    bottom: 18px !important;
  }
  .hero-premium-controls.hero-slider-controls {
    right: 16px !important;
    left: auto !important;
    transform: none !important;
    bottom: 18px !important;
  }
}
@media (max-width: 620px) {
  .hero-premium-stage { width: 100%; }
  .hero-premium-slider.hero-slider {
    height: 330px !important;
    min-height: 330px !important;
    border-left: 0;
    border-right: 0;
  }
  .hero-premium-slide.hero-slide {
    padding: 8px;
  }
  .hero-premium-actions.hero-slider-inline-actions {
    left: 14px !important;
    right: 14px !important;
    bottom: 14px !important;
    flex-wrap: wrap;
    gap: 8px;
  }
  .hero-premium-actions .btn {
    height: 40px;
    padding-inline: 14px;
    font-size: 12px;
  }
  .hero-premium-controls.hero-slider-controls {
    bottom: 64px !important;
    right: 12px !important;
    transform: scale(.78) !important;
    transform-origin: right bottom;
  }
}


/* ===== V40: full-zone homepage slider, no inner box ===== */
.hero-premium-slider-section.hero {
  padding: 0 !important;
  min-height: 0 !important;
  background:
    radial-gradient(circle at 16% 22%, rgba(40, 164, 101, .16), transparent 28%),
    linear-gradient(115deg, #061827 0%, #082033 50%, #0A3D42 100%) !important;
}
.hero-premium-stage {
  width: 100% !important;
  max-width: none !important;
  margin: 0 !important;
}
.hero-premium-slider.hero-slider {
  width: 100% !important;
  height: clamp(440px, 36vw, 580px) !important;
  min-height: 440px !important;
  border-radius: 0 !important;
  border: 0 !important;
  box-shadow: none !important;
  background: #061827 !important;
}
.hero-premium-slide.hero-slide {
  padding: 0 !important;
  overflow: hidden;
}
.hero-premium-slide .hero-slide-blur {
  inset: 0 !important;
  filter: none !important;
  transform: none !important;
  opacity: 1 !important;
  background-size: cover !important;
  background-position: center center !important;
}
.hero-premium-slide::before {
  background:
    linear-gradient(90deg, rgba(3,16,28,.14) 0%, rgba(3,16,28,.02) 50%, rgba(3,16,28,.16) 100%),
    linear-gradient(0deg, rgba(3,16,28,.36) 0%, rgba(3,16,28,.05) 28%, rgba(3,16,28,.06) 100%) !important;
}
.hero-premium-slide .hero-slide-img {
  opacity: 0 !important;
  visibility: hidden !important;
  position: absolute !important;
  pointer-events: none !important;
}
.hero-premium-actions.hero-slider-inline-actions {
  left: clamp(28px, 5vw, 88px) !important;
  bottom: clamp(28px, 4vw, 56px) !important;
  z-index: 8 !important;
}
.hero-premium-controls.hero-slider-controls {
  bottom: clamp(28px, 4vw, 56px) !important;
  z-index: 8 !important;
}
@media (min-width: 1400px) {
  .hero-premium-slider.hero-slider {
    height: 560px !important;
  }
}
@media (max-width: 980px) {
  .hero-premium-slider.hero-slider {
    height: clamp(360px, 58vw, 470px) !important;
    min-height: 360px !important;
  }
  .hero-premium-slide .hero-slide-blur {
    background-position: center center !important;
  }
}
@media (max-width: 620px) {
  .hero-premium-slider.hero-slider {
    height: 340px !important;
    min-height: 340px !important;
  }
  .hero-premium-actions.hero-slider-inline-actions {
    left: 16px !important;
    right: 16px !important;
    bottom: 14px !important;
    justify-content: flex-start;
  }
  .hero-premium-controls.hero-slider-controls {
    right: 14px !important;
    bottom: 70px !important;
  }
}

/* ===== V41: final responsiveness and device polish ===== */
html, body {
  max-width: 100%;
  overflow-x: hidden;
}
img, video, iframe, embed, object {
  max-width: 100%;
}
.wp-block-image img,
.entry-content img,
.page-view img {
  height: auto;
}
.site-main {
  width: 100%;
  overflow-x: hidden;
}
.wrap {
  width: min(1180px, calc(100vw - 40px));
}

/* Hero slider: controlled proportions across devices. */
.hero-premium-slider-section.hero {
  width: 100%;
  overflow: hidden;
}
.hero-premium-slider.hero-slider {
  height: clamp(430px, 34vw, 540px) !important;
  min-height: 430px !important;
}
.hero-premium-slide .hero-slide-blur {
  background-position: center center !important;
}
.hero-premium-actions.hero-slider-inline-actions {
  max-width: calc(100% - 48px);
}
.hero-premium-actions .btn,
.hero-slider-arrow,
.hero-slider-dot {
  touch-action: manipulation;
}

/* Universal grids should never force overflow. */
[class*="grid"],
.products-slider,
.rating-report-grid,
.magazine-archive-grid,
.people-grid,
.career-job-grid,
.about-capability-grid,
.about-values-grid,
.service-grid,
.insight-grid,
.learn-services-grid,
.news-track,
.rating-news-track {
  max-width: 100%;
}

/* Tables and PDF viewers remain usable on phones. */
.rating-symbol-table,
.symbol-table,
.page-view table,
.rating-report-table,
.wp-block-table table {
  width: 100%;
}
.table-scroll,
.rating-symbol-table-wrap,
.symbol-table-wrap,
.rating-table-shell,
.wp-block-table,
.page-view .table-wrap {
  max-width: 100%;
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
}
.page-view table,
.rating-symbol-table table,
.symbol-table table {
  min-width: 620px;
}
.pdf-preview,
.pdf-frame,
.methodology-pdf-frame,
.rating-file-preview iframe,
.page-pdf-frame,
iframe[src*=".pdf"] {
  width: 100%;
  min-height: 520px;
  border: 0;
}

/* Large tablet / small laptop. */
@media (max-width: 1180px) {
  .wrap {
    width: min(1000px, calc(100vw - 36px));
  }
  h1,
  .hero-copy h1,
  .about-hero-copy h1 {
    font-size: clamp(42px, 7vw, 58px) !important;
  }
  h2,
  .section-head h2,
  .career-section-title h2,
  .about-section-heading h2 {
    font-size: clamp(30px, 4vw, 44px) !important;
  }
  .hero-premium-slider.hero-slider {
    height: clamp(390px, 48vw, 500px) !important;
    min-height: 390px !important;
  }
  .mega.wide {
    width: min(760px, 92vw);
  }
}

/* Tablet layout. */
@media (max-width: 980px) {
  .wrap {
    width: calc(100vw - 28px);
  }
  .top-strip {
    display: none;
  }
  .header-top-inner,
  .header-bottom-inner,
  .nav {
    min-height: auto;
  }
  .header-top-bar {
    padding: 8px 0;
  }
  .header-brand-group {
    min-width: 0;
  }
  .brand {
    min-width: 0;
  }
  .brand-logo {
    width: 70px;
    height: 46px;
  }
  .brand-title {
    font-size: 22px;
  }
  .brand-sub {
    font-size: 8.5px;
  }
  .top-search-pill {
    max-width: 44vw;
  }
  .top-search-input {
    font-size: 13px;
  }
  .top-contact-pill {
    padding: 10px 16px;
  }
  .header-bottom-bar {
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
  }
  .main-menu {
    justify-content: flex-start;
    min-width: max-content;
  }
  .menu-link {
    padding: 18px 12px;
    font-size: 13px;
  }
  .mega {
    display: none !important;
  }
  .hero-premium-slider.hero-slider {
    height: clamp(330px, 54vw, 430px) !important;
    min-height: 330px !important;
  }
  .hero-premium-actions.hero-slider-inline-actions {
    left: 18px !important;
    bottom: 18px !important;
    gap: 10px;
  }
  .hero-premium-actions .btn {
    height: 42px;
    padding-inline: 16px;
    font-size: 13px;
  }
  .hero-premium-controls.hero-slider-controls {
    right: 18px !important;
    left: auto !important;
    bottom: 18px !important;
    transform: none !important;
  }
  .page-layout,
  .content-with-sidebar,
  .sidebar-layout,
  .two-col,
  .two-column,
  .about-hero-grid,
  .about-story-grid,
  .about-cta-shell,
  .contact-public-grid,
  .career-hero-inner,
  .career-culture-grid,
  .service-detail-grid,
  .single-profile-grid {
    grid-template-columns: 1fr !important;
  }
  .quick-links,
  .sidebar,
  .page-sidebar,
  .left-rail,
  .side-nav,
  .page-quick-links {
    display: none !important;
  }
  .about-capability-grid,
  .about-values-grid,
  .about-timeline,
  .who-focus-grid,
  .career-job-grid,
  .career-culture-grid,
  .rating-report-grid,
  .magazine-archive-grid,
  .people-grid,
  .learn-services-grid,
  .inside-credit-grid,
  .products-grid,
  .services-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  }
  .rating-news-track,
  .news-track,
  .products-slider {
    overflow-x: auto;
    scroll-snap-type: x proximity;
    -webkit-overflow-scrolling: touch;
  }
  .rating-news-card,
  .news-card,
  .product-card {
    scroll-snap-align: start;
  }
  .pdf-preview,
  .pdf-frame,
  .methodology-pdf-frame,
  .page-pdf-frame,
  iframe[src*=".pdf"] {
    min-height: 480px;
  }
}

/* Mobile. */
@media (max-width: 760px) {
  .wrap {
    width: calc(100vw - 22px);
  }
  body {
    font-size: 15px;
  }
  .header-top-inner {
    gap: 10px;
  }
  .desktop-burger {
    width: 40px;
    height: 40px;
    flex: 0 0 40px;
  }
  .brand-logo {
    width: 58px;
    height: 40px;
  }
  .brand-title {
    font-size: 18px;
  }
  .brand-sub {
    display: none;
  }
  .top-search-pill {
    order: 3;
    width: 100%;
    max-width: none;
    flex-basis: 100%;
    height: 42px;
  }
  .header-top-inner {
    flex-wrap: wrap;
  }
  .top-contact-pill {
    padding: 9px 14px;
    font-size: 13px;
  }
  .header-bottom-bar {
    display: none;
  }
  .mobile-drawer {
    width: min(420px, 92vw);
  }
  h1,
  .about-hero-copy h1,
  .career-hero-copy h1 {
    font-size: clamp(36px, 11vw, 48px) !important;
    line-height: 1.02 !important;
  }
  h2,
  .section-head h2,
  .career-section-title h2,
  .about-section-heading h2 {
    font-size: clamp(27px, 8vw, 36px) !important;
  }
  .lead,
  .hero-copy p,
  .career-hero-copy p,
  .about-hero-copy p {
    font-size: 16px !important;
  }
  .hero-premium-slider.hero-slider {
    height: clamp(280px, 68vw, 350px) !important;
    min-height: 280px !important;
  }
  .hero-premium-slide .hero-slide-blur {
    background-size: cover !important;
    background-position: center center !important;
  }
  .hero-premium-actions.hero-slider-inline-actions {
    left: 12px !important;
    right: 12px !important;
    bottom: 12px !important;
    flex-wrap: wrap;
    max-width: none;
  }
  .hero-premium-actions .btn {
    height: 38px;
    padding: 0 13px;
    font-size: 12px;
  }
  .hero-premium-controls.hero-slider-controls {
    right: 10px !important;
    bottom: 58px !important;
    transform: scale(.82) !important;
    transform-origin: right bottom;
  }
  .about-capability-grid,
  .about-values-grid,
  .about-timeline,
  .who-focus-grid,
  .career-job-grid,
  .career-culture-grid,
  .rating-report-grid,
  .magazine-archive-grid,
  .people-grid,
  .learn-services-grid,
  .inside-credit-grid,
  .products-grid,
  .services-grid,
  .footer-grid,
  .contact-card-grid {
    grid-template-columns: 1fr !important;
  }
  .career-filter-panel,
  .rating-list-filters,
  .magazine-filter-panel,
  .report-filter-panel,
  .methodology-filter-panel {
    grid-template-columns: 1fr !important;
    display: grid !important;
    gap: 10px;
  }
  .career-filter-panel input,
  .career-filter-panel select,
  .rating-list-filters input,
  .rating-list-filters select,
  .magazine-filter-panel select,
  .report-filter-panel select,
  .report-filter-panel input {
    width: 100% !important;
    min-height: 44px;
  }
  .btn,
  button,
  input,
  select,
  textarea {
    max-width: 100%;
  }
  .person-card,
  .career-job-card,
  .rating-report-card,
  .magazine-card,
  .service-card,
  .about-capability-card,
  .about-value-card {
    width: 100%;
  }
  .person-photo,
  .people-photo,
  .team-photo {
    width: 118px !important;
    height: 118px !important;
  }
  .pdf-preview,
  .pdf-frame,
  .methodology-pdf-frame,
  .page-pdf-frame,
  iframe[src*=".pdf"] {
    min-height: 390px;
  }
  .site-footer,
  .footer-brief {
    padding: 22px 0 !important;
  }
  .footer-brief-inner,
  .footer-grid,
  .footer-contact-line {
    gap: 10px !important;
  }
}

/* Small phones. */
@media (max-width: 420px) {
  .wrap {
    width: calc(100vw - 18px);
  }
  .header-top-inner {
    gap: 8px;
  }
  .brand-logo {
    width: 52px;
  }
  .brand-title {
    font-size: 16px;
  }
  .top-contact-pill {
    display: none;
  }
  .hero-premium-slider.hero-slider {
    height: 265px !important;
    min-height: 265px !important;
  }
  .hero-premium-actions.hero-slider-inline-actions {
    justify-content: center;
  }
  .hero-premium-actions .btn {
    min-width: 128px;
    height: 36px;
    font-size: 11.5px;
  }
  .hero-premium-controls.hero-slider-controls {
    left: 50% !important;
    right: auto !important;
    bottom: 56px !important;
    transform: translateX(-50%) scale(.74) !important;
    transform-origin: center bottom;
  }
  .page-view,
  section {
    overflow-x: hidden;
  }
  .pdf-preview,
  .pdf-frame,
  .methodology-pdf-frame,
  .page-pdf-frame,
  iframe[src*=".pdf"] {
    min-height: 330px;
  }
  .table-scroll,
  .rating-symbol-table-wrap,
  .symbol-table-wrap,
  .rating-table-shell {
    margin-left: -6px;
    margin-right: -6px;
    padding-inline: 6px;
  }
}

/* ===== V43 homepage/header cleanup ===== */
.top-strip {
  display: none !important;
  height: 0 !important;
  min-height: 0 !important;
  padding: 0 !important;
  margin: 0 !important;
  border: 0 !important;
}

.site-header {
  margin-top: 0 !important;
}

.rating-news-section {
  padding-bottom: 42px !important;
}

.insights {
  padding-top: 44px !important;
  padding-bottom: 62px !important;
}

.insight-label {
  margin-bottom: 16px !important;
}

.contact-copy .kicker {
  display: none !important;
}

.contact-copy h2 {
  margin-top: 0 !important;
}

.insights-archive-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 20px;
}

.insights-archive-card {
  background: #fff;
  border: 1px solid #E3EFE8;
  border-radius: 24px;
  padding: 24px;
  box-shadow: 0 12px 28px rgba(7,21,35,.05);
  transition: transform .22s ease, border-color .22s ease, box-shadow .22s ease;
}

.insights-archive-card:hover {
  transform: translateY(-5px);
  border-color: rgba(11,122,59,.42);
  box-shadow: 0 20px 44px rgba(11,122,59,.12);
}

.insights-archive-card small {
  display: block;
  margin-bottom: 12px;
  color: var(--green);
  font-size: 12px;
  font-weight: 900;
  letter-spacing: .08em;
  text-transform: uppercase;
}

.insights-archive-card h3 {
  margin: 0 0 12px;
  color: var(--navy);
  font-size: 23px;
  line-height: 1.18;
  letter-spacing: -.025em;
}

.insights-archive-card h3 a {
  text-decoration: none;
}

.insights-archive-card p {
  margin: 0 0 16px;
  color: #667085;
  font-size: 15px;
  line-height: 1.6;
}

.insights-read-more {
  color: var(--green);
  font-weight: 900;
  text-decoration: none;
}

.insights-read-more:hover {
  text-decoration: underline;
}

@media (max-width: 980px) {
  .insights {
    padding-top: 34px !important;
    padding-bottom: 48px !important;
  }
  .rating-news-section {
    padding-bottom: 34px !important;
  }
  .insights-archive-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 640px) {
  .insights {
    padding-top: 28px !important;
    padding-bottom: 42px !important;
  }
  .insights-archive-grid {
    grid-template-columns: 1fr;
  }
}

/* ===== V46 compact centered homepage slider =====
   Keeps the banner in a controlled central zone and reduces the overall hero height. */
.hero-premium-slider-section.hero {
  padding: 18px 0 22px !important;
  min-height: 0 !important;
  background:
    radial-gradient(circle at 84% 18%, rgba(24, 112, 87, .20), transparent 34%),
    linear-gradient(115deg, #061827 0%, #082033 50%, #0A3D42 100%) !important;
}
.hero-premium-slider-section.hero::before {
  opacity: .14 !important;
}
.hero-premium-stage {
  width: min(1020px, calc(100vw - 48px)) !important;
  max-width: 1020px !important;
  margin: 0 auto !important;
}
.hero-premium-slider.hero-slider {
  width: 100% !important;
  height: clamp(310px, 26vw, 390px) !important;
  min-height: 310px !important;
  max-height: 390px !important;
  border: 0 !important;
  border-radius: 0 !important;
  box-shadow: none !important;
  background: #061827 !important;
}
.hero-premium-slide.hero-slide {
  padding: 0 !important;
}
.hero-premium-slide .hero-slide-blur {
  display: block !important;
  inset: 0 !important;
  opacity: 1 !important;
  filter: none !important;
  transform: none !important;
  background-size: cover !important;
  background-position: center center !important;
  background-repeat: no-repeat !important;
}
.hero-premium-slide .hero-slide-img {
  opacity: 0 !important;
  visibility: hidden !important;
  position: absolute !important;
  pointer-events: none !important;
}
.hero-premium-slide::before {
  background:
    linear-gradient(90deg, rgba(3,16,28,.10) 0%, rgba(3,16,28,.02) 48%, rgba(3,16,28,.12) 100%),
    linear-gradient(0deg, rgba(3,16,28,.40) 0%, rgba(3,16,28,.04) 34%, rgba(3,16,28,.08) 100%) !important;
}
.hero-premium-actions.hero-slider-inline-actions {
  left: 34px !important;
  bottom: 22px !important;
  max-width: calc(100% - 68px) !important;
  z-index: 8 !important;
}
.hero-premium-actions .btn {
  height: 42px !important;
  min-width: 136px !important;
  padding: 0 18px !important;
  font-size: 13px !important;
}
.hero-premium-controls.hero-slider-controls {
  left: 50% !important;
  right: auto !important;
  bottom: 22px !important;
  transform: translateX(-50%) scale(.88) !important;
  z-index: 9 !important;
}
@media (min-width: 1500px) {
  .hero-premium-stage {
    max-width: 1060px !important;
  }
  .hero-premium-slider.hero-slider {
    height: 390px !important;
    min-height: 390px !important;
  }
}
@media (max-width: 980px) {
  .hero-premium-slider-section.hero {
    padding: 14px 0 18px !important;
  }
  .hero-premium-stage {
    width: calc(100vw - 28px) !important;
  }
  .hero-premium-slider.hero-slider {
    height: clamp(260px, 48vw, 340px) !important;
    min-height: 260px !important;
    max-height: 340px !important;
  }
  .hero-premium-actions.hero-slider-inline-actions {
    left: 18px !important;
    bottom: 16px !important;
  }
  .hero-premium-controls.hero-slider-controls {
    right: 18px !important;
    left: auto !important;
    bottom: 16px !important;
    transform: scale(.78) !important;
    transform-origin: right bottom;
  }
}
@media (max-width: 640px) {
  .hero-premium-stage {
    width: 100% !important;
  }
  .hero-premium-slider.hero-slider {
    height: 250px !important;
    min-height: 250px !important;
  }
  .hero-premium-slide .hero-slide-blur {
    background-position: center center !important;
  }
  .hero-premium-actions.hero-slider-inline-actions {
    left: 12px !important;
    right: 12px !important;
    bottom: 12px !important;
    gap: 8px !important;
  }
  .hero-premium-actions .btn {
    height: 36px !important;
    min-width: 120px !important;
    padding: 0 12px !important;
    font-size: 11.5px !important;
  }
  .hero-premium-controls.hero-slider-controls {
    bottom: 56px !important;
    right: 10px !important;
    transform: scale(.68) !important;
  }
}

/* ===== V47 homepage slider alignment and image-fit refinement =====
   The slider now uses the same central content width as the homepage sections.
   The image is contained inside the banner area so it is not cut off vertically. */
.hero-premium-slider-section.hero {
  padding: 0 !important;
  min-height: 0 !important;
  background:
    radial-gradient(circle at 88% 18%, rgba(12, 101, 92, .24), transparent 32%),
    linear-gradient(115deg, #061827 0%, #082033 50%, #0A3D42 100%) !important;
}
.hero-premium-slider-section .hero-premium-stage {
  width: min(1180px, 92vw) !important;
  max-width: 1180px !important;
  margin: 0 auto !important;
  padding: 0 !important;
}
.hero-premium-slider.hero-slider {
  width: 100% !important;
  height: clamp(420px, 31vw, 520px) !important;
  min-height: 420px !important;
  max-height: 520px !important;
  overflow: hidden !important;
  border: 0 !important;
  border-radius: 0 !important;
  box-shadow: none !important;
  background: transparent !important;
}
.hero-premium-slide.hero-slide {
  background: transparent !important;
}
.hero-premium-slide .hero-slide-blur {
  display: block !important;
  inset: -18px !important;
  opacity: .72 !important;
  filter: blur(22px) saturate(1.05) !important;
  transform: scale(1.08) !important;
  background-size: cover !important;
  background-position: center center !important;
  background-repeat: no-repeat !important;
}
.hero-premium-slide .hero-slide-img {
  display: block !important;
  opacity: 1 !important;
  visibility: visible !important;
  position: absolute !important;
  inset: 0 !important;
  width: 100% !important;
  height: 100% !important;
  object-fit: contain !important;
  object-position: center center !important;
  pointer-events: none !important;
  z-index: 2 !important;
}
.hero-premium-slide::before {
  z-index: 3 !important;
  background:
    linear-gradient(90deg, rgba(3,16,28,.22) 0%, rgba(3,16,28,.04) 48%, rgba(3,16,28,.18) 100%),
    linear-gradient(0deg, rgba(3,16,28,.46) 0%, rgba(3,16,28,.02) 34%, rgba(3,16,28,.05) 100%) !important;
}
.hero-premium-actions.hero-slider-inline-actions {
  left: 26px !important;
  bottom: 26px !important;
  right: auto !important;
  max-width: calc(100% - 52px) !important;
  z-index: 8 !important;
}
.hero-premium-controls.hero-slider-controls {
  left: 50% !important;
  right: auto !important;
  bottom: 26px !important;
  transform: translateX(-50%) scale(.86) !important;
  z-index: 9 !important;
}
.home-rating-news {
  margin-top: 0 !important;
}
@media (min-width: 1500px) {
  .hero-premium-slider.hero-slider {
    height: 520px !important;
    min-height: 520px !important;
  }
}
@media (max-width: 1100px) {
  .hero-premium-slider-section .hero-premium-stage {
    width: 100% !important;
    max-width: 100% !important;
  }
  .hero-premium-slider.hero-slider {
    height: clamp(360px, 46vw, 480px) !important;
    min-height: 360px !important;
  }
}
@media (max-width: 760px) {
  .hero-premium-slider.hero-slider {
    height: clamp(280px, 62vw, 380px) !important;
    min-height: 280px !important;
  }
  .hero-premium-actions.hero-slider-inline-actions {
    left: 14px !important;
    right: 14px !important;
    bottom: 14px !important;
    gap: 8px !important;
  }
  .hero-premium-actions .btn {
    height: 36px !important;
    min-width: 118px !important;
    padding: 0 12px !important;
    font-size: 11.5px !important;
  }
  .hero-premium-controls.hero-slider-controls {
    left: auto !important;
    right: 12px !important;
    bottom: 56px !important;
    transform: scale(.68) !important;
    transform-origin: right bottom !important;
  }
}
@media (max-width: 480px) {
  .hero-premium-slider.hero-slider {
    height: 250px !important;
    min-height: 250px !important;
  }
  .hero-premium-slide .hero-slide-img {
    object-fit: cover !important;
    object-position: center center !important;
  }
}

/* ===== V48 homepage hero banner correction =====
   True banner-fit slider: content-width aligned, compact height, no inner/blurred side image box. */
.hero-premium-slider-section.hero {
  padding: 0 !important;
  margin: 0 !important;
  min-height: 0 !important;
  background:
    radial-gradient(circle at 92% 12%, rgba(11,122,59,.18), transparent 30%),
    linear-gradient(115deg, #061827 0%, #082033 52%, #0A3D42 100%) !important;
  overflow: hidden !important;
}
.hero-premium-slider-section .hero-premium-stage {
  width: min(1180px, 92vw) !important;
  max-width: 1180px !important;
  margin: 0 auto !important;
  padding: 0 !important;
}
.hero-premium-slider.hero-slider {
  width: 100% !important;
  height: auto !important;
  min-height: 0 !important;
  max-height: none !important;
  aspect-ratio: 1672 / 600 !important;
  background: transparent !important;
  overflow: hidden !important;
  border: 0 !important;
  border-radius: 0 !important;
  box-shadow: none !important;
}
.hero-premium-slide.hero-slide {
  background: transparent !important;
  padding: 0 !important;
}
.hero-premium-slide .hero-slide-blur {
  display: none !important;
}
.hero-premium-slide .hero-slide-img {
  display: block !important;
  opacity: 1 !important;
  visibility: visible !important;
  position: absolute !important;
  inset: 0 !important;
  width: 100% !important;
  height: 100% !important;
  object-fit: cover !important;
  object-position: center center !important;
  pointer-events: none !important;
  z-index: 2 !important;
}
.hero-premium-slide::before {
  z-index: 3 !important;
  background: linear-gradient(0deg, rgba(3,16,28,.22) 0%, rgba(3,16,28,0) 42%) !important;
}
.hero-premium-actions.hero-slider-inline-actions {
  left: 28px !important;
  bottom: 24px !important;
  right: auto !important;
  max-width: calc(100% - 56px) !important;
  z-index: 8 !important;
}
.hero-premium-controls.hero-slider-controls {
  left: 50% !important;
  right: auto !important;
  bottom: 24px !important;
  transform: translateX(-50%) scale(.86) !important;
  z-index: 9 !important;
}
.home-rating-news {
  margin-top: 0 !important;
}
@media (max-width: 1100px) {
  .hero-premium-slider-section .hero-premium-stage {
    width: 100% !important;
    max-width: 100% !important;
  }
  .hero-premium-slider.hero-slider {
    aspect-ratio: 1672 / 600 !important;
  }
}
@media (max-width: 760px) {
  .hero-premium-slider.hero-slider {
    aspect-ratio: auto !important;
    height: 260px !important;
    min-height: 260px !important;
  }
  .hero-premium-slide .hero-slide-img {
    object-fit: cover !important;
    object-position: center center !important;
  }
  .hero-premium-actions.hero-slider-inline-actions {
    left: 14px !important;
    right: 14px !important;
    bottom: 14px !important;
    gap: 8px !important;
    justify-content: center !important;
  }
  .hero-premium-actions .btn {
    height: 36px !important;
    min-width: 118px !important;
    padding: 0 12px !important;
    font-size: 11.5px !important;
  }
  .hero-premium-controls.hero-slider-controls {
    left: auto !important;
    right: 12px !important;
    bottom: 56px !important;
    transform: scale(.68) !important;
    transform-origin: right bottom !important;
  }
}
@media (max-width: 420px) {
  .hero-premium-slider.hero-slider {
    height: 230px !important;
    min-height: 230px !important;
  }
}


/* ===== V49: transparent homepage banner container ===== */
.hero-premium-slider-section.hero {
  background: rgba(0, 0, 0, 0) !important;
}
.hero-premium-slider-section.hero::before,
.hero-premium-slider-section.hero::after {
  display: none !important;
  background: rgba(0, 0, 0, 0) !important;
}
.hero-premium-slider.hero-slider {
  background: rgba(0, 0, 0, 0) !important;
}


/* ===== V50: robust hero slider responsiveness for all display ratios =====
   The banner is content-width aligned, transparent behind the image, and keeps a stable aspect ratio
   so it will not disappear or become oversized on large monitors. */
.hero-premium-slider-section.hero {
  display: block !important;
  width: 100% !important;
  margin: 0 !important;
  padding: clamp(14px, 1.8vw, 26px) 0 0 !important;
  min-height: 0 !important;
  height: auto !important;
  background: rgba(0, 0, 0, 0) !important;
  overflow: visible !important;
}
.hero-premium-slider-section.hero::before,
.hero-premium-slider-section.hero::after {
  content: none !important;
  display: none !important;
}
.hero-premium-slider-section .hero-premium-stage {
  width: min(1180px, calc(100vw - 48px)) !important;
  max-width: 1180px !important;
  margin: 0 auto !important;
  padding: 0 !important;
  display: block !important;
  position: relative !important;
  overflow: visible !important;
}
.hero-premium-slider.hero-slider {
  display: block !important;
  position: relative !important;
  width: 100% !important;
  height: auto !important;
  min-height: 0 !important;
  max-height: none !important;
  aspect-ratio: 1672 / 600 !important;
  border-radius: 0 !important;
  border: 0 !important;
  box-shadow: none !important;
  background: rgba(0, 0, 0, 0) !important;
  overflow: hidden !important;
  isolation: isolate !important;
}
.hero-premium-slide.hero-slide {
  display: block !important;
  position: absolute !important;
  inset: 0 !important;
  width: 100% !important;
  height: 100% !important;
  min-height: 0 !important;
  background: rgba(0, 0, 0, 0) !important;
  opacity: 0;
  visibility: hidden;
  z-index: 1;
}
.hero-premium-slide.hero-slide.is-active {
  opacity: 1 !important;
  visibility: visible !important;
  z-index: 2 !important;
}
.hero-premium-slide .hero-slide-blur {
  display: none !important;
}
.hero-premium-slide .hero-slide-img {
  display: block !important;
  position: absolute !important;
  inset: 0 !important;
  width: 100% !important;
  height: 100% !important;
  max-width: none !important;
  object-fit: contain !important;
  object-position: center center !important;
  opacity: 1 !important;
  visibility: visible !important;
  z-index: 2 !important;
}
.hero-premium-slide::before {
  content: "" !important;
  position: absolute !important;
  left: 0 !important;
  right: 0 !important;
  bottom: 0 !important;
  top: auto !important;
  height: 38% !important;
  z-index: 3 !important;
  pointer-events: none !important;
  background: linear-gradient(0deg, rgba(3,16,28,.34) 0%, rgba(3,16,28,.12) 44%, rgba(3,16,28,0) 100%) !important;
}
.hero-premium-actions.hero-slider-inline-actions {
  position: absolute !important;
  left: clamp(16px, 2.3vw, 30px) !important;
  right: auto !important;
  bottom: clamp(14px, 2vw, 24px) !important;
  top: auto !important;
  z-index: 8 !important;
  display: flex !important;
  flex-wrap: wrap !important;
  gap: 10px !important;
  max-width: calc(100% - 60px) !important;
}
.hero-premium-controls.hero-slider-controls {
  position: absolute !important;
  left: 50% !important;
  right: auto !important;
  bottom: clamp(14px, 2vw, 24px) !important;
  top: auto !important;
  transform: translateX(-50%) scale(.84) !important;
  z-index: 9 !important;
}
@media (min-width: 1600px) {
  .hero-premium-slider-section .hero-premium-stage {
    width: min(1240px, calc(100vw - 96px)) !important;
    max-width: 1240px !important;
  }
}
@media (min-width: 2200px) {
  .hero-premium-slider-section .hero-premium-stage {
    width: 1280px !important;
    max-width: 1280px !important;
  }
}
@media (max-width: 980px) {
  .hero-premium-slider-section.hero {
    padding-top: 12px !important;
  }
  .hero-premium-slider-section .hero-premium-stage {
    width: min(100%, calc(100vw - 28px)) !important;
  }
  .hero-premium-slider.hero-slider {
    aspect-ratio: 16 / 7 !important;
  }
  .hero-premium-controls.hero-slider-controls {
    transform: translateX(-50%) scale(.76) !important;
  }
}
@media (max-width: 640px) {
  .hero-premium-slider-section .hero-premium-stage {
    width: calc(100vw - 20px) !important;
  }
  .hero-premium-slider.hero-slider {
    aspect-ratio: 16 / 8.3 !important;
  }
  .hero-premium-slide .hero-slide-img {
    object-fit: contain !important;
  }
  .hero-premium-actions.hero-slider-inline-actions {
    left: 10px !important;
    right: 10px !important;
    bottom: 10px !important;
    max-width: none !important;
    justify-content: center !important;
    gap: 8px !important;
  }
  .hero-premium-actions.hero-slider-inline-actions .btn {
    min-width: 122px !important;
    height: 38px !important;
    padding: 0 12px !important;
    font-size: 12px !important;
  }
  .hero-premium-controls.hero-slider-controls {
    left: 50% !important;
    bottom: 52px !important;
    transform: translateX(-50%) scale(.64) !important;
  }
}
@media (max-width: 380px) {
  .hero-premium-slider.hero-slider {
    aspect-ratio: 16 / 9.2 !important;
  }
  .hero-premium-controls.hero-slider-controls {
    display: none !important;
  }
}

/* ===== V51: final hero slider fit for all screen ratios =====
   The banner now has a real fixed visual area, fills the available content width,
   and uses cover-fit so large monitors do not show empty/gray side gaps. */
.hero-premium-slider-section.hero {
  display: block !important;
  width: 100% !important;
  margin: 0 !important;
  padding: 0 !important;
  background: rgba(0, 0, 0, 0) !important;
  overflow: hidden !important;
  min-height: 0 !important;
}
.hero-premium-slider-section.hero::before,
.hero-premium-slider-section.hero::after {
  display: none !important;
  content: none !important;
}
.hero-premium-slider-section .hero-premium-stage {
  width: min(1180px, calc(100vw - 48px)) !important;
  max-width: 1180px !important;
  margin: 0 auto !important;
  padding: 0 !important;
  position: relative !important;
  display: block !important;
  overflow: hidden !important;
}
.hero-premium-slider-section .hero-premium-slider.hero-slider {
  display: block !important;
  position: relative !important;
  width: 100% !important;
  height: clamp(310px, 31vw, 420px) !important;
  min-height: 310px !important;
  max-height: 420px !important;
  aspect-ratio: auto !important;
  overflow: hidden !important;
  background: rgba(0, 0, 0, 0) !important;
  border: 0 !important;
  border-radius: 0 !important;
  box-shadow: none !important;
  isolation: isolate !important;
}
.hero-premium-slider-section .hero-premium-slide.hero-slide {
  position: absolute !important;
  inset: 0 !important;
  width: 100% !important;
  height: 100% !important;
  min-height: 0 !important;
  padding: 0 !important;
  margin: 0 !important;
  background: rgba(0, 0, 0, 0) !important;
  opacity: 0 !important;
  visibility: hidden !important;
  transform: none !important;
  transition: opacity .55s ease, visibility .55s ease !important;
}
.hero-premium-slider-section .hero-premium-slide.hero-slide.is-active {
  opacity: 1 !important;
  visibility: visible !important;
  z-index: 2 !important;
}
.hero-premium-slider-section .hero-slide-blur {
  display: none !important;
}
.hero-premium-slider-section .hero-slide-img {
  display: block !important;
  position: absolute !important;
  inset: 0 !important;
  width: 100% !important;
  height: 100% !important;
  max-width: none !important;
  max-height: none !important;
  object-fit: cover !important;
  object-position: center center !important;
  opacity: 1 !important;
  visibility: visible !important;
  filter: none !important;
  transform: none !important;
  z-index: 2 !important;
}
.hero-premium-slider-section .hero-premium-slide::before {
  content: "" !important;
  position: absolute !important;
  left: 0 !important;
  right: 0 !important;
  top: auto !important;
  bottom: 0 !important;
  height: 38% !important;
  z-index: 3 !important;
  pointer-events: none !important;
  background: linear-gradient(0deg, rgba(3,16,28,.42) 0%, rgba(3,16,28,.13) 50%, rgba(3,16,28,0) 100%) !important;
}
.hero-premium-slider-section .hero-premium-actions.hero-slider-inline-actions {
  position: absolute !important;
  left: clamp(18px, 2.2vw, 30px) !important;
  right: auto !important;
  bottom: clamp(16px, 2vw, 24px) !important;
  top: auto !important;
  z-index: 8 !important;
  display: flex !important;
  align-items: center !important;
  flex-wrap: wrap !important;
  gap: 10px !important;
  max-width: calc(100% - 58px) !important;
}
.hero-premium-slider-section .hero-premium-actions .btn {
  height: 42px !important;
  min-width: 136px !important;
  padding: 0 18px !important;
  font-size: 13px !important;
  white-space: nowrap !important;
}
.hero-premium-slider-section .hero-premium-controls.hero-slider-controls {
  position: absolute !important;
  left: 50% !important;
  right: auto !important;
  bottom: clamp(16px, 2vw, 24px) !important;
  top: auto !important;
  transform: translateX(-50%) scale(.86) !important;
  transform-origin: center bottom !important;
  z-index: 9 !important;
}
@media (min-width: 1600px) {
  .hero-premium-slider-section .hero-premium-stage {
    width: min(1180px, calc(100vw - 96px)) !important;
  }
  .hero-premium-slider-section .hero-premium-slider.hero-slider {
    height: 420px !important;
    min-height: 420px !important;
    max-height: 420px !important;
  }
}
@media (max-width: 1180px) {
  .hero-premium-slider-section .hero-premium-stage {
    width: calc(100vw - 36px) !important;
  }
  .hero-premium-slider-section .hero-premium-slider.hero-slider {
    height: clamp(300px, 35vw, 410px) !important;
    min-height: 300px !important;
  }
}
@media (max-width: 980px) {
  .hero-premium-slider-section .hero-premium-stage {
    width: calc(100vw - 28px) !important;
  }
  .hero-premium-slider-section .hero-premium-slider.hero-slider {
    height: clamp(270px, 44vw, 360px) !important;
    min-height: 270px !important;
  }
  .hero-premium-slider-section .hero-premium-actions.hero-slider-inline-actions {
    left: 16px !important;
    bottom: 14px !important;
  }
  .hero-premium-slider-section .hero-premium-controls.hero-slider-controls {
    right: 16px !important;
    left: auto !important;
    bottom: 14px !important;
    transform: scale(.76) !important;
    transform-origin: right bottom !important;
  }
}
@media (max-width: 640px) {
  .hero-premium-slider-section .hero-premium-stage {
    width: 100% !important;
  }
  .hero-premium-slider-section .hero-premium-slider.hero-slider {
    height: clamp(230px, 58vw, 300px) !important;
    min-height: 230px !important;
  }
  .hero-premium-slider-section .hero-slide-img {
    object-position: center center !important;
  }
  .hero-premium-slider-section .hero-premium-actions.hero-slider-inline-actions {
    left: 12px !important;
    right: 12px !important;
    bottom: 10px !important;
    justify-content: center !important;
    max-width: none !important;
    gap: 8px !important;
  }
  .hero-premium-slider-section .hero-premium-actions .btn {
    height: 36px !important;
    min-width: 118px !important;
    padding: 0 12px !important;
    font-size: 11.5px !important;
  }
  .hero-premium-slider-section .hero-premium-controls.hero-slider-controls {
    left: 50% !important;
    right: auto !important;
    bottom: 50px !important;
    transform: translateX(-50%) scale(.64) !important;
    transform-origin: center bottom !important;
  }
}
@media (max-width: 380px) {
  .hero-premium-slider-section .hero-premium-slider.hero-slider {
    height: 220px !important;
    min-height: 220px !important;
  }
  .hero-premium-slider-section .hero-premium-controls.hero-slider-controls {
    display: none !important;
  }
}

/* ===== V53 Blog single article refinement ===== */
.blog-single-hero {
  padding: 74px 0 52px;
  background:
    radial-gradient(circle at 84% 18%, rgba(11,122,59,.08), transparent 28%),
    linear-gradient(180deg, #F8FCFA 0%, #FFFFFF 100%);
  border-bottom: 1px solid #E4EFE8;
}
.blog-single-wrap {
  max-width: 980px;
}
.blog-single-hero .breadcrumb {
  margin-bottom: 14px;
  color: var(--green);
  font-weight: 900;
  letter-spacing: .08em;
  text-transform: uppercase;
  font-size: 12px;
}
.blog-single-hero h1 {
  margin: 0;
  color: var(--navy);
  font-size: clamp(34px, 4.4vw, 62px);
  line-height: 1.05;
  letter-spacing: -.055em;
  max-width: 920px;
}
.blog-single-hero h1::after {
  content: "";
  display: block;
  width: 78px;
  height: 4px;
  margin-top: 18px;
  border-radius: 999px;
  background: var(--green);
}
.blog-single-meta {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  margin: 18px 0 0;
}
.blog-single-meta span {
  display: inline-flex;
  align-items: center;
  min-height: 34px;
  padding: 8px 12px;
  border-radius: 999px;
  background: #EAF5EF;
  color: var(--green-dark);
  border: 1px solid #DDEFE5;
  font-size: 13px;
  font-weight: 900;
}
.blog-single-hero p {
  margin: 20px 0 0;
  color: #475467;
  font-size: 19px;
  line-height: 1.72;
  max-width: 780px;
}
.blog-single-section {
  padding: 66px 0 92px;
  background: linear-gradient(180deg, #FFFFFF 0%, #F8FCFA 100%);
}
.blog-single-card {
  background: #fff;
  border: 1px solid #E3EFE8;
  border-radius: 30px;
  overflow: hidden;
  box-shadow: 0 20px 50px rgba(7,21,35,.08);
}
.blog-single-featured {
  margin: 0;
  background: #071523;
  border-bottom: 1px solid #E3EFE8;
}
.blog-single-featured img {
  width: 100%;
  max-height: 560px;
  object-fit: cover;
  object-position: center;
  display: block;
}
.blog-single-content {
  padding: clamp(28px, 5vw, 58px);
  color: #344054;
  font-size: 18px;
  line-height: 1.82;
}
.blog-single-content > *:first-child {
  margin-top: 0;
}
.blog-single-content > *:last-child {
  margin-bottom: 0;
}
.blog-single-content h1,
.blog-single-content h2,
.blog-single-content h3,
.blog-single-content h4 {
  color: var(--navy);
  letter-spacing: -.025em;
  line-height: 1.18;
  margin: 1.6em 0 .65em;
}
.blog-single-content h2 { font-size: 34px; }
.blog-single-content h3 { font-size: 26px; }
.blog-single-content p { margin: 0 0 1.1em; }
.blog-single-content a { color: var(--green); font-weight: 800; }
.blog-single-content ul,
.blog-single-content ol { padding-left: 1.25em; margin: 0 0 1.2em; }
.blog-single-content li { margin: .45em 0; }
.blog-single-content blockquote {
  margin: 2em 0;
  padding: 24px 28px;
  border-left: 5px solid var(--green);
  border-radius: 18px;
  background: #F4FBF7;
  color: #1D2939;
  font-size: 20px;
  line-height: 1.65;
}
.blog-single-content img {
  max-width: 100%;
  height: auto;
  border-radius: 22px;
  box-shadow: 0 14px 34px rgba(7,21,35,.08);
}
.blog-single-content figure {
  margin: 2em 0;
}
.blog-single-content figcaption {
  color: #667085;
  font-size: 14px;
  text-align: center;
  margin-top: 10px;
}
@media (max-width: 720px) {
  .blog-single-hero { padding: 54px 0 40px; }
  .blog-single-section { padding: 38px 0 64px; }
  .blog-single-card { border-radius: 24px; }
  .blog-single-content { font-size: 16.5px; line-height: 1.75; }
  .blog-single-content h2 { font-size: 28px; }
  .blog-single-content h3 { font-size: 22px; }
  .blog-single-featured img { max-height: 360px; }
}


/* ===== V55 Hero slider CTA position fix =====
   Keep Request a Rating and View Rating Reports inside the bottom-right corner of the slider. */
.hero-premium-slider-section .hero-premium-actions.hero-slider-inline-actions {
  left: auto !important;
  right: clamp(18px, 2.2vw, 30px) !important;
  bottom: clamp(16px, 2vw, 24px) !important;
  justify-content: flex-end !important;
  max-width: min(420px, calc(100% - 58px)) !important;
  z-index: 10 !important;
}
.hero-premium-slider-section .hero-premium-actions .btn {
  box-shadow: 0 10px 24px rgba(0,0,0,.18) !important;
}
@media (max-width: 980px) {
  .hero-premium-slider-section .hero-premium-actions.hero-slider-inline-actions {
    left: auto !important;
    right: 16px !important;
    bottom: 14px !important;
    justify-content: flex-end !important;
    max-width: calc(100% - 32px) !important;
  }
  .hero-premium-slider-section .hero-premium-controls.hero-slider-controls {
    left: 16px !important;
    right: auto !important;
    bottom: 14px !important;
    transform: scale(.76) !important;
    transform-origin: left bottom !important;
  }
}
@media (max-width: 640px) {
  .hero-premium-slider-section .hero-premium-actions.hero-slider-inline-actions {
    left: 12px !important;
    right: 12px !important;
    bottom: 10px !important;
    justify-content: center !important;
    max-width: none !important;
  }
  .hero-premium-slider-section .hero-premium-controls.hero-slider-controls {
    left: 50% !important;
    right: auto !important;
    bottom: 50px !important;
    transform: translateX(-50%) scale(.64) !important;
    transform-origin: center bottom !important;
  }
}


/* ===== V75 Slower homepage hero slider movement ===== */
.hero-premium-slider-section .hero-slide,
.hero-slider .hero-slide {
  transition: opacity .75s ease-in-out, visibility .75s ease-in-out, transform 6.5s ease-in-out !important;
}
.hero-premium-slider-section .hero-slide.is-active,
.hero-slider .hero-slide.is-active {
  transform: scale(1) !important;
}
.hero-premium-slider-section .hero-slider-dot,
.hero-slider .hero-slider-dot {
  transition: width .22s ease, background .22s ease, opacity .22s ease !important;
}

/* ===== V57 Monthly Magazine showcase redesign ===== */
.magazine-showcase-page {
  background: linear-gradient(180deg, #FFFFFF 0%, #F7FCF9 46%, #FFFFFF 100%);
}
.magazine-showcase-wrap {
  display: grid;
  gap: 34px;
}
.magazine-spotlight {
  display: grid;
  grid-template-columns: minmax(320px, .9fr) minmax(0, 1.1fr);
  gap: 34px;
  align-items: stretch;
  padding: 34px;
  border-radius: 34px;
  background:
    radial-gradient(circle at 90% 12%, rgba(11,122,59,.13), transparent 28%),
    linear-gradient(135deg, #F4FBF7 0%, #FFFFFF 70%);
  border: 1px solid #DDEFE5;
  box-shadow: 0 22px 54px rgba(7,21,35,.08);
  overflow: hidden;
  position: relative;
}
.magazine-spotlight::before {
  content: "";
  position: absolute;
  right: -100px;
  bottom: -120px;
  width: 280px;
  height: 280px;
  border-radius: 50%;
  background: rgba(11,122,59,.08);
}
.magazine-spotlight > * {
  position: relative;
  z-index: 1;
}
.magazine-spotlight-media {
  min-height: 430px;
  border-radius: 28px;
  overflow: hidden;
  background: linear-gradient(135deg, #0B7A3B 0%, #0D2235 100%);
  box-shadow: 0 26px 62px rgba(7,21,35,.18);
}
.magazine-spotlight-media img {
  width: 100%;
  height: 100%;
  min-height: 430px;
  object-fit: cover;
  display: block;
}
.magazine-spotlight-placeholder,
.magazine-issue-placeholder {
  width: 100%;
  height: 100%;
  min-height: 430px;
  padding: 32px;
  color: #fff;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  background:
    radial-gradient(circle at 84% 74%, rgba(255,255,255,.18), transparent 32%),
    linear-gradient(140deg, #0B7A3B 0%, #074A2A 55%, #0D2235 100%);
}
.magazine-spotlight-placeholder span,
.magazine-issue-placeholder span {
  text-transform: uppercase;
  letter-spacing: .16em;
  font-size: 13px;
  font-weight: 900;
  color: #DFF8E9;
}
.magazine-spotlight-placeholder strong {
  font-size: clamp(32px, 4vw, 52px);
  line-height: 1.02;
  letter-spacing: -.05em;
}
.magazine-spotlight-copy {
  align-self: center;
  padding: 12px 4px;
}
.magazine-eyebrow {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  color: var(--green);
  background: #EAF5EF;
  border: 1px solid #DDEFE5;
  border-radius: 999px;
  padding: 8px 12px;
  font-size: 12px;
  font-weight: 900;
  letter-spacing: .11em;
  text-transform: uppercase;
  margin-bottom: 16px;
}
.magazine-spotlight-copy h2,
.single-magazine-content h2 {
  margin: 0 0 16px;
  color: var(--navy);
  font-size: clamp(36px, 4vw, 58px);
  line-height: 1.03;
  letter-spacing: -.055em;
}
.magazine-meta-row {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  margin: 0 0 20px;
}
.magazine-meta-row span,
.magazine-issue-meta span {
  display: inline-flex;
  align-items: center;
  padding: 8px 12px;
  border-radius: 999px;
  background: #F2FBF6;
  border: 1px solid #DDEFE5;
  color: var(--green-dark);
  font-size: 13px;
  font-weight: 900;
}
.magazine-spotlight-copy p,
.single-magazine-content p {
  margin: 0 0 20px;
  color: #475467;
  font-size: 18px;
  line-height: 1.75;
  max-width: 760px;
}
.magazine-spotlight-actions {
  display: flex;
  gap: 12px;
  flex-wrap: wrap;
  align-items: center;
  margin-top: 24px;
}
.magazine-showcase-filter {
  display: grid;
  grid-template-columns: .7fr 1.3fr;
  gap: 22px;
  align-items: end;
  border-radius: 28px;
  padding: 26px;
  background: #FFFFFF;
  border: 1px solid #DDEFE5;
  box-shadow: 0 16px 36px rgba(7,21,35,.05);
}
.magazine-filter-intro h2 {
  margin: 0 0 8px;
  color: var(--navy);
  font-size: 28px;
  line-height: 1.08;
  letter-spacing: -.035em;
}
.magazine-filter-intro p {
  margin: 0;
  color: #667085;
  font-size: 15px;
  line-height: 1.55;
}
.magazine-showcase-filter .clean-magazine-filter {
  display: grid;
  grid-template-columns: repeat(3, minmax(135px, 1fr)) auto !important;
  gap: 12px;
}
.magazine-showcase-filter select {
  min-height: 52px;
  border-radius: 16px !important;
  border-color: #D5E5DB !important;
  background-color: #fff;
  font-weight: 750;
}
.magazine-showcase-head {
  margin-bottom: 22px;
}
.magazine-showcase-head h2 {
  margin: 0;
  color: var(--navy);
  font-size: 36px;
  line-height: 1.08;
  letter-spacing: -.04em;
}
.magazine-showcase-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 22px;
}
.magazine-issue-card {
  padding: 0 !important;
  overflow: hidden;
  border-radius: 26px !important;
  background: #fff !important;
  display: flex;
  flex-direction: column;
  min-height: 100%;
  transition: transform .22s ease, box-shadow .22s ease, border-color .22s ease;
}
.magazine-issue-card:hover {
  transform: translateY(-6px);
  border-color: rgba(11,122,59,.45) !important;
  box-shadow: 0 22px 48px rgba(11,122,59,.13) !important;
}
.magazine-issue-image {
  display: block;
  height: 230px;
  overflow: hidden;
  background: #EAF5EF;
  text-decoration: none;
}
.magazine-issue-image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  transition: transform .28s ease;
}
.magazine-issue-card:hover .magazine-issue-image img {
  transform: scale(1.035);
}
.magazine-issue-placeholder {
  min-height: 230px;
}
.magazine-issue-placeholder strong {
  font-size: 42px;
  line-height: 1;
}
.magazine-issue-body {
  display: flex;
  flex-direction: column;
  gap: 12px;
  padding: 22px;
  flex: 1;
}
.magazine-issue-meta {
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
}
.magazine-issue-meta span {
  font-size: 11px;
  padding: 6px 9px;
}
.magazine-issue-card h3 {
  margin: 0 !important;
  font-size: 23px !important;
  line-height: 1.18 !important;
  letter-spacing: -.025em;
}
.magazine-issue-card h3 a {
  color: var(--navy);
  text-decoration: none;
}
.magazine-issue-card h3 a:hover {
  color: var(--green);
}
.magazine-issue-card p {
  margin: 0;
  color: #667085;
  font-size: 15px;
  line-height: 1.6;
  flex: 1;
}
.magazine-issue-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
  margin-top: 8px;
}
.magazine-issue-actions a {
  color: var(--green);
  font-weight: 900;
  text-decoration: none;
  font-size: 14px;
}
.magazine-issue-actions a:hover {
  text-decoration: underline;
}
.single-magazine-layout {
  display: grid;
  grid-template-columns: minmax(300px, .78fr) minmax(0, 1.22fr);
  gap: 34px;
  padding: 34px;
  border-radius: 34px;
  border: 1px solid #DDEFE5;
  background: #fff;
  box-shadow: 0 22px 54px rgba(7,21,35,.08);
}
.single-magazine-cover {
  border-radius: 28px;
  overflow: hidden;
  background: #EAF5EF;
  box-shadow: 0 18px 44px rgba(7,21,35,.12);
}
.single-magazine-cover img {
  width: 100%;
  height: 100%;
  min-height: 500px;
  object-fit: cover;
  display: block;
}
.single-magazine-content {
  align-self: center;
}
.magazine-synopsis-content {
  color: #475467;
  font-size: 18px;
  line-height: 1.75;
}
.magazine-synopsis-content p {
  margin: 0 0 18px;
}
.single-magazine-actions {
  padding-top: 8px;
}
@media (max-width: 1100px) {
  .magazine-spotlight,
  .single-magazine-layout,
  .magazine-showcase-filter {
    grid-template-columns: 1fr;
  }
  .magazine-showcase-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
  .magazine-spotlight-media,
  .magazine-spotlight-media img,
  .magazine-spotlight-placeholder {
    min-height: 360px;
  }
}
@media (max-width: 720px) {
  .magazine-spotlight,
  .single-magazine-layout,
  .magazine-showcase-filter,
  .magazine-clean-archive {
    padding: 20px !important;
    border-radius: 24px !important;
  }
  .magazine-showcase-grid,
  .magazine-showcase-filter .clean-magazine-filter {
    grid-template-columns: 1fr !important;
  }
  .magazine-spotlight-media,
  .magazine-spotlight-media img,
  .magazine-spotlight-placeholder {
    min-height: 280px;
  }
  .magazine-spotlight-copy h2,
  .single-magazine-content h2 {
    font-size: 34px;
  }
  .magazine-spotlight-copy p,
  .single-magazine-content p,
  .magazine-synopsis-content {
    font-size: 16px;
  }
  .single-magazine-cover img {
    min-height: 320px;
  }
  .magazine-issue-image {
    height: 210px;
  }
}

/* ===== V58 Monthly Magazine premium publication layout ===== */
.magazine-premium-page {
  background:
    radial-gradient(circle at 12% 8%, rgba(247, 181, 63, .13), transparent 24%),
    radial-gradient(circle at 92% 18%, rgba(11, 122, 59, .12), transparent 24%),
    linear-gradient(180deg, #FFFDF8 0%, #F7FCF9 42%, #FFFFFF 100%) !important;
}
.magazine-premium-spotlight {
  grid-template-columns: minmax(340px, .95fr) minmax(0, 1.05fr) !important;
  padding: 28px !important;
  border-radius: 34px !important;
  background:
    radial-gradient(circle at 88% 10%, rgba(255, 173, 32, .20), transparent 24%),
    radial-gradient(circle at 8% 82%, rgba(11,122,59,.14), transparent 24%),
    linear-gradient(135deg, #fff 0%, #FFF9EC 38%, #F3FCF7 100%) !important;
  border: 1px solid rgba(11,122,59,.20) !important;
}
.magazine-premium-spotlight::after {
  content: "";
  position: absolute;
  inset: auto 26px 26px auto;
  width: 120px;
  height: 120px;
  border-radius: 32px;
  background: linear-gradient(135deg, rgba(255, 184, 66, .22), rgba(11, 122, 59, .12));
  transform: rotate(8deg);
}
.magazine-spotlight-media {
  min-height: 420px !important;
  border-radius: 28px !important;
  background: #0D2235 !important;
  box-shadow: 0 26px 62px rgba(7,21,35,.20) !important;
  text-decoration: none !important;
}
.magazine-spotlight-media img {
  min-height: 420px !important;
  object-fit: cover !important;
}
.magazine-spotlight-copy h2 a,
.magazine-issue-card h3 a {
  color: inherit;
  text-decoration: none;
}
.magazine-spotlight-copy h2 a:hover,
.magazine-issue-card h3 a:hover {
  color: var(--green) !important;
}
.magazine-featured-meta {
  margin-bottom: 18px !important;
}
.magazine-spotlight-copy p,
.magazine-issue-card p {
  display: none !important;
}
.magazine-showcase-filter {
  background:
    linear-gradient(135deg, #FFFFFF 0%, #F9FFF3 54%, #FFF8EC 100%) !important;
  border: 1px solid rgba(11,122,59,.18) !important;
}
.magazine-showcase-filter .btn.primary {
  background: linear-gradient(135deg, #0B7A3B 0%, #0E9C4F 100%) !important;
}
.magazine-showcase-head {
  display: flex;
  justify-content: space-between;
  align-items: end;
  gap: 18px;
  padding: 4px 2px 0;
}
.magazine-showcase-head h2 {
  font-size: clamp(30px, 3vw, 44px) !important;
}
.magazine-showcase-grid {
  gap: 26px !important;
}
.magazine-issue-card {
  border: 1px solid rgba(11,122,59,.16) !important;
  box-shadow: 0 16px 34px rgba(7,21,35,.06) !important;
  background: linear-gradient(180deg, #FFFFFF 0%, #FFFCF5 100%) !important;
  position: relative;
}
.magazine-issue-card:nth-child(3n+2) {
  background: linear-gradient(180deg, #FFFFFF 0%, #F5FBFF 100%) !important;
}
.magazine-issue-card:nth-child(3n+3) {
  background: linear-gradient(180deg, #FFFFFF 0%, #F3FCF7 100%) !important;
}
.magazine-issue-card::after {
  content: "";
  position: absolute;
  right: 18px;
  bottom: 18px;
  width: 44px;
  height: 44px;
  border-radius: 16px;
  background: rgba(11,122,59,.06);
  pointer-events: none;
}
.magazine-issue-image {
  height: 245px !important;
  background: linear-gradient(135deg, #F5E4B7, #EAF5EF) !important;
}
.magazine-issue-image img {
  object-fit: cover !important;
}
.magazine-issue-body {
  gap: 16px !important;
  padding: 24px !important;
}
.magazine-issue-meta span,
.magazine-meta-row span {
  background: #FFFFFF !important;
  border-color: rgba(11,122,59,.18) !important;
  box-shadow: 0 8px 18px rgba(7,21,35,.04);
}
.magazine-issue-card h3 {
  min-height: 58px;
  font-size: 24px !important;
}
.magazine-issue-actions {
  margin-top: auto !important;
  padding-top: 4px;
}
.magazine-issue-actions a {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 38px;
  padding: 8px 12px;
  border-radius: 999px;
  background: #F8FCFA;
  border: 1px solid rgba(11,122,59,.18);
  color: var(--green) !important;
}
.magazine-issue-actions a:hover {
  background: var(--green) !important;
  color: #fff !important;
  text-decoration: none !important;
}
.single-magazine-readable {
  display: block !important;
  max-width: 1040px;
  margin: 0 auto;
  padding: 0 !important;
  overflow: hidden;
  background:
    radial-gradient(circle at 92% 10%, rgba(255,184,66,.15), transparent 24%),
    #fff !important;
}
.single-magazine-hero-cover {
  width: 100%;
  min-height: 420px;
  max-height: 560px;
  overflow: hidden;
  background: #EAF5EF;
  border-bottom: 1px solid #E3EFE8;
}
.single-magazine-hero-cover img {
  width: 100%;
  height: 100%;
  min-height: 420px;
  object-fit: cover;
  display: block;
}
.single-magazine-readable .single-magazine-content {
  max-width: 820px;
  margin: 0 auto;
  padding: 42px 34px 46px;
}
.single-magazine-readable .single-magazine-content h2 {
  font-size: clamp(36px, 4vw, 58px) !important;
  margin-top: 8px !important;
}
.single-magazine-readable .magazine-synopsis-content {
  font-size: 18px !important;
  line-height: 1.85 !important;
}
.single-magazine-readable .magazine-synopsis-content p:first-child::first-letter {
  font-size: 4.2em;
  line-height: .9;
  float: left;
  margin: .08em .12em 0 0;
  color: var(--green);
  font-weight: 900;
}
.single-magazine-readable .single-magazine-actions {
  border-top: 1px solid #E6EFE9;
  margin-top: 28px;
  padding-top: 24px;
}
@media (max-width: 1100px) {
  .magazine-premium-spotlight {
    grid-template-columns: 1fr !important;
  }
  .magazine-spotlight-media,
  .magazine-spotlight-media img {
    min-height: 360px !important;
  }
  .magazine-showcase-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  }
}
@media (max-width: 720px) {
  .magazine-premium-spotlight,
  .magazine-showcase-filter,
  .magazine-clean-archive {
    padding: 18px !important;
  }
  .magazine-showcase-grid,
  .magazine-showcase-filter .clean-magazine-filter {
    grid-template-columns: 1fr !important;
  }
  .magazine-spotlight-media,
  .magazine-spotlight-media img {
    min-height: 280px !important;
  }
  .magazine-issue-image {
    height: 220px !important;
  }
  .magazine-issue-card h3 {
    min-height: auto;
  }
  .single-magazine-hero-cover,
  .single-magazine-hero-cover img {
    min-height: 260px;
  }
  .single-magazine-readable .single-magazine-content {
    padding: 28px 20px 34px;
  }
  .single-magazine-readable .magazine-synopsis-content {
    font-size: 16px !important;
  }
  .single-magazine-readable .magazine-synopsis-content p:first-child::first-letter {
    font-size: 3.4em;
  }
}

/* ===== V61 Home page aesthetic refinement: green + cool teal accent ===== */
:root {
  --waso-accent: #1F78A6;
  --waso-accent-soft: #EAF6FB;
  --waso-gold: #5AAE89;
  --waso-mint: #EAF7EF;
}

body.home,
.home #homeView {
  background:
    radial-gradient(circle at 8% 32%, rgba(31,120,166,.055), transparent 25%),
    radial-gradient(circle at 88% 58%, rgba(11,122,59,.07), transparent 28%),
    linear-gradient(180deg,#FFFFFF 0%,#FBFEFC 42%,#F6FBF8 100%);
}

.home .hero-premium-slider-section.hero {
  position: relative;
}

.home .hero-premium-slider-section.hero::before {
  content: "";
  position: absolute;
  left: 50%;
  top: 20px;
  width: min(1120px, 92vw);
  height: calc(100% - 40px);
  transform: translateX(-50%);
  border-radius: 28px;
  background:
    radial-gradient(circle at 12% 18%, rgba(31,120,166,.12), transparent 26%),
    radial-gradient(circle at 88% 22%, rgba(11,122,59,.14), transparent 28%);
  pointer-events: none;
  opacity: .72;
}

.home .hero-premium-slider-section .hero-premium-slider.hero-slider {
  box-shadow: 0 26px 62px rgba(7,21,35,.18), 0 0 0 1px rgba(255,255,255,.08) inset;
}

.home .hero-premium-actions .btn.primary,
.home .contact-copy .btn,
.home .inside-credit-main .btn {
  background: linear-gradient(135deg, var(--green) 0%, #0A8B46 72%);
  box-shadow: 0 12px 26px rgba(11,122,59,.22);
}

.home .hero-premium-actions .btn.ghost {
  border-color: rgba(255,255,255,.62);
  background: rgba(255,255,255,.10);
  backdrop-filter: blur(10px);
}

.home .rating-news-section {
  position: relative;
  overflow: hidden;
  background:
    radial-gradient(circle at 10% 14%, rgba(31,120,166,.07), transparent 28%),
    linear-gradient(180deg,#FFFFFF 0%,#F6FBF8 100%);
}

.home .rating-news-section::before {
  content: "";
  position: absolute;
  right: -120px;
  top: -130px;
  width: 310px;
  height: 310px;
  border-radius: 50%;
  background: rgba(31,120,166,.07);
}

.home .rating-news-head h2,
.home .product-head h2,
.home .insight-label strong {
  letter-spacing: -.045em;
}

.home .rating-news-head h2::after,
.home .product-head h2::after,
.home .insight-label strong::after {
  content: "";
  display: block;
  width: 80px;
  height: 4px;
  margin-top: 12px;
  border-radius: 999px;
  background: linear-gradient(90deg, var(--green), var(--waso-accent));
}

.home .rating-news-card,
.home .insight-item,
.home .service-mini-card,
.home .contact-action-card,
.home .insight-mini-card {
  border-color: rgba(11,122,59,.14) !important;
  box-shadow: 0 16px 38px rgba(7,21,35,.055) !important;
  transition: transform .22s ease, box-shadow .22s ease, border-color .22s ease;
}

.home .rating-news-card:hover,
.home .insight-item:hover,
.home .service-mini-card:hover,
.home .contact-action-card:hover,
.home .insight-mini-card:hover {
  transform: translateY(-7px);
  border-color: rgba(31,120,166,.36) !important;
  box-shadow: 0 24px 52px rgba(7,21,35,.10), 0 10px 24px rgba(31,120,166,.07) !important;
}

.home .rating-news-card::before,
.home .service-mini-card::before,
.home .contact-action-card::before {
  background: linear-gradient(90deg, var(--green), var(--waso-accent)) !important;
}

.home .rating-news-link,
.home .link-red,
.home .insight-item:hover h3,
.home .product-card:hover .product-body h3 {
  color: var(--green) !important;
}

.home .rating-news-card small,
.home .product-body small,
.home .insight-mini-card small,
.home .approach-label small {
  color: var(--green) !important;
}

.home .insights {
  position: relative;
  background:
    linear-gradient(180deg,#FFFFFF 0%,#FBFEFC 100%);
}

.home .insights::before {
  content: "";
  position: absolute;
  left: 0;
  right: 0;
  top: 0;
  height: 1px;
  background: linear-gradient(90deg, transparent, rgba(11,122,59,.18), rgba(31,120,166,.12), transparent);
}

.home .featured-insight {
  border-radius: 28px !important;
  box-shadow: 0 24px 56px rgba(7,21,35,.14);
}

.home .featured-insight::after {
  content: "";
  position: absolute;
  right: -60px;
  bottom: -70px;
  width: 210px;
  height: 210px;
  border-radius: 50%;
  background: radial-gradient(circle, rgba(31,120,166,.16), transparent 64%);
}

.home .approach {
  background:
    radial-gradient(circle at 95% 8%, rgba(31,120,166,.075), transparent 24%),
    linear-gradient(180deg,#F6FBF8 0%,#FFFFFF 100%) !important;
}

.home .approach-head,
.home .learn-overview {
  border-color: rgba(11,122,59,.16) !important;
  background:
    radial-gradient(circle at 92% 8%, rgba(31,120,166,.075), transparent 26%),
    linear-gradient(135deg,#FFFFFF 0%,#F7FCF9 100%) !important;
  box-shadow: 0 18px 42px rgba(7,21,35,.06) !important;
}

.home .approach-panel::before {
  background: linear-gradient(90deg, var(--green), var(--waso-accent)) !important;
}

.home .approach-icon,
.home .service-mini-icon,
.home .contact-action-icon {
  background:
    radial-gradient(circle at 30% 28%, rgba(31,120,166,.13), transparent 35%),
    #EAF6EF !important;
  color: var(--green) !important;
}

.home .learn {
  background:
    radial-gradient(circle at 6% 16%, rgba(11,122,59,.08), transparent 28%),
    radial-gradient(circle at 92% 86%, rgba(31,120,166,.07), transparent 24%),
    #FFFFFF !important;
}

.home .learn-overview .mini-accent {
  background: linear-gradient(90deg, var(--green), var(--waso-accent)) !important;
  width: 96px !important;
}

.home .products {
  position: relative;
  overflow: hidden;
  background:
    linear-gradient(180deg,#FFFFFF 0%,#F7FCF9 100%) !important;
}

.home .products::before {
  content: "";
  position: absolute;
  left: -110px;
  top: 60px;
  width: 260px;
  height: 260px;
  border-radius: 50%;
  background: rgba(11,122,59,.07);
}

.home .product-card {
  border-radius: 28px !important;
  border: 1px solid rgba(11,122,59,.12) !important;
  overflow: hidden;
  box-shadow: 0 18px 42px rgba(7,21,35,.07) !important;
}

.home .product-card:nth-child(3n+2) .product-img,
.home .product-card:nth-child(3n+2) .product-img.pattern {
  background: linear-gradient(135deg,#08243A 0%,#145A65 60%,#1F78A6 160%) !important;
}

.home .product-card:nth-child(3n+3) .product-img,
.home .product-card:nth-child(3n+3) .product-img.green {
  background:
    radial-gradient(circle at 20% 30%, rgba(255,255,255,.28), transparent 12%),
    radial-gradient(circle at 70% 35%, rgba(31,120,166,.18), transparent 14%),
    linear-gradient(135deg,#075C2D 0%,#0B7A3B 70%,#1F78A6 150%) !important;
}

.home .inside-credit {
  background:
    radial-gradient(circle at 80% 12%, rgba(31,120,166,.075), transparent 24%),
    linear-gradient(135deg,#F6FBF8 0%,#FFFFFF 54%,#F2FAFC 100%) !important;
}

.home .inside-credit-main {
  background:
    radial-gradient(circle at 88% 12%, rgba(31,120,166,.10), transparent 24%),
    #FFFFFF !important;
  border-color: rgba(11,122,59,.16) !important;
}

.home .inside-credit-tags span {
  background: linear-gradient(135deg,#F2FBF6,#EAF6FB) !important;
  border-color: rgba(31,120,166,.14) !important;
}

.home .contact-cta::before {
  background:
    radial-gradient(circle at 12% 20%, rgba(31,120,166,.075), transparent 25%),
    radial-gradient(circle at 88% 22%, rgba(11,122,59,.12), transparent 28%),
    linear-gradient(135deg,#FFFFFF 0%,#F7FCF9 55%,#F2FAFC 100%) !important;
}

.home .contact-copy {
  background:
    radial-gradient(circle at 84% 78%, rgba(31,120,166,.14), transparent 28%),
    linear-gradient(135deg,#075C2D 0%,#0B7A3B 58%,#0C8C4C 100%) !important;
}

.home .contact-copy::before {
  content: "";
  position: absolute;
  left: 38px;
  top: 38px;
  width: 84px;
  height: 5px;
  border-radius: 999px;
  background: linear-gradient(90deg,#FFFFFF,var(--waso-accent));
  opacity: .7;
}

@media (max-width: 760px) {
  .home .rating-news-head h2::after,
  .home .product-head h2::after,
  .home .insight-label strong::after {
    width: 64px;
  }
  .home .featured-insight {
    border-radius: 22px !important;
  }
}


/* ===== V61 contact CTA button and cool-accent cleanup ===== */
.home .contact-copy .btn {
  background: #FFFFFF !important;
  color: var(--green-dark) !important;
  border-color: rgba(255,255,255,.82) !important;
  box-shadow: 0 14px 30px rgba(7,21,35,.14) !important;
}
.home .contact-copy .btn:hover {
  background: #F2FBF6 !important;
  color: var(--green-dark) !important;
  border-color: #FFFFFF !important;
  transform: translateY(-2px);
}
.home .contact-copy::before {
  background: rgba(255,255,255,.88) !important;
}
.home .approach-panel::before,
.home .rating-news-card::before,
.home .service-mini-card::before,
.home .contact-action-card::before,
.home .learn-overview .mini-accent,
.home .rating-news-head h2::after,
.home .product-head h2::after,
.home .insight-label strong::after {
  background: linear-gradient(90deg, var(--green), var(--waso-accent)) !important;
}

/* V62 Rating Lists redesign: embedded searchable rating updates + PDF archive */
.rating-lists-modern-page {
  background: linear-gradient(180deg, #F7FCF9 0%, #FFFFFF 42%, #F8FCFA 100%);
  padding-top: 48px;
}
.rating-lists-modern-wrap {
  max-width: 1180px;
  display: grid;
  gap: 26px;
}
.rating-lists-modern-hero,
.rating-update-embed-shell,
.rating-lists-archive-modern {
  border: 1px solid #DDEFE5;
  background: rgba(255,255,255,.92);
  box-shadow: 0 18px 44px rgba(7,21,35,.07);
  border-radius: 30px;
}
.rating-lists-modern-hero {
  display: grid;
  grid-template-columns: 1fr 240px;
  gap: 28px;
  align-items: center;
  padding: 34px;
  overflow: hidden;
  position: relative;
}
.rating-lists-modern-hero::after {
  content: "";
  position: absolute;
  width: 320px;
  height: 320px;
  right: -120px;
  top: -150px;
  border-radius: 999px;
  background: radial-gradient(circle, rgba(19, 170, 119, .16), rgba(19, 170, 119, 0) 68%);
}
.rating-lists-hero-copy {
  position: relative;
  z-index: 1;
}
.rating-lists-hero-copy h2 {
  margin: 12px 0 14px;
  color: var(--navy);
  font-size: clamp(34px, 4.5vw, 54px);
  line-height: 1.03;
  letter-spacing: -.05em;
}
.rating-lists-hero-copy h2::after {
  content: "";
  display: block;
  width: 78px;
  height: 4px;
  margin-top: 14px;
  border-radius: 999px;
  background: linear-gradient(90deg, var(--green), #13AA77);
}
.rating-lists-hero-copy p {
  max-width: 820px;
  margin: 0;
  color: #475467;
  font-size: 17px;
  line-height: 1.75;
}
.rating-lists-hero-badge {
  position: relative;
  z-index: 1;
  justify-self: end;
  width: 220px;
  min-height: 160px;
  border-radius: 28px;
  color: #fff;
  padding: 24px;
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
  background:
    radial-gradient(circle at 80% 20%, rgba(255,255,255,.24), transparent 30%),
    linear-gradient(135deg, #075C2D 0%, #0B7A3B 54%, #0E7A74 100%);
  box-shadow: 0 18px 34px rgba(11,122,59,.18);
}
.rating-lists-hero-badge span {
  font-size: 12px;
  font-weight: 900;
  letter-spacing: .16em;
  text-transform: uppercase;
  color: #DFF8E9;
}
.rating-lists-hero-badge strong {
  display: block;
  margin-top: 8px;
  font-size: 26px;
  line-height: 1.05;
  letter-spacing: -.035em;
}
.rating-update-embed-shell {
  padding: 26px;
}
.rating-update-embed-head {
  display: grid;
  grid-template-columns: .9fr 1.1fr;
  gap: 22px;
  align-items: end;
  margin-bottom: 22px;
}
.rating-update-embed-head h2 {
  margin: 10px 0 0;
  color: var(--navy);
  font-size: clamp(26px, 3vw, 38px);
  line-height: 1.08;
  letter-spacing: -.04em;
}
.rating-update-searchbar {
  display: grid;
  grid-template-columns: 1fr auto;
  gap: 12px;
  padding: 10px;
  border: 1px solid #D7E8DE;
  border-radius: 999px;
  background: #F8FCFA;
  box-shadow: inset 0 1px 0 rgba(255,255,255,.9);
}
.rating-update-searchbar input {
  width: 100%;
  border: 0;
  outline: 0;
  background: transparent;
  padding: 10px 14px;
  color: var(--navy);
  font-size: 15px;
  font-family: inherit;
}
.rating-update-searchbar input:focus {
  outline: none !important;
  border-color: transparent !important;
  box-shadow: none !important;
}
.rating-update-embed-area {
  min-height: 230px;
  border: 1px solid #E3EFE8;
  border-radius: 24px;
  background: #fff;
  overflow: auto;
  box-shadow: 0 12px 28px rgba(7,21,35,.04);
}
.rating-update-embed-area > * {
  max-width: 100%;
}
.rating-update-embed-area table {
  width: 100% !important;
  border-collapse: collapse;
  font-size: 14px;
}
.rating-update-embed-area th,
.rating-update-embed-area td {
  padding: 14px 16px;
  border-bottom: 1px solid #E7ECEF;
  text-align: left;
  vertical-align: top;
}
.rating-update-embed-area th {
  background: #F3FBF6;
  color: #344054;
  text-transform: uppercase;
  letter-spacing: .06em;
  font-size: 12px;
  font-weight: 900;
}
.rating-update-embed-area tbody tr:hover td {
  background: #F8FCFA;
}
.rating-update-embed-area .dataTables_wrapper,
.rating-update-embed-area .wpDataTablesWrapper,
.rating-update-embed-area .tablepress {
  padding: 0;
  margin: 0;
}
.rating-embed-empty-state {
  min-height: 230px;
  display: grid;
  place-items: center;
  align-content: center;
  gap: 10px;
  padding: 34px;
  text-align: center;
  color: #667085;
}
.rating-embed-empty-icon {
  width: 62px;
  height: 62px;
  display: grid;
  place-items: center;
  border-radius: 22px;
  background: #EAF6EF;
  color: var(--green);
  font-weight: 900;
  font-size: 24px;
}
.rating-embed-empty-state h3 {
  margin: 0;
  color: var(--navy);
  font-size: 24px;
  letter-spacing: -.025em;
}
.rating-embed-empty-state p {
  margin: 0;
  max-width: 520px;
  line-height: 1.7;
}
.rating-embed-status {
  margin-top: 12px;
  color: #667085;
  font-size: 14px;
}
.rating-lists-archive-modern {
  padding: 28px;
}
.rating-lists-archive-modern .rating-report-section-head {
  margin-bottom: 20px;
}
.rating-lists-archive-modern .rating-archive-grid {
  grid-template-columns: repeat(3, minmax(0, 1fr));
}
.rating-lists-archive-modern .rating-report-card {
  border-radius: 22px;
  min-height: 178px;
}
.rating-lists-archive-modern .rating-report-card-main {
  align-items: flex-start;
}
.rating-lists-archive-modern .rating-report-actions {
  margin-top: 14px;
}
@media (max-width: 980px) {
  .rating-lists-modern-hero,
  .rating-update-embed-head {
    grid-template-columns: 1fr;
  }
  .rating-lists-hero-badge {
    justify-self: start;
    width: min(100%, 320px);
    min-height: 120px;
  }
  .rating-lists-archive-modern .rating-archive-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}
@media (max-width: 640px) {
  .rating-lists-modern-page {
    padding-top: 28px;
  }
  .rating-lists-modern-hero,
  .rating-update-embed-shell,
  .rating-lists-archive-modern {
    border-radius: 22px;
    padding: 20px;
  }
  .rating-update-searchbar {
    grid-template-columns: 1fr;
    border-radius: 20px;
  }
  .rating-update-searchbar .btn {
    width: 100%;
  }
  .rating-update-embed-area {
    border-radius: 18px;
  }
  .rating-update-embed-area th,
  .rating-update-embed-area td {
    padding: 12px;
    white-space: nowrap;
  }
  .rating-lists-archive-modern .rating-archive-grid {
    grid-template-columns: 1fr;
  }
}


/* V63 Rating Reports page: TablePress-ready public searchable table */
.rating-reports-tablepress-page {
  padding: 48px 0 78px;
  background: linear-gradient(180deg, #F7FCF9 0%, #FFFFFF 46%, #F8FCFA 100%);
}
.rating-reports-tablepress-wrap {
  max-width: 1180px;
  display: grid;
  gap: 26px;
}
.rating-reports-tablepress-intro,
.rating-reports-tablepress-shell {
  border: 1px solid #DDEFE5;
  border-radius: 30px;
  background: rgba(255,255,255,.94);
  box-shadow: 0 18px 44px rgba(7,21,35,.07);
}
.rating-reports-tablepress-intro {
  display: grid;
  grid-template-columns: 1fr 220px;
  gap: 26px;
  align-items: center;
  padding: 34px;
  overflow: hidden;
  position: relative;
}
.rating-reports-tablepress-intro::after {
  content: "";
  position: absolute;
  width: 320px;
  height: 320px;
  right: -128px;
  top: -150px;
  border-radius: 999px;
  background: radial-gradient(circle, rgba(19, 170, 119, .14), rgba(19, 170, 119, 0) 68%);
}
.rating-reports-tablepress-intro > * {
  position: relative;
  z-index: 1;
}
.rating-reports-tablepress-intro h2 {
  margin: 12px 0 14px;
  color: var(--navy);
  font-size: clamp(34px, 4vw, 50px);
  line-height: 1.05;
  letter-spacing: -.05em;
}
.rating-reports-tablepress-intro h2::after {
  content: "";
  display: block;
  width: 76px;
  height: 4px;
  margin-top: 14px;
  border-radius: 999px;
  background: linear-gradient(90deg, var(--green), #12A078);
}
.rating-reports-tablepress-intro p {
  max-width: 850px;
  margin: 0;
  color: #475467;
  font-size: 17px;
  line-height: 1.75;
}
.rating-reports-tablepress-mark {
  justify-self: end;
  width: 200px;
  min-height: 148px;
  border-radius: 26px;
  padding: 22px;
  color: #fff;
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
  background: linear-gradient(135deg, #075C2D 0%, #0B7A3B 54%, #0E7A74 100%);
  box-shadow: 0 18px 34px rgba(11,122,59,.16);
}
.rating-reports-tablepress-mark span {
  font-size: 12px;
  font-weight: 900;
  letter-spacing: .16em;
  text-transform: uppercase;
  color: #DFF8E9;
}
.rating-reports-tablepress-mark strong {
  display: block;
  margin-top: 8px;
  font-size: 25px;
  line-height: 1.05;
  letter-spacing: -.035em;
}
.rating-reports-tablepress-shell {
  padding: 28px;
}
.rating-reports-tablepress-head {
  display: flex;
  justify-content: space-between;
  align-items: end;
  gap: 24px;
  margin-bottom: 22px;
}
.rating-reports-tablepress-head small {
  color: var(--green);
  font-weight: 900;
  font-size: 12px;
  letter-spacing: .12em;
  text-transform: uppercase;
}
.rating-reports-tablepress-head h2 {
  margin: 8px 0 0;
  color: var(--navy);
  font-size: clamp(26px, 3vw, 36px);
  line-height: 1.08;
  letter-spacing: -.04em;
}
.rating-reports-tablepress-head p {
  margin: 0;
  max-width: 420px;
  color: #667085;
  font-size: 14px;
  line-height: 1.6;
}
.rating-reports-tablepress-area {
  overflow: auto;
  border: 1px solid #E3EFE8;
  border-radius: 22px;
  background: #fff;
  min-height: 260px;
  box-shadow: 0 12px 28px rgba(7,21,35,.04);
  padding: 0;
}
.rating-reports-tablepress-area .tablepress,
.rating-reports-tablepress-area table {
  width: 100% !important;
  margin: 0 !important;
  border-collapse: collapse;
}
.rating-reports-tablepress-area th,
.rating-reports-tablepress-area td {
  padding: 14px 16px;
  border-bottom: 1px solid #E7ECEF;
  text-align: left;
  vertical-align: top;
}
.rating-reports-tablepress-area thead th,
.rating-reports-tablepress-area .tablepress thead th {
  background: #DDF0F7 !important;
  color: #0B1B2A !important;
  font-weight: 900;
  font-size: 14px;
}
.rating-reports-tablepress-area tbody tr:nth-child(even) td {
  background: #F7F9FA;
}
.rating-reports-tablepress-area tbody tr:hover td {
  background: #F1FBF6;
}
.rating-reports-tablepress-area .dataTables_wrapper {
  padding: 22px;
}
.rating-reports-tablepress-area .dataTables_length,
.rating-reports-tablepress-area .dataTables_filter {
  margin: 0 0 16px;
  color: #263548;
  font-weight: 700;
}
.rating-reports-tablepress-area .dataTables_filter input,
.rating-reports-tablepress-area .dataTables_length select {
  border: 1px solid #D0D7DE;
  border-radius: 10px;
  padding: 9px 10px;
  font: inherit;
  background: #fff;
}
.rating-reports-empty-state {
  min-height: 260px;
  display: grid;
  place-items: center;
  align-content: center;
  gap: 10px;
  padding: 34px;
  text-align: center;
  color: #667085;
}
.rating-reports-empty-icon {
  width: 62px;
  height: 62px;
  border-radius: 22px;
  display: grid;
  place-items: center;
  background: #EAF6EF;
  color: var(--green);
  font-weight: 900;
  font-size: 24px;
}
.rating-reports-empty-state h3 {
  margin: 0;
  color: var(--navy);
  font-size: 24px;
  letter-spacing: -.025em;
}
.rating-reports-empty-state p {
  margin: 0;
  max-width: 540px;
  line-height: 1.7;
}
@media (max-width: 980px) {
  .rating-reports-tablepress-intro {
    grid-template-columns: 1fr;
  }
  .rating-reports-tablepress-mark {
    justify-self: start;
    width: min(100%, 320px);
    min-height: 120px;
  }
  .rating-reports-tablepress-head {
    display: block;
  }
  .rating-reports-tablepress-head p {
    margin-top: 10px;
  }
}
@media (max-width: 640px) {
  .rating-reports-tablepress-page {
    padding: 28px 0 54px;
  }
  .rating-reports-tablepress-intro,
  .rating-reports-tablepress-shell {
    border-radius: 22px;
    padding: 20px;
  }
  .rating-reports-tablepress-area {
    border-radius: 18px;
  }
  .rating-reports-tablepress-area .dataTables_wrapper {
    padding: 14px;
  }
  .rating-reports-tablepress-area th,
  .rating-reports-tablepress-area td {
    padding: 12px;
    white-space: nowrap;
  }
}

/* V66 Rating Reports hub + searchable report cards */
.rating-lists-hub-page,
.rating-reports-card-page {
  padding: 48px 0 78px;
  background: linear-gradient(180deg, #F7FCF9 0%, #FFFFFF 48%, #F8FCFA 100%);
}

.rating-lists-hub-wrap,
.rating-reports-card-wrap {
  max-width: 1180px;
  display: grid;
  gap: 24px;
}

.rating-lists-hub-header,
.rating-reports-card-header {
  border: 1px solid #DDEFE5;
  border-radius: 30px;
  background:
    radial-gradient(circle at 88% 10%, rgba(19,170,119,.14), transparent 30%),
    rgba(255,255,255,.96);
  box-shadow: 0 18px 44px rgba(7,21,35,.07);
  padding: 32px;
}

.rating-lists-hub-header h2,
.rating-reports-card-header h2 {
  margin: 10px 0 0;
  color: var(--navy);
  font-size: clamp(34px, 4vw, 52px);
  line-height: 1.04;
  letter-spacing: -.055em;
}

.rating-lists-feature-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 20px;
}

.rating-lists-feature-card {
  min-height: 250px;
  border: 1px solid #DDEFE5;
  border-radius: 28px;
  padding: 28px;
  background: #fff;
  color: inherit;
  text-decoration: none;
  box-shadow: 0 14px 32px rgba(7,21,35,.06);
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  transition: transform .18s ease, box-shadow .18s ease, border-color .18s ease;
  position: relative;
  overflow: hidden;
}

.rating-lists-feature-card::after {
  content: "";
  position: absolute;
  width: 210px;
  height: 210px;
  right: -82px;
  top: -92px;
  border-radius: 999px;
  background: radial-gradient(circle, rgba(11,122,59,.12), rgba(11,122,59,0) 68%);
}

.rating-lists-feature-card:hover {
  transform: translateY(-4px);
  border-color: rgba(11,122,59,.46);
  box-shadow: 0 22px 46px rgba(11,122,59,.12);
}

.rating-lists-feature-card > * {
  position: relative;
  z-index: 1;
}

.rating-lists-feature-card span,
.rating-report-result-status {
  color: var(--green);
  font-weight: 900;
  letter-spacing: .13em;
  text-transform: uppercase;
  font-size: 11px;
}

.rating-lists-feature-card h3 {
  margin: 12px 0 12px;
  color: var(--navy);
  font-size: clamp(26px, 3vw, 38px);
  line-height: 1.08;
  letter-spacing: -.04em;
}

.rating-lists-feature-card p {
  margin: 0;
  max-width: 560px;
  color: #556270;
  font-size: 16px;
  line-height: 1.68;
}

.rating-lists-feature-card strong {
  margin-top: auto;
  display: inline-flex;
  align-items: center;
  gap: 8px;
  color: var(--green);
  font-weight: 900;
}

.rating-lists-feature-card strong em {
  font-style: normal;
  transition: transform .18s ease;
}

.rating-lists-feature-card:hover strong em {
  transform: translateX(4px);
}

.rating-lists-feature-card.is-featured {
  grid-column: span 2;
  min-height: 300px;
  color: #fff;
  background:
    radial-gradient(circle at 88% 16%, rgba(255,255,255,.22), transparent 24%),
    linear-gradient(135deg, #075C2D 0%, #0B7A3B 54%, #0E7A74 100%);
  border-color: rgba(255,255,255,.12);
}

.rating-lists-feature-card.is-featured::after {
  background: radial-gradient(circle, rgba(255,255,255,.20), rgba(255,255,255,0) 68%);
}

.rating-lists-feature-card.is-featured span,
.rating-lists-feature-card.is-featured h3,
.rating-lists-feature-card.is-featured p,
.rating-lists-feature-card.is-featured strong {
  color: #fff;
}

.rating-lists-feature-card.is-featured p {
  color: rgba(255,255,255,.82);
  font-size: 17px;
}

.rating-reports-card-header {
  display: flex;
  align-items: end;
  justify-content: space-between;
  gap: 22px;
}

.rating-report-card-filter {
  display: grid;
  grid-template-columns: minmax(260px, 1.35fr) repeat(3, minmax(150px, .65fr)) auto;
  gap: 12px;
  align-items: center;
  padding: 18px;
  border: 1px solid #DDEFE5;
  border-radius: 24px;
  background: rgba(255,255,255,.96);
  box-shadow: 0 12px 28px rgba(7,21,35,.05);
}

.rating-report-card-filter input,
.rating-report-card-filter select {
  width: 100%;
  min-height: 48px;
  border: 1px solid #D0D7DE;
  border-radius: 999px;
  padding: 0 16px;
  background: #fff;
  color: #263548;
  font: inherit;
  outline: none;
}

.rating-report-card-filter input:focus,
.rating-report-card-filter select:focus {
  border-color: rgba(11,122,59,.58);
  box-shadow: 0 0 0 4px rgba(11,122,59,.08);
}

.rating-report-result-status {
  min-height: 18px;
  padding-left: 4px;
}

.rating-report-search-grid {
  display: grid !important;
  grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
  gap: 20px !important;
}

.rating-report-search-grid .rating-report-card {
  min-height: 260px !important;
  display: flex;
  flex-direction: column;
}

.rating-report-search-grid .rating-report-card-main {
  min-height: 220px !important;
  display: flex !important;
  flex-direction: column;
  align-items: flex-start !important;
}

.rating-report-search-grid .rating-report-actions {
  justify-content: flex-start;
  min-width: 0;
  margin-top: auto;
}

.rating-report-search-grid .rating-report-card h3 {
  font-size: 21px;
}

.rating-report-search-grid .rating-report-preview {
  width: 100%;
}

.rating-report-search-grid .rating-report-preview iframe {
  min-height: 520px;
}

@media (max-width: 1100px) {
  .rating-report-card-filter {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
  .rating-report-search-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  }
}

@media (max-width: 760px) {
  .rating-lists-hub-page,
  .rating-reports-card-page {
    padding: 28px 0 54px;
  }
  .rating-lists-hub-header,
  .rating-reports-card-header,
  .rating-lists-feature-card,
  .rating-report-card-filter {
    border-radius: 22px;
    padding: 20px;
  }
  .rating-lists-feature-grid,
  .rating-report-search-grid,
  .rating-report-card-filter {
    grid-template-columns: 1fr !important;
  }
  .rating-lists-feature-card.is-featured {
    grid-column: span 1;
    min-height: 260px;
  }
  .rating-reports-card-header {
    display: grid;
    align-items: start;
  }
}

/* V65 Rating Reports category-card flow */
.rating-report-category-filter {
  display: grid;
  grid-template-columns: minmax(260px, 1.4fr) repeat(2, minmax(150px, .65fr)) auto;
  gap: 12px;
  align-items: center;
  padding: 18px;
  border: 1px solid #DDEFE5;
  border-radius: 24px;
  background: rgba(255,255,255,.96);
  box-shadow: 0 12px 28px rgba(7,21,35,.05);
}

.rating-report-category-filter input,
.rating-report-category-filter select {
  width: 100%;
  min-height: 48px;
  border: 1px solid #D0D7DE;
  border-radius: 999px;
  padding: 0 16px;
  background: #fff;
  color: #263548;
  font: inherit;
  outline: none;
}

.rating-report-category-filter input:focus,
.rating-report-category-filter select:focus {
  border-color: rgba(11,122,59,.58);
  box-shadow: 0 0 0 4px rgba(11,122,59,.08);
}

.rating-report-category-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 20px;
}

.rating-report-category-card {
  min-height: 270px;
  border: 1px solid #DDEFE5;
  border-radius: 28px;
  padding: 28px;
  background: #fff;
  color: inherit;
  text-decoration: none;
  box-shadow: 0 14px 32px rgba(7,21,35,.06);
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  transition: transform .18s ease, box-shadow .18s ease, border-color .18s ease;
  position: relative;
  overflow: hidden;
}

.rating-report-category-card::after {
  content: "";
  position: absolute;
  width: 220px;
  height: 220px;
  right: -88px;
  top: -94px;
  border-radius: 999px;
  background: radial-gradient(circle, rgba(11,122,59,.12), rgba(11,122,59,0) 68%);
}

.rating-report-category-card:hover {
  transform: translateY(-4px);
  border-color: rgba(11,122,59,.46);
  box-shadow: 0 22px 46px rgba(11,122,59,.12);
}

.rating-report-category-card > * {
  position: relative;
  z-index: 1;
}

.rating-report-category-card span {
  color: var(--green);
  font-weight: 900;
  letter-spacing: .13em;
  text-transform: uppercase;
  font-size: 11px;
}

.rating-report-category-card h3 {
  margin: 12px 0 12px;
  color: var(--navy);
  font-size: clamp(26px, 3vw, 36px);
  line-height: 1.08;
  letter-spacing: -.04em;
}

.rating-report-category-card p {
  margin: 0 0 20px;
  max-width: 560px;
  color: #556270;
  font-size: 16px;
  line-height: 1.65;
}

.rating-report-category-meta {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-top: auto;
}

.rating-report-category-meta strong,
.rating-report-category-meta em {
  display: inline-flex;
  align-items: center;
  min-height: 30px;
  border-radius: 999px;
  padding: 5px 11px;
  border: 1px solid #DDEFE5;
  background: #F1FBF6;
  color: var(--green-dark);
  font-style: normal;
  font-size: 12px;
  font-weight: 900;
}

.rating-report-category-card b {
  margin-top: 18px;
  display: inline-flex;
  align-items: center;
  gap: 8px;
  color: var(--green);
  font-weight: 900;
}

.rating-report-category-card b i {
  font-style: normal;
  transition: transform .18s ease;
}

.rating-report-category-card:hover b i {
  transform: translateX(4px);
}

.rating-reports-detail-area {
  display: grid;
  gap: 18px;
}

.rating-reports-detail-area .rating-report-card-filter {
  grid-template-columns: minmax(260px, 1.35fr) repeat(2, minmax(150px, .65fr)) auto;
}

.rating-reports-detail-area .rating-report-card-filter select[hidden] {
  display: none;
}

@media (max-width: 1100px) {
  .rating-report-category-filter,
  .rating-reports-detail-area .rating-report-card-filter {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
  .rating-report-category-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 760px) {
  .rating-report-category-filter,
  .rating-report-category-grid,
  .rating-reports-detail-area .rating-report-card-filter {
    grid-template-columns: 1fr !important;
  }
  .rating-report-category-filter,
  .rating-report-category-card {
    border-radius: 22px;
    padding: 20px;
  }
}

/* V67 Rating Reports page hierarchy + TablePress leaf pages */
.rating-report-page-view .rating-reports-card-wrap,
.single-rating-report-page .rating-reports-card-wrap {
  max-width: 1200px;
}
.rating-report-leaf-header {
  align-items: center;
}
.rating-report-leaf-header .rating-report-meta {
  margin-top: 16px;
}
.rating-report-content-card {
  padding: 24px;
}
.rating-report-tablepress-area {
  min-height: 360px;
  overflow-x: auto;
}
.rating-report-tablepress-area > *:first-child {
  margin-top: 0;
}
.rating-report-tablepress-area > *:last-child {
  margin-bottom: 0;
}
.rating-report-tablepress-area .tablepress,
.rating-report-tablepress-area table {
  width: 100% !important;
}
.rating-report-tablepress-area .dataTables_wrapper {
  min-width: 760px;
}
.rating-report-tablepress-area .dataTables_length,
.rating-report-tablepress-area .dataTables_filter {
  display: block;
}
.rating-report-helper-content {
  border: 1px solid #DDEFE5;
  border-radius: 24px;
  padding: 22px 24px;
  background: rgba(255,255,255,.94);
  color: #475467;
  line-height: 1.7;
}
.rating-report-optional-files {
  border: 1px dashed #CFE6D8;
  border-radius: 22px;
  padding: 18px 20px;
  background: #F8FCFA;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 14px;
}
.rating-report-optional-files .single-actions {
  margin: 0;
}
.rating-report-page-card-grid .rating-report-category-card {
  min-height: 250px;
}
.rating-report-page-card .rating-report-category-meta:empty {
  display: none;
}
@media (max-width: 760px) {
  .rating-report-content-card {
    padding: 14px;
    border-radius: 18px;
  }
  .rating-report-optional-files {
    display: grid;
  }
  .rating-report-optional-files .single-actions {
    justify-content: flex-start;
  }
}

/* ===== V70 About page content and spacing polish ===== */
.about-overview-page {
  padding: 0 !important;
  margin: 0 !important;
}
.about-overview-page .about-hero-band {
  margin-top: 0 !important;
}
.about-hero-grid {
  padding-top: 74px;
}
.about-hero-copy p {
  max-width: 760px;
  font-size: 17px;
  line-height: 1.74;
}
.about-stat-card strong {
  white-space: nowrap;
}
.about-story-visual {
  display: flex;
  align-items: stretch;
  min-height: 390px;
}
.about-profile-card {
  position: relative;
  width: 100%;
  min-height: 100%;
  overflow: hidden;
  border-radius: 30px;
  padding: 36px;
  color: #fff;
  background:
    radial-gradient(circle at 18% 18%, rgba(96, 222, 143, .28), transparent 30%),
    radial-gradient(circle at 92% 88%, rgba(95, 189, 151, .22), transparent 34%),
    linear-gradient(135deg, #09263C 0%, #0B5D45 100%);
  border: 1px solid rgba(255,255,255,.16);
  box-shadow: var(--shadow);
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
}
.about-profile-card::before {
  content: "";
  position: absolute;
  inset: 28px;
  border-radius: 24px;
  border: 1px solid rgba(255,255,255,.14);
  pointer-events: none;
}
.about-profile-card::after {
  content: "";
  position: absolute;
  width: 220px;
  height: 220px;
  right: -58px;
  bottom: -70px;
  border-radius: 999px;
  background: rgba(255,255,255,.08);
  pointer-events: none;
}
.about-profile-badge {
  position: relative;
  z-index: 1;
  align-self: flex-start;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 44px;
  padding: 0 18px;
  border-radius: 999px;
  background: #EAF6EF;
  color: var(--green);
  font-size: 12px;
  font-weight: 900;
  letter-spacing: .12em;
  margin-bottom: auto;
}
.about-profile-card h3,
.about-profile-card p,
.about-profile-points {
  position: relative;
  z-index: 1;
}
.about-profile-card h3 {
  margin: 78px 0 14px;
  max-width: 520px;
  color: #fff;
  font-size: clamp(30px, 3.4vw, 44px);
  line-height: 1.05;
  letter-spacing: -.045em;
}
.about-profile-card p {
  margin: 0 0 24px;
  max-width: 560px;
  color: #DDEBE6;
  font-size: 17px;
  line-height: 1.65;
}
.about-profile-points {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 12px;
}
.about-profile-points span {
  min-height: 78px;
  border-radius: 18px;
  padding: 16px;
  display: flex;
  align-items: flex-end;
  background: rgba(255,255,255,.10);
  border: 1px solid rgba(255,255,255,.14);
  color: #F2FFF7;
  font-weight: 850;
  line-height: 1.25;
}
.about-timeline-item {
  opacity: 0;
  transform: translateY(18px);
  animation: wasoMilestoneRise .65s ease forwards;
  transition: transform .22s ease, filter .22s ease;
}
.about-timeline-item:nth-child(1) { animation-delay: .05s; }
.about-timeline-item:nth-child(2) { animation-delay: .18s; }
.about-timeline-item:nth-child(3) { animation-delay: .31s; }
.about-timeline-item:nth-child(4) { animation-delay: .44s; }
.about-timeline-item:hover {
  transform: translateY(-6px);
}
.about-timeline-dot {
  transition: transform .22s ease, box-shadow .22s ease;
}
.about-timeline-item:hover .about-timeline-dot {
  transform: scale(1.08);
  box-shadow: 0 0 0 1px #B7DEC5, 0 12px 28px rgba(11,122,59,.18);
}
@keyframes wasoMilestoneRise {
  to {
    opacity: 1;
    transform: translateY(0);
  }
}
@media (max-width: 1100px) {
  .about-profile-points {
    grid-template-columns: 1fr;
  }
  .about-profile-points span {
    min-height: auto;
  }
}
@media (max-width: 760px) {
  .about-hero-grid {
    padding-top: 54px;
  }
  .about-profile-card {
    padding: 28px;
  }
  .about-profile-card h3 {
    margin-top: 64px;
  }
}
@media (prefers-reduced-motion: reduce) {
  .about-timeline-item {
    opacity: 1;
    transform: none;
    animation: none;
  }
  .about-timeline-item,
  .about-timeline-dot {
    transition: none;
  }
}


/* V71: Team member cards show no biography/description text. */
.people-page-v21 .people-bio,
.people-page-v22 .people-bio,
.rating-committee-grid .people-bio {
  display: none !important;
}

.people-page-v21 .people-card,
.people-page-v21 .people-card-featured {
  min-height: 390px !important;
}

.people-page-v22 .people-card,
.people-page-v22 .people-card-featured {
  min-height: 404px !important;
}

.people-page-v21 .people-card-actions,
.people-page-v22 .people-card-actions,
.rating-committee-grid .people-card-actions {
  margin-top: auto !important;
  padding-top: 18px !important;
}

.people-page-v21 .people-designation,
.people-page-v22 .people-designation {
  margin-bottom: 0 !important;
}


/* V72: Bring desktop dropdowns directly under their parent menu item and keep them reachable. */
@media (min-width: 981px) {
  .site-header.moody-green-style .header-bottom-inner,
  .site-header.moody-green-style .main-menu {
    overflow: visible !important;
  }

  .site-header.moody-green-style .main-menu .menu-item {
    position: relative !important;
  }

  .site-header.moody-green-style .mega {
    top: 100% !important;
    left: 0 !important;
    right: auto !important;
    margin-top: 0 !important;
    translate: 0 0 !important;
    transform: translateY(4px) !important;
    z-index: 300 !important;
  }

  .site-header.moody-green-style .menu-item:hover > .mega,
  .site-header.moody-green-style .menu-item:focus-within > .mega,
  .site-header.moody-green-style .menu-item.open > .mega {
    transform: translateY(0) !important;
  }

  .site-header.moody-green-style .mega::before {
    content: "";
    position: absolute;
    left: 0;
    right: 0;
    top: -14px;
    height: 14px;
    display: block;
  }

  .site-header.moody-green-style .main-menu .menu-item:first-child > .mega,
  .site-header.moody-green-style .main-menu .menu-item:nth-child(2) > .mega,
  .site-header.moody-green-style .main-menu .menu-item:nth-child(3) > .mega,
  .site-header.moody-green-style .main-menu .menu-item:nth-child(5) > .mega {
    left: 0 !important;
    right: auto !important;
  }

  .site-header.moody-green-style .main-menu .menu-item:last-child > .mega {
    left: auto !important;
    right: 0 !important;
  }
}

/* V74: Show the complete Products & Services list inside the desktop submenu. */
@media (min-width: 981px) {
  .site-header.moody-green-style .mega.services-mega {
    width: min(980px, calc(100vw - 80px)) !important;
  }

  .site-header.moody-green-style .mega.services-mega .mega-grid.three {
    grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
    column-gap: 28px !important;
    row-gap: 2px !important;
  }

  .site-header.moody-green-style .mega.services-mega a {
    align-items: center !important;
    min-height: 44px !important;
    line-height: 1.25 !important;
    white-space: normal !important;
  }
}


/* V78: Rating Process flowchart refinement */
.flow-column-waso .flow-stack {
  gap: 7px;
}

.flow-column-client .flow-node,
.flow-column-independence .flow-node {
  min-height: 58px;
  display: grid;
  place-items: center;
}

.flow-column-waso .flow-node {
  min-height: 64px;
  display: grid;
  place-items: center;
}

.flow-column-independence .flow-col-head {
  min-height: 60px;
}

.decision-zone {
  padding-top: 10px;
  border-top: 1px dashed #C7D7E5;
}

@media(max-width:1180px) {
  .flow-columns {
    grid-template-columns: 1fr;
  }

  .flow-column {
    max-width: 760px;
    width: 100%;
    margin: 0 auto;
  }
}

@media(max-width:640px) {
  .process-flow-intro,
  .process-flowchart {
    padding: 22px 16px;
  }

  .flowchart-title {
    font-size: 17px;
    padding: 10px 18px;
  }

  .flow-node,
  .path-card p {
    font-size: 13.5px;
  }

  .decision-diamond {
    width: 120px;
    height: 120px;
  }

  .decision-diamond span {
    width: 74px;
    font-size: 14px;
  }
}


/* V79: Remove Quick Links sidebar and make inner pages full-width */
.content-grid,
.no-sidebar-grid {
  grid-template-columns: 1fr !important;
}

.side-card {
  display: none !important;
}

.content-grid > * {
  min-width: 0;
}

.rating-process-page {
  width: 100%;
  max-width: 1180px;
  margin: 0 auto;
  display: grid;
  gap: 24px;
}

.rating-process-lead {
  background: #FFFFFF;
  border: 1px solid #DDEFE5;
  border-radius: 22px;
  padding: 24px 28px;
  box-shadow: 0 12px 28px rgba(7,21,35,.06);
}

.rating-process-lead h2 {
  margin: 0 0 8px;
  color: var(--green);
  font-size: clamp(30px, 4vw, 44px);
  line-height: 1.05;
  letter-spacing: -.035em;
}

.rating-process-lead p {
  margin: 0;
  max-width: 820px;
  color: #475467;
  font-size: 16px;
  line-height: 1.55;
}

.rating-process-diagram {
  background: #FFFFFF;
  border: 1px solid #D7E2EA;
  border-radius: 22px;
  padding: 28px;
  box-shadow: 0 16px 38px rgba(7,21,35,.07);
  overflow-x: auto;
}

.rp-main-title {
  width: max-content;
  max-width: 100%;
  margin: 0 auto 22px;
  padding: 13px 34px;
  border-radius: 999px;
  background: var(--green);
  color: #FFFFFF;
  font-size: 20px;
  font-weight: 900;
  text-align: center;
  box-shadow: 0 10px 22px rgba(11,122,59,.18);
}

.rp-flow-grid {
  display: grid;
  grid-template-columns: minmax(220px,.9fr) minmax(360px,1.35fr) minmax(220px,.9fr);
  gap: 28px;
  align-items: start;
  min-width: 880px;
}

.rp-column-title {
  min-height: 42px;
  display: grid;
  place-items: center;
  border: 1.5px solid #89A8BF;
  background: #F8FAFC;
  color: #101828;
  font-size: 14px;
  font-weight: 900;
  text-align: center;
  padding: 8px 12px;
  margin-bottom: 12px;
}

.rp-stack {
  display: grid;
  justify-items: stretch;
}

.rp-box {
  min-height: 44px;
  display: grid;
  place-items: center;
  border: 1.5px solid #89A8BF;
  background: #FFFFFF;
  color: #101828;
  font-size: 13px;
  font-weight: 650;
  line-height: 1.25;
  text-align: center;
  padding: 9px 12px;
  box-shadow: 0 4px 12px rgba(16,24,40,.035);
}

.rp-waso .rp-box {
  min-height: 48px;
}

.rp-down-arrow,
.rp-long-arrow {
  width: 1.5px;
  background: #2F6F9D;
  height: 18px;
  margin: 0 auto;
  position: relative;
}

.rp-down-arrow::after,
.rp-long-arrow::after {
  content: "";
  position: absolute;
  left: 50%;
  bottom: -1px;
  transform: translateX(-50%);
  width: 0;
  height: 0;
  border-left: 4.5px solid transparent;
  border-right: 4.5px solid transparent;
  border-top: 7px solid #2F6F9D;
}

.rp-long-arrow {
  height: 96px;
}

.rp-independence .rp-box {
  min-height: 46px;
}

.rp-decision-row {
  margin-top: 26px;
  display: grid;
  grid-template-columns: 150px 1fr 1fr;
  gap: 18px;
  align-items: center;
  border-top: 1px dashed #BED0DE;
  padding-top: 24px;
  min-width: 880px;
}

.rp-decision-diamond {
  width: 104px;
  height: 104px;
  margin: 0 auto;
  border: 1.5px solid #89A8BF;
  background: #FFFFFF;
  transform: rotate(45deg);
  display: grid;
  place-items: center;
}

.rp-decision-diamond span {
  transform: rotate(-45deg);
  color: #101828;
  font-size: 13px;
  font-weight: 900;
  line-height: 1.15;
  text-align: center;
}

.rp-decision-path {
  border: 1.5px solid #89A8BF;
  background: #FFFFFF;
  padding: 14px 16px;
  min-height: 92px;
  display: grid;
  align-content: center;
}

.rp-decision-path span {
  display: inline-block;
  width: max-content;
  margin-bottom: 6px;
  padding: 3px 9px;
  border-radius: 999px;
  background: #EAF5EF;
  color: var(--green);
  font-size: 12px;
  font-weight: 900;
}

.rp-decision-path p {
  margin: 0;
  color: #344054;
  font-size: 13.5px;
  line-height: 1.35;
}

@media(max-width:980px) {
  .rating-process-diagram {
    padding: 20px;
  }

  .rp-flow-grid,
  .rp-decision-row {
    min-width: 760px;
  }
}

@media(max-width:760px) {
  .rating-process-diagram {
    overflow-x: visible;
  }

  .rp-flow-grid,
  .rp-decision-row {
    min-width: 0;
    grid-template-columns: 1fr;
  }

  .rp-column {
    max-width: 100%;
  }

  .rp-long-arrow {
    height: 32px;
  }

  .rp-decision-row {
    align-items: start;
  }
}

@media(max-width:520px) {
  .rating-process-lead,
  .rating-process-diagram {
    padding: 18px 14px;
    border-radius: 18px;
  }

  .rp-main-title {
    width: 100%;
    font-size: 17px;
    padding: 11px 18px;
  }

  .rp-box {
    font-size: 12.8px;
  }
}


/* V80: Acceptance rating decision corrected */
.rp-acceptance-stage {
  display: grid;
  grid-template-columns: 126px 1fr;
  gap: 16px;
  align-items: start;
}

.rp-decision-graphic {
  position: relative;
  padding-top: 54px;
  min-height: 360px;
}

.rp-decision-graphic .rp-decision-diamond {
  width: 92px;
  height: 92px;
  margin: 84px auto 0;
}

.rp-decision-graphic .rp-decision-diamond span {
  font-size: 12.5px;
}

.rp-branch {
  position: absolute;
  left: 0;
  width: 100%;
  display: flex;
  align-items: center;
  gap: 8px;
}

.rp-branch-no { top: 60px; }
.rp-branch-yes { top: 236px; }

.rp-branch-label {
  color: #101828;
  font-size: 12px;
  font-weight: 800;
  min-width: 22px;
}

.rp-branch-line {
  position: relative;
  flex: 1;
  height: 1.5px;
  background: #2F6F9D;
}

.rp-branch-line::after {
  content: "";
  position: absolute;
  right: -1px;
  top: 50%;
  transform: translateY(-50%);
  width: 0;
  height: 0;
  border-top: 4.5px solid transparent;
  border-bottom: 4.5px solid transparent;
  border-left: 7px solid #2F6F9D;
}

.rp-post-stack {
  display: grid;
  justify-items: stretch;
  position: relative;
}

.rp-middle-link {
  position: relative;
  height: 0;
}

.rp-middle-link::before {
  content: "";
  position: absolute;
  left: -104px;
  top: -24px;
  width: 92px;
  height: 1.5px;
  background: #2F6F9D;
}

.rp-middle-link::after {
  content: "";
  position: absolute;
  left: -18px;
  top: -28px;
  width: 0;
  height: 0;
  border-top: 4.5px solid transparent;
  border-bottom: 4.5px solid transparent;
  border-right: 7px solid #2F6F9D;
}

@media(max-width:760px) {
  .rp-acceptance-stage {
    grid-template-columns: 1fr;
  }

  .rp-decision-graphic {
    min-height: auto;
    padding: 0 0 8px;
    display: grid;
    justify-items: start;
    gap: 10px;
  }

  .rp-branch {
    position: static;
    width: auto;
  }

  .rp-decision-graphic .rp-decision-diamond {
    margin: 0;
  }

  .rp-middle-link::before,
  .rp-middle-link::after {
    display: none;
  }
}


/* V84: Structured editable job detail boxes */
.job-details-content {
  display: grid;
  gap: 20px;
  min-width: 0;
}

.job-details-panel {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 18px;
  align-items: start;
}

.job-detail-box {
  background: #FFFFFF;
  border: 1px solid #DDEFE5;
  border-radius: 24px;
  padding: 24px 26px;
  box-shadow: 0 12px 28px rgba(7,21,35,.055);
  min-width: 0;
}

.job-detail-box h3 {
  margin: 0 0 14px;
  color: var(--green);
  font-size: 20px;
  line-height: 1.2;
  letter-spacing: -.02em;
}

.job-detail-title {
  color: var(--navy);
  font-size: clamp(24px, 3vw, 34px);
  line-height: 1.15;
  font-weight: 900;
  letter-spacing: -.035em;
}

.job-detail-text {
  color: #475467;
  font-size: 16.5px;
  line-height: 1.75;
  overflow-wrap: anywhere;
}

.job-detail-text p {
  margin: 0 0 12px;
}

.job-detail-text p:last-child {
  margin-bottom: 0;
}

.job-detail-text ul,
.job-detail-text ol {
  margin: 8px 0 0 20px;
  padding: 0;
}

.job-detail-text li {
  margin: 6px 0;
}

.job-title-box,
.job-responsibilities-box,
.job-extra-content-box {
  grid-column: 1 / -1;
}

.job-responsibilities-box {
  padding: 28px 30px;
}

.job-responsibilities-box .job-detail-text {
  font-size: 17px;
}

.job-extra-content-box {
  margin-top: 0;
}

@media(max-width:1080px) {
  .job-details-panel {
    grid-template-columns: 1fr;
  }

  .career-single-layout {
    grid-template-columns: 1fr;
  }

  .career-single-sidebar {
    position: static;
  }
}

@media(max-width:640px) {
  .career-single-section {
    padding: 44px 0;
  }

  .job-detail-box,
  .job-responsibilities-box {
    padding: 20px 18px;
    border-radius: 20px;
  }

  .job-detail-box h3 {
    font-size: 18px;
  }

  .job-detail-text,
  .job-responsibilities-box .job-detail-text {
    font-size: 15.5px;
    line-height: 1.65;
  }
}


/* V86: Business Development Team section support */
.people-cluster-business-development-team .people-cluster-icon {
  background: linear-gradient(135deg, var(--green), #0F9F58);
}
