/*
Theme Name: Kendo-Dojo Offenburg
Theme URI: https://www.kendo-offenburg.com
Author: Kendo-Dojo Offenburg e.V.
Description: Vereins-Theme fuer den Kendo-Dojo Offenburg e.V. Seiten (Kendo, Training, Termine, FAQ, Kontakt), Beitraege (Aktuelles) und Mitglieder (eigener Beitragstyp) sind die Inhaltsquelle. Die Startseite setzt sich automatisch aus diesen Quellen zusammen.
Version: 1.0
Text Domain: kdo
Requires PHP: 7.4
*/

:root{
  --ink:#1C2029;
  --paper:#F6F7F9;
  --paper-soft:#EBEFF5;
  --sumi:#4C5D7D;
  --sumi-deep:#323D55;
  --sumi-soft:#8B99B3;
  --aka:#C1272D;
  --steel:#5D6575;
  --line:#D8DDE6;
  --white:#FFFFFF;

  --fs-2xs:.72rem;
  --fs-xs:.8rem;
  --fs-sm:.9rem;
  --fs-base:.97rem;
  --fs-md:1.08rem;
  --fs-lg:1.3rem;
  --fs-h3:1.22rem;
  --fs-h2:clamp(1.75rem,4.2vw,2.4rem);
  --fs-h1:clamp(2.3rem,7vw,3.5rem);

  --space-section:clamp(3.5rem,8vw,5.5rem);
  --radius:14px;
  --radius-lg:22px;

  --font-display:'Shippori Mincho','Hiragino Mincho ProN',Georgia,serif;
  --font-body:'Zen Kaku Gothic New','Hiragino Kaku Gothic ProN',system-ui,sans-serif;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
@media (prefers-reduced-motion: reduce){
  html{scroll-behavior:auto}
  *,*::before,*::after{animation:none!important;transition:none!important}
}
body{
  font-family:var(--font-body);
  color:var(--ink);
  background:var(--paper);
  line-height:1.7;
  font-size:16.5px;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
img{max-width:100%;display:block}
a{color:var(--sumi);text-underline-offset:2px}
a:hover{color:var(--sumi-deep)}
:focus-visible{outline:3px solid var(--aka);outline-offset:2px;border-radius:4px}
.screen-reader-text{position:absolute!important;left:-9999px;top:auto;width:1px;height:1px;overflow:hidden}

.wrap{max-width:1060px;margin:0 auto;padding:0 20px}

.eyebrow{font-size:var(--fs-2xs);letter-spacing:.22em;text-transform:uppercase;font-weight:700;color:var(--aka)}
.section--sumi .eyebrow{color:#EDB4B0}

h1,h2,h3{font-family:var(--font-display);font-weight:600;color:var(--ink)}
h1{line-height:1.12}
h2{font-size:var(--fs-h2);line-height:1.18;margin:.5rem 0 1.1rem}
h3{font-size:var(--fs-h3);line-height:1.3}
.section--sumi h2,.section--sumi h3{color:var(--white)}
.ini{color:var(--aka)}

.btn{display:inline-block;font-family:var(--font-body);font-weight:700;font-size:var(--fs-sm);letter-spacing:.01em;padding:.82rem 1.5rem;border-radius:999px;border:2px solid var(--sumi);background:var(--sumi);color:var(--white);text-decoration:none;cursor:pointer;box-shadow:0 8px 18px -8px rgba(50,61,85,.55);transition:background .2s ease,color .2s ease,border-color .2s ease,transform .15s ease,box-shadow .2s ease}
.btn:hover{background:var(--sumi-deep);border-color:var(--sumi-deep);color:var(--white);transform:translateY(-1px);box-shadow:0 10px 22px -8px rgba(50,61,85,.6)}
.btn--ghost{background:transparent;color:var(--sumi);border-color:var(--sumi);box-shadow:none}
.btn--ghost:hover{background:var(--sumi);color:var(--white)}
.btn--light{background:var(--white);border-color:var(--white);color:var(--sumi-deep);box-shadow:0 8px 18px -8px rgba(10,14,24,.5)}
.btn--light:hover{background:var(--paper);border-color:var(--paper);color:var(--sumi-deep)}

.site-header{position:sticky;top:0;z-index:50;background:rgba(246,247,249,.92);backdrop-filter:blur(10px);border-bottom:1px solid var(--line)}
.nav{display:flex;align-items:center;justify-content:space-between;padding:.65rem 20px;max-width:1060px;margin:0 auto}
.brand{display:flex;align-items:center;gap:.75rem;text-decoration:none;color:var(--ink)}
.brand:hover{color:var(--ink)}
.brand-logo{width:44px;height:44px;border-radius:10px;object-fit:cover;flex:none;box-shadow:0 2px 8px rgba(50,61,85,.35)}
.brand-text{display:flex;flex-direction:column;line-height:1.15}
.brand-text strong{font-family:var(--font-display);font-size:1.02rem;letter-spacing:.01em}
.brand-text span{font-size:.64rem;letter-spacing:.2em;text-transform:uppercase;color:var(--steel)}

.nav-links{display:flex;gap:.15rem;list-style:none;align-items:center}
.nav-links a{text-decoration:none;color:var(--ink);font-size:var(--fs-sm);font-weight:500;padding:.45rem .7rem;border-radius:8px}
.nav-links a:hover{background:var(--paper-soft);color:var(--ink)}
.nav-links a.is-page{border:1.5px solid var(--sumi);border-radius:999px;color:var(--sumi);font-weight:700;padding:.42rem .95rem;margin-left:.35rem}
.nav-links a.is-page.current,.nav-links a.is-page:hover{background:var(--sumi);color:var(--white)}
.nav-links a.current{background:var(--paper-soft);font-weight:700}

.burger{display:none;background:none;border:none;cursor:pointer;width:44px;height:44px;border-radius:8px}
.burger span{display:block;width:22px;height:2px;background:var(--ink);margin:5px auto;transition:transform .2s ease,opacity .2s ease}
.burger[aria-expanded="true"] span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.burger[aria-expanded="true"] span:nth-child(2){opacity:0}
.burger[aria-expanded="true"] span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}
@media (max-width:840px){
  .burger{display:block}
  .nav-links{position:absolute;top:100%;left:0;right:0;flex-direction:column;align-items:stretch;gap:0;background:var(--paper);border-bottom:1px solid var(--line);box-shadow:0 18px 30px -18px rgba(28,32,41,.25);padding:.5rem 20px 1rem;display:none}
  .nav-links.open{display:flex}
  .nav-links a{padding:.8rem .5rem}
  .nav-links a.is-page{margin:.5rem 0 0;text-align:center}
}

.hero{position:relative;overflow:hidden;padding:clamp(3.2rem,7vw,5rem) 0}
.hero-kanji{position:absolute;z-index:0;right:3%;top:50%;transform:translateY(-50%);writing-mode:vertical-rl;font-family:var(--font-display);font-size:clamp(7rem,18vw,13rem);font-weight:700;color:var(--sumi);opacity:.05;user-select:none;pointer-events:none;line-height:1}
.hero-grid{position:relative;z-index:1;display:grid;gap:2.6rem;align-items:center}
@media (min-width:860px){.hero-grid{grid-template-columns:1.15fr .85fr}}
.hero h1{font-size:var(--fs-h1);max-width:14ch;margin:.7rem 0 0}
.strike{position:relative;display:inline-block;padding-bottom:.3rem}
.strike::after{content:"";position:absolute;left:0;bottom:0;width:100%;height:3px;border-radius:2px;background:var(--aka);transform-origin:left;transform:scaleX(0);animation:strike .8s .4s ease forwards}
@keyframes strike{to{transform:scaleX(1)}}
.hero p.lead{max-width:50ch;margin:1.3rem 0 1.9rem;font-size:var(--fs-md);line-height:1.75;color:#3E4450}
.hero-ctas{display:flex;flex-wrap:wrap;gap:.8rem;margin-bottom:2rem}
.hero-facts{display:flex;flex-wrap:wrap;gap:.5rem;list-style:none}
.hero-facts li{font-size:var(--fs-xs);font-weight:700;border:1.5px solid var(--line);background:var(--white);padding:.4rem .9rem;border-radius:999px;color:#3E4450}

.logo-stage{display:flex;justify-content:center;perspective:950px}
.logo-card{position:relative;width:100%;max-width:330px;background:var(--sumi);border-radius:var(--radius-lg);overflow:hidden;transform-style:preserve-3d;will-change:transform;box-shadow:0 32px 62px -22px rgba(28,32,41,.5),0 6px 18px rgba(28,32,41,.12)}
.logo-card::after{content:"";position:absolute;inset:0;border-radius:var(--radius-lg);box-shadow:inset 0 0 0 1px rgba(255,255,255,.16);pointer-events:none}
.logo-img{display:block;width:100%;height:auto}
.logo-gloss{position:absolute;inset:0;border-radius:var(--radius-lg);background:linear-gradient(115deg,rgba(255,255,255,0) 34%,rgba(255,255,255,.4) 48%,rgba(255,255,255,0) 60%);pointer-events:none}
@keyframes logofloat{0%,100%{transform:rotateX(4deg) rotateY(-7deg)}50%{transform:rotateX(-3deg) rotateY(7deg) translateY(-6px)}}
@media (hover:none){.logo-card{animation:logofloat 7s ease-in-out infinite}}
@media (prefers-reduced-motion: reduce){.logo-card{animation:none}}

.section{padding:var(--space-section) 0}
.section--soft{background:var(--paper-soft)}
.section--sumi{background:linear-gradient(180deg,var(--sumi) 0%,var(--sumi-deep) 100%);color:var(--white)}
.section--sumi a{color:#C9D4E6}
.section-note{font-size:var(--fs-xs);color:var(--steel);margin-top:1.2rem}

.split{display:grid;gap:2.4rem;align-items:start}
@media (min-width:820px){.split{grid-template-columns:1.4fr 1fr}}
.split p{font-size:var(--fs-base);color:#3E4450}

.glossar{background:var(--white);border:1px solid var(--line);border-radius:var(--radius);padding:1.5rem 1.5rem 1.1rem}
.glossar h3{margin-bottom:1rem;font-size:var(--fs-base)}
.glossar dl{display:grid;grid-template-columns:auto 1fr;gap:.6rem 1.1rem;align-items:baseline}
.glossar dt{font-family:var(--font-display);font-size:1.45rem;color:var(--sumi);min-width:2.7rem;text-align:center}
.glossar dd{font-size:var(--fs-sm);color:#3E4450;line-height:1.6}
.glossar dd strong{color:var(--ink)}

.training-grid{display:grid;gap:1.3rem;margin-top:2rem}
@media (min-width:720px){.training-grid{grid-template-columns:1fr 1fr}}
.training-card{background:var(--paper);color:var(--ink);border-radius:var(--radius);padding:1.6rem;border-top:5px solid var(--aka);box-shadow:0 14px 30px -18px rgba(10,14,24,.55)}
.training-card .day{font-family:var(--font-display);font-size:var(--fs-lg);font-weight:700}
.training-card .time{font-size:1.7rem;font-weight:700;color:var(--sumi-deep);margin:.25rem 0 .15rem;letter-spacing:.01em;font-variant-numeric:tabular-nums}
.training-card .place{font-weight:500;font-size:var(--fs-base);color:#3E4450}
.training-card .note{font-size:var(--fs-xs);color:var(--steel);margin-top:.8rem;border-top:1px dashed var(--line);padding-top:.8rem;line-height:1.6}
.training-cta{margin-top:2.2rem;display:flex;flex-wrap:wrap;gap:1.1rem;align-items:center}
.training-cta p{font-size:var(--fs-sm);color:#CBD4E4;max-width:46ch;line-height:1.65}

.event-card{display:grid;gap:1.3rem;background:var(--white);border:1px solid var(--line);border-left:5px solid var(--aka);border-radius:var(--radius);padding:1.6rem;margin-top:1.8rem}
@media (min-width:760px){.event-card{grid-template-columns:auto 1fr auto;align-items:center}}
.event-date{font-family:var(--font-display);text-align:center;background:var(--paper-soft);border-radius:10px;padding:.7rem 1rem;min-width:112px}
.event-date .m{display:block;font-size:var(--fs-2xs);letter-spacing:.18em;text-transform:uppercase;color:var(--aka);font-family:var(--font-body);font-weight:700}
.event-date .d{display:block;font-size:1.5rem;font-weight:700;line-height:1.25;color:var(--sumi-deep)}
.event-body h3{margin-bottom:.3rem}
.event-body p{font-size:var(--fs-sm);color:#3E4450;line-height:1.65}
.event-tag{display:inline-block;font-size:var(--fs-2xs);font-weight:700;letter-spacing:.1em;text-transform:uppercase;background:rgba(193,39,45,.08);color:var(--aka);border-radius:999px;padding:.28rem .75rem;margin-bottom:.55rem}

.article{background:var(--white);border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;margin-top:1.8rem;box-shadow:0 18px 40px -28px rgba(28,32,41,.35)}
.article-media{margin:0;background:var(--sumi-deep)}
.article-media img{width:100%;height:auto}
.article-media .duo{display:grid;grid-template-columns:1fr 1fr;gap:2px}
.article-media .duo img{width:100%;height:100%;aspect-ratio:3/4;object-fit:cover}
.article-media img.pos-a{object-position:50% 38%}
.article-media img.pos-b{object-position:50% 30%}
.article-media figcaption{font-size:var(--fs-2xs);color:var(--steel);background:var(--white);padding:.6rem 1.7rem;border-bottom:1px solid var(--paper-soft);letter-spacing:.02em}
.article-body{padding:1.5rem 1.7rem 1.8rem}
.article-body h3{font-size:clamp(1.3rem,3vw,1.55rem);margin:.3rem 0 .35rem}
.article-body h3 a{color:inherit;text-decoration:none}
.byline{font-size:var(--fs-xs);color:var(--steel);margin-bottom:1rem}
.teaser{font-size:var(--fs-base);color:#3E4450;line-height:1.7}
.article-full{font-size:var(--fs-base);color:#3E4450;line-height:1.75;max-width:68ch}
.article-full p{margin-top:1rem}
.article-full img{border-radius:10px;margin:1rem 0;width:100%;height:auto}
.readmore{margin-top:.8rem}
.readmore summary{cursor:pointer;list-style:none;display:inline-flex;align-items:center;gap:.4rem;font-weight:700;font-size:var(--fs-sm);color:var(--sumi);padding:.35rem 0}
.readmore summary:hover{color:var(--sumi-deep)}
.readmore summary::-webkit-details-marker{display:none}
.readmore summary::after{content:"\2193";transition:transform .2s ease}
.readmore[open] summary::after{transform:rotate(180deg)}

.archiv-head{margin-top:3.2rem}
.blog-grid{display:grid;gap:1.3rem;margin-top:1.1rem}
@media (min-width:760px){.blog-grid{grid-template-columns:repeat(3,1fr)}}
.post{background:var(--white);border:1px solid var(--line);border-radius:var(--radius);padding:1.3rem;display:flex;flex-direction:column;gap:.5rem;text-decoration:none;color:var(--ink);transition:transform .15s ease,box-shadow .15s ease,border-color .15s ease}
.post:hover{transform:translateY(-3px);box-shadow:0 14px 28px -16px rgba(28,32,41,.35);border-color:var(--sumi-soft);color:var(--ink)}
.post .date{font-size:var(--fs-2xs);letter-spacing:.12em;text-transform:uppercase;color:var(--steel);font-weight:700}
.post h3{font-size:1.05rem}
.post p{font-size:var(--fs-xs);color:#3E4450;flex:1;line-height:1.6}
.post .more{font-size:var(--fs-xs);font-weight:700;color:var(--sumi)}

.faq{max-width:760px;margin-top:1.8rem}
.faq details{background:var(--white);border:1px solid var(--line);border-radius:12px;margin-bottom:.7rem;overflow:hidden;transition:border-color .15s ease}
.faq details[open]{border-color:var(--sumi-soft)}
.faq summary{cursor:pointer;list-style:none;padding:1.05rem 3rem 1.05rem 1.3rem;font-weight:700;font-size:var(--fs-base);position:relative}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{content:"+";position:absolute;right:1.2rem;top:50%;transform:translateY(-50%);font-family:var(--font-display);font-size:1.4rem;color:var(--sumi);transition:transform .2s ease}
.faq details[open] summary::after{transform:translateY(-50%) rotate(45deg)}
.faq details p{padding:0 1.3rem 1.2rem;font-size:var(--fs-sm);color:#3E4450;line-height:1.7;max-width:64ch}

.contact{display:grid;gap:2.4rem;margin-top:1.8rem}
@media (min-width:820px){.contact{grid-template-columns:1fr 1.2fr}}
.contact-info p{margin-bottom:1.1rem;font-size:var(--fs-base);color:#3E4450;max-width:44ch}
.contact-info a.mail{font-weight:700;font-size:var(--fs-md);word-break:break-all;color:var(--ink)}
.contact-info a.mail:hover{color:var(--sumi-deep)}
.socials{display:flex;gap:.7rem;margin-top:1.3rem}
.socials a{display:inline-flex;align-items:center;gap:.45rem;text-decoration:none;font-weight:700;font-size:var(--fs-sm);border:1.5px solid var(--line);border-radius:999px;padding:.5rem 1.05rem;color:var(--sumi);background:var(--white);transition:border-color .15s ease,color .15s ease}
.socials a:hover{border-color:var(--sumi);color:var(--sumi-deep)}
.form-box{background:var(--white);border:1px solid var(--line);border-radius:var(--radius);padding:1.7rem;box-shadow:0 18px 40px -28px rgba(28,32,41,.3)}
.form-box .wpcf7-form label{display:block;font-size:var(--fs-xs);font-weight:700;letter-spacing:.03em;margin:1rem 0 .35rem}
.form-box input[type=text],.form-box input[type=email],.form-box textarea{width:100%;font-family:var(--font-body);font-size:1rem;border:1.5px solid var(--line);border-radius:10px;padding:.72rem .95rem;background:var(--paper)}
.form-box input:focus,.form-box textarea:focus{outline:none;border-color:var(--sumi)}
.form-box .wpcf7-submit{margin-top:1.3rem;width:100%;font-family:var(--font-body);font-weight:700;font-size:var(--fs-sm);padding:.82rem 1.5rem;border-radius:999px;border:2px solid var(--sumi);background:var(--sumi);color:var(--white);cursor:pointer}
.form-box .wpcf7-submit:hover{background:var(--sumi-deep)}
.form-placeholder{font-size:var(--fs-sm);color:var(--steel);border:1.5px dashed var(--line);border-radius:10px;padding:1.2rem;text-align:center}

.page-head{padding:clamp(3rem,6vw,4rem) 0 2rem;position:relative;overflow:hidden}
.page-head .hero-kanji{font-size:clamp(6rem,14vw,10rem);right:2%}
.page-head .wrap{position:relative;z-index:1}
.page-head h1{font-size:clamp(2rem,5.5vw,2.9rem);margin:.6rem 0 .9rem}
.page-head p{max-width:58ch;color:#3E4450;font-size:var(--fs-base)}
.section--page{padding-top:1.2rem}

.demo-banner{display:inline-flex;align-items:center;gap:.5rem;background:rgba(193,39,45,.06);border:1.5px dashed rgba(193,39,45,.5);color:#8E2B24;border-radius:10px;padding:.55rem .95rem;font-size:var(--fs-xs);font-weight:500;margin-top:1.3rem;line-height:1.5}
.filters{display:flex;flex-wrap:wrap;gap:.5rem;margin:1.9rem 0 0}
.chip{font-family:var(--font-body);font-size:var(--fs-xs);font-weight:700;border:1.5px solid var(--line);background:var(--white);color:var(--ink);border-radius:999px;padding:.48rem 1.1rem;cursor:pointer;transition:background .15s ease,color .15s ease,border-color .15s ease}
.chip:hover{border-color:var(--sumi)}
.chip.active{background:var(--sumi);border-color:var(--sumi);color:var(--white)}
.members{display:grid;gap:1.3rem;padding:2.2rem 0 0}
.members--home{padding-top:1.8rem}
.members-more{margin-top:1.9rem}
@media (min-width:640px){.members{grid-template-columns:1fr 1fr}}
@media (min-width:960px){.members{grid-template-columns:repeat(3,1fr)}}
.member{background:var(--white);border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;display:flex;flex-direction:column;box-shadow:0 14px 30px -22px rgba(28,32,41,.35)}
.zekken{background:linear-gradient(160deg,var(--sumi) 0%,var(--sumi-deep) 100%);color:var(--white);padding:1.15rem 1.4rem 1.05rem;position:relative}
.zekken::after{content:"";position:absolute;inset:7px;border:1px dashed rgba(255,255,255,.3);border-radius:9px;pointer-events:none}
.zekken .dojo{font-size:.6rem;letter-spacing:.26em;text-transform:uppercase;color:rgba(255,255,255,.6);font-weight:700}
.zekken .name{font-family:var(--font-display);font-size:1.32rem;font-weight:600;margin-top:.15rem;line-height:1.25;padding-right:2.2rem}
.zekken .kanji{position:absolute;right:1rem;top:50%;transform:translateY(-50%);font-family:var(--font-display);font-size:2rem;opacity:.15}
.zekken.has-photo{padding:0;background:var(--sumi-deep)}
.zekken.has-photo img{width:100%;height:190px;object-fit:cover;display:block}
.zekken.has-photo .zekken-caption{padding:.8rem 1.4rem .9rem}
.member-body{padding:1.15rem 1.4rem 1.4rem;display:flex;flex-direction:column;gap:.75rem;flex:1}
.badges{display:flex;flex-wrap:wrap;gap:.4rem}
.badge{font-size:var(--fs-2xs);font-weight:700;letter-spacing:.05em;border-radius:999px;padding:.26rem .72rem}
.badge--dan{background:var(--sumi);color:var(--white)}
.badge--kyu{background:transparent;border:1.5px solid var(--sumi-soft);color:var(--steel)}
.badge--role{background:var(--paper-soft);color:#48505F}
.badge--medal{background:#B08D52;color:var(--white)}
.member-body .since{font-size:var(--fs-xs);color:var(--steel)}
.member-body .quote,.member-body .desc{font-size:var(--fs-sm);color:#3E4450;flex:1;line-height:1.65;border-left:3px solid rgba(76,93,125,.4);padding-left:.85rem}
.member-body .quote{font-style:italic}
.member--join{border:2px dashed rgba(76,93,125,.55);background:transparent;align-items:center;justify-content:center;text-align:center;padding:2.3rem 1.5rem;gap:.85rem;box-shadow:none}
.member--join .kanji-big{font-family:var(--font-display);font-size:2.6rem;color:var(--aka)}
.member--join h3{font-size:1.18rem}
.member--join p{font-size:var(--fs-sm);color:var(--steel);line-height:1.6}
.members-note{font-size:var(--fs-xs);color:var(--steel);max-width:70ch;padding:1.5rem 0 3.5rem;line-height:1.65}

.pagination{display:flex;gap:.5rem;flex-wrap:wrap;margin-top:2.4rem}
.pagination a,.pagination span{display:inline-flex;align-items:center;justify-content:center;min-width:2.4rem;height:2.4rem;padding:0 .6rem;border-radius:8px;border:1.5px solid var(--line);text-decoration:none;color:var(--ink);font-size:var(--fs-sm);font-weight:600}
.pagination .current{background:var(--sumi);border-color:var(--sumi);color:var(--white)}
.pagination a:hover{border-color:var(--sumi)}

.site-footer{background:var(--sumi-deep);color:#C4CCDC;padding:2.8rem 0;font-size:var(--fs-xs)}
.footer-grid{display:flex;flex-wrap:wrap;gap:1.5rem;justify-content:space-between;align-items:center}
.footer-brand{display:flex;align-items:center;gap:.75rem;color:var(--white)}
.footer-brand strong{font-family:var(--font-display);font-size:1rem;letter-spacing:.01em}
.footer-brand .brand-logo{width:36px;height:36px;border-radius:8px}
.footer-links{display:flex;flex-wrap:wrap;gap:1.3rem;list-style:none}
.footer-links a{color:#C4CCDC;text-decoration:none}
.footer-links a:hover{color:var(--white);text-decoration:underline}
.footer-note{width:100%;font-size:var(--fs-2xs);color:#97A2B8;border-top:1px solid rgba(255,255,255,.14);padding-top:1.2rem;margin-top:.4rem;line-height:1.6}

.reveal{opacity:0;transform:translateY(16px);transition:opacity .6s ease,transform .6s ease}
.reveal.in{opacity:1;transform:none}
@media (prefers-reduced-motion: reduce){.reveal{opacity:1;transform:none}}
