  :root{
    --orange:#F0471F;       /* signature brand orange (sampled from logo) */
    --orange-deep:#D43A12;
    --ink:#2D292B;          /* warm charcoal */
    --ink-2:#1c1a1b;
    --paper:#ffffff;
    --grey:#6E6F71;
    --grey-200:#E9E9E7;
    --reveal-cx:50%; --reveal-cy:58%;
  }
  *{box-sizing:border-box; -webkit-font-smoothing:antialiased; text-rendering:optimizeLegibility;}
  html{scroll-behavior:smooth;}
  section[id], footer[id]{scroll-margin-top:84px;}
  body{margin:0; font-family:'Inter',system-ui,sans-serif; color:var(--ink); background:var(--paper); overflow-x:hidden;}
  h1,h2,h3,.display{font-family:'Outfit','Inter',sans-serif; letter-spacing:-0.03em; margin:0;}
  a{text-decoration:none; color:inherit;}
  ::selection{background:var(--orange); color:#fff;}
  img{display:block; max-width:100%;}

  /* ============ concept ribbon (remove for production) ============ */
  .concept-ribbon{
    position:fixed; bottom:14px; left:14px; z-index:120;
    background:var(--ink); color:#fff; font-size:10.5px; letter-spacing:.16em;
    text-transform:uppercase; font-weight:600; padding:7px 12px; border-radius:999px;
    opacity:.78; pointer-events:none;
  }
  .concept-ribbon b{color:var(--orange);}

  /* ======================================================= */
  /* HEADER / NAV                                            */
  /* ======================================================= */
  header{
    position:fixed; top:0; left:0; right:0; z-index:100;
    padding:22px 0;
    transition:background .4s ease, padding .4s ease, box-shadow .4s ease, transform .45s cubic-bezier(.2,.7,.2,1);
  }
  header.scrolled{
    background:rgba(255,255,255,.92); backdrop-filter:blur(12px);
    padding:13px 0; box-shadow:0 1px 0 rgba(0,0,0,.06), 0 8px 30px -18px rgba(0,0,0,.35);
  }
  header.hide{transform:translateY(-105%);}
  .nav{max-width:1320px; margin:0 auto; padding:0 38px; display:flex; align-items:center; justify-content:space-between; gap:24px;}

  /* logo: white on hero, color when scrolled */
  .brand{display:block; height:38px; position:relative; flex-shrink:0;}
  .brand img{height:100%; width:auto; transition:opacity .35s ease;}
  .brand .logo-color{opacity:0; position:absolute; inset:0;}
  header.scrolled .brand .logo-white{opacity:0;}
  header.scrolled .brand .logo-color{opacity:1;}

  /* nav links */
  .menu{display:flex; align-items:center; gap:30px; list-style:none; margin:0; padding:0;}
  .menu > li > a{
    font-size:13px; font-weight:600; letter-spacing:.08em; text-transform:uppercase;
    color:#fff; position:relative; padding:6px 0; display:inline-flex; align-items:center; gap:6px;
    transition:color .25s ease;
  }
  header.scrolled .menu > li > a{color:var(--ink);}
  .menu > li > a::after{
    content:''; position:absolute; left:0; bottom:0; height:2px; width:0;
    background:var(--orange); transition:width .3s cubic-bezier(.2,.7,.2,1);
  }
  .menu > li > a:hover{color:var(--orange);}
  header.scrolled .menu > li > a:hover{color:var(--orange);}
  .menu > li > a:hover::after{width:100%;}
  .caret{width:8px; height:8px; border-right:2px solid currentColor; border-bottom:2px solid currentColor; transform:rotate(45deg) translateY(-1px); transition:transform .3s ease;}
  .has-drop:hover .caret{transform:rotate(225deg) translateY(-1px);}

  /* services dropdown (mega) */
  .has-drop{position:relative;}
  .svc-top{cursor:default;}
  .drop{
    position:absolute; top:calc(100% + 18px); left:50%; transform:translateX(-50%) translateY(10px);
    background:#fff; border-radius:16px; padding:16px; width:560px;
    box-shadow:0 30px 70px -25px rgba(0,0,0,.4); border:1px solid var(--grey-200);
    opacity:0; visibility:hidden; transition:opacity .3s ease, transform .3s cubic-bezier(.2,.7,.2,1);
    display:grid; grid-template-columns:1fr 1fr; gap:4px;
  }
  .has-drop:hover .drop{opacity:1; visibility:visible; transform:translateX(-50%) translateY(0);}
  .drop::before{content:''; position:absolute; top:-18px; left:0; right:0; height:18px;} /* hover bridge */
  .drop a{
    display:flex; align-items:center; gap:12px; padding:12px 14px; border-radius:11px;
    color:var(--ink); transition:background .22s ease, transform .22s ease;
  }
  .drop a:hover{background:#FBEDE9; transform:translateX(3px);}
  .drop a .d-dot{width:9px; height:9px; border-radius:50%; background:var(--orange); flex-shrink:0; opacity:.35; transition:opacity .2s;}
  .drop a:hover .d-dot{opacity:1;}
  .drop a .d-name{font-family:'Outfit'; font-weight:600; font-size:14.5px;}
  .drop a .d-sub{font-size:11px; color:var(--grey); margin-top:1px;}

  /* CTA */
  .cta{
    background:var(--orange); color:#fff; font-family:'Outfit'; font-weight:700;
    font-size:13.5px; letter-spacing:.02em; padding:12px 22px; border-radius:999px;
    display:inline-flex; align-items:center; gap:8px; white-space:nowrap;
    box-shadow:0 10px 26px -10px rgba(240,71,31,.7); transition:transform .3s cubic-bezier(.2,.7,.2,1), box-shadow .3s ease, background .3s;
  }
  .cta:hover{transform:translateY(-2px); background:var(--orange-deep); box-shadow:0 16px 34px -12px rgba(240,71,31,.85);}
  .cta .arr{transition:transform .3s ease;}
  .cta:hover .arr{transform:translateX(4px);}

  /* burger */
  .burger{display:none; width:42px; height:42px; border:none; background:transparent; cursor:pointer; flex-direction:column; gap:6px; align-items:center; justify-content:center;}
  .burger span{width:26px; height:2px; background:#fff; transition:.3s; border-radius:2px;}
  header.scrolled .burger span{background:var(--ink);}

  /* mobile menu */
  .m-menu{position:fixed; inset:0; z-index:110; background:var(--ink); padding:84px 30px 30px; transform:translateY(-100%); transition:transform .55s cubic-bezier(.7,0,.15,1); overflow-y:auto;}
  .m-menu.open{transform:translateY(0);}
  .m-menu a{display:block; color:#fff; font-family:'Outfit'; font-weight:700; font-size:30px; padding:14px 0; border-bottom:1px solid rgba(255,255,255,.1); text-transform:lowercase;}
  .m-menu a:hover{color:var(--orange);}
  .m-menu .m-sub{font-size:15px; font-weight:500; padding:9px 0 9px 16px; border:none; color:#cfcfca; text-transform:none;}
  .m-close{position:absolute; top:24px; right:24px; width:44px; height:44px; background:none; border:none; color:#fff; font-size:30px; cursor:pointer;}

  /* ======================================================= */
  /* HERO SLIDER                                             */
  /* ======================================================= */
  .hero{position:relative; height:100vh; min-height:600px; overflow:hidden; background:var(--ink);}

  .slide{position:absolute; inset:0; opacity:0; visibility:hidden;}
  .slide.active{opacity:1; visibility:visible;}
  .slide.entering{z-index:2;}
  /* --- transition A: orange-circle "eye" reveal (brand motif) --- */
  .slide.entering.t-circle{animation:circleReveal 1s cubic-bezier(.7,0,.2,1) forwards;}
  @keyframes circleReveal{
    from{clip-path:circle(0% at var(--reveal-cx) var(--reveal-cy));}
    to{clip-path:circle(150% at var(--reveal-cx) var(--reveal-cy));}
  }
  /* --- transition B: directional wipe --- */
  .slide.entering.t-wipe{animation:wipeReveal 1.05s cubic-bezier(.76,0,.24,1) forwards;}
  @keyframes wipeReveal{
    from{clip-path:inset(0 0 0 100%);}
    to{clip-path:inset(0 0 0 0);}
  }
  /* --- transition C: interlocking strip reveal (fancy default) --- */
  .fx{position:absolute; inset:0; z-index:5; display:flex; opacity:0; pointer-events:none;}
  .fx.show{opacity:1;}
  .fx .panel{position:relative; height:100%; flex:1 1 0; overflow:hidden;}
  .fx .pimg{
    position:absolute; top:0; height:100%;
    width:calc(100% * var(--n)); left:calc(-100% * var(--i));
    background-size:cover; background-position:center; will-change:clip-path;
    clip-path:inset(0 0 100% 0);                 /* odd strips: hidden from top */
    transition:clip-path .72s cubic-bezier(.7,0,.2,1);
    transition-delay:calc(var(--i) * 0.085s);
  }
  .fx .panel:nth-child(even) .pimg{clip-path:inset(100% 0 0 0);}  /* even: hidden from bottom */
  .fx.reveal .pimg{clip-path:inset(0 0 0 0);}
  /* thin orange seam flashes between strips during the reveal (brand accent) */
  .fx .panel::after{content:''; position:absolute; top:0; bottom:0; right:0; width:2px; background:var(--orange); opacity:0; transition:opacity .3s ease;}
  .fx .panel:last-child::after{display:none;}
  .fx.reveal .panel::after{opacity:.9; transition:opacity .3s ease calc(var(--seam,0s));}
  /* --- transition D: orange panel swipe --- */
  .swipe{position:absolute; top:-12%; bottom:-12%; left:0; right:0; z-index:5; pointer-events:none; opacity:0;}
  .swipe.run{opacity:1; animation:swipeMove 1.15s cubic-bezier(.76,0,.24,1) forwards;}
  @keyframes swipeMove{from{transform:translateX(-125%);} to{transform:translateX(125%);}}
  .swipe .bar{position:absolute; top:0; bottom:0; transform:skewX(-11deg);}
  .swipe .bar.orange{left:-15%; width:135%; background:var(--orange);}
  .swipe .bar.ink{left:117%; width:13%; background:var(--ink);}
  .slide-img{position:absolute; inset:0; background-size:cover; background-position:center; transform:scale(1.02);}
  .slide.active .slide-img{animation:kenburns 7s ease-out forwards;}
  @keyframes kenburns{from{transform:scale(1.02);} to{transform:scale(1.13);}}
  /* charcoal scrim so white + orange text always reads (brand: darken image) */
  .scrim{position:absolute; inset:0; background:
    linear-gradient(180deg, rgba(28,26,27,.30) 0%, rgba(28,26,27,.15) 38%, rgba(28,26,27,.62) 78%, rgba(28,26,27,.88) 100%),
    radial-gradient(120% 90% at 28% 80%, rgba(28,26,27,.45) 0%, rgba(28,26,27,0) 60%);}

  .slide-content{position:absolute; inset:0; display:flex; flex-direction:column; justify-content:center; padding:0;}
  .slide-inner{max-width:1320px; margin:0 auto; padding:0 38px; width:100%;}
  .eyebrow{display:flex; align-items:center; gap:12px; color:#fff; font-size:12px; font-weight:600; letter-spacing:.28em; text-transform:uppercase; margin-bottom:22px; opacity:.92;}
  .eyebrow .ebar{width:42px; height:2px; background:var(--orange);}
  .eyebrow b{color:var(--orange); font-weight:700;}

  .headline{color:#fff; font-weight:800; font-size:clamp(44px, 9.2vw, 132px); line-height:.92; text-transform:lowercase;}
  .headline .kw{color:var(--orange);}
  /* word-rise animation, re-triggers each time slide becomes active */
  .headline .ln{display:inline-block; opacity:0; transform:translateY(46px); }
  .slide.active .headline .ln{animation:rise .8s cubic-bezier(.2,.8,.2,1) forwards;}
  .slide.active .headline .ln:nth-child(1){animation-delay:.15s;}
  .slide.active .headline .ln:nth-child(2){animation-delay:.30s;}
  @keyframes rise{to{opacity:1; transform:translateY(0);}}

  .hero-cta{margin-top:34px; display:flex; align-items:center; gap:22px; opacity:0; transform:translateY(20px);}
  .slide.active .hero-cta{animation:rise .8s cubic-bezier(.2,.8,.2,1) .55s forwards;}
  .hero-cta .seework{
    display:inline-flex; align-items:center; gap:12px; color:#fff; font-family:'Outfit'; font-weight:600; font-size:15px;
  }
  .hero-cta .seework .circle{
    width:50px; height:50px; border-radius:50%; border:1.5px solid rgba(255,255,255,.55);
    display:flex; align-items:center; justify-content:center; transition:.35s;
  }
  .hero-cta .seework:hover .circle{background:var(--orange); border-color:var(--orange); transform:scale(1.06);}

  /* ---- slider chrome ---- */
  .h-progress{position:absolute; top:0; left:0; right:0; height:3px; background:rgba(255,255,255,.16); z-index:6;}
  .h-progress .bar{height:100%; width:0; background:var(--orange);}
  .h-progress .bar.run{animation:prog var(--dur,5800ms) linear forwards;}
  @keyframes prog{from{width:0;} to{width:100%;}}

  .h-controls{position:absolute; left:0; right:0; bottom:46px; z-index:6;}
  .h-controls-inner{max-width:1320px; margin:0 auto; padding:0 38px; display:flex; align-items:center; justify-content:space-between; gap:20px;}
  .counter{color:#fff; font-family:'Outfit'; font-weight:700; font-size:14px; letter-spacing:.05em;}
  .counter b{font-size:22px;}
  .counter .sep{opacity:.5; margin:0 6px;}
  .dots{display:flex; gap:12px; align-items:center;}
  .dot{height:3px; width:30px; background:rgba(255,255,255,.4); border:none; padding:0; cursor:pointer; border-radius:2px; transition:width .35s ease, background .35s ease;}
  .dot.active{width:60px; background:var(--orange);}
  .arrows{display:flex; gap:10px;}
  .arrow{width:48px; height:48px; border-radius:50%; border:1.5px solid rgba(255,255,255,.4); background:rgba(255,255,255,.06); color:#fff; cursor:pointer; display:flex; align-items:center; justify-content:center; transition:.3s; backdrop-filter:blur(4px);}
  .arrow:hover{background:var(--orange); border-color:var(--orange); transform:translateY(-2px);}
  .arrow svg{width:18px; height:18px;}

  /* a faint giant ž watermark = brand "eye/face" motif */
  .hero-watermark{position:absolute; top:46%; right:-40px; transform:translateY(-50%); font-family:'Outfit'; font-weight:900; font-size:42vh; color:rgba(255,255,255,.05); line-height:1; z-index:1; pointer-events:none; user-select:none;}

  /* ======================================================= */
  /* INTRO / WHO WE ARE                                      */
  /* ======================================================= */
  .intro{background:#fff; padding:clamp(96px,15vh,200px) 38px; position:relative; overflow:hidden;}
  .intro-inner{max-width:1200px; margin:0 auto; text-align:center; position:relative; z-index:2;}
  .statement{font-family:'Outfit',sans-serif; font-weight:900; color:var(--ink); font-size:clamp(32px,6.2vw,88px); line-height:1.05; letter-spacing:-.035em;}
  .statement .line{display:block; opacity:0; transform:translateY(52px); transition:opacity .85s cubic-bezier(.2,.8,.2,1), transform .85s cubic-bezier(.2,.8,.2,1);}
  .intro.in .statement .line{opacity:1; transform:none;}
  .intro.in .statement .line:nth-child(1){transition-delay:.00s;}
  .intro.in .statement .line:nth-child(2){transition-delay:.12s;}
  .intro.in .statement .line:nth-child(3){transition-delay:.24s;}
  .intro.in .statement .line:nth-child(4){transition-delay:.36s;}
  .statement .kw .u{display:inline-block; color:var(--orange);}
  .intro-copy{max-width:780px; margin:clamp(36px,5vh,64px) auto 0; color:#57534f; font-size:clamp(16px,1.5vw,20px); line-height:1.78; opacity:0; transform:translateY(22px); transition:opacity .9s ease .55s, transform .9s ease .55s;}
  .intro.in .intro-copy{opacity:1; transform:none;}
  .intro .wm{position:absolute; right:-3%; top:3%; width:37vh; height:37vh; background:url('assets/logo/zeleman-mark.png') no-repeat top right/contain; opacity:.045; z-index:1; pointer-events:none;}
  @media (max-width:768px){ .intro .wm{right:-22%; opacity:.06;} }
  @media (max-width:560px){ .intro .wm{display:none;} }

  /* ======================================================= */
  /* OUR FAMILY                                              */
  /* ======================================================= */
  .family{position:relative; background:#F4F3F1; padding:clamp(90px,13vh,170px) 38px; overflow:hidden;}
  .family .wm{position:absolute; left:-3%; top:3%; width:37vh; height:37vh; background:url('assets/logo/zeleman-mark.png') no-repeat top left/contain; opacity:.045; z-index:0; pointer-events:none;}
  .family-inner{max-width:1200px; margin:0 auto; position:relative; z-index:2;}
  .fam-head{text-align:center; margin-bottom:52px;}
  .fam-title{font-family:'Outfit'; font-weight:900; color:var(--ink); font-size:clamp(34px,5.2vw,68px); line-height:1.0; text-transform:uppercase; letter-spacing:-.01em; margin-top:12px;}
  .fam-lead{max-width:560px; margin:20px auto 0; color:#57534f; font-size:17px; line-height:1.6;}
  .fam-sub{font-family:'Outfit'; font-weight:600; color:#4a4644; font-size:clamp(18px,2.1vw,28px); line-height:1.25; margin-top:14px; letter-spacing:-.015em;}
  .fam-grid{display:grid; grid-template-columns:repeat(3,1fr); gap:22px;}
  .fam-head{opacity:0; transform:translateY(26px); transition:opacity .7s ease, transform .7s cubic-bezier(.2,.8,.2,1);}
  .family.in .fam-head{opacity:1; transform:none;}
  .fam-card{position:relative; display:flex; flex-direction:column; align-items:center; justify-content:center; min-height:224px; padding:34px 24px; border:1px solid #E7E6E3; border-radius:16px; background:#fff; cursor:pointer; overflow:hidden; text-decoration:none; box-shadow:0 2px 10px rgba(45,41,43,.05);
            opacity:0; transform:translateY(70px) scale(.55);
            transition:opacity .5s ease, transform .9s cubic-bezier(.18,1.5,.32,1), background .4s cubic-bezier(.2,.7,.2,1), border-color .4s ease, box-shadow .4s ease;}
  .family.in .fam-card{opacity:1; transform:translateY(0) scale(1);}
  .family.in .fam-card:nth-child(1){transition-delay:.05s}.family.in .fam-card:nth-child(2){transition-delay:.16s}.family.in .fam-card:nth-child(3){transition-delay:.27s}
  .family.in .fam-card:nth-child(4){transition-delay:.38s}.family.in .fam-card:nth-child(5){transition-delay:.49s}.family.in .fam-card:nth-child(6){transition-delay:.60s}
  .family.in .fam-card:nth-child(7){transition-delay:.71s}.family.in .fam-card:nth-child(8){transition-delay:.82s}.family.in .fam-card:nth-child(9){transition-delay:.93s}
  .fam-logo{display:flex; align-items:center; justify-content:center; min-height:104px; transition:opacity .35s ease, transform .4s cubic-bezier(.2,.7,.2,1);}
  .fam-logo img{max-height:76px; max-width:200px; width:auto; object-fit:contain;}
  .fam-logo.tall img{max-height:116px; max-width:225px;}   /* logos that stack mark + slogan */
  .fam-name{position:absolute; left:24px; right:24px; top:50%; transform:translateY(-50%) translateY(10px); font-family:'Outfit'; font-weight:800; font-size:clamp(18px,1.55vw,22px); line-height:1.25; color:#fff; text-align:center; opacity:0; transition:opacity .4s ease, transform .45s cubic-bezier(.2,.7,.2,1);}
  /* hover (style C): orange fill, logo fades out, bold service name appears */
  .fam-card:hover{background:var(--orange); border-color:var(--orange); transform:translateY(-6px); box-shadow:0 24px 50px -18px rgba(240,71,31,.55); transition:transform .35s cubic-bezier(.2,.7,.2,1), background .4s ease, border-color .4s ease, box-shadow .4s ease;}
  .fam-card:hover .fam-logo{opacity:0; transform:scale(.92);}
  .fam-card:hover .fam-name{opacity:1; transform:translateY(-50%);}
  .fam-card.fam-parent{border-color:rgba(240,71,31,.4);}
  @media (max-width:880px){ .fam-grid{grid-template-columns:repeat(2,1fr);} .family .wm{display:none;} }
  @media (max-width:520px){ .fam-grid{grid-template-columns:1fr;} }

  /* ======================================================= */
  /* OUR WORK                                                */
  /* ======================================================= */
  .work{position:relative; background:var(--ink); color:#fff; padding:clamp(90px,13vh,170px) 38px; overflow:hidden;}
  .work-inner{max-width:1560px; margin:0 auto; text-align:center; position:relative; z-index:2;}
  .work-head{opacity:0; transform:translateY(26px); transition:opacity .7s ease, transform .7s cubic-bezier(.2,.8,.2,1);}
  .work.in .work-head{opacity:1; transform:none;}
  .work-title{font-family:'Outfit'; font-weight:900; font-size:clamp(34px,5.2vw,68px); line-height:1; text-transform:uppercase; letter-spacing:-.01em; color:#fff;}
  .work-sub{font-family:'Outfit'; font-weight:600; color:#b9b6b3; font-size:clamp(18px,2.1vw,28px); line-height:1.25; margin-top:14px; letter-spacing:-.015em;}
  .work-filters{display:flex; flex-wrap:wrap; justify-content:center; gap:10px; margin-top:40px;
    opacity:0; transform:translateY(20px); transition:opacity .7s ease .15s, transform .7s cubic-bezier(.2,.8,.2,1) .15s;}
  .work.in .work-filters{opacity:1; transform:none;}
  .work-filters .filter{font-family:'Outfit'; font-weight:600; font-size:13px; letter-spacing:.06em; text-transform:uppercase; color:#cfccc9; background:transparent; border:1px solid rgba(255,255,255,.22); padding:10px 20px; border-radius:999px; cursor:pointer; transition:background .25s ease, border-color .25s ease, color .25s ease, transform .25s ease;}
  .work-filters .filter:hover{border-color:#fff; color:#fff; transform:translateY(-2px);}
  .work-filters .filter.active{background:var(--orange); border-color:var(--orange); color:#fff;}
  @media (prefers-reduced-motion: reduce){ .work-head, .work-filters{opacity:1; transform:none; transition:none;} .wcard.entering{animation:none;} .wthumb::before{animation:none;} .wcard img{transition:opacity .2s ease;} }
  /* work grid */
  .work-grid{display:grid; grid-template-columns:repeat(3,1fr); gap:70px; margin-top:50px;}
  .wcard{position:relative; display:block; cursor:pointer; text-decoration:none;}
  @keyframes wcardEnter{from{opacity:0; transform:translateY(30px);} to{opacity:1; transform:none;}}
  .wcard.entering{animation:wcardEnter .62s cubic-bezier(.2,.7,.2,1) both;}
  .wthumb{position:relative; aspect-ratio:16/9; border-radius:0; overflow:hidden; background:#1a1819;}
  .wthumb::before{content:''; position:absolute; inset:0; z-index:0; background:linear-gradient(100deg,#201e1f 28%,#2d2a2b 50%,#201e1f 72%); background-size:200% 100%; animation:wshimmer 1.4s ease-in-out infinite;}
  .wthumb.loaded::before{display:none;}
  @keyframes wshimmer{0%{background-position:200% 0;} 100%{background-position:-200% 0;}}
  .wcard img{position:relative; z-index:1; width:100%; height:100%; object-fit:cover; opacity:0; transition:opacity .5s ease, transform .6s cubic-bezier(.2,.7,.2,1);}
  .wthumb.loaded img{opacity:1;}
  .wcard:hover img{transform:scale(1.07);}
  .wcard .ov{position:absolute; inset:0; background:rgba(28,26,27,0); z-index:1; transition:background .4s ease;}
  .wcard:hover .ov{background:rgba(28,26,27,.4);}
  .wcard .play{position:absolute; top:50%; left:50%; transform:translate(-50%,-50%) scale(.7); z-index:2; width:84px; height:84px; border-radius:50%; background:rgba(20,18,19,.55); backdrop-filter:blur(4px); border:1px solid rgba(255,255,255,.3); display:flex; align-items:center; justify-content:center; opacity:0; transition:opacity .35s ease, transform .35s cubic-bezier(.2,.7,.2,1); box-shadow:0 14px 36px -10px rgba(0,0,0,.55);}
  .wcard .play svg{width:30px; height:30px; fill:#fff; margin-left:4px;}
  .wcard:hover .play{opacity:1; transform:translate(-50%,-50%) scale(1);}
  .wcard .ttl{display:block; margin-top:15px; color:#fff; font-family:'Outfit'; font-weight:600; font-size:16px; line-height:1.35; text-align:left;}
  .work-empty{display:none; text-align:center; color:#8a8783; font-size:16px; margin-top:50px;}
  .work-more{text-align:center; margin-top:40px;}
  .load-more{font-family:'Outfit'; font-weight:700; font-size:14px; letter-spacing:.04em; color:#fff; background:transparent; border:1px solid rgba(255,255,255,.3); padding:14px 30px; border-radius:999px; cursor:pointer; transition:background .3s ease, border-color .3s ease, transform .3s ease; display:inline-flex; align-items:center; gap:10px;}
  .load-more:hover{background:var(--orange); border-color:var(--orange); transform:translateY(-2px);}
  .lightbox{position:fixed; inset:0; z-index:200; background:rgba(15,14,14,.9); backdrop-filter:blur(8px); display:flex; align-items:center; justify-content:center; padding:30px; opacity:0; visibility:hidden; transition:opacity .35s ease, visibility .35s;}
  .lightbox.open{opacity:1; visibility:visible;}
  .lightbox .frame{position:relative; width:100%; max-width:1040px; aspect-ratio:16/9; transform:scale(.94); transition:transform .4s cubic-bezier(.2,.7,.2,1); background:#000; border-radius:12px; overflow:hidden; box-shadow:0 40px 100px -30px rgba(0,0,0,.8);}
  .lightbox.open .frame{transform:scale(1);}
  .lightbox #lbHost{position:absolute; inset:0; width:100%; height:100%;}
  .lightbox iframe{position:absolute; inset:0; width:100%; height:100%; border:0; display:block;}
  .lightbox .lb-close{position:absolute; top:26px; right:30px; width:48px; height:48px; border-radius:50%; background:rgba(255,255,255,.1); border:1px solid rgba(255,255,255,.25); color:#fff; cursor:pointer; display:flex; align-items:center; justify-content:center; backdrop-filter:blur(4px); transition:background .25s ease, border-color .25s ease, transform .4s cubic-bezier(.2,.7,.2,1); z-index:10;}
  .lightbox .lb-close svg{width:20px; height:20px;}
  .lightbox .lb-close:hover{background:var(--orange); border-color:var(--orange); transform:rotate(90deg) scale(1.05);}
  @media (max-width:980px){ .work-grid{grid-template-columns:repeat(2,1fr);} }
  @media (max-width:560px){ .work-grid{grid-template-columns:1fr;} }

  /* ======================================================= */
  /* MANAGEMENT TEAM                                         */
  /* ======================================================= */
  .team{position:relative; background:#fff; padding:clamp(90px,13vh,170px) 38px; overflow:hidden;}
  .team .wm{position:absolute; right:-2%; bottom:-2%; width:38vh; height:38vh; background:url('assets/logo/zeleman-mark.png') no-repeat bottom right/contain; opacity:.05; z-index:0; pointer-events:none;}
  .team-inner{max-width:1320px; margin:0 auto; text-align:center; position:relative; z-index:2;}
  .team-head{opacity:0; transform:translateY(26px); transition:opacity .7s ease, transform .7s cubic-bezier(.2,.8,.2,1);}
  .team.in .team-head{opacity:1; transform:none;}
  .team-title{font-family:'Outfit'; font-weight:900; font-size:clamp(34px,5.2vw,68px); line-height:1; text-transform:uppercase; letter-spacing:-.01em; color:var(--ink);}
  .team-sub{font-family:'Outfit'; font-weight:600; color:#6b6663; font-size:clamp(18px,2.1vw,28px); line-height:1.25; margin-top:14px; letter-spacing:-.015em;}
  .team-grid{display:grid; grid-template-columns:repeat(4,1fr); gap:50px 50px; margin-top:64px; align-items:start; max-width:1140px; margin-left:auto; margin-right:auto;}
  .member{opacity:0; transform:translateY(30px); transition:opacity .6s ease, transform .6s cubic-bezier(.2,.7,.2,1);}
  .team.in .member{opacity:1; transform:none;}
  .team.in .member:nth-child(1){transition-delay:.05s}.team.in .member:nth-child(2){transition-delay:.11s}.team.in .member:nth-child(3){transition-delay:.17s}.team.in .member:nth-child(4){transition-delay:.23s}.team.in .member:nth-child(5){transition-delay:.29s}
  .team.in .member:nth-child(6){transition-delay:.35s}.team.in .member:nth-child(7){transition-delay:.41s}.team.in .member:nth-child(8){transition-delay:.47s}.team.in .member:nth-child(9){transition-delay:.53s}
  .team.in .member:nth-child(10){transition-delay:.59s}.team.in .member:nth-child(11){transition-delay:.65s}.team.in .member:nth-child(12){transition-delay:.71s}.team.in .member:nth-child(13){transition-delay:.77s}
  .team.in .member:nth-child(14){transition-delay:.83s}.team.in .member:nth-child(15){transition-delay:.89s}
  /* ---- ID badge card (clip removed; hole only) ---- */
  .member .id{position:relative; aspect-ratio:1/1.4; border-radius:18px; overflow:hidden;
    background:#D7DBE2; border:0; border-bottom:16px solid var(--orange);
    box-shadow:0 24px 55px -20px rgba(45,41,43,.32);
    transform-origin:50% -12px; transition:transform .55s cubic-bezier(.3,.7,.3,1.3), box-shadow .45s ease;}
  .member .id .hole{position:absolute; top:14px; left:50%; transform:translateX(-50%); width:42px; height:9px; background:var(--ink); border-radius:5px; z-index:6;}
  .member .id .fc1{position:absolute; top:0; left:0; width:55%; height:40%; background:#E4E7EC; clip-path:polygon(0 0,100% 0,0 100%);}
  .member .id .fc2{position:absolute; top:0; right:0; width:42%; height:26%; background:#C6CCD4; clip-path:polygon(100% 0,100% 100%,0 0);}
  .member .id .photo{position:absolute; left:0; right:0; bottom:0; margin:0 auto; height:91%; width:auto; object-fit:contain; object-position:bottom; filter:grayscale(1); z-index:2; transition:transform .55s cubic-bezier(.2,.7,.2,1);}
  .member .id .photo.zout{height:80%;}  /* slightly smaller framing (Shani) */
  .member .id .photo.zin{height:106%;}  /* tighter framing for the wider shots */
  /* 'full' = use the photo as-is, filling the card (e.g. Shani) instead of a cut-out */
  .member.full .id .photo{inset:0; width:100%; height:100%; margin:0; object-fit:cover; object-position:center 16%;}
  .member.full .id .fc1, .member.full .id .fc2{display:none;}
  /* name/title panel — fixed size for uniformity, neutral light-black gradient, white text */
  .member .tag{position:absolute; right:0; bottom:0; width:78%; height:23%; display:flex; flex-direction:column; justify-content:center; padding:0 14px 0 24px; color:#fff; z-index:3;
    background:linear-gradient(235deg,#5B5B5D 0%,#3B3B3D 50%,#262628 100%); clip-path:polygon(16% 0,100% 0,100% 100%,0 100%);}
  .member .tag .nm{font-size:10.5px; font-weight:600; letter-spacing:.01em; color:#D7D1CF; line-height:1.2;}
  .member .tag .ro{font-family:'Outfit'; font-weight:800; font-size:16px; line-height:1.07; margin-top:3px; color:#fff;}
  .member .tag.med .ro{font-size:13px;}
  .member .tag.long .ro{font-size:11.5px;}
  .member:hover .id{transform:rotate(-2.2deg) translateY(-4px); box-shadow:0 34px 65px -20px rgba(45,41,43,.42);}
  .member:hover .id .photo{transform:scale(1.03);}
  @media (max-width:1020px){ .team-grid{grid-template-columns:repeat(3,1fr); max-width:760px;} }
  @media (max-width:720px){ .team-grid{grid-template-columns:repeat(2,1fr); max-width:520px;} }
  @media (max-width:440px){ .team-grid{grid-template-columns:1fr; max-width:280px;} .team .wm{display:none;} }
  @media (prefers-reduced-motion: reduce){ .team-head, .member{opacity:1; transform:none; transition:none;} }

  @media (max-width:980px){
    .menu, .nav > .cta{display:none;}
    .burger{display:flex;}
    .brand{height:34px;}
    .slide-content{padding-bottom:120px;}
    .hero-watermark{display:none;}
  }
  @media (max-width:560px){
    .nav{padding:0 22px;}
    .slide-inner,.h-controls-inner{padding:0 22px;}
    .counter .sep ~ *{}
    .arrows{display:none;}
    .slide-content{padding-bottom:104px;}
  }

  /* accessibility: respect reduced motion */
  @media (prefers-reduced-motion: reduce){
    .slide.entering, .slide.entering.t-circle, .slide.entering.t-wipe{animation:none;}
    .slide.active .slide-img{animation:none; transform:scale(1.04);}
    .slide.active .headline .ln,.slide.active .hero-cta{animation:none; opacity:1; transform:none;}
    .h-progress .bar.run{animation:none; width:100%;}
    .statement .line, .intro-copy{transition:none; opacity:1; transform:none;}
    .fam-head, .fam-card{opacity:1; transform:none; transition:background .25s ease, border-color .25s ease;}
    .fam-name{transition:opacity .2s ease;}
    *{scroll-behavior:auto;}
  }

  /* ======================================================= */
  /* SERVICES — orange, typographic                          */
  /* ======================================================= */
  .services{position:relative; overflow:hidden; padding:clamp(80px,12vh,150px) 38px;
    background:linear-gradient(135deg,#FF5E30 0%,#F0471F 52%,#D33A12 100%);}
  .services::after{content:''; position:absolute; left:-2%; top:5%; width:min(40vh,360px); height:min(40vh,360px);
    background:url('assets/logo/zeleman-mark.png') no-repeat top left/contain; filter:brightness(0) invert(1); opacity:.08; pointer-events:none;}
  .services-inner{position:relative; z-index:1; max-width:1200px; margin:0 auto;}
  .services-head{margin-bottom:clamp(40px,6vh,64px); text-align:center;}
  .services-title{font-family:'Outfit'; font-weight:900; font-size:clamp(40px,6.5vw,92px); line-height:.95; text-transform:uppercase; letter-spacing:-.01em; color:#fff;}
  .services-sub{font-family:'Outfit'; font-weight:600; color:rgba(255,255,255,.85); font-size:clamp(16px,1.9vw,22px); margin-top:12px; letter-spacing:-.01em;}
  .svc-grid{display:grid; grid-template-columns:repeat(3,1fr); gap:18px;}
  .svc-cell{position:relative; border:1.5px solid rgba(255,255,255,.32); border-radius:18px; padding:28px 28px 26px; min-height:172px; overflow:hidden;
    display:flex; flex-direction:column; justify-content:space-between;
    opacity:0; transform:translateY(26px); transition:opacity .6s ease, transform .55s cubic-bezier(.2,.7,.2,1), background .35s ease, border-color .35s ease, box-shadow .4s ease;}
  .services.in .svc-cell{opacity:1; transform:translateY(0);}
  .services.in .svc-cell:nth-child(1){transition-delay:.04s}.services.in .svc-cell:nth-child(2){transition-delay:.1s}.services.in .svc-cell:nth-child(3){transition-delay:.16s}.services.in .svc-cell:nth-child(4){transition-delay:.22s}.services.in .svc-cell:nth-child(5){transition-delay:.28s}.services.in .svc-cell:nth-child(6){transition-delay:.34s}.services.in .svc-cell:nth-child(7){transition-delay:.4s}.services.in .svc-cell:nth-child(8){transition-delay:.46s}.services.in .svc-cell:nth-child(9){transition-delay:.52s}
  .svc-ico{color:#fff; opacity:.92; transition:transform .45s cubic-bezier(.2,.7,.2,1);}
  .svc-ico svg{width:40px; height:40px; fill:none; stroke:currentColor; stroke-width:1.7; stroke-linecap:round; stroke-linejoin:round;}
  .svc-name{font-family:'Outfit'; font-weight:800; font-size:clamp(18px,1.6vw,24px); line-height:1; letter-spacing:-.02em; color:#fff; text-transform:lowercase;}
  .svc-cell:hover{background:#2D292B; border-color:#2D292B; transform:translateY(-6px); box-shadow:0 26px 54px -24px rgba(0,0,0,.5);}
  .svc-cell:hover .svc-ico{transform:translateX(4px) scale(1.08); opacity:1;}
  @media (max-width:900px){ .svc-grid{grid-template-columns:repeat(2,1fr);} }
  @media (max-width:540px){ .svc-grid{grid-template-columns:1fr;} .svc-cell{min-height:0;} }
  @media (prefers-reduced-motion: reduce){ .svc-cell{opacity:1; transform:none; transition:background .3s ease;} }

  /* ======================================================= */
  /* LET'S TALK — CTA band                                   */
  /* ======================================================= */
  .cta-band{position:relative; overflow:hidden; padding:clamp(90px,16vh,180px) 38px; text-align:center;
    background:linear-gradient(135deg,#FF5E30 0%,#F0471F 52%,#D33A12 100%);}
  .cta-band::after{content:''; position:absolute; right:-3%; bottom:-12%; width:min(52vh,460px); height:min(52vh,460px);
    background:url('assets/logo/zeleman-mark.png') no-repeat bottom right/contain; filter:brightness(0) invert(1); opacity:.09; z-index:0; pointer-events:none;}
  .cta-inner{position:relative; z-index:1; max-width:1000px; margin:0 auto;
    opacity:0; transform:translateY(30px); transition:opacity .8s ease, transform .8s cubic-bezier(.2,.7,.2,1);}
  .cta-band.in .cta-inner{opacity:1; transform:none;}
  .cta-kicker{font-family:'Outfit'; font-weight:600; font-size:clamp(15px,1.8vw,20px); letter-spacing:.02em; color:rgba(255,255,255,.85); margin-bottom:18px;}
  .cta-title{font-family:'Outfit'; font-weight:900; font-size:clamp(42px,8vw,108px); line-height:.92; letter-spacing:-.03em; color:#fff; text-transform:lowercase;}
  .cta-em{color:#2D292B;}
  .cta-sub{font-family:'Inter'; font-weight:400; font-size:clamp(15px,1.9vw,20px); line-height:1.55; color:rgba(255,255,255,.85); margin:clamp(16px,2.4vh,24px) auto 0; max-width:560px;}
  .cta-ar{font-size:1.1em; display:inline-block; transition:transform .35s cubic-bezier(.2,.7,.2,1);}
  /* contact form */
  .cta-form{max-width:620px; margin:clamp(34px,5vh,52px) auto 0; text-align:center;}
  .cf-hp{position:absolute; left:-9999px; width:1px; height:1px; opacity:0;}
  .cf-row{display:grid; grid-template-columns:1fr 1fr; gap:14px;}
  .cf-input{width:100%; background:#fff; border:1.5px solid transparent; border-radius:13px; padding:15px 18px;
    font-family:'Inter'; font-size:15px; color:var(--ink); margin-bottom:14px; outline:none; transition:box-shadow .25s ease, border-color .25s ease;}
  .cf-input::placeholder{color:#aaa6a2;}
  .cf-input:focus{border-color:var(--ink); box-shadow:0 0 0 3px rgba(45,41,43,.22);}
  .cf-area{resize:vertical; min-height:164px; line-height:1.5;}
  .cf-btn{display:inline-flex; align-items:center; justify-content:center; gap:10px; margin-top:4px; background:#2D292B; color:#fff;
    font-family:'Outfit'; font-weight:700; font-size:clamp(16px,1.6vw,18px); padding:17px 90px; border:none; border-radius:999px; cursor:pointer;
    box-shadow:0 16px 40px -16px rgba(0,0,0,.5); transition:transform .35s cubic-bezier(.2,.7,.2,1), background .3s ease, box-shadow .3s ease;}
  .cf-btn:hover{transform:translateY(-3px); background:#1c1a1b; box-shadow:0 22px 50px -16px rgba(0,0,0,.6);}
  .cf-btn:hover .cta-ar{transform:translateX(5px);}
  .cf-btn:disabled{opacity:.6; cursor:default; transform:none;}
  .cf-status{margin-top:16px; font-family:'Outfit'; font-weight:600; font-size:15px; color:#fff; min-height:1.2em;}
  @media (max-width:520px){ .cf-row{grid-template-columns:1fr;} }
  @media (prefers-reduced-motion: reduce){ .cta-inner{opacity:1; transform:none; transition:none;} }

  /* ======================================================= */
  /* CLIENTS — infinite marquee                              */
  /* ======================================================= */
  .clients{background:#ffffff; padding:clamp(70px,11vh,130px) 0; overflow:hidden;}
  .clients-head{text-align:center; padding:0 38px; margin-bottom:clamp(44px,6vh,68px);}
  .clients-title{font-family:'Outfit'; font-weight:900; font-size:clamp(34px,5.2vw,68px); line-height:1; text-transform:uppercase; letter-spacing:-.01em; color:var(--ink);}
  .clients-sub{font-family:'Outfit'; font-weight:600; color:#6b6663; font-size:clamp(18px,2.1vw,28px); margin-top:14px; letter-spacing:-.015em;}
  .marquee{overflow:hidden; -webkit-mask:linear-gradient(90deg,transparent,#000 8%,#000 92%,transparent); mask:linear-gradient(90deg,transparent,#000 8%,#000 92%,transparent);}
  .marquee + .marquee{margin-top:clamp(14px,2.4vh,30px);}
  .marquee-track{display:flex; align-items:center; gap:clamp(40px,5vw,80px); width:max-content; animation:marq 52s linear infinite; will-change:transform; -webkit-backface-visibility:hidden; backface-visibility:hidden; transform:translateZ(0);}
  .marquee-track.rev{animation-duration:46s; animation-direction:reverse;}
  .marquee:hover .marquee-track{animation-play-state:paused;}
  @keyframes marq{from{transform:translate3d(0,0,0);} to{transform:translate3d(-50%,0,0);}}
  .clients .logo{flex:0 0 auto; height:200px; display:flex; align-items:center; justify-content:center;}
  .clients .logo img{max-height:172px; max-width:360px; width:auto; object-fit:contain; filter:grayscale(1); opacity:.6; transition:opacity .3s ease, filter .3s ease, transform .3s ease;}
  .clients .logo:hover img{opacity:1; filter:grayscale(0); transform:scale(1.07);}
  @media (max-width:560px){ .clients .logo{height:112px;} .clients .logo img{max-height:96px; max-width:210px;} }
  @media (prefers-reduced-motion: reduce){
    .marquee{-webkit-mask:none; mask:none;}
    .marquee-track{animation:none; flex-wrap:wrap; width:auto; justify-content:center; gap:30px 48px; padding:0 38px;}
    .clients .logo img{opacity:.7;}
  }

  /* ======================================================= */
  /* STATS — "by the numbers"                                */
  /* ======================================================= */
  .stats{position:relative; background:#211D1F; color:#fff; padding:clamp(64px,10vh,120px) 38px; overflow:hidden;}
  .stats::before{content:''; position:absolute; left:50%; top:-30%; width:80vw; height:80vw; max-width:900px; max-height:900px; transform:translateX(-50%);
    background:radial-gradient(circle, rgba(240,71,31,.16) 0%, rgba(240,71,31,0) 62%); pointer-events:none;}
  .stats-inner{position:relative; max-width:1180px; margin:0 auto; text-align:center;}
  .stats-kicker{display:inline-block; font-family:'Outfit'; font-weight:600; font-size:13px; letter-spacing:.24em; text-transform:uppercase; color:#9b9491; margin-bottom:clamp(34px,5vh,54px);}
  .stats-kicker b{color:var(--orange); font-weight:600;}
  .stats-row{display:flex; justify-content:center; align-items:stretch; flex-wrap:wrap;}
  .stat{flex:1 1 0; min-width:170px; padding:8px 22px; opacity:0; transform:translateY(26px); transition:opacity .6s ease, transform .6s cubic-bezier(.2,.7,.2,1);}
  .stats.in .stat{opacity:1; transform:none;}
  .stats.in .stat:nth-child(1){transition-delay:.05s} .stats.in .stat:nth-child(3){transition-delay:.13s} .stats.in .stat:nth-child(5){transition-delay:.21s} .stats.in .stat:nth-child(7){transition-delay:.29s}
  .stat-num{font-family:'Outfit'; font-weight:900; font-size:clamp(48px,6.2vw,86px); line-height:.95; letter-spacing:-.02em; color:var(--orange); display:flex; align-items:baseline; justify-content:center;}
  .stat-num .plus{font-size:.62em; margin-left:.04em; transform:translateY(-.06em);}
  .stat-lab{font-family:'Outfit'; font-weight:600; font-size:clamp(14px,1.45vw,18px); color:#fff; margin-top:14px; letter-spacing:.005em;}
  .stat-div{width:1px; align-self:center; height:78px; background:linear-gradient(transparent,rgba(240,71,31,.85),transparent); transform:scaleY(0); transform-origin:center; transition:transform .7s cubic-bezier(.2,.7,.2,1) .2s;}
  .stats.in .stat-div{transform:scaleY(1);}
  @media (max-width:760px){
    .stats-row{gap:14px 0;}
    .stat{flex:1 1 40%; min-width:40%;}
    .stat-div{display:none;}
  }
  @media (prefers-reduced-motion: reduce){
    .stat, .stat-div{opacity:1; transform:none; transition:none;}
  }

  /* ======================================================= */
  /* FOOTER                                                  */
  /* ======================================================= */
  .footer{position:relative; background:#15100E; color:#fff; padding:clamp(70px,10vh,112px) 38px 28px; overflow:hidden;}
  .footer::before{content:''; position:absolute; top:0; left:0; right:0; height:3px; background:linear-gradient(90deg,#FF6A3D,#F0471F 50%,#D43A12);}
  .ft-glow{position:absolute; top:-46%; left:50%; transform:translateX(-50%); width:90vw; height:60vw; max-width:1000px; background:radial-gradient(circle, rgba(240,71,31,.16), rgba(240,71,31,0) 62%); pointer-events:none;}
  .ft-inner{position:relative; z-index:1; max-width:1240px; margin:0 auto;}
  .ft-grid{display:grid; grid-template-columns:1.5fr 1fr 1.65fr 1.15fr; gap:clamp(30px,4vw,56px);}
  .ft-logo{height:40px; width:auto;}
  .ft-tag{font-family:'Outfit'; font-weight:600; font-size:11.5px; letter-spacing:.16em; text-transform:uppercase; color:#9a938f; margin-top:18px;}
  .ft-blurb{font-family:'Inter'; font-size:14.5px; line-height:1.6; color:#b4aeaa; margin-top:16px; max-width:34ch;}
  .ft-social{display:flex; gap:12px; margin-top:24px;}
  .ft-social a{width:42px; height:42px; border-radius:50%; border:1px solid rgba(255,255,255,.18); display:flex; align-items:center; justify-content:center; color:#cfc9c6; transition:background .3s ease, border-color .3s ease, color .3s ease, transform .3s cubic-bezier(.2,.7,.2,1);}
  @media (hover:hover){ .ft-social a:hover{background:var(--orange); border-color:var(--orange); color:#fff; transform:translateY(-3px);} }
  .ft-social svg{width:17px; height:17px; fill:currentColor;}
  .ft-col h4{font-family:'Outfit'; font-weight:700; font-size:12.5px; letter-spacing:.14em; text-transform:uppercase; color:#fff; margin-bottom:18px;}
  .ft-col a{display:block; width:fit-content; color:#a39e9a; font-family:'Inter'; font-size:15px; text-decoration:none; padding:6px 0; text-transform:none; transition:color .25s ease, transform .25s cubic-bezier(.2,.7,.2,1);}
  @media (hover:hover){ .ft-col a:hover{color:var(--orange); transform:translateX(5px);} }
  .ft-fam{column-count:2; column-gap:34px;}
  .ft-fam h4{column-span:all;}
  .ft-fam a{text-transform:none; break-inside:avoid;}
  .ft-contact p{color:#a39e9a; font-family:'Inter'; font-size:15px; padding:6px 0;}
  .ft-talk{color:#fff !important; font-family:'Outfit' !important; font-weight:700 !important; margin-top:8px;}
  .ft-col a.ft-hot{display:flex; align-items:center; gap:9px; font-family:'Outfit'; font-weight:900; font-size:clamp(20px,1.9vw,26px); color:#fff;}
  .ft-col a.ft-hot svg{width:21px; height:21px; color:#fff; flex:none;}
  @media (hover:hover){ .ft-talk:hover{color:var(--orange) !important;} }
  .ft-wordmark{display:block; width:100%; max-width:1080px; height:auto; margin:clamp(28px,4.5vh,56px) auto 0; opacity:.13; user-select:none; pointer-events:none;}
  .ft-bottom{display:flex; flex-wrap:wrap; justify-content:space-between; align-items:center; gap:12px 24px; border-top:1px solid rgba(255,255,255,.1); padding-top:24px; margin-top:clamp(10px,2vh,24px);}
  .ft-bottom p, .ft-up{font-family:'Inter'; font-size:13px; color:#8a847f; margin:0; text-decoration:none;}
  .ft-up{transition:color .25s ease; text-transform:uppercase; letter-spacing:.08em; font-weight:600;}
  @media (hover:hover){ .ft-up:hover{color:var(--orange);} }
  @media (max-width:880px){ .ft-grid{grid-template-columns:1fr 1fr;} .ft-brand{grid-column:1/-1;} }
  @media (max-width:520px){ .ft-grid{grid-template-columns:0.78fr 1.22fr; gap:26px 16px;} .ft-fam{column-gap:18px;} .ft-brand{grid-column:1/-1;} .ft-contact{grid-column:1/-1;} .ft-bottom{justify-content:flex-start;} .ft-up{color:#F0471F;} }

  /* ======================================================= */
  /* SUB-PAGES (services + contact)                          */
  /* ======================================================= */
  .sp-hero{position:relative; min-height:64vh; display:flex; align-items:flex-end; overflow:hidden; background:var(--ink);}
  .sp-hero .sp-bg{position:absolute; inset:0; width:100%; height:100%; object-fit:cover; filter:grayscale(.35) brightness(.6); transform:scale(1.05); animation:spKen 14s ease-out forwards;}
  @keyframes spKen{to{transform:scale(1);}}
  .sp-hero::after{content:''; position:absolute; inset:0; background:linear-gradient(to top, rgba(18,14,12,.94), rgba(18,14,12,.25) 55%, rgba(18,14,12,.6)); z-index:1;}
  .sp-hero-inner{position:relative; z-index:2; max-width:1320px; margin:0 auto; width:100%; padding:120px 38px clamp(48px,8vh,88px);}
  .sp-crumb{font-family:'Outfit'; font-weight:600; font-size:13px; letter-spacing:.14em; text-transform:uppercase; color:var(--orange); margin-bottom:18px;}
  .sp-crumb a{color:rgba(255,255,255,.65); text-decoration:none; transition:color .2s;}
  .sp-crumb a:hover{color:#fff;}
  .sp-title{font-family:'Outfit'; font-weight:900; font-size:clamp(44px,8vw,104px); line-height:.92; letter-spacing:-.03em; color:#fff; text-transform:lowercase;}
  .sp-tagline{font-family:'Outfit'; font-weight:600; font-size:clamp(18px,2.3vw,30px); line-height:1.25; color:#fff; max-width:26ch; margin-top:20px; letter-spacing:-.01em;}
  .reveal-up{opacity:0; transform:translateY(70px); transition:opacity .9s ease, transform 1.15s cubic-bezier(.16,1,.3,1);}
  .reveal-up.in{opacity:1; transform:none;}

  .sp-intro{background:#fff; padding:clamp(72px,12vh,150px) 38px;}
  .sp-intro-inner{max-width:1320px; margin:0 auto; display:grid; grid-template-columns:1fr 1fr; gap:clamp(30px,5vw,80px); align-items:start;}
  .sp-lead{font-family:'Outfit'; font-weight:800; font-size:clamp(26px,3.2vw,46px); line-height:1.12; letter-spacing:-.025em; color:var(--ink); margin:0;}
  .sp-lead .em{color:var(--orange);}
  .sp-body{font-family:'Inter'; font-size:clamp(16px,1.25vw,18px); line-height:1.85; color:#57534f;}
  .sp-body p{margin:0;}
  .sp-body p + p{margin-top:18px;}
  @media (max-width:820px){ .sp-intro-inner{grid-template-columns:1fr; gap:26px;} }

  /* capabilities — interlocking cards (matches homepage "what we do") */
  .sp-caps{position:relative; background:#15100E; color:#fff; padding:clamp(72px,12vh,150px) 38px; overflow:hidden;}
  .sp-caps::after{content:''; position:absolute; right:-3%; top:4%; width:min(40vh,360px); height:min(40vh,360px); background:url('assets/logo/zeleman-mark.png') no-repeat top right/contain; filter:brightness(0) invert(1); opacity:.12; pointer-events:none;}
  .sp-caps-inner{position:relative; z-index:1; max-width:1320px; margin:0 auto;}
  .sp-caps-kicker{font-family:'Outfit'; font-weight:600; font-size:13px; letter-spacing:.2em; text-transform:uppercase; color:var(--orange); margin-bottom:14px;}
  .sp-caps h2{font-family:'Outfit'; font-weight:900; font-size:clamp(32px,5vw,66px); text-transform:lowercase; letter-spacing:-.03em; color:#fff; margin-bottom:clamp(36px,5vh,56px);}
  .sp-cap-grid{display:grid; grid-template-columns:repeat(auto-fit,minmax(280px,1fr)); gap:28px 24px;}
  .sp-cap{position:relative; padding:120px 26px 28px; min-height:228px; display:flex; flex-direction:column; overflow:visible;
    filter:drop-shadow(0 14px 22px rgba(45,41,43,.18)); transition:transform .55s cubic-bezier(.2,.7,.2,1), filter .4s ease;}
  .sp-cap::before{content:''; position:absolute; inset:0; z-index:0; background:#fff; border-radius:14px;
    -webkit-mask:url("data:image/svg+xml,%3Csvg%20xmlns='http://www.w3.org/2000/svg'%20width='120'%20height='114'%3E%3Cpath%20d='M0,0%20L120,0%20L120,92%20A22,22%200%200%201%2098,114%20L0,114%20Z'%20fill='%23000'/%3E%3C/svg%3E") top left/120px 114px no-repeat, linear-gradient(#000 0 0);
    -webkit-mask-composite:xor;
    mask:url("data:image/svg+xml,%3Csvg%20xmlns='http://www.w3.org/2000/svg'%20width='120'%20height='114'%3E%3Cpath%20d='M0,0%20L120,0%20L120,92%20A22,22%200%200%201%2098,114%20L0,114%20Z'%20fill='%23000'/%3E%3C/svg%3E") top left/120px 114px no-repeat, linear-gradient(#000 0 0);
    mask-composite:exclude;}
  .sp-cap-num{position:absolute; top:0; left:0; z-index:3; width:100px; height:96px; display:flex; align-items:center; justify-content:center;
    border-radius:14px 12px 12px 12px; background:linear-gradient(160deg,#FF5E30,#E5400F); color:#fff;
    font-family:'Outfit'; font-weight:900; font-size:36px; line-height:.9; letter-spacing:-.03em; transition:transform .5s cubic-bezier(.2,.7,.2,1);}
  .sp-cap-num::after{content:''; position:absolute; left:50%; transform:translateX(-50%); bottom:-9px; width:0; height:0; border-left:12px solid transparent; border-right:12px solid transparent; border-top:10px solid #E5400F;}
  .sp-cap .sp-cap-ico{position:absolute; top:30px; right:28px; z-index:2; color:#F0471F; line-height:0; transition:transform .45s cubic-bezier(.2,.7,.2,1);}
  .sp-cap .sp-cap-ico svg{width:34px; height:34px; fill:none !important; stroke:currentColor; stroke-width:1.6; stroke-linecap:round; stroke-linejoin:round;}
  .sp-cap-text{position:relative; z-index:1;}
  .sp-cap h3{display:flex; align-items:center; gap:10px; font-family:'Outfit'; font-weight:800; font-size:clamp(15px,1.3vw,18px); line-height:1.15; letter-spacing:.01em; color:#2D292B; text-transform:uppercase;}
  .sp-cap-plus{display:none;}
  .sp-cap p{font-family:'Inter'; font-size:13px; line-height:1.55; color:#6b655f; margin-top:10px;}
  .sp-cap:hover{transform:translateY(-7px); filter:drop-shadow(0 26px 30px rgba(45,41,43,.26));}
  .sp-cap:hover .sp-cap-num{transform:translateY(-3px) scale(1.05);}
  .sp-cap:hover .sp-cap-ico{transform:scale(1.1) rotate(-4deg);}

  /* sub-page CTA button (reuses .cta-band) */
  .cta-btn2{display:inline-flex; align-items:center; gap:12px; margin-top:clamp(30px,5vh,50px); background:#2D292B; color:#fff; font-family:'Outfit'; font-weight:700; font-size:clamp(16px,1.7vw,19px); padding:18px 42px; border-radius:999px; text-decoration:none; box-shadow:0 16px 40px -16px rgba(0,0,0,.5); transition:transform .35s cubic-bezier(.2,.7,.2,1), background .3s ease, box-shadow .3s ease;}
  .cta-btn2:hover{transform:translateY(-3px); background:#1c1a1b; box-shadow:0 22px 50px -16px rgba(0,0,0,.6);}
  .cta-btn2 .ar{transition:transform .35s cubic-bezier(.2,.7,.2,1);}
  .cta-btn2:hover .ar{transform:translateX(5px);}

  /* ===== CONTACT PAGE ===== */
  .cp{background:#fff; padding:clamp(60px,9vh,110px) 38px clamp(40px,7vh,90px);}
  .cp-inner{max-width:1320px; margin:0 auto; display:grid; grid-template-columns:1.05fr .95fr; gap:clamp(36px,5vw,76px); align-items:start;}
  .cp-form .cf-row{display:grid; grid-template-columns:1fr 1fr; gap:14px;}
  .cp-form .cf-input{width:100%; background:#F4F3F1; border:1.5px solid #e7e4e1; border-radius:13px; padding:15px 18px; font-family:'Inter'; font-size:15px; color:var(--ink); margin-bottom:14px; outline:none; transition:border-color .25s ease, box-shadow .25s ease;}
  .cp-form .cf-input::placeholder{color:#9a958f;}
  .cp-form .cf-input:focus{border-color:var(--orange); box-shadow:0 0 0 3px rgba(240,71,31,.16);}
  .cp-form .cf-area{resize:vertical; min-height:150px; line-height:1.5;}
  .cp-form .cf-btn{display:inline-flex; align-items:center; justify-content:center; gap:10px; margin-top:4px; background:var(--orange); color:#fff; font-family:'Outfit'; font-weight:700; font-size:17px; padding:17px 64px; border:none; border-radius:999px; cursor:pointer; box-shadow:0 16px 40px -16px rgba(240,71,31,.6); transition:transform .35s cubic-bezier(.2,.7,.2,1), background .3s ease;}
  .cp-form .cf-btn:hover{transform:translateY(-3px); background:var(--orange-deep);}
  .cp-form .cf-btn:disabled{opacity:.6; cursor:default; transform:none;}
  .cp-form .cf-hp{position:absolute; left:-9999px; width:1px; height:1px; opacity:0;}
  .cp-form .cf-status{margin-top:14px; font-family:'Outfit'; font-weight:600; font-size:15px; color:var(--orange); min-height:1.2em;}
  .cp-detail{display:flex; flex-direction:column; gap:26px;}
  .cp-card{background:#15100E; color:#fff; border-radius:18px; padding:28px 30px; position:relative; overflow:hidden;}
  .cp-card .lbl{font-family:'Outfit'; font-weight:700; font-size:12px; letter-spacing:.16em; text-transform:uppercase; color:var(--orange); margin-bottom:10px;}
  .cp-card a, .cp-card p{font-family:'Outfit'; font-weight:700; font-size:clamp(18px,1.8vw,23px); color:#fff; text-decoration:none; line-height:1.3; margin:0;}
  .cp-card a:hover{color:var(--orange);}
  .cp-card a.cp-hot{display:flex; align-items:center; gap:10px; margin-top:14px;}
  .cp-card a.cp-hot svg{width:26px; height:26px; flex:none; color:var(--orange);}
  .cp-card a.cp-hot b{font-family:'Outfit'; font-weight:900; font-size:clamp(24px,2.2vw,30px); line-height:1; color:#fff; letter-spacing:.02em;}
  .cp-card a.cp-hot:hover b{color:var(--orange);}
  .cp-social{display:flex; gap:12px;}
  .cp-social a{width:46px; height:46px; border-radius:50%; border:1px solid #e0ddda; display:flex; align-items:center; justify-content:center; color:var(--ink); transition:background .3s,border-color .3s,color .3s,transform .3s;}
  .cp-social a:hover{background:var(--orange); border-color:var(--orange); color:#fff; transform:translateY(-3px);}
  .cp-social svg{width:18px; height:18px; fill:currentColor;}
  .cp-map{position:relative; max-width:none; margin:0; padding:0;}
  .cp-map iframe{width:100%; height:clamp(380px,60vh,640px); border:0; border-radius:0; filter:grayscale(.4) contrast(1.05); display:block;}
  /* fun "we are here" waving character over the Snap Plaza pin (map centre) */
  .map-here{position:absolute; left:50%; top:50%; transform:translate(-50%, calc(-100% - 22px)); z-index:3; pointer-events:none; display:flex; flex-direction:column; align-items:center; gap:4px;}
  .map-here-bubble{position:relative; background:var(--orange); color:#fff; font-family:'Outfit',sans-serif; font-weight:800; font-size:clamp(14px,1.6vw,19px); letter-spacing:-.01em; line-height:1; padding:10px 17px; border-radius:999px; white-space:nowrap; box-shadow:0 12px 26px -8px rgba(240,71,31,.6); animation:mapBob 2.4s ease-in-out infinite;}
  .map-here-bubble::after{content:''; position:absolute; left:50%; bottom:-7px; transform:translateX(-50%); border:7px solid transparent; border-bottom:0; border-top-color:var(--orange);}
  .map-here-girl{width:auto; height:clamp(76px,11vh,120px); filter:drop-shadow(0 10px 14px rgba(0,0,0,.3));}
  .map-here-girl .wave-arm{transform-box:fill-box; transform-origin:50% 100%; animation:mapWave 1.1s ease-in-out infinite;}
  @keyframes mapBob{0%,100%{transform:translateY(0);}50%{transform:translateY(-5px);}}
  @keyframes mapWave{0%,100%{transform:rotate(6deg);}50%{transform:rotate(-22deg);}}
  @media (max-width:560px){ .map-here{transform:translate(-50%, calc(-100% - 14px));} .map-here-girl{height:72px;} .map-here-bubble{font-size:12px; padding:7px 13px;} }
  @media (prefers-reduced-motion: reduce){ .map-here-bubble, .map-here-girl .wave-arm{animation:none;} }
  @media (max-width:820px){ .cp-inner{grid-template-columns:1fr; gap:30px;} .cp-form .cf-row{grid-template-columns:1fr;} }

  /* ===== ABOUT PAGE ===== */
  .about-kicker{font-family:'Outfit'; font-weight:700; font-size:13px; letter-spacing:.16em; text-transform:uppercase; color:var(--orange); margin-bottom:18px;}
  .about-story .sp-lead .em{color:var(--orange);}
  .about-award{position:relative; background:#fff; color:#15100E; padding:clamp(70px,11vh,140px) 38px; overflow:hidden;}
  .about-award::before{display:none;}
  .award-inner{max-width:1320px; margin:0 auto; display:grid; grid-template-columns:1.15fr .85fr; gap:clamp(36px,5vw,76px); align-items:center;}
  .award-kicker{font-family:'Outfit'; font-weight:700; font-size:13px; letter-spacing:.16em; text-transform:uppercase; color:var(--orange); margin-bottom:18px;}
  .about-award h2{font-family:'Outfit'; font-weight:900; font-size:clamp(30px,4.6vw,62px); line-height:1; letter-spacing:-.03em; text-transform:lowercase; color:#15100E;}
  .award-body{font-family:'Inter'; font-size:clamp(15px,1.3vw,18px); line-height:1.75; color:#5e5851; margin-top:24px; max-width:48ch;}
  .award-img{justify-self:center;}
  .award-img img{max-width:100%; width:auto; max-height:430px; border-radius:18px; box-shadow:0 34px 70px -28px rgba(0,0,0,.7);}
  @media (max-width:820px){ .award-inner{grid-template-columns:1fr; gap:30px;} .award-img{order:-1;} }

  /* ===== About: "the latest" update blocks (Academy, Craft Addis) ===== */
  .upd{position:relative; padding:clamp(64px,10vh,128px) 38px;}
  .upd--light{background:#fff;}
  .upd--tint{background:linear-gradient(180deg,#F5F4F1,#ECEAE5);}

  /* creative bg — soft warm corner glows + faint dot-grid on light sections (matches homepage) */
  .sp-intro, .clients, .cp, .upd--light, .about-award{
    background-image:
      radial-gradient(125% 82% at 90% -20%, rgba(240,71,31,.30), rgba(240,71,31,.10) 42%, transparent 72%),
      radial-gradient(115% 75% at -18% 120%, rgba(240,71,31,.20), transparent 68%),
      radial-gradient(rgba(45,41,43,.09) 1.6px, transparent 1.8px);
    background-repeat:no-repeat, no-repeat, repeat;
    background-size:auto, auto, 26px 26px;}
  .upd-inner{max-width:1320px; margin:0 auto; display:grid; grid-template-columns:1fr 1fr; gap:clamp(36px,5vw,76px); align-items:center;}
  .upd.alt .upd-media{order:-1;}
  .upd-eyebrow{display:inline-flex; align-items:center; gap:9px; font-family:'Outfit'; font-weight:700; font-size:12px; letter-spacing:.16em; text-transform:uppercase; color:var(--orange); margin-bottom:20px;}
  .upd-eyebrow::before{content:''; width:26px; height:2px; background:var(--orange);}
  .upd-logo{display:block; height:38px; width:auto; margin-bottom:22px;}
  .upd-mark{display:block; height:54px; width:auto; margin-bottom:20px;}
  .upd h2{font-family:'Outfit'; font-weight:900; font-size:clamp(28px,4vw,52px); line-height:1.04; letter-spacing:-.02em; text-transform:lowercase; color:#15100E;}
  .upd-body{font-family:'Inter'; font-size:clamp(15px,1.25vw,17.5px); line-height:1.78; color:#5e5851; margin-top:22px; max-width:52ch;}
  .upd-link{display:inline-flex; align-items:center; gap:9px; margin-top:28px; font-family:'Outfit'; font-weight:700; font-size:14.5px; letter-spacing:.01em; color:var(--orange); text-decoration:none;}
  .upd-link .ar{transition:transform .3s ease;}
  .upd-link:hover .ar{transform:translateX(5px);}
  /* video thumbnail with play */
  .upd-video{position:relative; display:block; width:100%; padding:0; border:0; cursor:pointer; border-radius:16px; overflow:hidden; aspect-ratio:16/9; background:#000; box-shadow:0 34px 66px -30px rgba(45,41,43,.46);}
  .upd-video img{width:100%; height:100%; object-fit:cover; display:block; transition:transform .65s cubic-bezier(.2,.7,.2,1);}
  .upd-video:hover img{transform:scale(1.06);}
  .upd-video::after{content:''; position:absolute; inset:0; background:linear-gradient(to top, rgba(0,0,0,.32), transparent 55%);}
  .upd-play{position:absolute; z-index:2; top:50%; left:50%; transform:translate(-50%,-50%); width:76px; height:76px; border-radius:50%; background:rgba(15,16,16,.82); backdrop-filter:blur(4px); display:flex; align-items:center; justify-content:center; transition:transform .4s cubic-bezier(.2,.7,.2,1), background .3s ease; box-shadow:0 16px 34px -10px rgba(0,0,0,.6);}
  .upd-video:hover .upd-play{transform:translate(-50%,-50%) scale(1.1); background:#000;}
  .upd-play svg{width:26px; height:26px; fill:#fff; margin-left:4px;}
  .upd-photo{display:block; width:100%; max-width:430px; margin:0 auto; border-radius:16px; overflow:hidden; box-shadow:0 34px 66px -30px rgba(45,41,43,.46);}
  .upd-photo img{width:100%; height:auto; display:block;}
  .upd-body a{color:var(--orange); text-decoration:underline; text-underline-offset:2px; text-decoration-thickness:1px;}
  @media (max-width:820px){ .upd-inner{grid-template-columns:1fr; gap:28px;} .upd .upd-media{order:-1;} }

  /* per-page hero focal adjustments */
  .pg-creative .sp-hero .sp-bg{animation:none; transform:scale(1.32) translateX(11%); transform-origin:center;}
  @media (max-width:760px){ .pg-creative .sp-hero .sp-bg{transform:scale(1.18) translateX(6%);} }


  /* digital hero — a touch darker */
  .pg-digital .sp-hero .sp-bg{filter:grayscale(.4) brightness(.48);}

  /* btl hero — lighter (image is already moody) */
  .pg-btl-experiential .sp-hero .sp-bg{filter:grayscale(.25) brightness(.85);}
  .pg-btl-experiential .sp-hero::after{background:linear-gradient(to top, rgba(18,14,12,.86), rgba(18,14,12,.12) 52%, rgba(18,14,12,.4));}



  /* media planning hero — darkened collage, left-dark for headline */
  .pg-media-planning .sp-hero{background:#15100E;}
  .pg-media-planning .sp-hero::after{background:linear-gradient(100deg, rgba(18,14,12,.95) 0%, rgba(18,14,12,.78) 30%, rgba(18,14,12,.52) 58%, rgba(18,14,12,.34) 100%);}

  /* research hero — a touch darker */
  .pg-research-insights .sp-hero .sp-bg{filter:grayscale(.4) brightness(.48);}

  /* media monitoring hero — a touch darker */
  .pg-media-monitoring .sp-hero .sp-bg{filter:grayscale(.45) brightness(.33);}

  /* media planning — full-bleed collage, darkened a touch */
  .pg-media-planning .sp-hero .sp-bg{object-fit:cover; object-position:center; filter:brightness(.78) grayscale(1); transform:none; animation:none; opacity:1;}

  /* pr & special events hero — concert shot, a touch darker */
  .pg-pr-special-events .sp-hero .sp-bg{filter:grayscale(.35) brightness(.46);}

  /* contact hero — orange phone right, text left */

  .pg-newsroom .sp-hero .sp-bg{filter:grayscale(.5) brightness(.55) contrast(1.03); animation:none; transform:scale(1.04); object-position:center 92%;}
  .pg-newsroom .sp-hero::after{background:linear-gradient(to top, rgba(18,14,12,.82), rgba(18,14,12,.4) 55%, rgba(18,14,12,.58));}
  .pg-contact .sp-hero .sp-bg{filter:brightness(.92); object-position:center; transform:scale(1.12) translateX(5%); animation:none;}
  .pg-contact .sp-hero::after{background:linear-gradient(100deg, rgba(18,14,12,.95) 0%, rgba(18,14,12,.62) 40%, rgba(18,14,12,.2) 68%, rgba(18,14,12,.05) 100%);}
  .pg-contact .sp-tag-row{display:flex; align-items:center; justify-content:space-between; gap:24px; margin-top:20px;}
  .pg-contact .sp-tag-row .sp-tagline{margin-top:0;}
  .pg-contact .cp-hotline{display:inline-flex; align-items:center; gap:9px; color:var(--orange); text-decoration:none; flex:none; margin-right:229px;}
  .pg-contact .cp-hotline .cp-hot-ico{width:clamp(34px,3.2vw,46px); height:auto; color:var(--orange); flex:none;}
  .pg-contact .cp-hotline b{font-family:'Outfit'; font-weight:900; font-size:clamp(34px,3.2vw,46px); line-height:1; letter-spacing:.01em; color:#fff;}
  @media (max-width:980px){ .pg-contact .cp-hotline{margin-right:0;} }

  /* About: film awards slider (black section, caption below image) */
  .awards{position:relative; background:#0d0a09; color:#fff; padding:clamp(64px,10vh,128px) 38px; overflow:hidden;}
  .awards-inner{max-width:1320px; margin:0 auto; text-align:center;}
  .awards-kicker{font-family:'Outfit'; font-weight:700; font-size:13px; letter-spacing:.2em; text-transform:uppercase; color:#fff; margin-bottom:14px;}
  .awards-title{font-family:'Outfit'; font-weight:900; font-size:clamp(30px,4.6vw,60px); line-height:1; letter-spacing:-.03em; text-transform:lowercase; color:#fff; margin-bottom:clamp(34px,5vh,54px);}
  .aw-slider{position:relative; max-width:1244px; margin:0 auto;}
  .aw-viewport{overflow:hidden;}
  .aw-track{display:flex; transition:transform .6s cubic-bezier(.2,.7,.2,1);}
  .aw-slide{flex:0 0 100%; min-width:100%; display:flex; flex-direction:column; align-items:center;}
  .aw-imgwrap{width:100%; max-width:1060px; margin:0 auto; height:clamp(300px,54vh,580px); display:flex; align-items:center; justify-content:center;}
  .aw-imgwrap img{max-width:100%; max-height:100%; width:auto; object-fit:contain;}
  .aw-cap{font-family:'Outfit'; font-weight:700; font-size:clamp(16px,1.7vw,21px); letter-spacing:.01em; color:#fff; margin-top:20px;}
  .aw-nav{display:contents;}
  .aw-arrow{position:absolute; top:40%; transform:translateY(-50%); width:48px; height:48px; border-radius:50%; border:1px solid rgba(255,255,255,.25); background:rgba(255,255,255,.06); color:#fff; font-size:26px; line-height:1; cursor:pointer; display:flex; align-items:center; justify-content:center; transition:background .25s ease, border-color .25s ease; z-index:2;}
  .aw-arrow:hover{background:var(--orange); border-color:var(--orange);}
  .aw-prev{left:0;} .aw-next{right:0;}
  .aw-dots{display:flex; justify-content:center; gap:10px; margin-top:26px;}
  .aw-dot{width:9px; height:9px; border-radius:50%; border:none; padding:0; background:rgba(255,255,255,.28); cursor:pointer; transition:background .25s ease, width .25s ease;}
  .aw-dot.active{background:var(--orange); width:26px; border-radius:5px;}
  @media (max-width:640px){
    .awards{padding:clamp(48px,8vh,80px) 24px;}
    .awards-title{margin-bottom:18px;}
    .aw-imgwrap{height:auto; max-width:none;}
    .aw-imgwrap img{width:100%; height:auto; max-height:none;}
    .aw-nav{display:flex; justify-content:center; gap:22px; margin:18px 0 0;}
    .aw-arrow{position:static; transform:none; top:auto; width:44px; height:44px; font-size:22px;}
    .aw-prev, .aw-next{left:auto; right:auto;}
    .aw-cap{margin-top:14px;}
    .aw-dots{margin-top:20px;}
  }
