/* ============================================================
   AXIS FORM — Möbel nach Maß
   Tokens
   ============================================================ */
:root{
  --espresso:   #1E1B17;
  --espresso-2: #28241D;
  --cream:      #F6F3EC;
  --cream-2:    #ECE5D6;
  --oak:        #CBA463;
  --copper:     #B6904C;
  --copper-2:   #8C6A2E;
  --gold-bright:#D9B873;
  --glass:      #C7C9C3;
  --stone:      #6F6A62;
  --ink:        #29271F;
  --moss:       #4B4A38;
  --line:       rgba(41,39,31,0.13);
  --line-light: rgba(243,237,227,0.22);

  --display: "Italiana", "Iowan Old Style", Georgia, serif;
  --body:    "Work Sans", "Helvetica Neue", Arial, sans-serif;
  --mono:    "JetBrains Mono", "SFMono-Regular", Menlo, monospace;

  --max: 1180px;
  --pad: clamp(20px, 5vw, 64px);
}

*{ box-sizing:border-box; }
html{ scroll-behavior:smooth; }
body{
  margin:0;
  background:var(--cream);
  color:var(--ink);
  font-family:var(--body);
  font-size:16px;
  line-height:1.55;
  -webkit-font-smoothing:antialiased;
}
img{ max-width:100%; display:block; }
a{ color:inherit; text-decoration:none; }
h1,h2,h3,h4{ font-family:var(--display); margin:0; font-weight:400; letter-spacing:0.01em; }
p{ margin:0; }
ul{ margin:0; padding:0; list-style:none; }
.wrap{ max-width:var(--max); margin:0 auto; padding-left:var(--pad); padding-right:var(--pad); }

/* ---------- focus & motion ---------- */
:focus-visible{ outline:2px solid var(--copper); outline-offset:3px; }
@media (prefers-reduced-motion: reduce){
  *{ animation-duration:0.001ms !important; animation-iteration-count:1 !important; transition-duration:0.001ms !important; scroll-behavior:auto !important; }
}

/* ---------- reveal-on-scroll ---------- */
.reveal{ opacity:0; transform:translateY(18px); transition:opacity .7s ease, transform .7s ease; }
.reveal.is-visible{ opacity:1; transform:translateY(0); }

/* ============================================================
   Header
   ============================================================ */
.site-header{
  position:fixed; top:0; left:0; right:0; z-index:50;
  display:flex; align-items:center; justify-content:space-between;
  padding:16px var(--pad);
  background:rgba(246,243,236,0.0);
  border-bottom:1px solid transparent;
  transition:background .35s ease, border-color .35s ease, box-shadow .35s ease;
}
.site-header.scrolled{
  background:rgba(246,243,236,0.92);
  backdrop-filter:blur(6px);
  border-bottom:1px solid var(--line);
  box-shadow:0 1px 0 var(--line);
}
.brand{
  font-family:var(--display); font-size:1.3rem; color:var(--ink); letter-spacing:.06em;
  display:flex; align-items:baseline; gap:7px; text-transform:uppercase;
}
.brand .brand-form{ color:var(--copper); }
.brand small{ font-family:var(--mono); font-size:.55rem; letter-spacing:.16em; color:var(--copper); text-transform:uppercase; margin-left:4px; }
@media (max-width:560px){ .brand small{ display:none; } }
.main-nav{ display:flex; align-items:center; gap:28px; }
.main-nav a{
  font-family:var(--mono); font-size:.74rem; letter-spacing:.08em; text-transform:uppercase;
  color:var(--stone); position:relative; padding-bottom:4px;
}
.main-nav a::after{
  content:""; position:absolute; left:0; right:100%; bottom:0; height:1px; background:var(--copper);
  transition:right .25s ease;
}
.main-nav a:hover::after{ right:0; }
.main-nav a:hover{ color:var(--ink); }
.nav-cta{
  font-family:var(--mono); font-size:.72rem; letter-spacing:.06em; text-transform:uppercase;
  color:var(--cream); background:var(--copper); padding:10px 18px; border-radius:2px;
}
.nav-cta:hover{ background:var(--copper-2); color:var(--cream) !important; }
.nav-cta::after{ display:none; }
.nav-toggle{ display:none; }

