/* KRIBI WISE FACILITIES AND SERVICES SARL — 2026 premium, mobile-first */

:root{
  --bg: #ffffff;
  --surface: rgba(11,18,14,.045);
  --surface2: rgba(11,18,14,.070);
  --stroke: rgba(11,18,14,.12);
  --text: rgba(6,12,8,.92);
  --muted: rgba(6,12,8,.74);
  --muted2: rgba(6,12,8,.58);

  --g1:#1a7c2a; /* logo-inspired green */
  --g2:#79c11a; /* logo-inspired lime */
  --a: #1a7c2a;
  --a2: #79c11a;

  --shadow: 0 18px 60px rgba(10,18,12,.14);
  --shadow2: 0 10px 28px rgba(10,18,12,.12);

  --r-xs: 10px;
  --r-sm: 14px;
  --r-md: 18px;
  --r-lg: 26px;

  --container: 1120px;

  --fontDisplay: "Fraunces", serif;
  --fontBody: "Spline Sans", sans-serif;
}

@media (prefers-reduced-motion: reduce){
  *, *::before, *::after { animation: none !important; transition: none !important; scroll-behavior: auto !important; }
}

*{ box-sizing:border-box; }
html{ scroll-behavior:smooth; }
body{
  margin:0;
  font-family: var(--fontBody);
  background: var(--bg);
  color: var(--text);
  overflow-x:hidden;
}
a{ color:inherit; text-decoration:none; }
img{ max-width:100%; height:auto; display:block; }
button, input, textarea { font: inherit; }

.sr-only{
  position:absolute !important;
  width:1px;
  height:1px;
  padding:0;
  margin:-1px;
  overflow:hidden;
  clip: rect(0,0,0,0);
  white-space:nowrap;
  border:0;
}

.skip-link{
  position:absolute; left:-999px; top:auto;
  width:1px; height:1px; overflow:hidden;
}
.skip-link:focus{
  left: 12px; top: 12px; width:auto; height:auto;
  padding: 10px 12px; border-radius: 12px;
  background: rgba(255,255,255,.92); border: 1px solid var(--stroke);
  box-shadow: var(--shadow2);
  z-index: 9999;
}

.container{
  width:min(100% - 28px, var(--container));
  margin-inline:auto;
}

.noise{
  position: fixed;
  inset: 0;
  pointer-events: none;
  opacity: .10;
  background-image:
    url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='260' height='260'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.85' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='260' height='260' filter='url(%23n)' opacity='.35'/%3E%3C/svg%3E");
  mix-blend-mode: multiply;
  z-index: 0;
}

/* Header */
.site-header{
  position: sticky;
  top: 0;
  z-index: 1200;
  backdrop-filter: blur(14px);
  -webkit-backdrop-filter: blur(14px);
  background: rgba(255,255,255,.72);
  border-bottom: 1px solid rgba(11,18,14,.08);
  transition: transform .35s ease, background .35s ease, border-color .35s ease;
  will-change: transform;
}
.site-header.is-hidden{ transform: translateY(-100%); }
.header-inner{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap: 12px;
  padding: 12px 0;
}
.brand{
  display:flex;
  align-items:center;
  gap: 10px;
  min-width: 0;
}
.brand img{ width: 38px; height: 38px; border-radius: 999px; border: 1px solid rgba(11,18,14,.10); background: rgba(255,255,255,.85); }
.brand-title{
  display:flex;
  flex-direction:column;
  gap:2px;
  min-width: 0;
}
.brand-title strong{
  font-weight: 650;
  font-size: 14px;
  letter-spacing:.2px;
  white-space:nowrap;
  overflow:hidden;
  text-overflow:ellipsis;
}
.brand-title span{
  font-size: 12px;
  color: var(--muted2);
  white-space:nowrap;
  overflow:hidden;
  text-overflow:ellipsis;
}

