/* =================================================================
   BILLION REACH MEDIA — Performance, by design.
   Apple-grade monochrome system. Pure white / pure black / #f5f5f7.
   ================================================================= */

:root {
  /* Color — monochrome with a single restrained accent */
  --black:        #000000;
  --ink:          #1d1d1f;
  --white:        #ffffff;
  --bg-gray:      #f5f5f7;
  --line:         #d2d2d7;
  --line-dark:    rgba(255,255,255,0.14);
  --muted:        #86868b;
  --muted-2:      #6e6e73;
  --muted-dark:   #a1a1a6;
  --accent:       #0071e3;
  --accent-press: #0077ed;

  /* Type */
  --sans: -apple-system, BlinkMacSystemFont, "SF Pro Display", "SF Pro Text", "Inter", system-ui, "Segoe UI", Roboto, sans-serif;
  --mono: "SF Mono", ui-monospace, "JetBrains Mono", "Menlo", "Consolas", monospace;

  /* Rhythm */
  --pad-x: clamp(22px, 6vw, 80px);
  --section-y: clamp(88px, 12vw, 168px);
  --maxw: 1180px;
  --maxw-text: 940px;
  --radius: 20px;
  --nav-h: 52px;
}

* { margin:0; padding:0; box-sizing:border-box; }

html { scroll-behavior:smooth; -webkit-text-size-adjust:100%; }

body {
  font-family: var(--sans);
  background: var(--white);
  color: var(--ink);
  line-height: 1.5;
  letter-spacing: -0.01em;
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
  overflow-x: hidden;
}

