/* =====================================================
LOCAL FONTS
===================================================== */

@font-face{
font-family:'Inter';
src:url('../fonts/inter-regular.woff2') format('woff2');
font-weight:400;
font-style:normal;
font-display:swap;
}

@font-face{
font-family:'Inter';
src:url('../fonts/inter-medium.woff2') format('woff2');
font-weight:500;
font-style:normal;
font-display:swap;
}

@font-face{
font-family:'Inter';
src:url('../fonts/inter-semibold.woff2') format('woff2');
font-weight:600;
font-style:normal;
font-display:swap;
}

@font-face{
font-family:'Inter';
src:url('../fonts/inter-bold.woff2') format('woff2');
font-weight:700;
font-style:normal;
font-display:swap;
}



/* =====================================================
DESIGN SYSTEM
===================================================== */

:root{

--accent:#f2c94c;
--bg:#050505;

--section-overlay:rgba(0,0,0,0.24);

--max-width:1100px;

--ease:cubic-bezier(.2,.65,.25,1);

--text:#ffffff;
--text-dim:#d0d0d0;

/* Axis jetzt relativ zur Breite */
--axis-x:600px;

}



/* =====================================================
RESET
===================================================== */

*{
margin:0;
padding:0;
box-sizing:border-box;
}

html{
scroll-behavior:smooth;
}

body{
font-family:'Inter',sans-serif;
background:var(--bg);
color:var(--text);
line-height:1.6;
letter-spacing:0.25px;
overflow-x:hidden;
}



/* =====================================================
SEO HIDDEN H1
===================================================== */

.seo-heading{
position:absolute;
left:-9999px;
top:auto;
width:1px;
height:1px;
overflow:hidden;
}



/* =====================================================
LINKS
===================================================== */

a{
color:var(--text);
text-decoration:none;
border-bottom:1px solid rgba(255,255,255,0.15);
transition:color .2s var(--ease), border-color .2s var(--ease);
}

a:hover{
color:var(--accent);
border-color:var(--accent);
}

a[href^="tel"],
a[href^="mailto"]{
border-bottom:none;
}



/* =====================================================
LISTS
===================================================== */

ul{
padding-left:22px;
margin-top:12px;
}

li{
margin-bottom:10px;
line-height:1.6;
}



/* =====================================================
SERVICES GRID
===================================================== */

.services{
display:grid;
grid-template-columns:repeat(2,1fr);
gap:40px;
margin-top:50px;
}

.service{
position:relative;
padding:26px 0;
transition:transform .25s var(--ease);
}

.service-title{
font-size:1.15rem;
font-weight:600;
margin-bottom:8px;
position:relative;
display:inline-block;
}

.service-desc{
color:var(--text-dim);
line-height:1.6;
font-size:0.95rem;
}

.service-title::after{
content:"";
position:absolute;
left:0;
bottom:-6px;
width:0%;
height:2px;
background:var(--accent);
transition:width .25s var(--ease);
}

.service:hover .service-title::after{
width:100%;
}

.service:hover{
transform:translateY(-3px);
}



/* =====================================================
PROGRESS BAR
===================================================== */

.progress{
position:fixed;
top:0;
left:0;
height:2px;
width:0%;
background:var(--accent);
z-index:2000;
}



/* =====================================================
BACKGROUND
===================================================== */

.background{
position:fixed;
inset:0;
z-index:-6;
background:url("../bg-pics/hero-1920-desktop-perf.webp") center/cover no-repeat;
transform:scale(1.05);
transition:transform 3s ease;
}

body.loaded .background{
transform:scale(1);
}



/* =====================================================
GRID OVERLAY
===================================================== */

.grid-overlay{
position:fixed;
inset:0;
z-index:-5;
pointer-events:none;

background-image:
linear-gradient(rgba(255,255,255,0.02) 1px, transparent 1px),
linear-gradient(90deg, rgba(255,255,255,0.02) 1px, transparent 1px);

background-size:80px 80px;
opacity:.7;
}