.nav-desktop{ display:none; }
.nav-desktop a{
  position: relative;
  padding: 8px 10px;
  font-size: 13px;
  color: var(--muted);
}
.nav-desktop a::after{
  content:"";
  position:absolute;
  left: 10px; right: 10px; bottom: 5px;
  height: 2px;
  background: linear-gradient(90deg, var(--g2), var(--g1));
  transform: scaleX(0);
  transform-origin: left;
  transition: transform .24s ease;
  opacity:.9;
}
.nav-desktop a:hover{ color: var(--text); }
.nav-desktop a:hover::after{ transform: scaleX(1); }
.nav-desktop a[aria-current="page"]{
  color: var(--text);
}
.nav-desktop a[aria-current="page"]::after{
  transform: scaleX(1);
  opacity: 1;
}

.menu-btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap: 8px;
  border: 1px solid rgba(11,18,14,.14);
  background: rgba(255,255,255,.78);
  color: var(--text);
  border-radius: 999px;
  padding: 10px 12px;
  box-shadow: 0 10px 22px rgba(10,18,12,.10);
}
.menu-btn:focus-visible{ outline: 2px solid rgba(26,124,42,.35); outline-offset: 3px; }

/* Mobile menu */
.menu-overlay{
  position: fixed;
  inset: 0;
  background: rgba(9,14,10,.28);
  opacity: 0;
  pointer-events: none;
  transition: opacity .25s ease;
  z-index: 1250;
}
.menu-overlay.is-open{
  opacity: 1;
  pointer-events: auto;
}
.menu-panel{
  position: absolute;
  right: 0;
  top: 0;
  height: 100%;
  width: min(92vw, 380px);
  background:
    radial-gradient(800px 420px at 20% 10%, rgba(121,193,26,.16), transparent 65%),
    radial-gradient(660px 320px at 60% 40%, rgba(26,124,42,.14), transparent 62%),
    rgba(255,255,255,.96);
  border-left: 1px solid rgba(11,18,14,.10);
  transform: translateX(104%);
  transition: transform .35s cubic-bezier(.2,.9,.2,1);
  box-shadow: var(--shadow);
  padding: 18px 16px;
}
.menu-overlay.is-open .menu-panel{ transform: translateX(0); }
.menu-top{
  display:flex;
  justify-content:space-between;
  align-items:center;
  gap: 10px;
  padding-bottom: 10px;
  border-bottom: 1px solid rgba(11,18,14,.10);
}
.menu-close{
  border: 1px solid rgba(11,18,14,.14);
  background: rgba(255,255,255,.72);
  color: var(--text);
  border-radius: 999px;
  padding: 10px 12px;
}
.menu-links{
  display:flex;
  flex-direction:column;
  gap: 6px;
  padding: 14px 0;
}
.menu-links a{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap: 12px;
  padding: 12px 12px;
  border-radius: 14px;
  border: 1px solid rgba(11,18,14,.10);
  background: rgba(255,255,255,.70);
  color: var(--text);
}
.menu-links a span{ color: var(--muted2); font-size: 12px; }
.menu-links a:hover{ border-color: rgba(26,124,42,.22); background: rgba(121,193,26,.10); }
.menu-links a[aria-current="page"]{ border-color: rgba(26,124,42,.32); background: rgba(121,193,26,.14); }

/* Hero */
.hero{
  position: relative;
  padding: 34px 0 22px;
  z-index: 1;
}
.hero::before{
  content:"";
  position:absolute;
  inset: -240px -120px auto -120px;
  height: 520px;
  background:
    radial-gradient(520px 300px at 24% 36%, rgba(121,193,26,.30), transparent 60%),
    radial-gradient(520px 320px at 74% 46%, rgba(26,124,42,.28), transparent 62%),
    radial-gradient(420px 280px at 52% 6%, rgba(121,193,26,.16), transparent 62%);
  filter: blur(6px);
  opacity: .95;
  pointer-events:none;
}
.hero-grid{
  display:grid;
  grid-template-columns: 1fr;
  gap: 16px;
}
.eyebrow{
  display:inline-flex;
  align-items:center;
  gap: 8px;
  font-size: 12px;
  color: var(--muted);
  padding: 7px 10px;
  border: 1px solid rgba(255,255,255,.10);
  background: rgba(255,255,255,.04);
  border-radius: 999px;
  width: fit-content;
}
.eyebrow i{ color: var(--a); }
.hero h1{
  margin: 10px 0 8px;
  font-family: var(--fontDisplay);
  font-variation-settings: "opsz" 144, "wght" 600;
  line-height: 1.05;
  letter-spacing: -.02em;
  font-size: clamp(34px, 8vw, 54px);
}
.hero p{
  margin: 0 0 16px;
  color: var(--muted);
  font-size: 15px;
  line-height: 1.55;
}
.hero .keyline{
  margin-top: 14px;
  padding: 14px 14px;
  border-radius: var(--r-md);
  border: 1px solid rgba(255,255,255,.10);
  background: rgba(255,255,255,.04);
}
.hero .keyline strong{
  display:block;
  font-size: 12px;
  letter-spacing: .08em;
  text-transform: uppercase;
  color: var(--muted2);
  margin-bottom: 6px;
}
.hero .keyline span{
  font-size: 14px;
  color: rgba(255,255,255,.86);
}

