/*
Theme Name: Blue Lime Lab
Theme URI: 
Author: Ezequiel Espíndola
Author URI: 
Description: 
Requires at least: 6.9
Tested up to: 6.9
Requires PHP: 5.7
Version: 1.0.1
License: GNU General Public License v2 or later
License URI: http://www.gnu.org/licenses/gpl-2.0.html
Template: twentytwentyfive
Text Domain: bluelimelab
Tags: 
*/

 :root {
        /* Color tokens */
        --bg-a: #050b16; /* midnight navy */
        --bg-b: #061a3a; /* secondary navy */
        --text: #f4f1e8; /* warm off-white */

        --accent: #4ab6f0;
        --accent-r: 74;
        --accent-g: 182;
        --accent-b: 240;

        --wrap: 1280px;
        --gutter: clamp(24px, 5vw, 96px);
        --ease: cubic-bezier(0.16, 1, 0.3, 1);

        --grain-opacity: 0.0;
        --spot-opacity: 0;

        --bg-size: 220% 220%;
        --bg-dur: 42s;

        --header-mt: 24px;
        --header-h: 92px;
        --header-px: 24px;
        --header-radius: 18px;

        --header-mt-scrolled: 16px;
        --header-h-scrolled: 68px;
        --header-px-scrolled: 18px;

      }

header:has(>.is-position-sticky)::before {
  content: "";
  position: absolute;
  inset: 0;
  backdrop-filter: blur(8px);
  background: rgba(0, 29, 52, 0.5);
  pointer-events: none;
}

header:has(>.is-position-sticky) {
	position: sticky;
	top: calc( 0px + var( --wp-admin--admin-bar--height, 0px ) );
	z-index: 100;
	min-height: 70px;
	margin-bottom:-70px;
	color: white;
	isolation: isolate;
}

@media (max-width: 600px) {
	header:has(>.is-position-sticky) {
		top: 0;
	}
}

section {
	padding: var(--wp--preset--spacing--80) 0;
}

.hero {
        position: relative;
        isolation: isolate;
        min-height: 100svh;
        overflow: hidden;
  padding-top: calc(env(safe-area-inset-top) + clamp(110px, 30svh, 150px));
	
      }

@media (min-width: 900px){
  .hero {
    padding-top: clamp(160px, 20svh, 320px);
  }
}

.hero__bg,
      .hero__bg::after,
      .hero__grain,
      .hero__spot {
        position: absolute;
        inset: 0;
        pointer-events: none;
      }

      .hero__bg {
        background:
          radial-gradient(1200px 760px at 42% 28%, rgba(74,182,240,0.14), rgba(5,11,22,0) 64%),
          radial-gradient(900px 660px at 62% 50%, rgba(74,182,240,0.08), rgba(5,11,22,0) 72%),
          radial-gradient(900px 680px at 18% 88%, rgba(255,255,255,0.025), rgba(5,11,22,0) 64%),
          linear-gradient(180deg, var(--bg-a) 0%, var(--bg-b) 60%, var(--bg-a) 100%);
        background-size: var(--bg-size);
        background-position: 12% 38%;
        animation: blGradientDriftFast var(--bg-dur) ease infinite;
        transform: translateZ(0);
      }

.hero__bg::after {
  content: "";
  position: absolute;
  inset: -10%;
  pointer-events: none;

  background:
    radial-gradient(1600px 1000px at 30% 70%,
      rgba(185,255,0,0.18), rgba(5,11,22,0) 70%),
    radial-gradient(1400px 900px at 80% 20%,
      rgba(185,255,0,0.10), rgba(5,11,22,0) 75%);

  background-size: 240% 240%;
  background-position: 20% 80%;
  animation: blGradientDriftSlow 90s linear infinite;

  filter: blur(6px) saturate(1.6);
  opacity: 0.95;
}





      @keyframes blGradientDriftFast {
        0% { background-position: 12% 38%; }
        35% { background-position: 74% 22%; }
        65% { background-position: 56% 78%; }
        100% { background-position: 12% 38%; }
      }

      @keyframes blGradientDriftSlow {
        0% { background-position: 20% 80%; }
        50% { background-position: 80% 20%; }
        100% { background-position: 20% 80%; }
      }

