:root{ --bg:#0b0d10; --panel:#12161b; --text:#e7eef8; --muted:#b6c2d2; --brand:#ec2b2e; --ink:#1f2730; --ok:#2ecc71; }
    *,*::before,*::after{box-sizing:border-box}
    html{scroll-behavior:smooth}
    body{margin:0;background:linear-gradient(180deg,#0c0f13 0%,var(--bg) 100%);color:var(--text);font:16px/1.6 system-ui,-apple-system,Segoe UI,Roboto,Ubuntu,sans-serif;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}
    a{color:inherit;text-decoration:none}

    /* HEADER */
    header{position:sticky;top:0;z-index:50;background:rgba(11,13,16,.6);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);border-bottom:1px solid #202833;transition:background .3s ease, box-shadow .3s ease}
    header .nav{display:flex;align-items:center;justify-content:space-between;padding:14px 0}
    header.scrolled{background:rgba(11,13,16,.85);box-shadow:0 8px 24px rgba(0,0,0,.35)}
    header.scrolled .nav{padding:8px 0}

    .container{width:min(1200px,92%);margin-inline:auto}
    .brand{display:flex;align-items:center;gap:.9rem}
    .brand img{height:48px;width:auto;display:block}
    .brand-name{font-weight:700;letter-spacing:.06em;text-transform:uppercase;font-size:1.1rem;line-height:1;color:#fff;text-shadow:0 0 10px rgba(236,43,46,.35),0 0 3px rgba(236,43,46,.25)}

    nav ul{display:flex;align-items:center;gap:1.2rem;list-style:none;padding:0;margin:0}
    nav a{padding:.5rem .7rem;border-radius:10px}
    nav a:hover{background:rgba(255,255,255,.06)}

    .ig-link{display:inline-grid;place-items:center;margin-left:.6rem;width:48px;height:48px;border:1px solid #26303c;border-radius:10px;background:rgba(255,255,255,.04);transition:transform .2s ease, box-shadow .2s ease, border-color .2s ease}
    .ig-link svg{width:20px;height:20px;fill:#ec2b2e;filter:drop-shadow(0 0 6px rgba(236,43,46,.36))}
    .ig-link:hover{transform:translateY(-1px);box-shadow:0 8px 22px rgba(236,43,46,.18);border-color:#2e3947}
    .ig-link:hover svg{filter:drop-shadow(0 0 10px rgba(236,43,46,.6));animation:igPulse .6s ease-in-out 1}
    @keyframes igPulse{0%{transform:scale(1)}50%{transform:scale(1.08)}100%{transform:scale(1)}}

    .hamburger{display:none;align-items:center;justify-content:center;width:48px;height:48px;border:1px solid #26303c;border-radius:10px;background:rgba(255,255,255,.04);cursor:pointer}
    .hamburger span{display:block;width:20px;height:2px;background:#e7eef8;margin:3px 0;transition:transform .25s ease, opacity .25s ease}
    .hamburger.active span:nth-child(1){transform:translateY(5px) rotate(45deg)}
    .hamburger.active span:nth-child(2){opacity:0}
    .hamburger.active span:nth-child(3){transform:translateY(-5px) rotate(-45deg)}

    .mobile-nav{display:none;border-top:1px solid #202833;background:rgba(11,13,16,.9);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);padding:.4rem 0}
    .mobile-nav a{display:block;padding:.8rem 4%;border-bottom:1px solid #1b222d}
    .mobile-nav a:last-child{border-bottom:0}
    .mobile-nav.open{display:block}

    .laser-line{position:relative;width:100%;height:3px;background:linear-gradient(90deg,transparent,var(--brand),transparent);box-shadow:0 0 20px var(--brand);animation:laserSweep 4s linear infinite}
    @keyframes laserSweep{0%{opacity:.3;transform:translateX(-20%)}50%{opacity:1;transform:translateX(20%)}100%{opacity:.3;transform:translateX(-20%)}}

    #laserDots{position:fixed;left:0;top:0;width:100vw;height:100vh;z-index:0;pointer-events:none}
    header, main, footer{position:relative;z-index:1}
    main section{scroll-margin-top:84px}

    /* HERO */
    .hero{position:relative;padding:90px 0 70px;overflow:hidden;background:radial-gradient(1200px 520px at 68% 12%, rgba(236,43,46,.08), transparent 45%), radial-gradient(800px 380px at 80% 70%, rgba(236,43,46,.06), transparent 50%)}
    .hero .grid{display:grid;grid-template-columns:1.1fr .9fr;gap:3rem;align-items:center}
    .kicker{color:var(--brand);font-weight:700;letter-spacing:.12em;text-transform:uppercase;font-size:.9rem}
    h1{font-size:clamp(2rem,4.6vw,3.6rem);line-height:1.15;margin:.4rem 0 1rem}
    .lead{color:var(--muted);font-size:1.08rem}
    .cta{margin-top:1.4rem;display:flex;gap:.8rem;flex-wrap:wrap}
    .btn{display:inline-flex;align-items:center;gap:.6rem;padding:.8rem 1.05rem;border-radius:12px;border:1px solid #2a3442;background:#151a21;color:var(--text);font-weight:600}
    .btn.primary{background:var(--brand);border-color:#b32022}
    .btn:hover{transform:translateY(-1px);box-shadow:0 6px 18px rgba(236,43,46,.25)}
    .btn.ghost{background:transparent;border-color:#2a3442}

    /* HERO: logo z umirjenim laserskim sweepom */
    .hero-vis{position:relative;display:grid;place-items:center}
    .hero-logo{position:relative;display:grid;place-items:center;padding:24px;border-radius:20px;background:linear-gradient(180deg,rgba(255,255,255,.02),rgba(255,255,255,0));border:1px solid #1d2430;box-shadow:0 12px 30px rgba(0,0,0,.18)}
    .hero-logo img{width:min(440px,85%);height:auto;display:block;filter:drop-shadow(0 0 10px rgba(236,43,46,.12));opacity:1;transform:none}
    .hero-logo::after{
      content:""; position:absolute; inset:-12%; pointer-events:none;
      background:linear-gradient(60deg,
        rgba(236,43,46,0) 42%,
        rgba(236,43,46,.16) 50%,
        rgba(255,129,133,.22) 52%,
        rgba(236,43,46,.10) 56%,
        rgba(236,43,46,0) 64%);
      transform:translateX(-130%) translateY(20%);
      mix-blend-mode:screen;
      filter:blur(0.3px);
      opacity:.55;
      border-radius:22px;
      animation:laserSweepDiag 5.5s ease-in-out infinite;
    }
    @keyframes laserSweepDiag{
      0%{ transform:translateX(-130%) translateY(20%); opacity:.0 }
      12%{ opacity:.55 }
      50%{ transform:translateX(30%) translateY(-20%); opacity:.35 }
      88%{ opacity:.55 }
      100%{ transform:translateX(130%) translateY(-60%); opacity:.0 }
    }
    .hero-logo{ animation:logoAmbient 6s ease-in-out infinite }
    @keyframes logoAmbient{ 0%,100%{ box-shadow:0 12px 30px rgba(0,0,0,.18) } 50%{ box-shadow:0 12px 30px rgba(0,0,0,.18), 0 0 18px rgba(236,43,46,.08) } }

    /* STORITVE */
    .services { padding: 56px 0 16px; }
    .svc-head{margin-bottom:18px;text-align:left}
    .svc-head h2{margin:0 0 .2rem 0}
    .svc-sub{color:var(--muted);margin:0}
    .svc-grid { display:grid; grid-template-columns:repeat(4,1fr); gap:1.2rem; align-items:stretch; }
    .svc-card{position:relative;background:var(--panel);border:1px solid #1d2430;padding:1.1rem;border-radius:16px;box-shadow:0 6px 16px rgba(0,0,0,.22);transition:transform .25s ease, box-shadow .25s ease, border-color .25s ease}
    .svc-card:hover{transform:translateY(-3px);box-shadow:0 12px 28px rgba(0,0,0,.28);border-color:#273041}
    .svc-card h3{margin:.3rem 0 .25rem;font-size:1.06rem}
    .svc-card p{margin:.2rem 0 0;color:var(--muted);font-size:.98rem}
    .svc-icon{width:44px;height:44px;display:grid;place-items:center;margin-bottom:.4rem}
    .svc-icon svg{width:100%;height:100%;filter:drop-shadow(0 0 10px rgba(236,43,46,.28))}

    /* PROJEKTI */
    .work{padding:40px 0;border-bottom:none}
    .grid-portfolio{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem}
    .tile{position:relative;overflow:hidden;border-radius:16px;border:1px solid #1d2430;background:#0e1115}
    .tile img, .tile video{width:100%;height:auto;display:block;aspect-ratio:16/10;object-fit:cover;filter:saturate(1.05) contrast(1.03)}
    .tile .cap{position:absolute;left:0;right:0;bottom:0;padding:.7rem .9rem;background:linear-gradient(180deg,transparent,rgba(0,0,0,.7));}
    .tile .cap h3{margin:0 0 .1rem;font-size:1.02rem}
    .tile .cap p{margin:0;color:#b9c6d8;font-size:.94rem}

    /* fine framing for our own photos */
    .fit-person-1{object-position:55% 72%;} /* kitchen block: person+device */
    .fit-person-3{object-position:60% 72%;} /* construction site: person+device */

    /* ABOUT (Leica product images) */
    .about{padding:30px 0;border-top:none;box-shadow:none}
    .about .wrap{display:grid;grid-template-columns:1.1fr .9fr;gap:2rem;align-items:center}
    .about .photos{display:grid;grid-template-columns:1fr 1fr;gap:.8rem}
    .about .ph{position:relative;border-radius:16px;overflow:hidden;border:1px solid #1d2430;box-shadow:0 10px 28px rgba(0,0,0,.28);min-height:380px}
    .about .ph img{width:100%;height:auto;display:block;aspect-ratio:3/4;object-fit:contain;padding:2%;background:linear-gradient(180deg,rgba(255,255,255,.02),rgba(255,255,255,0));filter:saturate(1.02) contrast(1.04)}
    .about .ph::after{content:"";position:absolute;inset:0;pointer-events:none;background:
      radial-gradient(460px 260px at 85% 20%, rgba(236,43,46,.18), transparent 60%),
      linear-gradient(180deg, rgba(0,0,0,0) 60%, rgba(0,0,0,.28) 100%);mix-blend-mode:soft-light}
    .about .tag{position:absolute;right:.6rem;bottom:.6rem;background:rgba(0,0,0,.55);border:1px solid #2a3342;border-radius:999px;padding:.22rem .55rem;font-size:.8rem}

    /* CONTACT */
    .contact{padding:50px 0}
    .contact .wrap{display:grid;grid-template-columns:1fr .95fr;gap:2rem}
    form{background:var(--panel);border:1px solid #1d2430;padding:1.2rem;border-radius:16px}
    label{display:block;font-weight:600;margin:.2rem 0}
    input,textarea{width:100%;background:#0f1318;border:1px solid #293341;color:#e7eef8;border-radius:12px;padding:.75rem .9rem;font:inherit}
    textarea{min-height:140px;resize:vertical}
    .help,.hint{font-size:.9rem;color:var(--muted)}
    .success{display:none;margin-top:.6rem;color:#2ecc71;font-weight:700}
    .grid-2{display:grid;grid-template-columns:1fr 1fr;gap:.8rem}
    .grid-2 > *{min-width:0}
    .req{color:#ff8b8d}
    .row{margin:.6rem 0}
    .inline{display:flex;align-items:center;gap:.5rem}
    .error{display:none;color:#ff8b8d;font-size:.9rem}
    input:invalid, textarea:invalid{border-color:#6a3133}
    input:valid, textarea:valid{border-color:#2e5a39}

    footer{border-top:1px solid #202833;padding:24px 0 60px;color:#a8b5c6}

    @media (max-width: 1100px){ .svc-grid{grid-template-columns: repeat(2, 1fr);} }
    @media (max-width: 980px){
      .hero .grid{grid-template-columns:1fr;gap:1.8rem}
      .about .wrap, .contact .wrap{grid-template-columns:1fr}
      .grid-portfolio{grid-template-columns:1fr 1fr}
      nav ul{display:none}
      .hamburger{display:inline-flex}
    }
    @media (max-width: 700px){
      .svc-grid{grid-template-columns:1fr}
      .services{padding:44px 0 10px}
    }
    @media (max-width: 620px){ .grid-portfolio{ grid-template-columns:1fr } }
    @media (prefers-reduced-motion: reduce){ *{animation:none !important; transition:none !important} .laser-line{display:none} }