  :root{
    --red:#cd061e; --red-2:#e8203a;
    --ink:#1d1d1f; --muted:#6e6e73; --body:#3a3a3e;
    --page:#f2f2f5; --tile:#ffffff;
    --ring:rgba(0,0,0,.06);
    --shadow:0 1px 2px rgba(0,0,0,.05), 0 10px 28px rgba(0,0,0,.06);
    --shadow-hi:0 6px 14px rgba(0,0,0,.08), 0 22px 50px rgba(0,0,0,.12);
    --radius:24px;
  }
  *{box-sizing:border-box}
  html{scroll-behavior:smooth}
  html.gsap{scroll-behavior:auto} /* GSAP ScrollTo handles smoothing */
  body{margin:0;background:var(--page);color:var(--ink);
    font:16px/1.6 -apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Helvetica,Arial,"Noto Sans",sans-serif;
    -webkit-font-smoothing:antialiased;overflow-x:hidden}
  a{color:inherit}
  ::selection{background:rgba(205,6,30,.85);color:#fff}

  /* ---------- BENTO HERO ---------- */
  #stage{min-height:100vh;display:grid;place-items:center;padding:clamp(16px,3vw,40px);position:relative;isolation:isolate;overflow:hidden}

  .bento{position:relative;z-index:2;width:min(1180px,95vw);height:min(700px,84vh);display:grid;gap:14px;
    grid-template-columns:repeat(6,1fr);grid-template-rows:repeat(4,1fr);
    grid-template-areas:"in in nw co mc mc" "tm le lo lo re db" "tm cn lo lo rd db" "cd cd da rm ar ar"}
  .tw{will-change:transform;min-width:0}

  /* ----- liquid glass tiles ----- */
  .tile{position:relative;width:100%;height:100%;display:flex;flex-direction:column;justify-content:space-between;gap:8px;
    text-align:left;padding:clamp(13px,1.25vw,19px);
    background:linear-gradient(140deg,rgba(255,255,255,.66),rgba(255,255,255,.38));
    -webkit-backdrop-filter:blur(18px) saturate(1.5);backdrop-filter:blur(18px) saturate(1.5);
    border:1px solid rgba(255,255,255,.6);border-radius:var(--radius);
    color:var(--ink);cursor:pointer;overflow:hidden}
  .tile:focus-visible{outline:2px solid var(--red);outline-offset:2px}
  .tile .ic{width:30px;height:30px;color:var(--red);flex:0 0 auto}
  .tile .ic svg{width:100%;height:100%;display:block}
  .tile .bd{display:flex;flex-direction:column;min-width:0}
  .tile .lbl{font-size:clamp(14px,1.3vw,18px);font-weight:600;line-height:1.18;letter-spacing:-.01em}
  .tile .desc{display:none;margin-top:7px;font-size:12.5px;line-height:1.38;color:var(--muted);font-weight:400}
  .tile .arw{display:none}
  .tile.big .lbl{font-size:clamp(16px,1.65vw,23px);font-weight:700}
  .tile.big .desc{display:block}
  .tile .sheen{display:none}
  /* accents (glassy) */
  .tile.acc-red{background:linear-gradient(145deg,rgba(229,28,55,.86),rgba(172,4,24,.9));border-color:rgba(255,255,255,.28);color:#fff}
  .tile.acc-dark{background:linear-gradient(160deg,rgba(40,44,53,.84),rgba(17,19,24,.9));border-color:rgba(255,255,255,.16);color:#fff}
  .tile.acc-red .ic,.tile.acc-dark .ic{color:#fff}
  .tile.acc-red .desc,.tile.acc-dark .desc{color:rgba(255,255,255,.84)}
  .tile.acc-red .arw,.tile.acc-dark .arw{color:rgba(255,255,255,.85)}
  .tile.acc-red .sheen,.tile.acc-dark .sheen{background:radial-gradient(240px circle at var(--mx,50%) var(--my,28%),rgba(255,255,255,.28),rgba(255,255,255,0) 65%)}
  /* image tiles */
  .tile.img{background-size:cover;background-position:center;border-color:rgba(255,255,255,.4);color:#fff;justify-content:flex-end;
    -webkit-backdrop-filter:none;backdrop-filter:none}
  .tile.img::after{content:"";position:absolute;inset:0;z-index:0;background:linear-gradient(to top,rgba(0,0,0,.80),rgba(0,0,0,.28) 44%,rgba(0,0,0,0) 74%)}
  .tile.img>*{position:relative;z-index:1}
  .tile.img .ic{display:none}
  .tile.img .desc{display:none}
  .tile.img .lbl{color:#fff;text-shadow:0 1px 4px rgba(0,0,0,.6)}
  .tile.img .arw{color:#fff}
  .tile.img .sheen{z-index:3;background:radial-gradient(260px circle at var(--mx,50%) var(--my,28%),rgba(255,255,255,.30),rgba(255,255,255,0) 65%)}
  /* center logo tile */
  .tile.logo{grid-area:lo;align-items:center;justify-content:center;text-align:center;gap:16px;
    background:linear-gradient(160deg,rgba(255,255,255,.74),rgba(255,255,255,.44));
    -webkit-backdrop-filter:blur(22px) saturate(1.6);backdrop-filter:blur(22px) saturate(1.6);
    border:2px solid var(--red);
    animation-delay:60ms}
  .tile.logo img{width:min(60%,290px);height:auto;display:block;filter:drop-shadow(0 10px 26px rgba(205,6,30,.18))}
  .tile.logo .sub{color:var(--muted);font-size:clamp(9px,.85vw,11.5px);letter-spacing:.22em;text-transform:uppercase;padding-left:.22em;font-weight:600}
  /* no backdrop-filter support → solid fallbacks */
  @supports not ((backdrop-filter:blur(2px)) or (-webkit-backdrop-filter:blur(2px))){
    .tile{background:#fff}
    .tile.logo{background:radial-gradient(120% 120% at 50% 35%,#fff,#f4f4f6)}
    .tile.acc-red{background:linear-gradient(145deg,#e8203a,#b30518)}
    .tile.acc-dark{background:linear-gradient(160deg,#2c3037,#15171c)}
  }

  .scroll-hint{position:fixed;left:50%;bottom:18px;transform:translateX(-50%);z-index:5;color:var(--muted);font-size:11px;letter-spacing:.3em;
    text-transform:uppercase;display:flex;align-items:center;gap:9px;pointer-events:none;animation:hp 2.6s ease-in-out infinite;transition:opacity .3s}
  .scroll-hint.hide{opacity:0;animation:none}
  .scroll-hint .m{width:20px;height:31px;border:1.5px solid var(--muted);border-radius:11px;position:relative}
  .scroll-hint .m::after{content:"";position:absolute;left:50%;top:6px;width:3px;height:6px;border-radius:2px;background:var(--muted);transform:translateX(-50%);animation:wh 1.6s ease-in-out infinite}
  @keyframes wh{0%{opacity:0;top:6px}30%{opacity:1}60%{opacity:1;top:14px}100%{opacity:0;top:14px}}
  @keyframes hp{0%,100%{opacity:.5}50%{opacity:.85}}

  /* ---------- floating buttons ---------- */
  .fab{position:fixed;right:24px;bottom:24px;z-index:60;display:flex;align-items:center;gap:10px;
    opacity:0;transform:translateY(16px) scale(.96);pointer-events:none;transition:opacity .35s ease, transform .35s cubic-bezier(.2,.7,.2,1)}
  .fab.show{opacity:1;transform:none;pointer-events:auto}
  .cta{display:inline-flex;align-items:center;gap:9px;padding:13px 21px;border:none;border-radius:999px;cursor:pointer;
    background:linear-gradient(145deg,#e8203a,#b30518);color:#fff;font-weight:600;font-size:15px;box-shadow:0 12px 30px rgba(205,6,30,.42);transition:transform .25s, box-shadow .25s}
  .cta:hover{transform:translateY(-2px);box-shadow:0 16px 40px rgba(205,6,30,.52)}
  .cta svg{width:19px;height:19px}
  .fab-up{display:inline-flex;align-items:center;justify-content:center;width:48px;height:48px;border-radius:50%;cursor:pointer;
    background:rgba(255,255,255,.78);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);
    color:var(--ink);border:1px solid var(--ring);box-shadow:0 10px 26px rgba(0,0,0,.14);transition:transform .25s, box-shadow .25s, border-color .25s, color .25s}
  .fab-up:hover{transform:translateY(-2px);border-color:var(--red);color:var(--red);box-shadow:0 14px 32px rgba(0,0,0,.18)}
  .fab-up svg{width:20px;height:20px}

  /* ---------- content sections ---------- */
  main:not(.subpage) section{min-height:84vh;padding:11vh clamp(20px,7vw,110px) 9vh;display:flex;flex-direction:column;justify-content:center;align-items:flex-start;position:relative;background:var(--page);border-top:1px solid var(--ring);overflow:hidden}
  main:not(.subpage) section:nth-of-type(even){background:#fff}
  .eyebrow{color:var(--red);font-size:12px;letter-spacing:.32em;text-transform:uppercase;font-weight:700;margin:0 0 14px}
  main:not(.subpage) section h2{margin:0 0 26px;font-size:clamp(30px,5vw,58px);line-height:1.05;font-weight:800;letter-spacing:-.025em;max-width:18ch}
  .sec-index{position:absolute;right:clamp(18px,6vw,80px);top:8vh;color:rgba(0,0,0,.05);font-weight:800;font-size:clamp(46px,10vw,140px);line-height:1;user-select:none;z-index:0}
  .rich{width:100%;max-width:1000px;position:relative;z-index:1}
  .rich .lead{font-size:clamp(18px,2.1vw,26px);line-height:1.5;color:var(--ink);font-weight:500;max-width:30ch}
  .rich p{color:var(--body);font-size:clamp(15px,1.4vw,17.5px);line-height:1.7;margin:0 0 15px;max-width:72ch}
  .rich h3{font-size:clamp(17px,1.9vw,22px);font-weight:700;margin:26px 0 12px;letter-spacing:-.01em}
  .rich ul{margin:0 0 16px;padding:0;list-style:none}
  .rich li{position:relative;padding-left:22px;margin:0 0 9px;color:var(--body);font-size:clamp(14.5px,1.35vw,17px);line-height:1.6;max-width:72ch}
  .rich li::before{content:"";position:absolute;left:1px;top:.62em;width:7px;height:7px;border-radius:50%;background:var(--red)}
  .rich li ul{margin:9px 0 0}
  .rich li li::before{background:#c9ccd2}
  .rich a{color:var(--red);text-decoration:none;border-bottom:1px solid rgba(205,6,30,.32);transition:border-color .2s}
  .rich a:hover{border-color:var(--red)}
  .rich strong{color:var(--ink)}
  .cols{display:grid;grid-template-columns:1.05fr .95fr;gap:40px;align-items:start}
  .gallery{display:grid;grid-template-columns:repeat(auto-fit,minmax(170px,1fr));gap:14px;margin:6px 0 4px}
  .gallery img{width:100%;height:190px;object-fit:contain;background:#fff;border:1px solid var(--ring);border-radius:14px;padding:8px;display:block}
  .col-media img{width:100%;border-radius:16px;box-shadow:var(--shadow);display:block;margin:0 0 14px;border:1px solid var(--ring)}
  .news-poster{float:right;width:300px;max-width:40%;margin:4px 0 16px 26px;border-radius:14px;box-shadow:var(--shadow);border:1px solid var(--ring)}
  .toplink{margin-top:36px;align-self:flex-start;display:inline-flex;gap:8px;text-decoration:none;font-size:13px;border:1px solid var(--ring);border-radius:999px;padding:9px 16px;background:#fff;transition:.25s;position:relative;z-index:1}
  .toplink:hover{border-color:var(--red);color:var(--red)}

  /* team */
  .team-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:26px;width:100%;max-width:1120px}
  .member{background:#fff;border:1px solid var(--ring);border-radius:20px;padding:24px;box-shadow:var(--shadow);transition:transform .25s, box-shadow .25s}
  .member:hover{transform:translateY(-4px);box-shadow:var(--shadow-hi)}
  .member .photo{width:104px;height:104px;border-radius:50%;background-size:cover;background-position:center top;border:3px solid #f0f0f2;margin-bottom:16px;box-shadow:0 6px 18px rgba(0,0,0,.12)}
  /* portraits that would crop badly under cover: show the full photo, blended into the matching wall tone */
  .member .photo.contain,.tile .team-photos .tp.contain{background-size:contain;background-repeat:no-repeat;background-position:center;background-color:#c1bead}
  .member h4{margin:0 0 3px;font-size:19px;font-weight:700}
  .member .role{color:var(--red);font-size:13px;font-weight:600;margin:0 0 12px}
  .member .exp{color:var(--body);font-size:14px;line-height:1.55;margin:0 0 14px}
  .member .links{display:flex;gap:10px;align-items:center;flex-wrap:wrap}
  .member .links a{font-size:13px;color:var(--red);text-decoration:none;border-bottom:1px solid rgba(205,6,30,.3)}
  .member .mail{display:inline-flex;align-items:center;justify-content:center;width:34px;height:34px;border-radius:50%;background:#faf0f1;border:1px solid rgba(205,6,30,.18);border-bottom:1px solid rgba(205,6,30,.18)}
  .member .mail svg{width:16px;height:16px}

  /* contact */
  .contact-card{display:grid;gap:14px;background:#fff;border:1px solid var(--ring);border-radius:22px;padding:30px 32px;box-shadow:var(--shadow);max-width:560px}
  .contact-card .row{display:flex;gap:14px;align-items:flex-start}
  .contact-card .row svg{width:20px;height:20px;color:var(--red);flex:0 0 auto;margin-top:2px}
  .contact-card .row b{display:block;font-size:12px;text-transform:uppercase;letter-spacing:.06em;color:var(--muted);font-weight:600;margin-bottom:1px}
  .contact-card .row span,.contact-card .row a{font-size:16px;color:var(--ink)}

  footer{padding:42px;text-align:center;color:var(--muted);font-size:12.5px;border-top:1px solid var(--ring);background:#fff}
  .badge{display:inline-block;margin-bottom:10px;font-size:11px;letter-spacing:.28em;text-transform:uppercase;color:var(--red)}

  /* ---------- mobile ---------- */
  @media (max-width:860px){
    .scroll-hint{display:none}
    #stage{min-height:0;padding:38px 16px 24px}
    .bento{width:100%;height:auto;display:flex;flex-direction:column;gap:12px}
    .tw{transform:none!important}
    .tile{height:auto;min-height:96px;-webkit-backdrop-filter:blur(12px) saturate(1.3);backdrop-filter:blur(12px) saturate(1.3)}
    .tile.logo{order:-1;min-height:210px}
    .tile.logo img{width:min(72%,270px)}
    .tile.logo .sub{letter-spacing:.16em;font-size:9.5px}
    .tile .desc{display:block}
    .tile.img .desc{display:none}
    .fab{right:16px;bottom:16px}
    .cta{padding:12px 18px;font-size:14px}
    .fab-up{width:44px;height:44px}
    main:not(.subpage) section{padding:64px 20px 56px;min-height:0}
    .cols{grid-template-columns:1fr;gap:22px}
    .news-poster{float:none;width:100%;max-width:320px;margin:0 0 18px}
    .gallery img{height:170px}
  }
  @media (prefers-reduced-motion:reduce){
    html{scroll-behavior:auto}
    .tile{animation:none}
    .scroll-hint,.scroll-hint .m::after{animation:none}
    .fab{transition:opacity .2s}
  }

  /* ======================================================================
     SUBPAGE SHELL + COMPONENTS (shared by all non-home pages)
     ====================================================================== */
  .site-header{position:sticky;top:0;z-index:50;display:flex;align-items:center;justify-content:space-between;
    gap:18px;padding:14px clamp(18px,5vw,56px);
    background:rgba(255,255,255,.72);-webkit-backdrop-filter:blur(16px) saturate(1.4);backdrop-filter:blur(16px) saturate(1.4);
    border-bottom:1px solid var(--ring)}
  .site-header .site-logo{display:inline-flex;align-items:center}
  .site-header .site-logo img{height:30px;width:auto;display:block}
  .site-nav{display:flex;gap:clamp(10px,2vw,26px);align-items:center;flex-wrap:wrap}
  .site-nav a{font-size:14px;font-weight:600;color:var(--ink);text-decoration:none;letter-spacing:-.01em;opacity:.82;transition:opacity .2s,color .2s}
  .site-nav a:hover{opacity:1;color:var(--red)}
  .site-nav a.cta-link{background:linear-gradient(145deg,#e8203a,#b30518);color:#fff;opacity:1;padding:8px 16px;border-radius:999px}
  .site-nav a.cta-link:hover{color:#fff;transform:translateY(-1px)}

  main.subpage{max-width:1080px;margin:0 auto;padding:clamp(34px,6vw,76px) clamp(20px,6vw,56px) 30px}
  .subpage-head{margin:0 0 34px;border-bottom:1px solid var(--ring);padding-bottom:26px}
  .subpage-head h1{margin:0;font-size:clamp(30px,5.2vw,52px);line-height:1.05;font-weight:800;letter-spacing:-.025em}
  .subpage-head .role{color:var(--red);font-weight:600;font-size:clamp(15px,1.7vw,19px);margin:8px 0 0}
  .subpage-intro{margin:18px 0 0;font-size:clamp(16px,1.7vw,19px);line-height:1.55;color:var(--body);max-width:70ch}
  .crumb{display:inline-flex;gap:7px;align-items:center;font-size:13px;color:var(--muted);text-decoration:none;margin-bottom:22px;
    border:1px solid var(--ring);border-radius:999px;padding:7px 15px;background:#fff;transition:.2s}
  .crumb:hover{border-color:var(--red);color:var(--red)}

  /* generic prose on subpages reuses .rich; add headings spacing */
  .subpage .rich h2{font-size:clamp(20px,2.4vw,28px);font-weight:800;letter-spacing:-.02em;margin:34px 0 14px}
  .subpage .rich h2:first-child{margin-top:0}

  /* ---- publication / CV filter toolbar ---- */
  .pub-toolbar{position:sticky;top:60px;z-index:20;display:flex;flex-wrap:wrap;gap:10px;align-items:center;margin:0 0 30px;
    padding:14px;border:1px solid var(--ring);border-radius:16px;
    background:rgba(255,255,255,.82);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);box-shadow:var(--shadow)}
  .pub-toolbar .pub-search{flex:1 1 280px;min-width:0;padding:11px 14px;border:1px solid var(--ring);border-radius:10px;font:inherit;font-size:14px;background:#fff;color:var(--ink)}
  .pub-toolbar select{padding:11px 12px;border:1px solid var(--ring);border-radius:10px;font:inherit;font-size:14px;background:#fff;color:var(--ink);cursor:pointer}
  .pub-toolbar .pub-search:focus,.pub-toolbar select:focus{outline:2px solid var(--red);outline-offset:1px;border-color:transparent}
  .pub-clear{padding:11px 16px;border:1px solid var(--ring);border-radius:10px;background:#fff;font:inherit;font-size:14px;font-weight:600;color:var(--ink);cursor:pointer;transition:.2s}
  .pub-clear:hover{border-color:var(--red);color:var(--red)}
  .pub-count{font-size:13px;color:var(--muted);margin-left:auto;font-weight:600;white-space:nowrap}

  .pub-cat{margin:0 0 34px}
  .pub-cat > h2{display:flex;align-items:baseline;gap:10px;font-size:clamp(17px,2vw,22px);font-weight:700;letter-spacing:-.01em;
    margin:0 0 14px;padding-bottom:9px;border-bottom:1px solid var(--ring)}
  .pub-cat > h2 .cat-count{font-size:13px;color:var(--muted);font-weight:600}
  ol.pub-list,ul.pub-list{margin:0;padding:0;list-style:none;counter-reset:pub}
  .pub-item{position:relative;padding:11px 8px 11px 46px;border-bottom:1px solid rgba(0,0,0,.045);
    font-size:clamp(14px,1.35vw,15.5px);line-height:1.6;color:var(--body)}
  ol.pub-list .pub-item{counter-increment:pub}
  ol.pub-list .pub-item::before{content:counter(pub);position:absolute;left:0;top:11px;width:32px;text-align:right;
    color:var(--muted);font-size:12px;font-variant-numeric:tabular-nums;opacity:.7}
  .pub-item:hover{background:rgba(205,6,30,.025)}
  .pub-item .yr{color:var(--ink);font-weight:600}
  .pub-item[hidden]{display:none}
  .pub-cat[hidden]{display:none}

  /* CV blocks (lists + timeline) */
  .cv-list{margin:0 0 8px;padding:0;list-style:none}
  .cv-list .pub-item{padding-left:24px}
  .cv-list .pub-item::before{content:"";position:absolute;left:2px;top:1.05em;width:7px;height:7px;border-radius:50%;background:var(--red)}
  .cv-timeline{margin:0;padding:0 0 0 22px;list-style:none;border-left:2px solid var(--ring)}
  .cv-timeline .pub-item{padding:6px 8px 18px 22px;border-bottom:none}
  .cv-timeline .pub-item::before{content:"";position:absolute;left:-7px;top:12px;width:11px;height:11px;border-radius:50%;background:var(--red);border:2px solid #fff;box-shadow:0 0 0 1px var(--ring)}
  .cv-block{margin:0 0 12px;color:var(--body);font-size:15.5px;line-height:1.7;max-width:72ch}

  /* ---- news page ---- */
  .news-item{padding:30px 0;border-bottom:1px solid var(--ring)}
  .news-item:first-of-type{padding-top:6px}
  .news-item .news-date{color:var(--red);font-size:12px;letter-spacing:.18em;text-transform:uppercase;font-weight:700;margin:0 0 8px}
  .news-item h2{margin:0 0 14px;font-size:clamp(20px,2.6vw,30px);line-height:1.15;font-weight:800;letter-spacing:-.02em}
  .news-sep{margin:46px 0 30px;border:none;border-top:1px solid var(--ring);position:relative}
  .news-arch-title{font-size:clamp(20px,3vw,30px);font-weight:800;letter-spacing:-.02em;margin:8px 0 4px}

  /* ---- footer (real) ---- */
  footer .foot-nav{display:flex;flex-wrap:wrap;gap:8px 22px;justify-content:center;margin:0 0 16px}
  footer .foot-nav a{color:var(--ink);text-decoration:none;font-size:13.5px;font-weight:600;opacity:.8;transition:.2s}
  footer .foot-nav a:hover{opacity:1;color:var(--red)}
  footer .foot-meta{margin:0 0 6px;color:var(--muted)}
  footer .foot-meta a{color:var(--red);text-decoration:none}
  footer .foot-copy{margin:0;color:var(--muted);opacity:.85}

  @media (max-width:860px){
    .site-header{padding:11px 16px}
    .site-nav{gap:12px}
    .site-nav a{font-size:13px}
    .pub-toolbar{position:static;top:auto}
    .pub-count{margin-left:0;width:100%}
    main.subpage{padding:26px 16px 20px}
  }

  /* news/subpage inline images */
  .subpage .rich img{max-width:340px;width:100%;height:auto;float:right;margin:2px 0 16px 24px;border-radius:14px;border:1px solid var(--ring);box-shadow:var(--shadow)}
  .subpage .rich p{max-width:none}
  @media (max-width:680px){ .subpage .rich img{float:none;margin:0 0 16px;max-width:100%} }

  /* embedded database (Transfer Factor Explorer iframe) */
  .db-embed{position:relative;width:100%;margin:24px 0 10px;border:1px solid var(--ring);border-radius:16px;overflow:hidden;box-shadow:var(--shadow);background:#fff;height:320px}
  .db-embed iframe{width:100%;height:100%;border:0;display:block}
  .db-embed-note{font-size:13px;color:var(--muted)}
  .db-embed-note code{font-size:12px;background:rgba(0,0,0,.05);padding:1px 6px;border-radius:6px}
  @media (max-width:860px){ .db-embed{height:340px} }

  /* rich content figures (radioecology posters etc.) */
  .rich-figure{float:right;width:min(300px,42%);margin:4px 0 18px 26px;border:1px solid var(--ring);border-radius:14px;overflow:hidden;background:#fff;box-shadow:var(--shadow)}
  .rich-figure img{width:100%;height:auto;display:block}
  .rich-figure figcaption{padding:9px 12px;font-size:12.5px;line-height:1.4;color:var(--muted)}
  .rich-figure figcaption a{color:var(--red);text-decoration:none}
  .rich-list{margin:0 0 16px}
  @media (max-width:680px){ .rich-figure{float:none;width:100%;max-width:340px;margin:0 0 16px} }

  /* team tile: 6 member photos instead of icon */
  .tile .team-photos{display:grid;grid-template-columns:repeat(2,1fr);gap:8px;width:100%}
  .tile .team-photos .tp{aspect-ratio:1/1;border-radius:50%;background-size:cover;background-position:center top;border:2px solid rgba(255,255,255,.5);box-shadow:0 3px 9px rgba(0,0,0,.28)}
  /* contact tile: e-mail line */
  .tile .mail-line{display:block;margin-top:4px;font-size:12.5px;font-weight:600;color:var(--red);word-break:break-all}
  .tile.img .mail-line{color:#fff;text-shadow:0 1px 3px rgba(0,0,0,.65)}

