/* =========================================================
   Applied AI (Riot-ish layout, now more "Applied AI lab")
   - Default theme: GREEN lightning (stories)
   - Homepage: add body.theme-blue
   ========================================================= */

:root{
  --max: 1180px;
  --radius: 18px;
  --shadow: 0 24px 80px rgba(0,0,0,.55);

  /* Type */
  --sans: system-ui,-apple-system,Segoe UI,Roboto,Arial,sans-serif;
  --mono: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace;

  /* Surfaces + lines (used to feel more “app/tooling”) */
  --line: rgba(255,255,255,.12);
  --line2: rgba(255,255,255,.18);
  --panel: rgba(255,255,255,.035);
  --panel2: rgba(255,255,255,.06);

  /* Default = GREEN lightning (story pages) */
  --bg0:#020603;
  --bg1:#061208;
  --bg2:#0a2110;
  --text:#eaffea;
  --muted: rgba(234,255,234,.72);
  --ice:#d9ffda;
  --accent:#00ff4c;
  --accent2:#7dff9c;
}

/* Homepage override = BLUE lightning */
body.theme-blue{
  --bg0:#00040c;
  --bg1:#010a1a;
  --bg2:#041a33;
  --text:#eaf6ff;
  --muted: rgba(234,246,255,.70);
  --ice:#c8fbff;
  --accent:#41e6ff;
  --accent2:#8bf3ff;
}

*{ box-sizing:border-box; }
html,body{ height:100%; }

body{
  margin:0;
  color:var(--text);
  font-family: var(--sans);

  /* Lightning background + a subtle “tooling grid” to feel more Applied AI */
  background:
    radial-gradient(760px 560px at 50% 0%,
      rgba(217,255,218,.80),
      rgba(0,255,76,.26) 38%,
      transparent 72%),
    radial-gradient(900px 680px at 22% 18%,
      rgba(0,255,76,.16),
      transparent 66%),
    radial-gradient(900px 680px at 78% 22%,
      rgba(125,255,156,.12),
      transparent 68%),
    /* subtle grid overlay */
    repeating-linear-gradient(to right,
      rgba(255,255,255,.04) 0,
      rgba(255,255,255,.04) 1px,
      transparent 1px,
      transparent 64px),
    repeating-linear-gradient(to bottom,
      rgba(255,255,255,.03) 0,
      rgba(255,255,255,.03) 1px,
      transparent 1px,
      transparent 64px),
    linear-gradient(180deg, var(--bg2), var(--bg1) 45%, var(--bg0) 100%);
  background-attachment: fixed;
}

body.theme-blue{
  background:
    radial-gradient(720px 520px at 50% 0%,
      rgba(200,251,255,.72),
      rgba(65,230,255,.25) 38%,
      transparent 70%),
    radial-gradient(900px 680px at 28% 18%,
      rgba(26,70,255,.22),
      transparent 66%),
    radial-gradient(900px 680px at 74% 22%,
      rgba(65,230,255,.16),
      transparent 68%),
    repeating-linear-gradient(to right,
      rgba(255,255,255,.04) 0,
      rgba(255,255,255,.04) 1px,
      transparent 1px,
      transparent 64px),
    repeating-linear-gradient(to bottom,
      rgba(255,255,255,.03) 0,
      rgba(255,255,255,.03) 1px,
      transparent 1px,
      transparent 64px),
    linear-gradient(180deg, var(--bg2), var(--bg1) 45%, var(--bg0) 100%);
  background-attachment: fixed;
}

a{ color: var(--accent2); text-decoration:none; }
a:hover{ color: var(--ice); }
.muted{ color: var(--muted); }

/* Better defaults for “reading an analysis site” */
p, li{ line-height: 1.75; }
h1,h2,h3{ letter-spacing: -0.01em; }
::selection{ background: rgba(255,255,255,.16); }

/* Accessibility: visible focus ring */
:focus-visible{
  outline: 2px solid rgba(255,255,255,.55);
  outline-offset: 3px;
  border-radius: 10px;
}

/* Header */
.site-header{
  position: sticky;
  top:0;
  z-index: 50;
  background: rgba(0,0,0,.62);
  backdrop-filter: blur(14px);
  border-bottom: 1px solid rgba(255,255,255,.10);
}

.header-inner{
  max-width: var(--max);
  margin: 0 auto;
  padding: 0 18px;
  height: 72px;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap: 14px;
}