@media (max-width: 860px){
  .main-nav{ position:fixed; inset:0; top:64px; background:var(--cream); flex-direction:column;
    justify-content:flex-start; align-items:flex-start; padding:40px var(--pad); gap:26px;
    transform:translateX(100%); transition:transform .35s ease; border-left:1px solid var(--line); }
  .main-nav.open{ transform:translateX(0); }
  .main-nav a{ font-size:1rem; color:var(--ink); }
  .nav-toggle{
    display:flex; flex-direction:column; gap:5px; background:none; border:0; cursor:pointer; z-index:60;
  }
  .nav-toggle span{ width:24px; height:2px; background:var(--ink); display:block; }
}

/* ============================================================
   Hero — "Vom Entwurf zur Wirklichkeit" emblem
   ============================================================ */
.hero{
  position:relative; min-height:100vh; display:flex; align-items:center;
  background:
    radial-gradient(ellipse 70% 60% at 18% 15%, rgba(182,144,76,0.10), transparent 60%),
    var(--cream);
  overflow:hidden;
  padding-top:120px;
}
.hero-grid{
  position:absolute; inset:0; opacity:.6;
  background-image:
    linear-gradient(var(--line) 1px, transparent 1px),
    linear-gradient(90deg, var(--line) 1px, transparent 1px);
  background-size:64px 64px;
  mask-image:radial-gradient(ellipse 70% 70% at 50% 40%, rgba(0,0,0,.5), transparent 75%);
}
.hero-dims{ position:absolute; inset:0; pointer-events:none; }
.hero-inner{
  position:relative; z-index:2; width:100%;
  padding:40px var(--pad) 70px;
  display:grid; grid-template-columns:1.05fr .95fr; gap:40px; align-items:center;
}
.hero-eyebrow{
  font-family:var(--mono); color:var(--copper); font-size:.78rem; letter-spacing:.18em; text-transform:uppercase;
  display:flex; align-items:center; gap:12px; margin-bottom:22px;
}
.hero-eyebrow::before{ content:""; width:34px; height:1px; background:var(--copper); }
.hero h1{
  color:var(--ink); font-size:clamp(2.4rem, 5.2vw, 4.4rem); line-height:1.05; max-width:15ch;
}
.hero h1 em{ font-style:normal; color:var(--copper); }
.hero-sub{
  color:var(--stone); font-size:1.06rem; max-width:36ch; margin-top:22px;
}
.hero-cta{ display:flex; gap:14px; margin-top:34px; flex-wrap:wrap; }
.btn{
  font-family:var(--mono); font-size:.78rem; letter-spacing:.06em; text-transform:uppercase;
  padding:15px 26px; border-radius:2px; border:1px solid transparent; cursor:pointer;
  transition:transform .2s ease, background .2s ease, color .2s ease, border-color .2s ease;
  display:inline-flex; align-items:center; gap:10px;
}
.btn-primary{ background:var(--copper); color:var(--cream); }
.btn-primary:hover{ background:var(--copper-2); transform:translateY(-1px); }
.btn-ghost{ border-color:var(--line); color:var(--stone); background:transparent; }
.btn-ghost:hover{ border-color:var(--copper); color:var(--copper); }

.hero-spec{
  font-family:var(--mono); color:var(--stone); font-size:.74rem; border-left:1px solid var(--line);
  padding-left:22px; display:flex; flex-direction:column; gap:10px; margin-top:32px;
}
.hero-spec span{ color:var(--copper); }

.hero-scroll{
  position:absolute; left:var(--pad); bottom:28px; z-index:2;
  font-family:var(--mono); font-size:.68rem; letter-spacing:.12em; color:var(--stone);
  display:flex; align-items:center; gap:10px; text-transform:uppercase;
}
.hero-scroll::after{ content:""; width:1px; height:30px; background:linear-gradient(var(--copper), transparent); }

