/* ===== FONTS ===== */
/* Onest — основний текст */
@font-face{font-family:'Onest';src:url('../assets/fonts/Onest-Thin.woff2') format('woff2');font-weight:100;font-style:normal;font-display:swap;}
@font-face{font-family:'Onest';src:url('../assets/fonts/Onest-ExtraLight.woff2') format('woff2');font-weight:200;font-style:normal;font-display:swap;}
@font-face{font-family:'Onest';src:url('../assets/fonts/Onest-Light.woff2') format('woff2');font-weight:300;font-style:normal;font-display:swap;}
@font-face{font-family:'Onest';src:url('../assets/fonts/Onest-Regular.woff2') format('woff2');font-weight:400;font-style:normal;font-display:swap;}
@font-face{font-family:'Onest';src:url('../assets/fonts/Onest-Medium.woff2') format('woff2');font-weight:500;font-style:normal;font-display:swap;}
@font-face{font-family:'Onest';src:url('../assets/fonts/Onest-SemiBold.woff2') format('woff2');font-weight:600;font-style:normal;font-display:swap;}
@font-face{font-family:'Onest';src:url('../assets/fonts/Onest-Bold.woff2') format('woff2');font-weight:700;font-style:normal;font-display:swap;}
@font-face{font-family:'Onest';src:url('../assets/fonts/Onest-ExtraBold.woff2') format('woff2');font-weight:800;font-style:normal;font-display:swap;}
@font-face{font-family:'Onest';src:url('../assets/fonts/Onest-Black.woff2') format('woff2');font-weight:900;font-style:normal;font-display:swap;}

/* Futura futuris — заголовки */
@font-face{font-family:'Futura';src:url('../assets/fonts/Futurafuturisc-bold.woff2') format('woff2');font-weight:700;font-style:normal;font-display:swap;}

/* Cascadia Code — моноширинні акценти */
@font-face{font-family:'Cascadia Code';src:url('../assets/fonts/CascadiaCode-VariableFont_wght.woff2') format('woff2');font-weight:100 900;font-style:normal;font-display:swap;}

*{box-sizing:border-box;margin:0;padding:0;}

:root{
  --cream:#F5F0E4;
  --cream-dark:#EDE8D8;
  --navy:#0D1526;
  --navy-mid:#1E2D47;
  --yellow:#EDD934;
  --olive:#5C6145;
  --sage:#7A8468;
  --sand:#E2DDD0;
  --black:#1A1A1A;
  --white:#FAFAF5;
  --font-main:'Onest',sans-serif;
  --font-mono:'Cascadia Code',monospace;
  --font-display:'Futura','Onest',sans-serif;
}

html{scroll-behavior:smooth;}
body{font-family:var(--font-main);background:var(--cream);color:var(--navy);overflow-x:hidden;}

/* NAV */
nav{
  position:fixed;top:0;left:0;right:0;z-index:100;
  display:flex;align-items:center;justify-content:space-between;
  padding:20px 48px;
  background:var(--cream);
  border-bottom:1px solid var(--sand);
  transition:padding 0.3s;
}
.nav-logo{
  font-weight:800;font-size:18px;letter-spacing:0.04em;
  color:var(--navy);text-decoration:none;
  display:flex;align-items:center;gap:10px;
}
.nav-logo .clover{font-size:22px;line-height:1;}
.nav-logo-symbol{height:30px;width:auto;display:block;animation:logoSpin 14s linear infinite;}
@keyframes logoSpin{to{transform:rotate(360deg);}}
@media (prefers-reduced-motion: reduce){ .nav-logo-symbol{animation:none;} }
.nav-logo-text{height:17px;width:auto;display:block;}
.nav-links{display:flex;align-items:center;gap:32px;}
.nav-links a{
  font-size:13px;font-weight:500;letter-spacing:0.06em;text-transform:uppercase;
  color:var(--olive);text-decoration:none;transition:color 0.2s;
}
.nav-links a:hover{color:var(--navy);}
.nav-cta{
  background:var(--navy);color:var(--yellow);
  padding:10px 24px;border-radius:100px;
  font-size:13px;font-weight:700;letter-spacing:0.04em;
  text-decoration:none;transition:all 0.2s;
}
.nav-cta:hover{background:var(--yellow);color:var(--navy);}

