/* ============================================================
   COBIS — Design System (monochrome, light, Geist)
   ============================================================ */

@import url('https://fonts.googleapis.com/css2?family=Geist:wght@300;400;500;600;700&family=Geist+Mono:wght@400;500&display=swap');

:root{
  /* Monochrome ramp (strictly neutral) */
  --ink:        #131313;   /* primary text */
  --ink-2:      #3a3a3a;   /* secondary text */
  --ink-3:      #6b6b6b;   /* muted */
  --ink-4:      #9a9a9a;   /* faint */
  --line:       #e4e3e1;   /* hairline */
  --line-2:     #d2d1cf;   /* stronger hairline */
  --paper:      #fbfbfa;   /* page background */
  --paper-2:    #f4f3f1;   /* alt section bg */
  --paper-3:    #efeeec;   /* deeper alt */
  --white:      #ffffff;
  --black:      #0e0e0e;

  --maxw: 1240px;
  --gutter: clamp(20px, 5vw, 64px);

  --r-sm: 4px;
  --r:    8px;
  --r-lg: 14px;

  --ease: cubic-bezier(.22,.61,.36,1);

  --fs-eyebrow: 12px;
  --shadow-sm: 0 1px 2px rgba(0,0,0,.04);
  --shadow:    0 18px 50px -28px rgba(0,0,0,.30);
}

*{ box-sizing:border-box; }
html{ -webkit-text-size-adjust:100%; scroll-behavior:smooth; }
@media (prefers-reduced-motion: reduce){ html{ scroll-behavior:auto; } }

body{
  margin:0;
  font-family:"Geist", system-ui, -apple-system, sans-serif;
  background:var(--paper);
  color:var(--ink);
  font-size:18px;
  line-height:1.6;
  font-weight:400;
  letter-spacing:-0.011em;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}

img,svg{ display:block; max-width:100%; }
a{ color:inherit; text-decoration:none; }
button{ font-family:inherit; cursor:pointer; }

