:root{
  --bg:#0C1216; --bg2:#101A1F; --surface:#141E23;
  --ink:#F1EFEA; --soft:#9FAEB4; --muted:#6C7A80;
  --cyan:#34D6DB; --pink:#F25D9E;
  --line:rgba(255,255,255,.11);
  --cm:linear-gradient(115deg,#34D6DB,#F25D9E);
  --display:"Syne",sans-serif; --mono:"Space Mono",monospace; --sans:"Archivo",sans-serif;
  --ease:cubic-bezier(.22,.61,.36,1);
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{background:var(--bg);color:var(--ink);font-family:var(--sans);-webkit-font-smoothing:antialiased;overflow-x:hidden;-webkit-touch-callout:none;line-height:1.6;
  background-image:radial-gradient(110% 60% at 90% -10%,rgba(52,214,219,.10),transparent 58%),radial-gradient(80% 55% at -5% 108%,rgba(242,93,158,.07),transparent 60%)}
img{display:block;width:100%;height:100%;object-fit:cover;user-select:none;-webkit-user-drag:none}
a{color:inherit;text-decoration:none}
body::after{content:"";position:fixed;inset:0;pointer-events:none;z-index:9999;opacity:.04;mix-blend-mode:screen;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.82' numOctaves='3'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E")}
.wrap{max-width:1320px;margin:0 auto;padding:0 clamp(20px,5vw,64px)}
.eyebrow{font-family:var(--mono);font-size:11px;font-weight:700;letter-spacing:.24em;text-transform:uppercase;color:var(--cyan)}
.grad{background:var(--cm);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}

/* header */
header{position:fixed;top:0;left:0;right:0;z-index:100;transition:.45s var(--ease)}
.bar{display:flex;align-items:center;justify-content:space-between;padding:20px clamp(20px,5vw,64px)}
.brand{font-family:var(--display);font-weight:800;font-size:22px;letter-spacing:-.01em;color:#fff}
.brand span{font-weight:600;color:var(--soft);transition:color .3s var(--ease)}
.brand:hover span{color:var(--cyan)}
nav ul{display:flex;gap:30px;list-style:none;align-items:center}
nav a{font-family:var(--mono);font-size:12px;letter-spacing:.08em;text-transform:uppercase;color:var(--soft);transition:.3s}
nav a:hover{color:var(--cyan)}
.menu-btn{display:none;font-size:22px;line-height:1;color:#fff;background:none;border:none;cursor:pointer;width:44px;height:44px;align-items:center;justify-content:center;margin-right:-10px;-webkit-tap-highlight-color:transparent}
header.scrolled{background:rgba(12,18,22,.82);backdrop-filter:blur(12px);border-bottom:1px solid var(--line)}

/* mobile nav overlay */
.mobilenav{position:fixed;inset:0;z-index:99;background:rgba(10,15,18,.97);backdrop-filter:blur(16px);display:flex;flex-direction:column;justify-content:center;padding:0 clamp(20px,5vw,64px);opacity:0;visibility:hidden;transform:translateY(-10px);transition:opacity .4s var(--ease),transform .55s var(--ease),visibility .4s}
.mobilenav.on{opacity:1;visibility:visible;transform:none}
.mobilenav ul{list-style:none;display:flex;flex-direction:column;gap:6px}
.mobilenav a{display:block;font-family:var(--display);font-weight:800;font-size:clamp(34px,9vw,58px);line-height:1.1;letter-spacing:-.02em;color:#fff;padding:10px 0;transition:color .3s var(--ease),transform .3s var(--ease)}
.mobilenav a:hover,.mobilenav a:active{color:var(--cyan);transform:translateX(8px)}
.mobilenav .mn-foot{margin-top:clamp(28px,6vw,52px);font-family:var(--mono);font-size:12px;letter-spacing:.14em;text-transform:uppercase;color:var(--muted)}

/* hero */
.hero{position:relative;height:100vh;height:100svh;min-height:600px;display:flex;align-items:flex-end;overflow:hidden}
.hero .bg{position:absolute;inset:0;z-index:0;background:#0a0f12}
.hero .bg picture{display:block;width:100%;height:100%}
.hero .bg img{filter:saturate(1.04)}
.hero .bg::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(12,18,22,.42),rgba(12,18,22,.05) 32%,rgba(12,18,22,.5) 72%,var(--bg) 100%)}
.hero .inner{position:relative;z-index:2;width:100%;padding-bottom:clamp(46px,7vw,104px)}
.hero-eyebrow{display:flex;gap:14px;align-items:center;margin-bottom:22px}
.hero-eyebrow .rule{height:2px;width:54px;background:var(--cm);border-radius:2px}
.hero h1{font-family:var(--display);font-weight:800;line-height:.9;font-size:clamp(34px,10vw,150px);letter-spacing:-.02em;color:#fff}
.hero .lead{max-width:48ch;margin-top:24px;font-size:clamp(15px,1.5vw,18px);color:rgba(241,239,234,.9)}
.hero .scrollcue{position:absolute;right:clamp(20px,5vw,64px);bottom:clamp(46px,7vw,104px);z-index:2;color:var(--soft);font-family:var(--mono);font-size:11px;letter-spacing:.2em;text-transform:uppercase;writing-mode:vertical-rl}

/* sections */
.sec{padding:clamp(48px,7vw,104px) 0}
.sec-head{display:flex;justify-content:space-between;align-items:flex-end;gap:24px;margin-bottom:clamp(30px,4vw,56px)}
.sec-head h2{font-family:var(--display);font-weight:700;font-size:clamp(32px,5vw,64px);line-height:1;letter-spacing:-.02em}
.sec-num{font-family:var(--mono);font-size:12px;letter-spacing:.16em;color:var(--muted)}

/* collections grid */
.coll{columns:3;column-gap:clamp(16px,2vw,26px)}
.card{position:relative;overflow:hidden;cursor:pointer;background:var(--surface);display:block;border:1px solid var(--line);break-inside:avoid;margin-bottom:clamp(16px,2vw,26px);transition:box-shadow .45s,border-color .45s,transform .45s var(--ease)}
.card:hover{border-color:rgba(52,214,219,.55);box-shadow:0 0 22px rgba(52,214,219,.18),0 18px 44px -22px #000;transform:translateY(-3px)}
.card .ph{overflow:hidden;position:relative;background:var(--surface)}
.card .ph::after{content:"";position:absolute;inset:0;background:var(--cm);opacity:0;mix-blend-mode:soft-light;transition:opacity .5s}
.card:hover .ph::after{opacity:.2}
.card .ph img{transition:transform 1.1s var(--ease);height:auto}
.card:hover .ph img{transform:scale(1.05)}
.card .meta{display:flex;justify-content:space-between;align-items:baseline;padding:14px}
.card .name{font-family:var(--display);font-size:clamp(20px,2vw,27px);font-weight:700}
.card .cnt{font-family:var(--mono);font-size:11px;letter-spacing:.1em;color:var(--cyan);text-transform:uppercase}
.card .open{position:absolute;top:13px;right:13px;z-index:2;font-family:var(--mono);font-size:10px;letter-spacing:.12em;text-transform:uppercase;color:#0C1216;padding:7px 12px;background:var(--cyan);border-radius:100px;opacity:0;transform:translateY(-6px);transition:.45s var(--ease)}
.card:hover .open{opacity:1;transform:none}
/* Kollektions-Cover: natürliches Seitenverhältnis (kein Crop) via Masonry-Spalten */

/* masonry */
.masonry{columns:3;column-gap:clamp(16px,2vw,26px)}
.masonry figure{break-inside:avoid;margin-bottom:clamp(16px,2vw,26px);position:relative;overflow:hidden;border:1px solid var(--line)}
.masonry img{transition:transform 1s var(--ease)}
.masonry figure:hover img{transform:scale(1.05)}
.masonry figure:hover{box-shadow:0 0 26px rgba(242,93,158,.22)}

/* gallery page */
.ghead{padding:clamp(96px,13vh,150px) 0 clamp(20px,3vw,38px)}
.ghead .top{display:flex;justify-content:space-between;align-items:flex-end;gap:20px;flex-wrap:wrap}
.ghead .eyebrow{margin-bottom:16px}
.ghead h1{font-family:var(--display);font-weight:800;font-size:clamp(40px,8vw,110px);line-height:.92;letter-spacing:-.02em}
.ghead .sub{display:flex;gap:14px;align-items:center;color:var(--soft);font-size:13px;margin-top:14px}
.ghead .pill{font-family:var(--mono);padding:6px 13px;border:1px solid var(--line);border-radius:100px;text-transform:uppercase;font-size:11px;letter-spacing:.12em;color:var(--cyan)}
.ghead .rule{height:1px;background:var(--line);margin-top:clamp(22px,3vw,36px)}
.gallery{columns:3;column-gap:clamp(14px,1.8vw,24px);padding:clamp(20px,3vw,36px) 0 clamp(40px,6vw,80px)}
.gallery figure{break-inside:avoid;margin-bottom:clamp(14px,1.8vw,24px);position:relative;overflow:hidden;cursor:zoom-in;background:var(--surface);border:1px solid var(--line)}
.gallery figure::after{content:"";position:absolute;inset:0;background:var(--cm);opacity:0;mix-blend-mode:soft-light;transition:opacity .5s}
.gallery figure:hover::after{opacity:.22}
.gallery img{transition:transform 1s var(--ease)}
.gallery figure:hover img{transform:scale(1.05)}
.nextprev{display:flex;justify-content:space-between;border-top:1px solid var(--line);padding:clamp(26px,4vw,48px) 0}
.nextprev .lbl{font-family:var(--mono);font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--muted)}
.nextprev .nm{font-family:var(--display);font-weight:700;font-size:clamp(20px,3vw,32px)}
.nextprev a:last-child{text-align:right}
.nextprev a:hover .nm{color:var(--cyan)}

/* lightbox */
.lb{position:fixed;inset:0;z-index:1000;background:rgba(8,11,14,.97);display:flex;align-items:center;justify-content:center;opacity:0;visibility:hidden;transition:opacity .4s,visibility .4s}
.lb.on{opacity:1;visibility:visible}
.lb img{max-width:88vw;max-height:84vh;width:auto;height:auto;object-fit:contain;transform:scale(.97);transition:transform .4s var(--ease);box-shadow:0 40px 100px -30px #000}
.lb.on img{transform:scale(1)}
.lb .x{position:absolute;top:12px;right:14px;color:#fff;font-size:26px;line-height:1;cursor:pointer;opacity:.8;padding:12px;-webkit-tap-highlight-color:transparent;transition:opacity .3s,transform .35s var(--ease)}
.lb .x:hover{opacity:1;transform:rotate(90deg)}
.lb .nav{position:absolute;top:50%;transform:translateY(-50%);color:#fff;font-size:30px;cursor:pointer;padding:20px;opacity:.7;user-select:none;transition:opacity .3s,transform .35s var(--ease)}
.lb .nav:hover{opacity:1;transform:translateY(-50%) scale(1.18)}.lb .prev{left:6px}.lb .next{right:6px}
.lb .count{position:absolute;bottom:22px;left:0;right:0;text-align:center;color:rgba(255,255,255,.75);font-family:var(--mono);font-size:12px;letter-spacing:.2em}

/* about + form */
.intro{padding:clamp(116px,15vh,168px) 0 clamp(30px,4vw,52px)}
.intro .eyebrow{margin-bottom:16px}
.intro h1{font-family:var(--display);font-weight:800;font-size:clamp(40px,7vw,92px);line-height:.94;letter-spacing:-.02em}
.intro p{max-width:60ch;margin-top:16px;color:var(--soft);font-size:clamp(15px,1.5vw,18px)}
.exif{font-family:var(--mono);font-size:12px;letter-spacing:.16em;text-transform:uppercase;color:var(--muted);margin-top:24px}
.agrid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(30px,5vw,76px);align-items:start;padding-bottom:clamp(56px,8vw,110px)}
.portrait{aspect-ratio:4/3;border:1px solid var(--line);overflow:hidden;margin-bottom:24px;position:relative}
.who{font-family:var(--display);font-weight:700;font-size:clamp(24px,2.6vw,32px);margin-bottom:16px}
.bullets{list-style:none;display:flex;flex-direction:column;gap:14px}
.bullets li{display:flex;gap:14px;font-size:clamp(15px,1.4vw,17px)}
.bullets li::before{content:"";width:9px;height:9px;margin-top:8px;flex:0 0 auto;background:var(--cm)}
.formcard{background:var(--bg2);border:1px solid var(--line);padding:clamp(24px,3vw,40px)}
.formcard h2{font-family:var(--display);font-weight:700;font-size:clamp(22px,2.4vw,30px);margin-bottom:8px}
.formcard .sub{color:var(--soft);font-size:14px;margin-bottom:24px}
.field{margin-bottom:18px}
label{display:block;font-family:var(--mono);font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:var(--soft);margin-bottom:8px}
label .req{color:var(--pink)}
input,textarea{width:100%;background:var(--surface);border:1px solid var(--line);color:var(--ink);padding:13px 15px;font-family:var(--sans);font-size:16px;min-height:48px;transition:border-color .3s,box-shadow .3s}
input:focus,textarea:focus{outline:none;border-color:var(--cyan);box-shadow:0 0 0 3px rgba(52,214,219,.16)}
textarea{min-height:138px;resize:vertical;line-height:1.55}
.hp{position:absolute;left:-9999px}
.btn{width:100%;margin-top:6px;min-height:50px;border:none;cursor:pointer;background:var(--cm);color:#08272A;font-family:var(--display);font-weight:700;font-size:15px;transition:transform .35s var(--ease),box-shadow .35s}
.btn:hover{transform:translateY(-2px);box-shadow:0 14px 36px -14px rgba(52,214,219,.55)}
.btn:active{transform:translateY(0) scale(.985);transition-duration:.12s}
.ok{margin-top:16px;padding:13px 15px;border:1px solid rgba(52,214,219,.5);background:rgba(52,214,219,.08);color:var(--cyan);font-family:var(--mono);font-size:13px}
.err{margin-top:14px;color:var(--pink);font-size:13px}
.direct{display:flex;flex-direction:column;gap:12px;margin-top:24px;padding-top:22px;border-top:1px solid var(--line)}
.direct a{display:flex;justify-content:space-between;font-family:var(--mono);font-size:13px;color:var(--soft)}
.direct a:hover{color:var(--cyan)}

/* footer */
footer.site{position:relative;border-top:1px solid var(--line);overflow:hidden;margin-top:40px}
footer.site::before{content:"";position:absolute;left:0;right:0;bottom:0;height:38%;z-index:0;opacity:.5;
  background:linear-gradient(transparent,rgba(52,214,219,.08)),repeating-linear-gradient(90deg,rgba(52,214,219,.10) 0 1px,transparent 1px 8%);
  transform:perspective(460px) rotateX(60deg);transform-origin:bottom}
.foot{position:relative;z-index:1;display:grid;grid-template-columns:1.4fr 1fr;gap:40px;padding:clamp(56px,8vw,110px) 0}
.foot h3{font-family:var(--display);font-weight:700;font-size:clamp(34px,6vw,76px);line-height:.95;letter-spacing:-.02em}
.foot-links{display:flex;flex-direction:column;gap:14px;justify-content:flex-end}
.foot-links a{font-family:var(--mono);font-size:13px;padding:10px 0;border-bottom:1px solid var(--line);display:flex;justify-content:space-between;transition:.3s}
.foot-links a:hover{padding-left:8px;color:var(--cyan)}
.foot-bottom{position:relative;z-index:1;display:flex;justify-content:space-between;padding:22px 0;border-top:1px solid var(--line);font-family:var(--mono);font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--muted)}

.reveal{opacity:0;transform:translateY(26px);transition:opacity .9s var(--ease),transform .9s var(--ease)}
.reveal.in{opacity:1;transform:none}

/* motion: entrance choreography + feedback */
@keyframes riseIn{from{opacity:0;transform:translateY(24px)}to{opacity:1;transform:none}}
@keyframes heroSettle{from{transform:scale(1.06)}to{transform:scale(1)}}
@keyframes ruleIn{from{transform:scaleX(0)}to{transform:scaleX(1)}}
@keyframes okIn{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}
@keyframes errShake{0%,100%{transform:translateX(0)}20%{transform:translateX(-5px)}40%{transform:translateX(5px)}60%{transform:translateX(-3px)}80%{transform:translateX(3px)}}
/* hero (home only) */
.has-hero .hero .bg img{animation:heroSettle 1.8s var(--ease) both}
.has-hero .hero-eyebrow{animation:riseIn .7s var(--ease) both .15s}
.has-hero .hero-eyebrow .rule{transform-origin:left;animation:ruleIn .7s var(--ease) both .15s}
.has-hero .hero h1{animation:riseIn .85s var(--ease) both .28s}
.has-hero .hero .lead{animation:riseIn .85s var(--ease) both .44s}
/* mobile menu links cascade in */
.mobilenav.on li{animation:riseIn .5s var(--ease) both}
.mobilenav.on li:nth-child(2){animation-delay:.06s}
.mobilenav.on li:nth-child(3){animation-delay:.12s}
.mobilenav.on li:nth-child(4){animation-delay:.18s}
/* contact feedback */
.ok{animation:okIn .5s var(--ease) both}
.err{animation:errShake .45s ease both}

@media(max-width:880px){
  nav ul{display:none}.menu-btn{display:inline-flex}
  .masonry,.gallery,.coll{columns:2}
  .foot,.agrid{grid-template-columns:1fr;gap:28px}
  .hero .scrollcue{display:none}
}
@media(max-width:540px){
  .masonry,.gallery,.coll{columns:1}
  .nextprev{flex-direction:column;gap:22px}.nextprev a:last-child{text-align:left}
}
.legal{max-width:74ch;color:var(--soft);padding-bottom:clamp(56px,8vw,110px);line-height:1.75}
.legal h2{font-family:var(--display);color:var(--ink);font-weight:700;font-size:clamp(19px,2.2vw,25px);margin:34px 0 10px}
.legal h3{color:var(--ink);font-size:16px;margin:22px 0 6px}
.legal p{margin:0 0 13px}
.legal a{color:var(--cyan);word-break:break-word}
.legal strong{color:var(--ink);font-weight:600}
.legal .upd{font-family:var(--mono);font-size:12px;color:var(--muted);margin-top:26px}
.foot-bottom a{color:var(--soft)}.foot-bottom a:hover{color:var(--cyan)}
@media(hover:none){.card:active,.gallery figure:active{transform:scale(.99)}}
@media(prefers-reduced-motion:reduce){*{transition:none!important;animation:none!important}}
