/* ============================================================================
   MISSION MAILERS — Public site BLOG  (website visual system)
   Flat cyan accents · serif headlines · clean white · black footer.
   Distinct from the OPRA portal (which uses gradients).
   ============================================================================ */
:root{
  --cyan:#2AB3D6; --cyan-d:#1B93B8; --cyan-soft:#E9F7FB;
  --ink:#15191C;            /* near-black headings */
  --body:#454C52;           /* body copy */
  --muted:#8B949B;          /* meta text */
  --line:#E7EAEC;
  --line-2:#F0F2F4;
  --gray:#F7F8F9;           /* section background */
  --black:#0A0B0C;          /* footer */
  --font-display:'Playfair Display',Georgia,'Times New Roman',serif;
  --font-ui:'Mulish','Segoe UI',system-ui,sans-serif;
  --wrap:1200px;
  --shadow-card:0 1px 2px rgba(20,30,40,.04),0 16px 40px -24px rgba(20,30,40,.28);
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;font-family:var(--font-ui);color:var(--body);background:#fff;-webkit-font-smoothing:antialiased;font-size:16px;line-height:1.6}
img{display:block;max-width:100%}
a{color:inherit;text-decoration:none}
h1,h2,h3,h4{font-family:var(--font-display);color:var(--ink);font-weight:700;line-height:1.12;letter-spacing:-.01em;margin:0}
.wrap{max-width:var(--wrap);margin:0 auto;padding:0 32px}

/* eyebrow */
.eyebrow{font-family:var(--font-ui);font-weight:800;letter-spacing:.18em;text-transform:uppercase;font-size:12px;color:var(--cyan);display:inline-flex;align-items:center;gap:9px}
.eyebrow.center{justify-content:center}

/* pills / buttons */
.pill{display:inline-flex;align-items:center;gap:9px;height:50px;padding:0 26px;border-radius:999px;background:var(--cyan);color:#fff;font-family:var(--font-ui);font-weight:700;font-size:15px;border:0;cursor:pointer;transition:background .16s,transform .12s,box-shadow .16s;white-space:nowrap}
.pill:hover{background:var(--cyan-d);box-shadow:0 14px 30px -12px rgba(42,179,214,.7)}
.pill:active{transform:translateY(1px)}
.pill svg{width:17px;height:17px}
.pill.sm{height:42px;padding:0 20px;font-size:14px}
.pill.ghost{background:transparent;color:var(--ink);border:1.5px solid var(--line)}
.pill.ghost:hover{background:var(--gray);box-shadow:none;border-color:#d8dde0}

/* arrow link */
.arrowlink{display:inline-flex;align-items:center;gap:8px;color:var(--cyan-d);font-weight:800;font-size:14px;font-family:var(--font-ui)}
.arrowlink svg{width:16px;height:16px;transition:transform .16s}
.arrowlink:hover svg{transform:translateX(4px)}

/* ---------------- top nav (white, sticky) ---------------- */
.nav{position:sticky;top:0;z-index:40;background:rgba(255,255,255,.92);backdrop-filter:blur(10px);border-bottom:1px solid var(--line)}
.nav .wrap{display:flex;align-items:center;justify-content:space-between;height:80px}
.nav .logo{display:flex;flex-direction:column;gap:4px;align-items:flex-start}
.nav .logo .mark{width:148px}
.nav .logo .mark svg{width:100%;height:auto;display:block}
.nav .logo .sub{font-weight:800;letter-spacing:.46em;font-size:8px;text-transform:uppercase;color:var(--cyan-d);padding-left:2px}
.nav .links{display:flex;align-items:center;gap:34px}
.nav .links a{font-weight:600;font-size:15px;color:var(--ink);position:relative;padding:4px 0}
.nav .links a.active{color:var(--cyan-d)}
.nav .links a:not(.active):hover{color:var(--cyan-d)}
.nav .links a.active::after{content:"";position:absolute;left:0;right:0;bottom:-2px;height:2px;background:var(--cyan);border-radius:2px}
/* logo theming: dark wordmark + cyan mark on white */
.logo .cls-1{fill:none}.logo .cls-9{clip-path:url(#clippath)}
.logo .cls-8{fill:var(--ink)}
.logo .cls-3,.logo .cls-7{fill:var(--cyan)}

/* ---------------- page masthead ---------------- */
.masthead{padding:64px 0 26px}
.masthead.center{text-align:center;padding:74px 0 30px}
.masthead h1{font-size:54px;margin:14px 0 0}
.masthead.center h1{font-size:60px}
.masthead .lead{font-size:18px;color:var(--body);max-width:60ch;margin:16px 0 0}
.masthead.center .lead{margin:16px auto 0}

/* ---------------- category filter ---------------- */
.filters{display:flex;flex-wrap:wrap;gap:10px;padding:6px 0 4px}
.filters.center{justify-content:center}
.chip{font-family:var(--font-ui);font-weight:700;font-size:13.5px;color:var(--body);background:#fff;border:1.5px solid var(--line);border-radius:999px;padding:9px 18px;cursor:pointer;transition:.15s;white-space:nowrap}
.chip:hover{border-color:var(--cyan);color:var(--cyan-d)}
.chip.on{background:var(--ink);border-color:var(--ink);color:#fff}

/* ---------------- cards ---------------- */
.cat-tag{display:inline-flex;align-items:center;font-family:var(--font-ui);font-weight:800;font-size:11px;letter-spacing:.08em;text-transform:uppercase;color:var(--cyan-d);background:var(--cyan-soft);padding:5px 11px;border-radius:6px;white-space:nowrap}
.meta{display:flex;align-items:center;gap:8px;font-family:var(--font-ui);font-size:13px;color:var(--muted);font-weight:600}
.meta .dot{width:3px;height:3px;border-radius:50%;background:var(--muted);flex-shrink:0}
.meta .au{color:var(--body)}

/* base card (image-top) */
.card{display:flex;flex-direction:column;background:#fff;border:1px solid var(--line);border-radius:14px;overflow:hidden;cursor:pointer;transition:transform .18s,box-shadow .18s,border-color .18s}
.card:hover{transform:translateY(-4px);box-shadow:var(--shadow-card);border-color:transparent}
.card .ph{aspect-ratio:16/10;overflow:hidden;background:var(--gray);position:relative}
.card .ph img{width:100%;height:100%;object-fit:cover;transition:transform .35s ease}
.card:hover .ph img{transform:scale(1.04)}
.card .body{padding:20px 22px 24px;display:flex;flex-direction:column;gap:12px;flex:1}
.card .tagrow{display:flex}
.card h3{font-size:21px;line-height:1.22}
.card:hover h3{color:var(--cyan-d)}
.card .ex{font-size:14.5px;color:var(--body);margin:0;flex:1}
.card .cardmeta{margin-top:6px}

/* grids */
.grid3{display:grid;grid-template-columns:repeat(3,1fr);gap:28px}
.grid2{display:grid;grid-template-columns:repeat(2,1fr);gap:28px}

/* ---------------- featured (variant A) ---------------- */
.featured{display:grid;grid-template-columns:1.15fr 1fr;gap:0;border:1px solid var(--line);border-radius:18px;overflow:hidden;background:#fff;cursor:pointer;transition:box-shadow .2s}
.featured:hover{box-shadow:var(--shadow-card)}
.featured .ph{position:relative;min-height:420px;background:var(--gray)}
.featured .ph img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.featured .ph .badge{position:absolute;top:20px;left:20px;background:#fff;color:var(--cyan-d);font-family:var(--font-ui);font-weight:800;font-size:11px;letter-spacing:.1em;text-transform:uppercase;padding:7px 13px;border-radius:8px;box-shadow:0 6px 16px -6px rgba(0,0,0,.25)}
.featured .body{padding:46px 48px;display:flex;flex-direction:column;justify-content:center;gap:18px}
.featured .body .eyebrow{margin-bottom:-2px}
.featured .body h2{font-size:38px;line-height:1.1}
.featured:hover .body h2{color:var(--cyan-d)}
.featured .body .ex{font-size:16.5px;color:var(--body);margin:0;max-width:46ch}

/* ---------------- magazine split (variant C) ---------------- */
.split{display:grid;grid-template-columns:1.4fr 1fr;gap:28px}
.hero-big{position:relative;border-radius:18px;overflow:hidden;min-height:520px;cursor:pointer;color:#fff;display:flex;flex-direction:column;justify-content:flex-end}
.hero-big img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.hero-big::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(10,15,20,.05) 0%,rgba(10,15,20,.18) 42%,rgba(8,14,20,.9) 100%)}
.hero-big .ct{position:relative;z-index:2;padding:44px 46px;display:flex;flex-direction:column;gap:16px}
.hero-big .ct .eyebrow{color:#fff}
.hero-big .ct .eyebrow::before{background:#fff}
.hero-big .ct h2{color:#fff;font-size:40px;line-height:1.08;max-width:18ch}
.hero-big .ct .ex{color:rgba(255,255,255,.86);font-size:16px;margin:0;max-width:44ch}
.hero-big .ct .meta{color:rgba(255,255,255,.8)}
.hero-big .ct .meta .dot,.hero-big .ct .meta .au{background:rgba(255,255,255,.8);color:rgba(255,255,255,.92)}
.hero-big .ct .meta .au{background:none}
.picks{display:flex;flex-direction:column;gap:20px}
.pick{display:grid;grid-template-columns:118px 1fr;gap:18px;cursor:pointer;align-items:center}
.pick .ph{width:118px;height:104px;border-radius:12px;overflow:hidden;background:var(--gray);flex-shrink:0;position:relative}
.pick .ph img{width:100%;height:100%;object-fit:cover}
.pick .pb{display:flex;flex-direction:column;gap:8px}
.pick h3{font-size:18px;line-height:1.2}
.pick:hover h3{color:var(--cyan-d)}
.pick .meta{font-size:12px}
.picks .pdiv{height:1px;background:var(--line)}

/* ---------------- horizontal list rows (variant C) ---------------- */
.rows{display:flex;flex-direction:column}
.row{display:grid;grid-template-columns:300px 1fr auto;gap:32px;align-items:center;padding:28px 0;border-top:1px solid var(--line);cursor:pointer}
.row:hover h3{color:var(--cyan-d)}
.row .ph{width:300px;aspect-ratio:16/10;border-radius:12px;overflow:hidden;background:var(--gray);position:relative}
.row .ph img{width:100%;height:100%;object-fit:cover;transition:transform .35s ease}
.row:hover .ph img{transform:scale(1.03)}
.row .rb{display:flex;flex-direction:column;gap:12px}
.row h3{font-size:25px;line-height:1.18;max-width:24ch}
.row .ex{margin:0;font-size:15px;max-width:60ch}
.row .rarrow{width:52px;height:52px;border-radius:50%;border:1.5px solid var(--line);display:flex;align-items:center;justify-content:center;color:var(--cyan-d);transition:.16s}
.row:hover .rarrow{background:var(--cyan);border-color:var(--cyan);color:#fff}
.row .rarrow svg{width:20px;height:20px}

/* ---------------- newsletter ---------------- */
.news{background:var(--black);color:#fff;border-radius:22px;padding:56px 56px;display:grid;grid-template-columns:1.1fr 1fr;gap:40px;align-items:center;position:relative;overflow:hidden}
.news::before{content:"";position:absolute;width:420px;height:420px;border-radius:50%;right:-120px;top:-160px;background:radial-gradient(circle,rgba(42,179,214,.4),transparent 62%)}
.news .nl .eyebrow{color:var(--cyan)}
.news .nl .eyebrow::before{background:var(--cyan)}
.news .nl h2{color:#fff;font-size:34px;margin:12px 0 0}
.news .nl p{color:rgba(255,255,255,.7);font-size:15.5px;margin:12px 0 0;max-width:42ch}
.news form{position:relative;z-index:2;display:flex;flex-direction:column;gap:12px}
.news .inrow{display:flex;gap:12px}
.news input{flex:1;height:54px;border:0;border-radius:999px;padding:0 22px;font:500 15px var(--font-ui);background:rgba(255,255,255,.1);color:#fff;border:1.5px solid rgba(255,255,255,.16)}
.news input::placeholder{color:rgba(255,255,255,.5)}
.news input:focus{outline:none;border-color:var(--cyan);background:rgba(255,255,255,.14)}
.news .note{font-size:12.5px;color:rgba(255,255,255,.45)}
.news .note a{color:rgba(255,255,255,.7);text-decoration:underline}

/* eyebrow line decoration (dark contexts handled above) */
.eyebrow::before{content:"";width:26px;height:2px;background:var(--cyan);display:inline-block}

/* ---------------- footer (black, like site) ---------------- */
.foot{background:var(--black);color:rgba(255,255,255,.62);margin-top:80px;padding:64px 0 30px}
.foot .top{display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:32px;padding-bottom:42px;border-bottom:1px solid rgba(255,255,255,.1)}
.foot .logo .mark{width:150px}
.foot .logo .cls-8{fill:#fff}
.foot .logo .cls-3,.foot .logo .cls-7{fill:var(--cyan)}
.foot .logo .sub{color:rgba(255,255,255,.55)}
.foot .blurb{margin:18px 0 0;font-size:14px;line-height:1.6;max-width:34ch}
.foot h4{color:#fff;font-family:var(--font-ui);font-weight:800;font-size:13px;letter-spacing:.08em;text-transform:uppercase;margin:0 0 18px}
.foot .col a{display:block;font-size:14.5px;margin-bottom:11px;color:rgba(255,255,255,.62);transition:.15s}
.foot .col a:hover{color:var(--cyan)}
.foot .bottom{display:flex;align-items:center;justify-content:space-between;padding-top:26px;font-size:13px;color:rgba(255,255,255,.4)}
.foot .social{display:flex;gap:10px}
.foot .social a{width:36px;height:36px;border-radius:50%;border:1px solid rgba(255,255,255,.16);display:flex;align-items:center;justify-content:center;color:rgba(255,255,255,.6);transition:.15s}
.foot .social a:hover{background:var(--cyan);border-color:var(--cyan);color:#fff}
.foot .social svg{width:16px;height:16px}

/* ---------------- variation switcher (design tool overlay) ---------------- */
.switcher{position:fixed;bottom:22px;left:50%;transform:translateX(-50%);z-index:90;background:rgba(16,22,27,.92);backdrop-filter:blur(12px);border:1px solid rgba(255,255,255,.12);border-radius:999px;padding:7px 7px 7px 18px;display:flex;align-items:center;gap:12px;box-shadow:0 20px 50px -16px rgba(0,0,0,.6)}
.switcher .lab{color:rgba(255,255,255,.55);font-family:var(--font-ui);font-weight:800;font-size:11px;letter-spacing:.12em;text-transform:uppercase}
.switcher .seg{display:flex;gap:4px}
.switcher button{border:0;background:none;color:rgba(255,255,255,.7);font-family:var(--font-ui);font-weight:700;font-size:13px;padding:9px 16px;border-radius:999px;cursor:pointer;transition:.15s;white-space:nowrap}
.switcher button:hover{color:#fff}
.switcher button.on{background:var(--cyan);color:#fff}

/* variation visibility */
.variant{display:none}
.variant.show{display:block}
section.block{padding:18px 0}

/* responsive */
@media (max-width:980px){
  .grid3{grid-template-columns:repeat(2,1fr)}
  .featured,.split,.news{grid-template-columns:1fr}
  .featured .ph{min-height:280px}
  .foot .top{grid-template-columns:1fr 1fr}
  .nav .links{display:none}
}
@media (max-width:640px){
  .grid3,.grid2{grid-template-columns:1fr}
  .masthead h1,.masthead.center h1{font-size:38px}
  .row{grid-template-columns:1fr;gap:14px}.row .ph{width:100%}.row .rarrow{display:none}
  .wrap{padding:0 20px}
}