.cta-row{
  display:flex;
  gap: 10px;
  flex-wrap: wrap;
  margin-top: 14px;
}
.btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap: 10px;
  border-radius: 999px;
  padding: 12px 14px;
  border: 1px solid rgba(255,255,255,.12);
  background: rgba(255,255,255,.06);
  color: var(--text);
  box-shadow: 0 14px 30px rgba(10,18,12,.12);
  transition: transform .18s ease, box-shadow .18s ease, background .18s ease, border-color .18s ease;
  will-change: transform;
}
.btn:hover{ transform: translateY(-1px); box-shadow: 0 20px 44px rgba(10,18,12,.14); border-color: rgba(26,124,42,.20); }
.btn:active{ transform: translateY(0); }
.btn:focus-visible{ outline: 2px solid rgba(26,124,42,.32); outline-offset: 3px; }
.btn-primary{
  border-color: rgba(26,124,42,.22);
  background: linear-gradient(180deg, rgba(121,193,26,.22), rgba(26,124,42,.14));
}
.btn-primary i{ color: var(--g1); }
.btn-ghost{
  background: rgba(255,255,255,.70);
}

/* Sections */
section{
  position: relative;
  z-index: 1;
  padding: 26px 0;
}
.section-head{
  display:flex;
  align-items:flex-end;
  justify-content:space-between;
  gap: 12px;
  margin-bottom: 14px;
}
.section-head h2{
  margin: 0;
  font-family: var(--fontDisplay);
  font-variation-settings: "opsz" 144, "wght" 560;
  letter-spacing: -.01em;
  font-size: clamp(20px, 4.8vw, 28px);
}
.section-head p{
  margin: 0;
  color: var(--muted2);
  font-size: 13px;
  max-width: 44ch;
}

.grid{
  display:grid;
  grid-template-columns: 1fr;
  gap: 12px;
}
.card{
  border-radius: var(--r-lg);
  border: 1px solid rgba(15,20,17,.12);
  background: #ffffff;
  box-shadow: 0 10px 26px rgba(10,18,12,.08), 0 2px 8px rgba(10,18,12,.05);
  overflow:hidden;
  transition: transform .2s ease, box-shadow .2s ease, border-color .2s ease;
}
.card:hover{
  transform: translateY(-3px);
  border-color: rgba(26,124,42,.22);
  box-shadow: 0 16px 34px rgba(10,18,12,.11), 0 4px 12px rgba(10,18,12,.08);
}
.card-inner{
  padding: 18px 18px;
}
.card h3{
  margin: 0 0 8px;
  font-size: 17px;
  letter-spacing: -.01em;
}
.card p{
  margin: 0;
  color: rgba(6,12,8,.78);
  font-size: 14px;
  line-height: 1.6;
}
.pill{
  display:inline-flex;
  align-items:center;
  gap: 8px;
  font-size: 11px;
  letter-spacing: .06em;
  text-transform: uppercase;
  color: rgba(6,12,8,.78);
  padding: 7px 10px;
  border-radius: 999px;
  border: 1px solid rgba(15,20,17,.14);
  background: #ffffff;
}
.pill i{ color: var(--g1); }

