:root{
  --bg:#0f0f10;
  --bg2:#171718;
  --card:#1f1f21;
  --line:rgba(255,255,255,.10);
  --text:#f2f2f2;
  --muted:rgba(255,255,255,.72);
  --muted2:rgba(255,255,255,.56);
  --accent:#d6651a;
  --accent2:#f08a2d;
  --shadow: 0 18px 50px rgba(0,0,0,.45);
  --radius: 18px;
  --radius2: 26px;
  --max: 1160px;
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  background:var(--bg);
  color:var(--text);
  font-family:Inter,system-ui,-apple-system,Segoe UI,Roboto,Arial,sans-serif;
  line-height:1.5;
}
img{max-width:100%; display:block}
a{color:inherit; text-decoration:none}

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

.skip{position:absolute; left:-9999px; top:auto; width:1px; height:1px; overflow:hidden}
.skip:focus{left:20px; top:20px; width:auto; height:auto; padding:10px 14px; background:#000; border:1px solid var(--line); border-radius:10px; z-index:9999}

/* Buttons */
.btn{
  display:inline-flex; align-items:center; justify-content:center;
  gap:10px;
  padding:12px 18px;
  border-radius:999px;
  border:1px solid var(--line);
  background:transparent;
  color:var(--text);
  font-weight:600;
  letter-spacing:.2px;
  cursor:pointer;
  transition:transform .15s ease, background .15s ease, border-color .15s ease, opacity .15s ease;
}
.btn:hover{transform:translateY(-1px)}
.btn:active{transform:translateY(0)}
.btn--primary{background:var(--accent); border-color:rgba(0,0,0,.0); color:#111}
.btn--primary:hover{background:var(--accent2)}
.btn--ghost{background:rgba(255,255,255,.04)}
.btn--sm{padding:9px 14px; font-size:14px}

.iconbtn{
  width:42px; height:42px;
  display:inline-grid; place-items:center;
  border-radius:999px;
  background:rgba(255,255,255,.06);
  border:1px solid var(--line);
  color:var(--text);
  cursor:pointer;
}

/* Header */
.header{
  position:sticky; top:0; z-index:50;
  border-bottom:1px solid transparent;
  background:rgba(15,15,16,.55);
  backdrop-filter:saturate(130%) blur(10px);
}
.header.is-scrolled{border-bottom-color:var(--line); background:rgba(15,15,16,.82)}
.header--plain{background:rgba(15,15,16,.92); border-bottom:1px solid var(--line)}

.header__inner{display:flex; align-items:center; justify-content:space-between; gap:16px; padding:14px 0}

.brand{display:flex; align-items:center; gap:14px; min-width:0}
.brand__logo{height:36px; width:auto}
.brand__tag{font-size:12.5px; color:var(--muted2); white-space:nowrap; overflow:hidden; text-overflow:ellipsis}

.nav{display:flex; gap:18px; align-items:center}
.nav a{color:var(--muted); font-weight:600; font-size:14px}
.nav a:hover{color:#fff}

.header__actions{display:flex; align-items:center; gap:10px}
.burger{
  width:46px; height:46px; border-radius:999px;
  border:1px solid var(--line);
  background:rgba(255,255,255,.04);
  display:none;
  cursor:pointer;
}
.burger span{display:block; height:2px; width:18px; background:var(--text); margin:4px auto; border-radius:2px; opacity:.9}

/* Mobile menu */
.mobile{position:fixed; inset:0; background:rgba(0,0,0,.62); backdrop-filter:blur(8px); z-index:60}
.mobile__inner{margin-top:14px}
.mobile__top{display:flex; align-items:center; justify-content:space-between; gap:12px; padding:14px 16px; background:rgba(23,23,24,.96); border:1px solid var(--line); border-radius:var(--radius2)}
.mobile__brand{display:flex; align-items:center; gap:12px; min-width:0}
.mobile__nav{display:grid; gap:10px; padding:14px 16px; margin-top:12px; background:rgba(23,23,24,.96); border:1px solid var(--line); border-radius:var(--radius2)}
.mobile__nav a{padding:12px 10px; border-radius:14px; color:var(--muted); font-weight:600}
.mobile__nav a:hover{background:rgba(255,255,255,.05); color:#fff}
.mobile__cta{margin-top:12px; width:100%}

/* Hero */
.hero{position:relative; min-height:72vh; display:grid; align-items:center; overflow:hidden}
.hero__bg{
  position:absolute; inset:0;
  background:
    linear-gradient(180deg, rgba(0,0,0,.55), rgba(0,0,0,.75) );
}
/* use an image if you add /site-assets/img/hero.jpg */
.hero__bg{
  background-image:
    linear-gradient(180deg, rgba(0,0,0,.68) 0%, rgba(0,0,0,.70) 45%, rgba(15,15,16,.98) 100%),
    url('/site-assets/img/sections/hero-main.jpg');
  background-size:cover;
  background-position:center;
  filter:grayscale(1);
}
.hero__inner{position:relative; padding:64px 0 48px}

.kicker{color:var(--accent); letter-spacing:2.2px; font-weight:700; font-size:12px}
.hero h1{font-family:Montserrat,Inter,sans-serif; font-size:clamp(30px,4vw,54px); line-height:1.08; margin:14px 0 14px; max-width:22ch}
.lead{color:rgba(255,255,255,.84); max-width:68ch; font-size:16.5px}
.hero__cta{margin-top:24px; display:flex; gap:12px; flex-wrap:wrap}

/* Dark band */
.darkband{background:var(--bg2); border-top:1px solid var(--line); border-bottom:1px solid var(--line)}
.darkband .container{padding:34px 0}
.darkband__label{color:var(--muted2); text-transform:uppercase; letter-spacing:2px; font-size:12px; margin-bottom:14px}
.darkband__grid{display:grid; grid-template-columns:repeat(3,1fr); gap:14px}
.pill{padding:16px 18px; border-radius:var(--radius); border:1px solid var(--line); background:rgba(255,255,255,.03)}
.pill h3{margin:0 0 6px; font-size:15px}
.pill p{margin:0; color:var(--muted2)}

/* Sections */
.section{padding:76px 0}
.section--dark{background:var(--bg2); border-top:1px solid var(--line); border-bottom:1px solid var(--line)}
.section--light{background:#f4f4f4; color:#151515}
.section--light .muted{color:rgba(0,0,0,.62)}
.section--light a{color:#151515}

.section__head{display:flex; align-items:flex-end; justify-content:space-between; gap:20px; margin-bottom:26px}
.section__head h2{margin:0; font-family:Montserrat,Inter,sans-serif; font-size:28px}
.section__head p{margin:0; max-width:60ch}
.muted{color:var(--muted)}

/* Carousel */
.carousel{position:relative}
.cartrack{
  display:flex; gap:14px;
  overflow:auto;
  scroll-snap-type:x mandatory;
  padding:4px 4px 12px;
  scrollbar-width:thin;
}
.cartrack::-webkit-scrollbar{height:10px}
.cartrack::-webkit-scrollbar-thumb{background:rgba(255,255,255,.12); border-radius:999px}
.carbtn{
  position:absolute; top:50%; transform:translateY(-50%);
  width:44px; height:44px; border-radius:999px;
  border:1px solid var(--line);
  background:rgba(0,0,0,.40);
  color:#fff;
  cursor:pointer;
  z-index:2;
}
.carbtn:hover{background:rgba(0,0,0,.55)}
.carbtn[disabled]{opacity:.35; cursor:not-allowed}
.carbtn:first-of-type{left:-8px}
.carbtn:last-of-type{right:-8px}

.card{
  scroll-snap-align:start;
  flex:0 0 min(420px, 88vw);
  border-radius:var(--radius2);
  border:1px solid var(--line);
  background:rgba(255,255,255,.03);
  box-shadow:var(--shadow);
  overflow:hidden;
}
.card__img{height:160px; overflow:hidden; background:#111}
.card__img img{width:100%; height:100%; object-fit:cover; object-position:center 12%; filter:none}
.card__body{padding:18px}
.card__kicker{color:var(--accent); font-weight:700; font-size:12px; letter-spacing:1.6px; text-transform:uppercase}
.card h3{margin:8px 0 10px; font-size:18px}
.card p{margin:0 0 14px; color:var(--muted)}
.card__actions{display:flex; gap:10px; flex-wrap:wrap}
.carhint{margin-top:12px; color:var(--muted2); font-size:13px}

/* About */
.about__text{max-width:92ch}
.about__text p{margin:0 0 14px}

.bigwords{
  font-family:Montserrat,Inter,sans-serif;
  font-weight:800;
  font-size:clamp(44px,7vw,86px);
  letter-spacing:-1px;
  margin:28px 0;
  color:rgba(0,0,0,.08);
  user-select:none;
}

.about__grid{display:grid; grid-template-columns:1.15fr .85fr; gap:22px; align-items:stretch}
.about__card{
  background:#fff;
  border:1px solid rgba(0,0,0,.12);
  border-radius:var(--radius2);
  padding:22px;
  box-shadow:0 18px 40px rgba(0,0,0,.12);
}
.about__media{border-radius:var(--radius2); overflow:hidden; border:1px solid rgba(0,0,0,.12); box-shadow:0 18px 40px rgba(0,0,0,.10)}
.about__media img{width:100%; height:100%; object-fit:cover; filter:grayscale(1)}
.about__card h3{margin:0 0 14px; font-family:Montserrat,Inter,sans-serif}
.check{padding-left:18px; margin:0}
.check li{margin:10px 0; list-style: none; position:relative; padding-left:24px}
.check li::before{content:"✓"; position:absolute; left:0; top:0; color:var(--accent); font-weight:900}
.accentline{margin-top:14px; padding-top:14px; border-top:1px solid rgba(0,0,0,.12)}

/* Quote */
.quote{padding:68px 0; background:linear-gradient(100deg, #d6651a 0%, #ff9a3b 30%, #7a1a74 100%)}
.quote__inner{background:rgba(0,0,0,.18); border:1px solid rgba(255,255,255,.22); border-radius:var(--radius2); padding:26px; display:flex; gap:18px; align-items:flex-start}
.quote__mark{font-size:52px; font-family:Montserrat,Inter,sans-serif; line-height:1; color:rgba(255,255,255,.85)}
.quote__text{margin:0; font-size:20px; max-width:75ch}

/* Team */
.team{display:grid; grid-template-columns:1fr; gap:14px}
.tcard{display:grid; grid-template-columns:220px 1fr; gap:16px; padding:16px; border-radius:var(--radius2); border:1px solid var(--line); background:rgba(255,255,255,.03)}

/* TEAM PHOTO: стабільний контейнер, без ламання гріда */
.tcard__img{
  border-radius:16px;
  overflow:hidden;
  background:#111;
  height:260px;              /* БУЛО 220 — зробили вище */
}

/* фокус по вертикалі можна підкручувати через --face-y */
.tcard__img img{
  width:100%;
  height:100%;
  object-fit:cover;
  object-position:center var(--face-y, 16%);
  filter:none;
}

.tcard__head{display:flex; gap:10px; justify-content:space-between; align-items:flex-start}
.tcard h3{margin:0; font-size:18px}
.tcard .role{color:var(--muted2); margin-top:4px}
.tcard .bio{color:var(--muted); margin:12px 0 0}
.tcard .bio p{margin:0 0 10px}
.tcard .ln{display:inline-flex; gap:8px; align-items:center; padding:8px 10px; border-radius:999px; border:1px solid var(--line); background:rgba(0,0,0,.25)}
.tcard .ln svg{width:18px; height:18px; fill:#fff}
.tcard .ln span{font-weight:700; font-size:13px}

/* Cases */
.cases{display:grid; grid-template-columns:repeat(2,1fr); gap:14px}
.case{
  border-radius:var(--radius2);
  border:1px solid var(--line);
  background:rgba(0,0,0,.18);
  overflow:hidden;
}
.case__img{height:190px}
.case__img img{width:100%; height:100%; object-fit:cover; filter:grayscale(1)}
.case__body{padding:18px}
.case__body h3{margin:0 0 10px; font-size:18px}
.case__body p{margin:0 0 14px; color:var(--muted)}
.case__meta{color:var(--muted2); font-size:13px; margin-bottom:10px}

/* Blog */
.grid3{display:grid; grid-template-columns:repeat(3,1fr); gap:14px}
.post{border-radius:var(--radius2); border:1px solid var(--line); overflow:hidden; background:rgba(255,255,255,.03)}
.post__img{height:180px}
.post__img img{width:100%; height:100%; object-fit:cover; filter:grayscale(1)}
.post__body{padding:18px}
.post__meta{color:var(--accent); font-weight:800; letter-spacing:1.8px; font-size:11px; text-transform:uppercase}
.post h3{margin:8px 0 10px; font-size:18px}
.link{color:#fff; font-weight:700}
.section--light .link{color:#151515}

/* Contacts */
.contact{display:grid; grid-template-columns:1fr 1fr; gap:18px; align-items:stretch}
.contact__left{border-radius:var(--radius2); border:1px solid var(--line); background:rgba(255,255,255,.03); padding:22px; display:flex; flex-direction:column; gap:16px}
.contact__list{display:grid; gap:10px}
.contact__item{display:flex; gap:10px; align-items:center; padding:12px 14px; border-radius:16px; border:1px solid var(--line); background:rgba(0,0,0,.22)}
.contact__item:hover{border-color:rgba(255,255,255,.20)}
.ico{display:inline-grid; place-items:center; width:26px; height:26px; border-radius:999px; background:rgba(255,255,255,.08)}
.contact__social{display:flex; gap:10px; margin-top:6px}
.soc{width:44px; height:44px; display:grid; place-items:center; border-radius:999px; border:1px solid var(--line); background:rgba(255,255,255,.04)}
.soc svg{width:20px; height:20px; fill:#fff}
.contact__media{margin-top:auto; border-radius:var(--radius2); overflow:hidden; border:1px solid var(--line)}
.contact__media img{width:100%; height:220px; object-fit:cover; filter:grayscale(1)}

.contact__right{border-radius:var(--radius2); border:1px solid var(--line); background:rgba(255,255,255,.03); padding:22px}

/* Forms */
.form{display:grid; gap:12px; margin-top:12px}
.form label{display:grid; gap:6px}
.form span{font-weight:700; font-size:13px; color:var(--muted)}
.section--light .form span{color:rgba(0,0,0,.68)}
input, select, textarea{
  width:100%;
  padding:12px 12px;
  border-radius:14px;
  border:1px solid var(--line);
  background:rgba(0,0,0,.18);
  color:var(--text);
  outline:none;
}
.section--light input, .section--light select, .section--light textarea{background:#fff; color:#151515; border-color:rgba(0,0,0,.14)}
input:focus, select:focus, textarea:focus{border-color:rgba(214,101,26,.7); box-shadow:0 0 0 4px rgba(214,101,26,.18)}
.row2{display:grid; grid-template-columns:1fr 1fr; gap:12px}
.form__actions{display:flex; gap:12px; align-items:center; flex-wrap:wrap; margin-top:2px}
.form__status{color:var(--muted2); font-size:13px}
.consent{display:flex !important; gap:10px; align-items:flex-start}
.consent input{width:auto; margin-top:2px}
.consent a{text-decoration:underline}
.hp{position:absolute !important; left:-9999px; top:auto; width:1px; height:1px; overflow:hidden}

/* Footer */
.footer{padding:44px 0 0; border-top:1px solid var(--line); background:var(--bg)}
.footer__inner{display:flex; align-items:flex-start; justify-content:space-between; gap:26px; padding-bottom:32px}
.footer__brand{display:grid; gap:10px; max-width:360px}
.footer__brand img{height:34px; width:auto}
.footer__cols{display:grid; grid-template-columns:repeat(3,1fr); gap:18px}
.footer__title{color:var(--muted2); font-weight:800; text-transform:uppercase; letter-spacing:1.8px; font-size:11px; margin-bottom:8px}
.footer__cols a{display:block; padding:6px 0; color:var(--muted)}
.footer__cols a:hover{color:#fff}
.footer__bottom{border-top:1px solid var(--line); padding:14px 0; color:var(--muted2); font-size:13px}

/* Cookie */
.cookie{
  position:fixed;
  left:14px; right:14px; bottom:14px;
  max-width:min(980px, calc(100% - 28px));
  margin-inline:auto;
  z-index:80;
  display:flex;
  gap:12px;
  align-items:center;
  justify-content:space-between;
  padding:12px 14px;
  border-radius:16px;
  border:1px solid var(--line);
  background:rgba(0,0,0,.78);
  backdrop-filter:blur(10px);
}
.cookie__text{color:rgba(255,255,255,.80); font-size:13px}
.cookie__text a{text-decoration:underline}

/* Modal */
.modal{position:fixed; inset:0; z-index:90; display:grid; place-items:center}
.modal__backdrop{position:absolute; inset:0; background:rgba(0,0,0,.62); backdrop-filter:blur(8px)}
.modal__card{position:relative; width:min(860px, calc(100% - 28px)); max-height:calc(100% - 28px); overflow:auto; border-radius:var(--radius2); border:1px solid var(--line); background:rgba(23,23,24,.96); box-shadow:var(--shadow)}
.modal__close{position:absolute; right:12px; top:12px}
.modal__body{padding:22px}
.modal__body h3{margin:0 0 10px; font-size:22px; font-family:Montserrat,Inter,sans-serif}
.modal__content{color:var(--muted)}
.modal__content h4{margin:18px 0 10px; color:#fff}
.modal__content ul{margin:8px 0 0; padding-left:18px}
.modal__content li{margin:8px 0}

/* Prose */
.prose{max-width:90ch}
.prose h1{font-family:Montserrat,Inter,sans-serif}
.prose h2{margin-top:26px}
.prose .card{padding:16px; border-radius:18px; background:rgba(0,0,0,.04); border:1px solid rgba(0,0,0,.12); box-shadow:none}

/* Responsive */
@media (max-width: 980px){
  .nav{display:none}
  .burger{display:inline-block}
  .darkband__grid{grid-template-columns:1fr}
  .about__grid{grid-template-columns:1fr}
  .tcard{grid-template-columns:1fr}

/* TEAM PHOTO (mobile): ще вище, щоб не різало обличчя */
.tcard__img{ height:320px; }/* TEAM PHOTO (mobile): ще вище, щоб не різало обличчя */
.tcard__img{ height:320px; }

  .cases{grid-template-columns:1fr}
  .grid3{grid-template-columns:1fr}
  .contact{grid-template-columns:1fr}
  .row2{grid-template-columns:1fr}
  .footer__inner{flex-direction:column}
  .footer__cols{grid-template-columns:1fr; width:100%}
}

/* SMX hidden fix */
[hidden] { display: none !important; }

/* --- SMX SERVICES (Directus) START --- */

.smx-services-card{
  display:flex;
  flex-direction:column;
  justify-content:space-between;
  min-height:220px;
  padding:18px 18px;
  border:1px solid rgba(255,255,255,0.10);
  border-radius:18px;
  background:
    radial-gradient(900px 260px at 0% 0%, rgba(255,255,255,0.08), rgba(0,0,0,0) 60%),
    radial-gradient(700px 220px at 100% 0%, rgba(255,255,255,0.06), rgba(0,0,0,0) 55%),
    rgba(255,255,255,0.03);
  backdrop-filter: blur(6px);
}

.smx-services-title{
  font-weight:700;
  font-size:18px;
  line-height:1.25;
  margin:0 0 10px 0;
}

.smx-services-desc{
  opacity:0.86;
  font-size:14px;
  line-height:1.5;
  margin:0 0 14px 0;
  max-width:56ch;
}

.smx-services-btn{
  align-self:flex-start;
}

/* Modal */
.smx-modal-open{ overflow:hidden; }

#smxServiceModalWrap{
  position:fixed;
  inset:0;
  z-index:9999;
}

#smxServiceModalWrap .smx-modal-backdrop{
  position:absolute;
  inset:0;
  background:rgba(0,0,0,0.65);
}

#smxServiceModalWrap .smx-modal{
  position:relative;
  max-width:980px;
  margin:40px auto;
  background:rgba(15,15,15,0.96);
  border:1px solid rgba(255,255,255,0.10);
  border-radius:18px;
  box-shadow:0 20px 80px rgba(0,0,0,0.55);
}

#smxServiceModalWrap .smx-modal-close{
  position:absolute;
  top:14px;
  right:14px;
  width:38px;
  height:38px;
  border-radius:12px;
  border:1px solid rgba(255,255,255,0.12);
  background:rgba(255,255,255,0.06);
  color:#fff;
  font-size:22px;
  cursor:pointer;
}

#smxServiceModalWrap .smx-modal-body{
  padding:22px 22px 26px 22px;
  max-height: calc(100vh - 120px);
  overflow:auto;
}

#smxServiceModalWrap .smx-modal-kicker{
  opacity:0.7;
  font-size:13px;
  margin-bottom:6px;
}

#smxServiceModalWrap .smx-modal-title{
  margin:0 0 12px 0;
  font-size:28px;
  line-height:1.15;
}

#smxServiceModalWrap .smx-modal-content{
  opacity:0.92;
  line-height:1.6;
}

/* --- SMX SERVICES (Directus) END --- */

/* ===== SMX: Services carousel (fix layout + enable swipe) ===== */

.smx-services-host {
  position: relative;
}

.smx-services-viewport {
  overflow-x: auto;
  overflow-y: hidden;
  scroll-snap-type: x mandatory;
  -webkit-overflow-scrolling: touch;
  padding: 8px 2px 18px;
}

/* ховаємо scrollbar (акуратно) */
.smx-services-viewport::-webkit-scrollbar { height: 8px; }
.smx-services-viewport::-webkit-scrollbar-thumb { background: rgba(255,255,255,0.08); border-radius: 999px; }
.smx-services-viewport::-webkit-scrollbar-track { background: rgba(255,255,255,0.03); }

.smx-services-track {
  display: flex;
  gap: 18px;
  align-items: stretch;
}

/* ВАЖЛИВО: картки мають бути “однакові” */
.smx-services-track > * {
  scroll-snap-align: start;
  flex: 0 0 420px;          /* ширина картки на десктопі */
  min-height: 210px;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
}

/* адаптив: на вузьких екранах картка ширша (майже на весь екран) */
@media (max-width: 1200px) {
  .smx-services-track > * { flex-basis: 520px; }
}
@media (max-width: 820px) {
  .smx-services-track > * { flex-basis: 86vw; }
}
/* SMX: force services carousel track to be single-row */
#services .cartrack { flex-wrap: nowrap !important; }
#services .cartrack > * { flex: 0 0 min(420px, 88vw); scroll-snap-align: start; }