/* --- Emblem: arc + sketch/reality split photo + wordmark --- */
.hero-emblem{
  position:relative; display:flex; flex-direction:column; align-items:center; justify-content:center;
  padding:20px;
}
.emblem-stage{ position:relative; width:min(340px, 86%); aspect-ratio:1; }
.emblem-arc{ position:absolute; inset:0; width:100%; height:100%; overflow:visible; }
.emblem-arc .arc-glass{ fill:none; stroke:var(--glass); stroke-width:1.4; stroke-dasharray:2 7; }
.emblem-arc .arc-gold{ fill:none; stroke:var(--copper); stroke-width:2.2; filter:drop-shadow(0 0 5px rgba(182,144,76,0.45)); }
.emblem-photo{
  position:absolute; left:8%; top:8%; width:84%; height:84%; border-radius:50%;
  overflow:hidden; box-shadow:0 18px 40px rgba(41,39,31,0.18);
}
.emblem-photo img{ position:absolute; top:0; left:0; width:100%; height:100%; object-fit:cover; }
.emblem-photo .layer-sketch{
  clip-path:inset(0 50% 0 0);
  filter:grayscale(1) contrast(1.5) brightness(1.35) invert(0.86);
  opacity:.62;
}
.emblem-photo .layer-real{ clip-path:inset(0 0 0 50%); }
.emblem-photo::after{
  content:""; position:absolute; top:0; bottom:0; left:50%; width:2px; transform:translateX(-1px);
  background:linear-gradient(var(--gold-bright), var(--copper));
  box-shadow:0 0 12px 1px rgba(217,184,115,0.8);
}
.emblem-wordmark{ margin-top:26px; text-align:center; }
.emblem-wordmark .brand-mark{
  font-family:var(--display); font-size:clamp(1.6rem, 3vw, 2.1rem); letter-spacing:.14em; text-transform:uppercase;
}
.emblem-wordmark .axis{ color:var(--ink); }
.emblem-wordmark .form{ color:var(--copper); margin-left:.35em; }
.emblem-wordmark .rule{
  width:120px; height:1px; margin:12px auto 10px; background:linear-gradient(90deg, transparent, var(--copper), transparent);
}
.emblem-wordmark .tagline{
  font-family:var(--mono); font-size:.66rem; letter-spacing:.22em; text-transform:uppercase; color:var(--stone);
}

@media (max-width:860px){
  .hero-inner{ grid-template-columns:1fr; }
  .hero-emblem{ order:-1; }
  .hero-spec{ border-left:0; border-top:1px solid var(--line); padding-left:0; padding-top:18px; }
}

/* ============================================================
   Section shells
   ============================================================ */
section{ padding:108px 0; position:relative; }
.section-dark{ background:var(--espresso); color:var(--cream); }
.section-dark .eyebrow{ color:var(--oak); }
.section-dark p.lead{ color:var(--cream-2); }

.eyebrow{
  font-family:var(--mono); font-size:.76rem; letter-spacing:.16em; text-transform:uppercase; color:var(--copper);
  display:flex; align-items:center; gap:12px; margin-bottom:16px;
}
.eyebrow::before{ content:""; width:28px; height:1px; background:currentColor; }
.section-head{ max-width:640px; margin-bottom:56px; }
.section-head h2{ font-size:clamp(2rem, 4vw, 2.9rem); line-height:1.08; }
.section-head p.lead{ margin-top:18px; color:var(--stone); font-size:1.05rem; max-width:46ch; }

/* ============================================================
   Leistungen / Services
   ============================================================ */
.service-row{
  display:grid; grid-template-columns: 0.9fr 1.1fr; gap:56px; align-items:center;
  padding:56px 0; border-top:1px solid var(--line);
}
.service-row:first-of-type{ border-top:1px solid var(--line); }
.service-row:nth-child(even) .service-media{ order:2; }
.service-tag{
  font-family:var(--mono); font-size:.7rem; color:var(--copper); letter-spacing:.14em; text-transform:uppercase;
}
.service-text h3{ font-size:clamp(1.5rem,2.6vw,2rem); margin-top:10px; }
.service-text p{ color:var(--stone); margin-top:14px; max-width:42ch; }
.service-list{ margin-top:20px; display:flex; flex-direction:column; gap:9px; }
.service-list li{ display:flex; gap:10px; font-size:.94rem; }
.service-list li::before{ content:"—"; color:var(--oak); flex-shrink:0; }