.bento{
  display:grid;
  grid-template-columns: 1fr;
  gap: 12px;
}
.bento .card{
  background: #ffffff;
}
.list{
  margin: 10px 0 0;
  padding: 0;
  list-style:none;
  display:flex;
  flex-direction:column;
  gap: 10px;
}
.list li{
  display:flex;
  gap: 10px;
  align-items:flex-start;
  color: var(--muted);
  font-size: 14px;
  line-height: 1.45;
}
.list i{
  margin-top: 2px;
  color: var(--g1);
}

.media{
  aspect-ratio: 16 / 10;
  background: linear-gradient(180deg, rgba(255,255,255,.0), rgba(10,18,12,.14));
  border-bottom: 1px solid rgba(15,20,17,.10);
  position: relative;
}
.media img{
  width:100%;
  height:100%;
  object-fit: cover;
  opacity: .9;
  filter: saturate(1.05) contrast(1.02);
}
.media .badge{
  position:absolute;
  left: 12px;
  bottom: 12px;
  padding: 10px 12px;
  border-radius: 16px;
  border: 1px solid rgba(11,18,14,.12);
  background: rgba(255,255,255,.84);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
}
.media .badge strong{
  display:block;
  font-size: 12px;
}
.media .badge span{
  display:block;
  margin-top:2px;
  font-size: 12px;
  color: var(--muted2);
}

/* Forms */
.form{
  display:grid;
  gap: 12px;
}
.field{
  position: relative;
}
.field input, .field textarea{
  width:100%;
  padding: 16px 14px 12px;
  border-radius: 16px;
  border: 1px solid rgba(15,20,17,.16);
  background: #ffffff;
  color: var(--text);
  outline: none;
  box-shadow: inset 0 1px 2px rgba(10,18,12,.03);
}
.field textarea{ min-height: 120px; resize: vertical; }
.field label{
  position:absolute;
  left: 12px;
  top: 12px;
  padding: 0 6px;
  border-radius: 10px;
  color: rgba(20,28,23,.56);
  background: #ffffff;
  transition: transform .16s ease, color .16s ease, top .16s ease;
  pointer-events:none;
  font-size: 13px;
}
.field input:focus, .field textarea:focus{
  border-color: rgba(26,124,42,.42);
  box-shadow: 0 0 0 3px rgba(26,124,42,.10);
}
.field.is-filled label, .field :focus + label{
  top: -9px;
  transform: translateY(0);
  color: rgba(26,124,42,.86);
  font-size: 12px;
}
.help{
  color: var(--muted2);
  font-size: 12px;
  margin: 0;
}