/* BURGER + MOBILE MENU */
.nav-burger{
  display:none;flex-direction:column;justify-content:center;gap:5px;
  width:30px;height:24px;padding:0;background:none;border:none;cursor:pointer;z-index:101;
}
.nav-burger span{display:block;height:2px;width:100%;background:var(--navy);border-radius:2px;transition:transform .3s,opacity .3s;}
.nav-burger.open span:nth-child(1){transform:translateY(7px) rotate(45deg);}
.nav-burger.open span:nth-child(2){opacity:0;}
.nav-burger.open span:nth-child(3){transform:translateY(-7px) rotate(-45deg);}

.mobile-menu{
  position:fixed;inset:0;z-index:90;background:var(--cream);
  display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px;
  opacity:0;visibility:hidden;transition:opacity .32s ease,visibility .32s ease;
}
.mobile-menu.open{opacity:1;visibility:visible;}
.mobile-menu a{
  font-family:var(--font-display);font-weight:700;font-size:clamp(30px,9vw,42px);
  color:var(--navy);text-decoration:none;padding:10px 0;letter-spacing:-0.01em;
  transition:color .2s;
}
.mobile-menu a:hover{color:var(--olive);}
.mobile-menu .mobile-menu-cta{
  margin-top:28px;font-family:var(--font-main);font-size:16px;font-weight:700;
  background:var(--navy);color:var(--yellow);padding:16px 38px;border-radius:100px;letter-spacing:0.02em;
}
@media(min-width:901px){ .mobile-menu{display:none;} }

/* HERO */
.hero{
  min-height:80vh;
  display:flex;flex-direction:column;justify-content:flex-end;
  padding:120px 48px 64px;
  position:relative;overflow:hidden;
}
.hero-eyebrow{
  font-family:var(--font-mono);font-size:11px;font-weight:500;
  letter-spacing:0.12em;text-transform:uppercase;color:var(--sage);
  margin-bottom:24px;
  display:flex;align-items:center;gap:12px;
}
.hero-eyebrow::before{content:'';display:block;width:32px;height:1px;background:var(--sage);}
.hero-h1{
  font-family:var(--font-display);
  font-size:clamp(64px,9vw,132px);
  font-weight:700;line-height:0.92;letter-spacing:-0.03em;
  color:var(--navy);
  margin-bottom:48px;
}
.hero-h1 em{font-style:normal;color:var(--olive);}
.hero-h1 .accent{
  -webkit-text-stroke:2px var(--navy);
  color:transparent;
  font-style:italic;
}
.hero-bottom{
  display:flex;align-items:flex-end;justify-content:space-between;
  gap:32px;flex-wrap:wrap;
}
.hero-desc{
  max-width:420px;font-size:17px;font-weight:400;line-height:1.65;color:var(--navy-mid);
}
.hero-actions{display:flex;align-items:center;gap:16px;}
.btn-primary{
  background:var(--navy);color:var(--yellow);
  padding:16px 36px;border-radius:100px;
  font-size:15px;font-weight:700;letter-spacing:0.02em;
  text-decoration:none;display:inline-block;
  transition:all 0.25s;border:2px solid var(--navy);
}
.btn-primary:hover{background:var(--yellow);color:var(--navy);}
.btn-ghost{
  color:var(--navy);border:2px solid var(--navy);
  padding:14px 32px;border-radius:100px;
  font-size:15px;font-weight:600;
  text-decoration:none;display:inline-block;
  transition:all 0.25s;
}
.btn-ghost:hover{background:var(--navy);color:var(--cream);}

