/* ==========================================================================
   APART COMPASS — Dark Cinematic
   ========================================================================== */

:root{
  --bg:           #07091A;
  --bg-soft:      #0B1130;
  --bg-card:      #0F1733;
  --navy:         #1A2A4F;
  --navy-deep:    #060A1F;
  --gold:         #C7A86B;
  --gold-bright:  #E2C28A;
  --gold-dim:     #8E7945;
  --ink:          #F4EFE6;
  --ink-soft:     #B6BBCB;
  --ink-mute:     #7A819A;
  --line:         rgba(199,168,107,.22);
  --line-soft:    rgba(244,239,230,.08);

  --serif:        "Cormorant Garamond", "Times New Roman", serif;
  --sans:         "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", system-ui, sans-serif;

  --max:          1280px;
  --pad:          clamp(20px, 4vw, 48px);

  --radius:       18px;
  --radius-sm:    10px;

  --ease:         cubic-bezier(.2,.7,.2,1);
  --ease-soft:    cubic-bezier(.4,.0,.2,1);
}

*{box-sizing:border-box}
html,body{margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  font-family:var(--sans);
  font-weight:300;
  color:var(--ink-soft);
  background:var(--bg);
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale;
  overflow-x:hidden;
}

/* Sublte filmic grain overlay across whole page */
body::before{
  content:"";
  position:fixed;inset:0;
  pointer-events:none;
  z-index:1000;
  opacity:.05;
  mix-blend-mode:overlay;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='160' height='160'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2' stitchTiles='stitch'/></filter><rect width='100%25' height='100%25' filter='url(%23n)' opacity='0.6'/></svg>");
}

img,svg{display:block;max-width:100%}
a{color:inherit;text-decoration:none}
button{font:inherit;color:inherit;background:none;border:0;cursor:pointer}
ul{list-style:none;margin:0;padding:0}

.container{max-width:var(--max);margin:0 auto;padding:0 var(--pad)}

/* ==========================================================================
   Typography
   ========================================================================== */
h1,h2,h3,h4{
  font-family:var(--serif);
  font-weight:500;
  color:var(--ink);
  letter-spacing:-.01em;
  line-height:1.05;
  margin:0;
}
h1{font-size:clamp(2.6rem, 6.2vw, 5.6rem)}
h2{font-size:clamp(2.1rem, 4.6vw, 3.8rem)}
h3{font-size:clamp(1.25rem, 1.6vw, 1.55rem); line-height:1.2}
em{font-style:italic; color:var(--gold-bright); font-weight:400}

p{margin:0 0 .9em}

.eyebrow{
  display:inline-flex;align-items:center;gap:.7rem;
  font-family:var(--sans);
  font-size:.72rem;font-weight:500;
  letter-spacing:.28em;text-transform:uppercase;
  color:var(--gold);
}
.eyebrow::before{
  content:"";width:34px;height:1px;background:var(--gold);opacity:.7;
}
.eyebrow--light{color:var(--gold-bright)}
.eyebrow--light::before{background:var(--gold-bright)}

/* ==========================================================================
   Buttons
   ========================================================================== */
.btn{
  position:relative;
  display:inline-flex;align-items:center;gap:.6rem;
  padding:.95rem 1.5rem;
  font-family:var(--sans);
  font-size:.85rem;font-weight:500;
  letter-spacing:.18em;text-transform:uppercase;
  border:1px solid transparent;
  border-radius:999px;
  transition:all .45s var(--ease);
  overflow:hidden;
  isolation:isolate;
}
.btn--xl{padding:1.15rem 1.85rem;font-size:.92rem}
.btn--gold{
  background:linear-gradient(180deg, var(--gold-bright), var(--gold));
  color:#0a0d1f;
  box-shadow:
    0 18px 40px -18px rgba(199,168,107,.6),
    inset 0 1px 0 rgba(255,255,255,.4);
}
.btn--gold::after{
  content:"";position:absolute;inset:0;z-index:-1;
  background:linear-gradient(120deg, transparent 20%, rgba(255,255,255,.55) 50%, transparent 80%);
  transform:translateX(-110%);
  transition:transform .9s var(--ease);
}
.btn--gold:hover{transform:translateY(-2px);box-shadow:0 24px 60px -18px rgba(199,168,107,.7), inset 0 1px 0 rgba(255,255,255,.5)}
.btn--gold:hover::after{transform:translateX(110%)}