/* Logo */
.logo{
  display:flex;
  align-items:center;
  gap:10px;
  color: var(--text);
  font-weight: 950;
  letter-spacing:.2px;
}
.logo-dot{
  width: 18px;
  height: 18px;
  border-radius: 50%;
  background: radial-gradient(circle at 30% 30%, rgba(255,255,255,.95), rgba(255,255,255,.20) 60%, transparent 70%);
  box-shadow: 0 0 18px rgba(255,255,255,.18);
}
.logo-text{
  text-transform: uppercase;
  font-size: 13px;
  letter-spacing:.14em;
}

/* Nav */
.primary-nav{
  display:flex;
  align-items:center;
  gap: 18px;
}
.primary-nav a{
  font-weight: 900;
  font-size: 12px;
  letter-spacing: .14em;
  text-transform: uppercase;
  color: rgba(255,255,255,.78);
  padding: 10px 10px;
  border-radius: 999px;
}
.primary-nav a:hover{
  color: var(--ice);
  background: rgba(255,255,255,.05);
}

/* Actions */
.header-actions{
  display:flex;
  align-items:center;
  gap: 10px;
}

.icon-btn{
  width: 44px;
  height: 44px;
  border-radius: 14px;
  border: 1px solid rgba(255,255,255,.14);
  background: rgba(255,255,255,.03);
  color: var(--text);
  cursor:pointer;
}
.icon-btn:hover{
  border-color: rgba(255,255,255,.26);
  box-shadow: 0 0 0 3px rgba(255,255,255,.06);
}

/* Burger icon */
.burger{
  display:block;
  width: 18px;
  height: 2px;
  background: rgba(255,255,255,.9);
  position: relative;
  margin: 0 auto;
  border-radius: 99px;
}
.burger::before,
.burger::after{
  content:"";
  position:absolute;
  left:0;
  width: 18px;
  height: 2px;
  background: rgba(255,255,255,.9);
  border-radius: 99px;
}
.burger::before{ top: -6px; }
.burger::after{ top: 6px; }

.cta{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  padding: 11px 14px;
  border-radius: 999px;
  border: 1px solid rgba(255,255,255,.16);
  background: rgba(255,255,255,.04);
  color: var(--ice);
  font-weight: 950;
  font-size: 12px;
  letter-spacing: .12em;
  text-transform: uppercase;
}
body.theme-blue .cta:hover{ box-shadow: 0 0 22px rgba(65,230,255,.18); border-color: rgba(65,230,255,.45); }
body:not(.theme-blue) .cta:hover{ box-shadow: 0 0 22px rgba(0,255,76,.16); border-color: rgba(0,255,76,.50); }

/* Drawer */
.drawer{
  position: fixed;
  top:0; left:0;
  height:100%;
  width: 320px;
  background: rgba(0,0,0,.88);
  border-right: 1px solid rgba(255,255,255,.10);
  transform: translateX(-102%);
  transition: transform 220ms ease;
  z-index: 80;
  padding: 16px;
}
.drawer.open{ transform: translateX(0); }
.drawer-top{
  display:flex;
  align-items:center;
  justify-content:space-between;
  margin-bottom: 14px;
}
.close-btn{ font-size: 16px; }
.drawer-nav{
  display:grid;
  gap: 10px;
}
.drawer-nav a{
  padding: 12px 12px;
  border-radius: 14px;
  border: 1px solid rgba(255,255,255,.12);
  background: rgba(255,255,255,.03);
  color: var(--text);
  font-weight: 950;
}
.drawer-nav a:hover{ background: rgba(255,255,255,.06); }

.backdrop{
  position: fixed;
  inset:0;
  background: rgba(0,0,0,.55);
  z-index: 70;
}
.backdrop.show{ display:block; }

/* Hero */
.hero{
  max-width: var(--max);
  margin: 0 auto;
  padding: 26px 18px 10px;
}
.hero-grid{
  display:grid;
  grid-template-columns: 1.15fr .85fr;
  gap: 18px;
  align-items: stretch;
}
.hero-copy{
  border: 1px solid rgba(255,255,255,.14);
  background: rgba(255,255,255,.035);
  border-radius: var(--radius);
  padding: 24px;
  box-shadow: var(--shadow);
}

