:root{
      --bg: #0b0f14;
      --bg2:#0e141b;
      --card:#0f1721;
      --muted:#9fb0c0;
      --text:#e8eef6;
      --line: rgba(255,255,255,.08);
      --gold:#d7a31b;
      --bronze:#8a6a52;
      --shadow: 0 18px 60px rgba(0,0,0,.45);
      --radius: 18px;
      --radius2: 26px;
      --max: 1120px;
    }

    *{box-sizing:border-box}
    html,body{height:100%}
    body{
      margin:0;
      font-family: Inter, system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
      color:var(--text);
      background:
        radial-gradient(1200px 800px at 18% 10%, rgba(215,163,27,.12), transparent 60%),
        radial-gradient(900px 650px at 85% 25%, rgba(138,106,82,.14), transparent 55%),
        linear-gradient(180deg, var(--bg), var(--bg2));
      overflow-x:hidden;
    }

    a{color:inherit; text-decoration:none}
    .container{max-width:var(--max); margin:0 auto; padding:0 22px}

    /* Topbar */
    .topbar{
      position:sticky; top:0; z-index:50;
      backdrop-filter: blur(10px);
      background: linear-gradient(180deg, rgba(11,15,20,.86), rgba(11,15,20,.55));
      border-bottom: 1px solid var(--line);
    }
    .topbar-inner{
      display:flex; align-items:center; justify-content:space-between;
      padding:14px 0;
      gap:16px;
    }
    .brand{
      display:flex; align-items:center; gap:12px;
      min-width: 220px;
    }
    .brand-badge{
      width:42px; height:42px; border-radius:14px;
      background: linear-gradient(135deg, rgba(215,163,27,.95), rgba(138,106,82,.85));
      box-shadow: 0 10px 30px rgba(215,163,27,.15);
      display:grid; place-items:center;
      border:1px solid rgba(255,255,255,.12);
    }
    .brand-badge span{
      font-weight:800; letter-spacing:.08em;
      color:#0b0f14;
    }
    .brand-title{display:flex; flex-direction:column; line-height:1.1}
    .brand-title strong{font-size:14px; letter-spacing:.02em}
    .brand-title small{color:var(--muted); font-size:12px}

    nav{display:flex; align-items:center; gap:14px}
    nav a{
      padding:10px 10px;
      color: rgba(232,238,246,.88);
      border-radius: 12px;
      transition: .2s ease;
      font-weight: 500;
      font-size: 14px;
    }
    nav a:hover{background: rgba(255,255,255,.06)}
    .cta{
      display:flex; align-items:center; gap:10px;
    }
    .btn{
      display:inline-flex; align-items:center; justify-content:center;
      gap:10px;
      border-radius: 14px;
      padding:10px 14px;
      font-weight:600;
      border:1px solid rgba(255,255,255,.12);
      background: rgba(255,255,255,.04);
      transition: .2s ease;
      white-space:nowrap;
    }
    .btn:hover{transform: translateY(-1px); background: rgba(255,255,255,.07)}
    .btn.primary{
      border-color: rgba(215,163,27,.55);
      background: linear-gradient(135deg, rgba(215,163,27,.95), rgba(138,106,82,.85));
      color:#0b0f14;
    }
    .btn.primary:hover{filter: brightness(1.04);}

    .burger{display:none}
    .mobile-nav{display:none}

    /* Hero */
    .hero{
      padding: 58px 0 22px;
      position:relative;
    }
    .hero-grid{
      display:grid;
      grid-template-columns: 1.15fr .85fr;
      gap: 26px;
      align-items: stretch;
    }
    .hero-card{
      position:relative;
      overflow:hidden;
      border-radius: var(--radius2);
      border: 1px solid var(--line);
      background: rgba(15,23,33,.55);
      box-shadow: var(--shadow);
      min-height: 420px;
    }
    .hero-card .bg-img{
      position:absolute; inset:0;
      background-image:
        linear-gradient(90deg, rgba(11,15,20,.92), rgba(11,15,20,.62) 55%, rgba(11,15,20,.38)),
        url('assets/bagger-gross.jpeg');
      background-size: cover;
      background-position: center;
      transform: scale(1.03);
      filter: saturate(1.05) contrast(1.05);
    }
    .hero-card .content{
      position:relative;
      padding: 30px;
      height:100%;
      display:flex;
      flex-direction:column;
      justify-content:space-between;
      gap: 22px;
    }
    .eyebrow{
      display:inline-flex;
      gap:10px;
      align-items:center;
      font-size: 12px;
      color: rgba(232,238,246,.85);
      letter-spacing:.08em;
      text-transform: uppercase;
      background: rgba(0,0,0,.25);
      border:1px solid rgba(255,255,255,.12);
      padding:8px 12px;
      border-radius: 999px;
      width:fit-content;
    }
    .dot{
      width:8px; height:8px; border-radius:999px;
      background: var(--gold);
      box-shadow: 0 0 18px rgba(215,163,27,.35);
    }
    h1{
      margin:0;
      font-size: clamp(28px, 3.6vw, 44px);
      letter-spacing:-.02em;
      line-height:1.05;
    }
    .lead{
      margin: 12px 0 0;
      color: rgba(232,238,246,.86);
      max-width: 60ch;
      line-height:1.55;
      font-size: 15px;
    }
    .hero-actions{
      display:flex;
      flex-wrap:wrap;
      gap:10px;
      margin-top: 16px;
    }
    .meta{
      display:flex; flex-wrap:wrap; gap:10px;
      margin-top: 18px;
    }
    .pill{
      font-size: 12px;
      color: rgba(232,238,246,.85);
      border:1px solid rgba(255,255,255,.12);
      background: rgba(0,0,0,.22);
      padding: 8px 10px;
      border-radius: 999px;
    }

    .side{
      display:flex;
      flex-direction:column;
      gap: 16px;
    }
    .side-card{
      border-radius: var(--radius2);
      border: 1px solid var(--line);
      background: rgba(15,23,33,.55);
      box-shadow: var(--shadow);
      padding: 18px;
      overflow:hidden;
      position:relative;
    }
    .logos{
      display:grid;
      grid-template-columns: 1fr 1fr;
      gap:12px;
    }
    .logo-tile{
      border-radius: 18px;
      border: 1px solid rgba(255,255,255,.10);
      background: rgba(0,0,0,.22);
      padding: 12px;
      display:flex;
      flex-direction:column;
      gap:8px;
      min-height: 160px;
      justify-content:space-between;
    }
    .logo-tile img{
      width:100%;
      height: 94px;
      object-fit: contain;
      filter: drop-shadow(0 10px 22px rgba(0,0,0,.35));
    }
    .logo-tile strong{font-size: 13px}
    .logo-tile small{color: var(--muted); font-size: 12px}

    .quick{
      display:grid;
      grid-template-columns: 1fr 1fr;
      gap: 10px;
    }
    .quick a{
      display:flex; gap:10px; align-items:center;
      padding: 12px;
      border-radius: 16px;
      border: 1px solid rgba(255,255,255,.10);
      background: rgba(0,0,0,.18);
      transition:.2s ease;
      font-weight: 600;
      font-size: 13px;
      justify-content:center;
    }
    .quick a:hover{background: rgba(255,255,255,.06); transform: translateY(-1px)}
    .icon{
      width:18px; height:18px;
      opacity:.95;
    }

    /* Sections */
    section{padding: 44px 0}
    .section-title{
      display:flex; align-items:flex-end; justify-content:space-between;
      gap:16px;
      margin-bottom: 18px;
    }
    .section-title h2{
      margin:0;
      font-size: 20px;
      letter-spacing:-.02em;
    }
    .section-title p{
      margin:0;
      color: var(--muted);
      font-size: 13px;
      max-width: 58ch;
      line-height:1.5;
    }

    .grid-2{
      display:grid;
      grid-template-columns: 1fr 1fr;
      gap: 16px;
    }
    .card{
      border-radius: var(--radius2);
      border:1px solid var(--line);
      background: rgba(15,23,33,.55);
      box-shadow: var(--shadow);
      padding: 18px;
      position:relative;
      overflow:hidden;
    }
    .card h3{margin:0 0 8px; font-size: 16px}
    .card .sub{color: var(--muted); margin:0 0 12px; font-size: 13px; line-height:1.55}
    ul{margin: 0; padding-left: 18px; color: rgba(232,238,246,.90)}
    li{margin: 6px 0; line-height:1.5}

    .accent{
      position:absolute; inset:-2px; pointer-events:none; opacity:.35;
      background:
        radial-gradient(800px 240px at 18% 0%, rgba(215,163,27,.35), transparent 60%),
        radial-gradient(820px 280px at 85% 20%, rgba(138,106,82,.35), transparent 55%);
      mask-image: linear-gradient(180deg, rgba(0,0,0,.9), transparent 70%);
    }

    /* Materials */
    .chips{
      display:flex; flex-wrap:wrap; gap:10px;
      margin-top: 12px;
    }
    .chip{
      border:1px solid rgba(255,255,255,.10);
      background: rgba(0,0,0,.18);
      padding: 10px 12px;
      border-radius: 999px;
      color: rgba(232,238,246,.9);
      font-size: 13px;
    }

    /* Gallery */
    .gallery{
      display:grid;
      grid-template-columns: repeat(12, 1fr);
      gap: 12px;
    }
    .g{
      border-radius: 18px;
      border:1px solid rgba(255,255,255,.10);
      overflow:hidden;
      background: rgba(0,0,0,.25);
      position:relative;
      cursor:pointer;
      min-height: 160px;
    }
    .g img{
      width:100%; height:100%;
      object-fit: cover;
      transform: scale(1.02);
      transition: transform .25s ease, filter .25s ease;
      filter: contrast(1.02) saturate(1.02);
    }
    .g:hover img{transform: scale(1.05); filter: contrast(1.06) saturate(1.08)}
    .g::after{
      content:'';
      position:absolute; inset:0;
      background: linear-gradient(180deg, transparent, rgba(0,0,0,.45));
      opacity:.8;
    }
    .g span{
      position:absolute; left:12px; bottom:10px;
      font-weight:600;
      font-size: 12px;
      color: rgba(232,238,246,.92);
      z-index:2;
    }
    .g1{grid-column: span 7; min-height: 280px}
    .g2{grid-column: span 5; min-height: 280px}
    .g3,.g4{grid-column: span 6; min-height: 220px}

    /* Contact */
    .contact{
      display:grid;
      grid-template-columns: 1fr 1fr;
      gap: 16px;
      align-items: stretch;
    }
    .info{
      display:grid;
      gap: 10px;
      margin-top: 10px;
    }
    .row{
      display:flex; gap:10px; align-items:flex-start;
      padding: 12px;
      border-radius: 16px;
      border:1px solid rgba(255,255,255,.10);
      background: rgba(0,0,0,.18);
    }
    .row strong{display:block; font-size: 13px}
    .row small{color: var(--muted); display:block; margin-top:2px; font-size: 12px}
    .row a{color: rgba(232,238,246,.95); text-decoration:underline; text-underline-offset:3px}

    .map{
      border-radius: var(--radius2);
      overflow:hidden;
      border:1px solid rgba(255,255,255,.10);
      background: rgba(0,0,0,.18);
      min-height: 320px;
      position:relative;
    }
    .map iframe{border:0; width:100%; height:100%; filter: grayscale(1) contrast(1.05) invert(0.92); opacity:.92}
    .map .overlay{
      position:absolute; inset:0;
      pointer-events:none;
      background: radial-gradient(800px 320px at 20% 0%, rgba(215,163,27,.18), transparent 60%);
      mix-blend-mode: screen;
    }

    /* Footer */
    footer{
      padding: 26px 0 40px;
      border-top: 1px solid var(--line);
      color: var(--muted);
      font-size: 12px;
    }
    .foot{
      display:flex; justify-content:space-between; gap:14px; flex-wrap:wrap;
      align-items:center;
    }

    /* Modal */
    .modal{
      position:fixed; inset:0; z-index:100;
      display:none;
      align-items:center; justify-content:center;
      padding: 22px;
      background: rgba(0,0,0,.72);
      backdrop-filter: blur(8px);
    }
    .modal.open{display:flex}
    .modal .box{
      width: min(1100px, 100%);
      border-radius: 22px;
      overflow:hidden;
      border:1px solid rgba(255,255,255,.12);
      background: rgba(10,14,18,.86);
      box-shadow: 0 40px 120px rgba(0,0,0,.6);
      position:relative;
    }
    .modal img{width:100%; height:auto; display:block}
    .modal .close{
      position:absolute; right:12px; top:12px;
      width:42px; height:42px;
      border-radius: 14px;
      border:1px solid rgba(255,255,255,.14);
      background: rgba(0,0,0,.35);
      color: rgba(232,238,246,.92);
      cursor:pointer;
      display:grid; place-items:center;
      font-size: 20px;
    }

    /* Responsive */
    @media (max-width: 980px){
      .hero-grid{grid-template-columns: 1fr; }
      .hero-card{min-height: 430px}
      .contact{grid-template-columns: 1fr}
      .g1,.g2,.g3,.g4{grid-column: span 12; min-height: 230px}
    }
    @media (max-width: 760px){
      nav{display:none}
      .burger{display:inline-flex}
      .cta .btn{display:none}
      .mobile-nav{
        display:none;
        padding: 0 0 14px;
      }
      .mobile-nav.open{display:block}
      .mobile-nav a{
        display:block;
        padding: 12px 12px;
        border-radius: 14px;
        border:1px solid rgba(255,255,255,.10);
        background: rgba(0,0,0,.18);
        margin-top:10px;
      }
      .logos{grid-template-columns:1fr}
      .quick{grid-template-columns:1fr}
      .grid-2{grid-template-columns:1fr}
    }

    /* Subtle reveal */
    .reveal{opacity:0; transform: translateY(10px); transition: .5s ease}
    .reveal.show{opacity:1; transform:none}

