/* ===================================================================
   Edith Kals — site styles
   Faithful translation of the Claude Design "Lebensfasern" concept.
   Palette, type scale, spacing and effects mirror Design/*.dc.html.
   =================================================================== */
@import url("/css/fonts.css");

:root{
  --bg:#f4efe6;          /* warm cream (page)            */
  --bg-grad:#efe7d8;     /* hero gradient end / bands    */
  --panel:#faf8f4;       /* light panel sections         */
  --ink:#37322a;         /* primary text / dark accent   */
  --ink-soft:#4a4438;    /* slightly lighter heading ink */
  --muted:#6b6256;       /* body muted text              */
  --muted-2:#7a7060;     /* captions / fine print        */
  --gold:#a08e72;        /* eyebrow gold                 */
  --gold-2:#a99a82;      /* mono labels                  */
  --line:#b9a98f;        /* hairlines, numerals          */
  --line-2:#c2b298;
  --line-3:#cbbda3;
  --border:#e0d8c9;      /* input / divider border       */
  --border-2:#e3dccf;
  --foot-bg:#37322a;
  --foot-ink:#d8ccb6;
  --foot-muted:#b3a589;
  --foot-bright:#f4efe6;

  --maxw:1280px;
  --ff-body:'Hanken Grotesk',system-ui,-apple-system,Segoe UI,Roboto,sans-serif;
  --ff-display:'Schibsted Grotesk',Georgia,serif;
  --ff-mono:'Spline Sans Mono',ui-monospace,monospace;
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  background:var(--bg);
  color:var(--ink);
  font-family:var(--ff-body);
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  overflow-x:hidden;
}
img{display:block;max-width:100%}
a{color:inherit}
h1,h2,h3,p{margin:0}

/* ---- shared inline-ish helpers ---- */
.eyebrow{
  font:500 clamp(11px,1.4vw,13px) var(--ff-mono);
  letter-spacing:.28em;text-transform:uppercase;color:var(--gold);
}
.mono-label{
  font:500 12px var(--ff-mono);
  letter-spacing:.24em;text-transform:uppercase;color:var(--gold-2);
}
.wrap{max-width:var(--maxw);margin:0 auto}

/* ---- buttons ---- */
.btn{
  text-decoration:none;display:inline-block;border-radius:999px;
  font:500 15px var(--ff-body);letter-spacing:.03em;cursor:pointer;border:none;
  transition:opacity .25s ease,background .25s ease,gap .25s ease;
}
.btn--solid{padding:15px 34px;background:var(--ink);color:var(--bg)}
.btn--solid:hover{opacity:.88}
.btn--ghost{padding:15px 30px;background:transparent;color:var(--ink);border:1px solid rgba(55,50,42,.3)}
.btn--ghost:hover{background:rgba(55,50,42,.06)}
.btn--ghost-light{
  padding:14px 32px;border:1px solid rgba(244,239,230,.5);color:var(--foot-bright);
  background:transparent;
}
.btn--ghost-light:hover{background:rgba(244,239,230,.12)}
.btn--sm{padding:14px 30px;font-size:14px}

.textlink{
  text-decoration:none;display:inline-flex;align-items:center;gap:10px;
  font:500 13px var(--ff-mono);letter-spacing:.14em;text-transform:uppercase;color:var(--ink);
  transition:gap .25s ease;
}
.textlink:hover{gap:16px}

/* ===================== HEADER ===================== */
.site-header{
  position:sticky;top:0;z-index:50;display:flex;justify-content:space-between;
  align-items:center;gap:18px;flex-wrap:wrap;
  padding:18px clamp(20px,5vw,72px);
  background:rgba(244,239,230,.82);
  backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);
  border-bottom:1px solid rgba(180,166,140,.28);
}
.brand{
  text-decoration:none;font:600 14px var(--ff-body);
  letter-spacing:.3em;text-transform:uppercase;color:var(--ink);white-space:nowrap;
}
.main-nav{
  display:flex;gap:clamp(16px,2.4vw,32px);flex-wrap:wrap;
  font:500 14px var(--ff-body);color:var(--muted);
}
.main-nav a{text-decoration:none;color:inherit;transition:color .2s ease}
.main-nav a:hover,.main-nav a.is-active{color:var(--ink)}

