
@media (orientation: landscape) and (max-width: 1024px) {
  .gv-btn-login.gv-btn-sm.hide-mobile {
    display: inline-flex !important; 
  }
}


@media (orientation: landscape) and (max-width: 1100px) and (max-height: 850px) {
  #loginModal .modal-dialog {
    margin: 0 auto !important;
    max-width: 1000px !important;
    width: calc(100% - 1.25rem) !important;
    height: 100vh !important;
    display: flex !important;
    align-items: stretch !important;
  }
  #loginModal .modal-dialog-centered { 
    display: flex !important;
    align-items: stretch !important;
  }
  #loginModal .modal-content {
    height: 100% !important;
    overflow-y: auto !important;
    -webkit-overflow-scrolling: touch;
    background: transparent !important;
  }
  #loginModal iframe.login-iframe {
    height: 100% !important;
    min-height: 100% !important;
  }
}


@media (orientation: landscape) and (max-height: 900px) {
  #loginModal .modal { padding: 0 !important; }
  #loginModal .modal-dialog {
    margin: 0 auto !important;
    width: calc(100% - 2rem) !important;
    height: 100vh !important;
    display: flex !important;
    align-items: stretch !important;
  }
  #loginModal .modal-content {
    height: 100% !important;
    overflow-y: auto !important;
    -webkit-overflow-scrolling: touch;
    background: transparent !important;
  }
  #loginModal iframe.login-iframe {
    height: 100% !important;
    min-height: 100% !important;
  }
}


@media (orientation: landscape) and (min-width: 1180px) and (max-width: 1400px) and (max-height: 1050px) {
  .gv-nav-group.gv-nav-info { display: none !important; }
}


@media (width: 1024px) and (height: 600px) and (orientation: landscape) {
  #loginModal.modal { padding:0 !important; overflow:visible !important; }
  #loginModal .modal-dialog {
    max-width:1000px !important;
    width:calc(100% - 1rem) !important;
    margin:0 auto !important;
    height:820px !important; 
    transform:scale(0.73); 
    transform-origin:top center;
    display:flex !important;
    align-items:flex-start !important;
    justify-content:center !important;
  }
  #loginModal .modal-content { height:820px !important; overflow:visible !important; background:transparent !important; }
  #loginModal iframe.login-iframe { height:820px !important; }
}


@media (width: 932px) and (height: 430px) and (orientation: landscape) {
  .gravisual-footer-col.legal-col { display: none !important; }
}


@media (width: 915px) and (height: 412px) and (orientation: landscape) {
  .gravisual-footer-col.legal-col { display: none !important; }
}


@media (width: 1024px) and (height: 768px) and (orientation: landscape) {
  .gravisual-footer-col.legal-col { display: none !important; }
}


@media (width: 1180px) and (height: 820px) and (orientation: landscape) {
  .gravisual-footer-col.legal-col { display: none !important; }
}


@media (width: 1280px) and (height: 800px) and (orientation: landscape) {
  
  .gs-light-wrapper .container { max-width: 1120px !important; }
}


@media (width: 914px) and (height: 412px) and (orientation: landscape) {
  .gravisual-footer-col.legal-col { display: none !important; }
}


body.terms-page .gv-info-label,
body.license-page .gv-info-label,
body.cookies-page .gv-info-label,
body.accessibility-page .gv-info-label,
body.privacy-page .gv-info-label {
  color: #fff !important;
}

body.terms-page .gv-navbar,
body.license-page .gv-navbar,
body.cookies-page .gv-navbar,
body.accessibility-page .gv-navbar,
body.privacy-page .gv-navbar {
  background: #bf0303 !important;
}
@media (max-width:395px) {
  .why__title,
  .section-title {
    font-size:1.45rem !important;
    line-height:1.13 !important;
    word-break:break-word !important;
    white-space:normal !important;
    padding-left:0 !important;
    padding-right:0 !important;
    font-weight:800 !important;
  }
}

@media (max-width:410px) {
  .portfolio-title,
  .section-title,
  .why__title,
  .logotype {
    font-size:2.1rem !important;
    line-height:1.1 !important;
    word-break:break-word !important;
    white-space:normal !important;
    padding-left:0 !important;
    padding-right:0 !important;
  }
}

@media (min-width:880px) and (max-width:950px) and (min-height:1200px) and (orientation:portrait) {
  html, body {
    width: 100vw !important;
    min-height: 100vh !important;
    margin: 0 !important;
    padding: 0 !important;
    overflow-x: hidden !important;
    background: #090909 !important;
  }
  body > * {
    box-sizing: border-box !important;
    max-width: 100vw !important;
    margin: 0 auto !important;
  }
  
  .hero-bg {
    margin-top: calc(-1 * var(--gv-nav-height, 112px)) !important;
    padding-top: var(--gv-nav-height, 112px) !important;
  }
  
  
  .gv-btn-login.hide-mobile { display: inline-block !important; }
  .gv-btn-login.show-mobile { display: none !important; }
}

@media (width:912px) and (height:1368px) and (orientation:portrait) {
  .gv-btn-login.show-mobile { display:none !important; }
  .gv-btn-login.hide-mobile { display:inline-block !important; }
}

body.doc-page {
  
  padding-top: var(--gv-nav-height, 112px);
}


