/* ================================================================
   A2Z Facility Management — v3: Swiss-modern, sans-only, architectural
   Bewusst NICHT editorial / NICHT Tuxeck-DNA
   ================================================================ */

:root{
  /* Kühle, industrielle Palette — weg von Tuxeck-Cream+Terracotta */
  --ink:#0A1220;
  --ink-80:#1C2740;
  --ink-60:#4B5673;
  --ink-40:#8691A8;
  --ink-20:#C8CEDB;
  --line:#E4E7EE;
  --line-soft:#EFF1F5;
  --bg:#F6F7F9;
  --bg-2:#FFFFFF;
  --navy:#1C2A45;          /* wärmer/heller als pure ink, für große dunkle Flächen */
  --navy-2:#2A3A58;        /* für Card-Surfaces im Dark-Bereich */
  --steel:#2C4A72;         /* Primary accent — aufgehellt, weicher */
  --steel-700:#1E3A5F;
  --steel-50:#E8EEF5;
  --signal:#E86A33;         /* Secondary / Warn-Signal, sparsam */
  --white:#ffffff;

  --radius:4px;
  --radius-md:8px;
  --radius-lg:12px;

  --max:1280px;
  --pad:clamp(20px,4vw,48px);
  --font:'Inter',ui-sans-serif,system-ui,-apple-system,Segoe UI,Roboto,sans-serif;

  --shadow-sm:0 1px 2px rgba(10,18,32,.04),0 2px 8px rgba(10,18,32,.04);
  --shadow-md:0 4px 12px rgba(10,18,32,.05),0 12px 32px rgba(10,18,32,.06);
}

