/*
Theme Name: Ryantel Blueprint v2
Theme URI: https://ryantelsystems.com
Author: Ryantel Systems Limited
Description: Blueprint design system theme for Ryantel Systems - managed IT, systems integration, home fibre and AI automation.
Version: 1.0.0
License: Proprietary
Text Domain: ryantel-blueprint
*/

:root{
  --navy:#0B2350;        /* deep royal navy, matches logo wing (was #0A2540) */
  --navy-2:#16386C;      /* panel on dark */
  --paper:#F6FAFD;       /* cool white */
  --grid:rgba(30,64,175,.10);
  --line:#2B57A8;        /* blueprint linework, royal tint */
  --cyan:#2BAEE6;        /* logo cyan (was #59C2E8) */
  --royal:#1E40AF;       /* logo royal blue */
  --amber:#2BAEE6;       /* action accent, now cyan to match logo (no amber in brand) */
  --amber-d:#1E93C8;     /* darker cyan for hover */
  --ink:#16293D;         /* body on light */
  --mute:#5A718A;
  --ok:#2BB673;
  --max:1180px;
  --disp:"Archivo",-apple-system,"Helvetica Neue",Arial,sans-serif;
  --mono:"IBM Plex Mono","SFMono-Regular",Consolas,monospace;
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{font-family:var(--disp);color:var(--ink);background:var(--paper);line-height:1.6;font-size:16px}
img,svg{display:block;max-width:100%}
a{color:inherit}
.wrap{max-width:var(--max);margin:0 auto;padding:0 24px}
.mono{font-family:var(--mono)}
.eyebrow{font-family:var(--mono);font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--mute);display:flex;align-items:center;gap:10px}
.eyebrow::before{content:"";width:22px;height:1px;background:var(--amber)}
.dark .eyebrow{color:#8FB3CE}
h1,h2,h3{font-family:var(--disp);font-weight:800;line-height:1.12;letter-spacing:-.015em;color:var(--navy)}
.dark h1,.dark h2,.dark h3{color:#fff}
section{padding:88px 0}
.btn{display:inline-flex;align-items:center;gap:10px;font-weight:700;font-size:15px;text-decoration:none;padding:14px 26px;border-radius:6px;border:2px solid transparent;transition:transform .15s ease, box-shadow .15s ease, background .15s ease;cursor:pointer}
.btn:focus-visible{outline:3px solid var(--cyan);outline-offset:2px}
.btn-amber{background:var(--amber);color:var(--navy)}
.btn-amber:hover{background:var(--amber-d);transform:translateY(-1px);box-shadow:0 8px 20px rgba(43,174,230,.30)}
.btn-ghost{border-color:rgba(255,255,255,.45);color:#fff;background:transparent}
.btn-ghost:hover{border-color:#fff;background:rgba(255,255,255,.06)}
.btn-navy{background:var(--navy);color:#fff}
.btn-navy:hover{background:#0E3257;transform:translateY(-1px)}
.reveal{opacity:0;transform:translateY(18px);transition:opacity .6s ease,transform .6s ease}
.reveal.in{opacity:1;transform:none}
@media (prefers-reduced-motion: reduce){
  .reveal{opacity:1;transform:none;transition:none}
  html{scroll-behavior:auto}
}

/* ---------- NAV ---------- */
header{position:sticky;top:0;z-index:60;background:rgba(255,255,255,.97);backdrop-filter:blur(8px);border-bottom:1px solid #E3ECF4}
.nav{display:flex;align-items:center;gap:28px;height:68px}
.logo{display:flex;align-items:center;text-decoration:none}
.logo img{height:44px;width:auto;display:block}
.nav nav{display:flex;gap:24px;margin-left:auto}
.nav nav a{color:var(--navy);text-decoration:none;font-size:14.5px;font-weight:600}
.nav nav a:hover{color:var(--royal)}
.nav nav a.fibre{color:#1592C8}
.nav .btn{padding:10px 18px;font-size:13.5px;margin-left:8px}
.menu-btn{display:none;margin-left:auto;background:none;border:1px solid #C9D8E5;color:var(--navy);border-radius:6px;padding:8px 12px;font-family:var(--mono);font-size:12px}
@media(max-width:900px){
  .nav nav{display:none;position:absolute;top:68px;left:0;right:0;background:#fff;flex-direction:column;padding:18px 24px;gap:16px;border-bottom:1px solid #E3ECF4;box-shadow:0 16px 30px rgba(10,37,64,.10)}
  .nav nav.open{display:flex}
  .menu-btn{display:block}
  .nav .btn{display:none}
}

/* ---------- HERO ---------- */
.hero{background:var(--navy);color:#fff;position:relative;overflow:hidden;padding:84px 0 0}
.hero::before{content:"";position:absolute;inset:0;
  background-image:linear-gradient(rgba(89,194,232,.07) 1px,transparent 1px),linear-gradient(90deg,rgba(89,194,232,.07) 1px,transparent 1px);
  background-size:44px 44px;pointer-events:none}
.hero .wrap{display:grid;grid-template-columns:1.05fr .95fr;gap:48px;align-items:center;position:relative}
.hero h1{font-size:clamp(32px,4.6vw,52px);color:#fff;margin:18px 0 18px}
.hero h1 em{font-style:normal;color:var(--amber)}
.hero p.lead{font-size:18px;color:#C9DCEC;max-width:54ch}
.hero .ctas{display:flex;gap:14px;flex-wrap:wrap;margin:30px 0 12px}
.hero .micro{font-family:var(--mono);font-size:11.5px;color:#8FB3CE}
.schematic{position:relative}
.schematic .tag{position:absolute;font-family:var(--mono);font-size:10px;letter-spacing:.1em;color:var(--cyan);background:rgba(10,37,64,.85);border:1px solid rgba(89,194,232,.35);padding:3px 7px;border-radius:3px}
@media(max-width:980px){.hero .wrap{grid-template-columns:1fr}.schematic{max-width:520px;margin:0 auto}}

/* guarantee strip */
.guarantee{background:var(--navy-2);border-top:1px solid rgba(89,194,232,.18);margin-top:64px;position:relative}
.guarantee .wrap{display:grid;grid-template-columns:repeat(3,1fr);gap:0}
.g-item{padding:26px 28px;border-left:1px solid rgba(89,194,232,.18)}
.g-item:first-child{border-left:none}
.g-item b{display:block;color:#fff;font-size:15.5px;margin-bottom:4px}
.g-item span{font-size:13.5px;color:#A9C4DA}
.g-item .gnum{font-family:var(--mono);color:var(--amber);font-size:11px;letter-spacing:.15em;display:block;margin-bottom:8px}
@media(max-width:900px){.guarantee .wrap{grid-template-columns:1fr}.g-item{border-left:none;border-top:1px solid rgba(89,194,232,.18)}}

/* ---------- TRUST BAR ---------- */
.trust{padding:34px 0;border-bottom:1px solid var(--grid);background:#fff}
.trust .wrap{display:flex;align-items:center;gap:34px;flex-wrap:wrap;justify-content:space-between}
.trust .lbl{font-family:var(--mono);font-size:10.5px;letter-spacing:.2em;color:var(--mute)}
.trust .names{display:flex;gap:34px;flex-wrap:wrap;align-items:center}
.trust .names span{font-weight:800;color:#9AAEC2;font-size:15.5px;letter-spacing:.02em;white-space:nowrap}

/* ---------- ENGINES ---------- */
.engines .grid{display:grid;grid-template-columns:repeat(4,1fr);gap:20px;margin-top:42px}
.card{background:#fff;border:1px solid #E3ECF4;border-radius:10px;padding:26px 24px;position:relative;transition:transform .18s ease,box-shadow .18s ease;display:flex;flex-direction:column}
.card:hover{transform:translateY(-4px);box-shadow:0 16px 34px rgba(10,37,64,.10)}
.card::before,.card::after{content:"";position:absolute;width:14px;height:14px;border-color:var(--cyan);border-style:solid;opacity:.55}
.card::before{top:8px;left:8px;border-width:1.5px 0 0 1.5px}
.card::after{bottom:8px;right:8px;border-width:0 1.5px 1.5px 0}
.card .ref{font-family:var(--mono);font-size:10px;letter-spacing:.15em;color:var(--mute);margin-bottom:14px}
.card h3{font-size:18.5px;margin-bottom:10px}
.card p{font-size:14px;color:var(--ink);flex:1}
.card a{margin-top:16px;font-weight:700;font-size:13.5px;color:var(--navy);text-decoration:none}
.card a::after{content:" →";color:var(--amber)}
.card a:hover{text-decoration:underline}
.card.fibre-card{background:var(--navy);border-color:var(--navy)}
.card.fibre-card h3,.card.fibre-card a{color:#fff}
.card.fibre-card p{color:#C9DCEC}
.card.fibre-card .ref{color:var(--cyan)}
@media(max-width:1000px){.engines .grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:580px){.engines .grid{grid-template-columns:1fr}}
h2.sect{font-size:clamp(26px,3.4vw,38px);max-width:24ch;margin-top:14px}

/* ---------- TOTAL COVER (dark band) ---------- */
.cover{background:var(--navy);color:#fff;position:relative;overflow:hidden}
.cover::before{content:"";position:absolute;inset:0;background-image:linear-gradient(rgba(89,194,232,.05) 1px,transparent 1px),linear-gradient(90deg,rgba(89,194,232,.05) 1px,transparent 1px);background-size:44px 44px}
.cover .wrap{display:grid;grid-template-columns:1.1fr .9fr;gap:54px;position:relative}
.cover p{color:#C9DCEC}
.cover ul{list-style:none;margin-top:26px;display:grid;gap:16px}
.cover ul li{display:flex;gap:14px;font-size:15px;color:#DCE9F4}
.cover ul li b{color:#fff}
.cover ul li::before{content:"";flex:0 0 18px;height:18px;margin-top:3px;border:2px solid var(--amber);border-radius:50%;background:radial-gradient(circle at center,var(--amber) 0 35%,transparent 40%)}
.spec{background:var(--navy-2);border:1px solid rgba(89,194,232,.22);border-radius:12px;padding:30px;align-self:center}
.spec .ref{font-family:var(--mono);font-size:10.5px;letter-spacing:.2em;color:var(--cyan);margin-bottom:18px}
.spec .row{display:flex;justify-content:space-between;gap:14px;padding:13px 0;border-bottom:1px dashed rgba(89,194,232,.25);font-size:14px}
.spec .row:last-of-type{border-bottom:none}
.spec .row b{color:var(--amber);font-family:var(--mono);font-weight:500;text-align:right}
.spec .note{font-size:11px;color:#8FB3CE;margin-top:14px;font-family:var(--mono)}
@media(max-width:920px){.cover .wrap{grid-template-columns:1fr}}

/* ---------- FIBRE ---------- */
.fibre{background:#fff;border-top:1px solid var(--grid)}
.fibre .wrap{display:grid;grid-template-columns:.95fr 1.05fr;gap:54px;align-items:center}
.fibre .counties{display:flex;gap:10px;flex-wrap:wrap;margin:22px 0}
.fibre .counties span{font-family:var(--mono);font-size:12px;border:1.5px solid var(--navy);color:var(--navy);border-radius:99px;padding:6px 14px;font-weight:500}
.fibre form{display:flex;gap:10px;margin-top:26px;flex-wrap:wrap}
.fibre input{flex:1;min-width:200px;padding:14px 16px;border:1.5px solid #C9D8E5;border-radius:6px;font:inherit;font-size:14.5px;background:var(--paper)}
.fibre input:focus{outline:2px solid var(--cyan);border-color:var(--cyan)}
.fibre .small{font-size:12.5px;color:var(--mute);margin-top:12px}
.speedo{background:var(--navy);border-radius:14px;padding:34px;color:#fff;position:relative;overflow:hidden}
.speedo::before{content:"";position:absolute;inset:0;background-image:linear-gradient(rgba(89,194,232,.06) 1px,transparent 1px),linear-gradient(90deg,rgba(89,194,232,.06) 1px,transparent 1px);background-size:34px 34px}
.speedo .pkg{display:flex;justify-content:space-between;align-items:baseline;padding:16px 0;border-bottom:1px dashed rgba(89,194,232,.3);position:relative}
.speedo .pkg:last-child{border:none}
.speedo .pkg .n{font-weight:800;font-size:17px}
.speedo .pkg .s{font-family:var(--mono);font-size:12px;color:var(--cyan)}
.speedo .pkg .p{font-family:var(--mono);color:var(--amber);font-size:15px}
.speedo .lbl{font-family:var(--mono);font-size:10.5px;letter-spacing:.2em;color:#8FB3CE;position:relative}
@media(max-width:920px){.fibre .wrap{grid-template-columns:1fr}}

/* ---------- PROOF ---------- */
.proof{background:var(--paper)}
.proof .case{margin-top:42px;background:#fff;border:1px solid #E3ECF4;border-radius:12px;display:grid;grid-template-columns:1fr 1fr;overflow:hidden}
.proof .case .left{padding:38px;border-right:1px solid #E3ECF4}
.proof .case .left .ref{font-family:var(--mono);font-size:10.5px;letter-spacing:.18em;color:var(--mute);margin-bottom:14px}
.proof .case h3{font-size:23px;margin-bottom:12px}
.proof .case p{font-size:15px}
.proof .stats{display:grid;grid-template-columns:1fr 1fr;}
.proof .stat{padding:30px;border-left:1px solid #E3ECF4;border-top:1px solid #E3ECF4}
.proof .stat:nth-child(-n+2){border-top:none}
.proof .stat b{display:block;font-size:30px;font-weight:900;color:var(--navy);letter-spacing:-.02em}
.proof .stat span{font-size:12.5px;color:var(--mute)}
@media(max-width:920px){.proof .case{grid-template-columns:1fr}.proof .case .left{border-right:none;border-bottom:1px solid #E3ECF4}}

/* testimonials */
.quotes{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-top:42px}
.q{background:#fff;border:1px solid #E3ECF4;border-radius:10px;padding:26px}
.q h4{font-size:16.5px;color:var(--navy);margin-bottom:10px}
.q p{font-size:14px;color:var(--ink)}
.q .who{margin-top:16px;font-family:var(--mono);font-size:11.5px;color:var(--mute)}
@media(max-width:900px){.quotes{grid-template-columns:1fr}}

/* ---------- CLOSING CTA ---------- */
.close{background:var(--navy);color:#fff;text-align:left;position:relative;overflow:hidden}
.close::before{content:"";position:absolute;inset:0;background-image:linear-gradient(rgba(89,194,232,.06) 1px,transparent 1px),linear-gradient(90deg,rgba(89,194,232,.06) 1px,transparent 1px);background-size:44px 44px}
.close .wrap{display:grid;grid-template-columns:1.2fr .8fr;gap:54px;align-items:center;position:relative}
.close h2{color:#fff;font-size:clamp(26px,3.4vw,40px)}
.close p{color:#C9DCEC;margin-top:14px;max-width:52ch}
.magnet{background:var(--navy-2);border:1px solid rgba(89,194,232,.22);border-radius:12px;padding:28px}
.magnet .ref{font-family:var(--mono);font-size:10.5px;letter-spacing:.2em;color:var(--cyan);margin-bottom:12px}
.magnet b{color:#fff;font-size:16.5px;display:block;margin-bottom:8px}
.magnet p{font-size:13.5px;color:#A9C4DA;margin:0 0 18px}
@media(max-width:920px){.close .wrap{grid-template-columns:1fr}}

/* ---------- FOOTER ---------- */
footer{background:#071A2E;color:#9FB6CA;padding:54px 0 30px;font-size:13.5px}
footer .cols{display:grid;grid-template-columns:2fr 1fr 1fr 1.4fr;gap:34px}
footer h5{color:#fff;font-size:13px;letter-spacing:.06em;margin-bottom:14px;text-transform:uppercase}
footer a{color:#9FB6CA;text-decoration:none;display:block;margin-bottom:9px}
footer a:hover{color:#fff}
footer .lic{font-family:var(--mono);font-size:11px;line-height:1.8;color:#6E89A3}
footer .base{border-top:1px solid rgba(255,255,255,.08);margin-top:40px;padding-top:20px;display:flex;justify-content:space-between;gap:20px;flex-wrap:wrap;font-size:12px;color:#6E89A3}
@media(max-width:900px){footer .cols{grid-template-columns:1fr 1fr}}

/* whatsapp */
.wa{position:fixed;right:20px;bottom:20px;z-index:70;background:#25D366;color:#fff;width:56px;height:56px;border-radius:50%;display:flex;align-items:center;justify-content:center;box-shadow:0 10px 24px rgba(0,0,0,.25);text-decoration:none}
.wa svg{width:28px;height:28px;fill:#fff}
.wa:hover{transform:scale(1.06)}

/* ---- interior pages ---- */
.page-shell{max-width:860px;margin:0 auto;padding:72px 24px}
.page-shell h1{font-size:clamp(30px,4vw,44px);margin-bottom:22px}
.page-shell h2{font-size:24px;margin:34px 0 12px}
.page-shell h3{font-size:19px;margin:26px 0 10px}
.page-shell p{margin:0 0 16px}
.page-shell ul,.page-shell ol{margin:0 0 16px 22px}
.page-shell table{border-collapse:collapse;width:100%;margin:0 0 20px}
.page-shell td,.page-shell th{border:1px solid #E3ECF4;padding:10px 12px;font-size:14.5px;text-align:left}
.page-shell th{background:var(--paper)}

/* ---- header phone ---- */
.nav-tel{font-family:var(--mono);font-size:13px;color:var(--navy);text-decoration:none;letter-spacing:.04em;margin-left:14px;white-space:nowrap}
.nav-tel:hover{color:var(--royal)}
@media(max-width:900px){.nav-tel{display:none}}

/* ---- lead forms ---- */
.lead-form{background:#fff;border:1px solid #E3ECF4;border-radius:10px;padding:28px 26px;margin:26px 0}
.lead-form form{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.lead-form .lf-label{display:flex;flex-direction:column;gap:6px;font-family:var(--mono);font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:var(--mute)}
.lead-form .lf-label:has(textarea),.lead-form button{grid-column:1/-1}
.lead-form input,.lead-form select,.lead-form textarea{padding:13px 14px;border:1.5px solid #C9D8E5;border-radius:6px;font:inherit;font-size:14.5px;background:var(--paper);color:var(--ink);letter-spacing:normal;text-transform:none}
.lead-form input:focus,.lead-form select:focus,.lead-form textarea:focus{outline:2px solid var(--cyan);border-color:var(--cyan)}
.lead-form button{justify-content:center}
.lead-form .hp-field{position:absolute;left:-9999px;height:0;overflow:hidden;margin:0}
.form-success{font-weight:700;color:var(--navy);background:#EAF7EF;border:1px solid #BFE5CC;border-radius:8px;padding:18px 20px;margin:0}
@media(max-width:640px){.lead-form form{grid-template-columns:1fr}}

/* ---- closing CTA band on interior pages ---- */
.page-shell .cta-band{background:var(--navy);color:#fff;border-radius:12px;padding:34px 32px;margin:40px 0 10px}
.page-shell .cta-band h2{color:#fff;margin:0 0 10px}
.page-shell .cta-band p{color:#B9CCDD}
.page-shell .cta-band .btn{margin-top:8px;margin-right:10px}

/* ---- featured guide section (TMT-style lead magnet) ---- */
.guide-sec{background:var(--paper);border-top:1px solid #E3ECF4;border-bottom:1px solid #E3ECF4;padding:72px 24px;margin:40px 0}
.page-shell .guide-sec{margin:40px -24px;padding:48px 24px}
.gs-wrap{max-width:1080px;margin:0 auto;display:grid;grid-template-columns:300px 1fr;gap:56px;align-items:center}
.gs-cover{display:flex;justify-content:center}
.gs-art{background:var(--navy);background-image:linear-gradient(rgba(46,94,142,.25) 1px,transparent 1px),linear-gradient(90deg,rgba(46,94,142,.25) 1px,transparent 1px);background-size:28px 28px;border:1px solid #2E5E8E;border-radius:6px;width:260px;min-height:340px;padding:30px 24px;display:flex;flex-direction:column;gap:14px;transform:rotate(-2deg);box-shadow:14px 18px 34px rgba(10,37,64,.28)}
.gs-art .gs-tag{font-family:var(--mono);font-size:10px;letter-spacing:.18em;color:var(--amber)}
.gs-art b{font-size:44px;line-height:1.02;color:#fff;letter-spacing:-.01em}
.gs-art .gs-sub{font-size:15px;line-height:1.45;color:#B9CCDD}
.gs-art em{margin-top:auto;font-style:normal;font-family:var(--mono);font-size:9.5px;letter-spacing:.16em;color:#6E89A3}
.gs-body h2{font-size:clamp(24px,3vw,32px);line-height:1.15;color:var(--navy);margin:10px 0 14px}
.gs-body>p{color:var(--mute);margin:0 0 16px;max-width:60ch}
.gs-list{list-style:none;margin:0 0 6px;padding:0}
.gs-list li{position:relative;padding-left:26px;margin-bottom:9px;font-size:15px}
.gs-list li::before{content:"";position:absolute;left:0;top:7px;width:12px;height:7px;border-left:2.5px solid var(--amber);border-bottom:2.5px solid var(--amber);transform:rotate(-45deg)}
.guide-sec .lead-form{margin-bottom:0;box-shadow:0 8px 24px rgba(10,37,64,.06)}
@media(max-width:880px){.gs-wrap{grid-template-columns:1fr;gap:36px}.gs-cover{order:-1}}

/* ---- footer newsletter ---- */
footer .news-row{border-top:1px solid rgba(255,255,255,.08);margin-top:36px;padding-top:28px;display:grid;grid-template-columns:1.2fr 1fr;gap:28px;align-items:center}
footer .news-row .lead-form{background:transparent;border:none;padding:0;margin:0}
footer .news-row .lead-form form{display:flex;gap:10px;align-items:flex-end}
footer .news-row .lf-label{flex:1;color:#6E89A3}
footer .news-row .lead-form input{background:rgba(255,255,255,.06);border-color:rgba(255,255,255,.2);color:#fff}
footer .news-row .lead-form button{white-space:nowrap;padding:13px 22px}
footer .news-row .form-success{background:rgba(89,194,232,.1);border-color:rgba(89,194,232,.3);color:#DCE9F4}
@media(max-width:760px){footer .news-row{grid-template-columns:1fr}}

/* ---- Insights blog ---- */
.article-meta{display:flex;gap:14px;font-family:var(--mono);font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:var(--mute);margin-bottom:14px;flex-wrap:wrap}
.article-meta span{position:relative}
.article-meta span+span::before{content:"·";position:absolute;left:-10px;color:#C9D8E5}
.back-link{display:inline-block;font-family:var(--mono);font-size:12px;letter-spacing:.08em;color:var(--mute);text-decoration:none;margin-bottom:22px}
.back-link:hover{color:var(--navy)}
.insights-index .lead-intro{font-size:18px;color:var(--mute);max-width:64ch;margin-bottom:8px}
.post-list{display:flex;flex-direction:column;gap:4px;margin-top:30px}
.post-card{padding:28px 0;border-top:1px solid #E3ECF4}
.post-card:last-child{border-bottom:1px solid #E3ECF4}
.post-card h2{font-size:24px;line-height:1.2;margin:6px 0 10px}
.post-card h2 a{color:var(--navy);text-decoration:none}
.post-card h2 a:hover{color:var(--line)}
.post-card p{color:var(--mute);margin:0 0 12px;max-width:70ch}
.read-more{font-family:var(--mono);font-size:12.5px;letter-spacing:.06em;font-weight:500;color:var(--navy);text-decoration:none}
.read-more span{color:var(--amber)}
.read-more:hover{color:var(--line)}
.article .article-body{font-size:17px;line-height:1.7;max-width:68ch}
.article .article-body h2{font-size:25px;margin:34px 0 12px}
.article .article-body h3{font-size:19px;margin:26px 0 8px}
.article .article-body ul,.article .article-body ol{margin:0 0 18px 22px}
.article .article-body li{margin-bottom:7px}
.article .article-body table{border-collapse:collapse;width:100%;margin:0 0 20px;font-size:15px}
.article .article-body td,.article .article-body th{border:1px solid #E3ECF4;padding:10px 12px;text-align:left}
.article .article-body th{background:var(--paper);font-family:var(--mono);font-size:11px;letter-spacing:.08em;text-transform:uppercase}
.article .article-body blockquote{border-left:3px solid var(--amber);margin:0 0 18px;padding:4px 0 4px 18px;color:var(--navy);font-weight:600}
.article-foot{margin:36px 0 0;padding-top:20px;border-top:1px solid #E3ECF4}
.article-foot .byline{font-size:14px;color:var(--mute);margin:0}
.related{margin-top:44px}
.rel-grid{display:grid;grid-template-columns:1fr 1fr 1fr;gap:16px;margin-top:14px}
.rel-card{display:block;border:1px solid #E3ECF4;border-radius:8px;padding:18px;text-decoration:none;transition:transform .15s,box-shadow .15s}
.rel-card:hover{transform:translateY(-3px);box-shadow:0 12px 26px rgba(10,37,64,.08)}
.rel-card .rel-date{font-family:var(--mono);font-size:10.5px;letter-spacing:.1em;text-transform:uppercase;color:var(--mute)}
.rel-card b{display:block;margin-top:8px;font-size:15px;line-height:1.3;color:var(--navy)}
.pager{display:flex;gap:8px;margin-top:32px}
.pager .page-numbers{font-family:var(--mono);font-size:13px;padding:8px 13px;border:1px solid #C9D8E5;border-radius:6px;text-decoration:none;color:var(--navy)}
.pager .page-numbers.current{background:var(--navy);color:#fff;border-color:var(--navy)}
@media(max-width:680px){.rel-grid{grid-template-columns:1fr}}

/* ---- company profile download callout ---- */
.doc-cta{display:flex;gap:24px;align-items:center;justify-content:space-between;flex-wrap:wrap;background:var(--paper);border:1px solid #DCE6EF;border-left:4px solid var(--cyan);border-radius:10px;padding:22px 26px;margin:26px 0}
.doc-cta>div{flex:1;min-width:240px}
.doc-cta strong{display:block;font-size:17px;color:var(--navy);margin-bottom:5px}
.doc-cta p{margin:0;color:var(--mute);font-size:14.5px;max-width:56ch}
.doc-cta .btn{white-space:nowrap}
@media(max-width:600px){.doc-cta{flex-direction:column;align-items:flex-start}}

/* nav: remove default list markers from bare menu <li> items */
.nav nav{list-style:none}
.nav nav li{list-style:none;margin:0;padding:0}