/* =====================================================
CANVAS
===================================================== */

#hero-canvas{
position:fixed;
top:0;
left:0;
width:100vw;
height:100vh;
z-index:-4;
pointer-events:none;
opacity:0.45;
}



/* =====================================================
SCANLINE
===================================================== */

.scanline{
position:fixed;
top:-20%;
left:0;
width:100%;
height:2px;
background:linear-gradient(90deg,transparent,var(--accent),transparent);
opacity:0.12;
animation:scan 45s linear infinite;
z-index:-3;
}

@keyframes scan{
0%{transform:translateY(0);}
100%{transform:translateY(150vh);}
}



/* =====================================================
DEPTH OVERLAY
===================================================== */

.overlay{
position:fixed;
inset:0;
z-index:-2;

background:
radial-gradient(circle at 38% 40%, transparent 40%, rgba(0,0,0,0.55) 100%),
linear-gradient(
to bottom,
rgba(0,0,0,0.45) 0%,
rgba(0,0,0,0.2) 35%,
rgba(0,0,0,0.65) 100%
);
}



/* =====================================================
NAVIGATION
===================================================== */

nav{
position:fixed;
top:0;
width:100%;
backdrop-filter:blur(6px);
-webkit-backdrop-filter:blur(6px);
background:rgba(0,0,0,0.55);
transition:all .35s var(--ease);
z-index:1000;
}

nav.scrolled{
background:rgba(0,0,0,0.75);
border-bottom:1px solid rgba(255,255,255,0.06);
}

.nav-inner{
max-width:1200px;
margin:auto;
padding:14px 30px;
display:flex;
align-items:center;
justify-content:center;
position:relative;
}

.nav-brand{
position:absolute;
left:30px;
}

.nav-brand img{
height:28px;
}

.nav-menu{
display:flex;
gap:34px;
list-style:none;
}

.nav-menu a{
border-bottom:none;
position:relative;
}

.nav-menu a::after{
content:"";
position:absolute;
left:0;
bottom:-4px;
width:0%;
height:1px;
background:var(--accent);
transition:width .25s var(--ease);
}

.nav-menu a:hover::after{
width:100%;
box-shadow:0 0 6px rgba(242,201,76,0.6);
}

.nav-menu a.active{
color:var(--accent);
}

.nav-menu a.active::after{
width:100%;
}

.nav-toggle{
display:none;
flex-direction:column;
gap:5px;
background:none;
border:none;
cursor:pointer;
position:absolute;
right:30px;
}

.nav-toggle span{
width:22px;
height:2px;
background:#fff;
display:block;
}



/* =====================================================
PAGE HERO
===================================================== */

.page-hero{
min-height:45vh;
display:flex;
align-items:center;
justify-content:center;
text-align:center;
position:relative;
padding:160px 20px 80px;
}

.hero-inner{
width:clamp(900px,72vw,1400px);
margin:auto;

padding-left:clamp(20px,4vw,80px);
}

.page-hero h1{
font-size:clamp(2.6rem,5vw,3.6rem);
font-weight:600;
margin-bottom:12px;
}

.page-subtitle{
color:var(--text-dim);
letter-spacing:0.06em;
font-size:0.95rem;
}



/* =====================================================
HERO
===================================================== */

.hero{

min-height:100vh;

display:grid;

grid-template-columns:520px 1fr;

gap:clamp(60px,6vw,120px);

align-items:center;

position:relative;

padding:clamp(120px,10vh,180px) 6vw;

width:100%;

}



.hero-inner{

width:clamp(900px,72vw,1400px);

margin:auto;

}



/* Axis */

.hero-axis{
position:absolute;
top:0;
bottom:0;
left:var(--axis-x);
width:1px;
background:linear-gradient(
to bottom,
transparent,
rgba(242,201,76,0.35),
transparent
);
opacity:0.6;
pointer-events:none;
}