/* --- Extra pages & typography --- */

.page-hero{
  padding: 120px 0 34px;
}
.breadcrumbs{
  font-size: 13px;
  color: var(--muted);
  display:flex; gap:10px; align-items:center;
}
.breadcrumbs a{color:var(--muted)}
.breadcrumbs a:hover{color:var(--text)}
.prose{
  color: rgba(232,238,246,.92);
  line-height: 1.7;
}
.prose h2{margin-top:28px}
.prose h3{margin-top:18px}
.prose p{margin: 10px 0}
.prose ul{margin: 10px 0 10px 18px}
.prose li{margin: 6px 0}
.hr{height:1px;background:var(--line);margin:22px 0}
.toc{
  display:grid;
  gap:10px;
}
.toc a{
  display:flex; align-items:center; justify-content:space-between;
  padding:12px 14px;
  border:1px solid var(--line);
  border-radius: 14px;
  background: rgba(255,255,255,.02);
}
.toc a:hover{border-color: rgba(215,163,27,.35)}
details{
  border:1px solid var(--line);
  border-radius: 16px;
  background: rgba(255,255,255,.02);
  padding: 10px 14px;
}
details + details{margin-top:12px}
summary{
  cursor:pointer;
  font-weight:600;
  list-style:none;
  display:flex; align-items:center; justify-content:space-between;
  padding:10px 2px;
}
summary::-webkit-details-marker{display:none}
summary:after{
  content:"+";
  font-weight:700;
  color: var(--muted);
}
details[open] summary:after{content:"–"}
.footer-links{
  display:flex; flex-wrap:wrap; gap:10px 18px;
}
.footer-links a{color: var(--muted)}
.footer-links a:hover{color: var(--text)}