.service-media{ position:relative; }
.frame-grid{ display:grid; grid-template-columns:1.3fr 1fr; grid-template-rows:auto auto; gap:10px; }
.frame-grid .photo-frame:first-child{ grid-row:1 / 3; }
.photo-frame{
  position:relative; aspect-ratio:4/3; background:var(--cream-2); overflow:hidden;
  border:1px solid var(--line);
}
.frame-grid .photo-frame:first-child{ aspect-ratio:3/4; }
.photo-frame img{ width:100%; height:100%; object-fit:cover; display:block; }
.photo-frame::before, .photo-frame::after{ content:""; position:absolute; width:14px; height:14px; pointer-events:none; }
.photo-frame::before{ top:6px; left:6px; border-top:1.5px solid var(--copper); border-left:1.5px solid var(--copper); }
.photo-frame::after{ bottom:6px; right:6px; border-bottom:1.5px solid var(--copper); border-right:1.5px solid var(--copper); }
.photo-cap{
  position:absolute; left:6px; bottom:6px; right:30px;
  font-family:var(--mono); font-size:.62rem; color:var(--cream); background:rgba(34,28,22,0.72);
  padding:4px 8px; letter-spacing:.03em;
}
.photo-order-btn{
  position:absolute; top:8px; right:8px; z-index:3;
  font-family:var(--mono); font-size:.62rem; letter-spacing:.04em; text-transform:uppercase;
  background:var(--copper); color:var(--cream); border:0; padding:7px 11px; border-radius:2px;
  cursor:pointer; opacity:0; transform:translateY(-4px); transition:opacity .2s ease, transform .2s ease, background .2s ease;
}
.photo-frame:hover .photo-order-btn,
.gallery-item:hover .photo-order-btn,
.photo-order-btn:focus-visible{
  opacity:1; transform:translateY(0);
}
.photo-order-btn:hover{ background:var(--copper-2); }
@media (max-width:640px){
  .photo-order-btn{ opacity:1; transform:none; }
}

@media (max-width:860px){
  .service-row{ grid-template-columns:1fr; }
  .service-row:nth-child(even) .service-media{ order:0; }
}

/* ============================================================
   Ablauf / Process timeline (signature element)
   ============================================================ */
.process{ background:var(--cream-2); }
.process-list{ margin-top:10px; }
.process-step{
  display:grid; grid-template-columns:120px 1fr; gap:28px; padding:30px 0; position:relative;
}
.process-step + .process-step{ border-top:1px dashed var(--line); }
.step-sheet{
  font-family:var(--mono); color:var(--copper); font-size:.78rem; letter-spacing:.08em;
}
.step-sheet b{ display:block; font-size:1.6rem; color:var(--ink); font-family:var(--display); font-weight:400; }
.step-body h4{ font-size:1.2rem; }
.step-body p{ color:var(--stone); margin-top:8px; max-width:60ch; }
.dim{
  position:absolute; left:120px; top:0; bottom:0; width:1px; background:var(--line);
}
.dim::before, .dim::after{
  content:""; position:absolute; left:-4px; width:9px; height:1px; background:var(--copper);
}
.dim::before{ top:30px; }
.dim::after{ bottom:30px; }
.process-step:last-child .dim{ display:none; }

@media (max-width:640px){
  .process-step{ grid-template-columns:1fr; gap:6px; }
  .dim{ display:none; }
}

/* ============================================================
   Galerie
   ============================================================ */
.gallery-tabs{ display:flex; gap:10px; flex-wrap:wrap; margin-bottom:34px; }
.gallery-tab{
  font-family:var(--mono); font-size:.72rem; letter-spacing:.06em; text-transform:uppercase;
  padding:9px 16px; border:1px solid var(--line); border-radius:20px; cursor:pointer; background:transparent;
  color:var(--stone); transition:all .2s ease;
}
.gallery-tab.active, .gallery-tab:hover{ border-color:var(--copper); color:var(--copper); }
.gallery-grid{
  display:grid; grid-template-columns:repeat(auto-fill, minmax(240px,1fr)); gap:14px;
}
.gallery-item{
  position:relative; aspect-ratio:1; overflow:hidden; border:1px solid var(--line); cursor:pointer;
}
.gallery-item img{ width:100%; height:100%; object-fit:cover; transition:transform .5s ease; }
.gallery-item:hover img{ transform:scale(1.06); }
.gallery-item .photo-cap{ opacity:0; transition:opacity .25s ease; }
.gallery-item:hover .photo-cap{ opacity:1; }
.gallery-item[hidden]{ display:none; }

/* ============================================================
   Material / Vertrauen strip
   ============================================================ */