/* Glow */

.hero-glow{
position:absolute;
top:32%;
left:260px;
transform:translateX(-50%);
width:700px;
height:420px;
background:radial-gradient(circle, rgba(242,201,76,0.08), transparent 70%);
pointer-events:none;
}



/* =====================================================
LOGO
===================================================== */

.logo{
width:100%;
max-width:480px;
margin-bottom:36px;
opacity:0;
transform:translateY(20px);
filter:blur(6px);
transition:1.4s var(--ease);
}

body.loaded .logo{
opacity:1;
transform:none;
filter:none;
}



/* =====================================================
TEXT
===================================================== */

.subtitle{
font-size:1.22rem;
color:#e6e6e6;
line-height:1.7;
margin-bottom:20px;
opacity:0;
transform:translateY(20px);
filter:blur(6px);
transition:1.6s var(--ease);
}

body.loaded .subtitle{
opacity:1;
transform:none;
filter:none;
}

.hero-meta{
font-size:0.95rem;
color:#bdbdbd;
letter-spacing:0.08em;

max-width:440px;

line-height:1.6;

margin-bottom:44px;

opacity:0;
transform:translateY(20px);
transition:1.8s var(--ease);
}

body.loaded .hero-meta{
opacity:1;
transform:none;
}

/* =====================================================
SECTIONS
===================================================== */

section{
padding:150px 20px;
background:var(--section-overlay);
position:relative;
}

section::before{
content:"";
position:absolute;
top:0;
left:0;
width:100%;
height:1px;
background:rgba(255,255,255,0.06);
}

.container{
max-width:var(--max-width);
margin:auto;
}



/* =====================================================
SECTION TITLES
===================================================== */

.section-title{
display:flex;
align-items:center;
justify-content:center;
gap:20px;
margin-bottom:64px;
}

.section-line{
flex:1;
height:1px;
background:rgba(255,255,255,0.08);
max-width:160px;
}

.section-title h2{
font-size:2.4rem;
font-weight:600;
letter-spacing:0.03em;
}



/* =====================================================
CONTACT
===================================================== */

.contact{
text-align:center;
}

.contact a{
border-bottom:none;
}



/* =====================================================
FOOTER
===================================================== */

footer{
padding:40px;
text-align:center;
background:rgba(0,0,0,0.55);
font-size:0.85rem;
}

footer a{
border-bottom:none;
}

footer a:hover{
color:var(--accent);
}



/* =====================================================
REVEAL
===================================================== */

.reveal{
opacity:0;
transform:translateY(30px);
transition:0.8s var(--ease);
}

.reveal.active{
opacity:1;
transform:none;
}

/* =====================================================
UTILITIES
===================================================== */

.text-center{
text-align:center;
}

.narrow{
max-width:780px;
margin:auto;
}

.text-dim{
color:var(--text-dim);
}



/* =====================================================
MOBILE
===================================================== */

@media (max-width:900px){

.background{
background-image:url("../bg-pics/hero-mobile-portrait.webp");
background-position:38% center;
}

.hero{
grid-template-columns:1fr;
padding:120px 20px 100px;
text-align:center;
}

.hero-inner{
width:100%;
max-width:520px;
margin:auto;
}

.hero-axis,
.hero-glow{
display:none;
}

.logo{
max-width:320px;
}

section{
padding:110px 20px;
}

.nav-inner{
justify-content:space-between;
}

.nav-toggle{
display:flex;
}

.nav-menu{
position:absolute;
top:100%;
left:0;
width:100%;
flex-direction:column;
background:rgba(0,0,0,0.92);
padding:30px 0;
gap:18px;
opacity:0;
pointer-events:none;
transform:translateY(-10px);
transition:0.25s var(--ease);
}

.nav-menu.open{
opacity:1;
pointer-events:auto;
transform:none;
}

.nav-menu li{
text-align:center;
}

.services{
grid-template-columns:1fr;
gap:30px;
}

}