/* ===================== REVEAL ===================== */
[data-reveal]{will-change:opacity,transform}
/* initial hidden state applied by JS; fallback keeps content visible if JS fails */

/* ===================== FOOTER ===================== */
.site-footer{
  background:var(--foot-bg);color:var(--foot-ink);
  padding:clamp(40px,6vw,64px) clamp(20px,5vw,72px);
  display:flex;justify-content:space-between;align-items:flex-end;gap:24px;flex-wrap:wrap;
}
.site-footer .f-brand{font:600 13px var(--ff-body);letter-spacing:.3em;text-transform:uppercase;color:var(--foot-bright)}
.site-footer .f-sub{margin-top:10px;font-size:14px;line-height:1.6;color:var(--foot-muted)}
.site-footer .f-right{text-align:right;font-size:14px;line-height:1.8;color:var(--foot-muted)}
.site-footer .f-right a{color:var(--foot-muted);text-decoration:none;border-bottom:1px solid rgba(179,165,137,.5)}

/* ===================== HERO (home) ===================== */
.hero{
  position:relative;overflow:hidden;text-align:center;
  padding:clamp(72px,12vh,140px) clamp(20px,5vw,72px) clamp(60px,9vh,104px);
  background:linear-gradient(180deg,var(--bg) 0%,var(--bg-grad) 100%);
}
.hero__motif{position:absolute;inset:0;width:100%;height:100%;opacity:.45;pointer-events:none}
.hero__inner{position:relative;z-index:2;max-width:920px;margin:0 auto}
.hero__title{
  margin:clamp(18px,3vw,30px) 0 0;
  font:300 clamp(54px,12vw,150px)/.96 var(--ff-display);
  letter-spacing:-.03em;color:var(--ink);
}
.hero__lead{
  max-width:560px;margin:clamp(20px,3vw,30px) auto 0;
  font-size:clamp(16px,2.2vw,20px);line-height:1.6;color:var(--muted);text-wrap:pretty;
}
.hero__cta{margin-top:clamp(28px,4vw,42px);display:flex;gap:16px;justify-content:center;flex-wrap:wrap}
.hero__cue{position:absolute;left:50%;bottom:26px;transform:translateX(-50%);z-index:2}
.hero__cue svg{animation:scrollcue 2.2s ease-in-out infinite}

@keyframes drift{0%{transform:translateY(0)}50%{transform:translateY(-16px)}100%{transform:translateY(0)}}
@keyframes drift2{0%{transform:translateY(0)}50%{transform:translateY(13px)}100%{transform:translateY(0)}}
@keyframes drift3{0%{transform:translateY(0)}50%{transform:translateY(-9px)}100%{transform:translateY(0)}}
@keyframes scrollcue{0%{transform:translateY(0);opacity:.5}50%{transform:translateY(7px);opacity:1}100%{transform:translateY(0);opacity:.5}}
.motif-1{animation:drift 9s ease-in-out infinite}
.motif-2{animation:drift2 12s ease-in-out infinite}
.motif-3{animation:drift3 10s ease-in-out infinite}

/* curved divider */
.divider{height:clamp(40px,5vw,64px);background:var(--bg-grad);position:relative;margin-top:-1px}
.divider svg{position:absolute;inset:0;width:100%;height:100%}

/* ===================== GENERIC SECTIONS ===================== */
.section{padding:clamp(56px,8vw,104px) clamp(20px,5vw,72px)}
.section--cream{background:var(--bg)}
.section--panel{background:var(--panel)}
.section--band{background:var(--bg-grad)}
.section--dark{background:var(--ink);color:var(--foot-bright)}