/* “AI lab” feel: subtle inner hairline + micro texture on primary panels */
.hero-copy, .card, .hero-media, .post-list li{
  position: relative;
}
.hero-copy::before, .card::before, .hero-media::before, .post-list li::before{
  content:"";
  position:absolute;
  inset:0;
  border-radius: inherit;
  pointer-events:none;
  box-shadow: inset 0 1px 0 rgba(255,255,255,.06);
  background:
    radial-gradient(900px 200px at 20% 0%, rgba(255,255,255,.05), transparent 50%),
    radial-gradient(900px 200px at 80% 0%, rgba(255,255,255,.03), transparent 55%);
  opacity: .55;
}

.kicker{
  margin: 0 0 10px;
  font-weight: 950;
  font-size: 12px;
  letter-spacing: .18em;
  text-transform: uppercase;
  color: rgba(255,255,255,.68);
}
.hero-title{
  margin: 0 0 12px;
  font-size: clamp(28px, 3.4vw, 44px);
  line-height: 1.06;
  letter-spacing: -0.02em;
}
.hero-sub{
  margin: 0 0 16px;
  color: var(--muted);
  line-height: 1.7;
  max-width: 72ch;
}
.hero-actions{
  display:flex;
  gap: 12px;
  flex-wrap: wrap;
  margin-bottom: 14px;
}
.btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  padding: 12px 16px;
  border-radius: 14px;
  border: 1px solid rgba(255,255,255,.16);
  background: rgba(255,255,255,.04);
  color: var(--ice);
  font-weight: 950;
  font-size: 12px;
  letter-spacing: .12em;
  text-transform: uppercase;
  transition: transform .12s ease, box-shadow .12s ease, border-color .12s ease;
}
.btn:hover{ transform: translateY(-1px); }

.btn.primary{
  color:#001019;
  border-color: rgba(255,255,255,.18);
}
body.theme-blue .btn.primary{
  background: radial-gradient(circle at 30% 20%, rgba(200,251,255,.92), rgba(65,230,255,.72) 45%, rgba(26,70,255,.55) 85%);
}
body:not(.theme-blue) .btn.primary{
  background: radial-gradient(circle at 30% 20%, rgba(217,255,218,.92), rgba(0,255,76,.55) 45%, rgba(0,120,40,.55) 85%);
}
.btn.ghost{ background: rgba(255,255,255,.03); }

.hero-meta{
  display:flex;
  gap: 10px;
  flex-wrap: wrap;
}

/* Pills read like “tags/metadata” now */
.pill{
  display:inline-flex;
  align-items: center;
  gap: 8px;
  padding: 7px 10px;
  border-radius: 999px;
  border: 1px solid rgba(255,255,255,.12);
  background: rgba(0,0,0,.22);
  color: rgba(255,255,255,.88);
  font-weight: 900;
  font-size: 12px;
}
.pill::before{
  content:"";
  width: 7px;
  height: 7px;
  border-radius: 50%;
  background: var(--accent2);
  box-shadow: 0 0 14px rgba(255,255,255,.12);
}

/* Media panel */
.hero-media{
  border-radius: var(--radius);
  border: 1px solid rgba(255,255,255,.14);
  background: rgba(255,255,255,.03);
  box-shadow: var(--shadow);
  overflow:hidden;
}
.media-frame{
  position: relative;
  height: 100%;
  min-height: 320px;
  background: rgba(255,255,255,.02);
}
.media-glow{
  position:absolute;
  inset:0;
  pointer-events:none;
  mix-blend-mode: screen;
}
body.theme-blue .media-glow{
  background: radial-gradient(circle at 55% 15%, rgba(200,251,255,1), rgba(65,230,255,.22) 50%, transparent 75%);
}
body:not(.theme-blue) .media-glow{
  background: radial-gradient(circle at 55% 15%, rgba(217,255,218,1), rgba(0,255,76,.18) 50%, transparent 75%);
}
.scanlines{
  position:absolute;
  inset:0;
  pointer-events:none;
  opacity:.22;
  background: repeating-linear-gradient(to bottom,
    rgba(255,255,255,.02),
    rgba(255,255,255,.02) 1px,
    transparent 1px,
    transparent 6px
  );
}
.media-label{
  position:absolute;
  left: 14px;
  bottom: 14px;
  display:inline-flex;
  align-items:center;
  gap: 8px;
  padding: 8px 10px;
  border-radius: 999px;
  border: 1px solid rgba(255,255,255,.12);
  background: rgba(0,0,0,.55);
  font-weight: 900;
  font-size: 12px;
  color: rgba(255,255,255,.86);
}
.media-label .dot{
  width:8px; height:8px;
  border-radius: 50%;
  background: rgba(255,255,255,.85);
  box-shadow: 0 0 14px rgba(255,255,255,.22);
}