.hero-clover{
  position:absolute;right:-60px;top:50%;transform:translateY(-50%);
  width:520px;height:auto;opacity:0.06;
  pointer-events:none;user-select:none;
  will-change:transform;
}

/* TICKER */
.ticker{
  background:var(--navy);padding:14px 0;overflow:hidden;
  border-top:none;border-bottom:none;
  display:flex;
}
.ticker-track{
  display:flex;gap:0;
  animation:ticker 28s linear infinite;
  white-space:nowrap;
}
.ticker-item{
  font-family:var(--font-mono);font-size:12px;font-weight:500;
  letter-spacing:0.08em;text-transform:uppercase;
  color:var(--yellow);padding:0 40px;
  display:flex;align-items:center;gap:16px;
}
.ticker-dot{width:4px;height:4px;border-radius:50%;background:var(--olive);flex-shrink:0;}
@keyframes ticker{from{transform:translateX(0);}to{transform:translateX(-50%);}}

/* CLIENTS MARQUEE */
.clients{background:var(--white);padding-top:64px;padding-bottom:64px;overflow:hidden;}
.clients .section-label{max-width:var(--max-width);margin-left:auto;margin-right:auto;}
.clients-marquee{
  margin-top:36px;overflow:hidden;
  -webkit-mask:linear-gradient(90deg,transparent,#000 8%,#000 92%,transparent);
  mask:linear-gradient(90deg,transparent,#000 8%,#000 92%,transparent);
}
.clients-track{
  display:flex;align-items:center;gap:72px;width:max-content;
  animation:clientsScroll 45s linear infinite;
}
.clients-marquee:hover .clients-track{animation-play-state:paused;}
@keyframes clientsScroll{from{transform:translateX(0);}to{transform:translateX(-50%);}}
.client-logo{
  height:46px;width:auto;display:block;flex:0 0 auto;
  opacity:0.5;filter:grayscale(1);transition:opacity .25s,filter .25s;
}
.client-logo:hover{opacity:1;filter:none;}
.client-chip{
  flex:0 0 auto;white-space:nowrap;
  font-family:var(--font-display);font-weight:700;font-size:26px;
  color:var(--olive);opacity:0.65;letter-spacing:-0.01em;
}
@media (prefers-reduced-motion: reduce){ .clients-track{animation:none;} }
@media(max-width:900px){ .clients-track{gap:48px;} .client-logo{height:38px;} .client-chip{font-size:22px;} }

/* SECTIONS COMMON */
section{padding:100px 48px;}
.section-label{
  font-family:var(--font-mono);font-size:11px;font-weight:500;
  letter-spacing:0.12em;text-transform:uppercase;color:var(--sage);
  margin-bottom:48px;display:flex;align-items:center;gap:12px;
}
.section-label::after{content:'';flex:1;height:1px;background:var(--sand);}
.section-h2{
  font-family:var(--font-display);
  font-size:clamp(40px,5vw,72px);font-weight:700;
  line-height:1;letter-spacing:-0.02em;color:var(--navy);
  margin-bottom:64px;
}

/* SERVICES */
.services{background:var(--white);}
.services-grid{
  display:grid;grid-template-columns:repeat(3,1fr);gap:1px;
  background:var(--sand);border:1px solid var(--sand);
  border-radius:16px;overflow:hidden;
}
.service-card{
  background:var(--white);padding:40px 36px;
  transition:background 0.2s;cursor:default;
  display:flex;flex-direction:column;gap:16px;
}
.service-card:hover{background:var(--cream);}
.service-tag{
  display:inline-flex;align-items:center;
  background:var(--navy);color:var(--yellow);
  font-family:var(--font-mono);font-size:10px;font-weight:500;
  letter-spacing:0.1em;text-transform:uppercase;
  padding:5px 12px;border-radius:100px;width:fit-content;
}
.service-num{
  font-family:var(--font-mono);font-size:11px;color:var(--sage);
  letter-spacing:0.06em;
}
.service-title{font-size:22px;font-weight:800;color:var(--navy);line-height:1.2;}
.service-desc{font-size:14px;font-weight:400;line-height:1.65;color:var(--olive);flex:1;}
.service-arrow{
  font-size:20px;color:var(--sand);transition:color 0.2s;
  align-self:flex-start;margin-top:auto;
}
.service-card:hover .service-arrow{color:var(--navy);}

/* ABOUT */
.about{background:var(--cream);}
.about-inner{display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:start;}
.about-left{}
.about-text{font-size:19px;font-weight:400;line-height:1.7;color:var(--navy-mid);margin-bottom:40px;}
.about-text strong{color:var(--navy);font-weight:700;}
.stats-grid{display:grid;grid-template-columns:1fr 1fr;gap:1px;background:var(--sand);border:1px solid var(--sand);border-radius:12px;overflow:hidden;}
.stat{
  background:var(--cream);padding:28px 24px;
}
.stat-num{font-size:42px;font-weight:800;color:var(--navy);line-height:1;letter-spacing:-0.02em;margin-bottom:6px;}
.stat-num span{font-size:28px;color:var(--yellow);}
.stat-label{font-size:13px;font-weight:500;color:var(--sage);line-height:1.4;}
.about-right{}
.values-list{display:flex;flex-direction:column;gap:0;}
.value-item{
  display:flex;gap:20px;align-items:flex-start;
  padding:24px 0;border-bottom:1px solid var(--sand);
}
.value-item:last-child{border-bottom:none;}
.value-num{
  font-family:var(--font-mono);font-size:11px;color:var(--sage);
  letter-spacing:0.06em;padding-top:4px;flex-shrink:0;width:32px;
}
.value-text{}
.value-title{font-size:16px;font-weight:700;color:var(--navy);margin-bottom:6px;}
.value-desc{font-size:14px;color:var(--olive);line-height:1.6;}

/* CASES */
.cases{background:var(--cream-dark);}
.cases-grid{display:grid;grid-template-columns:1fr 1fr;gap:24px;}
.case-card{
  background:var(--cream);border:1px solid var(--sand);border-radius:16px;
  overflow:hidden;transition:transform 0.25s,box-shadow 0.25s;
  cursor:default;
}
.case-card:hover{transform:translateY(-4px);box-shadow:0 20px 40px rgba(13,21,38,0.1);}
.case-card.featured{grid-column:span 2;display:grid;grid-template-columns:1fr 1fr;}
.case-visual{
  aspect-ratio:4/3;background:var(--navy);
  display:flex;align-items:center;justify-content:center;
  font-size:80px;position:relative;overflow:hidden;
}
.case-card.featured .case-visual{aspect-ratio:auto;min-height:320px;}
.case-body{padding:44px 32px 36px;}
.case-tags{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:16px;}
.case-tag{
  font-family:var(--font-mono);font-size:10px;font-weight:500;
  letter-spacing:0.08em;text-transform:uppercase;
  padding:4px 10px;border-radius:100px;
  border:1px solid var(--sand);color:var(--sage);background:transparent;
}
.case-tag.active{background:var(--olive);color:var(--cream);border-color:var(--olive);}
.case-client{font-size:13px;font-weight:500;color:var(--sage);margin-bottom:8px;font-family:var(--font-mono);letter-spacing:0.06em;}
.case-title{font-size:22px;font-weight:800;color:var(--navy);line-height:1.25;margin-bottom:12px;}
.case-result{font-size:14px;color:var(--olive);line-height:1.6;}
.case-metric{
  display:inline-flex;align-items:baseline;gap:4px;
  margin-top:16px;
}
.case-metric-num{font-size:32px;font-weight:800;color:var(--navy);letter-spacing:-0.02em;}
.case-metric-label{font-size:13px;color:var(--sage);font-family:var(--font-mono);}

/* METRIC-LED CARDS */
.case-card{cursor:pointer;outline:none;}
.case-card:focus-visible{box-shadow:0 0 0 3px var(--yellow);}
.case-hero{
  display:flex;flex-direction:column;justify-content:center;align-items:flex-start;gap:8px;
  padding:44px 36px;min-height:210px;
}
.case-card.featured .case-hero{min-height:100%;}
.case-hero-num{
  font-family:var(--font-display);font-weight:700;
  font-size:clamp(52px,7vw,104px);line-height:0.88;letter-spacing:-0.02em;
}
.case-hero-cap{font-family:var(--font-mono);font-size:12px;letter-spacing:0.06em;text-transform:uppercase;opacity:0.75;}
.hero-navy{background:var(--navy);color:var(--yellow);}
.hero-navy .case-hero-cap{color:var(--sage);}
.hero-olive{background:var(--olive);color:var(--cream);}
.hero-olive .case-hero-cap{color:var(--sand);}
.hero-yellow{background:var(--yellow);color:var(--navy);}
.hero-yellow .case-hero-cap{color:var(--olive);}
.case-open{
  margin-top:18px;font-family:var(--font-mono);font-size:12px;font-weight:500;
  letter-spacing:0.04em;color:var(--sage);transition:color 0.2s,transform 0.2s;
  display:inline-block;
}
.case-card:hover .case-open{color:var(--navy);transform:translateX(4px);}

/* CASE MODAL */
.case-modal{
  position:fixed;inset:0;z-index:200;display:none;
  align-items:flex-start;justify-content:center;
}
.case-modal.open{display:flex;}
.case-modal-backdrop{position:absolute;inset:0;background:rgba(13,21,38,0.55);backdrop-filter:blur(4px);}
.case-modal-panel{
  position:relative;z-index:1;background:var(--cream);
  width:min(860px,100%);margin:48px 16px;border-radius:20px;
  max-height:calc(100vh - 96px);overflow-y:auto;
  box-shadow:0 30px 80px rgba(13,21,38,0.35);
  animation:modalIn 0.32s cubic-bezier(.2,.85,.25,1);
}
@keyframes modalIn{from{opacity:0;transform:translateY(24px);}to{opacity:1;transform:translateY(0);}}
.case-modal-close{
  position:sticky;top:16px;float:right;margin:16px 16px 0 0;
  width:40px;height:40px;border:none;border-radius:50%;
  background:var(--navy);color:var(--cream);font-size:22px;line-height:1;cursor:pointer;
  display:flex;align-items:center;justify-content:center;transition:background 0.2s;z-index:2;
}
.case-modal-close:hover{background:var(--olive);}
.case-modal-content{padding:36px 48px 56px;}
.cm-tags{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:16px;}
.cm-client{font-family:var(--font-mono);font-size:13px;color:var(--sage);letter-spacing:0.06em;margin-bottom:8px;}
.cm-title{font-family:var(--font-display);font-weight:700;font-size:clamp(28px,4vw,46px);line-height:1.05;color:var(--navy);margin-bottom:28px;}
.cm-block{margin-bottom:28px;}
.cm-label{font-family:var(--font-mono);font-size:11px;letter-spacing:0.1em;text-transform:uppercase;color:var(--sage);margin-bottom:10px;}
.cm-text{font-size:16px;line-height:1.7;color:var(--navy-mid);}
.cm-list{list-style:none;display:flex;flex-direction:column;gap:10px;}
.cm-list li{position:relative;padding-left:24px;font-size:15px;line-height:1.6;color:var(--navy-mid);}
.cm-list li::before{content:'✿';position:absolute;left:0;color:var(--olive);font-size:13px;}
.cm-metrics{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:1px;background:var(--sand);border:1px solid var(--sand);border-radius:12px;overflow:hidden;margin-top:8px;}
.cm-metric{background:var(--cream);padding:22px 20px;}
.cm-metric-num{font-family:var(--font-display);font-weight:700;font-size:34px;color:var(--navy);line-height:1;}
.cm-metric-cap{font-size:12px;color:var(--sage);font-family:var(--font-mono);margin-top:6px;}
.cm-media{display:flex;flex-direction:column;gap:16px;margin-top:8px;}
.cm-media-item{
  position:relative;border-radius:14px;overflow:hidden;background:var(--navy);
  aspect-ratio:16/9;display:flex;align-items:center;justify-content:center;cursor:pointer;
}
.cm-media-item img,.cm-media-item video{width:100%;height:100%;object-fit:cover;display:block;}
.cm-media-poster{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;}
.cm-play{
  position:relative;z-index:1;width:64px;height:64px;border-radius:50%;
  background:var(--yellow);color:var(--navy);font-size:24px;
  display:flex;align-items:center;justify-content:center;
  box-shadow:0 8px 24px rgba(13,21,38,0.3);transition:transform 0.2s;
}
.cm-media-item:hover .cm-play{transform:scale(1.08);}
.cm-media-label{
  position:absolute;bottom:14px;left:16px;z-index:1;
  font-family:var(--font-mono);font-size:11px;letter-spacing:0.06em;
  color:var(--cream);background:rgba(13,21,38,0.5);padding:5px 12px;border-radius:100px;
}
body.modal-lock{overflow:hidden;}
@media(max-width:900px){
  .case-modal-content{padding:28px 24px 40px;}
  .case-modal-panel{margin:16px 8px;max-height:calc(100vh - 32px);}
}

/* FORM */
.contact{background:var(--navy);}
.contact .section-label{color:var(--olive);}
.contact .section-label::after{background:var(--navy-mid);}
.contact .section-h2{color:var(--cream);}
.contact-inner{display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:start;}
.contact-left{}
.contact-desc{font-size:17px;color:var(--sage);line-height:1.7;margin-bottom:40px;}
.contact-info{display:flex;flex-direction:column;gap:20px;}
.contact-info-item{display:flex;gap:16px;align-items:flex-start;}
.contact-info-label{
  font-family:var(--font-mono);font-size:11px;color:var(--olive);
  letter-spacing:0.08em;text-transform:uppercase;
  width:80px;flex-shrink:0;padding-top:2px;
}
.contact-info-val{font-size:15px;color:var(--cream);font-weight:500;text-decoration:none;transition:color 0.2s;}
a.contact-info-val:hover{color:var(--yellow);}
.contact-form{display:flex;flex-direction:column;gap:16px;}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:16px;}
.form-group{display:flex;flex-direction:column;gap:8px;}
.form-label{
  font-family:var(--font-mono);font-size:11px;font-weight:500;
  letter-spacing:0.08em;text-transform:uppercase;color:var(--sage);
}
.form-input,.form-select,.form-textarea{
  background:var(--navy-mid);border:1px solid rgba(255,255,255,0.1);
  border-radius:12px;padding:14px 18px;
  font-family:var(--font-main);font-size:15px;color:var(--cream);
  outline:none;transition:border-color 0.2s;
  width:100%;
}
.form-input::placeholder,.form-textarea::placeholder{color:rgba(122,132,104,0.6);}
.form-input:focus,.form-select:focus,.form-textarea:focus{border-color:var(--yellow);}
.form-select{appearance:none;cursor:pointer;color:var(--sage);}
.form-select option{background:var(--navy-mid);color:var(--cream);}
.form-textarea{min-height:120px;resize:vertical;}
.form-submit{
  background:var(--yellow);color:var(--navy);
  border:none;border-radius:100px;
  padding:18px 40px;
  font-family:var(--font-main);font-size:16px;font-weight:800;
  letter-spacing:0.02em;cursor:pointer;
  transition:all 0.25s;
  align-self:flex-start;
}
.form-submit:hover{background:var(--cream);transform:translateY(-2px);}
.form-note{font-size:12px;color:var(--olive);line-height:1.5;margin-top:4px;}
.form-status{font-size:14px;line-height:1.5;margin-top:4px;font-weight:500;}
.form-status.ok{color:var(--yellow);}
.form-status.err{color:#ff8b6b;}

/* FOOTER */
footer{
  background:var(--black);padding:40px 48px;
  display:flex;align-items:center;justify-content:space-between;
  flex-wrap:wrap;gap:16px;
}
.footer-logo{display:flex;align-items:center;gap:12px;}
.footer-logo-symbol{height:28px;width:auto;display:block;}
.footer-logo-text{height:15px;width:auto;display:block;}
.footer-copy{font-family:var(--font-mono);font-size:11px;color:rgba(242,238,226,0.3);letter-spacing:0.06em;}
.footer-links{display:flex;gap:24px;}
.footer-links a{font-size:13px;color:rgba(242,238,226,0.4);text-decoration:none;transition:color 0.2s;}
.footer-links a:hover{color:var(--yellow);}

/* CLOVER SVG MARK */
.clover-mark{
  display:inline-block;font-size:inherit;line-height:1;
}

/* BRANDED ELEMENTS */
.accent.underlined{position:relative;}
.word-underline{
  position:absolute;left:-2%;bottom:-0.18em;width:104%;height:auto;
  pointer-events:none;
}
.circled{position:relative;white-space:nowrap;}
.word-circle{
  position:absolute;left:-10%;top:50%;transform:translateY(-50%);
  width:120%;height:auto;pointer-events:none;
}
.about{position:relative;overflow:hidden;}
.about-light{
  position:absolute;top:-40px;right:-60px;width:320px;height:auto;
  opacity:0.35;pointer-events:none;user-select:none;z-index:0;
}
.about .section-label,.about-inner{position:relative;z-index:1;}
.with-swirl{position:relative;display:inline-block;}
.heading-swirl{
  position:absolute;right:-56px;top:-18px;width:80px;height:auto;
  pointer-events:none;
}

/* SCRAMBLE WORD */
.scramble-word{display:inline-block;}
.scr-ltr{display:inline-block;will-change:transform;}      /* зовнішній шар — обмін місцями */
.scr-inner{display:inline-block;will-change:transform;animation:letterAlive 3.4s ease-in-out infinite;} /* внутрішній — «живий» рух */
@keyframes letterAlive{
  0%,100%{transform:translateY(0) rotate(0deg);}
  50%{transform:translateY(-2.5px) rotate(1.2deg);}
}
@media (prefers-reduced-motion: reduce){ .scr-inner{animation:none;} }

/* ANIMATIONS */
@keyframes fadeUp{
  from{opacity:0;transform:translateY(30px);}
  to{opacity:1;transform:translateY(0);}
}
.fade-up{animation:fadeUp 0.7s ease both;}
.fade-up-d1{animation-delay:0.1s;}
.fade-up-d2{animation-delay:0.2s;}
.fade-up-d3{animation-delay:0.35s;}
.fade-up-d4{animation-delay:0.5s;}

@media(max-width:900px){
  nav{padding:16px 24px;}
  .nav-links{display:none;}
  .nav-cta{display:none;}
  .nav-burger{display:flex;}
  .hero{padding:100px 24px 48px;}
  section{padding:72px 24px;}
  .services-grid{grid-template-columns:1fr;}
  .about-inner,.contact-inner{grid-template-columns:1fr;gap:48px;}
  /* кейси — свайп-слайдер на мобілці */
  .cases-grid{
    display:flex;grid-template-columns:none;
    overflow-x:auto;scroll-snap-type:x mandatory;
    gap:16px;margin:0 -24px;padding:4px 24px 12px;scroll-padding-left:24px;
    -webkit-overflow-scrolling:touch;scrollbar-width:none;
  }
  .cases-grid::-webkit-scrollbar{display:none;}
  .case-card{flex:0 0 84%;scroll-snap-align:start;}
  .case-card.featured{grid-column:auto;display:block;}
  .case-card.featured .case-hero{min-height:210px;}   /* щоб тіло картки не виштовхувалось униз */
  footer{padding:32px 24px;}
  .form-row{grid-template-columns:1fr;}
}
