/* ============================================================
   Minimum Global — styles
   Palette: Cantera. Type: Montserrat / Inter / JetBrains Mono.
   Pure CSS, self-hosted fonts, no third-party requests.
   ============================================================ */

/* ---- Fonts (self-hosted, subset latin) ---- */
@font-face{font-family:Montserrat;font-style:normal;font-weight:600;font-display:swap;src:url(../fonts/montserrat-600.woff2) format("woff2")}
@font-face{font-family:Montserrat;font-style:normal;font-weight:700;font-display:swap;src:url(../fonts/montserrat-700.woff2) format("woff2")}
@font-face{font-family:Inter;font-style:normal;font-weight:400;font-display:swap;src:url(../fonts/inter-400.woff2) format("woff2")}
@font-face{font-family:Inter;font-style:normal;font-weight:500;font-display:swap;src:url(../fonts/inter-500.woff2) format("woff2")}
@font-face{font-family:Inter;font-style:normal;font-weight:600;font-display:swap;src:url(../fonts/inter-600.woff2) format("woff2")}
@font-face{font-family:"JetBrains Mono";font-style:normal;font-weight:400;font-display:swap;src:url(../fonts/jetbrains-mono-400.woff2) format("woff2")}
@font-face{font-family:"JetBrains Mono";font-style:normal;font-weight:500;font-display:swap;src:url(../fonts/jetbrains-mono-500.woff2) format("woff2")}

/* ---- Tokens ---- */
:root{
  --cal:#F4EDE1;        /* surface / ground */
  --cal-2:#EFE7D7;      /* alternate surface */
  --ink:#211B1A;        /* body text */
  --ink-soft:rgba(33,27,26,.72);
  --ink-faint:rgba(33,27,26,.66);
  --hair:rgba(33,27,26,.14);
  --hair-soft:rgba(33,27,26,.08);
  --barro:#A85C42;      /* primary terracotta */
  --barro-deep:#8F4A33;
  --azulejo:#3F6B87;    /* accent / links */
  --cobre:#C07F45;      /* signal highlight (ink-only on light) */
  --agave:#4F7561;      /* success */

  --font-display:Montserrat,system-ui,-apple-system,Segoe UI,Roboto,sans-serif;
  --font-body:Inter,system-ui,-apple-system,Segoe UI,Roboto,sans-serif;
  --font-mono:"JetBrains Mono",ui-monospace,SFMono-Regular,Menlo,monospace;

  --r-sm:10px; --r:14px; --r-lg:20px;
  --shadow:0 1px 2px rgba(33,27,26,.04),0 10px 34px rgba(33,27,26,.07);
  --maxw:1080px; --readw:640px;
  --pad:clamp(1.25rem,5vw,2.25rem);
  --sec:clamp(4.5rem,11vh,8.5rem);
}

/* ---- Reset / base ---- */
*,*::before,*::after{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;background:var(--cal);color:var(--ink);
  font-family:var(--font-body);font-size:1.0625rem;line-height:1.65;
  font-weight:400;letter-spacing:.005em;
  -webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;
}
img,svg{display:block;max-width:100%}
h1,h2,h3{font-family:var(--font-display);font-weight:600;line-height:1.08;letter-spacing:-.01em;margin:0}
p{margin:0}
a{color:var(--azulejo);text-decoration:none;text-underline-offset:.18em;text-decoration-thickness:.06em}
a:hover{text-decoration:underline}
:focus-visible{outline:2.5px solid var(--azulejo);outline-offset:3px;border-radius:3px}
::selection{background:rgba(168,92,66,.22)}

/* ---- Layout helpers ---- */
.wrap{width:100%;max-width:var(--maxw);margin-inline:auto;padding-inline:var(--pad)}
.section{padding-block:var(--sec)}
.section--alt{background:var(--cal-2)}
.eyebrow{
  font-family:var(--font-mono);font-weight:500;font-size:.78rem;
  letter-spacing:.22em;text-transform:uppercase;color:var(--barro-deep);
  display:flex;align-items:center;gap:.6rem;margin:0 0 1.4rem;
}
.eyebrow::before{content:"";width:1.6rem;height:1px;background:var(--barro-deep);opacity:.7}
.lead{font-size:clamp(1.12rem,2.1vw,1.35rem);line-height:1.55;color:var(--ink-soft);max-width:var(--readw)}
.eyebrow--center{justify-content:center}
.h2{font-size:clamp(1.7rem,3.4vw,2.4rem)}