/* Sections */
.section{
  max-width: var(--max);
  margin: 0 auto;
  padding: 26px 18px 40px;
}
.section.alt{
  border-top: 1px solid rgba(255,255,255,.10);
  border-bottom: 1px solid rgba(255,255,255,.10);
  background: rgba(255,255,255,.02);
  border-radius: 0;
}
.section-head{
  display:flex;
  justify-content:space-between;
  align-items:baseline;
  gap: 12px;
  margin-bottom: 14px;
}
.section-head h2{
  margin:0;
  font-size: 14px;
  letter-spacing: .16em;
  text-transform: uppercase;
  color: rgba(255,255,255,.86);
}
.section-link{
  font-weight: 900;
  font-size: 12px;
  letter-spacing: .12em;
  text-transform: uppercase;
  color: rgba(255,255,255,.70);
}
.section-link:hover{ color: var(--ice); }

/* Cards */
.card-grid{
  display:grid;
  grid-template-columns: repeat(4, minmax(220px, 1fr));
  gap: 14px;
}
.card{
  border-radius: var(--radius);
  border: 1px solid rgba(255,255,255,.14);
  background: rgba(255,255,255,.035);
  box-shadow: var(--shadow);
  overflow:hidden;
}
.card-link{
  display:block;
  padding: 16px;
  color: var(--text);
}
.card-link:hover{
  background: rgba(255,255,255,.06);
}
.card-top{
  display:flex;
  justify-content:space-between;
  gap: 10px;
  margin-bottom: 10px;
}

.tag{
  font-weight: 950;
  font-size: 11px;
  letter-spacing: .14em;
  text-transform: uppercase;
  color: rgba(255,255,255,.84);
}
.date{
  font-weight: 900;
  font-size: 12px;
  color: rgba(255,255,255,.55);
}

.card h3{
  margin:0 0 8px;
  font-size: 18px;
  line-height: 1.25;
}
.card p{
  margin:0;
  color: var(--muted);
  line-height: 1.55;
  font-size: 13px;
}

/* Latest list */
.post-list{
  list-style:none;
  padding:0;
  margin:0;
  display:grid;
  gap: 10px;
}
.post-list li{
  border: 1px solid rgba(255,255,255,.12);
  background: rgba(255,255,255,.03);
  border-radius: 14px;
  padding: 12px 14px;
  display:flex;
  justify-content:space-between;
  align-items:baseline;
  gap: 12px;
}

/* Footer */
.footer{
  max-width: var(--max);
  margin: 0 auto;
  padding: 22px 18px 46px;
}
.footer-inner{
  display:flex;
  justify-content:space-between;
  gap: 12px;
  border-top: 1px solid rgba(255,255,255,.10);
  padding-top: 16px;
}

/* =========================================================
   Applied AI content helpers (for your article pages)
   - Gives you “analysis site” vibes: code, quotes, callouts
   ========================================================= */

main{
  /* slightly more readable spacing on long pages */
  padding-bottom: 14px;
}

/* If your article pages use .article or .post container, these help automatically */
.article, .post, .content{
  max-width: 86ch;
  margin: 0 auto;
  padding: 0 18px 44px;
}

/* Links in longform should look like references */
.article a, .post a, .content a{
  text-decoration: underline;
  text-decoration-thickness: 2px;
  text-underline-offset: 3px;
  color: var(--accent2);
}
.article a:hover, .post a:hover, .content a:hover{
  color: var(--ice);
}

/* Inline code */
code{
  font-family: var(--mono);
  font-size: .95em;
  padding: .15em .4em;
  border-radius: 8px;
  border: 1px solid var(--line);
  background: rgba(0,0,0,.35);
  color: rgba(255,255,255,.92);
}

/* Code blocks */
pre{
  margin: 16px 0;
  padding: 14px 14px;
  border-radius: 16px;
  border: 1px solid var(--line2);
  background:
    radial-gradient(1000px 250px at 10% 0%, rgba(255,255,255,.06), transparent 55%),
    rgba(0,0,0,.48);
  overflow:auto;
  box-shadow: 0 18px 60px rgba(0,0,0,.45);
}
pre code{
  border: none;
  background: transparent;
  padding: 0;
  color: rgba(255,255,255,.92);
  font-size: 13px;
  line-height: 1.6;
}