/* statement (home) */
.statement{
  max-width:1080px;margin:0 auto;display:grid;
  grid-template-columns:repeat(auto-fit,minmax(280px,1fr));
  gap:clamp(36px,5vw,72px);align-items:center;
}
.statement__lead{margin:20px 0 0;font:300 clamp(24px,3.4vw,38px)/1.4 var(--ff-display);letter-spacing:-.01em;color:var(--ink);text-wrap:pretty}
.statement__body{margin:22px 0 0;font-size:16px;line-height:1.7;color:var(--muted);max-width:440px}
.media{position:relative;overflow:hidden;border-radius:3px}
.media img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.media--4x5{aspect-ratio:4/5;box-shadow:0 14px 40px rgba(60,50,35,.16)}
.media--1x1{aspect-ratio:1/1;box-shadow:0 16px 44px rgba(60,50,35,.18)}
.media--5x4{aspect-ratio:5/4;box-shadow:0 14px 40px rgba(60,50,35,.16)}
.media--16x9{aspect-ratio:16/9;box-shadow:0 18px 50px rgba(60,50,35,.2)}

/* materials grid (home) */
.materials__head{text-align:center;margin-bottom:clamp(36px,5vw,56px)}
.materials__title{margin:0;font:400 clamp(28px,4.5vw,46px) var(--ff-display);letter-spacing:-.01em;color:var(--ink)}
.materials__sub{margin:14px auto 0;max-width:460px;font-size:15px;line-height:1.6;color:var(--muted-2)}
.materials__grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:clamp(18px,2.4vw,28px)}
.matcard{text-decoration:none;color:inherit;cursor:pointer;display:block}
.matcard__media{position:relative;overflow:hidden;aspect-ratio:3/4;border-radius:3px;box-shadow:0 6px 20px rgba(60,50,35,.10)}
.matcard__media img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;transition:transform .85s cubic-bezier(.2,.7,.2,1)}
.matcard__thread{position:absolute;inset:0;width:100%;height:100%;opacity:0;transition:opacity .5s ease}
.matcard__thread line{stroke:var(--panel);stroke-width:.7;stroke-dasharray:140;stroke-dashoffset:140;transition:stroke-dashoffset 1.1s ease}
.matcard:hover .matcard__media img{transform:scale(1.05)}
.matcard:hover .matcard__thread{opacity:1}
.matcard:hover .matcard__thread line{stroke-dashoffset:0}
.matcard__row{display:flex;justify-content:space-between;align-items:baseline;margin-top:18px}
.matcard__name{margin:0;font:500 21px var(--ff-body);color:var(--ink)}
.matcard__num{font:500 12px var(--ff-mono);color:var(--line)}
.matcard__desc{margin:7px 0 0;font-size:14px;line-height:1.55;color:var(--muted-2)}

/* featured (home) */
.featured{max-width:1180px;margin:0 auto;display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:clamp(32px,5vw,64px);align-items:center}
.featured__title{margin:16px 0 0;font:300 clamp(28px,4vw,44px)/1.15 var(--ff-display);letter-spacing:-.015em;color:var(--ink)}
.featured__body{margin:20px 0 0;font-size:16px;line-height:1.75;color:var(--muted);max-width:460px}

/* about band (home + about page hero) */
.aboutband{max-width:900px;margin:0 auto;text-align:center}
.aboutband__lead{margin:24px auto 0;max-width:780px;font:300 clamp(24px,3.6vw,38px)/1.45 var(--ff-display);letter-spacing:-.005em;text-wrap:pretty}
.aboutband .eyebrow{color:var(--line-3)}