.skip-link{position:absolute;left:-9999px;top:0;background:var(--ink);color:var(--cal);
  padding:.7rem 1.1rem;border-radius:0 0 var(--r-sm) 0;z-index:100;font-family:var(--font-mono);font-size:.85rem}
.skip-link:focus{left:0}

/* ---- Header ---- */
.site-header{position:sticky;top:0;z-index:50;
  background:color-mix(in srgb,var(--cal) 85%,transparent);
  backdrop-filter:saturate(1.1) blur(9px);-webkit-backdrop-filter:saturate(1.1) blur(9px);
  border-bottom:1px solid var(--hair-soft)}
.nav{display:flex;align-items:center;justify-content:space-between;gap:1rem;padding-block:.95rem}
.brand{display:inline-flex;align-items:center;gap:.6rem;color:var(--ink)}
.brand:hover{text-decoration:none}
.brand .mark{width:38px;height:auto;flex:none}
.brand .mark path{stroke:var(--barro)}
.brand .mark circle{fill:var(--barro)}
.brand .name{font-family:var(--font-display);font-weight:600;font-size:.95rem;
  letter-spacing:.2em;text-transform:uppercase}
.nav__cta{font-family:var(--font-mono);font-size:.82rem;letter-spacing:.04em;
  color:var(--ink);border:1px solid var(--hair);padding:.5rem .9rem;border-radius:999px;transition:border-color .2s,background .2s}
.nav__cta:hover{text-decoration:none;border-color:var(--barro);background:rgba(168,92,66,.06)}
@media (max-width:540px){.brand .name{display:none}}

/* ---- Buttons ---- */
.btn{display:inline-flex;align-items:center;gap:.55rem;font-family:var(--font-body);
  font-weight:600;font-size:1.02rem;line-height:1;padding:.95rem 1.5rem;border-radius:999px;
  border:1px solid transparent;cursor:pointer;transition:transform .15s ease,background .2s,box-shadow .2s}