/* Blockquotes become “field notes” */
blockquote{
  margin: 18px 0;
  padding: 14px 16px;
  border-radius: 16px;
  border: 1px solid var(--line);
  background: rgba(255,255,255,.03);
  color: rgba(255,255,255,.86);
}
blockquote p{ margin: 0; }

/* Callout box utility: add class="callout" in your HTML when needed */
.callout{
  margin: 18px 0;
  padding: 14px 16px;
  border-radius: 16px;
  border: 1px solid rgba(255,255,255,.14);
  background:
    radial-gradient(800px 220px at 15% 0%, rgba(255,255,255,.06), transparent 55%),
    rgba(0,0,0,.28);
}
.callout .callout-title{
  font-family: var(--mono);
  font-size: 12px;
  letter-spacing: .12em;
  text-transform: uppercase;
  opacity: .9;
  margin-bottom: 8px;
}

/* Tables (good for comparisons: tools, pricing, features) */
table{
  width: 100%;
  border-collapse: collapse;
  margin: 16px 0;
  border-radius: 14px;
  overflow: hidden;
  border: 1px solid var(--line);
  background: rgba(0,0,0,.22);
}
th, td{
  padding: 10px 12px;
  border-bottom: 1px solid rgba(255,255,255,.08);
  text-align: left;
  vertical-align: top;
}
th{
  font-size: 12px;
  letter-spacing: .12em;
  text-transform: uppercase;
  color: rgba(255,255,255,.84);
  background: rgba(255,255,255,.04);
}
tr:hover td{
  background: rgba(255,255,255,.03);
}

/* =========================================================
   Featured rotator fade (for your JS auto-rotation)
   ========================================================= */

.featured-rotator{
  transition: opacity 220ms ease;
  opacity: 1;
}
.featured-rotator.is-fading{
  opacity: 0;
}

/* =========================================================
   Extra featured-tabs CSS (left intact even if unused)
   ========================================================= */

.featured-tabs{ margin-top: 12px; }
.featured-tabs__top{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
  margin-bottom:12px;
}
.featured-tabs__controls{
  display:flex;
  align-items:center;
  gap:10px;
  flex:1;
}
.featured-btn{
  width: 44px;
  height: 44px;
  border-radius: 14px;
  border: 1px solid rgba(255,255,255,.14);
  background: rgba(255,255,255,.03);
  color: rgba(255,255,255,.9);
  cursor:pointer;
  line-height: 1;
  font-size: 22px;
}
.featured-btn:hover{ background: rgba(255,255,255,.06); }
.tablist{ display:flex; gap:8px; flex-wrap:wrap; }
.tab{
  border: 1px solid rgba(255,255,255,.12);
  background: rgba(255,255,255,.03);
  color: rgba(255,255,255,.82);
  padding: 10px 12px;
  border-radius: 999px;
  font-weight: 900;
  font-size: 12px;
  letter-spacing: .08em;
  text-transform: uppercase;
  cursor: pointer;
}
.tab:hover{ background: rgba(255,255,255,.06); }
.tab.is-active{
  color: var(--ice);
  border-color: rgba(255,255,255,.22);
  background: rgba(255,255,255,.06);
}
.panels{ border-radius: var(--radius); }
.panel-card{
  display:block;
  padding: 18px;
  border-radius: var(--radius);
  border: 1px solid rgba(255,255,255,.14);
  background: rgba(255,255,255,.035);
  box-shadow: var(--shadow);
}
.panel-card:hover{ background: rgba(255,255,255,.06); }
.panel-cta{
  margin-top: 10px;
  font-weight: 900;
  letter-spacing: .08em;
  text-transform: uppercase;
  font-size: 12px;
  color: rgba(255,255,255,.78);
}
.featured-tabs__hint{
  white-space: nowrap;
  font-size: 12px;
  opacity: .85;
}

/* Responsive */
@media (max-width: 980px){
  .hero-grid{ grid-template-columns: 1fr; }
  .card-grid{ grid-template-columns: repeat(2, minmax(220px, 1fr)); }
  .featured-tabs__hint{ display:none; }
}
@media (max-width: 560px){
  .primary-nav{ display:none; }
  .card-grid{ grid-template-columns: 1fr; }
  .post-list li{ flex-direction: column; align-items:flex-start; }
  .featured-btn{ width: 40px; height: 40px; font-size: 20px; }
  .tab{ padding: 9px 10px; font-size: 11px; }
}

/* =========================================================
   Fanatical-ish Featured grid (Featured page)
   Paste at END of style.css
   ========================================================= */