/* ---------- Layout ---------- */
.container{ width:100%; max-width:var(--maxw); margin-inline:auto; padding-inline:var(--gutter); }
.section{ padding-block:clamp(72px, 9vw, 140px); }
.section--tight{ padding-block:clamp(56px, 6vw, 96px); }
.bg-paper2{ background:var(--paper-2); }
.bg-paper3{ background:var(--paper-3); }
.bg-ink{ background:var(--black); color:#f3f3f2; }
.divide-top{ border-top:1px solid var(--line); }

/* ---------- Typography ---------- */
.display{
  font-weight:600;
  letter-spacing:-0.035em;
  line-height:0.98;
  font-size:clamp(40px, 6.6vw, 92px);
  margin:0;
}
h1,h2,h3,h4{ margin:0; font-weight:600; letter-spacing:-0.028em; line-height:1.04; }
.h2{ font-size:clamp(30px, 4.2vw, 56px); }
.h3{ font-size:clamp(23px, 2.5vw, 34px); letter-spacing:-0.022em; }
.h4{ font-size:clamp(19px, 1.5vw, 23px); letter-spacing:-0.018em; font-weight:600; }
.lede{ font-size:clamp(19px, 1.7vw, 24px); line-height:1.5; color:var(--ink-2); font-weight:400; letter-spacing:-0.015em; }
p{ margin:0 0 1.1em; color:var(--ink-2); }
.measure{ max-width:64ch; }
.measure-sm{ max-width:46ch; }
strong{ color:var(--ink); font-weight:600; }

.eyebrow{
  font-family:"Geist Mono", ui-monospace, monospace;
  font-size:var(--fs-eyebrow);
  font-weight:500;
  letter-spacing:0.18em;
  text-transform:uppercase;
  color:var(--ink-3);
  display:inline-flex;
  align-items:center;
  gap:10px;
  margin:0 0 22px;
}
.eyebrow::before{
  content:"";
  width:26px; height:1px; background:var(--ink-4);
  display:inline-block;
}
.eyebrow--plain::before{ display:none; }

.section-head{ max-width:62ch; margin-bottom:clamp(40px,5vw,72px); }
.section-head .lede{ margin-top:22px; }

/* ---------- Buttons ---------- */
.btn{
  --bg:var(--black); --fg:#fff; --bd:var(--black);
  display:inline-flex; align-items:center; gap:10px;
  background:var(--bg); color:var(--fg);
  border:1px solid var(--bd);
  padding:15px 26px;
  border-radius:var(--r);
  font-size:15px; font-weight:500; letter-spacing:-0.01em;
  transition:transform .45s var(--ease), background .3s var(--ease), color .3s var(--ease), border-color .3s var(--ease);
  position:relative; overflow:hidden;
}
.btn .arr{ transition:transform .45s var(--ease); }
.btn:hover{ transform:translateY(-2px); }
.btn:hover .arr{ transform:translateX(4px); }
.btn--ghost{ --bg:transparent; --fg:var(--ink); --bd:var(--line-2); }
.btn--ghost:hover{ --bd:var(--ink); background:transparent; }
.btn--light{ --bg:#fff; --fg:var(--black); --bd:#fff; }
.btn--block{ width:100%; justify-content:center; }
.btn--sm{ padding:11px 18px; font-size:14px; }

.linkarrow{
  display:inline-flex; align-items:center; gap:9px;
  font-weight:500; font-size:15px; color:var(--ink);
  border-bottom:1px solid var(--line-2);
  padding-bottom:3px;
  transition:gap .4s var(--ease), border-color .3s var(--ease);
}
.linkarrow:hover{ gap:14px; border-color:var(--ink); }
.linkarrow .arr{ transition:transform .4s var(--ease); }
.linkarrow:hover .arr{ transform:translateX(3px); }

/* ---------- Image placeholders (striped + mono label) ---------- */
.ph{
  position:relative;
  background:
    repeating-linear-gradient(135deg,
      #ededeb 0 11px,
      #f6f6f4 11px 22px);
  border:1px solid var(--line-2);
  border-radius:var(--r);
  display:grid; place-items:center;
  overflow:hidden;
  color:var(--ink-3);
  min-height:200px;
}
.ph::after{
  content:attr(data-label);
  font-family:"Geist Mono", monospace;
  font-size:11px; letter-spacing:0.14em; text-transform:uppercase;
  color:var(--ink-3);
  background:rgba(251,251,250,.82);
  border:1px solid var(--line-2);
  padding:7px 13px; border-radius:999px;
  backdrop-filter:blur(2px);
  max-width:80%; text-align:center;
}
.ph--dark{
  background:
    repeating-linear-gradient(135deg,
      #1b1b1b 0 11px,
      #232323 11px 22px);
  border-color:#2c2c2c;
}
.ph--dark::after{ background:rgba(14,14,14,.7); border-color:#333; color:#cfcfcf; }
.ph--tall{ aspect-ratio:4/5; }
.ph--wide{ aspect-ratio:16/9; }
.ph--square{ aspect-ratio:1/1; }
.ph--portrait{ aspect-ratio:3/4; }

/* ---------- Cards ---------- */
.card{
  background:var(--white);
  border:1px solid var(--line);
  border-radius:var(--r-lg);
  padding:clamp(26px,3vw,40px);
  transition:transform .5s var(--ease), border-color .4s var(--ease), box-shadow .5s var(--ease);
  position:relative;
}
.card:hover{ transform:translateY(-4px); border-color:var(--line-2); box-shadow:var(--shadow); }
.card .num{
  font-family:"Geist Mono", monospace; font-size:12px; letter-spacing:.1em;
  color:var(--ink-4); display:block; margin-bottom:24px;
}

/* ---------- Header ---------- */
.site-header{
  position:sticky; top:0; z-index:60;
  background:rgba(251,251,250,0);
  transition:background .4s var(--ease), border-color .4s var(--ease), backdrop-filter .4s var(--ease);
  border-bottom:1px solid transparent;
}
.site-header.is-stuck{
  background:rgba(251,251,250,.82);
  backdrop-filter:blur(12px) saturate(1.4);
  border-bottom-color:var(--line);
}
.nav{ display:flex; align-items:center; justify-content:space-between; height:80px; gap:32px; }
.nav__logo{ color:var(--ink); flex:none; }
.nav__logo svg{ height:30px; width:auto; }
.nav__links{ display:flex; align-items:center; gap:34px; list-style:none; margin:0; padding:0; }
.nav__links a{
  font-size:15px; color:var(--ink-2); font-weight:450;
  position:relative; padding:6px 0; transition:color .3s var(--ease);
}
.nav__links a::after{
  content:""; position:absolute; left:0; bottom:0; height:1px; width:0; background:var(--ink);
  transition:width .4s var(--ease);
}
.nav__links a:hover{ color:var(--ink); }
.nav__links a:hover::after,
.nav__links a.is-active::after{ width:100%; }
.nav__links a.is-active{ color:var(--ink); }
.nav__cta{ display:flex; align-items:center; gap:16px; }
.nav__toggle{ display:none; background:none; border:1px solid var(--line-2); border-radius:var(--r-sm); padding:9px; }
.nav__toggle span{ display:block; width:20px; height:1.6px; background:var(--ink); margin:4px 0; transition:.3s var(--ease); }

/* mobile drawer */
.nav__drawer{ display:none; }
@media (max-width: 920px){
  .nav__links, .nav__cta .btn{ display:none; }
  .nav__toggle{ display:block; }
  .nav__drawer{
    display:block; position:fixed; inset:80px 0 auto 0; z-index:55;
    background:var(--paper); border-bottom:1px solid var(--line);
    transform:translateY(-105%); transition:transform .5s var(--ease);
    padding:18px var(--gutter) 32px;
  }
  .nav__drawer.open{ transform:translateY(0); }
  .nav__drawer a{ display:block; padding:16px 0; font-size:20px; border-bottom:1px solid var(--line); color:var(--ink); }
  .nav__drawer .btn{ margin-top:22px; }
  body.nav-open{ overflow:hidden; }
}

/* ---------- Footer ---------- */
.site-footer{ background:var(--black); color:#cdcdcb; padding-block:clamp(64px,7vw,100px) 40px; }
.site-footer a{ color:#cdcdcb; transition:color .3s var(--ease); }
.site-footer a:hover{ color:#fff; }
.footer-grid{ display:grid; grid-template-columns:1.6fr 1fr 1fr 1fr; gap:48px; }
.footer-grid h5{ font-family:"Geist Mono",monospace; font-size:11px; letter-spacing:.16em; text-transform:uppercase; color:#7d7d7b; margin:0 0 20px; font-weight:500; }
.footer-grid ul{ list-style:none; margin:0; padding:0; display:flex; flex-direction:column; gap:13px; font-size:15px; }
.footer-logo{ color:#fff; margin-bottom:22px; }
.footer-logo svg{ height:30px; }
.footer-bottom{ display:flex; justify-content:space-between; gap:20px; flex-wrap:wrap; margin-top:clamp(48px,6vw,80px); padding-top:28px; border-top:1px solid #262626; font-size:13px; color:#7d7d7b; font-family:"Geist Mono",monospace; letter-spacing:.04em; }
@media (max-width:820px){ .footer-grid{ grid-template-columns:1fr 1fr; gap:40px 32px; } }
@media (max-width:520px){ .footer-grid{ grid-template-columns:1fr; } }

/* ---------- Reveal animations ---------- */
[data-reveal]{
  opacity:0; transform:translateY(26px);
  transition:opacity .9s var(--ease), transform .9s var(--ease);
  transition-delay:var(--d, 0ms);
  will-change:opacity, transform;
}
[data-reveal].in{ opacity:1; transform:none; }
@media (prefers-reduced-motion: reduce){
  [data-reveal]{ opacity:1 !important; transform:none !important; transition:none; }
}

/* ---------- Misc utilities ---------- */
.grid{ display:grid; gap:24px; }
.cols-2{ grid-template-columns:repeat(2,1fr); }
.cols-3{ grid-template-columns:repeat(3,1fr); }
.cols-4{ grid-template-columns:repeat(4,1fr); }
@media (max-width:900px){ .cols-3,.cols-4{ grid-template-columns:repeat(2,1fr); } }
@media (max-width:620px){ .cols-2,.cols-3,.cols-4{ grid-template-columns:1fr; } }

.rule{ height:1px; background:var(--line); border:0; margin:0; }
.kicker-index{ font-family:"Geist Mono",monospace; font-size:12px; color:var(--ink-4); letter-spacing:.08em; }

.logo-img{ height:30px; width:auto; }
.logo-img--invert{ filter:invert(1); }

.center-cta{ text-align:center; margin-top:clamp(48px,6vw,80px); }

/* ============================================================
   PAGE COMPONENTS
   ============================================================ */

/* ---- Hero ---- */
.hero{ padding-top:clamp(48px,6vw,84px); }
.hero__grid{
  display:grid; grid-template-columns:1.15fr .85fr; gap:clamp(32px,5vw,72px);
  align-items:center;
}
.hero__accent{ color:var(--ink-3); }
.hero__cta{ display:flex; flex-wrap:wrap; gap:14px; margin-top:36px; }
.hero__meta{
  display:flex; gap:clamp(20px,3vw,44px); list-style:none; margin:48px 0 0; padding:30px 0 0;
  border-top:1px solid var(--line); flex-wrap:wrap;
}
.hero__meta li{ display:flex; flex-direction:column; gap:3px; }
.hero__meta strong{ font-size:17px; }
.hero__meta span{ font-size:13px; color:var(--ink-3); }
.hero__media{ position:relative; }

/* Framed portrait — grayscale by default, gentle color reveal on hover */
.portrait-frame{
  position:relative; margin:0;
  background:var(--white);
  border:1px solid var(--line-2);
  border-radius:var(--r-lg);
  padding:14px 14px 0;
  box-shadow:var(--shadow);
}
.portrait-frame::before{
  /* faint striped mat behind the photo, echoing the placeholder language */
  content:""; position:absolute; inset:14px 14px 64px;
  background:repeating-linear-gradient(135deg,#f1f0ee 0 9px,#f6f5f3 9px 18px);
  border-radius:var(--r); z-index:0;
}
.portrait-frame__inner{
  position:relative; z-index:1;
  aspect-ratio:5/6; overflow:hidden; border-radius:var(--r);
  background:linear-gradient(180deg,#edecea 0%,#e3e2e0 100%);
}
.portrait-frame__img{
  width:100%; height:100%; object-fit:cover; object-position:50% 12%;
  filter:grayscale(1) contrast(1.02);
  transition:filter .7s var(--ease), transform 1.2s var(--ease);
  transform:scale(1.01);
}
.portrait-frame:hover .portrait-frame__img{
  filter:grayscale(0) contrast(1.01);
  transform:scale(1.04);
}
.portrait-frame__cap{
  position:relative; z-index:1;
  display:flex; align-items:baseline; justify-content:space-between; gap:12px;
  padding:14px 4px 16px;
}
.portrait-frame__name{ font-weight:600; letter-spacing:-0.02em; font-size:16px; }
.portrait-frame__role{
  font-family:"Geist Mono", monospace; font-size:11px; letter-spacing:.04em;
  text-transform:uppercase; color:var(--ink-3);
}
@media (prefers-reduced-motion: reduce){
  .portrait-frame__img{ transition:none; transform:none; }
}

.hero__badge{
  position:absolute; left:-22px; bottom:64px;
  background:var(--black); color:#f4f3f1; border:1px solid #2a2a2a; border-radius:var(--r);
  padding:16px 22px; box-shadow:var(--shadow); display:flex; flex-direction:column; gap:2px;
}
.hero__badge .kicker-index{ color:#8a8a88; }
.hero__badge-yr{ font-size:30px; font-weight:600; letter-spacing:-0.03em; line-height:1; }
@media (max-width:860px){
  .hero__grid{ grid-template-columns:1fr; }
  .hero__media{ order:-1; max-width:420px; }
  .hero__badge{ left:auto; right:18px; bottom:64px; }
}

/* ---- Pullquote ---- */
.pullquote{
  margin:0 0 clamp(56px,7vw,96px); padding:0;
  max-width:24ch; font-size:clamp(26px,3.4vw,46px); font-weight:500;
  letter-spacing:-0.025em; line-height:1.14; color:var(--ink);
  position:relative;
}
.pullquote .pullquote__mark{ display:block; font-size:1.4em; line-height:0; color:var(--ink-4); margin-bottom:.2em; }
.pullquote cite{ display:block; margin-top:22px; font-size:13px; font-style:normal; font-family:"Geist Mono",monospace; letter-spacing:.14em; text-transform:uppercase; color:var(--ink-3); }
@media (min-width:760px){ .pullquote{ max-width:30ch; } }

/* ---- Detail block (text + media) ---- */
.detail-block{ display:grid; grid-template-columns:.85fr 1.15fr; gap:clamp(32px,5vw,72px); align-items:start; }
.detail-block--reverse .detail-block__media{ order:2; }
.detail-block__media .ph{ position:sticky; top:110px; }
.spartenlist{
  list-style:none; margin:28px 0 0; padding:0;
  columns:2; column-gap:36px;
}
.spartenlist li{
  break-inside:avoid; padding:13px 0 13px 26px; border-top:1px solid var(--line);
  font-size:15.5px; color:var(--ink); position:relative; letter-spacing:-0.01em;
}
.spartenlist li::before{
  content:"+"; position:absolute; left:0; top:13px; color:var(--ink-4);
  font-family:"Geist Mono",monospace; font-size:14px;
}
@media (max-width:760px){
  .detail-block{ grid-template-columns:1fr; }
  .detail-block--reverse .detail-block__media{ order:0; }
  .detail-block__media .ph{ position:static; }
}
@media (max-width:480px){ .spartenlist{ columns:1; } }

/* ---- Teaser Pension (dark) ---- */
.teaser-grid{ display:grid; grid-template-columns:1.1fr .9fr; gap:clamp(40px,6vw,88px); align-items:center; }
.teaser-pension .h2{ color:#fff; max-width:18ch; }
.teaser-sub{ font-size:clamp(18px,2vw,24px); color:#fff; font-weight:500; margin:18px 0 22px; }
.gapfig{ display:flex; flex-direction:column; gap:14px; }
.gapfig__bar{
  position:relative; border:1px solid #2c2c2c; border-radius:var(--r);
  padding:18px 20px; display:flex; justify-content:space-between; align-items:baseline; gap:16px;
  overflow:hidden;
}
.gapfig__bar::before{ content:""; position:absolute; inset:0; background:#fff; transform-origin:left; transform:scaleX(var(--w,1)); opacity:.07; }
.gapfig__bar--full{ --w:1; }
.gapfig__bar--pension{ --w:.66; }
.gapfig__bar--bu{ --w:.58; }
.gapfig__lbl{ font-size:14px; color:#cfcfcd; position:relative; }
.gapfig__val{ font-family:"Geist Mono",monospace; font-size:15px; color:#fff; position:relative; font-weight:500; }
.gapfig__note{ font-size:12.5px; color:#7d7d7b; margin:6px 0 0; }
@media (max-width:820px){ .teaser-grid{ grid-template-columns:1fr; } }

/* ---- Finanzierung split ---- */
.fin-split{ display:grid; grid-template-columns:1fr 1fr; gap:clamp(36px,5vw,72px); align-items:start; }
.advantages{ list-style:none; margin:0; padding:0; display:flex; flex-direction:column; }
.advantages li{ display:flex; gap:22px; padding:24px 0; border-top:1px solid var(--line-2); }
.advantages li:last-child{ border-bottom:1px solid var(--line-2); }
.advantages__n{ font-family:"Geist Mono",monospace; font-size:13px; color:var(--ink-4); padding-top:4px; }
.advantages strong{ font-size:18px; display:block; margin-bottom:4px; }
.advantages p{ margin:0; font-size:15px; }
@media (max-width:760px){ .fin-split{ grid-template-columns:1fr; } }

/* ---- VIP grid ---- */
.vip-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:1px; background:var(--line); border:1px solid var(--line); border-radius:var(--r-lg); overflow:hidden; }
.vip{ background:var(--white); padding:clamp(26px,2.6vw,38px); transition:background .4s var(--ease); }
.vip:hover{ background:var(--paper-2); }
.vip__n{ font-family:"Geist Mono",monospace; font-size:12px; color:var(--ink-4); letter-spacing:.1em; display:block; margin-bottom:20px; }
.vip h4{ margin-bottom:12px; }
.vip p{ margin:0; font-size:15px; }
.vip--cta{ background:var(--black); color:#f3f3f2; display:flex; flex-direction:column; }
.vip--cta:hover{ background:#1a1a1a; }
.vip--cta h4{ color:#fff; }
.vip--cta p{ color:#bdbdbb; margin-bottom:18px; }
.vip--cta .linkarrow{ color:#fff; border-color:#444; margin-top:auto; }
.vip--cta .linkarrow:hover{ border-color:#fff; }
@media (max-width:860px){ .vip-grid{ grid-template-columns:repeat(2,1fr); } }
@media (max-width:560px){ .vip-grid{ grid-template-columns:1fr; } }

/* ---- About / stats ---- */
.about-grid{ display:grid; grid-template-columns:1fr 1fr; gap:clamp(40px,6vw,88px); align-items:center; }
.stats{ display:flex; flex-direction:column; }
.stat{ padding:26px 0; border-top:1px solid var(--line-2); display:flex; align-items:baseline; gap:24px; }
.stat:last-child{ border-bottom:1px solid var(--line-2); }
.stat__num{ font-size:clamp(40px,5vw,64px); font-weight:600; letter-spacing:-0.04em; line-height:1; flex:none; min-width:3.2ch; }
.stat__lbl{ color:var(--ink-2); font-size:16px; }
@media (max-width:820px){ .about-grid{ grid-template-columns:1fr; } }

/* ---- Geschäftsführung ---- */
.gf-grid{ display:grid; grid-template-columns:.8fr 1.2fr; gap:clamp(36px,5vw,80px); align-items:start; }
.gf-aside{ position:sticky; top:104px; display:flex; flex-direction:column; gap:18px; }
.gf-card{ border:1px solid var(--line); border-radius:var(--r); padding:22px; background:var(--white); }
.gf-card p{ font-size:15px; }
.gf-body{ display:flex; flex-direction:column; gap:clamp(36px,4vw,56px); }
.timeline__head{ margin-bottom:20px; padding-bottom:14px; border-bottom:1px solid var(--line-2); }
.timeline dl{ margin:0; }
.timeline dl > div{ display:grid; grid-template-columns:120px 1fr; gap:24px; padding:13px 0; border-top:1px solid var(--line); align-items:baseline; }
.timeline dl > div:first-child{ border-top:0; }
.timeline dt{ font-family:"Geist Mono",monospace; font-size:13px; color:var(--ink-3); letter-spacing:.02em; }
.timeline dd{ margin:0; color:var(--ink); font-size:16px; }
@media (max-width:860px){ .gf-grid{ grid-template-columns:1fr; } .gf-aside{ position:static; } }
@media (max-width:520px){ .timeline dl > div{ grid-template-columns:1fr; gap:4px; } }

/* ---- Team ---- */
.team-grid{ display:grid; grid-template-columns:1fr 1.1fr; gap:clamp(36px,5vw,72px); align-items:center; }
@media (max-width:820px){ .team-grid{ grid-template-columns:1fr; } }

/* ---- Awards ---- */
.award figcaption{ margin-top:16px; font-size:14px; color:var(--ink-2); letter-spacing:-0.01em; }
.award .ph{ transition:transform .5s var(--ease); }
.award:hover .ph{ transform:translateY(-4px); }

/* ---- Partners ---- */
.partners{ list-style:none; margin:0; padding:0; display:grid; grid-template-columns:repeat(2,1fr); gap:1px; background:var(--line-2); border:1px solid var(--line-2); border-radius:var(--r-lg); overflow:hidden; }
.partners li{ background:var(--paper); padding:clamp(24px,3vw,40px); display:flex; flex-direction:column; gap:8px; transition:background .4s var(--ease); }
.partners li:hover{ background:var(--white); }
.partners__role{ font-family:"Geist Mono",monospace; font-size:11.5px; letter-spacing:.14em; text-transform:uppercase; color:var(--ink-4); }
.partners__name{ font-size:clamp(18px,2vw,24px); font-weight:500; letter-spacing:-0.02em; color:var(--ink); }
@media (max-width:560px){ .partners{ grid-template-columns:1fr; } }

/* ---- Final CTA ---- */
.final-cta{ text-align:center; }
.final-cta__inner{ max-width:780px; margin-inline:auto; display:flex; flex-direction:column; align-items:center; gap:24px; }
.final-cta .display{ color:#fff; }
.final-cta__actions{ margin-top:8px; }
.final-cta__contact{ font-family:"Geist Mono",monospace; font-size:14px; letter-spacing:.04em; color:#bdbdbb; display:flex; gap:14px; align-items:center; }
.final-cta__contact a:hover{ color:#fff; }
.final-cta__contact .dot{ color:#555; }