.btn--primary{background:var(--barro);color:#fff;box-shadow:0 8px 22px rgba(168,92,66,.22)}
.btn--primary:hover{background:var(--barro-deep);text-decoration:none;transform:translateY(-1px)}
.btn--ghost{color:var(--ink);border-color:var(--hair);background:transparent}
.btn--ghost:hover{border-color:var(--ink);text-decoration:none}
.btn .arrow{transition:transform .2s}
.btn:hover .arrow{transform:translateX(3px)}

/* ============================================================
   Hero
   ============================================================ */
.hero{position:relative;overflow:hidden;padding-block:clamp(3rem,7vh,5.5rem) clamp(4rem,9vh,7rem);text-align:center}
.hero__inner{display:flex;flex-direction:column;align-items:center}
.hero__mark{width:min(540px,82vw);height:auto;margin-bottom:.4rem}
.hero__mark .curve{fill:none;stroke:var(--barro);stroke-width:2.6;stroke-linecap:round;stroke-linejoin:round}
.hero__mark .ball{fill:var(--barro)}
.hero__mark .gmin-line{stroke:var(--barro);stroke-width:.8;stroke-dasharray:2 3;opacity:0}
.hero__mark .gmin-label{font-family:var(--font-mono);font-size:5px;fill:var(--ink-faint);opacity:0;letter-spacing:.04em}

.wordmark{font-family:var(--font-display);font-weight:600;
  font-size:clamp(1.15rem,3.2vw,1.7rem);letter-spacing:.34em;text-transform:uppercase;
  color:var(--ink);margin-left:.34em;margin-bottom:1.9rem}
.hero__tagline{font-family:var(--font-display);font-weight:700;
  font-size:clamp(2.3rem,6.4vw,4.3rem);line-height:1.02;letter-spacing:-.02em;
  max-width:14ch;margin-bottom:1.3rem}
.hero__tagline .accent{color:var(--barro)}
.hero__sub{font-size:clamp(1.1rem,2.1vw,1.3rem);color:var(--ink-soft);max-width:46ch;margin-bottom:2.4rem}
.hero__actions{display:flex;gap:.9rem;flex-wrap:wrap;justify-content:center}

/* Signature animation: curve draws, point settles into the global minimum */
.hero__mark .curve{stroke-dasharray:1;stroke-dashoffset:1;animation:draw 1.5s cubic-bezier(.65,0,.35,1) .15s forwards}
.hero__mark .ball{transform-box:fill-box;transform-origin:center;opacity:0;
  animation:settle 1s cubic-bezier(.5,1.55,.55,1) 1.25s forwards}
.hero__mark .gmin-line{animation:fadein .6s ease 2.15s forwards}
.hero__mark .gmin-label{animation:fadein .6s ease 2.35s forwards}
@keyframes draw{to{stroke-dashoffset:0}}
@keyframes settle{0%{opacity:0;transform:translateY(-54px)}30%{opacity:1}100%{opacity:1;transform:translateY(0)}}
@keyframes fadein{to{opacity:1}}
@media (prefers-reduced-motion:reduce){
  .hero__mark .curve{stroke-dashoffset:0;animation:none}
  .hero__mark .ball{opacity:1;transform:none;animation:none}
  .hero__mark .gmin-line,.hero__mark .gmin-label{opacity:1;animation:none}
}

/* ============================================================
   What we do
   ============================================================ */
.do__grid{display:grid;grid-template-columns:1fr;gap:clamp(1.5rem,3vw,2.5rem);align-items:start}
@media (min-width:760px){.do__grid{grid-template-columns:1.15fr .85fr}}
.do__body p+p{margin-top:1.1rem}
.do__note{font-family:var(--font-mono);font-size:.9rem;color:var(--ink-faint);
  border-left:2px solid var(--barro);padding-left:1rem;align-self:start}
.do__note strong{color:var(--barro-deep);font-weight:500}

/* ============================================================
   How we work — principles
   ============================================================ */
.principles{display:grid;grid-template-columns:1fr;gap:0;margin-top:.5rem;
  border-top:1px solid var(--hair)}
@media (min-width:720px){.principles{grid-template-columns:1fr 1fr}}
.principle{padding:clamp(1.6rem,3vw,2.4rem) 0;border-bottom:1px solid var(--hair)}
@media (min-width:720px){
  .principle{padding:clamp(1.8rem,3vw,2.6rem) clamp(1.8rem,3vw,2.6rem)}
  .principle:nth-child(odd){padding-left:0;border-right:1px solid var(--hair)}
  .principle:nth-child(even){padding-right:0}
}
.principle__k{font-family:var(--font-mono);font-size:.8rem;color:var(--cobre);
  letter-spacing:.06em;margin-bottom:.8rem}
.principle h3{font-size:1.3rem;margin-bottom:.55rem}
.principle p{color:var(--ink-soft);font-size:1rem;line-height:1.6}

/* ============================================================
   Founder
   ============================================================ */
.founder__grid{display:grid;grid-template-columns:1fr;gap:clamp(1.8rem,4vw,3rem);align-items:center}
@media (min-width:680px){.founder__grid{grid-template-columns:auto 1fr}}
.founder__photo{width:clamp(160px,40vw,220px);height:auto;aspect-ratio:1;border-radius:var(--r-lg);
  object-fit:cover;box-shadow:var(--shadow);border:1px solid var(--hair-soft);justify-self:center}
.founder__bio p{color:var(--ink-soft);max-width:54ch}
.founder__bio .name{font-family:var(--font-display);font-weight:600;font-size:1.4rem;color:var(--ink);margin-bottom:.9rem}
.founder__meta{margin-top:1.3rem;font-family:var(--font-mono);font-size:.85rem;display:flex;gap:1.2rem;flex-wrap:wrap;align-items:center}
.founder__meta a{display:inline-flex;align-items:center;gap:.4rem}
.dot-sep{color:var(--ink-faint)}

/* ============================================================
   Contact
   ============================================================ */
.contact{text-align:center}
.contact .h2{margin-bottom:1rem}
.contact__line{color:var(--ink-soft);max-width:42ch;margin:0 auto 2rem}
.contact__email{font-family:var(--font-display);font-weight:600;
  font-size:clamp(1.5rem,4.5vw,2.6rem);letter-spacing:-.01em;color:var(--ink);display:inline-block;
  border-bottom:2px solid var(--barro);padding-bottom:.1em;transition:color .2s}
.contact__email:hover{color:var(--barro);text-decoration:none}
.contact__meta{margin-top:1.8rem;font-family:var(--font-mono);font-size:.84rem;color:var(--ink-faint);
  display:flex;gap:.55rem;justify-content:center;align-items:center}
.contact__meta .tick{color:var(--agave)}

/* ============================================================
   Footer
   ============================================================ */
.site-footer{background:var(--ink);color:var(--cal);padding-block:clamp(3rem,6vh,4.5rem)}
.footer__grid{display:flex;flex-direction:column;gap:1.8rem;align-items:flex-start}
@media (min-width:680px){.footer__grid{flex-direction:row;justify-content:space-between;align-items:flex-end}}
.footer__mark{width:150px;height:auto}
.footer__tag{font-family:var(--font-mono);font-size:.82rem;color:rgba(244,237,225,.66);margin-top:1rem;letter-spacing:.04em}
.footer__links{display:flex;gap:1.5rem;flex-wrap:wrap;font-family:var(--font-mono);font-size:.86rem}
.footer__links a{color:var(--cal);text-underline-offset:.2em}
.footer__links a:hover{color:var(--cobre);text-decoration:underline}
.footer__copy{font-family:var(--font-mono);font-size:.8rem;color:rgba(244,237,225,.62);margin-top:1.4rem}

/* ============================================================
   Legal pages (Impressum / Datenschutz / 404)
   ============================================================ */
.legal{padding-block:clamp(3rem,7vh,5rem) var(--sec);max-width:760px}
.legal h1{font-size:clamp(1.9rem,4vw,2.6rem);margin-bottom:.4rem}
.legal .updated{font-family:var(--font-mono);font-size:.82rem;color:var(--ink-faint);margin-bottom:2.4rem}
.legal h2{font-family:var(--font-display);font-size:1.2rem;font-weight:600;margin:2.4rem 0 .7rem}
.legal h3{font-family:var(--font-mono);font-size:.82rem;letter-spacing:.16em;text-transform:uppercase;
  color:var(--barro);margin:2.6rem 0 1rem;font-weight:500}
.legal p,.legal li{color:var(--ink-soft);margin-bottom:.9rem}
.legal ul{padding-left:1.2rem}
.legal address{font-style:normal;font-family:var(--font-mono);font-size:.95rem;line-height:1.9;
  color:var(--ink);background:var(--cal-2);border:1px solid var(--hair);border-radius:var(--r);padding:1.2rem 1.4rem;margin:1rem 0 1.6rem}
.legal .courtesy{border-left:2px solid var(--hair);padding-left:1.3rem;margin-top:2.6rem;color:var(--ink-faint)}
.legal .courtesy address{background:transparent;border:none;padding:0;color:var(--ink-soft)}
.legal .note{font-size:.92rem;color:var(--ink-faint);background:var(--cal-2);border-radius:var(--r);padding:1.1rem 1.3rem;margin-top:2rem}
.back-link{display:inline-flex;align-items:center;gap:.45rem;font-family:var(--font-mono);font-size:.85rem;margin-top:2.5rem}

.center-page{min-height:62vh;display:flex;flex-direction:column;justify-content:center;align-items:center;text-align:center}
.center-page .h2{margin:1.2rem 0 .6rem}
.center-page p{color:var(--ink-soft);margin-bottom:1.8rem}

/* ---- section divider (faint motif) ---- */
.divider{display:flex;justify-content:center;padding:0;opacity:.5}
.divider svg{width:120px;height:auto}
.divider path{stroke:var(--barro);fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round;opacity:.5}
.divider circle{fill:var(--barro);opacity:.5}