.grain{
  position: absolute;
  inset: -12%;
  width: 124%;
max-width: 124%;
  height: 124%;
  display: block;
  pointer-events: none;
  z-index: 1;

  opacity: 0.9;
  mix-blend-mode: soft-light;
  filter: contrast(130%) brightness(105%);
}


.hero__center {
	position: relative;
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
  align-items: flex-start;

  margin: 0;
  padding: 0;
}

.eyebrow {
  display: flex;
  align-items: center;
  gap: 12px;

  font-size: 0.6875rem !important;
  font-weight: 500;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: rgba(255, 255, 255, 0.3);
}

.eyebrow::before {
  content: "";
  width: 28px;
  height: 1px;
  background: rgba(255, 255, 255, 0.2);
}

.eyebrow.dark::before {
  background: rgba(0, 0, 0, 0.6);
}

.eyebrow.dark {
	color: rgba(0, 0, 0, 0.7);
}


      .headline {
    color: rgba(255,255,255,0.92);
  max-width: 30ch;
  margin: 0 0 2rem 0;
  word-spacing: -0.05em;
      }

.headline em {
  font-family: var(--wp--preset--font-family--dm-serif-display);
  font-weight: 500;
color: color-mix(in srgb, var(--accent) 82%, white);
  text-shadow: 0 1px 0 rgba(0,0,0,0.35);  
  line-height: 0.9;
}

      .scrollNudge {
        position: absolute;
        left: var(--gutter);

        bottom: 34px;
        z-index: 12;
        display: inline-flex;
        align-items: center;
        gap: 12px;
        opacity: 0.62;
      }

      .scrollNudge__dot {
		      margin-block-start: 1.2rem !important;
        width: 6px;
        height: 6px;
        border-radius: 999px;
        background: var(--accent);
        box-shadow: 0 0 0 6px rgba(var(--accent-r), var(--accent-g), var(--accent-b), 0.10);
      }

      .scrollNudge__stem {
        width: 1px;
        height: 34px;
        background: rgba(244, 241, 232, 0.18);
        position: relative;
        overflow: hidden;
      }

      .scrollNudge__stem::after {
        content: "";
        position: absolute;
        left: 0;
        right: 0;
        top: -50%;
        height: 55%;
        background: rgba(var(--accent-r), var(--accent-g), var(--accent-b), 0.85);
        animation: nudge 2.4s var(--ease) infinite;
      }

      @keyframes nudge {
        0% { transform: translateY(0); opacity: 0; }
        18% { opacity: 1; }
        70% { transform: translateY(240%); opacity: 1; }
        100% { transform: translateY(240%); opacity: 0; }
      }


/*
.project__figure{
  position:relative;
}

.project--right .project__figure{
  margin-left:auto;
}

.project--left .project__figure{
  margin-right:auto;
}

.project__meta{
  position:absolute;
  top:5%;
  max-width:34ch;
	  backdrop-filter: blur(6px);         /* optional but premium */
  box-shadow: 0 18px 60px rgba(10,18,32,.12); /* gives authority */
}


.project--right .project__meta{
  left:15vw;
}

.project--left .project__meta{
  right:15vw;
}
*/

.project__figure{
  position: relative;
  width: 100vw;
  height: 85vh;
}

.project__meta{
  position: absolute;
  top: 10%;
  max-width: 34ch;
  padding: 28px 32px;
  background: rgba(255,255,255,.9);
  backdrop-filter: blur(6px);
  box-shadow: 0 18px 60px rgba(10,18,32,.12);
}
.project--right .project__meta{ left: 8vw; }
.project--left  .project__meta{ right: 8vw; }