.btn--ghost{
  background:transparent;
  color:var(--ink);
  border-color:rgba(244,239,230,.35);
}
.btn--ghost::before{
  content:"";position:absolute;inset:0;z-index:-1;
  background:var(--gold);transform:scaleX(0);transform-origin:left;
  transition:transform .55s var(--ease);
}
.btn--ghost:hover{color:#0a0d1f;border-color:var(--gold)}
.btn--ghost:hover::before{transform:scaleX(1)}

/* ==========================================================================
   Header
   ========================================================================== */
.site-header{
  position:fixed; top:0; left:0; right:0;
  z-index:50;
  transition:all .35s var(--ease);
  background:linear-gradient(180deg, rgba(7,9,26,.55), rgba(7,9,26,0));
}
.site-header.is-scrolled{
  background:rgba(7,9,26,.78);
  backdrop-filter:saturate(140%) blur(14px);
  -webkit-backdrop-filter:saturate(140%) blur(14px);
  border-bottom:1px solid var(--line-soft);
}
.header__inner{
  display:flex;align-items:center;justify-content:space-between;gap:1.2rem;
  padding:1.05rem 0;
  transition:padding .35s var(--ease);
}
.is-scrolled .header__inner{padding:.7rem 0}

/* Brand */
.brand{display:inline-flex;align-items:center;gap:.8rem;color:var(--ink)}
.brand__mark{
  width:42px;height:42px;
  display:grid;place-items:center;
  color:var(--gold);
  border:1px solid var(--gold);border-radius:50%;
  transition:transform .8s var(--ease);
}
.brand:hover .brand__mark{transform:rotate(360deg)}
.icon--compass{width:24px;height:24px}
.brand__name{
  font-family:var(--serif);
  display:flex;flex-direction:column;line-height:.92;
}
.brand__line1{font-size:.78rem; letter-spacing:.5em; color:var(--gold); font-weight:500}
.brand__line2{font-size:1.35rem; letter-spacing:.18em; color:var(--ink); font-weight:600}

/* Nav */
.nav > ul{display:flex;gap:1.85rem;align-items:center}
.nav a{
  position:relative;
  font-family:var(--sans);font-size:.82rem;font-weight:400;
  letter-spacing:.18em;text-transform:uppercase;
  color:var(--ink); opacity:.85;
  padding:.45rem 0;
  transition:color .25s ease, opacity .25s ease;
}
.nav a:hover{opacity:1;color:var(--gold-bright)}
.nav a::after{
  content:"";position:absolute;left:0;right:0;bottom:0;height:1px;
  background:var(--gold);transform:scaleX(0);transform-origin:right;
  transition:transform .4s var(--ease);
}
.nav a:hover::after{transform:scaleX(1);transform-origin:left}

.has-sub{position:relative}
.subnav{
  position:absolute;top:100%;left:-1rem;
  min-width:220px;padding:.8rem 1rem;
  background:rgba(7,9,26,.95);
  border:1px solid var(--line-soft);
  border-radius:var(--radius-sm);
  backdrop-filter:blur(10px);
  display:flex;flex-direction:column;gap:.3rem;
  opacity:0;visibility:hidden;transform:translateY(8px);
  transition:all .25s var(--ease);
  pointer-events:none;
}
.has-sub:hover .subnav,.has-sub:focus-within .subnav{
  opacity:1;visibility:visible;transform:translateY(0);pointer-events:auto;
}
.subnav a{padding:.4rem 0;letter-spacing:.1em;font-size:.78rem}

/* Phone CTA */
.phone-cta{
  display:inline-flex;align-items:center;gap:.55rem;
  padding:.7rem 1.1rem;
  border:1px solid var(--gold);border-radius:999px;
  font-family:var(--sans);font-weight:500;font-size:.82rem;
  letter-spacing:.08em;
  color:var(--gold);
  transition:all .35s var(--ease);
}
.phone-cta:hover{background:var(--gold);color:#0a0d1f}
.phone-cta__icon{display:inline-grid;place-items:center}

/* Burger */
.burger{display:none;width:36px;height:36px;flex-direction:column;gap:6px;align-items:center;justify-content:center}
.burger span{display:block;width:22px;height:2px;background:var(--ink);transition:transform .35s var(--ease), opacity .25s}
.burger.is-open span:nth-child(1){transform:translateY(8px) rotate(45deg)}
.burger.is-open span:nth-child(2){opacity:0}
.burger.is-open span:nth-child(3){transform:translateY(-8px) rotate(-45deg)}

/* ==========================================================================
   Hero
   ========================================================================== */
.hero{
  position:relative;
  min-height:100vh;min-height:100svh;
  display:flex;align-items:center;
  overflow:hidden;
  isolation:isolate;
}
.hero__media{
  position:absolute;inset:-3% -3%;
  background-size:cover;background-position:center;
  z-index:-3;
  will-change:transform;
}
.hero__veil{
  position:absolute;inset:0;z-index:-2;
  background:
    linear-gradient(180deg, rgba(7,9,26,.55) 0%, rgba(7,9,26,.35) 35%, rgba(7,9,26,.85) 100%),
    linear-gradient(105deg, rgba(7,9,26,.7) 0%, rgba(7,9,26,0) 60%);
}
.hero__vignette{
  position:absolute;inset:0;z-index:-1;
  background:radial-gradient(ellipse at center, transparent 30%, rgba(7,9,26,.55) 100%);
}
.hero__inner{
  position:relative;z-index:2;
  padding:9rem 0 6rem;
  max-width:920px;
}
.hero__title{
  margin:1.2rem 0 1.2rem;
  letter-spacing:-.02em;
  font-weight:500;
}
.hero__sub{
  font-size:clamp(1rem, 1.3vw, 1.18rem);
  color:rgba(244,239,230,.85);
  max-width:640px;
  margin:0 0 2rem;
}
.hero__cta{display:flex;gap:.9rem;flex-wrap:wrap}

.hero__scroll{
  position:absolute;left:50%;bottom:2.2rem;transform:translateX(-50%);
  width:1px;height:60px;
  display:block;background:rgba(244,239,230,.3);
  z-index:3;
}
.hero__scroll span{
  position:absolute;top:0;left:-1px;width:3px;height:18px;background:var(--gold);
  animation:scrolldown 2.4s var(--ease) infinite;
}
@keyframes scrolldown{
  0%{top:0;opacity:0}
  20%{opacity:1}
  100%{top:60px;opacity:0}
}

/* Ken Burns */
.kenburns{
  animation:kenburns 24s ease-in-out infinite alternate;
  transform-origin:50% 50%;
}
.kenburns--slow{animation-duration:32s}
@keyframes kenburns{
  0%   { transform: scale(1.04) translate3d(0,0,0); }
  100% { transform: scale(1.16) translate3d(-2%, -1.5%, 0); }
}

/* ==========================================================================
   Section common
   ========================================================================== */
section{position:relative}
.section-head{margin-bottom:3rem;max-width:760px}
.section-head h2{margin:1rem 0 .9rem}
.section-sub{font-size:1.05rem;color:var(--ink-soft)}
.section-head--small h2{font-size:clamp(1.6rem, 3vw, 2.4rem)}

/* ==========================================================================
   Values
   ========================================================================== */
.values{padding:7rem 0 5rem; background:linear-gradient(180deg, var(--bg) 0%, var(--bg-soft) 100%)}
.values__row{
  display:grid;
  grid-template-columns:repeat(3, 1fr);
  gap:0;
  border-top:1px solid var(--line);
  border-bottom:1px solid var(--line);
}
.value{
  padding:3rem 2rem;
  position:relative;
}
.value + .value{border-left:1px solid var(--line)}
.value__num{
  font-family:var(--serif); font-size:.9rem; font-style:italic; color:var(--gold);
  letter-spacing:.1em;
}
.value h3{margin:.5rem 0 .8rem; font-family:var(--serif); font-size:1.8rem}
.value p{font-size:.98rem; color:var(--ink-soft); margin:0}

/* ==========================================================================
   Categories
   ========================================================================== */
.categories{padding:7rem 0 8rem; background:var(--bg-soft)}
.cards{
  display:grid;
  grid-template-columns:repeat(4, 1fr);
  gap:1.25rem;
}
.card{
  position:relative;
  display:block;
  overflow:hidden;
  border-radius:var(--radius);
  background:var(--bg-card);
  aspect-ratio:3/4;
  isolation:isolate;
  border:1px solid var(--line-soft);
  transition:transform .55s var(--ease), border-color .55s var(--ease);
}
.card--wide{
  grid-column:span 2;
  aspect-ratio:16/10;
}
.card__media{
  position:absolute;inset:0;z-index:-2;
  background-size:cover;background-position:center;
  transform:scale(1.04);
  transition:transform 1.4s var(--ease), filter .8s var(--ease);
  filter:saturate(.95) brightness(.85);
}
.card__veil{
  position:absolute;inset:0;z-index:-1;
  background:
    linear-gradient(180deg, rgba(7,9,26,0) 30%, rgba(7,9,26,.95) 95%),
    linear-gradient(180deg, rgba(7,9,26,.45), rgba(7,9,26,0) 50%);
  transition:opacity .6s var(--ease);
}
.card__body{
  position:absolute; left:0; right:0; bottom:0;
  padding:1.8rem 1.6rem 1.6rem;
  color:var(--ink);
}
.card__tag{
  display:inline-block;
  font-family:var(--sans); font-size:.65rem; font-weight:500;
  letter-spacing:.28em; text-transform:uppercase;
  color:var(--gold);
  padding:.35rem .7rem;
  border:1px solid var(--line);
  border-radius:999px;
  margin-bottom:1rem;
  backdrop-filter:blur(4px);
  background:rgba(7,9,26,.35);
}
.card h3{
  font-family:var(--serif);font-weight:500;
  font-size:clamp(1.4rem, 1.8vw, 1.9rem);
  margin:0 0 .5rem;
  color:var(--ink);
}
.card p{
  font-size:.92rem;color:var(--ink-soft);
  max-width:32ch;
  margin:0 0 1rem;
  opacity:.92;
}
.card__cta{
  display:inline-flex;align-items:center;gap:.5rem;
  font-family:var(--sans);font-size:.78rem;font-weight:500;
  letter-spacing:.22em;text-transform:uppercase;
  color:var(--gold-bright);
  padding-bottom:.35rem;
  border-bottom:1px solid var(--gold);
  transition:gap .35s var(--ease), color .25s ease;
}
.card:hover{transform:translateY(-6px); border-color:var(--line)}
.card:hover .card__media{transform:scale(1.12); filter:saturate(1.05) brightness(.95)}
.card:hover .card__cta{gap:.9rem; color:var(--gold-bright)}

/* ==========================================================================
   About
   ========================================================================== */
.about{
  padding:8rem 0;
  background:
    radial-gradient(ellipse at 80% 20%, rgba(26,42,79,.55) 0%, transparent 60%),
    var(--bg);
}
.about__grid{
  display:grid;
  grid-template-columns:5fr 6fr;
  gap:5rem;
  align-items:center;
}
.about__photo{
  position:relative;margin:0;
  aspect-ratio:4/5;
  border-radius:var(--radius);
  overflow:hidden;
  isolation:isolate;
}
.about__photo::before{
  content:"";position:absolute;inset:18px;border:1px solid var(--gold);
  border-radius:calc(var(--radius) - 8px);z-index:2;pointer-events:none;
  opacity:.55;
}
.about__photo-wrap{
  position:absolute;inset:0;
  background-size:cover;background-position:center top;
  z-index:1;
  filter:saturate(.95) contrast(1.02);
}
.about__photo figcaption{
  position:absolute;left:1.5rem;bottom:1.2rem;z-index:3;
  font-family:var(--serif);font-style:italic;font-size:1rem;
  color:var(--ink);
  background:linear-gradient(180deg, transparent, rgba(7,9,26,.6));
  padding:1.5rem 1.2rem .2rem; margin:0 -1.5rem -1.2rem;
}
.about__text h2{margin:1rem 0 1.4rem}
.about__text p{font-size:1.06rem; line-height:1.75; color:var(--ink-soft); max-width:55ch}
.about__sig{margin-top:2rem; padding-top:1.5rem; border-top:1px solid var(--line)}
.about__sig-name{
  display:block; font-family:var(--serif); font-style:italic;
  font-size:1.8rem; color:var(--gold-bright); letter-spacing:.01em;
}
.about__sig-line{
  display:block; margin-top:.3rem;
  font-family:var(--sans);font-size:.74rem;font-weight:500;
  letter-spacing:.28em; text-transform:uppercase;
  color:var(--ink-mute);
}

/* ==========================================================================
   Services
   ========================================================================== */
.services{padding:7rem 0; background:var(--bg-soft)}
.services__grid{
  display:grid; grid-template-columns:repeat(3,1fr); gap:1.4rem;
}
.service{
  padding:1.6rem; background:var(--bg-card);
  border:1px solid var(--line-soft);
  border-radius:var(--radius);
  transition:transform .45s var(--ease), border-color .45s var(--ease);
}
.service:hover{transform:translateY(-4px); border-color:var(--line)}
.service__img{
  height:170px;border-radius:var(--radius-sm);
  background-size:cover;background-position:center;
  margin-bottom:1.2rem;
  filter:saturate(.9) brightness(.9);
}
.service h3{font-family:var(--serif); font-size:1.4rem; margin:0 0 .5rem; color:var(--ink)}
.service p{margin:0; font-size:.95rem; color:var(--ink-soft)}

/* ==========================================================================
   CTA block
   ========================================================================== */
.cta-block{
  position:relative;
  padding:9rem 0;
  overflow:hidden;
  isolation:isolate;
}
.cta-bg{
  position:absolute;inset:-3%;z-index:-2;
  background-size:cover;background-position:center;
  filter:brightness(.7) saturate(1.05);
  animation:kenburns 28s ease-in-out infinite alternate;
}
.cta-veil{
  position:absolute;inset:0;z-index:-1;
  background:
    linear-gradient(180deg, rgba(7,9,26,.65), rgba(7,9,26,.85)),
    radial-gradient(ellipse at center, transparent 30%, rgba(7,9,26,.5) 100%);
}
.cta-inner{text-align:center; max-width:780px; margin:0 auto}
.cta-inner h2{margin:1rem 0 1rem; color:var(--ink)}
.cta-inner > p{color:rgba(244,239,230,.85); font-size:1.1rem; margin-bottom:2.2rem}
.cta-actions{display:flex; gap:1rem; justify-content:center; flex-wrap:wrap}
.cta-meta{
  margin-top:2rem; font-size:.78rem; letter-spacing:.18em;
  text-transform:uppercase; color:var(--ink-mute);
  display:flex; gap:1rem; justify-content:center; align-items:center; flex-wrap:wrap;
}
.dot{width:4px;height:4px;border-radius:50%;background:var(--gold);display:inline-block}

/* ==========================================================================
   Footer
   ========================================================================== */
.site-footer{
  padding:5rem 0 2rem;
  background:var(--navy-deep);
  color:var(--ink-soft);
  border-top:1px solid var(--line-soft);
}
.footer__grid{
  display:grid;
  grid-template-columns:2fr 1fr 1fr;
  gap:3rem;
  padding-bottom:3rem;
  border-bottom:1px solid var(--line-soft);
}
.footer__brand p{max-width:30ch; margin-top:1rem; font-size:.95rem}
.footer__nav h4, .footer__contact h4{
  font-family:var(--sans); font-size:.7rem; font-weight:500;
  letter-spacing:.3em; text-transform:uppercase;
  color:var(--gold); margin:0 0 1.2rem;
}
.footer__nav ul, .footer__contact ul{display:flex;flex-direction:column;gap:.5rem; margin:0 0 1.8rem}
.footer__nav a, .footer__contact a{
  font-size:.92rem; color:var(--ink-soft); transition:color .25s ease;
}
.footer__nav a:hover, .footer__contact a:hover{color:var(--gold-bright)}
.footer__base{
  padding-top:1.6rem;
  display:flex; gap:1rem; align-items:center; justify-content:center; flex-wrap:wrap;
  font-size:.78rem; letter-spacing:.16em; text-transform:uppercase; color:var(--ink-mute);
}

/* ==========================================================================
   Reveal Animations  (Progressive Enhancement — nur aktiv wenn JS lädt)
   ========================================================================== */
.reveal{opacity:1; transform:none}
html.js .reveal:not(.is-in){
  opacity:0;
  transform:translate3d(0, 28px, 0);
  transition:opacity .95s var(--ease), transform .95s var(--ease);
  transition-delay:calc(var(--i, 0) * 90ms);
  will-change:opacity, transform;
}
html.js .reveal.is-in{
  opacity:1; transform:none;
  transition:opacity .95s var(--ease), transform .95s var(--ease);
  transition-delay:calc(var(--i, 0) * 90ms);
}
html.js .stagger .reveal:not(.is-in){transition-delay:calc(var(--idx, 0) * 110ms)}

@media (prefers-reduced-motion: reduce){
  .reveal{opacity:1; transform:none; transition:none}
  .kenburns, .cta-bg{animation:none}
  .hero__scroll span{animation:none}
}

/* ==========================================================================
   Responsive
   ========================================================================== */
@media (max-width: 1080px){
  .cards{grid-template-columns:repeat(2,1fr)}
  .card--wide{grid-column:span 2}
  .about__grid{grid-template-columns:1fr; gap:3rem}
  .footer__grid{grid-template-columns:1fr 1fr}
}
@media (max-width: 760px){
  .nav, .phone-cta{display:none}
  .burger{display:flex}
  .nav.is-open{
    display:block;
    position:fixed; top:0; left:0; right:0; bottom:0;
    background:rgba(7,9,26,.97); backdrop-filter:blur(20px);
    padding:6rem 2rem 2rem; z-index:40;
  }
  .nav.is-open > ul{flex-direction:column;align-items:flex-start;gap:1.4rem}
  .nav.is-open a{font-size:1.05rem}
  .nav.is-open .subnav{position:static; opacity:1; visibility:visible; transform:none; background:transparent; border:0; padding:.4rem 0 0 1rem; pointer-events:auto}
  .values__row{grid-template-columns:1fr}
  .value + .value{border-left:0; border-top:1px solid var(--line)}
  .cards{grid-template-columns:1fr}
  .card, .card--wide{aspect-ratio:4/5; grid-column:span 1}
  .services__grid{grid-template-columns:1fr}
  .footer__grid{grid-template-columns:1fr; gap:2rem}
  .hero__inner{padding:8rem 0 5rem}
}