/* Footer */
.site-footer{
  position: relative;
  z-index: 1;
  padding: 38px 0 88px;
  border-top: 1px solid rgba(255,255,255,.22);
  background:
    linear-gradient(180deg, #111111 0%, #090909 100%);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
}
.site-footer::before{
  content:"";
  position:absolute;
  left:0;
  top:0;
  width:100%;
  height:2px;
  background: linear-gradient(90deg, rgba(121,193,26,.0), rgba(121,193,26,.9), rgba(121,193,26,.0));
}
.footer-grid{
  display:grid;
  grid-template-columns: 1fr;
  gap: 18px;
}
.footer-title{
  display:flex;
  align-items:center;
  gap: 10px;
}
.footer-title img{
  width: 44px;
  height: 44px;
  border-radius: 999px;
  border: 1px solid rgba(255,255,255,.22);
  box-shadow: 0 8px 20px rgba(0,0,0,.35);
}
.footer-title strong{
  font-size: 15px;
  letter-spacing: .3px;
  color: #ffffff;
}
.footer-title span{
  display:block;
  color: rgba(255,255,255,.82);
  font-size: 12px;
}
.site-footer .kicker{
  color: #ffffff !important;
  letter-spacing: .08em;
  text-transform: uppercase;
  font-size: 11px;
  font-weight: 700;
}
.footer-links{
  display:grid;
  grid-template-columns: 1fr 1fr;
  gap: 9px;
}
.footer-links a{
  color: rgba(255,255,255,.86);
  font-size: 13px;
  padding: 11px 12px;
  border-radius: 12px;
  border: 1px solid rgba(255,255,255,.16);
  background: rgba(255,255,255,.04);
  transition: transform .16s ease, border-color .16s ease, background .16s ease;
}
.footer-links a:hover{
  transform: translateY(-1px);
  border-color: rgba(121,193,26,.58);
  color: #ffffff;
  background: rgba(121,193,26,.14);
}
.meta{
  color: rgba(255,255,255,.84);
  font-size: 12px;
  line-height: 1.65;
}
.site-footer .meta{
  line-height: 1.9;
}
.site-footer .meta + .meta{
  margin-top: 10px;
}
.site-footer .meta a{
  color: #ffffff;
  text-decoration: underline;
  text-decoration-color: rgba(121,193,26,.72);
  text-underline-offset: 2px;
}
.copyright{
  margin-top: 14px;
  padding-top: 10px;
  border-top: 1px solid rgba(255,255,255,.16);
  color: rgba(255,255,255,.68);
  font-size: 12px;
}
.copyright a{ color: rgba(255,255,255,.92); }
.copyright a:hover{ color: #ffffff; }

/* Utilities */
.reveal{
  opacity: 0;
  transform: translateY(14px);
  transition: opacity .55s ease, transform .55s ease;
}
.reveal.is-in{
  opacity: 1;
  transform: translateY(0);
}
.kicker{
  color: var(--muted2);
  font-size: 13px;
}
.tagline{
  display:block;
  font-family: var(--fontDisplay);
  font-variation-settings: "opsz" 144, "wght" 520;
  font-size: clamp(18px, 4.2vw, 22px);
  color: rgba(255,255,255,.88);
  letter-spacing: -.01em;
}

/* Floating actions */
.fab{
  position: fixed;
  right: 16px;
  bottom: 18px;
  display:flex;
  flex-direction: column;
  gap: 16px;
  z-index: 1500;
}
.fab i{
  line-height: 1;
}
.fab a, .fab button{
  width: 58px;
  height: 58px;
  border-radius: 999px;
  border: 2px solid rgba(11,18,14,.18);
  background: rgba(255,255,255,.98);
  color: #0b170f;
  display:grid;
  place-items:center;
  box-shadow: 0 16px 34px rgba(10,18,12,.22), 0 0 0 4px rgba(255,255,255,.92);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  transition: transform .18s ease, background .18s ease, border-color .18s ease;
  font-size: 20px;
}
.fab a:hover, .fab button:hover{
  transform: translateY(-2px) scale(1.03);
  border-color: rgba(26,124,42,.34);
  background: #f7fff2;
}
.fab a:focus-visible, .fab button:focus-visible{ outline: 2px solid rgba(26,124,42,.32); outline-offset: 3px; }
.fab .wa{
  background: linear-gradient(180deg, #8fd23a, #4ca22c);
  border-color: rgba(26,124,42,.48);
  box-shadow: 0 18px 36px rgba(26,124,42,.34), 0 0 0 4px rgba(255,255,255,.92);
  animation: waPulse 2.2s ease-in-out infinite;
}
.fab .wa i{ color: #ffffff; }

#toTop{
  background: #111111;
  color: #ffffff;
  border-color: rgba(255,255,255,.45);
}

@keyframes waPulse{
  0%,100%{ transform: scale(1); }
  50%{ transform: scale(1.06); }
}

/* Desktop enhancements */
@media (min-width: 860px){
  .menu-btn{ display:none; }
  .nav-desktop{
    display:flex;
    align-items:center;
    gap: 2px;
  }
  .hero{ padding: 54px 0 26px; }
  .hero-grid{
    grid-template-columns: 1.08fr .92fr;
    align-items: start;
    gap: 18px;
  }
  .grid{
    grid-template-columns: repeat(2, 1fr);
    gap: 14px;
  }
  .bento{
    grid-template-columns: repeat(12, 1fr);
    gap: 14px;
  }
  .bento .card:nth-child(1){ grid-column: span 7; }
  .bento .card:nth-child(2){ grid-column: span 5; }
  .bento .card:nth-child(3){ grid-column: span 6; }
  .bento .card:nth-child(4){ grid-column: span 6; }
  .footer-grid{
    grid-template-columns: 1.2fr 1fr 1fr;
    align-items:start;
  }
  .footer-links{ grid-template-columns: 1fr; }
}