/* visit / contact (home) */
.visit{max-width:1080px;margin:0 auto;display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:clamp(32px,5vw,64px);align-items:center}
.visit__title{margin:0;font:400 clamp(26px,4vw,40px) var(--ff-display);letter-spacing:-.01em;color:var(--ink)}
.visit__body{margin:16px 0 0;font-size:16px;line-height:1.7;color:var(--muted);max-width:380px}
.deflist{margin-top:28px;display:flex;flex-direction:column;gap:14px}
.deflist__row{display:flex;gap:14px;align-items:baseline}
.deflist__key{min-width:88px;font:500 12px var(--ff-mono);letter-spacing:.12em;text-transform:uppercase;color:var(--gold-2)}
.deflist__val{font-size:16px;color:var(--ink)}
.deflist__val a{color:var(--ink);text-decoration:none;border-bottom:1px solid #c8bba2}

/* ===================== ABOUT PAGE ===================== */
.about-hero{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:clamp(36px,5vw,72px);align-items:center;max-width:1080px;margin:0 auto}
.about-hero .media{aspect-ratio:4/5;box-shadow:0 16px 44px rgba(60,50,35,.18)}
.about-title{margin:16px 0 0;font:300 clamp(38px,6vw,68px)/1.02 var(--ff-display);letter-spacing:-.025em;color:var(--ink)}
.about-intro{margin:24px 0 0;font:300 clamp(20px,2.6vw,26px)/1.5 var(--ff-display);color:var(--ink-soft);text-wrap:pretty}
.about-body{margin:20px 0 0;font-size:16px;line-height:1.75;color:var(--muted);max-width:460px}
.quote{max-width:820px;margin:0 auto;font:300 clamp(24px,3.6vw,40px)/1.45 var(--ff-display);letter-spacing:-.005em;text-wrap:pretty}
.quote__author{margin-top:28px;font:500 12px var(--ff-mono);letter-spacing:.24em;text-transform:uppercase;color:var(--line-3)}
.techniques{max-width:1080px;margin:0 auto}
.techniques__head{text-align:center;margin-bottom:clamp(32px,5vw,52px)}
.techniques__title{margin:14px 0 0;font:400 clamp(26px,4vw,40px) var(--ff-display);letter-spacing:-.01em;color:var(--ink)}
.techgrid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:clamp(20px,3vw,32px)}
.tech__num{font:500 28px var(--ff-display);color:var(--line-2)}
.tech__name{margin:10px 0 0;font:500 20px var(--ff-body);color:var(--ink)}
.tech__desc{margin:8px 0 0;font-size:15px;line-height:1.6;color:var(--muted-2)}

/* ===================== ATELIER / CONTACT shared hero ===================== */
.page-hero{text-align:center;position:relative;overflow:hidden}
.page-hero__inner{max-width:760px;margin:0 auto}
.page-hero__title{margin:clamp(14px,2vw,22px) 0 0;font:300 clamp(40px,8vw,84px)/1 var(--ff-display);letter-spacing:-.025em;color:var(--ink)}
.page-hero__lead{max-width:540px;margin:clamp(18px,2.6vw,28px) auto 0;font-size:clamp(16px,2.2vw,20px);line-height:1.6;color:var(--muted);text-wrap:pretty}