/* mobile safety */
@media (max-width:900px){
  .project__meta{
    position:static;
    margin-top:24px;
  }
}




    :root{
      --bl-muted:#6b7280;
      --bl-gap:32px;
      --bl-card-pad:20px;
      --bl-card-radius:26px;
      --bl-media-radius:18px;
      --bl-border:rgba(17,17,17,.06);
      --bl-shadow:0 18px 30px rgba(16,24,40,.12);

      --bl-cast:#2f80ff;
      --bl-cast-opacity:.45;

      --bl-pill-1-bg:#ffedd5; --bl-pill-1-text:#c2410c;
      --bl-pill-2-bg:rgba(34,197,94,.18); --bl-pill-2-text:#15803d;
      --bl-pill-3-bg:rgba(236,72,153,.18); --bl-pill-3-text:#9d174d;

      --bl-max:1240px;
      --bl-pad-x:clamp(20px,4vw,44px);
    }

    /* Demo base */
    body{margin:0;background:#fff;color:#111;font-family:system-ui,-apple-system,Segoe UI,Roboto,Arial,sans-serif;line-height:1.5;}

    /* Keep the preview realistic without fighting WP: only style inside bl-team */
    .bl-team{padding-left:var(--bl-pad-x);padding-right:var(--bl-pad-x);}
    .bl-team > .wp-block-group.alignwide{max-width:var(--bl-max);margin-left:auto;margin-right:auto;}

    /* Header: WP columns need display:flex in canvas */
    .bl-team .wp-block-columns{display:flex;flex-wrap:nowrap;align-items:flex-start;justify-content:space-between;gap:24px;margin:0;}
    .bl-team .wp-block-column{min-width:0;}
    .bl-team .wp-block-columns > .wp-block-column:last-child{flex:0 0 auto;margin-left:auto;max-width:380px;}

    .bl-team h2.wp-block-heading{margin:0;font-size:clamp(40px,4.2vw,56px);line-height:1.05;letter-spacing:-.03em;font-weight:650;}
    .bl-team .wp-block-columns > .wp-block-column:last-child p{margin:4px 0 0;color:var(--bl-muted);line-height:1.35;text-align:right;font-size:14px;}

    /* Space between header and cards */
    .bl-team > .wp-block-group.is-layout-grid{margin-top:40px;}

    @media (max-width:720px){
      .bl-team .wp-block-columns{flex-direction:column;}
      .bl-team .wp-block-columns > .wp-block-column:last-child{margin-left:0;max-width:46ch;}
      .bl-team .wp-block-columns > .wp-block-column:last-child p{text-align:left;}
    }

    /* Grid */
    .bl-team > .wp-block-group.is-layout-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:var(--bl-gap);align-items:stretch;}
    @media (max-width:1024px){.bl-team > .wp-block-group.is-layout-grid{grid-template-columns:repeat(2,minmax(0,1fr));}}
    @media (max-width:640px){.bl-team > .wp-block-group.is-layout-grid{grid-template-columns:1fr;}}

    /* Card */
    .bl-card{background:#fafafa;border:1px solid var(--bl-border);border-radius:var(--bl-card-radius);padding:var(--bl-card-pad);margin:0;transition:transform .18s ease,box-shadow .18s ease,background-color .18s ease,border-color .18s ease;}
    .bl-card:hover{transform:translateY(-6px);box-shadow:var(--bl-shadow);background:#fff;border-color:rgba(17,17,17,.08);}

    /* Tight rhythm */
    .bl-card > *{margin:0;}

    /* Pill */
    .bl-card > p:first-of-type{display:inline-flex;align-items:center;width:fit-content;padding:4px 10px;border-radius:6px;font-size:12px;font-weight:600;letter-spacing:.01em;margin:0 0 12px;background:var(--bl-pill-1-bg);color:var(--bl-pill-1-text);}
    .bl-team > .wp-block-group.is-layout-grid > .bl-card:nth-child(2) > p:first-of-type{background:var(--bl-pill-2-bg);color:var(--bl-pill-2-text);}
    .bl-team > .wp-block-group.is-layout-grid > .bl-card:nth-child(3) > p:first-of-type{background:var(--bl-pill-3-bg);color:var(--bl-pill-3-text);}

    /* Image + cast */
    .bl-card figure.wp-block-image{margin:0 0 12px;border-radius:var(--bl-media-radius);overflow:hidden;aspect-ratio:1/1;background:#d1d5db;position:relative;}
    .bl-card figure.wp-block-image img{width:100%;height:100%;object-fit:cover;display:block;filter:grayscale(1) contrast(1.05) brightness(1.05);transform:scale(1);transition:filter .25s ease,transform .25s ease;}
    .bl-card figure.wp-block-image::after{content:"";position:absolute;inset:0;background:var(--bl-cast);mix-blend-mode:color;opacity:var(--bl-cast-opacity);transition:opacity .25s ease;pointer-events:none;}
    .bl-card:hover figure.wp-block-image img{filter:none;transform:scale(1.03);}
    .bl-card:hover figure.wp-block-image::after{opacity:0;}

    /* Name + role */
    .bl-card h3.wp-block-heading{font-size:18px;font-weight:650;letter-spacing:-.01em;line-height:1.2;}
    .bl-card h3.wp-block-heading + p{margin-top:4px;color:var(--bl-muted);font-size:14px;line-height:1.35;}





  /* Section */
  .bl-locations {
    --bl-wide: 1280px;

    --bl-text: #0b1220;
    --bl-muted: rgba(11, 18, 32, 0.72);

    --bl-accent: #6aa8ff;
    --bl-accent-2: rgba(106, 168, 255, 0.65);

    --bl-ocean-1: #061632;
    --bl-ocean-2: #092a63;

    --bl-radius: 26px;
    --bl-card-radius: 22px;
    --bl-gap: clamp(14px, 1.8vw, 22px);
    --bl-card-pad: clamp(20px, 2vw, 26px);

    background:
      radial-gradient(900px 420px at 50% -120px, rgba(106, 168, 255, 0.12), transparent 60%),
      linear-gradient(180deg, #ffffff, #fbfbfd);

    color: var(--bl-text);
  }

  /* Force ALL alignwide blocks inside this section to true 1280 max */
  .bl-locations > .wp-block-group.alignwide {
    width: min(var(--bl-wide), calc(100% - 48px));
    max-width: var(--bl-wide);
    margin-inline: auto;
  }

  .bl-locations h2.wp-block-heading {
    margin: 0;
    font-weight: 760;
    letter-spacing: -0.02em;
    font-size: clamp(34px, 3.2vw, 46px);
    line-height: 1.08;
  }

  /* Map */
  .bl-locations__map {
    position: relative;
    overflow: hidden;
    width: 100%;

    /* Optional (recommended): reserves space before the image loads to avoid layout shift.
       Remove if you truly want the image alone to define height.
    */
    /* Let the SVG define the height (like the source site) */
    aspect-ratio: auto;

    border-radius: var(--bl-radius);
    border: 1px solid rgba(11, 18, 32, 0.10);

    background:
      radial-gradient(900px 420px at 55% 15%, rgba(106, 168, 255, 0.18), transparent 55%),
      radial-gradient(700px 320px at 15% 25%, rgba(255, 255, 255, 0.05), transparent 60%),
      linear-gradient(180deg, var(--bl-ocean-2), var(--bl-ocean-1));

    box-shadow:
      0 1px 0 rgba(255, 255, 255, 0.08) inset,
      0 30px 80px rgba(11, 18, 32, 0.22);
  }

  .bl-locations__map::before {
    content: "";
    position: absolute;
    inset: 0;
    z-index: 1;
    pointer-events: none;
    opacity: 0.95;
    background:
      radial-gradient(900px 420px at 50% 0%, rgba(255, 255, 255, 0.07), transparent 55%),
      radial-gradient(1200px 520px at 50% 120%, rgba(0, 0, 0, 0.40), transparent 60%);
  }

  .bl-locations__map img {
    display: block;
    width: 100%;
    height: auto;

    /* Key difference vs earlier versions:
       The image stays in normal flow (like the source site).
       That means the container’s coordinate space matches what you SEE,
       so pin % values behave predictably.
    */
    position: relative;
    z-index: 0;

    padding: 0;

    filter: invert(1) brightness(1.18) contrast(0.92) saturate(0.75);
    opacity: 0.88;
    mix-blend-mode: screen;
  }

  /* Pins */
  .bl-locations__pin {
    position: absolute;
    left: var(--x, 50%);
    top: var(--y, 50%);
    z-index: 20;

    display: block;
    width: 12px;
    height: 12px;
    border-radius: 999px;

    transform: translate(-50%, -50%);

    background: var(--bl-accent);
    border: 2px solid rgba(6, 22, 50, 0.65);

    text-decoration: none;
    outline: none;

    box-shadow:
      0 16px 34px rgba(0, 0, 0, 0.34),
      0 0 0 6px rgba(106, 168, 255, 0.16);

    animation: bl-pulse 2.3s ease-out infinite;
  }

  @keyframes bl-pulse {
    0% {
      box-shadow:
        0 16px 34px rgba(0, 0, 0, 0.34),
        0 0 0 6px rgba(106, 168, 255, 0.16);
    }
    55%,
    100% {
      box-shadow:
        0 16px 34px rgba(0, 0, 0, 0.34),
        0 0 0 18px rgba(106, 168, 255, 0);
    }
  }

  /* Stem (not white) */
  .bl-locations__pin::before {
    content: "";
    position: absolute;
    left: 50%;
    bottom: calc(100% + 2px);

    width: 2px;
    height: var(--stem);

    transform: translateX(-50%);

    background: linear-gradient(180deg, var(--bl-accent-2), rgba(106, 168, 255, 0));
    opacity: 0.95;
    pointer-events: none;
  }

  /* Label */
  .bl-locations__pin::after {
    content: attr(data-label);
    position: absolute;
    left: 50%;
    bottom: calc(100% + var(--stem) + 10px);

    transform: translate(calc(-50% + var(--nudge)), 0);

    padding: 8px 12px;
    border-radius: 999px;

    border: 1px solid rgba(106, 168, 255, 0.28);
    background: rgba(8, 16, 32, 0.46);
    backdrop-filter: blur(10px);

    color: rgba(255, 255, 255, 0.92);
    font-size: 12px;
    letter-spacing: 0.02em;
    white-space: nowrap;

    box-shadow: 0 18px 44px rgba(0, 0, 0, 0.30);
    pointer-events: none;
  }

  .bl-locations__pin:focus-visible {
    outline: 3px solid rgba(106, 168, 255, 0.55);
    outline-offset: 6px;
  }

  /* Cards: target your existing WP grid wrapper (no HTML changes) */
  .bl-locations > .wp-block-group.alignwide.is-layout-grid {
    margin-top: clamp(-48px, -4vw, -32px);
    position: relative;
    z-index: 3;

    padding: 0;

    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: var(--bl-gap);
  }

  .bl-locations > .wp-block-group.alignwide.is-layout-grid > .wp-block-group {
    position: relative;
    overflow: hidden;

    border: 1px solid transparent;
    border-radius: var(--bl-card-radius);

    background:
      linear-gradient(180deg, rgba(255, 255, 255, 0.98), rgba(255, 255, 255, 0.90)) padding-box,
      linear-gradient(135deg, rgba(106, 168, 255, 0.42), rgba(11, 18, 32, 0.12)) border-box;

    padding: var(--bl-card-pad);

    box-shadow:
      0 1px 0 rgba(255, 255, 255, 0.78) inset,
      0 18px 44px rgba(11, 18, 32, 0.10);

    transition: transform 160ms ease, box-shadow 160ms ease;
    scroll-margin-top: 18px;
  }

  .bl-locations > .wp-block-group.alignwide.is-layout-grid > .wp-block-group::before {
    content: "";
    position: absolute;
    inset: 0;
    pointer-events: none;
    opacity: 0.95;
    background:
      radial-gradient(520px 220px at 18% 0%, rgba(106, 168, 255, 0.12), transparent 62%),
      radial-gradient(520px 220px at 82% 0%, rgba(170, 140, 255, 0.10), transparent 70%),
      radial-gradient(520px 320px at 50% 120%, rgba(0, 0, 0, 0.06), transparent 58%);
  }

  .bl-locations > .wp-block-group.alignwide.is-layout-grid > .wp-block-group::after {
    content: "";
    position: absolute;
    left: 0;
    right: 0;
    top: 0;
    height: 7px;
    opacity: 0.9;
    pointer-events: none;
    background: linear-gradient(90deg, rgba(106, 168, 255, 0.95), rgba(170, 140, 255, 0.92), rgba(120, 200, 255, 0.90));
  }

  .bl-locations > .wp-block-group.alignwide.is-layout-grid > .wp-block-group:hover {
    transform: translateY(-3px);
    box-shadow:
      0 1px 0 rgba(255, 255, 255, 0.82) inset,
      0 30px 78px rgba(11, 18, 32, 0.14);
  }

  .bl-locations > .wp-block-group.alignwide.is-layout-grid > .wp-block-group:target {
    border-color: rgba(106, 168, 255, 0.55);
    box-shadow:
      0 1px 0 rgba(255, 255, 255, 0.75) inset,
      0 26px 70px rgba(106, 168, 255, 0.18);
  }

  .bl-locations > .wp-block-group.alignwide.is-layout-grid h4.wp-block-heading {
    margin: 0 0 12px;
    font-size: 18px;
    line-height: 1.15;
    font-weight: 760;
    letter-spacing: -0.01em;
  }

  .bl-locations > .wp-block-group.alignwide.is-layout-grid p {
    margin: 0;
    color: var(--bl-muted);
    line-height: 1.7;
  }

    /* Responsive */

  /* Mobile: same wrapper becomes a snap carousel */
  @media (max-width: 900px) {
    .bl-locations > .wp-block-group.alignwide.is-layout-grid {
      display: flex;
      flex-wrap: nowrap;
      overflow-x: auto;
      gap: 14px;

      padding: 6px 10px 10px;

      scroll-snap-type: x mandatory;
      scroll-padding-inline: 10px;
      -webkit-overflow-scrolling: touch;

      scrollbar-width: none;
    }

    .bl-locations > .wp-block-group.alignwide.is-layout-grid::-webkit-scrollbar { display: none; }

    .bl-locations > .wp-block-group.alignwide.is-layout-grid > .wp-block-group {
      flex: 0 0 min(84%, 380px);
      scroll-snap-align: start;
    }

        /* (Removed edge-fade overlays — they were creating the vertical “glass” stripe in narrow widths) */

    /* Optional: slightly shorter stems on mobile */
    .bl-locations__pin[aria-label="Miami"] { --stem: 38px; }
    .bl-locations__pin[aria-label="Madrid"] { --stem: 40px; }
    .bl-locations__pin[aria-label="Buenos Aires"] { --stem: 44px; }
  }

  @media (prefers-reduced-motion: reduce) {
    .bl-locations__pin { animation: none; }
    .bl-locations > .wp-block-group.alignwide.is-layout-grid > .wp-block-group {
      transition: none;
    }
    .bl-locations > .wp-block-group.alignwide.is-layout-grid > .wp-block-group:hover {
      transform: none;
    }
  }


  .bl-footer{
    --t:rgba(255,255,255,.92);
    --m:rgba(255,255,255,.62);
    --line:rgba(255,255,255,.16);

    position:relative;
    overflow:hidden;
    border-radius:44px !important; /* overrides the 16px inline radius */
    color:var(--t);

    background:
      radial-gradient(1200px 520px at 70% 35%, rgba(255,255,255,.06), transparent 55%),
      linear-gradient(180deg, #161616, #0f0f0f) !important;
  }
  .bl-footer:before{
    content:"";
    position:absolute;
    inset:-2px;
    pointer-events:none;
    opacity:.22;
    background:linear-gradient(180deg, rgba(255,255,255,.10), transparent 22%, transparent 78%, rgba(255,255,255,.08));
  }
  .bl-footer > *{ position:relative; z-index:1; }

  /* Top stack: title ABOVE CTA */
  .bl-footer > .wp-block-group.is-layout-flex{ align-items:center !important; gap:18px !important; }
  .bl-footer > .wp-block-group.is-layout-flex p{
    margin:0 !important;
    text-align:center !important;
    letter-spacing:-.02em;
    line-height:1.12;
    font-size:clamp(28px, 2.6vw, 42px) !important;
  }
  .bl-footer > .wp-block-group.is-layout-flex p strong{ font-weight:800; }

  /* CTA pill + orange arrow circle */
  .bl-footer .wp-block-button__link{
    display:inline-flex;
    align-items:center;
    gap:12px;
    padding:12px 14px 12px 16px;
    border-radius:999px;
    font-weight:700;
    white-space:nowrap;
    text-decoration:none;

    color:var(--t) !important;
    background:rgba(255,255,255,.04) !important;
    border:1px solid rgba(255,255,255,.12) !important;
    box-shadow:0 14px 40px rgba(0,0,0,.35);
  }
  .bl-footer .wp-block-button__link:hover{ background:rgba(255,255,255,.06) !important; border-color:rgba(255,255,255,.16) !important; }
  .bl-footer .wp-block-button__link:after{
    content:"→";
    width:34px;
    height:34px;
    border-radius:999px;
    display:inline-flex;
    align-items:center;
    justify-content:center;
    font-size:14px;
    line-height:1;

    color:#0b0b0b;
    background:linear-gradient(180deg, #ff7a1a, #ff6b00);
  }

  /* Separator line on the bottom row */
  .bl-footer > .wp-block-columns{ margin-top:38px; padding-top:24px; position:relative; }
  .bl-footer > .wp-block-columns:before{
    content:"";
    position:absolute;
    left:0; right:0; top:0;
    height:1px;
    background:linear-gradient(90deg, transparent, var(--line) 18%, var(--line) 82%, transparent);
  }

  /* Bottom row basics */
  .bl-footer .wp-block-site-logo img{ height:32px; width:auto; }
  .bl-footer .wp-block-navigation-item__content{ color:var(--m); text-decoration:none; font-size:13.5px; letter-spacing:.01em; }
  .bl-footer .wp-block-navigation-item__content:hover{ color:var(--t); }
  .bl-footer .wp-block-social-link,
  .bl-footer .wp-block-social-link-anchor{ background:transparent !important; }
  .bl-footer .wp-block-social-link-anchor{ color:var(--m); }
  .bl-footer .wp-block-social-link-anchor:hover{ color:var(--t); }

  @media (max-width: 860px){
    .bl-footer{ border-radius:34px !important; }
    .bl-footer > .wp-block-columns{ margin-top:26px; padding-top:18px; }
  }
  @media (max-width: 480px){
    .bl-footer{ border-radius:26px !important; }
    .bl-footer .wp-block-button{ width:100%; }
    .bl-footer .wp-block-button__link{ width:100%; justify-content:center; }
  }