/* ============================================
   MAC MEDILIFE — V3 STYLESHEET
   Exact Pfizer.com Design System Clone
   Font: Noto Sans | Primary: #3643BA (Pfizer Indigo)
   ============================================ */

/* --- RESET & BASE --- */
*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
:root{
  --pfizer-indigo:#3643BA;
  --pfizer-indigo-dark:#2A3399;
  --pfizer-indigo-deep:#1B2275;
  --pfizer-blue:#0095DA;
  --pfizer-blue-light:#E8F6FD;
  --pfizer-teal:#00857C;
  --pfizer-red:#E4002B;
  --white:#FFFFFF;
  --off-white:#F5F5F5;
  --gray-50:#FAFAFA;
  --gray-100:#F5F5F5;
  --gray-200:#EEEEEE;
  --gray-300:#E0E0E0;
  --gray-400:#BDBDBD;
  --gray-500:#9E9E9E;
  --gray-600:#757575;
  --gray-700:#616161;
  --gray-800:#424242;
  --gray-900:#212121;
  --black:#000000;
  --radius:8px;
  --radius-pill:100px;
  --shadow-sm:0 1px 3px rgba(0,0,0,0.08);
  --shadow-md:0 4px 16px rgba(0,0,0,0.1);
  --shadow-lg:0 8px 32px rgba(0,0,0,0.12);
  --transition:0.3s ease;
  --max-width:1280px;
  --nav-height:72px;
}
html{scroll-behavior:smooth;font-size:16px}
body{
  font-family:'Noto Sans',system-ui,-apple-system,sans-serif;
  color:var(--gray-900);
  line-height:1.6;
  background:var(--white);
  -webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale;
  overflow-x:hidden;
}
h1,h2,h3,h4,h5,h6{
  font-family:'Noto Sans',system-ui,sans-serif;
  font-weight:700;
  line-height:1.15;
  color:var(--gray-900);
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
ul{list-style:none}

.container{max-width:var(--max-width);margin:0 auto;padding:0 48px}

/* =========================================
   NAVIGATION — Pfizer single-row white bar
   Logo left | Primary links center | Utility right
   ========================================= */
.pf-nav{
  position:sticky;
  top:0;
  z-index:1000;
  background:var(--white);
  border-bottom:1px solid var(--gray-200);
  transition:box-shadow 0.3s ease;
}
.pf-nav.scrolled{box-shadow:0 2px 12px rgba(0,0,0,0.08)}
.pf-nav-inner{
  display:flex;
  align-items:center;
  height:var(--nav-height);
  max-width:var(--max-width);
  margin:0 auto;
  padding:0 48px;
}
.pf-logo{display:flex;flex-direction:column;align-items:center;flex-shrink:0;margin-right:40px}
.pf-logo img{height:36px;width:auto}
.pf-logo-text{font-size:0.55rem;color:var(--gray-500);text-transform:uppercase;letter-spacing:1.5px;font-weight:600;margin-top:5px;white-space:nowrap}

/* Primary nav links - center */
.pf-links{
  display:flex;
  align-items:center;
  gap:0;
  flex:1;
  height:100%;
}
.pf-links > a,
.pf-links > .pf-nav-item > a{
  display:flex;
  align-items:center;
  height:var(--nav-height);
  padding:0 18px;
  font-size:0.88rem;
  font-weight:500;
  text-transform:uppercase;
  letter-spacing:0.5px;
  color:var(--gray-800);
  text-decoration:none;
  position:relative;
  transition:color 0.2s;
  white-space:nowrap;
}
.pf-links > a::after,
.pf-links > .pf-nav-item > a::after{
  content:'';
  position:absolute;
  bottom:0;left:18px;right:18px;
  height:3px;
  background:var(--pfizer-indigo);
  transform:scaleX(0);
  transition:transform 0.25s ease;
}
.pf-links > a:hover,
.pf-links > .pf-nav-item:hover > a{color:var(--pfizer-indigo)}
.pf-links > a:hover::after,
.pf-links > .pf-nav-item:hover > a::after,
.pf-links > a.active::after,
.pf-links > .pf-nav-item > a.active::after{transform:scaleX(1)}
.pf-links > a.active,
.pf-links > .pf-nav-item > a.active{color:var(--pfizer-indigo)}

.pf-nav-item.current-page > a{color:var(--pfizer-indigo)}
.pf-nav-item.current-page > a::after{transform:scaleX(1)}

/* Nav item with mega menu */
.pf-nav-item{position:relative;height:100%;display:flex;align-items:center}

/* ---- MEGA MENU (Pfizer-style dropdown) ---- */
.pf-mega{
  position:absolute;
  top:100%;
  left:50%;
  transform:translateX(-50%);
  min-width:600px;
  background:var(--white);
  border-radius:0 0 12px 12px;
  box-shadow:0 12px 40px rgba(0,0,0,0.12);
  padding:36px 40px;
  opacity:0;
  visibility:hidden;
  transform:translateX(-50%) translateY(8px);
  transition:all 0.25s ease;
  z-index:200;
  border-top:3px solid var(--pfizer-indigo);
}
.pf-nav-item:hover .pf-mega{
  opacity:1;
  visibility:visible;
  transform:translateX(-50%) translateY(0);
}
.pf-mega-header{
  font-size:0.68rem;
  text-transform:uppercase;
  letter-spacing:2.5px;
  font-weight:700;
  color:var(--pfizer-indigo);
  margin-bottom:20px;
  padding-bottom:12px;
  border-bottom:1px solid var(--gray-200);
}
.pf-mega-grid{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:0 40px;
}
.pf-mega-link{
  display:flex;
  align-items:center;
  gap:14px;
  padding:14px 0;
  border-bottom:1px solid var(--gray-100);
  text-decoration:none;
  color:var(--gray-800);
  transition:all 0.2s;
}
.pf-mega-link:hover{color:var(--pfizer-indigo);padding-left:6px}
.pf-mega-icon{
  width:40px;height:40px;
  border-radius:10px;
  display:flex;align-items:center;justify-content:center;
  flex-shrink:0;
  transition:all 0.2s;
}
.pf-mega-link:hover .pf-mega-icon{transform:scale(1.08)}
.pf-mega-icon svg{width:20px;height:20px;stroke-width:1.5}
.pf-mega-label h5{font-size:0.88rem;font-weight:700;margin-bottom:2px;color:inherit}
.pf-mega-label span{font-size:0.75rem;color:var(--gray-500);font-weight:400}
.pf-mega-footer{
  margin-top:20px;
  padding-top:16px;
  border-top:1px solid var(--gray-200);
  display:flex;
  align-items:center;
  justify-content:space-between;
}
.pf-mega-footer a{
  font-size:0.85rem;
  font-weight:700;
  color:var(--pfizer-indigo);
  text-decoration:none;
  display:inline-flex;
  align-items:center;
  gap:6px;
  transition:all 0.2s;
}
.pf-mega-footer a:hover{color:var(--pfizer-indigo-dark)}
.pf-mega-footer a svg{width:16px;height:16px;stroke:currentColor;fill:none;stroke-width:2.5;transition:transform 0.3s}
.pf-mega-footer a:hover svg{transform:translateX(4px)}

/* Mega menu — preview variant (Benoquin / Our Story) */
.pf-mega.pf-mega-preview{
  min-width:520px;
  padding:0;
  overflow:hidden;
}
.pf-mega-preview-inner{
  display:grid;
  grid-template-columns:200px 1fr;
}
.pf-mega-preview-img{
  background:var(--gray-50);
  display:flex;
  align-items:center;
  justify-content:center;
  padding:24px;
}
.pf-mega-preview-img img{
  max-height:200px;
  width:auto;
  object-fit:contain;
}
.pf-mega-preview-content{
  padding:32px;
}
.pf-mega-preview-content h4{
  font-size:1.1rem;
  font-weight:700;
  color:var(--gray-900);
  margin-bottom:10px;
}
.pf-mega-preview-content p{
  font-size:0.85rem;
  color:var(--gray-600);
  line-height:1.6;
  margin-bottom:16px;
}

/* Mega menu background overlay */
.pf-mega-overlay{
  position:fixed;
  top:var(--nav-height);
  left:0;right:0;bottom:0;
  background:rgba(54,67,186,0.6);
  z-index:100;
  opacity:0;
  visibility:hidden;
  transition:opacity 0.3s ease,visibility 0.3s ease;
  pointer-events:none;
}
.pf-mega-overlay.active{
  opacity:1;
  visibility:visible;
}

/* Utility links - right */
.pf-utility{
  display:flex;
  align-items:center;
  gap:16px;
  margin-left:auto;
  flex-shrink:0;
}
.pf-utility a{
  font-size:0.8rem;
  font-weight:500;
  color:var(--gray-600);
  text-decoration:none;
  transition:color 0.2s;
  white-space:nowrap;
}
.pf-utility a:hover{color:var(--pfizer-indigo)}
.pf-utility .pf-search-btn{
  width:36px;height:36px;
  border-radius:50%;
  border:1px solid var(--gray-300);
  background:var(--white);
  display:flex;align-items:center;justify-content:center;
  cursor:pointer;
  transition:all 0.2s;
}
.pf-utility .pf-search-btn:hover{border-color:var(--pfizer-indigo);background:var(--pfizer-indigo)}
.pf-utility .pf-search-btn:hover svg{stroke:var(--white)}
.pf-utility .pf-search-btn svg{width:16px;height:16px;stroke:var(--gray-600);fill:none;stroke-width:2}
.pf-utility .pf-contact-btn{
  padding:8px 22px;
  border-radius:var(--radius-pill);
  background:var(--pfizer-indigo);
  color:var(--white);
  font-size:0.8rem;
  font-weight:600;
  transition:all 0.2s;
  border:2px solid var(--pfizer-indigo);
}
.pf-utility .pf-contact-btn:hover{background:var(--white);color:var(--pfizer-indigo);border:2px solid var(--pfizer-indigo);padding:6px 20px}

/* Mobile hamburger */
.pf-hamburger{
  display:none;
  background:none;border:none;cursor:pointer;padding:8px;
  margin-left:auto;
}
.pf-hamburger svg{width:24px;height:24px;stroke:var(--gray-800);fill:none;stroke-width:2}

/* Mobile menu — hidden on desktop */
.pf-mobile-menu{display:none}

/* =========================================
   SEARCH OVERLAY — Pfizer full-width search
   ========================================= */
.pf-search-overlay{
  position:fixed;
  top:0;left:0;right:0;bottom:0;
  background:rgba(0,0,0,0.5);
  z-index:2000;
  display:none;
  align-items:flex-start;
  justify-content:center;
  padding-top:120px;
}
.pf-search-overlay.open{display:flex}
.pf-search-box{
  background:var(--white);
  border-radius:12px;
  padding:40px 48px;
  width:100%;
  max-width:720px;
  box-shadow:var(--shadow-lg);
  position:relative;
}
.pf-search-box h3{font-size:1.4rem;font-weight:700;margin-bottom:20px;color:var(--gray-900)}
.pf-search-input-wrap{position:relative}
.pf-search-input-wrap input{
  width:100%;
  padding:16px 56px 16px 20px;
  border:2px solid var(--gray-300);
  border-radius:var(--radius-pill);
  font-family:'Noto Sans',sans-serif;
  font-size:1rem;
  color:var(--gray-900);
  outline:none;
  transition:border-color 0.2s;
}
.pf-search-input-wrap input:focus{border-color:var(--pfizer-indigo)}
.pf-search-input-wrap button{
  position:absolute;right:6px;top:50%;transform:translateY(-50%);
  width:40px;height:40px;border-radius:50%;
  background:var(--pfizer-indigo);border:none;
  display:flex;align-items:center;justify-content:center;
  cursor:pointer;transition:background 0.2s;
}
.pf-search-input-wrap button:hover{background:var(--pfizer-indigo-dark)}
.pf-search-input-wrap button svg{width:18px;height:18px;stroke:var(--white);fill:none;stroke-width:2}
.pf-search-close{
  position:absolute;top:16px;right:16px;
  width:36px;height:36px;border-radius:50%;
  border:none;background:var(--gray-100);
  display:flex;align-items:center;justify-content:center;
  cursor:pointer;transition:background 0.2s;
}
.pf-search-close:hover{background:var(--gray-200)}
.pf-search-close svg{width:18px;height:18px;stroke:var(--gray-700);fill:none;stroke-width:2}

/* Search suggestions */
.pf-search-suggestions{margin-top:16px;max-height:320px;overflow-y:auto}
.pf-search-group{margin-bottom:12px}
.pf-search-group-label{display:block;font-size:0.7rem;font-weight:700;text-transform:uppercase;letter-spacing:1.5px;color:var(--gray-500);padding:4px 0 8px;border-bottom:1px solid var(--gray-200);margin-bottom:4px}
.pf-search-suggestion{display:flex;align-items:center;justify-content:space-between;padding:10px 12px;border-radius:var(--radius);transition:background 0.15s;cursor:pointer;text-decoration:none;color:var(--gray-900)}
.pf-search-suggestion:hover{background:var(--gray-100)}
.pf-search-sug-name{font-size:0.92rem;font-weight:500}
.pf-search-sug-cat{font-size:0.78rem;color:var(--gray-500);margin-left:12px;flex-shrink:0}
.pf-search-no-results{padding:16px 0;text-align:center;color:var(--gray-500);font-size:0.92rem}

/* =========================================
   TICKER STRIP — Scrolling announcement bar
   ========================================= */
.pf-ticker{
  background:#D4880F;
  overflow:hidden;
  white-space:nowrap;
  position:relative;
}
.pf-ticker-track{
  display:inline-flex;
  animation:ticker 40s linear infinite;
}
.pf-ticker-track span{
  display:inline-flex;
  align-items:center;
  padding:10px 48px;
  font-size:0.78rem;
  font-weight:600;
  color:rgba(255,255,255,0.9);
  letter-spacing:0.5px;
}
.pf-ticker-track span::before{
  content:'';
  width:6px;height:6px;
  border-radius:50%;
  background:rgba(255,255,255,0.4);
  margin-right:16px;
  flex-shrink:0;
}
@keyframes ticker{
  0%{transform:translateX(0)}
  100%{transform:translateX(-50%)}
}

/* =========================================
   HERO — Pfizer full-width bg image + overlay
   ========================================= */
.pf-hero{
  position:relative;
  min-height:560px;
  display:flex;
  align-items:center;
  overflow:hidden;
}
.pf-hero-bg{
  position:absolute;inset:0;z-index:0;
  background:linear-gradient(135deg,#141248 0%,#1B2275 45%,#2A2F8E 100%);
}
.pf-hero-content{
  position:relative;z-index:1;
  max-width:var(--max-width);
  margin:0 auto;
  padding:80px 48px;
  width:100%;
}
.pf-hero-content h1{
  font-size:3.5rem;
  font-weight:700;
  line-height:1.08;
  color:var(--white);
  max-width:640px;
  margin-bottom:24px;
  letter-spacing:-0.5px;
}
.pf-hero-content h1 em{font-style:italic;font-weight:400}
.pf-hero-content p{
  font-size:1.1rem;
  color:rgba(255,255,255,0.85);
  max-width:520px;
  line-height:1.7;
  margin-bottom:32px;
}
.pf-hero-cta{
  display:inline-flex;
  align-items:center;
  gap:10px;
  padding:14px 36px;
  border-radius:var(--radius-pill);
  background:var(--white);
  color:var(--pfizer-indigo);
  font-weight:700;
  font-size:0.95rem;
  text-decoration:none;
  transition:all 0.25s ease;
}
.pf-hero-cta svg{width:16px;height:16px;stroke:currentColor;fill:none;stroke-width:2.5;transition:transform 0.3s}
.pf-hero-cta:hover{transform:translateY(-2px);box-shadow:0 8px 24px rgba(0,0,0,0.2)}
.pf-hero-cta:hover svg{transform:translateX(4px)}

/* =========================================
   SECTIONS — Generic
   ========================================= */
.pf-section{padding:88px 0}
.pf-section-sm{padding:64px 0}
.pf-section.bg-white{background:var(--white)}
.pf-section.bg-gray{background:var(--gray-100)}
.pf-section.bg-blue-light{background:var(--pfizer-blue-light)}
.pf-section.bg-indigo{background:var(--pfizer-indigo);color:var(--white)}

/* Section header — Pfizer style */
.pf-sec-header{margin-bottom:48px}
.pf-sec-header h2{
  font-size:2.4rem;
  font-weight:700;
  line-height:1.12;
  color:var(--gray-900);
  letter-spacing:-0.3px;
}
.pf-sec-header.white h2{color:var(--white)}
.pf-sec-header p{
  font-size:1rem;
  color:var(--gray-600);
  margin-top:16px;
  max-width:600px;
  line-height:1.7;
}
.pf-sec-header.white p{color:rgba(255,255,255,0.75)}

/* =========================================
   PILL BUTTONS — Pfizer style
   ========================================= */
.pf-btn{
  display:inline-flex;
  align-items:center;
  gap:8px;
  padding:14px 32px;
  border-radius:var(--radius-pill);
  font-family:'Noto Sans',sans-serif;
  font-weight:700;
  font-size:0.9rem;
  text-decoration:none;
  transition:all 0.25s ease;
  cursor:pointer;
  border:none;
  letter-spacing:0.2px;
}
.pf-btn svg{width:16px;height:16px;stroke:currentColor;fill:none;stroke-width:2.5;transition:transform 0.3s}
.pf-btn:hover svg{transform:translateX(4px)}

.pf-btn-primary{background:var(--pfizer-indigo);color:var(--white)}
.pf-btn-primary:hover{background:var(--pfizer-indigo-dark);transform:translateY(-2px);box-shadow:0 4px 16px rgba(54,67,186,0.3)}

.pf-btn-outline{background:transparent;border:2px solid var(--pfizer-indigo);color:var(--pfizer-indigo)}
.pf-btn-outline:hover{background:var(--pfizer-indigo);color:var(--white);transform:translateY(-2px)}

.pf-btn-white{background:var(--white);color:var(--pfizer-indigo)}
.pf-btn-white:hover{transform:translateY(-2px);box-shadow:0 4px 16px rgba(0,0,0,0.15)}

.pf-btn-text{
  display:inline-flex;align-items:center;gap:6px;
  font-weight:700;font-size:0.9rem;
  color:var(--pfizer-indigo);
  text-decoration:none;
  background:none;border:none;cursor:pointer;padding:0;
  transition:all 0.2s;
}
.pf-btn-text svg{width:18px;height:18px;stroke:currentColor;fill:none;stroke-width:2.5;transition:transform 0.3s}
.pf-btn-text:hover{color:var(--pfizer-indigo-dark)}
.pf-btn-text:hover svg{transform:translateX(4px)}

/* =========================================
   VIDEO + ARTICLES — Two column
   ========================================= */
.pf-media-grid{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:48px;
  align-items:start;
}
.pf-video-card{
  border-radius:12px;
  overflow:hidden;
  background:var(--gray-100);
  position:relative;
  aspect-ratio:16/9;
}
.pf-video-card img{width:100%;height:100%;object-fit:cover}
.pf-video-play{
  position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);
  width:72px;height:72px;border-radius:50%;
  background:rgba(255,255,255,0.9);
  display:flex;align-items:center;justify-content:center;
  cursor:pointer;transition:all 0.3s;
}
.pf-video-play:hover{background:var(--white);transform:translate(-50%,-50%) scale(1.1)}
.pf-video-play svg{width:24px;height:24px;fill:var(--pfizer-indigo);margin-left:3px}
.pf-video-label{
  position:absolute;bottom:20px;left:20px;
  background:var(--pfizer-indigo);
  color:var(--white);
  padding:8px 20px;
  border-radius:var(--radius-pill);
  font-size:0.78rem;
  font-weight:700;
  letter-spacing:0.3px;
}

/* Articles list */
.pf-articles{display:flex;flex-direction:column;gap:0}
.pf-articles-title{
  font-size:0.72rem;
  text-transform:uppercase;
  letter-spacing:3px;
  font-weight:700;
  color:var(--pfizer-indigo);
  margin-bottom:24px;
}
.pf-article-item{
  padding:24px 0;
  border-bottom:1px solid var(--gray-200);
  display:block;
  text-decoration:none;
  color:var(--gray-900);
  transition:all 0.2s;
}
.pf-article-item:first-of-type{border-top:1px solid var(--gray-200)}
.pf-article-item:hover{color:var(--pfizer-indigo)}
.pf-article-item h4{font-size:1rem;font-weight:700;line-height:1.4;margin-bottom:6px;transition:color 0.2s}
.pf-article-item:hover h4{color:var(--pfizer-indigo)}
.pf-article-date{font-size:0.78rem;color:var(--gray-500);font-weight:500}

/* =========================================
   PRODUCTS SECTION — Homepage
   ========================================= */
.pf-products-home{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:48px;
  align-items:start;
}
.pf-products-search{margin-bottom:32px}
.pf-products-search .pf-search-field{
  display:flex;
  gap:12px;
  align-items:center;
}
.pf-products-search input{
  flex:1;
  padding:14px 20px;
  border:2px solid var(--gray-300);
  border-radius:var(--radius-pill);
  font-family:'Noto Sans',sans-serif;
  font-size:0.95rem;
  color:var(--gray-900);
  outline:none;
  transition:border-color 0.2s;
}
.pf-products-search input:focus{border-color:var(--pfizer-indigo)}

.pf-product-list{display:flex;flex-direction:column;gap:0}
.pf-product-link{
  display:flex;
  align-items:center;
  justify-content:space-between;
  padding:16px 0;
  border-bottom:1px solid var(--gray-200);
  text-decoration:none;
  color:var(--gray-900);
  font-weight:600;
  font-size:0.95rem;
  transition:color 0.2s;
}
.pf-product-link:hover{color:var(--pfizer-indigo)}
.pf-product-link svg{width:16px;height:16px;stroke:currentColor;fill:none;stroke-width:2;opacity:0;transform:translateX(-8px);transition:all 0.3s}
.pf-product-link:hover svg{opacity:1;transform:translateX(0)}

/* =========================================
   STATS / PIPELINE CARDS — Pfizer counter row
   ========================================= */
.pf-stats-row{
  display:grid;
  grid-template-columns:repeat(5,1fr);
  gap:24px;
}
.pf-stat-card{
  background:var(--white);
  border-radius:12px;
  padding:36px 28px;
  text-align:center;
  border:1px solid var(--gray-200);
  transition:all 0.3s;
}
.pf-stat-card:hover{box-shadow:var(--shadow-md);transform:translateY(-4px)}
.pf-stat-num{
  font-size:2.8rem;
  font-weight:700;
  color:var(--pfizer-indigo);
  line-height:1;
  margin-bottom:8px;
  display:block;
}
.pf-stat-label{
  font-size:0.82rem;
  color:var(--gray-600);
  font-weight:500;
  line-height:1.4;
}

/* =========================================
   LEGACY STATS — Navy band with hero stats
   ========================================= */
.pf-legacy-stats{
  position:relative;
  background:linear-gradient(135deg, #141a52 0%, #1B2275 55%, #252d8a 100%);
  color:var(--white);
  padding:104px 0;
  overflow:hidden;
}
.pf-legacy-aura{
  position:absolute;
  inset:0;
  background:
    radial-gradient(circle at 15% 25%, rgba(167,139,250,0.12), transparent 45%),
    radial-gradient(circle at 85% 80%, rgba(124,58,237,0.10), transparent 50%);
  pointer-events:none;
}
.pf-legacy-grid{
  position:relative;
  z-index:1;
  display:grid;
  grid-template-columns:0.85fr 1.15fr;
  gap:88px;
  align-items:center;
}
.pf-legacy-eyebrow{
  display:inline-block;
  font-size:0.72rem;
  font-weight:700;
  text-transform:uppercase;
  letter-spacing:2.5px;
  color:#C4B5FD;
  margin-bottom:20px;
}
.pf-legacy-intro h2{
  font-size:2.75rem;
  font-weight:300;
  line-height:1.12;
  color:var(--white);
  margin-bottom:28px;
  letter-spacing:-0.02em;
}
.pf-legacy-intro h2 em{
  display:inline;
  font-style:normal;
  font-weight:700;
  color:#C4B5FD;
  background:linear-gradient(120deg, #C4B5FD 0%, #DDD6FE 100%);
  -webkit-background-clip:text;
  background-clip:text;
  -webkit-text-fill-color:transparent;
}
.pf-legacy-intro p{
  font-size:1rem;
  line-height:1.7;
  color:rgba(255,255,255,0.72);
  max-width:440px;
}
.pf-legacy-intro p strong{
  color:var(--white);
  font-weight:600;
}
.pf-legacy-stats-grid{
  display:grid;
  grid-template-columns:repeat(2,1fr);
  gap:52px 44px;
}
.pf-legacy-stat{
  display:grid;
  grid-template-columns:auto 1fr;
  gap:20px;
  align-items:start;
}
.pf-legacy-num{
  font-size:4rem;
  font-weight:700;
  line-height:0.95;
  color:#C4B5FD;
  letter-spacing:-0.035em;
  white-space:nowrap;
  font-feature-settings:"tnum";
}
.pf-legacy-num sup{
  font-size:0.5em;
  font-weight:600;
  margin-left:2px;
  top:-0.65em;
  position:relative;
  color:#C4B5FD;
}
.pf-legacy-cap{
  font-size:0.9rem;
  line-height:1.5;
  color:rgba(255,255,255,0.78);
  padding-top:10px;
  font-weight:400;
}

@media(max-width:1024px){
  .pf-legacy-stats{padding:80px 0}
  .pf-legacy-grid{grid-template-columns:1fr;gap:56px}
  .pf-legacy-intro p{max-width:640px}
  .pf-legacy-intro h2{font-size:2.4rem}
}
@media(max-width:768px){
  .pf-legacy-stats{padding:64px 0}
  .pf-legacy-intro h2{font-size:2rem;margin-bottom:20px}
  .pf-legacy-eyebrow{margin-bottom:14px;font-size:0.68rem;letter-spacing:2px}
  .pf-legacy-num{font-size:3.1rem}
  .pf-legacy-stats-grid{gap:36px 28px}
  .pf-legacy-cap{font-size:0.84rem}
}
@media(max-width:520px){
  .pf-legacy-stats-grid{grid-template-columns:1fr;gap:32px}
  .pf-legacy-stat{gap:16px}
  .pf-legacy-num{font-size:2.8rem}
}

/* =========================================
   BRAND DNA — 3-card showcase
   ========================================= */
.pf-brand-dna{
  position:relative;
  overflow:hidden;
  isolation:isolate;
}
.pf-dna-bg{
  position:absolute;
  inset:-10% 0 -10% 0;
  z-index:0;
  pointer-events:none;
}
.pf-dna-bg .container,
.pf-brand-dna .container{position:relative;z-index:1}
.pf-dna-layer{
  position:absolute;
  inset:0;
  will-change:transform;
}
/* Wavy background — Aceternity-style flowing waves */
.pf-dna-waves{
  position:absolute;
  inset:0;
  width:100%;
  height:100%;
  display:block;
  pointer-events:none;
  opacity:0.85;
  will-change:transform;
}

.pf-brand-dna-head{
  display:grid;
  grid-template-columns:1fr auto;
  gap:56px;
  align-items:center;
  text-align:left;
  max-width:980px;
  margin:0 auto 64px;
}
.pf-brand-dna-text{max-width:560px}
.pf-dna-eq{
  width:180px;
  height:260px;
  background:var(--white);
  border-radius:14px;
  padding:10px;
  box-shadow:0 14px 40px rgba(54,67,186,0.12);
  flex-shrink:0;
  position:relative;
  overflow:hidden;
}
.pf-dna-eq-canvas{
  width:100%;
  height:100%;
  display:block;
  border-radius:4px;
}
.pf-dna-eq-logo-wrap{
  position:absolute;
  left:50%;
  bottom:16px;
  transform:translateX(-50%);
  width:76%;
  background:var(--white);
  padding:2px 8px;
  z-index:2;
  pointer-events:none;
  display:flex;
  align-items:center;
  justify-content:center;
}
.pf-dna-eq-logo{
  width:100%;
  height:auto;
  display:block;
  user-select:none;
}
@media(max-width:820px){
  .pf-brand-dna-head{
    grid-template-columns:1fr;
    gap:32px;
    text-align:center;
  }
  .pf-brand-dna-text{max-width:100%;margin:0 auto}
  .pf-dna-eq{margin:0 auto;width:150px;height:216px;padding:9px}
  .pf-dna-eq-logo-wrap{bottom:13px;width:80%;padding:2px 8px;border:none;border-radius:0}
}
@media(max-width:480px){
  .pf-dna-eq{width:130px;height:186px;padding:8px}
  .pf-dna-eq-logo-wrap{bottom:11px;width:82%;padding:2px 6px;border:none;border-radius:0}
}
.pf-brand-dna-eyebrow{
  display:inline-block;
  font-size:0.72rem;
  font-weight:700;
  text-transform:uppercase;
  letter-spacing:2.5px;
  color:var(--pfizer-indigo);
  margin-bottom:18px;
}
.pf-brand-dna-head h2{
  font-size:3.6rem;
  font-weight:800;
  line-height:1.05;
  color:var(--gray-900);
  letter-spacing:-0.03em;
  margin-bottom:20px;
}
.pf-brand-dna-head h2 em{
  font-style:normal;
  background:linear-gradient(120deg, var(--pfizer-indigo) 0%, #7C3AED 100%);
  -webkit-background-clip:text;
  background-clip:text;
  -webkit-text-fill-color:transparent;
}
.pf-brand-dna-head p{
  font-size:1.05rem;
  line-height:1.6;
  color:var(--gray-600);
}

.pf-brand-dna-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:28px;
}
.pf-dna-card{
  position:relative;
  display:block;
  text-decoration:none;
  color:inherit;
  border-radius:16px;
  transition:transform 0.4s ease, box-shadow 0.4s ease;
}
.pf-dna-card-inner{
  position:relative;
  display:flex;
  flex-direction:column;
  background:var(--white);
  border:1px solid var(--gray-200);
  border-radius:16px;
  overflow:hidden;
  height:100%;
  transition:border-color 0.4s ease;
}
.pf-dna-card:hover{
  transform:translateY(-6px);
  box-shadow:0 18px 40px rgba(27,34,117,0.12);
}
.pf-dna-card:hover .pf-dna-card-inner{
  border-color:transparent;
}

.pf-dna-card-media{
  position:relative;
  aspect-ratio:4/3;
  background:
    linear-gradient(135deg, rgba(54,67,186,0.06) 0%, rgba(124,58,237,0.08) 100%),
    repeating-linear-gradient(45deg, rgba(54,67,186,0.04) 0 12px, transparent 12px 24px);
  display:flex;
  align-items:center;
  justify-content:center;
  border-bottom:1px solid var(--gray-200);
  overflow:hidden;
}
.pf-dna-card-media img{
  width:100%;
  height:100%;
  object-fit:cover;
  display:block;
  transition:transform 0.6s ease;
}
.pf-dna-card:hover .pf-dna-card-media img{
  transform:scale(1.04);
}
.pf-dna-card-placeholder{
  font-size:0.72rem;
  font-weight:600;
  text-transform:uppercase;
  letter-spacing:2px;
  color:var(--gray-500);
}
.pf-dna-card-body{
  padding:28px 28px 36px;
  display:flex;
  flex-direction:column;
  gap:14px;
  flex:1;
}
/* Footer row — Explore link on left, brand logo on right */
.pf-dna-card-footer{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:16px;
  margin-top:auto;
  padding-top:18px;
  border-top:1px solid var(--gray-200);
}
.pf-dna-card-footer .pf-btn-text{
  flex-shrink:0;
}
.pf-dna-card-logo{
  display:flex;
  align-items:center;
  justify-content:flex-end;
  flex-shrink:1;
  min-width:0;
}
.pf-dna-card-logo img{
  width:auto;
  height:auto;
  object-fit:contain;
  display:block;
}
.pf-dna-card-logo > img{
  max-height:44px;
  max-width:100%;
}
.pf-dna-card-logo-duo{
  flex-direction:column;
  align-items:flex-end;
  gap:8px;
}
.pf-dna-card-logo-duo img{
  max-height:40px;
  max-width:100%;
  flex:0 1 auto;
}
.pf-dna-card-tag{
  font-size:0.82rem;
  font-weight:700;
  text-transform:uppercase;
  letter-spacing:2px;
  color:var(--pfizer-indigo);
}
.pf-dna-card-body h3{
  font-size:1.35rem;
  font-weight:700;
  line-height:1.25;
  color:var(--gray-900);
  margin:0;
}
.pf-dna-card-body p{
  font-size:0.92rem;
  line-height:1.6;
  color:var(--gray-600);
  margin:0;
  flex:1;
}
.pf-dna-card-body .pf-btn-text{
  margin-top:8px;
}

@media(max-width:1024px){
  .pf-brand-dna-grid{grid-template-columns:repeat(2,1fr)}
  .pf-brand-dna-head h2{font-size:3rem}
}
@media(max-width:768px){
  .pf-brand-dna-head{margin-bottom:44px}
  .pf-brand-dna-head h2{font-size:2.4rem}
  .pf-brand-dna-head p{font-size:0.95rem}
  .pf-brand-dna-grid{grid-template-columns:1fr;gap:20px}
}

/* =========================================
   NEW ERA SOLUTIONS — Dark parallax section
   ========================================= */
.pf-new-era{
  position:relative;
  padding:120px 0;
  background:linear-gradient(180deg, #0E1145 0%, #1B1F6B 45%, #2A1F7A 100%);
  color:var(--white);
  overflow:hidden;
  isolation:isolate;
}
.pf-new-era-bg{
  position:absolute;
  inset:-15% 0 -15% 0;
  z-index:-1;
  pointer-events:none;
  will-change:transform;
}
/* One soft atmospheric orb beneath the vortex for base depth */
.pf-ne-orb{
  position:absolute;
  border-radius:50%;
  filter:blur(110px);
  mix-blend-mode:screen;
  pointer-events:none;
}
.pf-ne-orb-1{
  width:720px;height:720px;
  left:50%;top:50%;
  transform:translate(-50%,-50%);
  opacity:0.45;
  background:radial-gradient(circle, #7C3AED 0%, rgba(124,58,237,0) 70%);
}

/* Vortex canvas — vanilla JS particle swirl */
.pf-ne-vortex{
  position:absolute;
  inset:0;
  width:100%;
  height:100%;
  pointer-events:none;
  opacity:0.75;
  will-change:transform;
}

/* Heading */
.pf-new-era-head{
  text-align:center;
  max-width:760px;
  margin:0 auto 72px;
  position:relative;
}
.pf-new-era-eyebrow{
  display:inline-block;
  font-size:0.72rem;
  font-weight:700;
  text-transform:uppercase;
  letter-spacing:2.8px;
  color:#C4B5FD;
  margin-bottom:20px;
  padding:6px 16px;
  border:1px solid rgba(196,181,253,0.35);
  border-radius:999px;
  background:rgba(196,181,253,0.08);
  backdrop-filter:blur(8px);
  -webkit-backdrop-filter:blur(8px);
}
.pf-new-era-head h2{
  font-size:3.8rem;
  font-weight:800;
  line-height:1.05;
  letter-spacing:-0.03em;
  color:var(--white);
  margin-bottom:22px;
}
.pf-new-era-head h2 em{
  font-style:normal;
  background:linear-gradient(120deg, #C4B5FD 0%, #DDD6FE 50%, #A78BFA 100%);
  -webkit-background-clip:text;
  background-clip:text;
  -webkit-text-fill-color:transparent;
}
.pf-new-era-head p{
  font-size:1.05rem;
  line-height:1.6;
  color:rgba(255,255,255,0.72);
}

/* Grid + glass cards */
.pf-new-era-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:28px;
  position:relative;
}
.pf-ne-card{
  display:flex;
  flex-direction:column;
  background:linear-gradient(160deg, rgba(255,255,255,0.08) 0%, rgba(255,255,255,0.02) 100%);
  border:1px solid rgba(255,255,255,0.12);
  border-radius:18px;
  overflow:hidden;
  text-decoration:none;
  color:inherit;
  backdrop-filter:blur(14px) saturate(140%);
  -webkit-backdrop-filter:blur(14px) saturate(140%);
  transition:transform 0.4s ease, border-color 0.4s ease, box-shadow 0.4s ease;
}
.pf-ne-card:hover{
  transform:translateY(-6px);
  border-color:rgba(196,181,253,0.45);
  box-shadow:0 22px 60px rgba(124,58,237,0.25);
}
.pf-ne-card-media{
  position:relative;
  aspect-ratio:4/3;
  background:
    radial-gradient(circle at 30% 30%, rgba(167,139,250,0.25) 0%, transparent 55%),
    radial-gradient(circle at 75% 70%, rgba(99,102,241,0.22) 0%, transparent 60%),
    linear-gradient(135deg, rgba(14,17,69,0.7) 0%, rgba(42,31,122,0.7) 100%);
  display:flex;
  align-items:center;
  justify-content:center;
  border-bottom:1px solid rgba(255,255,255,0.08);
  overflow:hidden;
}
.pf-ne-card-media img{
  width:100%;height:100%;
  object-fit:cover;
  display:block;
  transition:transform 0.6s ease;
}
.pf-ne-card:hover .pf-ne-card-media img{transform:scale(1.04)}
.pf-ne-card-placeholder{
  font-size:0.7rem;
  font-weight:600;
  text-transform:uppercase;
  letter-spacing:2.5px;
  color:rgba(196,181,253,0.7);
}
.pf-ne-card-body{
  padding:30px 28px 36px;
  display:flex;
  flex-direction:column;
  gap:14px;
  flex:1;
}
.pf-ne-card-tag{
  font-size:0.68rem;
  font-weight:700;
  text-transform:uppercase;
  letter-spacing:2.2px;
  color:#C4B5FD;
}
.pf-ne-card-body h3{
  font-size:1.55rem;
  font-weight:700;
  line-height:1.2;
  color:var(--white);
  margin:0;
  letter-spacing:-0.01em;
}
.pf-ne-card-body p{
  font-size:0.93rem;
  line-height:1.6;
  color:rgba(255,255,255,0.72);
  margin:0;
  flex:1;
}
.pf-ne-card-more{
  display:inline-block;
  font-size:0.78rem;
  font-weight:500;
  line-height:1.4;
  color:rgba(196,181,253,0.7);
  letter-spacing:0.01em;
  padding-top:2px;
  padding-bottom:4px;
  border-top:1px dashed rgba(196,181,253,0.2);
  margin-top:4px;
}
.pf-ne-card-body .pf-btn-text{
  color:#C4B5FD;
  margin-top:6px;
}
.pf-ne-card-body .pf-btn-text:hover{color:#DDD6FE}
.pf-ne-card-body .pf-btn-text svg{stroke:#C4B5FD}

@media(max-width:1024px){
  .pf-new-era{padding:96px 0}
  .pf-new-era-grid{grid-template-columns:repeat(2,1fr)}
  .pf-new-era-head h2{font-size:3rem}
}
@media(max-width:768px){
  .pf-new-era{padding:72px 0}
  .pf-new-era-head{margin-bottom:48px}
  .pf-new-era-head h2{font-size:2.3rem}
  .pf-new-era-head p{font-size:0.95rem}
  .pf-new-era-grid{grid-template-columns:1fr;gap:20px}
  .pf-ne-orb{filter:blur(60px)}
}
@media(prefers-reduced-motion:reduce){
  .pf-ne-orb,.pf-ne-particles circle{animation:none !important}
}

/* =========================================
   AREAS OF FOCUS — Horizontal scroll carousel
   ========================================= */
/* Focus section animated background */
.pf-focus-section{
  position:relative;
  overflow:hidden;
  background:linear-gradient(135deg,#EEF0FB 0%,#F5F3FF 25%,#EDF6FF 50%,#F0FDF4 75%,#EEF0FB 100%);
  background-size:400% 400%;
  animation:focusBgShift 12s ease infinite;
}
@keyframes focusBgShift{
  0%{background-position:0% 50%}
  50%{background-position:100% 50%}
  100%{background-position:0% 50%}
}
/* Floating orbs */
.pf-focus-section::before,
.pf-focus-section::after{
  content:'';
  position:absolute;
  border-radius:50%;
  opacity:0.12;
  pointer-events:none;
  z-index:0;
}
.pf-focus-section::before{
  width:400px;height:400px;
  background:radial-gradient(circle,var(--pfizer-indigo),transparent 70%);
  top:-100px;right:-80px;
  animation:focusOrb1 8s ease-in-out infinite;
}
.pf-focus-section::after{
  width:300px;height:300px;
  background:radial-gradient(circle,#7C3AED,transparent 70%);
  bottom:-60px;left:-40px;
  animation:focusOrb2 10s ease-in-out infinite;
}
@keyframes focusOrb1{
  0%,100%{transform:translate(0,0) scale(1)}
  50%{transform:translate(-60px,40px) scale(1.15)}
}
@keyframes focusOrb2{
  0%,100%{transform:translate(0,0) scale(1)}
  50%{transform:translate(50px,-30px) scale(1.1)}
}
/* Animated vector globe */
.pf-globe-wrap{
  position:absolute;
  top:50%;right:-5%;
  transform:translateY(-50%);
  width:620px;height:620px;
  pointer-events:none;
  z-index:0;
  opacity:0.7;
}
.pf-globe-svg{
  width:100%;height:100%;
  animation:globeSpin 60s linear infinite;
}
@keyframes globeSpin{
  0%{transform:rotate(0deg)}
  100%{transform:rotate(360deg)}
}
.pf-globe-lines{
  animation:globePulse 8s ease-in-out infinite;
}
@keyframes globePulse{
  0%,100%{opacity:1}
  50%{opacity:0.6}
}
.pf-globe-continents{
  animation:continentDrift 20s ease-in-out infinite alternate;
}
@keyframes continentDrift{
  0%{transform:translateX(0)}
  100%{transform:translateX(15px)}
}
@media(max-width:768px){
  .pf-globe-wrap{
    width:380px;height:380px;
    right:50%;top:50%;
    transform:translate(50%,-50%);
    opacity:0.55;
  }
}
@media(max-width:480px){
  .pf-globe-wrap{
    width:320px;height:320px;
    right:50%;top:50%;
    transform:translate(50%,-50%);
    opacity:0.5;
  }
}
.pf-focus-section .container{position:relative;z-index:1}

/* Carousel scroll indicator dots */
.pf-carousel-dots{
  display:flex;
  justify-content:center;
  gap:8px;
  margin-top:20px;
}
.pf-carousel-dots .dot{
  width:10px;height:10px;
  border-radius:50%;
  background:var(--gray-300);
  border:none;
  cursor:pointer;
  padding:0;
  transition:all 0.3s;
}
.pf-carousel-dots .dot.active{
  background:var(--pfizer-indigo);
  width:28px;
  border-radius:5px;
}

/* Mobile-only carousel overlay arrows */
.pf-carousel-mob-nav{
  display:none;
  position:absolute;
  top:50%;transform:translateY(-50%);
  z-index:5;
}
.pf-carousel-mob-nav.left{left:4px}
.pf-carousel-mob-nav.right{right:4px}
.pf-carousel-mob-nav .pf-mob-arrow{
  width:36px;height:36px;
  border-radius:50%;
  border:none;
  background:rgba(255,255,255,0.85);
  backdrop-filter:blur(4px);
  box-shadow:0 2px 8px rgba(0,0,0,0.15);
  display:flex;align-items:center;justify-content:center;
  cursor:pointer;
  transition:all 0.2s;
}
.pf-carousel-mob-nav .pf-mob-arrow:active{
  background:var(--pfizer-indigo);
}
.pf-carousel-mob-nav .pf-mob-arrow:active svg{stroke:#fff}
.pf-carousel-mob-nav .pf-mob-arrow svg{
  width:18px;height:18px;stroke:var(--gray-700);fill:none;stroke-width:2.5;
}

.pf-carousel-wrap{position:relative}
.pf-carousel{
  display:flex;
  gap:24px;
  overflow-x:auto;
  scroll-snap-type:x mandatory;
  scroll-behavior:smooth;
  -webkit-overflow-scrolling:touch;
  padding:8px 0 16px;
  scrollbar-width:none;
}
.pf-carousel::-webkit-scrollbar{display:none}
.pf-carousel-card{
  flex:0 0 320px;
  scroll-snap-align:start;
  border-radius:16px;
  overflow:hidden;
  background:var(--white);
  border:1px solid var(--gray-200);
  transition:all 0.3s;
  text-decoration:none;
  color:var(--gray-900);
  display:flex;
  flex-direction:column;
}
.pf-carousel-card:hover{box-shadow:var(--shadow-md);transform:translateY(-4px)}
.pf-carousel-img{
  height:200px;
  overflow:hidden;
  position:relative;
}
.pf-carousel-img img{width:100%;height:100%;object-fit:cover;transition:transform 0.5s}
.pf-carousel-card:hover .pf-carousel-img img{transform:scale(1.05)}
/* Abstract art gradient fallback for cards without images */
.pf-carousel-img.abstract-1{background:linear-gradient(135deg,#5C6BC0 0%,#7E57C2 50%,#AB47BC 100%)}
.pf-carousel-img.abstract-2{background:linear-gradient(135deg,#26A69A 0%,#00897B 50%,#00695C 100%)}
.pf-carousel-img.abstract-3{background:linear-gradient(135deg,#FFA726 0%,#FF7043 50%,#E53935 100%)}
.pf-carousel-img.abstract-4{background:linear-gradient(135deg,#42A5F5 0%,#1E88E5 50%,#1565C0 100%)}
.pf-carousel-img.abstract-5{background:linear-gradient(135deg,#66BB6A 0%,#43A047 50%,#2E7D32 100%)}
.pf-carousel-img.abstract-6{background:linear-gradient(135deg,#EC407A 0%,#D81B60 50%,#AD1457 100%)}
.pf-carousel-body{padding:24px;flex:1;display:flex;flex-direction:column}
.pf-carousel-body h4{font-size:1.05rem;font-weight:700;margin-bottom:8px}
.pf-carousel-body p{font-size:0.85rem;color:var(--gray-600);line-height:1.6;flex:1}
.pf-carousel-body .pf-btn-text{margin-top:16px}

/* Carousel arrows */
.pf-carousel-nav{
  position:absolute;top:50%;
  transform:translateY(-50%);
  display:flex;gap:8px;
  z-index:5;
}
.pf-carousel-nav.left{left:-20px}
.pf-carousel-nav.right{right:-20px}
.pf-arrow{
  width:48px;height:48px;
  border-radius:50%;
  background:var(--white);
  border:1px solid var(--gray-300);
  display:flex;align-items:center;justify-content:center;
  cursor:pointer;
  transition:all 0.2s;
  box-shadow:var(--shadow-sm);
}
.pf-arrow:hover{background:var(--pfizer-indigo);border-color:var(--pfizer-indigo)}
.pf-arrow:hover svg{stroke:var(--white)}
.pf-arrow svg{width:20px;height:20px;stroke:var(--gray-700);fill:none;stroke-width:2}

/* =========================================
   ABOUT TEASER — Large text + CTA
   ========================================= */
.pf-about-teaser{
  max-width:800px;
}
.pf-about-teaser h2{
  font-size:2.6rem;
  font-weight:700;
  line-height:1.15;
  margin-bottom:24px;
  color:var(--gray-900);
}
.pf-about-teaser p{
  font-size:1.05rem;
  color:var(--gray-600);
  line-height:1.75;
  margin-bottom:32px;
  max-width:640px;
}

/* =========================================
   BLUE BAND / ACCORD SECTION
   ========================================= */
.pf-blue-band{
  padding:80px 0;
  background:var(--pfizer-indigo);
  color:var(--white);
  overflow:hidden;
  position:relative;
}
.pf-blue-band-inner{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:64px;
  align-items:center;
}
.pf-blue-band h2{font-size:2.2rem;font-weight:700;color:var(--white);margin-bottom:16px}
.pf-blue-band p{color:rgba(255,255,255,0.8);font-size:1rem;line-height:1.7;margin-bottom:28px}
.pf-blue-band-img{
  border-radius:16px;
  overflow:hidden;
  position:relative;
}
.pf-blue-band-img img{width:100%;height:100%;object-fit:cover}
.pf-blue-band-img.abstract{
  background:linear-gradient(135deg,rgba(255,255,255,0.1) 0%,rgba(255,255,255,0.05) 100%);
  min-height:300px;
  display:flex;align-items:center;justify-content:center;
}

/* =========================================
   CONTACT FORM — Get in Touch (index page)
   ========================================= */
.pf-contact-section{background:var(--white)}
.pf-contact-inner{
  display:grid;
  grid-template-columns:1.05fr 1fr;
  gap:72px;
  align-items:center;
}
.pf-contact-eyebrow{
  display:inline-block;
  font-size:0.72rem;
  font-weight:700;
  text-transform:uppercase;
  letter-spacing:2.5px;
  color:var(--pfizer-indigo);
  margin-bottom:16px;
}
.pf-contact-form-wrap > h2{
  font-size:2.4rem;
  font-weight:800;
  line-height:1.1;
  color:var(--gray-900);
  margin-bottom:12px;
  letter-spacing:-0.02em;
}
.pf-contact-form-wrap > p{
  font-size:0.98rem;
  color:var(--gray-600);
  margin-bottom:36px;
  max-width:520px;
}
.pf-contact-form{
  display:flex;
  flex-direction:column;
  gap:28px;
}
.pf-cf-row{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:32px;
}
.pf-cf-field{
  display:flex;
  flex-direction:column;
  position:relative;
  min-width:0;
}
.pf-cf-field label{
  font-size:0.7rem;
  font-weight:700;
  text-transform:uppercase;
  letter-spacing:2px;
  color:var(--pfizer-indigo);
  margin-bottom:10px;
}
.pf-cf-req{
  color:#D32F2F;
  margin-left:4px;
  font-size:0.85rem;
  vertical-align:middle;
  letter-spacing:0;
}
.pf-cf-field input,
.pf-cf-field select,
.pf-cf-field textarea{
  font-family:'Noto Sans',sans-serif;
  font-size:0.95rem;
  color:var(--gray-900);
  border:none;
  border-bottom:1px solid var(--gray-300);
  padding:8px 0;
  background:transparent;
  outline:none;
  transition:border-color 0.3s;
  width:100%;
  border-radius:0;
}
.pf-cf-field input:focus,
.pf-cf-field select:focus,
.pf-cf-field textarea:focus{
  border-bottom-color:var(--pfizer-indigo);
}
.pf-cf-field input::placeholder,
.pf-cf-field textarea::placeholder{
  color:var(--gray-400);
}
.pf-cf-field input:disabled{
  color:var(--gray-400);
  background:transparent;
  cursor:not-allowed;
  opacity:0.75;
}
.pf-cf-field input:disabled::placeholder{
  color:var(--gray-400);
  font-style:italic;
}

/* Phone field — split prefix chip + number input */
.pf-cf-phone-wrap{
  display:flex;
  align-items:center;
  gap:12px;
  border-bottom:1px solid var(--gray-300);
  padding:8px 0;
  transition:border-color 0.3s;
}
.pf-cf-phone-wrap:focus-within{border-bottom-color:var(--pfizer-indigo)}
.pf-cf-phone-wrap:has(input:disabled){
  border-bottom-style:dashed;
  border-bottom-color:var(--gray-200);
  opacity:0.75;
}
.pf-cf-phone-code{
  font-family:'Noto Sans',sans-serif;
  font-size:0.95rem;
  font-weight:500;
  color:var(--gray-900);
  min-width:30px;
  flex-shrink:0;
  padding-right:12px;
  border-right:1px solid var(--gray-300);
  font-variant-numeric:tabular-nums;
  user-select:none;
}
.pf-cf-phone-wrap:has(input:disabled) .pf-cf-phone-code{
  color:var(--gray-400);
}
.pf-cf-phone-wrap input{
  border-bottom:none !important;
  padding:0 !important;
  flex:1;
  min-width:0;
  opacity:1 !important;
}
.pf-cf-field.has-error .pf-cf-phone-wrap{
  border-bottom-color:#D32F2F;
}
.pf-cf-field select{
  cursor:pointer;
  padding-right:28px;
  appearance:none;
  -webkit-appearance:none;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23757575' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'><path d='M6 9l6 6 6-6'/></svg>");
  background-repeat:no-repeat;
  background-position:right 0 center;
  background-size:16px 16px;
  color:var(--gray-900);
}
.pf-cf-field select:invalid{color:var(--gray-400)}
.pf-cf-field textarea{
  resize:vertical;
  min-height:48px;
  line-height:1.5;
}
.pf-cf-full{grid-column:1 / -1}
.pf-cf-error{
  display:none;
  color:#D32F2F;
  font-size:0.78rem;
  margin-top:8px;
  font-weight:500;
}
.pf-cf-field.has-error input,
.pf-cf-field.has-error select,
.pf-cf-field.has-error textarea{border-bottom-color:#D32F2F}
.pf-cf-field.has-error .pf-cf-error{display:block}
.pf-cf-submit{
  align-self:flex-start;
  margin-top:8px;
  background:var(--pfizer-indigo);
  color:var(--white);
  border:none;
  padding:16px 44px;
  font-family:'Noto Sans',sans-serif;
  font-size:0.78rem;
  font-weight:700;
  letter-spacing:2.5px;
  text-transform:uppercase;
  cursor:pointer;
  transition:background 0.25s ease, transform 0.25s ease, box-shadow 0.25s ease;
  border-radius:2px;
}
.pf-cf-submit:hover{
  background:var(--pfizer-indigo-dark);
  transform:translateY(-2px);
  box-shadow:0 8px 22px rgba(54,67,186,0.28);
}
.pf-contact-image{
  border-radius:16px;
  overflow:hidden;
  aspect-ratio:4/5;
  background:linear-gradient(135deg, var(--gray-100), var(--gray-200));
  position:relative;
}
.pf-contact-image img{
  width:100%;
  height:100%;
  object-fit:cover;
  display:block;
}
@media(max-width:960px){
  .pf-contact-inner{
    grid-template-columns:1fr;
    gap:48px;
  }
  .pf-contact-image{aspect-ratio:16/10}
  .pf-contact-form-wrap > h2{font-size:2rem}
}
@media(max-width:600px){
  .pf-cf-row{grid-template-columns:1fr;gap:24px}
  .pf-contact-form{gap:24px}
}

/* =========================================
   FOOTER — Pfizer style: White bg, structured
   ========================================= */
.pf-footer{
  background:var(--white);
  border-top:1px solid var(--gray-200);
  padding:64px 0 32px;
}
.pf-footer-top{
  display:grid;
  grid-template-columns:2fr 1fr 1fr 1fr 1.5fr;
  gap:40px;
  padding-bottom:48px;
  border-bottom:1px solid var(--gray-200);
}
.pf-footer-logo-group{display:flex;flex-direction:column;align-items:center;margin-bottom:16px}
.pf-footer-brand img{height:36px;width:auto;margin-bottom:6px}
.pf-footer-tagline{display:block;font-size:0.55rem;color:var(--gray-400);text-transform:uppercase;letter-spacing:1.5px;font-weight:600}
.pf-footer-brand p{font-size:0.82rem;color:var(--gray-500);line-height:1.7;max-width:280px}
.pf-footer h4{
  font-size:0.7rem;
  text-transform:uppercase;
  letter-spacing:2.5px;
  font-weight:700;
  color:var(--gray-900);
  margin-bottom:18px;
}
.pf-footer ul li{margin-bottom:10px}
.pf-footer ul a{
  font-size:0.85rem;
  color:var(--gray-600);
  text-decoration:none;
  transition:color 0.2s;
}
.pf-footer ul a:hover{color:var(--pfizer-indigo)}
.pf-footer-social{display:flex;gap:12px;margin-top:20px}
.pf-footer-social a{
  width:36px;height:36px;
  border-radius:50%;
  border:1px solid var(--gray-300);
  display:flex;align-items:center;justify-content:center;
  transition:all 0.2s;
}
.pf-footer-social a:hover{background:var(--pfizer-indigo);border-color:var(--pfizer-indigo)}
.pf-footer-social a:hover svg{fill:var(--white)}
.pf-footer-social a svg{width:16px;height:16px;fill:var(--gray-600)}

.pf-footer-bottom{
  padding-top:24px;
  display:flex;
  justify-content:space-between;
  align-items:center;
  font-size:0.75rem;
  color:var(--gray-400);
}
.pf-footer-legal{display:flex;gap:24px;flex-wrap:wrap}
.pf-footer-legal a{color:var(--gray-500);text-decoration:none;transition:color 0.2s}
.pf-footer-legal a:hover{color:var(--pfizer-indigo)}

/* =========================================
   PAGE HERO — Inner pages (abstract art bg)
   ========================================= */
.pf-page-hero{
  padding:64px 0 48px;
  position:relative;
  overflow:hidden;
  min-height:280px;
  display:flex;
  align-items:flex-end;
}
.pf-page-hero-bg{
  position:absolute;inset:0;z-index:0;
}
.pf-page-hero-bg.abstract-warm{background:linear-gradient(135deg,#FFF3E0 0%,#FFE0B2 30%,#FFCC80 60%,#FFB74D 100%)}
.pf-page-hero-bg.abstract-cool{background:linear-gradient(135deg,#E8EAF6 0%,#C5CAE9 30%,#9FA8DA 60%,#7986CB 100%)}
.pf-page-hero-bg.abstract-teal{background:linear-gradient(135deg,#E0F2F1 0%,#B2DFDB 30%,#80CBC4 60%,#4DB6AC 100%)}
.pf-page-hero-content{
  position:relative;z-index:1;
  max-width:var(--max-width);
  margin:0 auto;
  padding:0 48px;
  width:100%;
}
.pf-page-hero-content h1{
  font-size:3rem;
  font-weight:700;
  color:var(--gray-900);
  margin-bottom:12px;
}
.pf-breadcrumb{
  font-size:0.82rem;
  color:var(--gray-500);
  margin-bottom:16px;
}
.pf-breadcrumb a{color:var(--pfizer-indigo);text-decoration:none;font-weight:600;transition:color 0.2s}
.pf-breadcrumb a:hover{color:var(--pfizer-indigo-dark)}
.pf-breadcrumb span{margin:0 8px;color:var(--gray-400)}

/* =========================================
   PRODUCTS PAGE — Category Filter Bar
   ========================================= */
.pf-filter-label{
  font-size:0.82rem;
  font-weight:700;
  text-transform:uppercase;
  letter-spacing:1.5px;
  color:var(--gray-500);
  margin-right:4px;
}
.pf-filter-pill{
  display:inline-flex;
  align-items:center;
  padding:8px 20px;
  border-radius:var(--radius-pill);
  border:2px solid var(--gray-300);
  background:var(--white);
  color:var(--gray-700);
  font-family:'Noto Sans',sans-serif;
  font-size:0.82rem;
  font-weight:600;
  cursor:pointer;
  transition:all 0.2s ease;
  white-space:nowrap;
}
.pf-filter-pill:hover{
  border-color:var(--pfizer-indigo);
  color:var(--pfizer-indigo);
  background:rgba(54,67,186,0.04);
}
.pf-filter-pill.active{
  background:var(--pfizer-indigo);
  border-color:var(--pfizer-indigo);
  color:var(--white);
}
.pf-filter-pill.active:hover{
  background:var(--pfizer-indigo-dark);
  border-color:var(--pfizer-indigo-dark);
  color:var(--white);
}
.pf-filter-count{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-width:22px;
  height:22px;
  padding:0 6px;
  border-radius:11px;
  background:rgba(0,0,0,0.08);
  font-size:0.7rem;
  font-weight:700;
  margin-left:6px;
}
.pf-filter-pill.active .pf-filter-count{
  background:rgba(255,255,255,0.25);
}
.pf-no-results{
  text-align:center;
  padding:64px 24px;
  color:var(--gray-500);
  font-size:1rem;
}
.pf-no-results svg{
  width:48px;height:48px;stroke:var(--gray-400);fill:none;stroke-width:1.5;margin-bottom:16px;
}

/* =========================================
   PRODUCTS PAGE — A-Z listing with search
   ========================================= */
.pf-products-layout{
  display:grid;
  grid-template-columns:1fr 56px;
  gap:32px;
  align-items:start;
}
.pf-products-main{flex:1}
.pf-products-search-bar{margin-bottom:40px}
.pf-search-row{
  display:flex;
  align-items:center;
  gap:12px;
  max-width:540px;
}
.pf-search-row input{
  flex:1;
  padding:14px 20px 14px 48px;
  border:2px solid var(--gray-300);
  border-radius:var(--radius-pill);
  font-family:'Noto Sans',sans-serif;
  font-size:0.95rem;
  color:var(--gray-900);
  outline:none;
  transition:border-color 0.2s;
  background:var(--white) url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='18' height='18' viewBox='0 0 24 24' fill='none' stroke='%239E9E9E' stroke-width='2'%3E%3Ccircle cx='11' cy='11' r='8'/%3E%3Cpath d='m21 21-4.3-4.3'/%3E%3C/svg%3E") 16px center no-repeat;
}
.pf-search-row input:focus{border-color:var(--pfizer-indigo)}

/* Filter icon button */
.pf-filter-toggle{
  position:relative;
  width:50px;height:50px;
  border-radius:50%;
  border:2px solid var(--gray-300);
  background:var(--white);
  cursor:pointer;
  display:flex;align-items:center;justify-content:center;
  transition:all 0.2s;
  flex-shrink:0;
}
.pf-filter-toggle:hover{
  border-color:var(--pfizer-indigo);
  background:rgba(54,67,186,0.04);
}
.pf-filter-toggle.has-filter{
  border-color:var(--pfizer-indigo);
  background:var(--pfizer-indigo);
}
.pf-filter-toggle.has-filter svg{stroke:var(--white)}
.pf-filter-toggle svg{
  width:22px;height:22px;
  stroke:var(--gray-600);
  fill:none;stroke-width:2;
  stroke-linecap:round;
}
.pf-filter-badge{
  display:none;
  position:absolute;top:-4px;right:-4px;
  min-width:20px;height:20px;
  padding:0 5px;
  border-radius:10px;
  background:#E53935;
  color:#fff;
  font-size:0.65rem;
  font-weight:700;
  line-height:20px;
  text-align:center;
}
.pf-filter-badge.show{display:block}

/* Filter Modal Overlay */
.pf-filter-modal-overlay{
  position:fixed;
  inset:0;
  background:rgba(0,0,0,0.45);
  backdrop-filter:blur(4px);
  z-index:1100;
  display:none;
  align-items:center;
  justify-content:center;
  opacity:0;
  transition:opacity 0.25s;
}
.pf-filter-modal-overlay.open{
  display:flex;
  opacity:1;
}
.pf-filter-modal{
  background:var(--white);
  border-radius:20px;
  width:90%;
  max-width:480px;
  box-shadow:0 24px 64px rgba(0,0,0,0.18);
  transform:translateY(20px) scale(0.96);
  transition:transform 0.3s cubic-bezier(0.34,1.56,0.64,1);
  overflow:hidden;
}
.pf-filter-modal-overlay.open .pf-filter-modal{
  transform:translateY(0) scale(1);
}
.pf-filter-modal-head{
  display:flex;
  align-items:center;
  justify-content:space-between;
  padding:24px 28px 16px;
  border-bottom:1px solid var(--gray-200);
}
.pf-filter-modal-head h3{
  font-size:1.15rem;
  font-weight:700;
  color:var(--gray-900);
  margin:0;
}
.pf-filter-modal-close{
  width:36px;height:36px;
  border-radius:50%;
  border:none;
  background:var(--gray-100);
  cursor:pointer;
  display:flex;align-items:center;justify-content:center;
  transition:background 0.15s;
}
.pf-filter-modal-close:hover{background:var(--gray-200)}
.pf-filter-modal-close svg{
  width:18px;height:18px;
  stroke:var(--gray-700);
  fill:none;stroke-width:2;
  stroke-linecap:round;
}
.pf-filter-modal-body{
  padding:24px 28px;
  display:flex;
  flex-wrap:wrap;
  gap:10px;
}
.pf-filter-modal-foot{
  display:flex;
  gap:12px;
  padding:16px 28px 24px;
  border-top:1px solid var(--gray-200);
}
.pf-filter-apply{
  flex:1;
  padding:12px 24px;
  border-radius:var(--radius-pill);
  border:none;
  background:var(--pfizer-indigo);
  color:var(--white);
  font-family:'Noto Sans',sans-serif;
  font-size:0.9rem;
  font-weight:700;
  cursor:pointer;
  transition:background 0.2s;
}
.pf-filter-apply:hover{background:var(--pfizer-indigo-dark)}
.pf-filter-clear{
  padding:12px 24px;
  border-radius:var(--radius-pill);
  border:2px solid var(--gray-300);
  background:var(--white);
  color:var(--gray-700);
  font-family:'Noto Sans',sans-serif;
  font-size:0.9rem;
  font-weight:600;
  cursor:pointer;
  transition:all 0.2s;
}
.pf-filter-clear:hover{border-color:var(--gray-400);background:var(--gray-100)}

/* Letter groups */
.pf-letter-group{margin-bottom:32px}
.pf-letter-group h3{
  font-size:1.4rem;
  font-weight:700;
  color:var(--pfizer-indigo);
  padding-bottom:12px;
  border-bottom:2px solid var(--pfizer-indigo);
  margin-bottom:0;
}
.pf-letter-products{display:flex;flex-direction:column}
.pf-letter-products a{
  display:flex;
  align-items:center;
  justify-content:space-between;
  padding:14px 0;
  border-bottom:1px solid var(--gray-200);
  text-decoration:none;
  color:var(--gray-800);
  font-size:0.95rem;
  font-weight:500;
  transition:all 0.2s;
}
.pf-letter-products a:hover{color:var(--pfizer-indigo);padding-left:8px}
.pf-letter-products a svg{
  width:16px;height:16px;stroke:var(--pfizer-indigo);
  fill:none;stroke-width:2;
  opacity:0;transition:all 0.3s;
}
.pf-letter-products a:hover svg{opacity:1}
.pf-letter-products .prod-cat-tag{
  font-size:0.68rem;
  text-transform:uppercase;
  letter-spacing:1.5px;
  color:var(--gray-500);
  font-weight:600;
  margin-left:16px;
  flex-shrink:0;
}

/* Letter sidebar */
.pf-letter-sidebar{
  position:sticky;
  top:calc(var(--nav-height) + 24px);
  display:flex;
  flex-direction:column;
  align-items:center;
  gap:2px;
}
.pf-letter-sidebar a{
  display:flex;
  align-items:center;
  justify-content:center;
  width:32px;height:28px;
  font-size:0.72rem;
  font-weight:700;
  color:var(--gray-500);
  text-decoration:none;
  border-radius:4px;
  transition:all 0.15s;
}
.pf-letter-sidebar a:hover,.pf-letter-sidebar a.active{
  background:var(--pfizer-indigo);
  color:var(--white);
}
.pf-letter-sidebar a.disabled{
  color:var(--gray-300);
  pointer-events:none;
}

/* =========================================
   ABOUT PAGE — Two-column sections
   ========================================= */
.pf-two-col{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:72px;
  align-items:center;
}
.pf-two-col.reverse{direction:rtl}
.pf-two-col.reverse > *{direction:ltr}
.pf-two-col-img{border-radius:16px;overflow:hidden}
.pf-two-col-img img{width:100%;height:100%;object-fit:cover;min-height:360px}
.pf-two-col-img.abstract{
  min-height:360px;
  display:flex;align-items:center;justify-content:center;
}
.pf-two-col-text h2{font-size:2rem;font-weight:700;margin-bottom:16px;color:var(--gray-900)}
.pf-two-col-text h2 em{font-style:italic;font-weight:400}
.pf-two-col-text p{font-size:0.95rem;color:var(--gray-600);line-height:1.75;margin-bottom:16px}

/* Accordion — Pfizer expandable */
.pf-accordion{margin-top:24px}
.pf-accordion-item{border-bottom:1px solid var(--gray-200)}
.pf-accordion-header{
  display:flex;
  align-items:center;
  justify-content:space-between;
  padding:18px 0;
  cursor:pointer;
  transition:color 0.2s;
  background:none;border:none;width:100%;text-align:left;
  font-family:'Noto Sans',sans-serif;
  font-size:0.95rem;
  font-weight:600;
  color:var(--gray-800);
}
.pf-accordion-header:hover{color:var(--pfizer-indigo)}
.pf-accordion-icon{
  width:24px;height:24px;
  border-radius:50%;
  border:2px solid var(--gray-400);
  display:flex;align-items:center;justify-content:center;
  flex-shrink:0;
  transition:all 0.3s;
}
.pf-accordion-icon svg{width:12px;height:12px;stroke:var(--gray-600);fill:none;stroke-width:2.5;transition:transform 0.3s}
.pf-accordion-item.open .pf-accordion-icon{border-color:var(--pfizer-indigo);background:var(--pfizer-indigo)}
.pf-accordion-item.open .pf-accordion-icon svg{stroke:var(--white);transform:rotate(180deg)}
.pf-accordion-body{
  max-height:0;
  overflow:hidden;
  transition:max-height 0.4s ease, padding 0.3s ease;
}
.pf-accordion-item.open .pf-accordion-body{max-height:500px;padding-bottom:20px}
.pf-accordion-body p{font-size:0.9rem;color:var(--gray-600);line-height:1.7}

/* =========================================
   OUR JOURNEY — About page (Galaxy-style timeline)
   - Full-width milestones with alternating image/text columns
   - Sticky decade-chip nav that scrolls into view
   - Media placeholders with brand-indigo gradient until real images arrive
   ========================================= */
.pf-journey{padding-bottom:40px}
.pf-journey-header{text-align:center;max-width:720px;margin:0 auto 24px}
.pf-journey-eyebrow{
  display:inline-block;
  font-size:0.72rem;font-weight:700;
  text-transform:uppercase;letter-spacing:2.5px;
  color:var(--pfizer-indigo);
  margin-bottom:14px;
}
.pf-journey-header h2{font-size:clamp(2rem,4vw,2.75rem);line-height:1.15;margin-bottom:14px}
.pf-journey-header h2 em{font-style:normal;color:var(--pfizer-indigo)}
.pf-journey-header p{color:var(--gray-500);font-size:1.02rem;line-height:1.7;max-width:580px;margin:0 auto}

/* Sticky decade chips — jumps to milestone anchors */
.pf-journey-nav{
  position:sticky;
  top:var(--nav-height);
  z-index:5;
  background:rgba(255,255,255,0.92);
  backdrop-filter:blur(10px);
  -webkit-backdrop-filter:blur(10px);
  border-top:1px solid var(--gray-200);
  border-bottom:1px solid var(--gray-200);
  margin:40px 0 64px;
}
.pf-journey-nav-inner{
  max-width:var(--max-width);
  margin:0 auto;
  padding:12px 24px;
  display:flex;
  justify-content:center;
  flex-wrap:wrap;
  gap:8px;
  overflow-x:auto;
  scroll-behavior:smooth;
  -webkit-overflow-scrolling:touch;
}
/* Underlined tab style — matches the main nav links (scaleX underline on hover/active) */
.pf-journey-chip{
  position:relative;
  padding:12px 18px;
  color:var(--gray-800);
  font-size:0.88rem;
  font-weight:600;
  letter-spacing:0.3px;
  text-decoration:none;
  white-space:nowrap;
  background:transparent;
  transition:color 0.2s ease;
}
.pf-journey-chip::after{
  content:'';
  position:absolute;
  left:18px;right:18px;
  bottom:0;
  height:3px;
  background:var(--pfizer-indigo);
  transform:scaleX(0);
  transition:transform 0.25s ease;
}
.pf-journey-chip:hover,
.pf-journey-chip.is-active{color:var(--pfizer-indigo)}
.pf-journey-chip:hover::after,
.pf-journey-chip.is-active::after{transform:scaleX(1)}

/* Milestone rows — alternating image/text with a central vertical chronology spine */
.pf-journey-timeline{
  position:relative;
  display:flex;
  flex-direction:column;
  gap:120px;
  padding:24px 0 64px;
}
/* Static gray spine — ends at the last milestone's center (via --spine-end-offset
   set by JS). Falls back to full height if JS hasn't measured yet. */
.pf-journey-timeline::before{
  content:'';
  position:absolute;
  left:50%;
  top:0;
  bottom:var(--spine-end-offset, 0px);
  width:2px;
  background:var(--gray-200);
  transform:translateX(-50%);
  z-index:0;
  pointer-events:none;
}
/* Progressive indigo fill — height is set via --progress-h by JS on scroll.
   Starts at top of timeline, grows down as user scrolls past milestones. */
.pf-journey-timeline::after{
  content:'';
  position:absolute;
  left:50%;
  top:0;
  width:3px;
  height:var(--progress-h, 0px);
  background:linear-gradient(180deg, var(--pfizer-indigo) 0%, #7C3AED 100%);
  border-radius:2px;
  transform:translateX(-50%);
  z-index:1;
  pointer-events:none;
  box-shadow:0 0 12px rgba(54,67,186,0.35);
}
.pf-journey-milestone{
  position:relative;
  /* Paint the milestone (and therefore its dot) above the spine+fill, which
     are at z-index 0 and 1 on the timeline. The reveal-state transform below
     creates a stacking context, so this explicit value is required — otherwise
     the dot's local z-index stays inside the milestone's context and can't
     beat the timeline::after fill. */
  z-index:2;
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:72px;
  align-items:center;
  scroll-margin-top:calc(var(--nav-height) + 80px);
}
.pf-journey-milestone:nth-child(even) .pf-journey-media{order:2}
.pf-journey-milestone:nth-child(even) .pf-journey-body{order:1}
/* Milestone dot — sits on the spine, aligned with the row's vertical center */
.pf-journey-milestone::before{
  content:'';
  position:absolute;
  left:50%;
  top:50%;
  width:20px;
  height:20px;
  border-radius:50%;
  background:var(--white);
  border:3px solid var(--gray-200);
  transform:translate(-50%,-50%);
  z-index:2;
  transition:border-color 0.45s ease, background 0.45s ease, box-shadow 0.45s ease, transform 0.45s ease;
}
.pf-journey-milestone.revealed::before{
  border-color:var(--pfizer-indigo);
  background:var(--pfizer-indigo);
  box-shadow:0 0 0 6px rgba(54,67,186,0.15), 0 0 20px rgba(54,67,186,0.25);
  transform:translate(-50%,-50%) scale(1.05);
}

.pf-journey-media{
  position:relative;
  aspect-ratio:3/2;
  overflow:hidden;
  border-radius:18px;
  background:linear-gradient(135deg,var(--pfizer-indigo-deep) 0%,var(--pfizer-indigo) 60%,#7C3AED 100%);
  box-shadow:0 20px 60px rgba(54,67,186,0.18), 0 2px 8px rgba(54,67,186,0.08);
}
.pf-journey-media img{
  width:100%;height:100%;
  object-fit:cover;
  display:block;
}
/* Illustrated PNG milestones — show fully, no crop, no card */
.pf-journey-milestone--illus .pf-journey-media{
  aspect-ratio:auto;
  overflow:visible;
  background:none;
  box-shadow:none;
  border-radius:0;
}
.pf-journey-milestone--illus .pf-journey-media img{
  width:100%;height:auto;
  object-fit:contain;
  border-radius:18px;
}
/* 1960, 1983, 2003 — reduce to 60% */
#journey-1960 .pf-journey-media img,
#journey-1983 .pf-journey-media img,
#journey-2003 .pf-journey-media img{
  width:60%;
  margin:0 auto;
  display:block;
}

.pf-journey-year{
  display:inline-block;
  font-size:0.82rem;font-weight:800;
  color:var(--pfizer-indigo);
  letter-spacing:2.5px;
  padding:7px 16px;
  background:rgba(54,67,186,0.08);
  border-radius:999px;
  margin-bottom:18px;
  text-transform:uppercase;
}
.pf-journey-body h3{
  font-size:clamp(1.5rem,2.6vw,2rem);
  font-weight:700;
  line-height:1.2;
  color:var(--gray-900);
  margin-bottom:18px;
}
.pf-journey-body p{
  color:var(--gray-600);
  font-size:1rem;
  line-height:1.75;
  margin-bottom:20px;
}
.pf-journey-body ul{
  list-style:none;
  padding:0;
  margin:0;
}
.pf-journey-body ul li{
  position:relative;
  padding-left:22px;
  color:var(--gray-600);
  font-size:0.94rem;
  line-height:1.7;
  margin-bottom:10px;
}
.pf-journey-body ul li::before{
  content:'';
  position:absolute;
  left:0;top:10px;
  width:8px;height:8px;
  background:var(--pfizer-indigo);
  border-radius:2px;
}
.pf-journey-body ul li strong{color:var(--gray-900);font-weight:700}

/* Reveal animation entry state */
.pf-journey-milestone{
  opacity:0;
  transform:translateY(28px);
  transition:opacity 0.8s ease, transform 0.9s cubic-bezier(0.2,0.8,0.2,1);
}
.pf-journey-milestone.revealed{opacity:1;transform:none}

@media(max-width:820px){
  .pf-journey-timeline{gap:72px}
  /* Hide central spine + dots on mobile — layout is single-column, spine doesn't apply */
  .pf-journey-timeline::before,
  .pf-journey-timeline::after,
  .pf-journey-milestone::before{display:none}
  .pf-journey-milestone{
    grid-template-columns:1fr;
    gap:24px;
  }
  .pf-journey-milestone:nth-child(even) .pf-journey-media{order:0}
  .pf-journey-milestone:nth-child(even) .pf-journey-body{order:0}
  .pf-journey-nav-inner{justify-content:flex-start;padding:6px 16px}
  .pf-journey-chip{padding:10px 12px;font-size:0.82rem}
  .pf-journey-chip::after{left:12px;right:12px}
}
@media(max-width:480px){
  .pf-journey-body h3{font-size:1.35rem}
  .pf-journey-body p{font-size:0.94rem}
}

/* =========================================
   CONTACT PAGE
   ========================================= */
/* ---- About MAC page ---- */
.pf-about-intro{max-width:100%}
@media(max-width:768px){.pf-about-two-col{grid-template-columns:1fr !important}}
.pf-about-intro p{font-size:1.05rem;color:var(--gray-700);line-height:1.85;margin-bottom:1.4rem}
.pf-about-contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:32px;margin-top:48px}
.pf-about-info-card{background:transparent;border-radius:0;padding:16px 0;border:none;border-top:1px solid var(--gray-200)}
.pf-about-info-card h3{font-size:1rem;font-weight:700;color:var(--pfizer-indigo);text-transform:uppercase;letter-spacing:2px;margin-bottom:16px}
.pf-about-info-card p,.pf-about-info-card address{font-style:normal;font-size:0.95rem;color:var(--gray-700);line-height:1.7}
.pf-about-info-card a{color:var(--pfizer-indigo);text-decoration:none;font-weight:500}
.pf-about-info-card a:hover{text-decoration:underline}
.pf-about-map-link{display:inline-flex;align-items:center;gap:6px;margin-top:14px;font-size:0.88rem;font-weight:600;color:var(--pfizer-indigo)}
.pf-about-map-link svg{width:16px;height:16px}
@media(max-width:768px){.pf-about-contact-grid{grid-template-columns:1fr}}

/* Leadership Team */
.pf-team-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:28px;margin-top:40px}
.pf-team-card{background:var(--white);border-radius:16px;border:1px solid var(--gray-200);overflow:hidden;box-shadow:0 4px 20px rgba(54,67,186,0.06);transition:box-shadow 0.2s ease,transform 0.2s ease}
.pf-team-card:hover{box-shadow:0 8px 32px rgba(54,67,186,0.13);transform:translateY(-3px)}
.pf-team-avatar{width:100%;aspect-ratio:1/1;background:linear-gradient(135deg,#EDE7F6 0%,#C5CAE9 100%);display:flex;align-items:center;justify-content:center;font-size:2.2rem;font-weight:800;color:var(--pfizer-indigo);letter-spacing:-1px}
.pf-team-avatar img{width:100%;height:100%;object-fit:cover}
.pf-team-body{padding:24px}
.pf-team-name{font-size:1rem;font-weight:700;color:var(--gray-900);margin-bottom:4px}
.pf-team-role{font-size:0.78rem;font-weight:700;text-transform:uppercase;letter-spacing:1.5px;color:var(--pfizer-indigo);margin-bottom:14px}
.pf-team-bio{font-size:0.88rem;color:var(--gray-600);line-height:1.65;margin-bottom:18px}
.pf-team-social{display:flex;gap:10px}
.pf-team-social a{width:32px;height:32px;border-radius:8px;background:var(--gray-100);display:flex;align-items:center;justify-content:center;color:var(--gray-600);transition:background 0.15s ease,color 0.15s ease}
.pf-team-social a:hover{background:var(--pfizer-indigo);color:var(--white)}
.pf-team-social svg{width:16px;height:16px}
@media(max-width:1024px){.pf-team-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:600px){.pf-team-grid{grid-template-columns:1fr}}

/* Chairman's Message */
.pf-chairman{background:linear-gradient(135deg,#141a52 0%,#1B2275 55%,#252d8a 100%);color:var(--white);padding:96px 0}
.pf-chairman-inner{display:block;max-width:1000px}
.pf-chairman-photo{border-radius:18px;overflow:hidden;background:rgba(255,255,255,0.08);aspect-ratio:3/4;display:flex;align-items:center;justify-content:center;font-size:3rem;font-weight:800;color:rgba(255,255,255,0.3);border:2px solid rgba(255,255,255,0.12)}
.pf-chairman-photo img{width:100%;height:100%;object-fit:cover}
.pf-chairman-eyebrow{font-size:0.72rem;font-weight:700;text-transform:uppercase;letter-spacing:3px;color:rgba(255,255,255,0.55);margin-bottom:12px;display:block}
.pf-chairman-name{font-size:1.5rem;font-weight:800;margin-bottom:4px}
.pf-chairman-title{font-size:0.9rem;color:rgba(255,255,255,0.6);margin-bottom:28px}
.pf-chairman-body p{font-size:0.97rem;color:rgba(255,255,255,0.82);line-height:1.8;margin-bottom:1.1rem}
.pf-chairman-quote{font-size:1.15rem;font-style:italic;color:var(--white);border-left:3px solid rgba(255,255,255,0.35);padding-left:20px;margin-top:28px;line-height:1.6}
@media(max-width:900px){.pf-chairman-inner{grid-template-columns:1fr}.pf-chairman-photo{aspect-ratio:1/1;max-width:240px}}

.pf-contact-grid{
  display:grid;
  grid-template-columns:1fr 1.2fr;
  gap:72px;
  align-items:start;
}
.pf-contact-info h3{font-size:1.4rem;font-weight:700;margin-bottom:24px;color:var(--gray-900)}
.pf-contact-item{display:flex;gap:16px;margin-bottom:24px;align-items:flex-start}
.pf-contact-item-icon{
  width:44px;height:44px;
  border-radius:50%;
  background:var(--pfizer-blue-light);
  display:flex;align-items:center;justify-content:center;
  flex-shrink:0;
}
.pf-contact-item-icon svg{width:20px;height:20px;stroke:var(--pfizer-indigo);fill:none;stroke-width:2}
.pf-contact-item h4{font-size:0.9rem;font-weight:700;margin-bottom:4px;color:var(--gray-900)}
.pf-contact-item p,.pf-contact-item a{font-size:0.88rem;color:var(--gray-600);line-height:1.5}
.pf-contact-item a{color:var(--pfizer-indigo);text-decoration:none}
.pf-contact-item a:hover{text-decoration:underline}

.pf-form{background:var(--gray-50);border-radius:16px;padding:40px}
.pf-form h3{font-size:1.2rem;font-weight:700;margin-bottom:24px;color:var(--gray-900)}
.pf-form-group{margin-bottom:20px}
.pf-form-group label{display:block;font-size:0.82rem;font-weight:600;color:var(--gray-700);margin-bottom:8px}
.pf-form-group input,.pf-form-group textarea,.pf-form-group select{
  width:100%;padding:14px 16px;
  border:2px solid var(--gray-300);
  border-radius:var(--radius);
  font-family:'Noto Sans',sans-serif;
  font-size:0.9rem;color:var(--gray-900);
  background:var(--white);
  outline:none;transition:border-color 0.2s;
}
.pf-form-group input:focus,.pf-form-group textarea:focus{border-color:var(--pfizer-indigo)}
.pf-form-group textarea{resize:vertical;min-height:120px}
.pf-form-row{display:grid;grid-template-columns:1fr 1fr;gap:20px}

/* =========================================
   PRODUCT DETAIL PAGE
   ========================================= */
.pf-detail-grid{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:72px;
  align-items:start;
}
.pf-detail-img{
  background:var(--gray-50);
  border-radius:16px;
  padding:32px 32px 20px;
  display:flex;
  flex-direction:column;
  align-items:center;
  gap:16px;
  position:sticky;
  top:calc(var(--nav-height) + 24px);
}
.pf-detail-img img{max-height:380px;width:auto;object-fit:contain}

/* ---- Packshot carousel ---- */
.pf-packshot-main{
  width:100%;
  display:flex;
  align-items:center;
  justify-content:center;
  min-height:280px;
}
.pf-packshot-main img{
  max-height:340px;
  max-width:100%;
  object-fit:contain;
  transition:opacity 0.2s ease;
}
.pf-packshot-thumbs{
  display:flex;
  flex-wrap:wrap;
  gap:8px;
  justify-content:center;
  padding-top:4px;
}
.pf-packshot-thumbs img{
  width:60px;
  height:60px;
  object-fit:contain;
  border-radius:8px;
  border:2px solid var(--gray-200);
  cursor:pointer;
  background:var(--white);
  padding:4px;
  transition:border-color 0.15s ease, transform 0.15s ease;
}
.pf-packshot-thumbs img:hover{border-color:var(--gray-400);transform:scale(1.06)}
.pf-packshot-thumbs img.active{border-color:var(--pfizer-indigo)}
.pf-detail-info h1{font-size:2.2rem;font-weight:700;margin-bottom:8px;color:var(--gray-900)}
.pf-detail-category{
  font-size:0.72rem;
  text-transform:uppercase;
  letter-spacing:2px;
  color:var(--pfizer-indigo);
  font-weight:700;
  margin-bottom:16px;
  display:inline-block;
}
.pf-detail-tagline{font-size:1.1rem;color:var(--gray-600);margin-bottom:24px;line-height:1.6}
.pf-detail-section{margin-bottom:32px}
.pf-detail-section h3{font-size:1rem;font-weight:700;margin-bottom:12px;color:var(--gray-900)}
.pf-detail-section p{font-size:0.9rem;color:var(--gray-600);line-height:1.7}
.pf-detail-variants{display:flex;flex-wrap:wrap;gap:10px;margin-top:12px}
.pf-detail-variant{
  padding:8px 20px;
  border-radius:var(--radius-pill);
  border:2px solid var(--gray-300);
  font-size:0.82rem;
  font-weight:600;
  color:var(--gray-700);
  cursor:pointer;
  transition:all 0.2s;
  background:var(--white);
}
.pf-detail-variant:hover,.pf-detail-variant.active{
  border-color:var(--pfizer-indigo);
  background:var(--pfizer-indigo);
  color:var(--white);
}

/* =========================================
   PRODUCT TABS — Overview, How to Use, etc.
   ========================================= */
.pf-tabs{
  margin-top:40px;
  border-top:1px solid var(--gray-200);
}
.pf-tabs-header{
  display:flex;
  gap:0;
  border-bottom:2px solid var(--gray-200);
}
.pf-tab-btn{
  padding:16px 28px;
  background:transparent;
  border:none;
  cursor:pointer;
  font-family:'Noto Sans',sans-serif;
  font-size:0.85rem;
  font-weight:700;
  color:var(--gray-500);
  letter-spacing:0.2px;
  border-bottom:3px solid transparent;
  transition:all 0.2s;
  position:relative;
  bottom:-2px;
  white-space:nowrap;
}
.pf-tab-btn:hover{
  color:var(--pfizer-indigo);
}
.pf-tab-btn.active{
  color:var(--pfizer-indigo);
  border-bottom-color:var(--pfizer-indigo);
}
.pf-tab-content{
  display:none;
  padding:32px 0;
  animation:tabFadeIn 0.3s ease;
}
.pf-tab-content.active{
  display:block;
}
@keyframes tabFadeIn{
  from{opacity:0;transform:translateY(-8px)}
  to{opacity:1;transform:translateY(0)}
}
.pf-tab-content h4{
  font-size:1.05rem;
  font-weight:700;
  color:var(--gray-900);
  margin-bottom:12px;
}
.pf-tab-content p{
  font-size:0.92rem;
  color:var(--gray-600);
  line-height:1.75;
  margin-bottom:16px;
}
.pf-tab-content p:last-child{
  margin-bottom:0;
}
.pf-tab-content ul{
  list-style:disc;
  padding-left:20px;
  margin-bottom:16px;
}
.pf-tab-content ul li{
  font-size:0.92rem;
  color:var(--gray-600);
  line-height:1.75;
  margin-bottom:6px;
}
.pf-tab-content .pf-tab-warn{
  background:#FFF8E1;
  border-left:4px solid #FFC107;
  padding:16px 20px;
  border-radius:0 8px 8px 0;
  margin:20px 0;
}
.pf-tab-content .pf-tab-warn p{
  color:var(--gray-800);
  font-size:0.88rem;
  margin:0;
}
.pf-tab-content .pf-tab-warn strong{
  color:var(--gray-900);
}
@media(max-width:768px){
  .pf-tabs-header{
    overflow-x:auto;
    -webkit-overflow-scrolling:touch;
    scrollbar-width:none;
  }
  .pf-tabs-header::-webkit-scrollbar{display:none}
  .pf-tab-btn{
    padding:12px 18px;
    font-size:0.78rem;
  }
  .pf-tab-content{
    padding:24px 0;
  }
}

/* India map bg for the indigo band — full map, uncropped, faded.
   Height-driven sizing so the aspect ratio is preserved (SVG is 1:1); we leave
   headroom so the whole country is visible, not clipped by the section bounds.
   The source SVG is green (#6f9c76); the filter converts it to pure white so
   it sits naturally against the indigo band at low opacity. */
.pf-india-map-bg{
  position:relative;
  overflow:hidden;
}
.pf-india-map-bg .pf-india-svg{
  position:absolute;
  right:4%;
  top:50%;
  transform:translateY(-50%);
  width:auto;
  height:85%;
  max-height:480px;
  opacity:0.13;
  pointer-events:none;
  /* Flatten the green SVG to pure white so the tint matches the blue band */
  filter:brightness(0) invert(1);
}

/* Floating contact — removed */

/* =========================================
   BACK TO TOP
   ========================================= */
/* Floating WhatsApp + Call buttons */
.pf-float-btns{
  position:fixed;bottom:28px;right:28px;
  display:flex;flex-direction:column;gap:10px;
  z-index:999;
}
.pf-float-btn{
  width:50px;height:50px;border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  box-shadow:0 4px 16px rgba(0,0,0,0.22);
  transition:transform 0.2s ease,box-shadow 0.2s ease;
  text-decoration:none;
}
.pf-float-btn:hover{transform:scale(1.12);box-shadow:0 6px 22px rgba(0,0,0,0.28)}
.pf-float-btn svg{width:26px;height:26px}
.pf-float-wa{background:#25D366}
.pf-float-call{background:var(--pfizer-indigo)}

.pf-btt{
  position:fixed;bottom:90px;right:28px;
  width:44px;height:44px;border-radius:50%;
  background:var(--gray-900);color:var(--white);
  border:none;cursor:pointer;
  display:flex;align-items:center;justify-content:center;
  opacity:0;visibility:hidden;transform:translateY(16px);
  transition:all 0.3s;z-index:998;
}
.pf-btt.visible{opacity:1;visibility:visible;transform:translateY(0)}
.pf-btt:hover{background:var(--pfizer-indigo)}
.pf-btt svg{width:18px;height:18px;fill:none;stroke:white;stroke-width:2.5;stroke-linecap:round;stroke-linejoin:round}

/* =========================================
   SCROLL REVEAL
   ========================================= */
@keyframes pf-reveal-fallback{to{opacity:1;transform:translateY(0)}}
@keyframes pf-reveal-fallback-left{to{opacity:1;transform:translateX(0)}}
@keyframes pf-reveal-fallback-right{to{opacity:1;transform:translateX(0)}}
.reveal{opacity:0;transform:translateY(20px);transition:opacity 0.6s ease,transform 0.6s ease;animation:pf-reveal-fallback 0.6s ease 3.5s forwards}
.reveal.revealed{opacity:1;transform:translateY(0);animation:none}
.reveal-left{opacity:0;transform:translateX(-24px);transition:opacity 0.6s ease,transform 0.6s ease;animation:pf-reveal-fallback-left 0.6s ease 3.5s forwards}
.reveal-left.revealed{opacity:1;transform:translateX(0);animation:none}
.reveal-right{opacity:0;transform:translateX(24px);transition:opacity 0.6s ease,transform 0.6s ease;animation:pf-reveal-fallback-right 0.6s ease 3.5s forwards}
.reveal-right.revealed{opacity:1;transform:translateX(0);animation:none}

/* Stagger children */
.stagger > *:nth-child(1){transition-delay:0s}
.stagger > *:nth-child(2){transition-delay:0.06s}
.stagger > *:nth-child(3){transition-delay:0.12s}
.stagger > *:nth-child(4){transition-delay:0.18s}
.stagger > *:nth-child(5){transition-delay:0.24s}
.stagger > *:nth-child(6){transition-delay:0.3s}

/* =========================================
   RESPONSIVE
   ========================================= */
@media(max-width:1100px){
  .pf-stats-row{grid-template-columns:repeat(3,1fr)}
  .pf-footer-top{grid-template-columns:repeat(3,1fr)}
}
@media(max-width:1024px){
  .container{padding:0 32px}
  .pf-nav-inner{padding:0 32px}
  .pf-hero-content{padding:60px 32px}
  .pf-page-hero-content{padding:0 32px}
  .pf-media-grid{grid-template-columns:1fr}
  .pf-products-home{grid-template-columns:1fr}
  .pf-two-col{grid-template-columns:1fr;gap:40px}
  .pf-two-col.reverse{direction:ltr}
  .pf-blue-band-inner{grid-template-columns:1fr}
  .pf-contact-grid{grid-template-columns:1fr}
  .pf-detail-grid{grid-template-columns:1fr}
  .pf-detail-img{position:static}
  .pf-carousel-card{flex:0 0 280px}
}
@media(max-width:768px){
  .container{padding:0 20px}
  .pf-nav-inner{padding:0 20px}
  .pf-links,.pf-utility{display:none}
  .pf-hamburger{display:block}
  /* Mobile menu */
  .pf-mobile-menu{
    position:fixed;top:var(--nav-height);left:0;right:0;bottom:0;
    background:var(--white);z-index:999;
    padding:32px 20px;
    display:none;flex-direction:column;gap:0;
    overflow-y:auto;
  }
  .pf-mobile-menu.open{display:flex}
  .pf-mobile-menu a{
    display:block;
    padding:16px 0;
    font-size:1.1rem;
    font-weight:600;
    color:var(--gray-800);
    border-bottom:1px solid var(--gray-200);
    text-decoration:none;
  }
  .pf-mobile-menu a:hover{color:var(--pfizer-indigo)}
  /* Mobile mega menu — accordion style */
  .pf-mobile-item{border-bottom:1px solid var(--gray-200)}
  .pf-mobile-toggle{
    display:flex;
    align-items:center;
    justify-content:space-between;
    width:100%;
    padding:16px 0;
    font-size:1.1rem;
    font-weight:600;
    color:var(--gray-800);
    background:none;
    border:none;
    cursor:pointer;
    font-family:'Noto Sans',sans-serif;
  }
  .pf-mobile-toggle svg{
    width:16px;height:16px;
    stroke:var(--gray-500);fill:none;stroke-width:2.5;
    transition:transform 0.3s;
  }
  .pf-mobile-item.open .pf-mobile-toggle svg{transform:rotate(180deg)}
  .pf-mobile-item.open .pf-mobile-toggle{color:var(--pfizer-indigo)}
  .pf-mobile-sub{
    max-height:0;
    overflow:hidden;
    transition:max-height 0.4s ease;
    padding-left:16px;
  }
  .pf-mobile-item.open .pf-mobile-sub{max-height:500px}
  .pf-mobile-sub a{
    display:block;
    padding:10px 0;
    font-size:0.92rem;
    font-weight:500;
    color:var(--gray-600);
    border-bottom:1px solid var(--gray-100);
  }
  .pf-mobile-sub a:last-child{border-bottom:none}
  .pf-mobile-sub a:hover{color:var(--pfizer-indigo)}

  /* Rich mobile mega menu — icons, snippets, preview cards */
  .pf-mob-sub-header{
    display:block;
    font-size:0.68rem;
    font-weight:700;
    text-transform:uppercase;
    letter-spacing:1.5px;
    color:var(--gray-400);
    padding:8px 0 12px;
    border-bottom:none;
  }
  .pf-mob-rich-link{
    display:flex!important;
    align-items:center;
    gap:14px;
    padding:12px 0!important;
    border-bottom:1px solid var(--gray-100)!important;
  }
  .pf-mob-rich-link:last-of-type{border-bottom:none!important}
  .pf-mob-icon{
    width:40px;height:40px;
    border-radius:10px;
    display:flex;align-items:center;justify-content:center;
    flex-shrink:0;
    transition:transform 0.2s;
  }
  .pf-mob-rich-link:hover .pf-mob-icon{transform:scale(1.08)}
  .pf-mob-icon svg{width:20px;height:20px;stroke-width:1.5}
  .pf-mob-link-text{
    display:flex;
    flex-direction:column;
    gap:2px;
    min-width:0;
  }
  .pf-mob-link-text strong{
    font-size:0.9rem;
    font-weight:700;
    color:var(--gray-800);
    line-height:1.3;
  }
  .pf-mob-link-text small{
    font-size:0.75rem;
    color:var(--gray-500);
    font-weight:400;
    line-height:1.4;
  }
  .pf-mob-rich-link:hover .pf-mob-link-text strong{color:var(--pfizer-indigo)}

  /* Sub-footer link */
  .pf-mob-sub-footer{
    margin-top:8px;
    padding-top:12px;
    border-top:1px solid var(--gray-200);
  }
  .pf-mob-sub-footer a{
    display:flex!important;
    align-items:center;
    gap:8px;
    font-size:0.88rem!important;
    font-weight:700!important;
    color:var(--pfizer-indigo)!important;
    padding:8px 0!important;
    border-bottom:none!important;
  }
  .pf-mob-sub-footer a svg{
    width:16px;height:16px;
    stroke:var(--pfizer-indigo);
    fill:none;stroke-width:2.5;
    transition:transform 0.3s;
  }
  .pf-mob-sub-footer a:hover svg{transform:translateX(4px)}

  /* Preview card (Benoquin, Our Story) */
  .pf-mob-preview{
    display:flex;
    gap:14px;
    padding:14px 0;
    align-items:flex-start;
  }
  .pf-mob-preview img{
    width:80px;height:80px;
    object-fit:cover;
    border-radius:12px;
    flex-shrink:0;
    background:var(--gray-100);
  }
  .pf-mob-preview-text{
    display:flex;
    flex-direction:column;
    gap:4px;
    min-width:0;
  }
  .pf-mob-preview-text strong{
    font-size:0.92rem;
    font-weight:700;
    color:var(--gray-800);
    line-height:1.3;
  }
  .pf-mob-preview-text small{
    font-size:0.78rem;
    color:var(--gray-500);
    line-height:1.5;
    display:-webkit-box;
    -webkit-line-clamp:3;
    -webkit-box-orient:vertical;
    overflow:hidden;
  }
  .pf-mob-preview-btn{
    display:inline-flex!important;
    align-items:center;
    gap:6px;
    font-size:0.82rem!important;
    font-weight:700!important;
    color:var(--pfizer-indigo)!important;
    padding:6px 0!important;
    border-bottom:none!important;
    margin-top:4px;
  }
  .pf-mob-preview-btn svg{
    width:14px;height:14px;
    stroke:var(--pfizer-indigo);
    fill:none;stroke-width:2.5;
    transition:transform 0.3s;
  }
  .pf-mob-preview-btn:hover svg{transform:translateX(4px)}

  /* Increase max-height for richer submenus */
  .pf-mobile-item.open .pf-mobile-sub{max-height:800px}

  .pf-mobile-menu .pf-contact-btn{
    display:inline-block;
    margin-top:24px;
    padding:14px 32px;
    border-radius:var(--radius-pill);
    background:var(--pfizer-indigo);
    color:var(--white);
    font-weight:700;
    text-align:center;
  }
  .pf-hero{min-height:420px}
  .pf-hero-content{padding:48px 20px}
  .pf-hero-content h1{font-size:2.2rem}
  .pf-page-hero-content{padding:0 20px}
  .pf-page-hero-content h1{font-size:2rem}
  .pf-section{padding:56px 0}
  .pf-sec-header h2{font-size:1.8rem}
  .pf-stats-row{grid-template-columns:repeat(2,1fr)}
  .pf-carousel-card{flex:0 0 260px}
  .pf-arrow{display:none}
  /* Mobile carousel overlay arrows */
  .pf-carousel-mob-nav{display:flex}
  .pf-footer-top{grid-template-columns:1fr 1fr}
  .pf-products-layout{grid-template-columns:1fr}
  .pf-letter-sidebar{
    position:static;
    flex-direction:row;
    flex-wrap:wrap;
    gap:4px;
    margin-bottom:24px;
  }
  .pf-form-row{grid-template-columns:1fr}
}
@media(max-width:480px){
  .pf-hero-content h1{font-size:1.8rem}
  .pf-stats-row{grid-template-columns:1fr}
  .pf-footer-top{grid-template-columns:1fr}
  .pf-newsletter-form{flex-direction:column}
  .pf-filter-modal{width:95%;border-radius:16px}
  .pf-filter-modal-head{padding:20px 20px 14px}
  .pf-filter-modal-body{padding:20px}
  .pf-filter-modal-foot{padding:14px 20px 20px}
  .pf-filter-toggle{width:44px;height:44px}
  .pf-filter-toggle svg{width:20px;height:20px}
}

/* =========================================
   MOTION — Global animation enhancements
   ========================================= */

/* --- Preloader: mini equalizer, shown on every page load --- */
body.pf-preloading{overflow:hidden}
.pf-preloader{
  position:fixed;
  inset:0;
  z-index:9999;
  background:#fff;
  display:flex;
  align-items:center;
  justify-content:center;
  transition:opacity 0.6s ease;
}
.pf-preloader.pf-hide{opacity:0;pointer-events:none}
.pf-preloader.pf-done{display:none}
.pf-preloader-eq{
  width:140px;
  height:200px;
  background:#fff;
  border-radius:10px;
  padding:8px;
  position:relative;
  overflow:hidden;
  box-shadow:0 18px 60px rgba(54,67,186,0.15), 0 0 0 1px rgba(54,67,186,0.05);
}
.pf-preloader-canvas{
  width:100%;
  height:100%;
  display:block;
  border-radius:4px;
}
.pf-preloader-logo-wrap{
  position:absolute;
  left:50%;
  bottom:10px;
  transform:translateX(-50%);
  width:80%;
  background:#fff;
  padding:3px 8px;
  border-radius:4px;
  display:flex;
  align-items:center;
  justify-content:center;
  z-index:2;
}
.pf-preloader-logo-wrap img{
  width:100%;
  height:auto;
  display:block;
}
@media(prefers-reduced-motion:reduce){
  .pf-preloader{transition:none;display:none !important}
  body.pf-preloading{overflow:auto}
}

/* --- Scroll progress bar (fixed top, above nav) --- */
.pf-scroll-progress{
  position:fixed;
  top:0;
  left:0;
  height:3px;
  width:0%;
  background:linear-gradient(90deg, #3643BA 0%, #7C3AED 100%);
  z-index:1100;
  pointer-events:none;
  transition:width 0.08s ease-out;
  box-shadow:0 0 8px rgba(124,58,237,0.35);
}

/* --- Hero headline word-by-word reveal --- */
.word-reveal{display:block}
.word-reveal > span,
.word-reveal em > span{
  display:inline-block;
  opacity:0;
  transform:translateY(22px);
  transition:opacity 0.7s ease, transform 0.7s cubic-bezier(0.2,0.8,0.2,1);
  transition-delay:calc(var(--i, 0) * 95ms);
}
.word-reveal.revealed > span,
.word-reveal.revealed em > span{
  opacity:1;
  transform:translateY(0);
}
.word-reveal em{display:inline-block;font-style:italic}


/* --- Hero CTA arrow nudge on hover --- */
.pf-hero-cta svg{transition:transform 0.3s cubic-bezier(0.2,0.8,0.2,1)}
.pf-hero-cta:hover svg{transform:translateX(6px)}

/* --- Legacy Stats: "1st" pop-in --- */
.pf-legacy-num.pop-in{
  display:inline-block;
  opacity:0;
  transform:scale(0.4);
  transform-origin:center;
}
.pf-legacy-num.pop-in.revealed{
  animation:pfPopIn 0.9s cubic-bezier(0.5, 1.8, 0.5, 1) forwards;
}
@keyframes pfPopIn{
  0%  {opacity:0;transform:scale(0.4)}
  60% {opacity:1;transform:scale(1.18)}
  100%{opacity:1;transform:scale(1)}
}

/* --- Contact form: submit button pulse (once) --- */
.pf-cf-submit.pulsed{animation:pfSubmitPulse 2s ease-out 0.4s}
@keyframes pfSubmitPulse{
  0%  {box-shadow:0 0 0 0 rgba(54,67,186,0.45)}
  70% {box-shadow:0 0 0 22px rgba(54,67,186,0)}
  100%{box-shadow:0 0 0 0 rgba(54,67,186,0)}
}

/* --- Contact form: phone field enable flash --- */
.pf-cf-phone-wrap.just-enabled{animation:pfPhoneFlash 0.7s ease-out}
@keyframes pfPhoneFlash{
  0%  {background:rgba(124,58,237,0.12)}
  100%{background:transparent}
}

/* --- Contact form: input focus underline draw-in --- */
.pf-cf-field input,
.pf-cf-field select,
.pf-cf-field textarea{
  background-image:linear-gradient(90deg, var(--pfizer-indigo), var(--pfizer-indigo));
  background-size:0% 1px;
  background-position:left bottom;
  background-repeat:no-repeat;
  transition:background-size 0.35s ease, border-color 0.3s ease;
}
.pf-cf-field input:focus,
.pf-cf-field select:focus,
.pf-cf-field textarea:focus{background-size:100% 1px}
.pf-cf-phone-wrap{
  background-image:linear-gradient(90deg, var(--pfizer-indigo), var(--pfizer-indigo));
  background-size:0% 1px;
  background-position:left bottom;
  background-repeat:no-repeat;
  transition:background-size 0.35s ease, border-color 0.3s ease;
}
.pf-cf-phone-wrap:focus-within{background-size:100% 1px}

/* --- Footer: social icon pop-in --- */
.pf-footer-social a{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  opacity:0;
  transform:scale(0);
  transition:opacity 0.45s ease, transform 0.5s cubic-bezier(0.5,1.6,0.5,1);
}
.pf-footer-top.revealed .pf-footer-social a{
  opacity:1;
  transform:scale(1);
}
.pf-footer-top.revealed .pf-footer-social a:nth-child(1){transition-delay:0.5s}
.pf-footer-top.revealed .pf-footer-social a:nth-child(2){transition-delay:0.6s}
.pf-footer-top.revealed .pf-footer-social a:nth-child(3){transition-delay:0.7s}

/* --- Back-to-top button: subtle bounce hint --- */
.pf-btt.visible{
  animation:pfBttBounce 8s ease-in-out 4s infinite;
}
@keyframes pfBttBounce{
  0%, 88%, 100%{transform:translateY(0)}
  92%{transform:translateY(-8px)}
  95%{transform:translateY(-1px)}
  97%{transform:translateY(-4px)}
  100%{transform:translateY(0)}
}

/* --- Brand DNA + New Era cards: directional slide-in on section view --- */
/* Override the generic .reveal for these cards so cascade feels more dynamic */
.pf-brand-dna-grid > .pf-dna-card.reveal,
.pf-new-era-grid > .pf-ne-card.reveal{
  opacity:0;
  transition:opacity 0.85s ease, transform 0.9s cubic-bezier(0.2,0.85,0.25,1);
}
/* Card 1: slides in from LEFT */
.pf-brand-dna-grid > .pf-dna-card.reveal:nth-child(1),
.pf-new-era-grid > .pf-ne-card.reveal:nth-child(1){
  transform:translateX(-60px) translateY(20px);
}
/* Card 2 (center): slides up from BELOW with slight scale */
.pf-brand-dna-grid > .pf-dna-card.reveal:nth-child(2),
.pf-new-era-grid > .pf-ne-card.reveal:nth-child(2){
  transform:translateY(60px) scale(0.95);
}
/* Card 3: slides in from RIGHT */
.pf-brand-dna-grid > .pf-dna-card.reveal:nth-child(3),
.pf-new-era-grid > .pf-ne-card.reveal:nth-child(3){
  transform:translateX(60px) translateY(20px);
}
/* Revealed state — all cards land at identity */
.pf-brand-dna-grid > .pf-dna-card.reveal.revealed,
.pf-new-era-grid > .pf-ne-card.reveal.revealed{
  opacity:1;
  transform:translateX(0) translateY(0) scale(1);
}
/* Stagger across the row (existing .stagger delays apply on top) */
.pf-brand-dna-grid.stagger > .pf-dna-card.reveal:nth-child(1),
.pf-new-era-grid.stagger > .pf-ne-card.reveal:nth-child(1){transition-delay:0s}
.pf-brand-dna-grid.stagger > .pf-dna-card.reveal:nth-child(2),
.pf-new-era-grid.stagger > .pf-ne-card.reveal:nth-child(2){transition-delay:0.15s}
.pf-brand-dna-grid.stagger > .pf-dna-card.reveal:nth-child(3),
.pf-new-era-grid.stagger > .pf-ne-card.reveal:nth-child(3){transition-delay:0.3s}
@media(max-width:768px){
  /* On mobile, keep all cards simple slide-up (no horizontal drift on narrow screens) */
  .pf-brand-dna-grid > .pf-dna-card.reveal:nth-child(1),
  .pf-brand-dna-grid > .pf-dna-card.reveal:nth-child(2),
  .pf-brand-dna-grid > .pf-dna-card.reveal:nth-child(3),
  .pf-new-era-grid > .pf-ne-card.reveal:nth-child(1),
  .pf-new-era-grid > .pf-ne-card.reveal:nth-child(2),
  .pf-new-era-grid > .pf-ne-card.reveal:nth-child(3){
    transform:translateY(36px);
  }
}

/* --- Brand DNA header: text slide-left + equalizer scale-right --- */
.pf-brand-dna-text{
  opacity:0;
  transform:translateX(-32px);
  transition:opacity 0.8s ease, transform 0.9s cubic-bezier(0.2,0.8,0.2,1);
}
.pf-dna-eq{
  opacity:0;
  transform:scale(0.9);
  transition:opacity 0.8s ease, transform 0.9s cubic-bezier(0.2,0.8,0.2,1);
  transition-delay:0.15s;
}
.pf-brand-dna-head.revealed .pf-brand-dna-text,
.pf-brand-dna-head.revealed .pf-dna-eq{
  opacity:1;
  transform:none;
}

/* --- Respect reduced motion --- */
@media(prefers-reduced-motion:reduce){
  .pf-scroll-progress,
  .word-reveal > span,
  .word-reveal em > span,
  .pf-hero-cta svg,
  .pf-legacy-num.pop-in,
  .pf-cf-submit.pulsed,
  .pf-cf-phone-wrap.just-enabled,
  .pf-footer-social a,
  .pf-btt.visible,
  .pf-brand-dna-text,
  .pf-dna-eq{
    animation:none !important;
    transition:none !important;
    opacity:1 !important;
    transform:none !important;
  }
}

/* =========================================
   HERO V5 — Kinetic type + wavy canvas + clip-path shards
   ========================================= */
.pf-hero-v5{
  position:relative;width:100%;
  aspect-ratio:21/9;min-height:560px;max-height:760px;
  overflow:hidden;background:#0A0838;
  display:flex;align-items:center;justify-content:center;
  font-family:'Inter','Noto Sans',sans-serif;
  color:#fff;
}
@media(max-width:768px){.pf-hero-v5{aspect-ratio:16/10;min-height:440px}}

/* Wavy canvas fills hero */
.pf-hv5-wavy{
  position:absolute;inset:0;z-index:0;
  width:100%;height:100%;display:block;pointer-events:none;
}
/* Darkening vignette for text contrast */
.pf-hero-v5::after{
  content:'';position:absolute;inset:0;z-index:1;
  background:radial-gradient(ellipse at center, transparent 10%, rgba(10,8,56,0.55) 75%, rgba(10,8,56,0.85) 100%);
  pointer-events:none;
}

/* Counter top-right */
.pf-hv5-count{
  position:absolute;top:40px;right:48px;z-index:5;
  font-size:0.72rem;font-weight:700;letter-spacing:3px;color:rgba(207,194,244,0.8);
  font-variant-numeric:tabular-nums;
}
.pf-hv5-count strong{color:#fff;font-weight:800}

/* Image shards — 2 full-height angular strips, all viewports */
.pf-hv5-shard{
  position:absolute;overflow:hidden;
  background:#1C1678;
  transform:translate(var(--tx,0),var(--ty,0)) scale(var(--sc,0.92));
  opacity:0;
  transition:transform 0.9s cubic-bezier(0.3,0.7,0.3,1), opacity 0.6s ease;
  z-index:2;
}
.pf-hv5-shard img{width:100%;height:100%;object-fit:cover;display:block}
.pf-hv5-shard-1 img{object-position:30% 20%}
.pf-hv5-shard-2 img{object-position:75% 35%}
/* Per-story framing — keep subjects visible within the clipped shards */
.pf-hero-v5[data-story="vitiligo"] .pf-hv5-shard-1 img{object-position:62% 32%}
.pf-hero-v5[data-story="vitiligo"] .pf-hv5-shard-2 img{object-position:50% 35%}
.pf-hero-v5[data-story="wellness"] .pf-hv5-shard-1 img{object-position:55% 40%}
.pf-hero-v5[data-story="wellness"] .pf-hv5-shard-2 img{object-position:50% 45%}
.pf-hv5-shard::after{
  content:'';position:absolute;inset:0;z-index:2;
  background:linear-gradient(135deg,rgba(10,8,56,0.35),rgba(75,35,199,0.25) 60%,transparent 100%);
  pointer-events:none;
}
.pf-hv5-shard-3,.pf-hv5-shard-4{display:none}
.pf-hv5-shard-1{
  top:0;bottom:0;left:0;right:auto;
  width:clamp(160px,22vw,420px);height:auto;
  clip-path:polygon(0% 0%, 100% 0%, 55% 100%, 0% 100%);
  -webkit-clip-path:polygon(0% 0%, 100% 0%, 55% 100%, 0% 100%);
  --tx:-30px;--ty:0;
}
.pf-hv5-shard-2{
  top:0;bottom:0;right:0;left:auto;
  width:clamp(160px,22vw,420px);height:auto;
  clip-path:polygon(45% 0%, 100% 0%, 100% 100%, 0% 100%);
  -webkit-clip-path:polygon(45% 0%, 100% 0%, 100% 100%, 0% 100%);
  --tx:30px;--ty:0;
}

/* Kinetic word stack */
.pf-hv5-stack{
  position:relative;z-index:3;
  display:flex;flex-direction:column;align-items:center;gap:0;
  line-height:0.92;letter-spacing:-0.035em;text-align:center;
  padding:0 clamp(140px,20vw,380px);max-width:100vw;
}
.pf-hv5-word{
  display:block;font-weight:900;font-size:clamp(3rem,11vw,9rem);
  position:relative;opacity:0;transform:translateY(40px);
  transition:opacity 0.55s ease, transform 0.7s cubic-bezier(0.2,0.8,0.2,1);
  text-shadow:0 4px 40px rgba(10,8,56,0.5);
  margin:0;
}
.pf-hv5-word-1{color:rgba(255,255,255,0.85);font-weight:300;font-size:clamp(2.4rem,8vw,6.5rem)}
.pf-hv5-word-2{color:#fff;font-weight:800;font-size:clamp(3.2rem,12vw,9.5rem);letter-spacing:-0.035em;transform:translateX(-60px)}
.pf-hv5-word-3{color:#CFC2F4;font-weight:800;font-size:clamp(2.8rem,10vw,8rem);letter-spacing:-0.025em;transform:translateX(60px)}

/* Phase states — words enter sequentially */
.pf-hero-v5.p1 .pf-hv5-word-1,
.pf-hero-v5.p2 .pf-hv5-word-1,.pf-hero-v5.p2 .pf-hv5-word-2,
.pf-hero-v5.p3 .pf-hv5-word-1,.pf-hero-v5.p3 .pf-hv5-word-2,.pf-hero-v5.p3 .pf-hv5-word-3,
.pf-hero-v5.p4 .pf-hv5-word{opacity:1;transform:translate(0,0)}

/* Shards enter paired with words */
.pf-hero-v5.p1 .pf-hv5-shard-1,
.pf-hero-v5.p2 .pf-hv5-shard-1,.pf-hero-v5.p2 .pf-hv5-shard-2,
.pf-hero-v5.p3 .pf-hv5-shard-1,.pf-hero-v5.p3 .pf-hv5-shard-2,.pf-hero-v5.p3 .pf-hv5-shard-3,.pf-hero-v5.p3 .pf-hv5-shard-4,
.pf-hero-v5.p4 .pf-hv5-shard{opacity:1;transform:translate(0,0) scale(1)}

/* Exit phase */
.pf-hero-v5.p5 .pf-hv5-word-1{opacity:0;transform:translateY(-20px);transition-delay:0s}
.pf-hero-v5.p5 .pf-hv5-word-2{opacity:0;transform:translateY(-20px);transition-delay:0.08s}
.pf-hero-v5.p5 .pf-hv5-word-3{opacity:0;transform:translateY(-20px);transition-delay:0.16s}
.pf-hero-v5.p5 .pf-hv5-shard-1{opacity:0;transform:translate(-40px,-40px) scale(0.92);transition-delay:0s}
.pf-hero-v5.p5 .pf-hv5-shard-2{opacity:0;transform:translate(40px,-30px) scale(0.92);transition-delay:0.08s}
.pf-hero-v5.p5 .pf-hv5-shard-3{opacity:0;transform:translate(50px,40px) scale(0.92);transition-delay:0.16s}
.pf-hero-v5.p5 .pf-hv5-shard-4{opacity:0;transform:translate(-40px,40px) scale(0.92);transition-delay:0.24s}

/* Bottom rule */
.pf-hv5-rule{
  position:absolute;left:48px;right:48px;bottom:48px;z-index:5;
  display:flex;justify-content:space-between;align-items:center;
  font-size:0.68rem;font-weight:600;letter-spacing:3px;text-transform:uppercase;color:rgba(207,194,244,0.75);
}
.pf-hv5-rule-line{flex:1;height:1px;background:rgba(207,194,244,0.25);margin:0 24px}

@media(max-width:820px){
  .pf-hv5-shard-1,.pf-hv5-shard-2{width:32vw}
  .pf-hv5-stack{padding:0 22vw}
  .pf-hv5-rule{left:24px;right:24px;bottom:24px;font-size:0.6rem}
  .pf-hv5-count{top:20px;right:24px}
}
@media(max-width:560px){
  .pf-hv5-shard-1,.pf-hv5-shard-2{width:34vw}
  .pf-hv5-stack{padding:0 20vw}
}
/* --- Mobile: drop the decorative background canvas animations (hero wavy,
       Brand DNA waves, New Era vortex). Keep the pixel-equalizer canvases
       running on every viewport — they're small and intentional. --- */
@media(max-width:768px){
  /* Hero — kill wavy canvas, replace with static gradient, fade-only shards */
  .pf-hv5-wavy{display:none}
  .pf-hero-v5{
    background:
      radial-gradient(ellipse at 18% 28%, rgba(124,58,237,0.38), transparent 62%),
      radial-gradient(ellipse at 82% 72%, rgba(99,102,241,0.32), transparent 62%),
      radial-gradient(ellipse at 50% 50%, rgba(54,67,186,0.22), transparent 70%),
      #0A0838;
  }
  .pf-hv5-shard{
    transform:none !important;
    transition:opacity 0.55s ease !important;
  }
  .pf-hero-v5.p5 .pf-hv5-shard-1,
  .pf-hero-v5.p5 .pf-hv5-shard-2,
  .pf-hero-v5.p5 .pf-hv5-shard-3,
  .pf-hero-v5.p5 .pf-hv5-shard-4{transform:none !important}

  /* Other decorative canvases — hide entirely on mobile */
  .pf-dna-waves,
  .pf-ne-vortex{display:none}
}
@media(prefers-reduced-motion:reduce){
  .pf-hv5-word,.pf-hv5-shard{
    opacity:1 !important;transform:none !important;transition:none !important;
  }
  .pf-hv5-wavy{display:none}
}

/* =========================================
   FALLBACK — Safari (all versions) and JS-disabled
   =========================================
   The inline <head> script adds .js to <html> when JS runs, and .pf-safari
   if the browser is Apple WebKit. When JS is OFF, the initial class="no-js"
   stays, and these rules apply. When Safari runs, .pf-safari applies the
   same rules. Swaps decorative canvas animations for pre-rendered static
   images, and swaps the pixel equalizers for the logo-baked GIF. */

/* Base state: GIFs hidden on desktop non-Safari (canvas runs); revealed in fallback. */
.pf-dna-eq-gif,
.pf-preloader-gif{
  display:none;
  position:absolute;
  inset:0;
  width:100%;
  height:100%;
  object-fit:fill;
  border-radius:4px;
  pointer-events:none;
}

/* Hide decorative bg canvases (they'd be blank without JS, animated+broken in Safari) */
.no-js .pf-hv5-wavy,
.no-js .pf-dna-waves,
.no-js .pf-ne-vortex,
.pf-safari .pf-hv5-wavy,
.pf-safari .pf-dna-waves,
.pf-safari .pf-ne-vortex{display:none !important}

/* Static wave images as section backgrounds */
.no-js .pf-hero-v5,
.pf-safari .pf-hero-v5{
  background:
    linear-gradient(rgba(10,8,56,0.2), rgba(10,8,56,0.4)),
    url('../images/fallback-hero-wave.jpg') center/cover no-repeat,
    #0A0838 !important;
}
.no-js .pf-brand-dna,
.pf-safari .pf-brand-dna{
  background:url('../images/fallback-dna-waves.jpg') center/cover no-repeat !important;
}
.no-js .pf-new-era,
.pf-safari .pf-new-era{
  background:
    linear-gradient(rgba(10,8,56,0.5), rgba(10,8,56,0.65)),
    url('../images/fallback-ne-vortex.jpg') center/cover no-repeat,
    #0A0838 !important;
}

/* Swap live equalizer canvases for pre-rendered GIF (logo baked in).
   Hide the separate logo-wrap elements since the logo is already in the GIF. */
.no-js .pf-dna-eq-canvas,
.no-js .pf-preloader-canvas,
.no-js .pf-dna-eq-logo-wrap,
.no-js .pf-preloader-logo-wrap,
.pf-safari .pf-dna-eq-canvas,
.pf-safari .pf-preloader-canvas,
.pf-safari .pf-dna-eq-logo-wrap,
.pf-safari .pf-preloader-logo-wrap{display:none !important}
.no-js .pf-dna-eq-gif,
.no-js .pf-preloader-gif,
.pf-safari .pf-dna-eq-gif,
.pf-safari .pf-preloader-gif{display:block !important}

/* Mobile: use GIF instead of canvas animation for preloader + Brand DNA equalizer */
@media(max-width:768px){
  .pf-dna-eq-canvas,
  .pf-preloader-canvas,
  .pf-dna-eq-logo-wrap,
  .pf-preloader-logo-wrap{display:none !important}
  .pf-dna-eq-gif,
  .pf-preloader-gif{display:block !important}
}

/* Without JS, the preloader stays on screen forever — force-hide so the page is usable. */
.no-js .pf-preloader{display:none !important}
.no-js body.pf-preloading{overflow:auto !important}

/* Without JS, reveal-animated content would be permanently invisible.
   Force it visible so the page reads as a static site. */
.no-js .reveal,
.no-js .stagger > *,
.no-js .pf-brand-dna-text,
.no-js .pf-dna-eq,
.no-js .pf-hv5-word,
.no-js .pf-hv5-shard{
  opacity:1 !important;
  transform:none !important;
}
/* The hero shard imgs get their src set by JS — hide them in no-JS to avoid broken placeholders. */
.no-js .pf-hv5-shard img{display:none !important}

/* =========================================
   PRODUCTS PAGE — new catalogue component (§8 of productupdatesplan.md)
   Sidebar filter + search + grid + mobile bottom-sheet.
   ========================================= */
.pf-products-section{padding:64px 0 96px}
.pf-products-shell{
  display:grid;
  grid-template-columns:280px 1fr;
  gap:48px;
  align-items:start;
}

/* SIDEBAR */
.pf-products-sidebar{
  position:sticky;
  top:calc(var(--nav-height) + 24px);
}
.pf-cat-search{
  width:100%;
  padding:11px 14px;
  border:1px solid var(--gray-200);
  border-radius:var(--radius-sm);
  font:inherit;
  font-size:0.88rem;
  color:var(--gray-900);
  background:var(--white);
  transition:border-color 0.2s;
  margin-bottom:24px;
}
.pf-cat-search:focus{outline:none;border-color:var(--pfizer-indigo)}
.pf-cat-search::placeholder{color:var(--gray-500)}

.pf-cat-title{
  font-size:0.72rem;
  font-weight:800;
  letter-spacing:2px;
  text-transform:uppercase;
  color:var(--gray-700);
  margin-bottom:14px;
}
.pf-cat-list{list-style:none;padding:0;margin:0}
.pf-cat-item{margin-bottom:6px}
.pf-cat-btn{
  width:100%;
  text-align:left;
  padding:11px 14px;
  border:1px solid var(--gray-200);
  border-radius:var(--radius-sm);
  background:var(--white);
  color:var(--gray-800);
  font:inherit;
  font-size:0.86rem;
  font-weight:600;
  cursor:pointer;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
  transition:border-color 0.18s, background 0.18s, color 0.18s;
}
.pf-cat-btn:hover{border-color:var(--pfizer-indigo);background:var(--pfizer-blue-light)}
.pf-cat-btn.is-active{
  background:var(--pfizer-indigo);
  color:var(--white);
  border-color:var(--pfizer-indigo);
}
.pf-cat-count{
  font-size:0.72rem;
  font-weight:700;
  opacity:0.75;
}

/* COUNT ROW + CLEAR */
.pf-prod-count-row{
  display:flex;
  align-items:center;
  gap:12px;
  margin-bottom:20px;
}
.pf-prod-count{
  font-size:0.82rem;
  color:var(--gray-600);
  font-weight:500;
  letter-spacing:0.3px;
}
.pf-prod-count strong{color:var(--gray-900);font-weight:800}
.pf-prod-clear{
  display:none;
  align-items:center;
  gap:6px;
  padding:5px 12px;
  font:inherit;
  font-size:0.72rem;
  font-weight:700;
  color:var(--pfizer-indigo);
  background:rgba(54,67,186,0.08);
  border:1px solid rgba(54,67,186,0.25);
  border-radius:999px;
  cursor:pointer;
  transition:background 0.2s;
  white-space:nowrap;
}
.pf-prod-clear svg{width:12px;height:12px;stroke:currentColor;stroke-width:2.5;fill:none}
.pf-prod-clear:hover{background:rgba(54,67,186,0.15)}
.pf-prod-clear.is-visible{display:inline-flex}

/* GRID + CARDS */
.pf-prod-grid{
  display:grid;
  grid-template-columns:repeat(3, 1fr);
  gap:20px;
}
.pf-prod-card{
  display:flex;
  flex-direction:column;
  background:var(--white);
  border:1px solid var(--gray-200);
  border-radius:12px;
  overflow:hidden;
  text-decoration:none;
  color:inherit;
  transition:transform 0.25s ease, box-shadow 0.25s ease, border-color 0.25s ease;
}
.pf-prod-card:hover{
  transform:translateY(-3px);
  box-shadow:0 14px 32px rgba(54,67,186,0.10);
  border-color:var(--pfizer-indigo);
}
.pf-prod-card-img{
  aspect-ratio:4/3;
  background:#F5F7FC;
  display:flex;
  align-items:center;
  justify-content:center;
  overflow:hidden;
}
.pf-prod-card-img img{
  max-width:84%;
  max-height:84%;
  object-fit:contain;
  display:block;
}
.pf-prod-card-body{padding:16px 18px 18px;display:flex;flex-direction:column;gap:6px}
.pf-prod-card-cat{
  font-size:0.66rem;
  font-weight:800;
  letter-spacing:1.5px;
  text-transform:uppercase;
  color:var(--pfizer-indigo);
}
.pf-prod-card-body h5{
  font-size:0.95rem;
  font-weight:700;
  color:var(--gray-900);
  margin:0;
  line-height:1.35;
}
.pf-prod-card-link{
  margin-top:6px;
  display:inline-flex;
  align-items:center;
  gap:4px;
  font-size:0.78rem;
  font-weight:600;
  color:var(--pfizer-indigo);
}
.pf-prod-card-link svg{width:12px;height:12px;stroke:currentColor;stroke-width:2;fill:none}
.pf-prod-no-results{
  padding:48px 24px;
  text-align:center;
  color:var(--gray-500);
  border:1px dashed var(--gray-200);
  border-radius:12px;
}
.pf-prod-no-results p{margin:0}

/* MOBILE FILTER BAR — hidden on desktop */
.pf-prod-mobile-filter-bar{display:none}

/* BOTTOM-SHEET MODAL — hidden on desktop */
.pf-prod-filter-modal{
  display:none;
  position:fixed;
  inset:0;
  background:rgba(0,0,0,0.4);
  z-index:200;
  opacity:0;
  transition:opacity 0.25s;
}
.pf-prod-filter-modal.is-open{display:flex;align-items:flex-end;opacity:1}
.pf-prod-filter-modal-panel{
  background:var(--white);
  border-radius:20px 20px 0 0;
  padding:24px 20px 32px;
  width:100%;
  max-height:72vh;
  overflow-y:auto;
  transform:translateY(100%);
  transition:transform 0.3s ease;
}
.pf-prod-filter-modal.is-open .pf-prod-filter-modal-panel{transform:translateY(0)}
.pf-prod-filter-modal-head{
  display:flex;justify-content:space-between;align-items:center;
  margin-bottom:18px;
}
.pf-prod-filter-modal-head h3{font-size:1rem;font-weight:800;color:var(--gray-900);margin:0}
.pf-prod-filter-modal-close{
  background:none;border:none;cursor:pointer;padding:4px;color:var(--gray-600);
}
.pf-prod-filter-modal-close svg{width:22px;height:22px;stroke:currentColor;stroke-width:2;fill:none}

/* Responsive */
@media(max-width:1024px){
  .pf-products-shell{grid-template-columns:1fr;gap:28px}
  .pf-products-sidebar{position:static}
  .pf-cat-list{display:grid;grid-template-columns:repeat(2,1fr);gap:8px}
  .pf-cat-item{margin-bottom:0}
  .pf-prod-grid{grid-template-columns:repeat(2,1fr)}
}
@media(max-width:768px){
  .pf-products-section{padding:32px 0 64px}
  .pf-products-sidebar{display:none}
  .pf-prod-mobile-filter-bar{
    display:flex;gap:10px;margin-bottom:16px;
  }
  .pf-prod-mobile-search{
    flex:1;
    padding:10px 14px 10px 36px;
    font:inherit;
    font-size:0.86rem;
    border-radius:999px;
    border:1px solid var(--gray-200);
    color:var(--gray-900);
    background:var(--gray-50) url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%236B7280' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Ccircle cx='11' cy='11' r='8'/%3E%3Cpath d='M21 21l-4.35-4.35'/%3E%3C/svg%3E") 12px center no-repeat;
  }
  .pf-prod-mobile-search:focus{outline:none;border-color:var(--pfizer-indigo)}
  .pf-prod-mobile-filter-btn{
    display:flex;align-items:center;gap:6px;
    padding:10px 16px;
    font:inherit;font-size:0.82rem;font-weight:700;
    border-radius:999px;
    border:1px solid var(--gray-200);
    background:var(--white);
    color:var(--gray-900);
    cursor:pointer;
    white-space:nowrap;
  }
  .pf-prod-mobile-filter-btn svg{width:16px;height:16px;stroke:currentColor;stroke-width:2;fill:none}
  .pf-prod-mobile-filter-btn:hover{border-color:var(--pfizer-indigo);color:var(--pfizer-indigo)}
  .pf-prod-grid{grid-template-columns:1fr}
  .pf-prod-card-img{aspect-ratio:3/2}
}