.split{max-width:1080px;margin:0 auto;display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:clamp(36px,5vw,72px);align-items:start}
.split__lead{margin:0;font:300 clamp(26px,3.6vw,38px)/1.3 var(--ff-display);letter-spacing:-.01em;color:var(--ink);text-wrap:pretty}
.split__body{margin:22px 0 0;font-size:16px;line-height:1.75;color:var(--muted)}
.split__body + .split__body{margin-top:18px}
.infocol{border-left:1px solid var(--border-2);padding-left:clamp(24px,3vw,40px);display:flex;flex-direction:column;gap:22px}
.infocol__key{font:500 12px var(--ff-mono);letter-spacing:.12em;text-transform:uppercase;color:var(--gold-2)}
.infocol__val{margin-top:6px;font-size:17px;color:var(--ink)}
.infocol__val a{color:var(--ink);text-decoration:none;border-bottom:1px solid #c8bba2}

/* ===================== CONTACT PAGE ===================== */
.contact{max-width:1000px;margin:0 auto}
.contact__intro{max-width:560px}
.contact__title{margin:clamp(12px,2vw,20px) 0 0;font:300 clamp(38px,7vw,76px)/1 var(--ff-display);letter-spacing:-.025em;color:var(--ink)}
.contact__lead{margin:clamp(16px,2.4vw,24px) 0 0;font-size:clamp(15px,2vw,18px);line-height:1.65;color:var(--muted);text-wrap:pretty}
.contact__grid{margin-top:clamp(40px,5vw,64px);display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:clamp(36px,5vw,64px);align-items:start}
.contact-aside{border-left:1px solid var(--border-2);padding-left:clamp(24px,3vw,40px);display:flex;flex-direction:column;gap:24px}
.contact-aside__key{font:500 12px var(--ff-mono);letter-spacing:.14em;text-transform:uppercase;color:var(--gold-2)}
.contact-aside__val{margin-top:7px;font-size:17px;line-height:1.5;color:var(--ink)}
.contact-aside__val a{color:var(--ink);text-decoration:none;border-bottom:1px solid #c8bba2}
.contact-card{
  background:var(--panel);border:1px solid var(--border);border-radius:3px;
  padding:clamp(28px,4vw,40px);display:flex;flex-direction:column;gap:18px;align-self:start;
}
.contact-card__line{font-size:17px;line-height:1.6;color:var(--ink)}
.contact-card__mail{
  align-self:flex-start;margin-top:6px;
}

/* ===================== GALLERY ===================== */
.gallery-intro{text-align:center}
.gallery-title{margin:clamp(14px,2vw,22px) 0 0;font:300 clamp(40px,8vw,88px)/1 var(--ff-display);letter-spacing:-.025em;color:var(--ink)}
.gallery-lead{max-width:520px;margin:clamp(16px,2.4vw,26px) auto 0;font-size:clamp(15px,2vw,18px);line-height:1.6;color:var(--muted);text-wrap:pretty}
.filters{display:flex;justify-content:center;flex-wrap:wrap;gap:10px;padding:0 clamp(20px,5vw,72px) clamp(32px,5vw,52px)}
.filter-btn{
  cursor:pointer;padding:10px 22px;border-radius:999px;border:1px solid rgba(55,50,42,.22);
  background:transparent;color:var(--muted);font:500 13px var(--ff-body);letter-spacing:.02em;
  transition:background .2s ease,color .2s ease;
}
.filter-btn.is-active{background:var(--ink);color:var(--bg)}
.gallery-grid{
  max-width:1280px;margin:0 auto;display:grid;
  grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:clamp(16px,2vw,26px);
}
.tile{margin:0;cursor:pointer}
.tile__media{position:relative;overflow:hidden;aspect-ratio:3/4;border-radius:3px;box-shadow:0 6px 20px rgba(60,50,35,.10)}
.tile__media img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;transition:transform .8s cubic-bezier(.2,.7,.2,1)}
.tile:hover .tile__media img{transform:scale(1.05)}
.tile__cap{display:flex;justify-content:space-between;align-items:baseline;margin-top:14px;gap:12px}
.tile__name{font:500 17px var(--ff-body);color:var(--ink)}
.tile__cat{font:500 11px var(--ff-mono);letter-spacing:.12em;text-transform:uppercase;color:var(--line);white-space:nowrap}

/* lightbox */
.lightbox{
  display:none;position:fixed;inset:0;z-index:100;background:rgba(40,36,30,.92);
  align-items:center;justify-content:center;padding:clamp(20px,5vw,64px);
  flex-direction:column;gap:18px;
}
.lightbox.is-open{display:flex}
.lightbox__img{max-width:100%;max-height:78vh;object-fit:contain;border-radius:3px;box-shadow:0 30px 80px rgba(0,0,0,.5);cursor:pointer}
.lightbox__cap{font:500 13px var(--ff-mono);letter-spacing:.18em;text-transform:uppercase;color:var(--foot-ink);text-align:center;max-width:680px}
.lightbox__desc{font-size:14px;line-height:1.6;color:#cfc3ad;max-width:560px;text-align:center}
.lightbox__hint{font:500 11px var(--ff-mono);letter-spacing:.14em;text-transform:uppercase;color:#8a7f6d}
.lightbox__nav,.lightbox__close{
  position:fixed;display:flex;align-items:center;justify-content:center;cursor:pointer;z-index:2;
  border:1px solid rgba(244,239,230,.25);background:rgba(244,239,230,.06);color:#e8ddc8;border-radius:999px;
  transition:background .2s ease,border-color .2s ease,color .2s ease;
}
.lightbox__nav:hover,.lightbox__close:hover{background:rgba(244,239,230,.16);border-color:rgba(244,239,230,.55);color:#fff}
.lightbox__nav{top:50%;transform:translateY(-50%);width:clamp(44px,5vw,54px);height:clamp(44px,5vw,54px)}
.lightbox__nav--prev{left:clamp(10px,3vw,40px)}
.lightbox__nav--next{right:clamp(10px,3vw,40px)}
.lightbox__close{top:clamp(12px,3vw,28px);right:clamp(12px,3vw,28px);width:44px;height:44px}

/* ===================== CONTENT PAGE (Aktuelles, Links, RTE) ===================== */
.content-hero{max-width:820px;margin:0 auto;text-align:center}
.content-title{margin:clamp(14px,2vw,22px) 0 0;font:300 clamp(36px,7vw,76px)/1.02 var(--ff-display);letter-spacing:-.025em;color:var(--ink)}
.content-lead{max-width:600px;margin:clamp(16px,2.4vw,24px) auto 0;font-size:clamp(15px,2vw,18px);line-height:1.65;color:var(--muted);text-wrap:pretty}
.rte{max-width:760px;margin:0 auto;font-size:16px;line-height:1.75;color:var(--ink-soft)}
.rte h1{font:300 clamp(26px,3.4vw,34px)/1.2 var(--ff-display);letter-spacing:-.01em;color:var(--ink);margin:clamp(40px,5vw,56px) 0 0}
.rte h1:first-child{margin-top:0}
.rte h2{font:400 clamp(20px,2.6vw,25px) var(--ff-display);color:var(--ink);margin:28px 0 0}
.rte h3{font:600 17px var(--ff-body);color:var(--ink-soft);margin:24px 0 0}
.rte p{margin:14px 0 0;color:var(--muted)}
.rte a{color:var(--ink);text-decoration:none;border-bottom:1px solid #c8bba2}
.rte a:hover{border-bottom-color:var(--ink)}
.rte ul{margin:14px 0 0;padding-left:1.1em;color:var(--muted)}
.rte img{border-radius:3px;margin:24px 0 0;box-shadow:0 10px 30px rgba(60,50,35,.14)}

/* ===================== LINK LIST (Links page) ===================== */
.linklist{max-width:760px;margin:0 auto;display:flex;flex-direction:column}
.linklist__item{
  display:grid;grid-template-columns:1fr auto;align-items:baseline;column-gap:18px;
  text-decoration:none;color:inherit;padding:22px 6px;border-top:1px solid var(--border-2);
  transition:padding-left .25s ease;
}
.linklist__item:last-child{border-bottom:1px solid var(--border-2)}
.linklist__item:hover{padding-left:12px}
.linklist__label{grid-column:1;grid-row:1;font:500 clamp(18px,2.2vw,21px) var(--ff-body);color:var(--ink);border-bottom:1px solid transparent;transition:border-color .2s ease}
.linklist__item:hover .linklist__label{border-bottom-color:#c8bba2}
.linklist__desc{grid-column:1;grid-row:2;margin-top:5px;font-size:15px;line-height:1.55;color:var(--muted-2)}
.linklist__arrow{grid-column:2;grid-row:1;color:var(--gold);font-size:18px;transition:transform .25s ease}
.linklist__item:hover .linklist__arrow{transform:translateX(5px)}

/* ===================== ERROR PAGE ===================== */
.errorpage{min-height:60vh;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:clamp(64px,10vw,140px) clamp(20px,5vw,72px)}
.errorpage .code{font:500 13px var(--ff-mono);letter-spacing:.24em;color:var(--gold)}
.errorpage h1{margin:18px 0 0;font:300 clamp(32px,5vw,56px) var(--ff-display);letter-spacing:-.02em;color:var(--ink)}
.errorpage p{margin:18px 0 0;max-width:460px;font-size:16px;line-height:1.7;color:var(--muted)}
.errorpage .btn{margin-top:32px}

/* reduce motion */
@media (prefers-reduced-motion:reduce){
  *{animation:none!important}
  html{scroll-behavior:auto}
}