a { color: inherit; text-decoration: none; }
img { display:block; max-width:100%; }
::selection { background: var(--accent); color: #fff; }

/* ---------- Layout helpers ---------- */
.wrap { width:100%; max-width: var(--maxw); margin:0 auto; padding-left:var(--pad-x); padding-right:var(--pad-x); }
.section { padding-top: var(--section-y); padding-bottom: var(--section-y); }
.section--dark { background: var(--black); color:#f5f5f7; }
.section--gray { background: var(--bg-gray); color: var(--ink); }
.section--white { background: var(--white); color: var(--ink); }

.eyebrow {
  font-family: var(--mono);
  font-size: 12px;
  font-weight: 500;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--muted);
  margin-bottom: 22px;
}
.section--dark .eyebrow { color: #6e6e73; }

/* ---------- Type scale ---------- */
h1, h2, h3 { font-weight: 700; letter-spacing: -0.035em; line-height: 1.04; }
.display {
  font-size: clamp(48px, 9vw, 108px);
  font-weight: 700;
  letter-spacing: -0.045em;
  line-height: 0.98;
}
.h2 {
  font-size: clamp(34px, 5.4vw, 68px);
  letter-spacing: -0.04em;
  line-height: 1.02;
}
.lead {
  font-size: clamp(18px, 2.2vw, 26px);
  line-height: 1.4;
  letter-spacing: -0.015em;
  color: var(--muted-2);
  font-weight: 400;
}
.section--dark .lead { color: var(--muted-dark); }

/* =================================================================
   NAV
   ================================================================= */
.nav {
  position: fixed; top:0; left:0; right:0; z-index: 100;
  height: var(--nav-h);
  display:flex; align-items:center;
  background: rgba(255,255,255,0.72);
  backdrop-filter: saturate(180%) blur(20px);
  -webkit-backdrop-filter: saturate(180%) blur(20px);
  border-bottom: 1px solid transparent;
  transition: background .3s ease, border-color .3s ease;
}
.nav.scrolled { border-bottom-color: rgba(0,0,0,0.09); }
.nav__inner { width:100%; max-width: var(--maxw); margin:0 auto; padding:0 var(--pad-x);
  display:flex; align-items:center; justify-content:space-between; }
.brand { display:flex; align-items:center; gap:9px; font-weight:600; font-size:15px; letter-spacing:-0.02em; }
.brand__mark { width:11px; height:11px; border-radius:50%; background:var(--ink);
  box-shadow: 0 0 0 3px rgba(0,0,0,0.06); }
.nav__links { display:flex; align-items:center; gap: clamp(18px, 2.4vw, 34px); }
.nav__links a { font-size:13px; color: var(--ink); opacity:.82; transition:opacity .2s; }
.nav__links a:hover { opacity:1; }
.nav__cta {
  font-size:13px; font-weight:500; padding:7px 15px; border-radius:980px;
  background: var(--accent); color:#fff !important; opacity:1 !important;
  transition: background .2s, transform .15s;
}
.nav__cta:hover { background: var(--accent-press); }
.nav__cta:active { transform: scale(0.97); }
.nav__toggle { display:none; flex-direction:column; gap:5px; background:none; border:none; cursor:pointer; padding:6px; }
.nav__toggle span { width:22px; height:1.5px; background:var(--ink); transition: transform .3s, opacity .3s; }

/* =================================================================
   HERO
   ================================================================= */
.hero {
  position: relative;
  min-height: 100svh;
  display:flex; flex-direction:column; justify-content:center;
  padding-top: calc(var(--nav-h) + 4vh);
  padding-bottom: 0;
  overflow:hidden;
  background: var(--white);
}
.hero__grid {
  position:absolute; inset:0; z-index:0; pointer-events:none;
  background-image:
    linear-gradient(to right, rgba(0,0,0,0.035) 1px, transparent 1px),
    linear-gradient(to bottom, rgba(0,0,0,0.035) 1px, transparent 1px);
  background-size: 72px 72px;
  -webkit-mask-image: radial-gradient(120% 95% at 70% 18%, #000 12%, transparent 72%);
          mask-image: radial-gradient(120% 95% at 70% 18%, #000 12%, transparent 72%);
}
.hero__glow {
  position:absolute; z-index:0; top:-14%; right:-8%;
  width: 70vw; height: 70vw; max-width:900px; max-height:900px;
  border-radius:50%; pointer-events:none;
  background: radial-gradient(circle, rgba(0,113,227,0.12) 0%, rgba(0,113,227,0.04) 38%, transparent 66%);
  filter: blur(8px);
}
.hero__inner { position:relative; z-index:2; }
.hero__eyebrow {
  display:inline-flex; align-items:center; gap:9px;
  font-family:var(--mono); font-size:12px; letter-spacing:0.16em; text-transform:uppercase;
  color: var(--muted); margin-bottom: 26px;
}
.hero__eyebrow .dot { width:6px; height:6px; border-radius:50%; background:var(--accent);
  box-shadow:0 0 0 4px rgba(0,113,227,0.14); }
.hero h1 { max-width: 14ch; }
.hero h1 .grey { color: var(--muted); }
.hero__sub { margin-top: 30px; max-width: 30ch; }
.hero__actions { margin-top: 40px; display:flex; gap:14px; flex-wrap:wrap; align-items:center; }

.btn {
  display:inline-flex; align-items:center; gap:8px;
  font-size:16px; font-weight:500; padding:13px 26px; border-radius:980px;
  transition: background .2s, color .2s, transform .15s, border-color .2s;
  cursor:pointer; border:1px solid transparent;
}
.btn--primary { background: var(--accent); color:#fff; }
.btn--primary:hover { background: var(--accent-press); }
.btn--primary:active { transform: scale(0.98); }
.btn--ghost { background:transparent; color: var(--ink); border-color: var(--line); }
.btn--ghost:hover { border-color:#86868b; }
.btn--light { background:#fff; color:#1d1d1f; }
.btn--light:hover { background:#e8e8ed; }
.btn .arrow { transition: transform .25s; }
.btn:hover .arrow { transform: translate(3px,-3px); }

/* ---------- Market ticker (under hero) ---------- */
.ticker {
  position:relative; z-index:2;
  margin-top: clamp(46px, 8vh, 92px);
  border-top: 1px solid var(--line);
  padding-top: 22px; padding-bottom: 4px;
}
.ticker__label { font-family:var(--mono); font-size:11px; letter-spacing:0.18em; text-transform:uppercase;
  color: var(--muted); margin-bottom:14px; }
.marquee { position:relative; overflow:hidden; -webkit-mask-image:linear-gradient(90deg,transparent,#000 8%,#000 92%,transparent);
  mask-image:linear-gradient(90deg,transparent,#000 8%,#000 92%,transparent); }
.marquee__track { display:flex; width:max-content; animation: scrollX 34s linear infinite; }
.marquee:hover .marquee__track { animation-play-state: paused; }
.marquee__track .city {
  display:flex; align-items:center; gap:11px; padding-right:44px;
  font-size: clamp(20px, 3vw, 34px); font-weight:600; letter-spacing:-0.03em; color: var(--ink); white-space:nowrap;
}
.marquee__track .city::before { content:""; width:5px; height:5px; border-radius:50%; background: var(--muted); }
@keyframes scrollX { from{ transform:translateX(0);} to{ transform:translateX(-50%);} }

/* =================================================================
   PREMISE (dark, centered)
   ================================================================= */
.premise { text-align:center; }
.premise .h2 { max-width: 16ch; margin:0 auto; }
.premise .lead { max-width: 30ch; margin: 28px auto 0; }

/* =================================================================
   SERVICES
   ================================================================= */
.svc__head { max-width: var(--maxw-text); margin-bottom: clamp(48px,7vw,80px); }
.svc__head .h2 { max-width: 18ch; }
.svc__grid {
  display:grid; grid-template-columns: repeat(3, 1fr);
  gap:1px; background: var(--line);
  border:1px solid var(--line); border-radius: var(--radius); overflow:hidden;
}
.svc {
  background:#fff; padding: clamp(30px,3.4vw,46px) clamp(26px,3vw,38px);
  min-height: 280px; display:flex; flex-direction:column;
  transition: background .3s ease;
}
.svc:hover { background: #fafafc; }
.svc__num { font-family:var(--mono); font-size:12px; letter-spacing:0.14em; color: var(--muted); margin-bottom:auto; }
.svc__icon { width:34px; height:34px; margin-bottom:24px; color: var(--ink); }
.svc__icon svg { width:100%; height:100%; }
.svc h3 { font-size: clamp(21px, 2.1vw, 25px); letter-spacing:-0.03em; margin-bottom:12px; }
.svc p { font-size:16px; line-height:1.5; color: var(--muted-2); }
.svc__tag { margin-top:18px; font-family:var(--mono); font-size:11px; letter-spacing:0.12em; text-transform:uppercase;
  color: var(--accent); }

/* =================================================================
   CREATIVE / REELS (split, dark)
   ================================================================= */
.creative__grid { display:grid; grid-template-columns: 1.05fr 0.95fr; gap: clamp(40px,5vw,80px); align-items:center; }
.creative__copy .h2 { max-width: 12ch; }
.creative__copy .lead { margin-top:26px; max-width:38ch; }
.creative__offer {
  margin-top:34px; padding:26px 28px; border-radius:18px;
  background: rgba(255,255,255,0.05); border:1px solid var(--line-dark);
}
.creative__offer strong { color:#fff; font-weight:600; }
.creative__offer p { color: var(--muted-dark); font-size:16px; line-height:1.55; }
.creative__offer .pill { display:inline-block; margin-bottom:14px; font-family:var(--mono); font-size:11px;
  letter-spacing:0.14em; text-transform:uppercase; color:#fff; padding:5px 11px; border:1px solid var(--line-dark); border-radius:980px; }

/* Phone mock visual */
.phone { justify-self:center; position:relative; width:min(300px,72vw); aspect-ratio: 9/19; }
.phone__shell {
  position:absolute; inset:0; border-radius:42px; padding:10px;
  background: linear-gradient(160deg,#2a2a2e,#0a0a0c);
  box-shadow: 0 40px 90px rgba(0,0,0,0.55), inset 0 0 0 1px rgba(255,255,255,0.08);
}
.phone__screen {
  position:absolute; inset:10px; border-radius:34px; overflow:hidden;
  background: linear-gradient(155deg,#111114 0%, #1b2a4a 55%, #0a1830 100%);
  display:flex; flex-direction:column; justify-content:flex-end;
}
.phone__notch { position:absolute; top:18px; left:50%; transform:translateX(-50%); z-index:3;
  width:96px; height:26px; background:#000; border-radius:980px; }
.phone__play { position:absolute; top:50%; left:50%; transform:translate(-50%,-50%); z-index:2;
  width:62px; height:62px; border-radius:50%; background:rgba(255,255,255,0.16);
  backdrop-filter:blur(6px); display:flex; align-items:center; justify-content:center;
  border:1px solid rgba(255,255,255,0.3); }
.phone__play::after { content:""; margin-left:4px; border-style:solid; border-width:9px 0 9px 15px;
  border-color: transparent transparent transparent #fff; }
.phone__caption { position:relative; z-index:2; padding:18px 16px; }
.phone__caption .h { color:#fff; font-size:15px; font-weight:600; letter-spacing:-0.02em; }
.phone__caption .s { color: rgba(255,255,255,0.7); font-size:12px; margin-top:3px; }
.phone__bars { position:relative; z-index:2; display:flex; gap:4px; align-items:flex-end; padding:0 16px 22px; height:48px; }
.phone__bars span { flex:1; background: var(--accent); border-radius:3px 3px 0 0; opacity:.85;
  animation: eq 1.2s ease-in-out infinite; }
.phone__bars span:nth-child(2){ animation-delay:.15s }
.phone__bars span:nth-child(3){ animation-delay:.3s }
.phone__bars span:nth-child(4){ animation-delay:.45s }
.phone__bars span:nth-child(5){ animation-delay:.6s }
.phone__bars span:nth-child(6){ animation-delay:.75s }
@keyframes eq { 0%,100%{ height:22% } 50%{ height:92% } }

/* =================================================================
   STATS
   ================================================================= */
.stats__head { text-align:center; max-width: var(--maxw-text); margin:0 auto clamp(48px,6vw,76px); }
.stats__head .h2 { max-width:16ch; margin:0 auto; }
.stats__grid { display:grid; grid-template-columns: repeat(4,1fr); gap:1px; background: var(--line-dark);
  border-top:1px solid var(--line-dark); border-bottom:1px solid var(--line-dark); }
.stat { background: var(--black); padding: clamp(30px,4vw,52px) clamp(18px,2.4vw,30px); text-align:left; }
.stat__num { font-size: clamp(52px, 6vw, 80px); font-weight:700; letter-spacing:-0.05em; line-height:1; color:#fff; }
.stat__num .plus { color: var(--accent); }
.stat__label { margin-top:16px; font-size:15px; color: var(--muted-dark); line-height:1.4; }
.stats__foot { text-align:center; margin-top: clamp(40px,5vw,60px); }
.stats__foot p { font-family:var(--mono); font-size:13px; letter-spacing:0.08em; color: var(--muted-dark); }

/* =================================================================
   PROCESS
   ================================================================= */
.process__head { max-width: var(--maxw-text); margin-bottom: clamp(44px,6vw,72px); }
.process__head .h2 { max-width:14ch; }
.process__grid { display:grid; grid-template-columns: repeat(4,1fr); gap:1px; background: var(--line);
  border:1px solid var(--line); border-radius: var(--radius); overflow:hidden; }
.proc { background:#fff; padding: clamp(28px,3vw,40px) clamp(24px,2.6vw,32px); min-height:230px;
  display:flex; flex-direction:column; }
.proc__step { font-family:var(--mono); font-size:12px; letter-spacing:0.14em; text-transform:uppercase;
  color: var(--muted); margin-bottom:auto; }
.proc h3 { font-size: clamp(19px,1.9vw,23px); letter-spacing:-0.03em; margin:0 0 12px; }
.proc p { font-size:15px; color: var(--muted-2); line-height:1.5; }

/* =================================================================
   OPERATING MODEL (numbered list, dark)
   ================================================================= */
.model__head { text-align:center; margin-bottom: clamp(40px,5vw,64px); }
.model__head .eyebrow { color:#6e6e73; }
.model__head .h2 { max-width:18ch; margin:0 auto; }
.model__row {
  display:grid; grid-template-columns: 70px 1fr; gap: clamp(16px,4vw,56px);
  padding: clamp(28px,3.4vw,42px) 0; border-top:1px solid var(--line-dark);
  align-items:start;
}
.model__row:last-child { border-bottom:1px solid var(--line-dark); }
.model__no { font-family:var(--mono); font-size:14px; color: var(--muted); padding-top:8px; }
.model__body h3 { font-size: clamp(24px,3.4vw,40px); letter-spacing:-0.035em; color:#fff; }
.model__body p { margin-top:14px; max-width:60ch; font-size:17px; line-height:1.55; color: var(--muted-dark); }

/* =================================================================
   CONTROL (split, gray)
   ================================================================= */
.control__grid { display:grid; grid-template-columns: 1fr 1fr; gap: clamp(40px,5vw,80px); align-items:center; }
.control__copy .h2 { max-width:10ch; }
.control__copy .lead { margin-top:24px; max-width:42ch; }
.control__copy .rule { height:1px; background: var(--line); margin:32px 0; max-width:480px; }
.control__copy .kicker { font-size: clamp(20px,2.4vw,28px); font-weight:600; letter-spacing:-0.03em; color: var(--ink); }
.control__panel {
  border-radius: var(--radius); padding: clamp(30px,4vw,48px);
  background: linear-gradient(150deg,#fff 0%, #eef1f6 100%);
  border:1px solid var(--line); box-shadow: 0 30px 70px rgba(0,0,0,0.07);
}
.control__platforms { display:grid; grid-template-columns: repeat(2,1fr); gap:14px; }
.plat { display:flex; align-items:center; gap:12px; padding:16px 18px; border-radius:14px;
  background:#fff; border:1px solid var(--line); }
.plat__dot { width:9px; height:9px; border-radius:50%; background: var(--accent); }
.plat__name { font-weight:600; font-size:15px; letter-spacing:-0.02em; }
.plat__sub { font-family:var(--mono); font-size:11px; color: var(--muted); letter-spacing:0.06em; }
.control__note { margin-top:24px; font-family:var(--mono); font-size:12px; letter-spacing:0.1em;
  text-transform:uppercase; color: var(--muted-2); display:flex; align-items:center; gap:9px; }
.control__note .live { width:8px; height:8px; border-radius:50%; background:#1db954; box-shadow:0 0 0 4px rgba(29,185,84,0.18); }

/* =================================================================
   REVIEWS (left-to-right scroll, multi-market)
   ================================================================= */
.reviews { overflow:hidden; }
.reviews__head { max-width: var(--maxw-text); margin-bottom: clamp(40px,5vw,64px); padding:0 var(--pad-x);
  margin-left:auto; margin-right:auto; }
.reviews__head .h2 { max-width:18ch; }
.rev-marquee { position:relative; overflow:hidden;
  -webkit-mask-image:linear-gradient(90deg,transparent,#000 5%,#000 95%,transparent);
          mask-image:linear-gradient(90deg,transparent,#000 5%,#000 95%,transparent); }
.rev-marquee + .rev-marquee { margin-top: 20px; }
.rev-track { display:flex; width:max-content; gap:20px; padding:4px 10px;
  animation: revScroll 60s linear infinite; }
.rev-track--rev { animation-direction: reverse; animation-duration: 72s; }
.rev-marquee:hover .rev-track { animation-play-state: paused; }
@keyframes revScroll { from{ transform:translateX(0);} to{ transform:translateX(-50%);} }

.rev-card {
  flex: 0 0 clamp(300px, 30vw, 388px);
  background:#fff; border:1px solid var(--line); border-radius:18px;
  padding: 26px 28px; display:flex; flex-direction:column; gap:16px;
}
.section--dark .rev-card { background:#161617; border-color:#2a2a2c; }
.rev-card__stars { color:#1d1d1f; font-size:14px; letter-spacing:2px; }
.section--dark .rev-card__stars { color:#fff; }
.rev-card__quote { font-size:16px; line-height:1.55; letter-spacing:-0.01em; color: var(--ink); }
.section--dark .rev-card__quote { color:#f5f5f7; }
.rev-card__who { display:flex; align-items:center; gap:13px; margin-top:auto; }
.rev-card__av { width:40px; height:40px; border-radius:50%; flex:none;
  display:flex; align-items:center; justify-content:center; font-weight:600; font-size:14px;
  background: var(--bg-gray); color: var(--ink); }
.section--dark .rev-card__av { background:#2a2a2c; color:#f5f5f7; }
.rev-card__name { font-weight:600; font-size:14px; letter-spacing:-0.01em; }
.rev-card__meta { font-family:var(--mono); font-size:11px; color: var(--muted); letter-spacing:0.04em; margin-top:2px; }
.section--dark .rev-card__meta { color: var(--muted-dark); }
.rev-card__flag { margin-left:auto; font-size:18px; }

/* =================================================================
   WHO IT'S FOR
   ================================================================= */
.who { text-align:center; }
.who h2 { font-size: clamp(38px,6vw,76px); letter-spacing:-0.04em; line-height:1.05; max-width:18ch; margin:0 auto; }
.who h2 .grey { color: var(--muted); }
.who .lead { max-width: 40ch; margin: 30px auto 0; }

/* =================================================================
   CTA / FOOTER
   ================================================================= */
.cta { text-align:center; }
.cta h2 { font-size: clamp(40px,7vw,84px); letter-spacing:-0.045em; line-height:1.02; max-width:16ch; margin:0 auto; }
.cta__btn { margin-top: 44px; }
.cta__contacts { margin-top: clamp(54px,7vw,80px); display:flex; justify-content:center; flex-wrap:wrap;
  gap: clamp(22px,5vw,64px); }
.cta__contact { text-align:left; }
.cta__contact .k { font-family:var(--mono); font-size:11px; letter-spacing:0.14em; text-transform:uppercase;
  color: var(--muted); display:block; margin-bottom:6px; }
.cta__contact a { font-size:16px; font-weight:500; color:#f5f5f7; border-bottom:1px solid transparent; transition:border-color .2s; }
.cta__contact a:hover { border-bottom-color:#f5f5f7; }

.foot { border-top:1px solid var(--line-dark); }
.foot__inner { padding: 34px var(--pad-x); display:flex; justify-content:space-between; align-items:center;
  flex-wrap:wrap; gap:16px; max-width:var(--maxw); margin:0 auto; }
.foot__brand { display:flex; align-items:center; gap:9px; font-weight:600; font-size:14px; color:#f5f5f7; }
.foot__brand .brand__mark { background:#f5f5f7; box-shadow:0 0 0 3px rgba(255,255,255,0.08); }
.foot__legal { font-size:12px; color: var(--muted); }

/* =================================================================
   SCROLL REVEAL
   ================================================================= */
.reveal { opacity:0; transform: translateY(26px); transition: opacity .8s cubic-bezier(.2,.7,.2,1), transform .8s cubic-bezier(.2,.7,.2,1); }
.reveal.in { opacity:1; transform:none; }
.reveal[data-d="1"]{ transition-delay:.08s } .reveal[data-d="2"]{ transition-delay:.16s }
.reveal[data-d="3"]{ transition-delay:.24s } .reveal[data-d="4"]{ transition-delay:.32s }

/* =================================================================
   RESPONSIVE
   ================================================================= */
@media (max-width: 980px) {
  .svc__grid { grid-template-columns: repeat(2,1fr); }
  .stats__grid { grid-template-columns: repeat(2,1fr); }
  .process__grid { grid-template-columns: repeat(2,1fr); }
  .creative__grid, .control__grid { grid-template-columns: 1fr; gap:46px; }
  .phone { order:-1; }
  .control__panel { order:2; }
}
@media (max-width: 720px) {
  .nav__links { position:fixed; inset: var(--nav-h) 0 auto 0; flex-direction:column; align-items:flex-start;
    gap:4px; padding: 18px var(--pad-x) 26px; background: rgba(255,255,255,0.96);
    backdrop-filter: blur(20px); border-bottom:1px solid var(--line);
    transform: translateY(-12px); opacity:0; pointer-events:none; transition: transform .3s, opacity .3s; }
  .nav__links.open { transform:none; opacity:1; pointer-events:auto; }
  .nav__links a { font-size:17px; padding:9px 0; }
  .nav__cta { margin-top:10px; }
  .nav__toggle { display:flex; }
  .svc__grid, .process__grid { grid-template-columns: 1fr; }
  .stats__grid { grid-template-columns: 1fr 1fr; }
  .model__row { grid-template-columns: 1fr; gap:6px; }
  .model__no { padding-top:0; }
}
@media (max-width: 420px) {
  .stats__grid { grid-template-columns: 1fr; }
  .hero__actions { flex-direction:column; align-items:stretch; }
  .btn { justify-content:center; }
}

/* Reduced motion */
@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after { animation-duration:0.001ms !important; animation-iteration-count:1 !important;
    transition-duration:0.001ms !important; scroll-behavior:auto !important; }
  .reveal { opacity:1; transform:none; }
}

/* Focus visibility */
:focus-visible { outline: 2px solid var(--accent); outline-offset: 3px; border-radius:4px; }