*,*::before,*::after{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family:var(--font);
  color:var(--ink);
  background:var(--bg-2);
  line-height:1.55;
  font-size:16px;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
button{font:inherit;cursor:pointer}
svg{flex-shrink:0}
.container{max-width:var(--max);margin:0 auto;padding:0 var(--pad)}

/* ---------- Typografie — Inter only, Display-Weight durch Size ---------- */
.h2{
  font-family:var(--font);
  font-weight:600;
  font-size:clamp(30px,3.8vw,52px);
  line-height:1.08;
  letter-spacing:-0.028em;
  margin:0 0 20px;
  color:var(--ink);
}
.accent{color:var(--steel)}

.eyebrow{
  display:inline-flex;align-items:center;gap:10px;
  font-size:12px;font-weight:600;
  letter-spacing:.14em;text-transform:uppercase;
  color:var(--ink-60);
  margin-bottom:20px;
  font-feature-settings:"tnum" 1;
}
.eyebrow::before{
  content:"";display:inline-block;width:20px;height:2px;background:var(--steel);
}
.eyebrow--light{color:var(--ink-20)}
.eyebrow--light::before{background:var(--ink-20)}

.section__lede{max-width:680px;color:var(--ink-60);font-size:17px;line-height:1.6;margin:0}
.section__head{max-width:880px;margin-bottom:56px}
.section__head--center{margin-left:auto;margin-right:auto;text-align:center}
.section__head--center .eyebrow{justify-content:center}
.section__head--center .section__lede{margin-left:auto;margin-right:auto}

/* ---------- Reveal ---------- */
.reveal{opacity:0;transform:translateY(14px);transition:opacity .7s ease,transform .7s ease}
.reveal.in{opacity:1;transform:none}

/* ---------- Nav: IMMER opak weiß mit großem Dark-Logo ---------- */
.nav{
  position:sticky;top:0;z-index:50;
  background:#fff;
  border-bottom:1px solid var(--line-soft);
  transition:border-color .25s, box-shadow .25s;
}
.nav--scrolled{border-bottom-color:var(--line);box-shadow:var(--shadow-sm)}
.nav__inner{
  max-width:var(--max);margin:0 auto;padding:18px var(--pad);
  display:flex;align-items:center;justify-content:space-between;gap:24px;
}
.nav__brand{display:flex;align-items:center}
.nav__logo{height:44px;width:auto}
@media(max-width:1100px){.nav__logo{height:38px}}
@media(max-width:860px){.nav__logo{height:34px}}

.nav__menu{display:flex;align-items:center;gap:32px}
.nav__menu a{
  color:var(--ink);font-size:14.5px;font-weight:500;
  transition:color .2s;
}
.nav__menu a:hover{color:var(--steel)}
.nav__menu a[aria-current="page"]{color:var(--steel);font-weight:600}
.nav__menu a.nav__cta{
  padding:11px 22px;background:var(--steel);color:#fff;
  border:1px solid var(--steel);
  border-radius:var(--radius);font-size:14px;font-weight:600;
  white-space:nowrap;
  transition:background .2s, border-color .2s;
}
.nav__menu a.nav__cta:hover{background:var(--steel-700);border-color:var(--steel-700);color:#fff}

.nav__burger{display:none;background:none;border:0;padding:8px;flex-direction:column;gap:5px}
.nav__burger span{
  display:block;width:26px;height:2px;background:var(--ink);border-radius:2px;
  transition:transform .25s, opacity .25s;
}
.nav--open .nav__burger span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.nav--open .nav__burger span:nth-child(2){opacity:0}
.nav--open .nav__burger span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

@media(max-width:860px){
  .nav__burger{display:flex}
  .nav__menu{
    position:fixed;inset:80px 0 0 0;
    flex-direction:column;gap:0;align-items:stretch;
    background:#fff;padding:32px 24px;
    transform:translateY(-110%);transition:transform .35s ease;
    border-top:1px solid var(--line);
  }
  .nav--open .nav__menu{transform:translateY(0)}
  .nav__menu a{
    font-size:18px;font-weight:600;
    padding:18px 0;border-bottom:1px solid var(--line-soft);
  }
  .nav__cta{margin-top:20px;text-align:center}
}

/* ---------- Buttons ---------- */
.btn{
  display:inline-flex;align-items:center;gap:10px;
  padding:15px 26px;border-radius:var(--radius);
  font-weight:600;font-size:14.5px;
  transition:transform .2s, background .2s, border-color .2s;
  border:1.5px solid transparent;white-space:nowrap;
}
.btn__icon{transition:transform .2s}
.btn:hover .btn__icon{transform:translateX(3px)}
.btn--primary{background:var(--steel);color:#fff;border-color:var(--steel)}
.btn--primary:hover{background:var(--steel-700);border-color:var(--steel-700)}
.btn--ghost{color:#fff;border-color:rgba(255,255,255,.4)}
.btn--ghost:hover{background:rgba(255,255,255,.1);border-color:#fff}

/* ---------- Hero ---------- */
.hero{
  position:relative;
  min-height:min(760px, 90vh);
  padding:100px var(--pad) 80px;
  display:flex;flex-direction:column;justify-content:center;
  color:#fff;overflow:hidden;
}
.hero__bg{
  position:absolute;inset:0;
  background-size:cover;background-position:center;
  filter:saturate(.8) contrast(1.02) brightness(.85);
}
.hero__veil{
  position:absolute;inset:0;
  background:linear-gradient(135deg, rgba(10,18,32,.88) 0%, rgba(30,58,95,.72) 60%, rgba(10,18,32,.78) 100%);
}
.hero__inner{position:relative;max-width:var(--max);margin:0 auto;width:100%;padding-top:20px}
.hero__title{
  font-family:var(--font);font-weight:600;
  font-size:clamp(44px,7vw,96px);
  line-height:1.0;letter-spacing:-0.035em;
  margin:12px 0 28px;max-width:900px;
}
.hero__title .accent{color:#7FA8D8}
.hero__lede{
  max-width:600px;
  font-size:clamp(16px,1.3vw,18px);
  line-height:1.55;color:rgba(255,255,255,.82);
  margin:0 0 36px;
}
.hero__ctas{display:flex;flex-wrap:wrap;gap:14px;align-items:center}

.hero__meta{
  position:relative;z-index:2;margin-top:auto;
  display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(20px,4vw,48px);
  max-width:var(--max);margin-left:auto;margin-right:auto;
  border-top:1px solid rgba(255,255,255,.14);
  padding-top:32px;margin-top:60px;width:100%;
}
@media(max-width:680px){.hero__meta{grid-template-columns:1fr;gap:20px}}
.hero__meta > div{display:flex;flex-direction:column;gap:4px}
.hero__meta b{
  font-family:var(--font);font-weight:600;
  font-size:clamp(24px,3vw,36px);line-height:1;color:#fff;
  letter-spacing:-0.025em;
}
.hero__meta .meta__sm{font-size:.55em;color:rgba(255,255,255,.55);font-weight:500}
.hero__meta span{font-size:13px;color:rgba(255,255,255,.65);line-height:1.4}
.hero__meta b span{color:inherit;font-size:inherit}

/* ---------- Sections ---------- */
.section{padding:clamp(80px,9vw,130px) 0}
.section--intro{background:#fff}
.section--leistungen{background:var(--bg)}
.section--group{background:var(--navy);color:#D7DEEB}
.section--nachfolge{background:#fff}
.section--process{background:var(--bg)}
.section--faq{background:#fff}
.section--contact{background:var(--bg)}

.section--group .h2{color:#fff}
.section--group .eyebrow{color:var(--ink-20)}
.section--group .eyebrow::before{background:#7FA8D8}

/* ---------- Intro ---------- */
.intro__grid{
  display:grid;grid-template-columns:1fr 1.2fr;gap:clamp(40px,6vw,96px);
  align-items:start;
}
@media(max-width:900px){.intro__grid{grid-template-columns:1fr}}
.intro__copy p{color:var(--ink-60);font-size:16.5px;line-height:1.7;margin:0 0 20px;max-width:620px}
.intro__signature{color:var(--ink) !important;font-size:17px !important;border-left:3px solid var(--steel);padding-left:18px}
.intro__signature b{color:var(--ink);font-weight:600}

/* ---------- Leistungen / 3 Säulen ---------- */
.pillars{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
@media(max-width:900px){.pillars{grid-template-columns:1fr}}
.pillar{
  background:#fff;border:1px solid var(--line);
  border-radius:var(--radius-md);padding:36px 32px;
  display:flex;flex-direction:column;gap:16px;
  position:relative;transition:border-color .25s, transform .25s, box-shadow .25s;
}
.pillar:hover{border-color:var(--steel);transform:translateY(-2px);box-shadow:var(--shadow-md)}
.pillar__icon{
  width:48px;height:48px;display:flex;align-items:center;justify-content:center;
  background:var(--steel-50);color:var(--steel);
  border-radius:var(--radius);
}
.pillar__num{
  position:absolute;top:24px;right:28px;
  font-size:13px;font-weight:500;color:var(--ink-40);
  letter-spacing:.08em;font-feature-settings:"tnum" 1;
}
.pillar h3{font-size:22px;font-weight:600;margin:0;letter-spacing:-0.015em}
.pillar__label{margin:-6px 0 8px;font-size:13px;color:var(--ink-40);font-weight:500;letter-spacing:.01em}
.pillar__list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:14px}
.pillar__list li{border-top:1px solid var(--line-soft);padding-top:14px}
.pillar__list li:first-child{border-top:0;padding-top:0}
.pillar__list b{display:block;font-size:14.5px;color:var(--ink);font-weight:600;margin-bottom:4px}
.pillar__list span{font-size:14px;color:var(--ink-60);line-height:1.55}
.pillar--accent{background:var(--ink);color:#D7DEEB;border-color:var(--ink)}
.pillar--accent h3{color:#fff}
.pillar--accent .pillar__label{color:var(--ink-20)}
.pillar--accent .pillar__num{color:var(--ink-20)}
.pillar--accent .pillar__icon{background:rgba(255,255,255,.08);color:#7FA8D8}
.pillar--accent .pillar__list li{border-color:rgba(255,255,255,.1)}
.pillar--accent .pillar__list b{color:#fff}
.pillar--accent .pillar__list span{color:var(--ink-20)}
.pillar--accent:hover{border-color:#7FA8D8}

/* ---------- Gruppe ---------- */
.group__flex{
  display:grid;grid-template-columns:1.3fr 1fr;gap:clamp(48px,6vw,96px);
  align-items:start;
}
@media(max-width:900px){.group__flex{grid-template-columns:1fr}}
.group__text p{color:#B7C2D4;font-size:16.5px;line-height:1.7;margin:0 0 28px;max-width:560px}
.group__text b{color:#fff;font-weight:600}
.checklist{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:14px;max-width:560px}
.checklist li{
  display:flex;gap:14px;align-items:flex-start;
  color:#B7C2D4;font-size:15.5px;line-height:1.55;
}
.checklist li svg{color:#7FA8D8;flex-shrink:0;margin-top:2px}
.checklist li b{color:#fff}
.checklist li span{flex:1}

.group__stack{display:flex;flex-direction:column;gap:4px;position:sticky;top:100px}
@media(max-width:900px){.group__stack{display:none}}
.group__stat{
  padding:28px 0;border-top:1px solid rgba(255,255,255,.1);
  display:flex;flex-direction:column;gap:10px;
}
.group__stat:first-child{border-top:0;padding-top:0}
.group__stat:last-child{padding-bottom:0}
.group__stat b{
  font-family:var(--font);font-weight:600;
  font-size:clamp(32px,4vw,56px);line-height:1.05;color:#fff;
  letter-spacing:-0.03em;
}
@media(max-width:900px){
  .group__stat{padding:20px 0}
  .group__stat b{font-size:28px}
  .group__stat > span{font-size:14.5px;max-width:none}
}
.group__stat b span{color:#7FA8D8;font-weight:500}
.group__stat > span{color:#8E9AB0;font-size:14px;line-height:1.5;max-width:320px}

/* ---------- Nachfolge ---------- */
.nachfolge__grid{
  display:grid;grid-template-columns:1fr 1fr;gap:24px;
  margin-bottom:60px;
}
@media(max-width:900px){.nachfolge__grid{grid-template-columns:1fr}}
.nachfolge__card{
  background:#fff;border:1px solid var(--line);
  border-radius:var(--radius-md);padding:40px 36px;
  transition:transform .25s ease, box-shadow .25s ease, border-color .25s ease;
}
.nachfolge__card:hover{transform:translateY(-3px);box-shadow:var(--shadow-md);border-color:var(--steel)}
.nachfolge__card--dark:hover{border-color:var(--steel);box-shadow:0 18px 40px -12px rgba(0,0,0,.45)}
.nachfolge__card h3{font-size:20px;font-weight:600;margin:0 0 24px;letter-spacing:-0.01em}
.nachfolge__offer{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:20px}
.nachfolge__offer li{
  display:flex;gap:18px;align-items:flex-start;
  padding-bottom:20px;border-bottom:1px solid var(--line-soft);
}
.nachfolge__offer li:last-child{border-bottom:0;padding-bottom:0}
.nachfolge__offer .p__icon{color:var(--steel);flex-shrink:0;margin-top:2px}
.nachfolge__offer b{display:block;color:var(--ink);font-size:17px;margin-bottom:4px;font-weight:600;letter-spacing:-0.005em}
.nachfolge__offer span{color:var(--ink-60);font-size:14.5px;line-height:1.55;display:block}

.nachfolge__card--dark{background:var(--navy-2);color:#D7DEEB;border-color:var(--navy-2)}
.nachfolge__card--dark h3{color:#fff}
.nachfolge__promise{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:20px}
.nachfolge__promise li{
  display:flex;gap:18px;align-items:flex-start;
  padding-bottom:20px;border-bottom:1px solid rgba(255,255,255,.08);
}
.nachfolge__promise li:last-child{border-bottom:0;padding-bottom:0}
.nachfolge__promise .p__icon{color:#7FA8D8;flex-shrink:0;margin-top:2px}
.nachfolge__promise b{display:block;color:#fff;font-size:17px;margin-bottom:4px;font-weight:600;letter-spacing:-0.005em}
.nachfolge__promise span{color:#B7C2D4;font-size:14.5px;line-height:1.55}

.nachfolge__quote{margin:48px auto 0;max-width:820px;text-align:center}
.nachfolge__quote blockquote{
  margin:0;padding:0 20px;
  font-size:clamp(20px,2.2vw,26px);font-weight:500;
  letter-spacing:-0.015em;color:var(--ink);line-height:1.4;
  border-left:3px solid var(--steel);padding:8px 0 8px 24px;
  text-align:left;max-width:680px;margin:0 auto;
}

/* ---------- Prozess ---------- */
.steps{
  list-style:none;padding:0;margin:0;
  display:grid;grid-template-columns:repeat(4,1fr);gap:20px;
}
@media(max-width:900px){.steps{grid-template-columns:repeat(2,1fr)}}
@media(max-width:540px){.steps{grid-template-columns:1fr}}
.step{
  background:#fff;border:1px solid var(--line);border-top:4px solid var(--line);
  border-radius:var(--radius-md);
  padding:36px 28px 32px;
  display:flex;flex-direction:column;gap:12px;
  position:relative;transition:transform .2s, box-shadow .2s, border-color .2s;
  box-shadow:none;
}
.step:hover{
  transform:translateY(-3px);box-shadow:var(--shadow-md);
  border-top-color:#0B3B8C;
}
.step:hover .step__num{color:#0B3B8C}
.step:hover h3{color:var(--ink)}
.step:hover p{color:var(--ink-70)}
.step__num{
  font-family:var(--font);font-weight:700;
  font-size:44px;line-height:1;color:var(--ink-40);
  letter-spacing:-0.03em;font-feature-settings:"tnum" 1;
  margin-bottom:4px;
  transition:color .2s;
}
.step h3{font-size:18px;font-weight:600;margin:0;letter-spacing:-0.01em;color:var(--ink-60);transition:color .2s}
.step p{margin:0;color:var(--ink-40);font-size:14.5px;line-height:1.6;transition:color .2s}

/* ---------- FAQ ---------- */
.faq{max-width:880px;margin:0 auto}
.faq__item{border-bottom:1px solid var(--line)}
.faq__item summary{
  list-style:none;cursor:pointer;
  padding:24px 40px 24px 0;
  font-size:17px;font-weight:600;color:var(--ink);
  position:relative;letter-spacing:-0.005em;
  transition:color .2s;
}
.faq__item summary::-webkit-details-marker{display:none}
.faq__item summary:hover{color:var(--steel)}
.faq__item summary::after{
  content:"+";position:absolute;right:4px;top:50%;transform:translateY(-50%);
  font-size:22px;font-weight:400;color:var(--ink-40);
  transition:transform .25s, color .2s;
  line-height:1;
}
.faq__item[open] summary::after{transform:translateY(-50%) rotate(45deg);color:var(--steel)}
.faq__item p{margin:0 0 24px;color:var(--ink-60);font-size:15.5px;line-height:1.65;max-width:760px}

/* ---------- Contact ---------- */
.contact__grid{
  display:grid;grid-template-columns:1fr 1.05fr;gap:clamp(40px,5vw,72px);
  align-items:center;
}
@media(max-width:900px){.contact__grid{grid-template-columns:1fr}}

.contact__head{margin:0 0 14px}
.contact__intro{color:var(--ink-60);font-size:16px;line-height:1.6;margin:0 0 36px;max-width:460px}

.contact__card{
  background:#fff;border:1px solid var(--line);
  border-radius:var(--radius-md);overflow:hidden;
  box-shadow:var(--shadow-sm);
}
@media(max-width:900px){.contact__card{max-width:420px}}
.contact__photo{
  width:100%;aspect-ratio:1/1;
  background:var(--bg);overflow:hidden;display:block;
}
.contact__photo img{
  display:block;width:100%;height:100%;object-fit:cover;object-position:center center;
}
.contact__info{padding:28px 32px 32px}
.contact__eyebrow{
  font-size:11.5px;font-weight:600;letter-spacing:.14em;text-transform:uppercase;
  color:var(--ink-40);margin-bottom:10px;display:block;
}
.contact__info h3{font-size:24px;font-weight:600;margin:0 0 4px;letter-spacing:-0.015em}
.contact__role{margin:0 0 20px;color:var(--steel);font-size:14.5px;font-weight:500}

.contact__facts{
  list-style:none;padding:18px 0 0;margin:0;
  display:flex;flex-direction:column;gap:12px;
  border-top:1px solid var(--line-soft);
}
.contact__facts li{
  display:flex;align-items:center;gap:12px;
  color:var(--ink);font-size:15px;
}
.contact__facts svg{color:var(--steel);flex-shrink:0}
.contact__facts a{color:var(--ink);transition:color .2s}
.contact__facts a:hover{color:var(--steel)}

/* ---------- Form ---------- */
.contact__form{
  background:#fff;padding:36px;
  border-radius:var(--radius-md);border:1px solid var(--line);
  display:grid;grid-template-columns:1fr 1fr;gap:18px;
  box-shadow:var(--shadow-sm);
}
@media(max-width:540px){.contact__form{grid-template-columns:1fr;padding:28px}}
.hp{position:absolute;left:-9999px}
.field{display:flex;flex-direction:column;gap:6px}
.field--full{grid-column:1/-1}
.field span{font-size:13px;font-weight:500;color:var(--ink-60)}
.field input,.field textarea,.field select{
  padding:12px 14px;border:1px solid var(--line);background:#fff;
  border-radius:var(--radius);font:inherit;color:var(--ink);
  transition:border-color .2s, box-shadow .2s;
}
.field input::placeholder,.field textarea::placeholder{color:var(--ink-40)}
.field input:focus,.field textarea:focus,.field select:focus{
  outline:0;border-color:var(--steel);box-shadow:0 0 0 3px rgba(30,58,95,.12);
}
.field select{appearance:none;-webkit-appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%232C4A72' stroke-width='1.6' fill='none' stroke-linecap='round'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 14px center;padding-right:36px;cursor:pointer}
.field textarea{resize:vertical;min-height:110px;font-family:inherit}
.check{flex-direction:row;align-items:flex-start;gap:10px}
.check input{margin-top:3px;accent-color:var(--steel)}
.check span{font-size:13px;color:var(--ink-60);line-height:1.55}
.contact__form button{justify-content:center;grid-column:1/-1;margin-top:4px;width:100%}

/* ---------- Footer ---------- */
.footer{background:#fff;border-top:1px solid var(--line);color:var(--ink-60);padding:72px 0 28px}
.footer__inner{
  display:grid;grid-template-columns:1.2fr 2fr;gap:clamp(32px,5vw,80px);
  padding-bottom:40px;border-bottom:1px solid var(--line);
}
@media(max-width:780px){.footer__inner{grid-template-columns:1fr}}
.footer__logo{height:40px;margin-bottom:16px}
.footer__brand p{color:var(--ink-60);font-size:14.5px;line-height:1.6;max-width:340px;margin:0}
.footer__cols{display:grid;grid-template-columns:repeat(3,1fr);gap:32px}
@media(max-width:620px){.footer__cols{grid-template-columns:1fr 1fr}}
.footer__cols h4{
  font-size:11.5px;letter-spacing:.14em;text-transform:uppercase;color:var(--ink);
  margin:0 0 14px;font-weight:600;
}
.footer__cols ul{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:8px}
.footer__cols a{color:var(--ink-60);font-size:14px;transition:color .2s}
.footer__cols a:hover{color:var(--steel)}
.footer__base{
  padding-top:24px;display:flex;justify-content:space-between;gap:16px;flex-wrap:wrap;
  color:var(--ink-40);font-size:13px;
}

/* ---------- Accessibility ---------- */
.skip-link{
  position:absolute;left:-9999px;top:8px;z-index:100;
  background:var(--ink);color:#fff;padding:10px 18px;border-radius:var(--radius);
  font-size:14px;font-weight:600;
}
.skip-link:focus{left:8px;outline:2px solid var(--steel);outline-offset:2px}
:focus-visible{outline:2px solid var(--steel);outline-offset:3px;border-radius:var(--radius)}
.btn:focus-visible,.nav__cta:focus-visible{outline-offset:4px}
.field input:focus-visible,.field textarea:focus-visible{outline:0}

@media(prefers-reduced-motion:reduce){
  *{animation:none!important;transition:none!important}
  .reveal{opacity:1;transform:none}
}