.site-header {
  background: var(--surface-1, #151518);
  padding: 0.75rem var(--side-pad);
}
.site-header .container {
  display: flex;
  align-items: center;
  gap: 1.5rem;
}
.site-header .brand {
  color: var(--text-light, #fff);
  font-weight: 600;
  text-decoration: none;
}
.site-header .nav {
  display: flex;
  gap: 1.25rem;
  flex-wrap: wrap;
}
.site-header .nav a {
  color: var(--text-light, #fff);
  text-decoration: none;
  font-weight: 500;
}
.site-header .nav a:hover,
.site-header .nav a.active {
  text-decoration: underline;
}

*,
*::before,
*::after { box-sizing: border-box; }

html {
  font-family:'Inter', system-ui,-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Oxygen,Ubuntu,Cantarell,"Fira Sans","Droid Sans","Helvetica Neue",Arial,sans-serif;
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
  scrollbar-gutter: stable !important;
  
  background:#090909;
      
  font-kerning: normal;
  font-feature-settings: "kern" 1;  
  font-variant-ligatures: common-ligatures discretionary-ligatures;
  h1, h2 { letter-spacing: -0.01em; }
  .smallcaps { letter-spacing: 0.03em; }
  
  overflow-x:hidden;
}


body { overflow-x: hidden; }


.gravisual-footer{ overflow-x:hidden; }
.gravisual-footer-bg-svg{ background-position:center center !important; background-size:cover !important; left:0; right:0; }
.gravisual-footer-inner{ box-sizing:border-box; max-width:100vw; }

body {
  margin:0;
  font-family:'Inter', system-ui,-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Oxygen,Ubuntu,Cantarell,"Fira Sans","Droid Sans","Helvetica Neue",Arial,sans-serif;
  background:#090909;
  color:#490b0b;
  line-height:1.4;
  min-height:100vh;
  overflow-x:hidden;
}

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

:focus-visible {
  outline:2px solid #ffde7a;
  outline-offset:2px;
  border-radius:4px;
}


.hidden { display:none !important; }
.text-red, .text-accent { color:#ee0302; }
.fw-bold { font-weight:800; }


:root{
  
  --brand-red:#ee0302;
  --brand-red-hover:#c70404;

  
  --text-light:#ffffff;
  --text-dim:#9fa4b1;
  --surface-0:#090909;
  --surface-1:#151518;
  --surface-2:#1d1f25;
  --surface-3:#20222a;

  
  --line:#ffffff22;
  --line-strong:#ffffff40;
  --shadow-sm:0 2px 6px rgba(0,0,0,.35);
  --shadow-md:0 6px 24px -4px rgba(0,0,0,.40);
  --shadow-lg:0 24px 60px -10px rgba(0,0,0,.55);

  
  --radius-sm:8px;
  --radius-md:12px;
  --radius-lg:20px;
  --radius-pill:28px;

  
  --max-w:2100px;
  --side-pad:clamp(16px,5vw,60px);

  
  --gv-nav-height:96px;
  --gv-nav-pad-x:clamp(28px,4vw,70px);
  --gv-nav-max-width:1900px;

  
  --fs-2xs:clamp(.62rem,.54rem + .25vw,.4rem);
  --fs-xs :clamp(.70rem,.56rem + .35vw,.80rem);
  --fs-sm :clamp(.78rem,.62rem + .40vw,.92rem);
  --fs-md :clamp(.90rem,.74rem + .45vw,1.06rem);
  --fs-lg :clamp(1.10rem,.9rem + .6vw,1.4rem);
  --fs-title:clamp(1.8rem,1.2rem + 2.6vw,3.6rem);

  
  --footer-bg:#090909;
  --footer-text:#fff;
  --footer-gray:#aab4d4;
  --footer-line:rgba(255,255,255,.14);
  --footer-link:#fff;
  --footer-link-hover:#ffe48a;

  
  --gv-bg:#0b0b0c;
  --gv-surface:#151518;
  --gv-text:#e9eaec;
  --gv-dim:#a8acb3;
  --gv-line:rgba(255,255,255,.08);
  --gv-accent:#ff5353;
  --gv-radius:14px;
  --gv-shadow:0 20px 50px rgba(0,0,0,.45);
  --gv-gutter:16px;

  
  --transition-fast:.18s cubic-bezier(.55,.05,.5,1);
  --transition-base:.30s cubic-bezier(.55,.05,.5,1);
}

body.modal-open {
  padding-right: 0 !important;
  overflow-y: hidden !important;
}

html, body {
  font-family: 'Inter', system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Oxygen, Ubuntu, Cantarell, "Fira Sans", "Droid Sans", "Helvetica Neue", Arial, sans-serif !important;
}


body.doc-page{
  
  padding-top: var(--gv-nav-height, 112px);
}


body:not(.doc-page) .hero-bg{
  margin-top: calc(-1 * var(--gv-nav-height, 112px));
  padding-top: 0;
}


.gv-navbar{
  position:fixed;
  inset:0 0 auto;
  height:var(--gv-nav-height);
  display:flex;
  align-items:center;
  background:transparent;
  padding:8px var(--gv-nav-pad-x) 0;
  
  z-index:1800;
  transition: background .35s ease, box-shadow .35s ease, height .30s, transform .25s ease;
  font-size:var(--fs-sm);
  line-height:1.25;
  -webkit-font-smoothing:antialiased;
}

.gv-navbar.scrolled{
  background:#090909f2;
  box-shadow:0 3px 16px rgba(0,0,0,.45);
  backdrop-filter:blur(6px);
  height:80px;
}

.gv-nav-inner{
  width:100%;
  max-width:var(--gv-nav-max-width);
  margin:0 auto;
  display:grid;
  grid-template-columns:auto auto 1fr auto;
  column-gap:clamp(16px,3vw,56px);
  align-items:start;
  position:relative;
}

.gv-nav-group{
  display:flex;
  align-items:center;
  gap:clamp(10px,1.5vw,24px);
  min-width:0;
  flex-wrap:nowrap;
}

.gv-nav-brand{ align-items:flex-start; }
.gv-brand-link{ display:inline-flex; }
.gv-brand-logo{
  width:clamp(52px,6vw,56px);
  height:clamp(52px,6vw,56px);
  object-fit:contain;
  transition:transform .35s;
  margin-top: -6px;
  margin-left: -1px;
}
.gv-navbar.scrolled .gv-brand-logo{ transform:scale(.88); }

.gv-nav-info{
  gap:34px;
  padding-top:6px;
  font-size:var(--fs-xs);
  white-space:nowrap;
  letter-spacing:.02em;
}
.gv-info-block{ display:flex; flex-direction:column; gap:2px; line-height:1.15; }
.gv-info-label{
  font-weight:600;
  color:#c1c1c1;
  font-size:var(--fs-2xs);
  letter-spacing:.05em;
  text-transform:uppercase;
}
.gv-info-link{
  text-decoration:none !important;
  color:#fff;
  font-weight:400;
  font-size: 0.7rem;
  margin-top: 4px;
}
.gv-info-link:hover{text-decoration:underline;}

.gv-nav-primary{
  justify-content:center;
  flex:1 1 auto;
  gap:clamp(16px,2.2vw,40px);
  overflow:hidden;
  min-width:0;
  margin-top: 5px;
}
.gv-nav-link{
  position:relative;
  text-decoration:none !important;
  color:#fff;
  font-weight:500;
  padding:4px 0 6px;
  letter-spacing:.015em;
  display:inline-flex;
  align-items:center;
  white-space:nowrap;
  transition:color .25s;
  
  -webkit-user-select:none; user-select:none;
}
.gv-nav-link::after{
  content:"";
  position:absolute;
  left:0; bottom:0;
  height:2px; width:100%;
  background:#fff;
  transform:scaleX(0);
  transform-origin:left;
  transition:transform .26s;
}
.gv-nav-link:hover::after,
.gv-nav-link.active::after{ transform:scaleX(1); }

.gv-nav-controls{
  gap:14px;
  align-items:center;
  justify-content:flex-end;
  white-space:nowrap;
}


.gv-btn,
.gv-btn-sm{
  border:1px solid #f2f2f25c;
  background:transparent;
  color:#fff;
  font:500 var(--fs-sm) 'Inter',sans-serif;
  padding:8px 14px;
  border-radius:10px;
  display:inline-flex;
  align-items:center;
  gap:6px;
  cursor:pointer;
  line-height:1.1;
  transition:background .2s,border-color .2s;
  -webkit-user-select:none; user-select:none;
}
.gv-btn-sm{ font-size:var(--fs-xs); padding:6px 12px; }
.gv-btn:hover{ background:#ffffff18; border-color:#ffffff30; }
.gv-btn svg{ width:16px; height:16px; opacity:.85; }
.gv-btn-lang{ font-weight:600; }

.gv-btn-login{
  background:#fff;
  color:#000;
  font-weight:600;
  font-size:var(--fs-xs);
  padding:7px 16px;
  border-radius:10px;
  border:1px solid #fff;
  cursor:pointer;
  transition:background .23s,color .23s;
}
.gv-btn-login:hover{ background:#ffe48a; color: #000; }

.gv-btn-cta{
  background:var(--brand-red);
  color:#fff;
  text-decoration:none !important;
  font-weight:600;
  padding:10px 26px;
  border-radius:var(--radius-pill);
  font-size:clamp(.78rem,.62rem + .38vw,.95rem);
  box-shadow:0 4px 18px -4px rgba(238,3,2,.6);
  display:inline-flex;
  align-items:center;
  justify-content:center;
  transition:background .25s, box-shadow .25s;
  -webkit-user-select:none; user-select:none;
}


html :where(*):not(input):not(textarea):not(select):not([contenteditable="true"]) {
  caret-color: transparent !important;
}

html :where(*):not(input):not(textarea):not(select):not([contenteditable="true"]):focus{
  caret-color: transparent !important;
}

input, textarea, select, [contenteditable="true"],
input:focus, textarea:focus, select:focus, [contenteditable="true"]:focus{
  caret-color: auto !important;
}
.gv-btn-cta:hover{ background:var(--brand-red-hover); box-shadow:0 6px 26px -4px rgba(238,3,2,.7); }

.gv-burger{
  display:none;
  background:none;
  border:0;
  padding:6px;
  cursor:pointer;
  flex-direction:column;
  gap:5px;
}
.gv-burger span{
  width:30px; height:3px;
  background:#fff;
  border-radius:2px;
  transition:.3s;
}
.gv-burger.open span:nth-child(1){transform:translateY(8px) rotate(45deg);}
.gv-burger.open span:nth-child(2){opacity:0;}
.gv-burger.open span:nth-child(3){transform:translateY(-8px) rotate(-45deg);}

.gv-item{ position:relative; }
.gv-panel{
  position:absolute;
  top:calc(100% + 10px);
  
  right:0;
  background:var(--gv-surface);
  border:1px solid var(--gv-line);
  border-radius:14px;
  padding:18px;
  box-shadow:var(--gv-shadow);
  z-index:1500;
  min-width:clamp(520px,55vw,820px);
}
.gv-panel[hidden]{ display:none !important; }

.gv-mega-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:14px;
  margin-bottom:10px;
}
.gv-card{
  display:block;
  background:#1a1b20;
  border:1px solid var(--gv-line);
  border-radius:12px;
  overflow:hidden;
  text-decoration:none;
  color:#e9eaec;
  transition:transform .18s, border-color .18s;
}
.gv-card:hover{ transform:translateY(-2px); border-color:#ffffff35; }
.gv-card img{width:100%;height:140px;object-fit:cover;display:block;}
.gv-card-body{padding:10px 12px;}
.gv-cap{font-size:var(--fs-2xs);margin:0 0 2px;color:var(--gv-dim);text-transform:uppercase;letter-spacing:.05em;}
.gv-title{margin:0;display:flex;align-items:center;gap:6px;font-weight:600;color:#fff;font-size:var(--fs-sm);}
.gv-title svg{width:16px;height:16px;opacity:.75;}
.gv-desc{margin:6px 0 0;font-size:var(--fs-xs);color:#c8cbd2;}

.gv-stack{margin:8px 0 0;border-top:1px dashed var(--gv-line);padding-top:10px;}
.gv-stack ul{list-style:none;margin:0;padding:0;}
.gv-stack a{
  display:flex;justify-content:space-between;align-items:center;
  gap:8px;padding:9px 8px;text-decoration:none;
  color:#e8eaef;font-size:var(--fs-xs);
  border-radius:10px;border:1px solid transparent;
  transition:background .18s,border-color .18s;
}
.gv-stack a:hover{background:#1f2026;border-color:#ffffff20;}
.gv-divider{width:100%;height:1px;background:var(--gv-line);margin:6px 0;}

.gv-lang-panel{
  min-width:170px !important;
  padding:8px !important;
  left:auto; right:0; top:calc(100% + 8px);
}
.gv-lang-list{
  list-style:none;
  display:flex;
  flex-direction:column;
  gap:4px;
  margin:0; padding:0;
}
.gv-lang-link{
  display:block;
  text-decoration:none !important;
  color:#fff;
  font-size:var(--fs-xs);
  padding:8px 10px;
  border-radius:8px;
  transition:background .15s,color .15s;
}
.gv-lang-link:hover{background:#23252c;color:#fff;}
.gv-lang-link.is-active{background:#2b2f37;font-weight:600;}

@media (pointer:fine){
  .gv-item.gv-hoverable:hover>.gv-panel{display:block;}
}


.gv-navbar{ --gv-nav-font-mult: .94; }
.gv-navbar .gv-nav-link{
  font-size: calc(var(--fs-sm) * var(--gv-nav-font-mult));
  padding: 3px 0 4px;
}
.gv-navbar .gv-info-label{ font-size: calc(var(--fs-2xs) * var(--gv-nav-font-mult)); }
.gv-navbar .gv-info-link{ font-size: calc(.70rem * var(--gv-nav-font-mult)); }
.gv-navbar .gv-btn{ font-size: calc(var(--fs-sm) * var(--gv-nav-font-mult)); padding: 7px 13px; }
.gv-navbar .gv-btn-sm{ font-size: calc(var(--fs-xs) * var(--gv-nav-font-mult)); padding: 5px 11px; }
.gv-navbar .gv-btn svg{ width:14px; height:14px; }
.gv-navbar .gv-btn-login{ font-size: calc(var(--fs-xs) * var(--gv-nav-font-mult)); padding: 6px 14px; border-radius:var(--radius-pill); }
.gv-navbar .gv-btn-cta{ font-size: calc(.78rem * var(--gv-nav-font-mult)); padding: 9px 24px; }


.gv-mobile-menu{
  position:fixed;
  inset:0;
  background:#0d0d0d;
  z-index:1400;
  display:flex;
  flex-direction:column;
  animation:fadeIn .35s;
}
.gv-mobile-menu[hidden]{display:none !important;}
.gv-mobile-inner{
  padding:calc(14px + env(safe-area-inset-top)) 26px 42px;
  overflow-y:auto;
  flex:1;
  display:flex;
  flex-direction:column;
  gap:18px;
}
.gv-mobile-close{
  position:absolute;
  top:14px; right:14px;
  width:44px; height:44px;
  background:#1d1f25;
  border:1px solid var(--gv-line);
  color:#fff;
  font-size:1.5rem;
  border-radius:12px;
  cursor:pointer;
}
.gv-mobile-nav{
  display:flex;
  flex-direction:column;
  gap:0;
  margin:0;
  padding:0;
  margin-top: 35px;
  margin-bottom: 35px;
}
.gv-mobile-nav a{
  text-decoration:none !important;
  color:#fff;
  font-weight:600;
  font-size:1.05rem;
  padding:13px 4px;
  border-bottom:1px solid #2a2a2a;
  letter-spacing:.01em;
}



.gv-mobile-contact{
  display:flex;
  flex-direction:column;
  gap:4px;
  font-size:var(--fs-xs);
  line-height:1.35;
  color:#ddd;
  margin-top:54px;
}
.gv-mobile-contact .mc-label{
  font-size:var(--fs-2xs);
  letter-spacing:.05em;
  text-transform:uppercase;
  color:#9fa4b1;
  font-weight:600;
}
.gv-mobile-contact .mc-link{
  color:#fff;
  text-decoration:none;
  font-weight:500;
  word-break:break-all;
}
.gv-mobile-contact .mc-link:hover{ text-decoration:underline; }


@media (max-width: 900px){
  .gv-mobile-inner{ padding:calc(20px + env(safe-area-inset-top)) 22px 28px; gap:14px; }
  .gv-mobile-close{
    top:16px; right:16px; width:42px; height:42px;
    background:#1a1c22; border-color:#2e323a; color:#fff;
  }
  .gv-mobile-divider.thin{ height:1px; background:rgba(255,255,255,.12); margin:12px 0 16px; }
  .gv-mobile-contact{ margin-top:18px; color:#d6d7db; }
  .gv-mobile-contact .mc-label{ color:#a7adb8; letter-spacing:.06em; }

  .gv-mobile-nav{ margin-top:14px; margin-bottom:10px; }
  .gv-mobile-nav a{
    display:flex; align-items:center; gap:10px;
    padding:14px 0; min-height:44px;
    border:0; border-bottom:1px solid rgba(255,255,255,.08);
    color:#e9eaec; font-weight:700; font-size:1.08rem; letter-spacing:.01em;
    transition:color .2s, background .2s, border-color .2s;
  }
  .gv-mobile-nav a::before{
    content:""; display:inline-block; width:4px; height:22px; border-radius:3px;
    background:transparent; margin-right:10px; transition:background .25s;
  }
  .gv-mobile-nav a:hover, .gv-mobile-nav a.active{ color:#ffe48a; border-color:rgba(255,255,255,.16); }
  .gv-mobile-nav a:hover::before, .gv-mobile-nav a.active::before{ background:var(--brand-red); }

  .gv-mobile-brand .mb-icon-img{ width:220px; height:auto; margin-top:12px !important; display:block; }
  .gv-mobile-partner{ margin-top:18px; padding-top:12px; border-top:1px solid rgba(255,255,255,.10); }
  .mobile-col-copyright{ color:#c9cbd1; font-size:.88rem; }
}

.gv-mobile-divider{
  width:100%;
  height:1px;
  background:#ffffff14;
  margin:22px 0;
}


.gravisual-footer-col.legal-col{ padding-left:24px; }
.gravisual-footer-col.legal-col .legal-links{ display:flex; flex-direction:column; gap:8px; }
.gravisual-footer-col.legal-col .legal-select{ display:none; margin-top:8px; padding:8px; background:#0d0d0d; color:#fff; border:1px solid #222; }

@media (max-width:900px){
  .gravisual-footer-col.legal-col .legal-links{ display:flex; flex-direction:column; gap:8px; }
  .gravisual-footer-col.legal-col .legal-select{ display:none; }
}


@media (max-width:900px){
  
  .gravisual-footer-col.legal-col{ display:none !important; }
  
  .footer-legal-wrap{ display:none !important; }
}


.gv-mobile-menu .lang-custom,
.gv-mobile-menu .mob-user-block,
.gv-mobile-menu .mob-user-name,
.gv-mobile-menu .mob-login-below-brand,
.gv-mobile-menu .gv-btn-login{
  display: none !important;
}

.gv-mobile-brand{
  display:flex;
  flex-direction:column;
  gap:10px;
  align-items:flex-start;
}
.gv-mobile-brand .mb-icon img{
  width:74px;
  height:74px;
  object-fit:contain;
  display:block;
}
.gv-mobile-brand .mb-wordmark{
  width:240px;
  max-width:68vw;
  display:block;
  height:auto;
  filter:drop-shadow(0 4px 18px rgba(0,0,0,.45));
}

.gv-mobile-lang-login{
  display:flex;
  align-items:center;
  gap:18px;
  flex-wrap:wrap;
}
.gv-mobile-lang-login .mobile-lang-group{
  display:flex;
  align-items:center;
  gap:8px;
  background:#1d1f25;
  border:1px solid #2c2f36;
  padding:8px 14px;
  border-radius:40px;
}
.gv-mobile-lang-login .ml-label{
  font-size:1.15rem;
  color:#fff;
  display:flex;
  align-items:center;
  justify-content:center;
}
.gv-mobile-lang-login .ml-select{
  background:transparent;
  border:0;
  color:#fff;
  font-size:.85rem;
  font-weight:600;
  outline:none;
  appearance:none;
  padding:0 4px;
  cursor:pointer;
}
.gv-mobile-lang-login .ml-select option{ color:#111; }
.gv-mobile-lang-login .full-width{
  flex:1 1 auto;
  min-width:140px;
}

.gv-mobile-partner{
  display:flex;
  flex-direction:column;
  gap:6px;
  color:#9fa4b1;
  margin-top:4px;
}
.gv-mobile-partner .partner-eyebrow{
  font-size:.55rem;
  text-transform:uppercase;
  letter-spacing:.12em;
  color:#62666f;
  font-weight:600;
  margin-top:4px;
}
.gv-mobile-partner .partner-logo{
  width:auto; height:42px; max-width:70vw;
  display:block;
  filter:grayscale(1) brightness(.92);
  opacity:.9;
  align-self: baseline;
}

.gv-mobile-copyright{
  margin-top:12px;
  font-size:.72rem;
  line-height:1.35;
  color:#767676;
  letter-spacing:.02em;
  max-width:240px;
}

.gv-mobile-extra{ margin-top:auto; }
.gv-btn-cta.full{ width:100%; text-align:center; }


.gv-mobile-footer{ margin-top:auto; padding-top:10px; }

@keyframes fadeIn{from{opacity:0} to{opacity:1}}

html.scroll-lock,
body.scroll-lock{ overflow:hidden; overscroll-behavior:none; }
body.scroll-lock{ position:fixed; width:100%; }

body.scroll-lock{
  overflow:hidden;
  overscroll-behavior:none;
  position:fixed;
  width:100%;
  padding-right: var(--gv-scrollbar-comp, 0px) !important;
}

@media (max-width:1024px){
  .hide-mobile { display:none !important; }
  .gv-navbar.scrolled{ height:74px; }
}
@media (max-width:640px){
  .hide-mobile-medium { display:none !important; }
  .gv-btn-cta{ display:none; }
  .gv-nav-controls{ gap:10px; margin-top: 10px;}

@media (max-width:360px){
  .logotype{ width:clamp(340px,100vw,380px); }
}
  .gv-btn-login{ padding:6px 12px; }
}

@media (max-width:1350px){
  .gv-nav-info{gap:18px;}
  .gv-nav-inner{column-gap:clamp(14px,2.2vw,42px);}
}
@media (max-width:1180px){
  .gv-nav-info{display:none;}
  .gv-nav-inner{grid-template-columns:auto 1fr auto;}
}
@media (max-width:1024px){
  .gv-nav-primary{display:none;}
  .gv-burger{display:flex;}
  .gv-nav-inner{grid-template-columns:auto 1fr auto;}
}

.gv-burger:focus-visible{
  outline:2px solid #ffe48a;
  outline-offset:4px;
  border-radius:6px;
}

@media (prefers-reduced-motion:reduce){
  .gv-navbar,
  .gv-btn,
  .gv-btn-cta,
  .gv-nav-link::after{transition:none !important;}
}

.hero-bg{
  
  margin-top: calc(-1 * var(--gv-nav-height, 112px));
  
  padding-top: var(--gv-nav-height, 112px);
  width:100%;
  min-height:100vh;
  
  position:relative;
  display:flex;
  flex-direction:column;
  justify-content: flex-start;
}


.hero-content{
  padding: 60px var(--side-pad);
  min-height:700px;
  width:100%;
  max-width:var(--max-w);
  margin:0 auto;
}

.logotype{
  
  width:100%;
  max-width:700px;
  margin:400px 0 22px 23px;
}
.logotype img{ width:100%; height:auto; display:block; }

.hero-desc{
  font-size:1.02rem;
  line-height:1.45;
  font-weight:500;
  color:#f0f0f0;
  margin-left:26px;
  max-width:640px;
  letter-spacing: -.01em;
}



@media (max-width:900px){
  .hero-content{ padding:calc(var(--gv-nav-height) + 20px) 24px 0; }
  .logotype{ width:400px; margin:40px 0 18px 18px; }

@media (min-width:401px) and (max-width:480px){
  .logotype{ width:clamp(340px,88vw,390px); }
}
  .hero-desc{ margin-left:18px; max-width:70vw; }
}
@media (max-width:600px){
  .logotype{ width:270px; margin:28px 0 16px 14px; }
  .hero-desc{ font-size:.95rem; margin-left:14px; }
}


@media (min-width:900px) and (max-width:1100px) and (max-height:650px) {
  .hero-content { padding:calc(var(--gv-nav-height) + 8px) 48px 0; }
  
  .logotype { margin:160px 0 22px 0px; }
  .hero-desc { margin-left:0; }
}


@media (min-width:1000px) and (max-width:1050px) and (min-height:1200px) and (orientation:portrait) {
  .hero-content { padding:calc(var(--gv-nav-height) + 20px) 60px 0; }
  .logotype { margin:300px 0 22px -5px; }
  .hero-desc { margin-left:0; }
}


@media (min-width:1000px) and (max-width:1100px) and (min-height:1200px) and (orientation:portrait) {
  html, body {
    width: 100vw !important;
    min-height: 100vh !important;
    margin: 0 !important;
    padding: 0 !important;
    overflow-x: hidden !important;
    background: #090909 !important;
  }
  body > * {
    box-sizing: border-box !important;
    max-width: 100vw !important;
    margin: 0 auto !important;
  }
}


@media (min-width:880px) and (max-width:940px) and (min-height:1200px) and (orientation:portrait) {
  .hero-content { padding:calc(var(--gv-nav-height) + 16px) 58px 0; }
  .logotype { margin:280px 0 22px -5px; }
  .hero-desc { margin-left:0; }
}


.portfolio-section{ background:#fff; padding:0 0 50px; color:#222; }
.portfolio-container{ max-width:1200px; margin:auto; padding:0 24px; }

.portfolio-header{ text-align:center; margin-bottom:40px; }
.portfolio-title{
  display:flex; justify-content:center; align-items:flex-end; gap:.28em;
  font-size:clamp(1.6rem,4.2vw,3.4rem); font-weight:800; letter-spacing:-.04em; margin-top:0;
}
.portfolio-arrow{ position:relative; top:.18em; flex-shrink:0; }
.portfolio-arrow svg{ width:2em; height:2em; display:block; animation:bounce 1.8s infinite; }
@keyframes bounce{0%,100%{transform:translateY(0)}50%{transform:translateY(6px)}}

.portfolio-header p{
  color:#555; font-size:clamp(.95rem,2.5vw,1.06rem); line-height:1.55; margin:0; letter-spacing:-.02em;
}
.portfolio-grid{ display:grid; grid-template-columns:repeat(auto-fit,minmax(270px,1fr)); gap:28px; }
.portfolio-item{
  background:#f6f6f6; border-radius:13px; box-shadow:0 6px 18px rgba(0,0,0,.09);
  transition:transform .34s, box-shadow .34s; display:flex; flex-direction:column; justify-content:flex-end;
  position:relative; overflow:hidden;
}
.portfolio-item:hover{ transform:translateY(-10px) scale(1.04); box-shadow:0 16px 40px rgba(0,0,0,.09); }
.portfolio-item img{
  width:100%; height:300px; object-fit:cover; object-position:center; display:block;
  transition:transform .5s cubic-bezier(.55,.05,.5,1), filter .7s;
  filter:grayscale(.18) brightness(.93); border-bottom:1px solid #eee;
}
.portfolio-item:hover img{ transform:scale(1.08); filter:grayscale(0) brightness(1); }
.p-caption{
  background:rgba(255,255,255,.93); color:#212121; padding:16px 20px 15px;
  font-size:1rem; line-height:1.45; font-weight:500; border-radius:0 0 12px 12px;
  box-shadow:0 1px 10px rgba(230,57,70,.04); position:absolute; inset:auto 0 0 0;
}

@media (max-width:900px){
  .portfolio-container{ padding:0 35px 35px; }
  .portfolio-grid{ gap:30px; }
  .portfolio-title{ font-size:2.6rem; }
}
@media (max-width:650px){
  .portfolio-container{ padding:0 28px 28px; }
  .portfolio-grid{ gap:26px; }
  .p-caption{ font-size:.93rem; }
  .refs-container{ padding: 0 28px 28px; }
}

@media (max-width:520px){
  .portfolio-title{ font-size:2.05rem; line-height:1.15; gap:.18em; flex-wrap:wrap; }
  .portfolio-title .portfolio-arrow{ width:100%; display:flex; justify-content:center; top:0; margin-bottom:6px; }
  .portfolio-title .portfolio-arrow svg{ width:100px; height:100px; }
  .portfolio-header p{ font-size:.95rem; line-height:1.35em; letter-spacing: -0.025em; margin-top:8px; }
}
@media (max-width:380px){
  .portfolio-title{ font-size:1.82rem; }
  .portfolio-title .portfolio-arrow svg{ width:28px; height:28px; }
}


.why__section{
  position:relative;
  background:#090909;
  padding:0;
  width:100%;
  overflow:hidden !important;
  color: #fff;
  padding: clamp(20px, 4vw, 48px);
}
.why__glow-canvas{
  position:absolute; left:0; top:0; width:100%; height:100%; pointer-events:none; z-index:2; display:block;
}
.why__intro{ text-align:center; background:transparent; margin-bottom:0; z-index:3; position:relative; }
.why__subtitle{ font-size:.775rem; color:#888; margin-bottom:.5rem; text-transform:uppercase; letter-spacing:.05em; }

.why__title{
  display:flex; justify-content:center; align-items:flex-end; gap:.28em;
  font-size:clamp(1.6rem,4.5vw,3.4rem); font-weight:700; line-height:1.22; margin-top:10px; color:#fff; letter-spacing:-.03em;
}
.why__arrow{ position:relative; top:.18em; flex-shrink:0; }
.why__arrow svg{ width:2.1em; height:2.1em; display:block; animation:whyBounce 1.9s infinite; }
.why__highlight{ color:var(--brand-red); }

.why__card-row{
  position:relative; display:flex; flex-wrap:wrap; gap:2.5rem; justify-content:center; margin:2rem 0; z-index:3;
}
.why__card{
  position:relative; border-radius:2rem; padding:0rem -2.15rem 2rem;
  width:100%; max-width:520px; min-width:240px;
  display:flex; flex-direction:column; align-items:center; z-index:4; background:transparent; 
  font-size: .95rem; letter-spacing: -0.005em;
}
.why__wrapper{ position:relative; width:340px; height:340px; margin-bottom:2rem; pointer-events:none; }
.why__model{
  position:absolute; top:50%; left:50%; transform:translate(-50%,-50%);
  width:300px; height:300px;
  background:transparent !important; pointer-events:none; user-select:none; touch-action:none; z-index:3;
}
.why__card-content{ width:100%; text-align:center; }
.why__card-title{ color:#ee0302; font-size:1.6rem; font-weight:700; margin:0 0 1rem; letter-spacing: -0.025em;}
.why__card-text{ color:#ccc; font-size:1rem; margin:0; }

@keyframes whyBounce{ 0%,100%{transform:translateY(0)} 50%{transform:translateY(6px)} }

@media (max-width:900px){
  .why__title{ font-size:clamp(2rem,4.4vw,2.4rem); gap:.15em; }
  .why__arrow svg{ width:1.8em; height:1.8em; }
  .why__card-row{ gap:2rem; }
  .why__wrapper{ width:300px; height:300px; }
  .why__model{ width:260px; height:260px; }
  .why__card{ padding:0rem 1.5rem 1.5rem; font-size: 0.75em; }
}

@media (min-width:740px) and (max-width:820px){
  .filters-section{ padding: 1rem 9.5vw 1rem; }
}


@media (min-width:760px) and (max-width:780px){
  body .filters-section{ padding: 1rem 9.5vw 1rem !important; }
}


@media (min-width:720px) and (max-width:900px){
  .filters-section{ padding: 1rem 9.5vw 1rem !important; }
}


@media (min-width:1024px) and (max-width:1366px){
  .filters-section{ padding: 1rem 8.5vw 1rem !important; }
}


@media (min-width:912px) and (max-width:1368px){
  .filters-section{ padding: 1rem 9.0vw 1rem !important; }
}
@media (max-width:650px){
  .why__title{ font-size:2.4rem; flex-wrap:wrap; line-height:1.3; }
  .why__arrow{ top:.1em; order:-1; }
  .why__arrow svg{ width:120px; height:120px; }
  .why__wrapper{ width:260px; height:260px; }
  .why__model{ width:220px; height:220px; }
  .why__section{ padding-right: 1em; padding-left: 1em; color: #fff;}
  .why__card{ padding:-1rem 0.5rem 1.5rem; }
}
@media (max-width:480px){
  .why__wrapper{ width:220px; height:220px; }
  .why__model{ width:190px; height:190px; }
  .why__card-title{ font-size:1.6rem; }
  .why__card-text{ font-size:.92rem; }
  .why__card-row{ gap:1.3rem; }
}

.why__grid{
  position:absolute; left:0; right:0; top:96px; height:548px;
  transform-origin:center top;
  transform:perspective(1500px) rotateX(-320deg);
  opacity:1; pointer-events:none; z-index:1;
}
@media (max-width:650px){
  .why__grid{ top:340px; opacity:.16; }
}

    
    .why__section{ padding: clamp(20px, 4vw, 48px) clamp(16px, 5vw, 64px); }
    .why__intro{ margin-bottom: clamp(8px, 2.5vw, 20px); }
    
    .why__card-row{
      display:grid;
      grid-template-columns:repeat(3,minmax(0,1fr));
      gap:clamp(16px, 2.5vw, 32px);
      margin:clamp(12px, 2vw, 32px) 0;
      position:relative;
      z-index:3;
      align-items:start;
    }
    
    @media (orientation:portrait) and (max-width:650px){
      .why__card-row{ grid-template-columns:1fr; }
    }
    @media (orientation:portrait) and (min-width:651px){
      .why__card-row{ grid-template-columns:repeat(3,minmax(0,1fr)); }
      .why__title{ margin-bottom: 40px; }
      .why__card-title{ font-size: 20px !important }
      .why__section{ padding: 25px; }
    }
    
    @media (orientation:landscape) and (max-width:1199px){
      .why__card-row{ grid-template-columns:repeat(3,minmax(0,1fr));}
      .why__card-content{ padding:0 8px 0 8px;  }
    }
    .why__card{width:100%; max-width:none;}
    
    .why__wrapper{ width:clamp(180px, 22vw, 320px); height:clamp(180px, 22vw, 320px); margin:0 auto 1.6rem; }
    .why__model{ width:clamp(190px, 20vw, 300px) !important; height:clamp(190px, 20vw, 300px) !important; }
    
    .why__card-title{ font-size:clamp(2rem, 1.2vw + .6rem, 1.6rem); }
    .why__card-text{ font-size:clamp(.9rem, .25vw + .82rem, 1rem); }


@media (min-width:1024px){
  .why__card-row .why__card-content{
    width: calc(100% - 100px); 
  }
}


.refs-section{ background:#fff; padding:0; color:#111; }

.refs-header{ text-align:center; margin:0 0 40px; }

.refs-title{
  display:flex; justify-content:center; align-items:flex-end; gap:.28em;
  font-size:clamp(1.6rem,4.2vw,3.4rem); font-weight:800; letter-spacing:-.04em; margin:0 0 40px;
}

.refs-arrow{ position:relative; top:.18em; flex-shrink:0; }
.refs-arrow svg{ width:2em; height:2em; display:block; animation:bounce 1.8s infinite; }

.logo-row{
  background:#e6e6e6; display:flex; flex-wrap:wrap; justify-content:center; align-items:center;
  gap:2rem; padding:2rem;
}
.logo-item{ flex:0 1 clamp(110px,8vw,160px); display:flex; justify-content:center; align-items:center; }
.logo-item img{
  width:100%; max-height:clamp(60px,5.5vw,100px); object-fit:contain;
  filter:grayscale(.15) brightness(.95); transition:filter .3s;
}
.logo-item:hover img{ filter:none; }

@media (max-width:900px){
  .refs-title{ flex-wrap:wrap; justify-content:center; font-size:3em; text-align:center; line-height:.85em; letter-spacing:-.045em; }
  .refs-arrow{ top:0; }
}
@media (max-width:650px){
  .refs-title{
    display:flex; flex-direction:column; align-items:center; gap:.25em;
    font-size:2.4rem; margin:0 0 24px; text-align:center; line-height:.9em;
  }
  .logo-item{ flex:0 1 calc(33.333% - 1rem); }
}
@media (max-width:480px){
  .logo-item{ flex:0 1 calc(50% - 1rem); }
}


@media (max-width:520px){
  
  .why__title .why__arrow{ width:100%; display:flex; justify-content:center; top:0; margin-bottom:6px; order:-1; }
  .why__title .why__arrow svg{ width:100px; height:100px; }

  
  .refs-title{ font-size:2rem; line-height:1; }
  .refs-title .refs-arrow{ width:100%; display:flex; justify-content:center; top:0; margin-bottom:6px; }
  .refs-title .refs-arrow svg{ width:100px; height:100px; }

  
  .faq-section .section-title{ font-size:1.9rem; }
}
@media (max-width:380px){
  .why__title{ font-size:1.82rem; }
  .why__title .why__arrow svg{ width:100px; height:100px; }
  .refs-title{ font-size:1.82rem; }
  .refs-title .refs-arrow svg{ width:28px; height:28px; }
}


.faq-section{ background:#f6f7f8; padding:60px 24px 20px; color:#111; }
.faq-section .section-title{
  font-size:clamp(2.2rem,1.2rem + 3.2vw,3.4rem);
  text-align:center;
  margin:0 0 2.2rem;
  font-weight:800;
  letter-spacing:-.04em;
}
.faq-section .highlight{ color:var(--brand-red); }

.faq-accordion{ max-width:960px; margin:0 auto; }
.faq-accordion details{
  border:1px solid #e5e5e5; border-radius:10px; margin-bottom:16px; overflow:hidden; padding:18px 24px;
  background:#fafafa; transition:box-shadow .25s, border-color .25s;
}
.faq-accordion details[open]{ box-shadow:0 4px 24px rgba(0,0,0,.06); border-color:#dadada; }
.faq-accordion summary{
  cursor:pointer;
  font-weight:700;
  font-size:1.15rem;
  position:relative;
  list-style:none;
  
  display:block;
  padding-right:52px; 
}
.faq-accordion summary::-webkit-details-marker{ display:none; }
.faq-accordion summary::after{
  content:"+";
  position:absolute;
  right:18px;
  top:50%;
  transform:translateY(-50%);
  font-weight:800;
  transition:transform .18s ease, content .18s;
  pointer-events:none; 
}
.faq-accordion details[open] summary::after{ content:"-"; transform:translateY(-50%) rotate(180deg); }
.faq-accordion p{
  font-size:.95rem; line-height:1.6; color:#444; margin:0;
  margin-top:10px; 
  padding-left:6px; 
}

@media (max-width:520px){
  .faq-accordion summary{ padding-right:60px; }
  .faq-accordion summary::after{ right:20px; }
}


.faq-accordion details[open] summary::after{ content:"-" !important; }


.footer-logotype img{ width:100%; height:auto; margin-bottom:-30px; display:block; }

.gravisual-footer{
  background:var(--footer-bg); color:var(--footer-text);
  padding-top:10px; position:relative; overflow:hidden;
  font-size:var(--fs-sm);
}
.gravisual-footer-bg-svg{
  position:absolute; inset:0; width:100%; height:100%;
  pointer-events:none; z-index:0; opacity:.45;
  background:url('../images/svg/gravisual-hero-scanlight-wave.svg') no-repeat center / cover;
}

.gravisual-footer-inner{
  max-width:var(--max-w); margin:0 auto; padding:0 var(--side-pad) 40px;
  display:grid; grid-template-columns:minmax(260px,2fr) repeat(2,minmax(180px,1fr)) minmax(260px,1.3fr);
  gap:0 114px; align-items:start; border-bottom:1px solid var(--footer-line);
  position:relative; z-index:1;
}
.gravisual-footer-col{ display:flex; flex-direction:column; gap:14px; min-width:0; }

.logo-col .footer-logo-big{
  font-size:clamp(3rem,8vw,7rem); font-weight:800; line-height:1; margin:0 0 12px;
  letter-spacing:-.04em; white-space:nowrap;
}
.footer-address{ color:var(--footer-gray); font-size:1.02rem; line-height:1.32; }
.footer-bold{ font-weight:700; letter-spacing:.01em; }

.footer-label{ color:var(--brand-red); font-size:.82rem; font-weight:600; margin-bottom:4px; letter-spacing:.08em; text-transform:uppercase; }
.footer-link-lg,.footer-link-md,.footer-link-sm{
  color:var(--footer-link); text-decoration:none; font-weight:500; transition:color .2s;
  line-height:1.4;
}
.footer-link-lg{ font-size:1.1rem; margin-bottom:4px; }
.footer-link-md{ font-size:.95rem; }
.footer-link-sm{ font-size:.78rem; letter-spacing:.03em; }
.footer-link-lg:hover,.footer-link-md:hover,.footer-link-sm:hover{ color:var(--footer-link-hover); text-decoration:underline; }

.social-partner-wrap{
  grid-column:span 1;
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:32px;
}
.social-partner-wrap .social-col{
  display:flex; flex-direction:column; gap:8px;
}
.partner-col{
  display:flex; justify-content:flex-end; align-items:flex-start;
}
.footer-partner{
  display:flex; flex-direction:column; gap:8px; color:#cbd1e1;
}
.footer-partner-eyebrow{
  font-size:.55rem; letter-spacing:.10em; text-transform:uppercase; color:#595959;
}
.footer-partner-logo{
  height:45px; width:auto; display:block;
  filter:grayscale(1) brightness(.92);
  opacity:.95;
}

.gravisual-footer-bottom{
  max-width:var(--max-w); margin:0 auto; padding:18px var(--side-pad) 12px;
  display:flex; justify-content:space-between; align-items:center; font-size:.82rem;
  opacity:.9; flex-wrap:wrap; gap:1rem; position:relative; z-index:1;
}


@media (min-width: 769px){
  .gravisual-footer-bottom .footer-bottom-right{ margin-right:88px; }
}

@media (max-width:1200px){
  .gravisual-footer-inner{
    grid-template-columns:minmax(240px,1.7fr) repeat(2,minmax(180px,1fr));
    gap:0 42px;
  }
  .social-partner-wrap{ grid-column:span 1; }
  .footer-logotype{ width:300px; }
}
@media (max-width:900px){
  .gravisual-footer-inner{
    grid-template-columns:1fr 1fr;
    gap:32px 20px;
    padding:0 5vw 32px;
  .footer-logotype{ width:255px;}
  }
  .logo-col{ grid-column:1 / -1; }
  .contact-col{ grid-row:2; grid-column:1 / -1; }
  .social-partner-wrap{
    grid-row:3; grid-column:1 / -1;
    display:flex; justify-content:space-between; align-items:flex-start; gap:20px;
  }
  .social-partner-wrap .social-col{ flex:1; }
  .social-partner-wrap .partner-col{ flex:1; justify-content:flex-end; }
}
@media (max-width:650px){
  .gravisual-footer-inner{
    grid-template-columns:1fr; gap:22px 0; padding:0 7vw 28px;
  }
  .gravisual-footer-col{ gap:12px; }
  .footer-partner{ margin-top:12px; }
  .gravisual-footer-bottom{
    flex-direction:column; text-align:center; padding:14px 7vw 10px; gap:.8rem;
  }
}
@media (max-width:480px){
  .footer-partner-logo{ height:40px; }
  .gravisual-footer-bottom{ font-size:.75rem; }
}


.footer-svg-path{
  stroke-dasharray:1800; stroke-dashoffset:1800; opacity:0;
  transition:stroke-dashoffset 1.6s cubic-bezier(.67,.06,.38,1), opacity 1.1s cubic-bezier(.67,.06,.38,1);
}
.gravisual-footer.footer-animate .footer-svg-path{ stroke-dashoffset:0; opacity:1; }
.gravisual-footer-inner,.gravisual-footer-bottom{
  opacity:0; transform:translateY(40px);
  transition:opacity 1.2s cubic-bezier(.67,.06,.38,1), transform 1s cubic-bezier(.67,.06,.38,1);
}
.gravisual-footer.footer-animate .gravisual-footer-inner,
.gravisual-footer.footer-animate .gravisual-footer-bottom{ opacity:1; transform:none; padding: 40px;}


.hero--home{ padding-top:calc(var(--gv-nav-height) + 40px); }
.site-main{ background:#fff; color:#111; }
html.scroll-lock, body.scroll-lock{ overscroll-behavior:none; }

body.modal-open { padding-right: var(--gv-scrollbar-comp,0px) !important; }


@media (max-width:640px) {
  #btn-fiyatlar { display: none !important; }
}


.gv-mobile-menu{
  position:fixed;
  inset:0;
  background:#090909;
  z-index:1400;
  display:flex;
  flex-direction:column;
  height:100dvh;
  
  height:100vh;
}
.gv-mobile-inner{
  flex:1;
  display:flex;
  flex-direction:column;
  min-height:0;
  padding:calc(18px + env(safe-area-inset-top)) 35px 20px;
  gap:0;
}
.gv-mobile-top{
  flex:1 1 auto;
  min-height:0;
  display:flex;
  flex-direction:column;
  overflow-y:auto;
  overscroll-behavior:contain;
  scrollbar-width:none;
}
.gv-mobile-top::-webkit-scrollbar{width:0;height:0;}


@media (min-width:900px) and (max-height:760px){
  .gv-mobile-top.gv-mobile-grid.gv-mobile-grid-3{
    
    display:flex;
    flex-direction:column;
    gap:24px;
    overflow:auto; 
  }
  
  .gv-mobile-top.gv-mobile-grid:not(.gv-mobile-grid-3){
    display:flex;
    flex-direction:column;
    gap:28px;
    overflow:auto;
  }
  .gv-mobile-top.gv-mobile-grid .mob-col{min-width:0;display:flex;flex-direction:column;}
  .gv-mobile-top.gv-mobile-grid .mob-col-left{overflow:visible;padding-right:0;}
  .gv-mobile-top.gv-mobile-grid .mob-col-mid{display:none !important;}
  .gv-mobile-top.gv-mobile-grid .mob-col-right{display:none !important;}
  .gv-mobile-top.gv-mobile-grid .gv-mobile-contact{margin-bottom:4px;}
  .gv-mobile-top.gv-mobile-grid .gv-mobile-divider.thin{margin:12px 0 14px;}
  .gv-mobile-top.gv-mobile-grid .lang-custom{margin-bottom:18px;}
  .gv-mobile-top.gv-mobile-grid .gv-mobile-nav a{padding:10px 0 9px;font-size:.95rem;}
  .gv-mobile-top.gv-mobile-grid .mob-brand-below-nav{margin-top:26px;}
  .gv-mobile-top.gv-mobile-grid .mob-brand-below-nav .mb-brand{margin-bottom:0;}
  
  .gv-mobile-top.gv-mobile-grid .mob-login-below-brand{margin-top:20px;}
  .gv-mobile-top.gv-mobile-grid .gv-mobile-partner{margin-top:16px;}
  .gv-mobile-footer.gv-mobile-footer-grid{margin-top:6px;padding-top:4px;}
  
  .gv-mobile-top.gv-mobile-grid .gv-mobile-contact{margin-top:8px !important; margin-bottom:6px !important;}
  .gv-mobile-top.gv-mobile-grid .gv-mobile-divider.thin{margin:8px 0 12px !important;}
  
  @media (min-width:900px) and (max-height:760px){
    .gv-mobile-contact{display:block !important;}
  }
}


@media (min-width:900px) and (max-height:640px){
  .gv-mobile-top.gv-mobile-grid{gap:30px;}
  .gv-mobile-top.gv-mobile-grid .gv-mobile-nav a{padding:8px 0 7px;font-size:.9rem;}
  .gv-mobile-top.gv-mobile-grid .lang-custom .lang-pill{padding:8px 14px;font-size:.85rem;}
  .gv-mobile-top.gv-mobile-grid .gv-btn-login.pill-outline{padding:9px 14px;font-size:.8rem;}
}

.gv-mobile-footer{
  flex-shrink:0;
  display:flex;
  flex-direction:column;
  
  padding-top:4px;
}


.gv-mobile-divider{height:1px;background:#ffffff12;margin:20px 0;}
.gv-mobile-divider.thin{margin:14px 0 16px;}
.gv-mobile-divider.brand-sep{margin:16px 0 18px;}
.gv-mobile-divider.footer-sep{margin:18px 0 10px;}


.gv-mobile-nav a{
  text-decoration:none;
  color:#fff;
  font-weight:600;
  font-size:1.02rem;
  padding:12px 0 11px;
  border-bottom:1px solid #262626;
}


.gv-mobile-nav a:focus-visible{outline:2px solid #ffe48a; outline-offset:2px; border-radius:4px;}


.mobile-lang-group.full-pill{
  width:100%;
  background:#1d1f25;
  border:1px solid #2a2d32;
  padding:10px 16px;
  border-radius:28px;
  display:flex;
  align-items:center;
  gap:10px;
  position:relative;
  font-size:.95rem;
}
.mobile-lang-group.full-pill i{font-size:1.05rem;color:#d4d6da;}
.mobile-lang-group.full-pill .ml-select{
  flex:1;
  font-size:.95rem;
  font-weight:600;
  padding-right:30px;
  background:transparent;
  border:0;
  color:#fff;
  cursor:pointer;
  outline:none;
  appearance:none;
  text-align:center;
  text-align-last:center; 
}
.mobile-lang-group.full-pill .ml-select option{color:#111;}
.mobile-lang-group.full-pill .ml-caret{
  width:18px;height:18px;position:absolute;right:14px;top:50%;transform:translateY(-50%);
  opacity:.8;pointer-events:none;
}


.gv-mobile-brand.inline{
  flex-direction:row;
  align-items:center;
  gap:16px;
  margin:6px 0 0;
}
.gv-mobile-brand.inline .mb-brand{
  display:flex;
  align-items:center;
  gap:16px;
  text-decoration:none;
  margin-bottom:35px;
}


.gv-mobile-brand.inline .mb-icon-img{
  width:240px;height:60px;object-fit:contain;display:block;
}



.gv-mobile-brand.mob-brand-below-nav { gap:14px; margin-top:18px; margin-bottom:6px; }
.gv-mobile-menu .mob-login-below-brand {
  display:flex !important; 
  align-items:center;
  justify-content:center;
  width:100% !important;
  margin-top:4px;
  background:#fff;
  color:#000;
  font-weight:600;
  border:1px solid #fff;
  border-radius:14px;
  padding:12px 20px;
}



@media (max-width: 1024px) {
  .gv-mobile-menu .lang-custom,
  .gv-mobile-menu .mob-user-block,
  .gv-mobile-menu .mob-user-name,
  .gv-mobile-menu .mob-login-below-brand,
  .gv-mobile-menu .gv-btn-login { display: none !important; }
}


.hidden-navbar {
  transform: translateY(calc(-1 * var(--gv-nav-height, 112px))) !important;
  transition: transform .25s ease;
}

.gv-navbar {
  position: fixed;
  top: 0;
  left: 0; right: 0;
  z-index: 1000;
  transition: transform 0.25s cubic-bezier(.55,.05,.5,1), background .35s, box-shadow .35s, height .30s;
  will-change: transform;
}
.gv-navbar.hide-navbar {
  transform: translateY(-100%);
}

.site-header {
  position: fixed;
  top: var(--gv-nav-height, 112px);
  left: 0; right: 0;
  z-index: 1700;
  transition: transform 0.25s cubic-bezier(.55,.05,.5,1);
  will-change: transform;
}
.site-header.hide-header {
  transform: translateY(-100%);
}
.site-header.shift-up {
  transform: translateY(-112px); 
}
.site-header {
  
  position: sticky;  
  top: var(--gv-nav-height, 112px);
  z-index: 1700;
  transition: top .25s, box-shadow .25s, background .25s;
}
.site-header.fixed-to-top {
  position: fixed !important;
  top: 0 !important;
  left: 0; right: 0;
  box-shadow: 0 3px 18px rgba(0,0,0,.28);
  background: #151518; 
  z-index: 1700;
}


@media (min-width: 900px) {
  .show-mobile { display: none !important; text-decoration: none !important; }
}
@media (max-width: 767.98px) {
  .show-mobile { display: inline-block !important; text-decoration: none !important; }
}


@media (max-width: 390px) {
  .gv-btn-lang .gv-lang-label {
    display: none !important;
  }
}


@media (max-width:900px) {
  #btn-fiyatlar {
    display: none !important;
  }
}


@media (min-width:1000px) and (max-width:1100px) and (min-height:1200px) and (orientation:portrait) {
  .hero-bg {
    margin-top: calc(-1 * var(--gv-nav-height, 112px)) !important;
    padding-top: 0px;
  }
  .hide-mobile {
    display: inline-block !important;
  }
  
  #btn-fiyatlar {
    display: none !important;
  }
}


@media (width:1024px) and (height:600px) and (orientation:landscape) {
  .gv-btn-login.hide-mobile { display: inline-block !important; }
}


@media (max-height: 800px) {
  .gv-nav-info,
  #btn-fiyatlar {
    display: none !important;
  }
}

@media (width:912px) and (height:1368px) and (orientation:portrait) {
  #btn-fiyatlar { display: none !important; }
}

@media (max-width:950px) and (orientation:portrait) {
  .gv-btn-login.show-mobile { display: inline-block !important; }
}

@media (width:912px) and (height:1368px) and (orientation:portrait) {
  .gv-btn-login.show-mobile { display: none !important; }
  .gv-btn-login.hide-mobile { display: inline-block !important; }
}
@media (max-height:600px) and (orientation:landscape) {
  .gv-btn-login.show-mobile { display: none !important; }
  .gv-btn-login.hide-mobile { display: inline-block !important; }
}



.gv-panel.gv-panel-lg{ background:transparent !important; box-shadow:none !important; border:0 !important; }
.gs-mega-panel.gs-3col{
  display:grid;
  grid-template-columns:320px 320px 320px;
  gap:24px;
  padding:28px;
  max-width:1320px;
  background:#f6f6f6;
  border-radius:14px;
  box-shadow:0 18px 40px rgba(0,0,0,.18);
}
.gs-col{min-width:0}
.gs-left{border-right:1px solid #e5e5e5; padding-right:16px}
.gs-mid{
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:flex-start;
  gap:16px;
}
.gs-mid-frame{
  width: 100%;
  height: 380px;
  overflow: hidden;
  border-radius: 12px;
  position: relative;
  flex-shrink: 0;
  background: #f0f0f0;
  box-shadow: 0 8px 20px rgba(0,0,0,.1);
}
.gs-mid-img{
  width: 100%;
  height: 100%;
  object-fit: cover;
  border-radius: 8px;
  transition: all 0.3s ease;
  transform: scale(3) translateX(-5px);
}
.gs-mid-buttons{
  display:flex;
  gap:8px;
  flex-shrink:0;
  justify-content:center;
  flex-wrap:wrap;
}
.gs-mid-btn{
  font-size:12px;
  padding:8px 16px;
  border-radius:28px;
  text-decoration:none;
  font-weight:600;
  transition:all 0.2s ease;
}
.gs-mid-btn-view{ background:#1976d2; color:#fff; border:1px solid #1565c0; }
.gs-mid-btn-view:hover{ background:#1565c0; }
.gs-mid-btn-code{ background:#f57c00; color:#fff; border:1px solid #ef6c00; }
.gs-mid-btn-code:hover{ background:#ef6c00; }
.gs-right{border-left:1px solid #e5e5e5; padding-left:16px}

.gs-mega-h{margin:0 0 8px; font-size:28px; font-weight:800; color:#000; letter-spacing:-.01em}
.gs-mega-subtitle{margin:0 0 16px; font-size:12px; letter-spacing:.18em; text-transform:uppercase; color:#8a8a8a}
.gs-list{display:flex; flex-direction:column; gap:12px}
.gs-li{
  display:flex;
  align-items:flex-start;
  gap:10px;
  padding:12px 14px;
  min-height:78px;
  border:1px solid #e8e8e8;
  background:#fff;
  border-radius:10px;
  text-decoration:none;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: normal;
  word-break: break-word;
  line-height: 1.5;
  padding: 1.5rem;
}
.gs-li:hover{border-color:#d0d0d0; background:#fafafa}
.gs-li-main{flex:1; min-width:0}
.gs-li-title{font-weight:700; color:#111; font-size:14px; margin-bottom:4px}
.gs-li-desc{
  font-size:12px;
  color: #666;
  line-height:1.4;
  overflow:hidden;
  text-overflow:ellipsis;
  display:-webkit-box;
  -webkit-line-clamp:2;
  line-clamp:2;
  -webkit-box-orient:vertical;
}
.gs-li-ico{display:flex; align-items:center; justify-content:center; width:28px; height:28px; border-radius:50%; background:#f0f0f0; color:#777; flex-shrink:0}

.gs-right-card{
  background:#616060;
  color:#e6e6e6;
  border-radius:12px;
  padding:18px;
  box-shadow:0 14px 28px rgba(0,0,0,.25);
  display:flex;
  flex-direction:column;
  justify-content:space-between;
  height:420px;
  overflow:hidden;
  text-overflow: ellipsis;
  white-space: normal;
  word-break: break-word;
  line-height: 1.5;
  padding: 1.5rem;
}
.gs-right-title{margin:0 0 10px; color:#fff; font-weight:800; font-size:28px}
.gs-right-text{font-size:15px; line-height:1.5; color:#d6d6d6; overflow:hidden; display:-webkit-box; line-clamp:5; -webkit-box-orient:vertical; margin-bottom: 15px;}
.gs-right-actions{display:flex; flex-direction:column; gap:12px; margin-top:auto}
.gs-right-btn{background:#ee0302; color:#fff; border:0; padding:8px 14px; border-radius:999px; font-weight:700; cursor:pointer; align-self:flex-start}
.gs-right-email{color:#bfc2c9; font-size:10.5px; margin-top:4px}
.gs-right-email a{color:#fff; text-decoration:underline}


@media (max-width:1024px){
  .gs-mega-panel.gs-3col{grid-template-columns:1fr; gap:16px; padding:22px}
  .gs-left,.gs-right{border:0; padding:0}
}

#projectSubmitModal.show ~ .modal-backdrop.show {
  opacity: 0;
  background: transparent;
}
#projectSubmitModal .modal-dialog {
  margin: 3vh auto;
}
#projectSubmitModal .modal-content {
  background: transparent;
  box-shadow: none;
}



@supports selector(:has(*)) {
  html:has(.modal.show) {
    overflow-y: scroll !important; 
  }
}

body.modal-open { padding-right: 0 !important; }

body.modal-open {
  overflow: hidden !important;
  position: fixed !important;
  width: 100% !important;
}


@font-face {
  font-family: 'OCR-B';
  src: url('fonts/OCR-B.ttf') format('truetype');
  font-weight: normal;
  font-style: normal;
}
.ocrb-font {
  font-family: 'OCR-B', monospace !important;
}


  
  :root{ --hero-grid-opacity: 0.15; --hero-wave-opacity: 1.7; }
  
  .gv-hero{
    position:relative;
    overflow:hidden;
    
    background:#040404;
    color:#fff;
    font-family:"Inter","Segoe UI",sans-serif;
    
    
    min-height: 100vh;
    
    min-height: clamp(640px, 80svh, 115svh);
  }


  
  .gv-hero{ --hero-grid-size: 100%; }
  
  
  @media (max-width:900px){ .gv-hero{ --hero-grid-size: 250%; --hero-wave-size: 210%; --hero-wave-pos: 34%; --hero-wave-opacity: 0.8; } }
  
  @media (max-width:420px){ .gv-hero{ --hero-wave-pos: 11%; --hero-wave-size: 250%; --hero-wave-opacity: 1; } }
    
  @media (max-width:440px){ .gv-hero{ --hero-wave-pos: 5%; --hero-wave-size: 250%; --hero-wave-opacity: 1; } }
    
  @media (max-width:360px){ .gv-hero{ --hero-wave-pos: 12%; --hero-wave-size: 250%; --hero-wave-opacity: 1; } }

  .gv-hero .gv-wrap{
    position:relative; z-index:4;
    max-width:1600px; margin:0 auto;
    padding:72px 32px 160px;
    text-align:center;
  }
  @media(max-width:900px){
    
    .gv-hero { 
      min-height: 100vh; 
      min-height: clamp(560px, 90svh, 130svh);
    }
    .gv-hero .gv-wrap{ padding:64px 20px 140px; margin: -120px auto; }
  }

  
  @media (max-width:420px){
    .gv-hero{ --hero-grid-size: 500%; }
    .gv-hero::before{ background-position: 50% 50%; }
    .gv-hero .gv-wrap{ padding:68px 18px 130px; }
    
    .gv-hero p.gv-lead{ margin:90px auto 0; }
    .gv-hero p.gv-sub{ margin-top:16px; }
  }

  
  @media (min-width:421px) and (max-width:480px){
    .gv-hero{ --hero-grid-size: 420%; }
    .gv-hero::before{ background-position: 50% 10%; }
    .gv-hero .gv-wrap{ padding:74px 22px 140px; }
    .gv-hero p.gv-lead{ margin:100px auto 0; font-size: clamp(2.2rem, 4.8vw, 2.9rem); }
    .gv-hero p.gv-sub{ margin-top:18px; font-size:0.95rem; line-height:1.45; }
    .gv-row{ margin-top:26px; }
  }

  
  @media (min-width:481px) and (max-width:620px){
    .gv-hero{ --hero-grid-size: 340%; }
    .gv-hero::before{ background-position: 50% 10%; }
    .gv-hero .gv-wrap{ padding:76px 22px 140px; }
    .gv-hero p.gv-lead{ margin:108px auto 0; font-size: clamp(2.4rem, 4.2vw, 3.1rem); }
    .gv-hero p.gv-sub{ margin-top:18px; }
    .gv-row{ margin-top:28px; }
  }

  
  @media (min-width:880px) and (max-height:900px){
    .gv-hero{ 
      min-height: clamp(600px, 80svh, 100svh); 
    }
    .gv-hero .gv-wrap{ padding:56px 28px 120px; margin:0 auto; }
    
  }

  
  @media (min-width:900px) and (max-width:1040px){
    .gv-hero{ --hero-grid-size: 210%; }
    .gv-hero::before{ background-position: 50% 44%; }
    .gv-hero p.gv-lead{ margin:120px auto 0; font-size: clamp(2.6rem, 3.4vw, 3.3rem); }
    .gv-hero p.gv-sub{ margin-top:20px; max-width:820px; }
    .gv-row{ margin-top:34px; }
    .gv-card.meeting{ margin:40px auto 0; }
  }
  

@media screen and (width:1280px) and (height:800px) and (orientation:landscape) {
  
  .gv-hero p.gv-lead {
    font-size: clamp(2.9rem, 3.0vw, 3.7rem);
    line-height: 1.06;
    max-width: 980px;      
    margin: 140px auto 0;
    font-weight: 700;
    letter-spacing: -0.02em;
  }

  
  .gv-hero p.gv-sub {
    font-size: clamp(1.02rem, 1.05vw, 1.12rem);
    line-height: 1.55;
    max-width: 860px;
    margin: 16px auto 0;
    color: #fff;
  }

  
  .gv-hero {
    --hero-wave-pos: 28%;
    --hero-wave-size: 190%;
  }
}

  .gv-hero h1{font-weight:900;letter-spacing:-.01em;margin:0}
  .gv-hero p.gv-lead{
    margin:110px 140px 0;
    font-size:42pt; font-weight:700; line-height:1.05;
    letter-spacing:-.02em; color:#fff
  }
  .gv-hero p.gv-sub{
    margin:18px auto 0;
    font-size:1.05rem; line-height:1.6; color: #ffffff;
  }

  
.gv-row { display:grid; gap:8px; margin:30px auto 0; padding:10px; background:#ffffff0f; border-radius:16px; backdrop-filter:blur(6px); max-width:980px; }
  
  @media (min-width:600px){ .gv-row{ grid-template-columns:200px 1fr; } }

  .gv-dd{position:relative}
  .gv-dd>button{
    width:100%; display:flex; align-items:center; justify-content:space-between; gap:8px;
    padding:14px 16px; color:#fff; background:rgba(255,255,255,.08);
    border:1px solid rgba(255,255,255,.18); cursor:pointer; border-radius:12px; font-size:.9rem
  }
  .gv-dd>button:hover{ background:rgba(255,255,255,.16) }
  .gv-dd-menu{
    position:absolute; inset:auto 0 0 0; transform:translateY(calc(100% + 8px));
    background:#101010; border:1px solid rgba(255,255,255,.12); border-radius:12px;
    padding:6px; display:none; z-index:5; box-shadow:0 24px 60px rgba(0,0,0,.45)
  }
  .gv-dd.open .gv-dd-menu{ display:block }
  .gv-dd-menu button{
    display:block; width:100%; text-align:left; padding:9px 12px;
    color:#cfd6df; background:transparent; border:0; border-radius:8px; font-size:.88rem
  }
  .gv-dd-menu button:hover{ background:rgba(255,255,255,.08); color:#fff }

  .gv-search{
    display:flex; align-items:center; overflow:hidden;
    border-radius:12px; border:1px solid rgba(255,255,255,.18); background:#05080d
  }
  .gv-search input{
    flex:1; min-width:0; background:transparent; border:0; outline:none;
    padding:14px 16px; color:#fff; font-size:0.8rem
  }
  .gv-search input::placeholder{ color:rgba(255,255,255,.45) }
  .gv-search .gv-s-btn{ width:52px; height:50px; border:0; background:transparent; color:#fff; cursor:pointer }
  .gv-search .gv-s-btn:hover{ color:#ee0302 }


  
  .gv-plan-h2{
    margin:28px auto 0; max-width:900px;
    font-weight:900; font-size:clamp(1.4rem,2.2vw,2rem); letter-spacing:-.01em; color:#fff
  }
  .gv-card.meeting{
    max-width:420px; margin:20px auto 0; text-align:left;
    border-radius:26px;
    background:linear-gradient(160deg,#ffffff 0%,#f4f6ff 60%,#f8edff 100%);
    border:0.15em solid rgba(255, 0, 0, 0.99);
    padding:20px; box-shadow:0 40px 80px rgba(4,4,4,.55); color:#12151d
  }
  .gv-chip{
    display:inline-flex; align-items:center; justify-content:center;
    font-size:.7rem; text-transform:uppercase; letter-spacing:.10em;
    background:#4633ff; color:#fff; padding:6px 14px; border-radius:999px;
  }
  .gv-card.meeting h3{margin:10px 0 8px; font-size:2.2rem; font-weight:800; color:#090909; letter-spacing: -0.03em; line-height: 1.05em;}
  .gv-card.meeting ul{margin:18px 0 26px; padding:0; list-style:none; display:grid; gap:10px}
  .gv-card.meeting ul li{position:relative; padding-left:36px; color:#090909ba; font-size:.65rem; line-height:1.6}
  .gv-card.meeting ul li::before{
    content:""; position:absolute; left:0; top:50%; transform:translateY(-50%);
    width:22px; height:22px; border-radius:50%;
    background:#2ECC71; 
  }
  .gv-card ul li::after{
    content:""; position:absolute; left:6px; top:50%; transform:translateY(-55%) rotate(-45deg);
    width:10px; height:6px;
    border-left:3px solid #fff; border-bottom:3px solid #fff;
    border-radius:1px;
  }
  .gv-flex{display:flex; align-items:flex-end; gap:12px; justify-content:space-between; margin-top: 12px;}
  .gv-price{font-size:2.6rem; font-weight:800; color:#0a1220}
  .gv-price small{font-weight:600; color:#5b6472; font-size:.45em}
  .gv-card.meeting .gv-plan-note{font-size:.8rem; color:#6b7383; margin-top:4px}
  .gv-terms-link{ background:transparent; border:0; color:#0a57ff; text-decoration:underline; cursor:pointer; padding:0; font-size:.75rem; }
  .gv-service-icons{ display:flex; align-items:center; gap:16px; margin:10px 0 15px; opacity:.9 }
  .gv-service-icons .ico{ display:flex; align-items:center; gap:6px; color: var(--text, #111); font-size:.9rem }
  .gv-service-icons .ico svg{ width:30px; height:30px; display:block }
  
  .gv-service-icons .ico svg path{ fill: #090909; }

  
  .gv-card--legacy{ display:none !important; }

  
  .gv-trust{
    display:grid; grid-template-columns:repeat(auto-fit,minmax(140px,1fr));
    gap:12px; margin-top:46px; color:rgba(255,255,255,.75)
  }

  
  @media (max-width: 768px) {
    .gv-card.meeting{
      max-width:360px;
      margin:25px auto 0;
      padding:20px 18px;
      border-radius:20px;
      box-shadow:0 28px 48px rgba(4,4,4,.48);
    }
    .gv-card.meeting h3{ font-size:2.2rem; margin:8px 0 6px }
    .gv-card.meeting ul{ margin:14px 0 20px; gap:8px }
    .gv-card.meeting ul li{ font-size:.75rem; padding-left:33px; padding-top: 5px; }
    .gv-chip{ font-size:.66rem; padding:5px 12px }
  }

  
  @media (max-width: 768px) {
    .gv-hero p.gv-lead{
      margin:240px auto 0;
      font-size:29pt;
      font-weight:700;
      line-height:1.05;
      letter-spacing:-.02em;
      color:#fff; 
    }
  }

  
  @media (min-width:600px) and (max-width:1023px){
    .gv-row{ margin:30px 40px 10px; grid-template-columns:200px 1fr; }
  }

  
  @media (min-width:800px) and (max-width:900px){
    
    .gv-hero .gv-wrap{
      margin:0 auto;
      padding: calc(var(--gv-nav-height, 112px) + 80px) 28px 140px;
    }
    
    .gv-hero p.gv-lead{ margin: 100px auto 0; }
    .gv-row{ margin:30px auto 10px; }
  }

  
  @media (max-width:1400px){
    
    .gv-hero{
      --hero-grid-size: 500%;
      --hero-wave-size: 230%;
      --hero-wave-pos: 10%;
      --hero-wave-opacity: 1.0;
    }

    .gv-hero .gv-wrap{ padding:68px 20px 140px; }



    .gv-row{ margin-top:26px; }
  }

  
  @media (min-width:700px) and (max-width:820px){
    .gv-hero .gv-wrap{ padding: 120px 28px 140px; }
    .gv-hero p.gv-lead{
      max-width: 920px;
      margin: 160px 28px 0;
      line-height: 1.06;
      font-size: clamp(3.2rem, 4.4vw, 3.2rem);
    }
        .gv-hero{
      --hero-grid-size: 500%;
      --hero-wave-size: 230%;
      --hero-wave-pos: 100%;
      --hero-wave-opacity: 1.0;
    }
  }

  
@media (min-width: 800px) and (max-width: 860px) {
  .gv-hero p.gv-lead {
    font-size: clamp(4.2rem, 4.4vw, 4.2rem); 
    line-height: 1.06;
    margin: 75px 75px 0;                      
    max-width: 920px;                         
    font-weight: 700;
  }

  .gv-hero p.gv-sub {
    font-size: 1.5rem;                       
    line-height: 1.6;
    margin: 18px 122px 0;                     
    color: #ffffff;
  }
}


@media (min-width:1000px) and (max-width:1100px) {
  
  .gv-hero p.gv-lead {
    font-size: clamp(3rem, 4.2vw, 4.4rem); 
    line-height: 1.06;
    max-width: 900px;       
    margin: 120px 145px 0;    
    font-weight: 700;
    letter-spacing: -0.02em;
  }

  
  .gv-hero p.gv-sub {
    font-size: clamp(1rem, 1.1vw, 1.05rem);
    line-height: 1.6;
    max-width: 760px;
    margin: 14px 125px 0;
    color: #ffffff;
  }
  
}


@media (min-width:900px) and (max-width:980px) {
   
  .gv-hero p.gv-lead {
    font-size: clamp(4.6rem, 3.4vw, 3.3rem);
    line-height: 1.06;
    max-width: 880px;        
    margin: 120px auto 0;    
    font-weight: 700;
    letter-spacing: -0.02em;
  }

   
  .gv-hero p.gv-sub {
    font-size: clamp(1.5rem, 1.0vw, 1.05rem);
    line-height: 1.6;
    max-width: 760px;
    margin: 14px 125px 0;
    color: #ffffff;
  }
}


  
  @media (max-width: 768px) {
    .gv-hero p.gv-sub{
      margin:18px 32px 0;
      font-size:1.05rem;
      line-height:1.4rem;
      color:#ffffff;
    }
  }
  
  @media (max-width:599px) {
    .gv-row{
      display:grid;
      grid-template-columns:1fr;
      gap:10px;
      justify-items:center;
      align-items:center;
      padding:10px;
      margin:18px 20px 10px;
    }
    
    .gv-row > *{ width:100%; max-width:520px; }
    .gv-dd>button, .gv-search, .gv-btn{ width:100%; }
  }
  .gv-badge{
    display:flex; align-items:center; gap:8px; border-radius:12px; padding:12px;
    background:rgba(10,10,10,.78); border:1px solid rgba(255,255,255,.08); font-size:.9rem
  }
  .gv-ico{width:22px; height:22px; stroke:#fff; fill:none; stroke-width:2}

  

  .gv-f{position:absolute; z-index:1; pointer-events:none}
  .gv-fx{animation:gv-float 6s ease-in-out infinite}
  @keyframes gv-float{0%{transform:translateY(0)}50%{transform:translateY(10px)}100%{transform:translateY(0)}}
  .gv-pill{padding:12px; border-radius:18px; background:rgba(255,255,255,.08); border:1px solid rgba(255,255,255,.12); box-shadow:0 12px 36px rgba(0,0,0,.45)}
  .gv-hero .visually-hidden{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);border:0}
  .gv-btn-cta.try-now{
  background:var(--brand-red);
  color:#fff;
  text-decoration:none !important;
  font-weight:600;
  padding:10px 26px;
  border-radius:var(--radius-pill);
  font-size:clamp(.78rem,.62rem + .38vw,.95rem);
  box-shadow:0 4px 18px -4px rgba(238,3,2,.6);
  display:inline-flex;
  align-items:center;
  justify-content:center;
  transition:background .25s, box-shadow .25s;
  -webkit-user-select:none; user-select:none;
  }
  
  .gs-card-icon{ display:flex; align-items:center; justify-content:center; margin-bottom:12px }
  .gs-card-icon svg{ width:72px; height:72px; fill:currentColor }

  
  
  .gv-panel.gv-panel-lg{ background:transparent !important; box-shadow:none !important; border:0 !important; }
  .gs-mega-panel.gs-3col{
    display:grid;
    grid-template-columns:320px 320px 320px;
    gap:24px;
    padding:28px;
    max-width:1320px;
    background:#f6f6f6;
    border-radius:14px;
    box-shadow:0 18px 40px rgba(0,0,0,.18);
  }
  .gs-col{min-width:0}
  .gs-left{border-right:1px solid #e5e5e5; padding-right:16px}
  .gs-mid{
    display:flex; 
    flex-direction:column; 
    align-items:center; 
    justify-content:flex-start;
    gap:16px;
  }
  .gs-mid-frame{
    width: 100%;
    height: 380px; 
    overflow: hidden;
    border-radius: 12px;
    position: relative;
    flex-shrink: 0;
    background: #f0f0f0;
    box-shadow: 0 8px 20px rgba(0,0,0,.1);
  }
  .gs-mid-img{  
    width: 100%;
    height: 100%;
    object-fit: cover;
    border-radius: 8px;
    transition: all 0.3s ease;
    transform: scale(3) translateX(-5px);
  }
  .gs-mid-buttons{
    display:flex;
    gap:8px;
    flex-shrink:0;
    justify-content:center;
    flex-wrap:wrap;
  }
  .gs-mid-btn{
    font-size:12px;
    padding:8px 16px;
    border-radius:28px;
    text-decoration:none;
    font-weight:600;
    transition:all 0.2s ease;
  }
  .gs-mid-btn-view{
    background:#1976d2;
    color:#fff;
    border:1px solid #1565c0;
  }
  .gs-mid-btn-view:hover{
    background:#1565c0;
  }
  .gs-mid-btn-code{
    background:#f57c00;
    color:#fff;
    border:1px solid #ef6c00;
  }
  .gs-mid-btn-code:hover{
    background:#ef6c00;
  }
  .gs-right{border-left:1px solid #e5e5e5; padding-left:16px}

  .gs-mega-h{margin:0 0 8px; font-size:28px; font-weight:800; color:#000; letter-spacing:-.01em}
  .gs-mega-subtitle{margin:0 0 16px; font-size:12px; letter-spacing:.18em; text-transform:uppercase; color:#8a8a8a}
  .gs-list{display:flex; flex-direction:column; gap:12px}
  .gs-li{
    display:flex; 
    align-items:flex-start; 
    gap:10px; 
    padding:12px 14px; 
    min-height:78px; 
    border:1px solid #e8e8e8; 
    background:#fff; 
    border-radius:10px; 
    text-decoration:none;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: normal;
    word-break: break-word;
    line-height: 1.5;
    padding: 1.5rem;
  }
  .gs-li:hover{border-color:#d0d0d0; background:#fafafa}
  .gs-li-main{flex:1; min-width:0}
  .gs-li-title{font-weight:700; color:#111; font-size:14px; margin-bottom:4px}
  .gs-li-desc{
    font-size:12px; 
    color: #666; 
    line-height:1.4; 
    overflow:hidden; 
    text-overflow:ellipsis; 
    display:-webkit-box; 
    -webkit-line-clamp:2; 
    line-clamp:2; 
    -webkit-box-orient:vertical;
  }
  .gs-li-ico{display:flex; align-items:center; justify-content:center; width:28px; height:28px; border-radius:50%; background:#f0f0f0; color:#777; flex-shrink:0}

  .gs-right-card{
    background:#616060;
    color:#e6e6e6;
    border-radius:12px;
    padding:18px;
    box-shadow:0 14px 28px rgba(0,0,0,.25);
    display:flex;
    flex-direction:column;
    justify-content:space-between;
    height:420px; 
    overflow:hidden;
    text-overflow: ellipsis;
    white-space: normal;
    word-break: break-word;
    line-height: 1.5;
    padding: 1.5rem;
  }
  .gs-right-title{margin:0 0 10px; color:#fff; font-weight:800; font-size:26px; line-height: 1.1;}
  .gs-right-text{font-size:15px; line-height:1.5; color:#d6d6d6; overflow:hidden; display:-webkit-box; line-clamp:5; -webkit-box-orient:vertical; margin-bottom: 15px;}
  .gs-right-actions{display:flex; flex-direction:column; gap:12px; margin-top:auto}
  .gs-right-btn{background:#ee0302; color:#fff; border:0; padding:8px 14px; border-radius:999px; font-weight:700; cursor:pointer; align-self:flex-start}
  .gs-right-email{color:#bfc2c9; font-size:10.5px; margin-top:4px}
  .gs-right-email a{color:#fff; text-decoration:underline}

  
  @media (max-width:1024px){
    .gs-mega-panel.gs-3col{grid-template-columns:1fr; gap:16px; padding:22px}
    .gs-left,.gs-right{border:0; padding:0}
  }

  
  @media screen and (width:1024px) and (height:1366px) and (orientation:portrait),
         screen and (device-width:1024px) and (device-height:1366px) and (orientation:portrait){
    .gravisual-footer-col.legal-col{ display:none !important; }
        .gv-hero{
      --hero-grid-size: 500%;
      --hero-wave-size: 230%;
      --hero-wave-pos: 100%;
      --hero-wave-opacity: 1.0;
    }
  }

  
  @media screen and (width:1024px) and (height:600px) and (orientation:landscape),
         screen and (device-width:1024px) and (device-height:600px) and (orientation:landscape){
    .gravisual-footer-col.legal-col{ display:none !important; }
    .gv-hero{
      --hero-wave-pos: 100%;
      --hero-wave-opacity: 1.0;
    }
  }

  
@media (min-width:880px) and (max-width:930px) and (orientation:portrait) {
  .gravisual-footer-col.legal-col { display:none !important; }
}


.gs-light-wrapper{
  
  --bg: #f6f7f8;
  --text: #111111;
  --muted: #666a73;
  --line: #e9eaee;
  --card: #ffffff;
  --shadow: 0 4px 18px rgba(0,0,0,0.06);
  --radius: 16px;
  --brand: #ee0302; 
  --brand-ink: #b40202;
  background: var(--bg);
  color: var(--text);
}
.gs-light-wrapper .container{ max-width:1200px; margin:0 auto; padding:20px 20px; }


.gs-light-wrapper .title{
  font-size: clamp(28px, 3.5vw, 40px);
  line-height: 1.15;
  letter-spacing: -0.02em;
  font-weight: 700;
  margin: 0;
}
.gs-light-wrapper .subtitle,
.gs-light-wrapper .value-subtitle,
.gs-light-wrapper .gravisuite-subtitle{
  color: var(--muted);
  font-size: clamp(15px, 1.8vw, 18px);
  line-height: 1.65;
  margin-top: 14px;
  max-width: 895px;
}

.gs-light-wrapper .gravisuite-subtitle{
  text-align: center;
  margin-left: auto;
  margin-right: auto;
}
.gs-light-wrapper .eyebrow{
  display: inline-block;
  font-size: 20px;
  letter-spacing: .12em;
  text-transform: uppercase;
  color: var(--brand);
  font-weight: 500;
  margin-bottom: 12px;
}


.value-section{ padding-bottom: 35px; border-bottom: 1px solid var(--line); }
.value-grid{
  display:grid; gap:22px; margin: 28px 0 26px;
  grid-template-columns: repeat(3, minmax(0,1fr));
}
@media (max-width:930px){ .value-grid{ grid-template-columns:1fr; margin: 28px 0 0px; } }

.value-card{
  
  background: var(--card);
  border: 1px solid var(--line);
  border-radius: var(--radius);
  padding: 24px 22px;
  box-shadow: var(--shadow);
  transition: transform .25s ease, box-shadow .25s ease, border-color .25s ease;
  
  display: flex;
  align-items: flex-start;
  gap: 16px;
  
  --titleSize: clamp(20px, 2.4vw, 22px);
}
.value-card:hover{ transform: translateY(-4px); border-color: var(--brand); box-shadow: 0 8px 24px rgba(0,0,0,0.08); }
.value-card .icon{ 
  flex-shrink: 0;
  
  width: calc(var(--titleSize) * 3);
  height: calc(var(--titleSize) * 3);
  display: flex;
  align-items: center;
  justify-content: center;
}
.value-card .icon svg{
  width: 100%;
  height: 100%;
  display: block;
  fill: var(--brand);
}
.value-card-content{
  flex: 1;
}
.value-card h3{ font-size: 26px; margin: 0 0 8px; color: #090909; font-weight: 700; letter-spacing: -0.015rem; }
.value-card p{ margin: 0; color: var(--muted); }

.value-card .value-card-desc{ color: var(--muted); }
.value-card .value-card-desc p{ margin: 0; }

.cta-row{ margin-top: 8px; }
.btn-primary{
  display:inline-block; text-decoration:none; color:#fff; background: var(--brand);
  padding: 13px 26px; border-radius: 999px; font-weight: 700; transition: filter .25s ease, transform .05s ease;
}
.btn-primary:active{ transform: translateY(1px); }
.btn-primary:hover{ filter: brightness(1.05); }


.gravisuite-section{ padding-top: 35px; }
.gs-head{ text-align:center; }

.gs-grid{ display:grid; gap:22px; margin: 22px 0 28px; grid-template-columns: repeat(3, minmax(0,1fr)); }
.gs-grid-render-section { display:grid; gap:22px; margin: 22px 0 28px; grid-template-columns: repeat(4, minmax(0,1fr)); }

@media (max-width:1200px){ .gs-grid-render-section{ grid-template-columns: repeat(4, minmax(0,1fr)); } }
@media (min-width:621px) and (max-width:900px){ .gs-grid-render-section{ grid-template-columns: repeat(2, minmax(0,1fr)); } }
@media (max-width:1100px){ .gs-grid{ grid-template-columns: repeat(3, minmax(0,1fr)); } }
@media (max-width:620px){
  
  .gs-grid{
    display:flex;
    flex-direction:row;
    gap:18px;
    overflow-x:auto;
    -webkit-overflow-scrolling:touch;
    padding-bottom:6px;
    scroll-snap-type:x mandatory;
    margin: 18px 0 22px;
    padding: 15px 0px 0px 0;
  }
  
  .gs-grid-render-section{
    display:flex;
    flex-direction:row;
    gap:18px;
    overflow-x:auto;
    -webkit-overflow-scrolling:touch;
    padding-bottom:6px;
    scroll-snap-type:x mandatory;
    margin: 18px 0 22px;
    padding: 15px 0px 0px 0;
  }
  .gs-grid .gs-card{
    flex:0 0 84%; 
    min-width:260px;
    scroll-snap-align:start;
  }
  .gs-grid-render-section .gs-card{
    flex:0 0 84%;
    min-width:260px;
    scroll-snap-align:start;
  }
  
  .gs-grid{
    -ms-overflow-style: none; 
    scrollbar-width: none; 
  }
  .gs-grid::-webkit-scrollbar{ display: none; height: 0; }

  .gs-grid-render-section{
    -ms-overflow-style: none;
    scrollbar-width: none;
  }
  .gs-grid-render-section::-webkit-scrollbar{ display: none; height: 0; }

  .gs-light-wrapper .eyebrow{ font-size:18px; }
}

.gs-card{
  background: var(--card);
  border: 1px solid var(--line);
  border-radius: var(--radius);
  padding: 24px 22px 20px;
  box-shadow: var(--shadow);
  transition: transform .25s ease, border-color .25s ease, box-shadow .25s ease;
}
.gs-card:hover{ transform: translateY(-4px); border-color: var(--brand); box-shadow: 0 8px 24px rgba(0,0,0,0.08); }
.gs-card h3{ margin: 20px 0 8px; font-size: 20px; color: var(--text); font-weight: 700; }

.gs-grid-render-section .gs-card h3{
  display:-webkit-box; -webkit-box-orient:vertical; overflow:hidden; text-overflow:ellipsis;
  -webkit-line-clamp:2; line-clamp:2;
}
.gs-card p{ margin: 0 0 16px; color: var(--muted); }
.card-link{ color: var(--brand-ink); text-decoration: none; font-weight: 400; }
.card-link:hover{ text-decoration: underline; }


.gs-card-media{ margin-bottom:12px; overflow:hidden; border-radius:12px }
.gs-card-media img{ width:100%; height:220px; object-fit:none; display:block; height: max-content; }
@media(min-width:900px){ .gs-card-media img{ height:260px } }
@media(min-width:1200px){ .gs-card-media img{ height:320px } }


@media (min-width:621px) and (max-width:900px){
  
  .gs-grid-render-section{ grid-template-columns:repeat(2,minmax(0,1fr)); }
  .gs-grid-render-section .gs-card{
    display:grid;
    grid-template-columns:64px 1fr;
    grid-template-rows:auto auto auto;
    grid-template-areas:
      "icon title"
      "icon body"
      "icon link";
    column-gap:14px;
    align-items:start;
    padding:26px 24px 24px;
    min-height:100%;
  }
  .gs-grid-render-section .gs-card-icon{ grid-area:icon; margin:0; display:flex; align-items:center; justify-content:center; width:64px; height:64px; }
  .gs-grid-render-section .gs-card-icon svg{ width:100%; height:100%; }
  .gs-grid-render-section .gs-card h3{
    grid-area:title; margin:0 0 8px; font-size:clamp(22px,2.6vw,26px); line-height:1.15;
    display:-webkit-box; -webkit-box-orient:vertical; -webkit-line-clamp:2; line-clamp:2; overflow:hidden;
  }
  .gs-grid-render-section .gs-card p{ grid-area:body; margin:0 0 14px; font-size:.9rem; line-height:1.5; }
  .gs-grid-render-section .gs-card .card-link{ grid-area:link; margin-top:auto; }
}

.gs-foot{ text-align:-webkit-left; margin-top: 8px; color: gray; display:flex; flex-direction:column; align-items:center; gap:12px; }
.gs-foot-logo{ max-width:180px; width:100%; opacity:.88; }
.gs-foot-logo svg{ width:100%; height:auto; display:block; filter:drop-shadow(0 4px 12px rgba(0,0,0,.15)); }
@media (max-width:700px){ .gs-foot-logo{ max-width:200px; opacity:.8; } }


.gs-grid-render-section + .gs-foot{
  align-items:flex-start;
  column-gap:18px;
}
.gs-grid-render-section + .gs-foot p{ grid-column:1 / span 3; margin:0; }
.gs-grid-render-section + .gs-foot .gs-foot-logo{ grid-column:3; justify-self:end; }
@media (max-width:900px){
  .gs-grid-render-section + .gs-foot{ grid-template-columns: 1fr; row-gap:10px; text-align:-webkit-left; }
  .gs-grid-render-section + .gs-foot p{ grid-column:auto; }
  .gs-grid-render-section + .gs-foot .gs-foot-logo{ grid-column:auto; justify-self:center; }
}
.btn-outline{
  display:inline-block; text-decoration:none; color: var(--brand-ink); border: 1.5px solid var(--brand);
  padding: 12px 22px; border-radius: 999px; font-weight: 700; transition: background .25s ease, color .25s ease;
}
.btn-outline:hover{ background: var(--brand); color: #fff; }


.pf-banner{
  
  background-color:#595959;
  background-image: linear-gradient(rgba(91,89,89, 0.45), rgba(91,89,89, 0.45)), url('../images/svg/gravisual-hero-scanlight-wave.svg');
  background-repeat:no-repeat;
  background-position:center;
  background-size:cover;
  
  filter: brightness(1.15) contrast(1.25);
  padding:30px 15px; color:#e5e7eb; margin:0 0 0; box-shadow:0 10px 30px rgba(0,0,0,.12);
  
  position:relative; overflow:hidden;
  width:100vw; min-height:250px; margin-left:calc(-50vw + 50%);
}
.pfb-wrap{ max-width:980px; margin:0 auto; text-align:center }
.pfb-wrap h3{ margin:0 0 15px; font-weight:700; font-size:38px; color:#818181; letter-spacing: -0.02em; }
.pfb-sub{ margin:0 auto 14px; max-width:1500px; color:#bdbaba; font-size: 15px; }
.pfb-sub p{ margin:0; }
.pfb-actions{ display:flex; align-items:baseline; justify-content:center; gap:16px; flex-wrap:wrap }
.pfb-btn{ background: var(--brand); color:#fff; border:0; border-radius:999px; padding:12px 20px; font-weight:700; cursor:pointer }
.pfb-btn:hover{ filter:brightness(.95) }
.pfb-alt{ color:#aeb2bb; text-decoration:underline }

.pf-banner .email-info{
  color: #cfcfd1;                 
  font-size: 12px;
  display: inline-flex;
  gap: 8px;
  align-items: center;
  justify-content: center;
  line-height: 1.5;
}
.pf-banner .email-info a{
  color: #bdbaba;
  text-decoration: underline;
  font-weight: 400;
}
.pf-banner .email-info p{ margin:0; }

@media (max-width:480px){
  .pf-banner .email-info{ display:block; font-size:13px; margin-top:6px; }
}


@media (max-width:768px){
  .pf-banner{
    min-height:315px;
    padding:35px 19px;
    margin:20px 0 0;
    background-size: auto;
    width: -webkit-fill-available;
    border-radius: var(--radius);
  }
  .pfb-wrap h3{
    font-size:24px;
    margin:0 40px 15px;
  }
  .pfb-sub{
    font-size:15px;
    margin:0 20px 20px;
    
  }
  .pfb-actions{
    gap:10px;
    align-items: center;
  }
  .pfb-btn{
    padding:10px 16px;
    font-size:13px;
  }
  .gs-light-wrapper .title{
    font-size: clamp(35px, 5vw, 32px);
  }
  .value-card h3{
    line-height: 1.15em;
  }
}

@media (max-width:480px){
  .pf-banner{
    min-height:425px;
    padding:35px 19px;
    margin:16px 0 0;
    width: -webkit-fill-available;
    border-radius: var(--radius);

  }
  .pfb-wrap h3{
    font-size:30px;
    margin:0 40px 15px;
    line-height: 1.0em;
  }
  .pfb-sub{
    font-size:15px;
    margin:0 20px 20px;
    line-height:1.5;

  }
  .pfb-actions{
    flex-direction:column;
    gap:8px;
    width:100%;
  }
  .pfb-btn{
    width:40%;
    padding:10px 14px;
    font-size:12px;
  }
  .pfb-alt{
    font-size:12px;
    white-space:nowrap;
  }
  .gs-light-wrapper .title{
    font-size: clamp(35px, 5vw, 32px);
  }
  .value-card h3{
    line-height: 1.15em;
  }
}


.pf-modal[hidden]{ display:none }
.pf-modal{ position:fixed; inset:0; z-index:1000 }
.pf-modal__backdrop{ position:absolute; inset:0; background:rgba(0,0,0,.58) }
.pf-modal__dialog{ position:relative; margin:12vh auto; max-width:960px; background:#fff; color:#111; border-radius:16px; padding:16px 18px; box-shadow:0 20px 60px rgba(0,0,0,.25) }
.pf-modal__close{ position:absolute; top:10px; right:12px; border:0; background:transparent; font-size:22px; line-height:1; cursor:pointer }


.pf-form{ margin:15px }
.pf-grid{ display:grid; grid-template-columns:repeat(2,minmax(0,1fr)); gap:35px; margin-top: 15px; }
.pf-grid.pf-grid--3{ grid-template-columns:repeat(3,minmax(0,1fr)); }
.pf-field{ display:flex; flex-direction:column; gap:8px }
.pf-field span{ font:500 13px/1.2 system-ui; color:#111 }
.pf-field input,.pf-field select,.pf-field textarea{ appearance:none; border:1px solid #e5e7eb; border-radius:10px; background:#fff; padding:9px 11px; font:400 14px/1.4 system-ui; color:#111; outline:none }
.pf-field input:focus,.pf-field select:focus,.pf-field textarea:focus{ border-color: var(--brand); box-shadow:0 0 0 3px rgba(238,3,2,.12) }
.pf-wide{ margin-top:15px }
.pf-check{ display:flex; gap:10px; margin:10px 0 35px; font:400 13px/1.5 system-ui; color:#6b7280 }
.pf-actions{ display:flex; flex-wrap:wrap; align-items:center; gap:12px; margin-top:6px }
.pf-btn{ background: var(--brand); color:#fff; border:0; border-radius:999px; padding:9px 16px; font:600 14px/1 system-ui; cursor:pointer }
.pf-note{ margin-top:8px; color:#6b7280; font:400 12px/1.6 system-ui }
.pf-field > .pf-field{ margin-top:6px }
.pf-modal-desc{ margin:0 14px 24px 14px; font:400 13px/1.5 system-ui; color:#4b5563; }
.hp{ position:absolute; left:-9999px; top:auto; width:1px; height:1px; overflow:hidden }
@media (max-width:720px){ .pf-grid{ grid-template-columns:1fr } .pf-grid.pf-grid--3{ grid-template-columns:1fr } .pf-modal__dialog{ margin:4vh 10px; padding:14px } }


.gs-light-wrapper .section-divider{
  height:1px; background:var(--line); margin:35px 0; width:100%;
}



.gv-modal.gv-light {
  position: fixed;
  inset: 0;
  background: rgba(0,0,0,.45);
  backdrop-filter: blur(8px);
  display: grid;
  place-items: center;
  padding: 20px;
  z-index: 999;
}
.gv-cookie-panel {
  width: min(500px, 92vw);
  background: #fff;
  border-radius: 14px;
  box-shadow: 0 10px 40px rgba(0,0,0,.15);
  padding: 28px 28px 22px;
  color: #222;
  font-family: 'Inter', sans-serif;
  animation: fadeIn .25s ease;
  text-align: left;
}
.gv-cookie-panel h3 {
  margin-top: 0;
  font-size: 18px;
  font-weight: 700;
  color: #090909;
  margin-bottom: 12px;
  letter-spacing: -0.01em;
}
.gv-cookie-panel p {
  font-size: 12.5px;
  line-height: 1.6;
  color: #444;
  margin-bottom: 12px;
}
.gv-cookie-panel ul {
  margin: 0 0 10px 18px;
  padding: 0;
  color: #444;
  font-size: 12px;
  line-height: 1.6;
}
.gv-cookie-panel li { margin-bottom: 6px; }
.cookie-foot {
  text-align: right;
  border-top: 1px solid #eee;
  margin-top: 14px;
  padding-top: 12px;
}
.btn-accept {
  background: #000;
  color: #fff;
  border: none;
  border-radius: 999px;
  padding: 10px 20px;
  font-weight: 600;
  cursor: pointer;
}
.btn-accept:hover { filter: brightness(1.1); }

#render-campaign-modal .gv-cookie-panel{
  width: min(1000px, 96vw);
  padding: 16px 0 0 0; 
  background: transparent;
  border: 0;
  box-shadow: none;
}
#render-campaign-modal #renderCampaignTitle{ margin: 8px 12px; }
#render-campaign-modal .gv-embed-wrap{ background: transparent; }
#render-campaign-modal .gv-embed-frame{ display:block; width:100%; height:calc(100vh - 160px); border:0; background:transparent; }
@keyframes fadeIn { from { opacity: 0; transform: translateY(10px); } to { opacity: 1; transform: translateY(0); } }