.store-hero{
  max-width: var(--max);
  margin: 0 auto;
  padding: 26px 18px 10px;
}

.store-hero-inner{
  border: 1px solid rgba(255,255,255,.14);
  background: rgba(255,255,255,.03);
  border-radius: var(--radius);
  padding: 22px;
  box-shadow: var(--shadow);
}

.store-hero-top{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap: 12px;
  margin-bottom: 8px;
}

.store-kicker{
  margin:0;
  font-weight: 950;
  font-size: 12px;
  letter-spacing: .18em;
  text-transform: uppercase;
  color: rgba(255,255,255,.72);
}

.store-hero-link{
  font-weight: 900;
  font-size: 12px;
  letter-spacing: .12em;
  text-transform: uppercase;
  color: rgba(255,255,255,.70);
  padding: 10px 12px;
  border-radius: 999px;
  border: 1px solid rgba(255,255,255,.12);
  background: rgba(0,0,0,.20);
}
.store-hero-link:hover{
  color: var(--ice);
  border-color: rgba(255,255,255,.22);
}

.store-title{
  margin: 0 0 8px;
  font-size: clamp(26px, 3.2vw, 40px);
  line-height: 1.08;
  letter-spacing: -0.02em;
}

.store-sub{
  margin: 0;
  max-width: 80ch;
  color: var(--muted);
  line-height: 1.7;
}

.store-section{
  max-width: var(--max);
  margin: 0 auto;
  padding: 16px 18px 40px;
}

.store-grid{
  display:grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 16px;
}

/* Card */
.store-card{
  border-radius: var(--radius);
  border: 1px solid rgba(255,255,255,.14);
  background: rgba(255,255,255,.03);
  box-shadow: var(--shadow);
  overflow:hidden;
}

.store-card-link{
  display:block;
  color: var(--text);
}

.store-card-link:hover .store-card-media{
  transform: scale(1.02);
}

.store-card-media{
  position: relative;
  height: 160px;
  background: rgba(255,255,255,.02);
  transition: transform .16s ease;
}

.store-card-placeholder{
  position:absolute;
  inset:0;
  background:
    radial-gradient(700px 260px at 50% 0%,
      rgba(255,255,255,.16),
      rgba(255,255,255,.04) 45%,
      transparent 70%),
    linear-gradient(180deg, rgba(255,255,255,.03), rgba(0,0,0,.10));
}

.store-card-badge{
  position:absolute;
  top: 10px;
  left: 10px;
  z-index: 2;
  padding: 7px 10px;
  border-radius: 999px;
  border: 1px solid rgba(255,255,255,.16);
  background: rgba(0,0,0,.55);
  color: rgba(255,255,255,.88);
  font-weight: 950;
  font-size: 11px;
  letter-spacing: .14em;
  text-transform: uppercase;
}

.store-card-body{
  padding: 14px 14px 16px;
}

.store-card-meta{
  display:flex;
  justify-content:space-between;
  gap: 10px;
  margin-bottom: 10px;
}

.store-tag{
  font-weight: 950;
  font-size: 11px;
  letter-spacing: .14em;
  text-transform: uppercase;
  color: rgba(255,255,255,.84);
}

.store-date{
  font-weight: 900;
  font-size: 12px;
  color: rgba(255,255,255,.55);
}

.store-card-title{
  margin: 0 0 8px;
  font-size: 16px;
  line-height: 1.25;
}

.store-card-desc{
  margin: 0 0 12px;
  color: var(--muted);
  line-height: 1.55;
  font-size: 13px;
}

.store-card-cta{
  font-weight: 950;
  font-size: 12px;
  letter-spacing: .12em;
  text-transform: uppercase;
  color: var(--ice);
  opacity: .9;
}

/* Responsive */
@media (max-width: 980px){
  .store-grid{ grid-template-columns: repeat(2, minmax(0, 1fr)); }
}
@media (max-width: 560px){
  .store-grid{ grid-template-columns: 1fr; }
  .store-card-media{ height: 150px; }
}

/* Story image upgrade */
article figure{
  margin: 22px 0;
}

article figure img{
  display: block;
  width: 100%;
  max-width: 100%;
  height: auto;
  border-radius: 18px;
  border: 1px solid rgba(255,255,255,.12);
  box-shadow: 0 18px 50px rgba(0,0,0,.45);
  background: rgba(255,255,255,.03);
}

article figcaption{
  margin-top: 10px;
  font-size: 13px;
  line-height: 1.6;
  color: var(--muted);
  text-align: center;
}