.trust-strip{
  display:grid; grid-template-columns:repeat(4,1fr); gap:30px; padding:50px var(--pad);
  background:var(--espresso); color:var(--cream-2);
}
.trust-item b{ font-family:var(--display); font-size:1.9rem; color:var(--oak); display:block; }
.trust-item span{ font-family:var(--mono); font-size:.7rem; letter-spacing:.06em; text-transform:uppercase; }
@media (max-width:760px){ .trust-strip{ grid-template-columns:repeat(2,1fr); } }

/* ============================================================
   Kontakt
   ============================================================ */
.contact{ background:var(--espresso); color:var(--cream); }
.contact-grid{ display:grid; grid-template-columns:.9fr 1.1fr; gap:60px; }
.contact-info p.lead{ color:var(--cream-2); margin-top:16px; max-width:36ch; }
.contact-detail{ margin-top:38px; display:flex; flex-direction:column; gap:18px; }
.contact-detail dt{ font-family:var(--mono); font-size:.68rem; letter-spacing:.1em; text-transform:uppercase; color:var(--oak); }
.contact-detail dd{ margin:4px 0 0; font-size:1.05rem; }
.contact-form{ background:var(--espresso-2); border:1px solid var(--line-light); padding:36px; border-radius:2px; }
.form-row{ display:grid; grid-template-columns:1fr 1fr; gap:18px; }
.field{ margin-bottom:20px; }
.field label{
  font-family:var(--mono); font-size:.68rem; letter-spacing:.08em; text-transform:uppercase; color:var(--cream-2);
  display:block; margin-bottom:8px;
}
.field input, .field select, .field textarea{
  width:100%; background:transparent; border:0; border-bottom:1px solid var(--line-light);
  color:var(--cream); font-family:var(--body); font-size:.98rem; padding:9px 2px; outline:none;
  transition:border-color .2s ease;
}
.field select{ -webkit-appearance:none; appearance:none; }
.field select option{ color:#111; }
.field input::placeholder, .field textarea::placeholder{ color:rgba(243,237,227,0.35); }
.field input:focus, .field select:focus, .field textarea:focus{ border-color:var(--oak); }
.field textarea{ resize:vertical; min-height:90px; }
.form-note{ font-size:.78rem; color:rgba(243,237,227,0.55); margin-top:6px; }
.form-status{ font-family:var(--mono); font-size:.78rem; margin-top:16px; min-height:1em; }
.form-status.ok{ color:var(--oak); }

@media (max-width:860px){
  .contact-grid{ grid-template-columns:1fr; }
  .form-row{ grid-template-columns:1fr; }
}

/* ============================================================
   Footer
   ============================================================ */
.site-footer{
  background:#1A1510; color:rgba(243,237,227,0.55); padding:34px var(--pad);
  display:flex; justify-content:space-between; align-items:center; flex-wrap:wrap; gap:14px;
  font-family:var(--mono); font-size:.72rem; letter-spacing:.04em;
}
.site-footer a{ color:rgba(243,237,227,0.75); }
.site-footer a:hover{ color:var(--oak); }
.footer-links{ display:flex; gap:20px; }

/* ============================================================
   Legal pages (Impressum/Datenschutz)
   ============================================================ */
.legal{ padding:160px 0 100px; max-width:760px; }
.legal h1{ font-size:2.2rem; margin-bottom:30px; }
.legal h2{ font-size:1.2rem; margin-top:40px; margin-bottom:10px; font-family:var(--body); font-weight:600; }
.legal p, .legal li{ color:var(--stone); margin-bottom:10px; }
.legal a{ color:var(--copper); text-decoration:underline; }
.back-link{ display:inline-block; margin-top:40px; font-family:var(--mono); font-size:.8rem; color:var(--copper); }

/* ============================================================
   Floating WhatsApp button
   ============================================================ */
.whatsapp-float{
  position:fixed; right:22px; bottom:22px; z-index:80;
  width:56px; height:56px; border-radius:50%;
  background:#25D366; color:#fff;
  display:flex; align-items:center; justify-content:center;
  box-shadow:0 6px 18px rgba(0,0,0,0.28);
  transition:transform .2s ease, box-shadow .2s ease;
}
.whatsapp-float:hover{ transform:translateY(-2px) scale(1.05); box-shadow:0 10px 22px rgba(0,0,0,0.32); }
@media (max-width:640px){
  .whatsapp-float{ right:16px; bottom:16px; width:50px; height:50px; }
}
