/* === normalize.css === */
/*! normalize.css v3.0.3 | MIT License | github.com/necolas/normalize.css */
/**
 * 1. Set default font family to sans-serif.
 * 2. Prevent iOS and IE text size adjust after device orientation change,
 *    without disabling user zoom.
 */
html {
  font-family: sans-serif;
  /* 1 */
  -ms-text-size-adjust: 100%;
  /* 2 */
  -webkit-text-size-adjust: 100%;
  /* 2 */
}
/**
 * Remove default margin.
 */
body {
  margin: 0;
}
/* HTML5 display definitions
   ========================================================================== */
/**
 * Correct `block` display not defined for any HTML5 element in IE 8/9.
 * Correct `block` display not defined for `details` or `summary` in IE 10/11
 * and Firefox.
 * Correct `block` display not defined for `main` in IE 11.
 */

footer,
menu,
nav,
section {
  display: block;
}
/**
 * 1. Correct `inline-block` display not defined in IE 8/9.
 * 2. Normalize vertical alignment of `progress` in Chrome, Firefox, and Opera.
 */

progress {
  display: inline-block;
  /* 1 */
  vertical-align: baseline;
  /* 2 */
}
/**
 * Prevent modern browsers from displaying `audio` without controls.
 * Remove excess height in iOS 5 devices.
 */
/**
 * Address `[hidden]` styling not present in IE 8/9/10.
 * Hide the `template` element in IE 8/9/10/11, Safari, and Firefox < 22.
 */
[hidden] {
  display: none;
}
/* Links
   ========================================================================== */
/**
 * Remove the gray background color from active links in IE 10.
 */
a {
  background-color: transparent;
}
/**
 * Improve readability of focused elements when they are also in an
 * active/hover state.
 */
a:active,
a:hover {
  outline: 0;
}
/* Text-level semantics
   ========================================================================== */
/**
 * Address styling not present in IE 8/9/10/11, Safari, and Chrome.
 */
/**
 * Address style set to `bolder` in Firefox 4+, Safari, and Chrome.
 */
b,
strong {
  font-weight: bold;
}
/**
 * Address styling not present in Safari and Chrome.
 */
/**
 * Address variable `h1` font-size and margin within `section` and `article`
 * contexts in Firefox 4+, Safari, and Chrome.
 */
h1 {
  font-size: 2em;
  margin: 0.67em 0;
}
/**
 * Address styling not present in IE 8/9.
 */
/**
 * Address inconsistent and variable font size in all browsers.
 */
small {
  font-size: 80%;
}
/**
 * Prevent `sub` and `sup` affecting `line-height` in all browsers.
 */
/* Embedded content
   ========================================================================== */
/**
 * Remove border when inside `a` element in IE 8/9/10.
 */
img {
  border: 0;
}
/**
 * Correct overflow not hidden in IE 9/10/11.
 */
svg:not(:root) {
  overflow: hidden;
}
/* Grouping content
   ========================================================================== */
/**
 * Address margin not present in IE 8/9 and Safari.
 */
/**
 * Address differences between Firefox and other browsers.
 */
/**
 * Contain overflow in all browsers.
 */
/**
 * Address odd `em`-unit font size rendering in all browsers.
 */
/* Forms
   ========================================================================== */
/**
 * Known limitation: by default, Chrome and Safari on OS X allow very limited
 * styling of `select`, unless a `border` property is set.
 */
/**
 * 1. Correct color not being inherited.
 *    Known issue: affects color of disabled elements.
 * 2. Correct font properties not being inherited.
 * 3. Address margins set differently in Firefox 4+, Safari, and Chrome.
 */
button,
input,
textarea {
  color: inherit;
  /* 1 */
  font: inherit;
  /* 2 */
  margin: 0;
  /* 3 */
}
/**
 * Address `overflow` set to `hidden` in IE 8/9/10/11.
 */
button {
  overflow: visible;
}
/**
 * Address inconsistent `text-transform` inheritance for `button` and `select`.
 * All other form control elements do not inherit `text-transform` values.
 * Correct `button` style inheritance in Firefox, IE 8/9/10/11, and Opera.
 * Correct `select` style inheritance in Firefox.
 */
button {
  text-transform: none;
}
/**
 * 1. Avoid the WebKit bug in Android 4.0.* where (2) destroys native `audio`
 *    and `video` controls.
 * 2. Correct inability to style clickable `input` types in iOS.
 * 3. Improve usability and consistency of cursor style between image-type
 *    `input` and others.
 * 4. CUSTOM FOR WEBFLOW: Removed the input[type="submit"] selector to reduce
 *    specificity and defer to the .w-button selector
 */
button,
html input[type="button"] {
  -webkit-appearance: button;
  /* 2 */
  cursor: pointer;
  /* 3 */
}
/**
 * Re-set default cursor for disabled elements.
 */
button[disabled],
html input[disabled] {
  cursor: default;
}
/**
 * Remove inner padding and border in Firefox 4+.
 */
button::-moz-focus-inner,
input::-moz-focus-inner {
  border: 0;
  padding: 0;
}
/**
 * Address Firefox 4+ setting `line-height` on `input` using `!important` in
 * the UA stylesheet.
 */
input {
  line-height: normal;
}
/**
 * It's recommended that you don't attempt to style these elements.
 * Firefox's implementation doesn't respect box-sizing, padding, or width.
 *
 * 1. Address box sizing set to `content-box` in IE 8/9/10.
 * 2. Remove excess padding in IE 8/9/10.
 */
input[type='checkbox'],
input[type='radio'] {
  box-sizing: border-box;
  /* 1 */
  padding: 0;
  /* 2 */
}
/**
 * Fix the cursor style for Chrome's increment/decrement buttons. For certain
 * `font-size` values of the `input`, it causes the cursor style of the
 * decrement button to change from `default` to `text`.
 */
/**
 * 1. CUSTOM FOR WEBFLOW: changed from `textfield` to `none` to normalize iOS rounded input
 * 2. CUSTOM FOR WEBFLOW: box-sizing: content-box rule removed
 *    (similar to normalize.css >=4.0.0)
 */
/**
 * Remove inner padding and search cancel button in Safari and Chrome on OS X.
 * Safari (but not Chrome) clips the cancel button when the search input has
 * padding (and `textfield` appearance).
 */
/**
 * Define consistent border, margin, and padding.
 */
/**
 * 1. Correct `color` not being inherited in IE 8/9/10/11.
 * 2. Remove padding so people aren't caught out if they zero out fieldsets.
 */
/**
 * Remove default vertical scrollbar in IE 8/9/10/11.
 */
textarea {
  overflow: auto;
}
/**
 * Don't inherit the `font-weight` (applied by a rule above).
 * NOTE: the default cannot safely be changed in Chrome and Safari on OS X.
 */
/* Tables
   ========================================================================== */
/**
 * Remove most spacing between table cells.
 */

/* === webflow.css === */
* {
  -webkit-box-sizing: border-box;
  -moz-box-sizing: border-box;
  box-sizing: border-box;
}
html {
  height: 100%;
}
body {
  margin: 0;
  min-height: 100%;
  background-color: #fff;
  font-family: Arial, sans-serif;
  font-size: 14px;
  line-height: 20px;
  color: #333;
}
img {
  max-width: 100%;
  vertical-align: middle;
  display: inline-block;
}
html.w-mod-touch * {
  background-attachment: scroll !important;
}
.w-inline-block {
  max-width: 100%;
  display: inline-block;
}
.w-button {
  display: inline-block;
  padding: 9px 15px;
  background-color: #3898EC;
  color: white;
  border: 0;
  line-height: inherit;
  text-decoration: none;
  cursor: pointer;
  border-radius: 0;
}
input.w-button {
  -webkit-appearance: button;
}
h1,
h2,
h3 {
  font-weight: bold;
  margin-bottom: 10px;
}
h1 {
  font-size: 38px;
  line-height: 44px;
  margin-top: 20px;
}
h2 {
  font-size: 32px;
  line-height: 36px;
  margin-top: 20px;
}
h3 {
  font-size: 24px;
  line-height: 30px;
  margin-top: 20px;
}
p {
  margin-top: 0;
  margin-bottom: 10px;
}
ul {
  margin-top: 0px;
  margin-bottom: 10px;
  padding-left: 40px;
}
.w-embed:before,
.w-embed:after {
  content: " ";
  display: table;
  grid-column-start: 1;
  grid-row-start: 1;
  grid-column-end: 2;
  grid-row-end: 2;
}
.w-embed:after {
  clear: both;
}
button,
[type='button'] {
  border: 0;
  cursor: pointer;
  -webkit-appearance: button;
}
.w-form {
  margin: 0 0 15px;
}
.w-form-done {
  display: none;
  padding: 20px;
  text-align: center;
  background-color: #dddddd;
}
.w-form-fail {
  display: none;
  margin-top: 10px;
  padding: 10px;
  background-color: #ffdede;
}
label {
  display: block;
  margin-bottom: 5px;
  font-weight: bold;
}
.w-input {
  display: block;
  width: 100%;
  height: 38px;
  padding: 8px 12px;
  margin-bottom: 10px;
  font-size: 14px;
  line-height: 1.42857143;
  color: #333333;
  vertical-align: middle;
  background-color: #ffffff;
  border: 1px solid #cccccc;
}
.w-input::placeholder {
  color: #999;
}
.w-input:focus {
  border-color: #3898EC;
  outline: 0;
}
.w-input[disabled] {
  cursor: not-allowed;
}
.w-input[disabled]:not(.w-input-disabled) {
  background-color: #eeeeee;
}
textarea.w-input {
  height: auto;
}
.w-form-label {
  display: inline-block;
  cursor: pointer;
  font-weight: normal;
  margin-bottom: 0px;
}
.w-radio {
  display: block;
  margin-bottom: 5px;
  padding-left: 20px;
}
.w-radio:before,
.w-radio:after {
  content: " ";
  display: table;
  grid-column-start: 1;
  grid-row-start: 1;
  grid-column-end: 2;
  grid-row-end: 2;
}
.w-radio:after {
  clear: both;
}
.w-radio-input {
  margin: 4px 0 0;
  line-height: normal;
  float: left;
  margin-left: -20px;
}
.w-radio-input {
  margin-top: 3px;
}
.w-container {
  margin-left: auto;
  margin-right: auto;
  max-width: 940px;
}
.w-container:before,
.w-container:after {
  content: " ";
  display: table;
  grid-column-start: 1;
  grid-row-start: 1;
  grid-column-end: 2;
  grid-row-end: 2;
}
.w-container:after {
  clear: both;
}
@media screen and (max-width: 991px) {
  .w-container {
    max-width: 728px;
  }
}
@media screen and (max-width: 479px) {
  .w-container {
    max-width: none;
  }
}
@media screen and (max-width: 767px) {
  .w-nav-brand {
    padding-left: 10px;
  }
}
/**
 * ## Note
 * Safari (on both iOS and OS X) does not handle viewport units (vh, vw) well.
 * For example percentage units do not work on descendants of elements that
 * have any dimensions expressed in viewport units. It also doesn’t handle them at
 * all in `calc()`.
 */
/**
 * Wrapper around all lightbox elements
 *
 * 1. Since the lightbox can receive focus, IE also gives it an outline.
 * 2. Fixes flickering on Chrome when a transition is in progress
 *    underneath the lightbox.
 */
/**
 * Neat trick to bind the rubberband effect to our canvas instead of the whole
 * document on iOS. It also prevents a bug that causes the document underneath to scroll.
 */
/* .w-lightbox-content */
/*
 * 1. Remove default margin set by user-agent on the <figure> element.
 */
/**
 * IE adds image dimensions as width and height attributes on the IMG tag,
 * but we need both width and height to be set to auto to enable scaling.
 */
/**
 * 1. Reset if style is set by user on "All Images"
 */
/*
 * Without specifying the with and height inside the SVG, all versions of IE render the icon too small.
 * The bug does not seem to manifest itself if the elements are tall enough such as the above arrows.
 * (http://stackoverflow.com/questions/16092114/background-size-differs-in-internet-explorer)
 */
/**
 * 1. All IE versions add extra space at the bottom without this.
 */
/*
 * 1. We use content-box to avoid having to do `width: calc(10vh + 2vw)`
 *    which doesn’t work in Safari anyway.
 * 2. Chrome renders images pixelated when switching to GPU. Making sure
 *    the parent is also rendered on the GPU (by setting translate3d for
 *    example) fixes this behavior.
 */
/*
 * Spinner
 *
 * Absolute pixel values are used to avoid rounding errors that would cause
 * the white spinning element to be misaligned with the track.
 */
/*
 * Utility classes
 */
@media (min-width: 768px) {
  /* .w-lightbox-content */
}
.w-nav {
  position: relative;
  background: #dddddd;
  z-index: 1000;
}
.w-nav:before,
.w-nav:after {
  content: " ";
  display: table;
  grid-column-start: 1;
  grid-row-start: 1;
  grid-column-end: 2;
  grid-row-end: 2;
}
.w-nav:after {
  clear: both;
}
.w-nav-brand {
  position: relative;
  float: left;
  text-decoration: none;
  color: #333333;
}
.w-nav-link {
  position: relative;
  display: inline-block;
  vertical-align: top;
  text-decoration: none;
  color: #222222;
  padding: 20px;
  text-align: left;
  margin-left: auto;
  margin-right: auto;
}
.w-nav-link.w--current {
  color: #0082f3;
}
.w-nav-menu {
  position: relative;
  float: right;
}
[data-nav-menu-open] {
  display: block !important;
  position: absolute;
  top: 100%;
  left: 0;
  right: 0;
  background: #C8C8C8;
  text-align: center;
  overflow: visible;
  min-width: 200px;
}
.w--nav-link-open {
  display: block;
  position: relative;
}
.w-nav-overlay {
  position: absolute;
  overflow: hidden;
  display: none;
  top: 100%;
  left: 0;
  right: 0;
  width: 100%;
}
.w-nav-overlay [data-nav-menu-open] {
  top: 0;
}
.w-nav[data-animation='over-left'] .w-nav-overlay {
  width: auto;
}
.w-nav[data-animation='over-left'] .w-nav-overlay,
.w-nav[data-animation='over-left'] [data-nav-menu-open] {
  right: auto;
  z-index: 1;
  top: 0;
}
.w-nav[data-animation='over-right'] .w-nav-overlay {
  width: auto;
}
.w-nav[data-animation='over-right'] .w-nav-overlay,
.w-nav[data-animation='over-right'] [data-nav-menu-open] {
  left: auto;
  z-index: 1;
  top: 0;
}
.w-nav-button {
  position: relative;
  float: right;
  padding: 18px;
  font-size: 24px;
  display: none;
  cursor: pointer;
  -webkit-tap-highlight-color: rgba(0, 0, 0, 0);
  tap-highlight-color: rgba(0, 0, 0, 0);
  user-select: none;
}
.w-nav-button:focus {
  outline: 0;
}
.w-nav-button.w--open {
  background-color: #C8C8C8;
  color: white;
}
.w-nav[data-collapse='all'] .w-nav-menu {
  display: none;
}
.w-nav[data-collapse='all'] .w-nav-button {
  display: block;
}
.w--nav-dropdown-open {
  display: block;
}
.w--nav-dropdown-toggle-open {
  display: block;
}
.w--nav-dropdown-list-open {
  position: static;
}
/**
 * NOTE: These rules are overridden in site-designer.less to use container queries instead of media queries
 * when the navbar is inside a Frame on the Open Canvas.
 */
@media screen and (max-width: 991px) {
  .w-nav[data-collapse='medium'] .w-nav-menu {
    display: none;
  }
  .w-nav[data-collapse='medium'] .w-nav-button {
    display: block;
  }
}
@media screen and (max-width: 767px) {
  .w-nav[data-collapse='small'] .w-nav-menu {
    display: none;
  }
  .w-nav[data-collapse='small'] .w-nav-button {
    display: block;
  }
  .w-nav-brand {
    padding-left: 10px;
  }
}
@media screen and (max-width: 479px) {
  .w-nav[data-collapse='tiny'] .w-nav-menu {
    display: none;
  }
  .w-nav[data-collapse='tiny'] .w-nav-button {
    display: block;
  }
}
.w-tabs {
  position: relative;
}
.w-tabs:before,
.w-tabs:after {
  content: " ";
  display: table;
  grid-column-start: 1;
  grid-row-start: 1;
  grid-column-end: 2;
  grid-row-end: 2;
}
.w-tabs:after {
  clear: both;
}
.w-tab-menu {
  position: relative;
}
.w-tab-link {
  position: relative;
  display: inline-block;
  vertical-align: top;
  text-decoration: none;
  padding: 9px 30px;
  text-align: left;
  cursor: pointer;
  color: #222222;
  background-color: #dddddd;
}
.w-tab-link.w--current {
  background-color: #C8C8C8;
}
.w-tab-link:focus {
  outline: 0;
}
.w-tab-content {
  position: relative;
  display: block;
  overflow: hidden;
}
.w-tab-pane {
  position: relative;
  display: none;
}
.w--tab-active {
  display: block;
}
@media screen and (max-width: 479px) {
  .w-tab-link {
    display: block;
  }
}

/* === norbering.webflow.css === */
/* Inter — loaded self-hosted in four weights as WOFF2. Previously only
   SemiBold 600 shipped, so every Inter fallback forced 600 weight on body
   and form inputs. Now body inherits 400 as intended. */
@font-face {
  font-family: Inter;
  src: url('../fonts/inter-latin-ext-400-normal.woff2') format('woff2');
  font-weight: 400;
  font-style: normal;
  font-display: swap;
}
@font-face {
  font-family: Inter;
  src: url('../fonts/inter-latin-ext-500-normal.woff2') format('woff2');
  font-weight: 500;
  font-style: normal;
  font-display: swap;
}
@font-face {
  font-family: Inter;
  src: url('../fonts/inter-latin-ext-600-normal.woff2') format('woff2');
  font-weight: 600;
  font-style: normal;
  font-display: swap;
}
@font-face {
  font-family: Inter;
  src: url('../fonts/inter-latin-ext-700-normal.woff2') format('woff2');
  font-weight: 700;
  font-style: normal;
  font-display: swap;
}
@font-face {
  font-family: Lato;
  src: url('../fonts/lato-latin-ext-400-normal.woff2') format('woff2');
  font-weight: 400;
  font-style: normal;
  font-display: swap;
}
@font-face {
  font-family: Lato;
  src: url('../fonts/lato-latin-ext-700-normal.woff2') format('woff2');
  font-weight: 700;
  font-style: normal;
  font-display: swap;
}

:root {
  --primary50: #E7F4EC;
  --primary100: #C3E6D0;
  --primary300: #6FBE8C;
  --primary600: #10633E;
  --primary700: #0E7A47;
  --success100: #C3E6D0;

  --gray900: #15191B;
  --gray800: #232A2C;
  --gray700: #394246;
  --gray600: #525C5F;
  --gray500: #717B7E;
  --gray400: #9BA4A6;
  --gray300: #CDD3D3;
  --gray200: #E7EAEA;
  --gray100: #F1F4F3;
  --gray50: #F8FAF9;
  --white: #FFFFFF;

  --error500: #F04438;

  --text-secondary: #15191B99;
  --text-tertiary:  #15191B80;
  --text-disabled:  #15191B4d;
  --border-subtle:  #15191B1a;

  --surface-cream-overlay: #F8FAF9CC;
  --border-on-dark:        #CDD3D366;
  --hover-on-dark:         #FFFFFF1A;
  --hover-on-dark-faint:   #FFFFFF0D;
  --hover-on-light:        #0000001A;
  --hover-on-light-faint:  #0000000D;

  --cta-gradient: linear-gradient(135deg, #0E5236 0%, #16A75F 100%);
}

.w-layout-grid {
  grid-row-gap: 16px;
  grid-column-gap: 16px;
  grid-template-rows: auto auto;
  grid-template-columns: 1fr 1fr;
  grid-auto-columns: 1fr;
  display: grid;
}

.w-checkbox {
  margin-bottom: 5px;
  padding-left: 20px;
  display: block;
}

.w-checkbox:before {
  content: " ";
  grid-area: 1 / 1 / 2 / 2;
  display: table;
}

.w-checkbox:after {
  content: " ";
  clear: both;
  grid-area: 1 / 1 / 2 / 2;
  display: table;
}

.w-checkbox-input {
  float: left;
  margin: 4px 0 0 -20px;
  line-height: normal;
}

.w-checkbox-input--inputType-custom {
  border: 1px solid #ccc;
  border-radius: 2px;
  width: 12px;
  height: 12px;
}

.w-checkbox-input--inputType-custom.w--redirected-checked {
  background-color: #3898ec;
  background-image: url('https://d3e54v103j8qbb.cloudfront.net/static/custom-checkbox-checkmark.589d534424.svg');
  background-position: 50%;
  background-repeat: no-repeat;
  background-size: cover;
  border-color: #3898ec;
}

.w-checkbox-input--inputType-custom.w--redirected-focus {
  box-shadow: 0 0 3px 1px #3898ec;
}

.w-layout-blockcontainer {
  max-width: 940px;
  margin-left: auto;
  margin-right: auto;
  display: block;
}

.w-layout-vflex {
  flex-direction: column;
  align-items: flex-start;
  display: flex;
}

.w-form-formradioinput--inputType-custom {
  border: 1px solid #ccc;
  border-radius: 50%;
  width: 12px;
  height: 12px;
}

.w-form-formradioinput--inputType-custom.w--redirected-focus {
  box-shadow: 0 0 3px 1px #3898ec;
}

.w-form-formradioinput--inputType-custom.w--redirected-checked {
  border-width: 4px;
  border-color: #3898ec;
}

@media screen and (max-width: 991px) {
  .w-layout-blockcontainer {
    max-width: 728px;
  }
}

@media screen and (max-width: 767px) {
  .w-layout-blockcontainer {
    max-width: none;
  }
}

body {
  color: var(--gray600);
  font-family: Inter, Arial, sans-serif;
  font-weight: 400;
  font-size: 1rem;
  line-height: 1.5;
}

/* Form controls inherit the document font stack so typed content matches body
   copy. Without this, browsers use a system UI font (which doesn't map to our
   Inter @font-face weights) and fall back to 600, making inputs look bold. */
input, select, textarea, button {
  font-family: inherit;
  font-weight: 400;
}

h1 {
  color: var(--gray900);
  letter-spacing: -.02em;
  margin-top: 0;
  margin-bottom: 0;
  font-size: 4.5rem;
  font-weight: 600;
  line-height: 1.2;
}

h2 {
  color: var(--gray900);
  letter-spacing: -.02em;
  margin-top: 0;
  margin-bottom: 0;
  font-size: 3.75rem;
  font-weight: 600;
  line-height: 1.2;
}

h3 {
  color: var(--gray900);
  letter-spacing: -.02em;
  margin-top: 0;
  margin-bottom: 0;
  font-size: 3rem;
  font-weight: 600;
  line-height: 1.2;
}

p {
  color: var(--gray600);
  letter-spacing: normal;
  margin-bottom: 0;
}

a {
  color: var(--gray600);
  cursor: pointer;
  border-bottom-color: #000;
  text-decoration: none;
}

ul {
  margin-top: 1rem;
  margin-bottom: 1rem;
  padding-left: 1.25rem;
}

li {
  margin-top: .25rem;
  margin-bottom: .25rem;
}

img {
  max-width: 100%;
  display: inline-block;
}

label {
  margin-bottom: .25rem;
  font-weight: 500;
}

.show {
  display: block;
}

.text-size-regular {
  letter-spacing: normal;
  font-size: 1rem;
}

.hide {
  display: none;
}

.container-large {
  width: 100%;
  max-width: 80rem;
  margin-left: auto;
  margin-right: auto;
}

.align-center {
  margin-left: auto;
  margin-right: auto;
}

.max-width-large {
  width: 100%;
  max-width: 48rem;
}

.container-small {
  width: 100%;
  max-width: 48rem;
  margin-left: auto;
  margin-right: auto;
}

.padding-huge {
  padding: 6rem;
}

.padding-top {
  padding-bottom: 0;
  padding-left: 0;
  padding-right: 0;
}

.padding-bottom {
  padding-top: 0;
  padding-left: 0;
  padding-right: 0;
}

.text-weight-medium {
  font-weight: 500;
}

.text-size-medium {
  letter-spacing: normal;
  font-family: Inter, Arial, sans-serif;
  font-size: 1.125rem;
}

.icon-small {
  flex-flow: column;
  justify-content: center;
  align-items: center;
  width: 2rem;
  height: 2rem;
  display: flex;
}

.text-size-large {
  letter-spacing: normal;
  font-size: 1.25rem;
}

.icon-xsmall {
  flex-flow: column;
  flex: none;
  justify-content: center;
  align-items: center;
  width: 1.5rem;
  height: 1.5rem;
  display: flex;
}

.heading-medium {
  font-size: 2.25rem;
  font-weight: 600;
  line-height: 1.3;
}

.heading-large {
  font-size: 3rem;
  font-weight: 600;
  line-height: 1.2;
}

.heading-large.font-lato.text-weight-medium {
  font-weight: 500;
}

.button {
  grid-column-gap: .5rem;
  border: none;
  background-color: var(--primary600);
  background-image: var(--cta-gradient);
  color: var(--white);
  text-align: center;
  white-space: nowrap;
  border-radius: 100px;
  justify-content: center;
  align-items: center;
  padding: .625rem 1.125rem;
  font-weight: 600;
  transition: all .3s;
  display: flex;
  box-shadow: 0 1px 2px #1018280d;
}

.button:hover {
  border-color: var(--primary700);
  filter: brightness(1.1);
}

.button:focus {
  background-color: var(--primary600);
  box-shadow: 0 1px 2px 0 #1018280d;
}

.heading-xsmall {
  letter-spacing: 0;
  font-size: 1.5rem;
  font-weight: 600;
  line-height: 1.4;
}

.button-secondary {
  grid-column-gap: .5rem;
  border: 1px solid var(--gray300);
  background-color: var(--white);
  color: var(--gray700);
  text-align: center;
  white-space: nowrap;
  border-radius: 100px;
  justify-content: center;
  align-items: center;
  padding: .75rem 1.25rem;
  font-weight: 600;
  text-decoration: none;
  transition: all .3s;
  display: flex;
  box-shadow: 0 1px 2px #1018280d;
}

.button-secondary:hover {
  background-color: var(--gray100);
}

.button-secondary:focus {
  box-shadow: 0 1px 2px 0 #1018280d, 0 0 0 4px var(--gray100);
}

.heading-small {
  letter-spacing: 0;
  font-size: 1.875rem;
  font-weight: 600;
  line-height: 1.4;
}

.heading-xlarge {
  font-size: 3.75rem;
  font-weight: 600;
  line-height: 1.2;
}

.button-row {
  grid-column-gap: .75rem;
  grid-row-gap: .75rem;
  flex-wrap: wrap;
  align-items: center;
  display: flex;
}

.button-row.align-center {
  justify-content: center;
  align-items: center;
}

.icon-1x1-xsmall {
  width: 1.5rem;
  height: 1.5rem;
}

.icon-1x1-small {
  flex-flow: column;
  justify-content: center;
  align-items: center;
  width: 2rem;
  height: 2rem;
  display: flex;
}

.background-color-gray100 {
  background-color: var(--gray100);
}

.main-button {
  grid-column-gap: .5rem;
  border: none;
  background-color: var(--primary600);
  background-image: var(--cta-gradient);
  color: var(--white);
  text-align: center;
  white-space: nowrap;
  border-radius: 100px;
  justify-content: center;
  align-items: center;
  padding: .75rem 1.25rem;
  font-weight: 600;
  line-height: 1.5;
  text-decoration: none;
  transition: all .3s;
  display: flex;
  box-shadow: 0 1px 2px #1018280d;
}

.main-button:hover {
  border-color: var(--primary700);
  filter: brightness(1.1);
}

.main-button:focus {
  background-color: var(--primary600);
  box-shadow: 0 1px 2px 0 #1018280d;
}

/* Buttons lift slightly on hover. The transform gets a snappy 100ms ease;
   colour/shadow keep their original .3s fade. Overrides the `all .3s` set
   on each base button rule above (later source order, equal specificity). */
.button,
.button-secondary,
.main-button {
  transition: transform .2s ease, filter .3s, background-color .3s, border-color .3s, box-shadow .3s, color .3s;
}
.button:hover,
.button-secondary:hover,
.main-button:hover {
  transform: translateY(-3px);
}

/* Shimmer sweep on the primary green CTAs — plays once on hover only.
   The ::after sits off-screen by default and animates across on :hover. */
.button,
.main-button {
  position: relative;
  overflow: hidden;
}
.button::after,
.main-button::after {
  content: '';
  position: absolute;
  top: 0;
  left: -150%;
  width: 60%;
  height: 100%;
  background: linear-gradient(120deg, transparent, rgba(255, 255, 255, 0.45), transparent);
  transform: skewX(-20deg);
  pointer-events: none;
  z-index: 2;
}
.button:hover::after,
.main-button:hover::after {
  animation: cta-shimmer 1.5s ease-in-out infinite;
}
@keyframes cta-shimmer {
  0%   { left: -150%; }
  55%  { left: 150%; }
  100% { left: 150%; }
}

.navbar {
  background-color: #fff;
  align-items: center;
  min-height: 5rem;
  padding-left: 2rem;
  padding-right: 2rem;
  display: flex;
  position: sticky;
  top: 0;
  z-index: 1000;
  box-shadow: 0 4px 8px rgba(16, 24, 40, 0);
  transition: box-shadow .3s;
}

.navbar.is-scrolled {
  box-shadow: 0 4px 8px rgba(16, 24, 40, .05);
}

.navbar_container {
  justify-content: space-between;
  align-items: center;
  width: 100%;
  max-width: 80rem;
  height: 100%;
  margin-left: auto;
  margin-right: auto;
  display: flex;
}

.navbar_logo-link {
  flex: none;
  padding-left: 0;
}

.navbar_menu {
  flex: 1;
  justify-content: space-between;
  align-items: center;
  display: flex;
  position: static;
}

.navbar_menu-left {
  flex: 1;
  justify-content: center;
  align-items: center;
  gap: 0;
  display: flex;
}

.navbar_menu-link {
  color: var(--gray600);
  align-items: center;
  margin-left: 0;
  margin-right: 0;
  padding: .75rem 1rem;
  font-size: 1rem;
  font-weight: 600;
  transition: all .3s;
}

.navbar_menu-link:hover {
  color: var(--gray700);
}

.navbar_menu-link.w--current {
  color: #000;
}

.navbar_menu-right {
  grid-template-rows: auto;
  grid-template-columns: 1fr 1fr;
  grid-auto-columns: 1fr;
  align-items: center;
  display: flex;
}

.navbar_menu-button {
  padding: 0;
}

.navbar_button-wrap {
  grid-column-gap: .75rem;
  grid-row-gap: .75rem;
  align-items: center;
  display: flex;
}

.navbar_logo-image {
  width: calc(12rem + 1px);
  max-width: calc(12rem + 1px);
  height: auto;
}

.padding-global {
  padding-left: 2rem;
  padding-right: 2rem;
}

.home-hero_image-wrap {
  border-radius: 1rem;
  justify-content: center;
  align-items: flex-start;
  width: 100%;
  margin-top: 4rem;
  display: flex;
  overflow: hidden;
}

@media screen and (max-width: 767px) {
  .home-hero_image-wrap {
    margin-top: 3rem;
  }
}

.text-size-xlarge {
  color: var(--gray600);
  font-family: Lato, Arial, sans-serif;
  font-size: 1.25rem;
  line-height: 1.5;
}

.home-hero_image {
  object-fit: cover;
  width: 100%;
  height: 32.25rem;
}

.space-small {
  width: 100%;
  min-height: 1.5rem;
}

.space-large {
  width: 100%;
  min-height: 3rem;
}

.home-hero_content {
  grid-column-gap: 2rem;
  grid-row-gap: 2rem;
  justify-content: flex-start;
  align-items: flex-start;
  display: flex;
}

.home-hero_content-max-width {
  width: 100%;
  max-width: 48rem;
}

.home-hero_factor-list {
  grid-column-gap: 1.25rem;
  grid-row-gap: 1.25rem;
  flex-flow: column;
  justify-content: flex-start;
  align-items: flex-start;
  padding-bottom: 1.5rem;
  padding-left: 1rem;
  display: flex;
}

.home-hero_factor {
  grid-column-gap: .75rem;
  grid-row-gap: .75rem;
  justify-content: flex-start;
  align-items: center;
  display: flex;
}

.home-hero_factor-text {
  font-family: Lato, Arial, sans-serif;
  font-size: 1.125rem;
  line-height: 1.75rem;
}

.home-quote_wrap {
  display: grid;
  grid-template-columns: 31.25rem 1fr;   /* 500px */
  grid-template-areas:
    "image quote"
    "image card";
  align-content: center;
  column-gap: 2rem;       /* 32px */
  row-gap: 3rem;          /* 48px */
}

.home-quote_image {
  grid-area: image;
  object-fit: cover;
  object-position: center;
  border-radius: .75rem;   /* 12px */
  width: 31.25rem;         /* 500px */
  height: 31.25rem;
}

.home-quote_text {
  grid-area: quote;
  align-self: end;
  margin: 0;
  font-size: 3.375rem;     /* 54px */
  line-height: 130%;
  text-align: center;
}

.home-quote_card {
  grid-area: card;
  align-self: start;
  justify-self: center;
  text-align: center;
  background-color: var(--white);
  border: 1px solid var(--gray200);
  border-radius: .5rem;    /* 8px */
  padding: .75rem 1.5rem;  /* 12px 24px */
}

.home-quote_card .home-quote_name {
  color: var(--gray900);
  text-decoration: none;
  transition: opacity .2s;
}

.home-quote_card .home-quote_name:hover {
  opacity: .7;
}

.home-quote_card .home-quote_role {
  color: var(--gray600);
}

/* Tablet + mobile: stacked layout with the card overlaid on the image
   (the two-column desktop grid wraps badly below ~992px). */
@media screen and (max-width: 991px) {
  .home-quote_wrap {
    grid-template-columns: minmax(0, 1fr);
    grid-template-areas:
      "quote"
      "media";
    justify-items: center;
    width: 100%;
    max-width: 100%;
    row-gap: 1.5rem;
  }
  .home-quote_image {
    grid-area: media;
    min-width: 0;
    max-width: 31.25rem;   /* cap so the image isn't huge on tablet */
    width: 100%;
    height: auto;
    aspect-ratio: 1 / 1;
  }
  .home-quote_card {
    grid-area: media;
    align-self: end;
    justify-self: center;
    margin-bottom: 1.5rem;
    z-index: 1;
  }
  .home-quote_text {
    font-size: 2.5rem;
    max-width: 31.25rem;
  }
}

@media screen and (max-width: 767px) {
  .home-quote_text {
    font-size: 2rem;
  }
  .home-quote_card {
    margin-bottom: 1rem;
  }
  .home-quote_card .home-quote_name {
    font-size: 1rem;
  }
  .home-quote_card .home-quote_role {
    font-size: .875rem;
  }
}

.heading-tiny {
  color: var(--gray900);
  letter-spacing: normal;
  margin-top: 0;
  margin-bottom: 0;
  font-family: system-ui, -apple-system, BlinkMacSystemFont, Segoe UI, Roboto, Oxygen, Ubuntu, Cantarell, Fira Sans, Droid Sans, Helvetica Neue, sans-serif;
  font-size: 1.125rem;
  font-weight: 600;
  line-height: 1.5;
}

.font-lato {
  font-family: Lato, Arial, sans-serif;
}

.home-tabs_wrap {
  grid-column-gap: 3rem;
  grid-row-gap: 3rem;
  flex-flow: column;
  justify-content: center;
  align-items: center;
  display: flex;
}

.home-tabs_tab-link {
  background-color: #0000;
  padding: 1.5rem 2rem;
  display: block;
  cursor: pointer;
  border-radius: .5rem;
  transition: background-color .3s;
}

/* Active option gets a very light gray highlight; all text stays full opacity. */
.home-tabs_tab-link.w--current {
  background-color: var(--gray50);
}

.home-tabs_tab-component {
  grid-column-gap: 4rem;
  grid-row-gap: 4rem;
  grid-template-rows: auto;
  grid-template-columns: 1fr 1fr;
  grid-auto-columns: 1fr;
  align-items: center;
  display: grid;
}

.home-tabs_tab-menu {
  grid-column-gap: 1rem;
  grid-row-gap: 0rem;
  grid-template-rows: auto auto;
  grid-template-columns: 1fr;
  grid-auto-columns: 1fr;
  display: grid;
}

.home-tabs_tab-image {
  border-radius: 1rem;
  width: 100%;
  height: 100%;
  min-height: 35rem;
  position: relative;
  overflow: hidden;
}

.space-xxsmall {
  width: 100%;
  min-height: .5rem;
}

.heading-xxsmall {
  letter-spacing: 0;
  font-size: 1.25rem;
  font-weight: 600;
  line-height: 1.875rem;
}

.home-services_wrap {
  flex-flow: column;
  justify-content: flex-start;
  align-items: flex-start;
  display: flex;
}

.contacts_heading-wrap {
  width: 100%;
  max-width: 48rem;
}

.uui-heading-xxsmall {
  color: var(--gray900);
  letter-spacing: normal;
  margin-top: 0;
  margin-bottom: 0;
  font-family: system-ui, -apple-system, BlinkMacSystemFont, Segoe UI, Roboto, Oxygen, Ubuntu, Cantarell, Fira Sans, Droid Sans, Helvetica Neue, sans-serif;
  font-size: 1.25rem;
  font-weight: 600;
  line-height: 1.5;
}

.home-services_list {
  grid-column-gap: 2rem;
  grid-row-gap: 4rem;
  grid-template-rows: auto;
  grid-template-columns: 1fr 1fr 1fr;
  grid-auto-columns: 1fr;
  place-items: start;
  margin-top: 4rem;
  margin-bottom: 4rem;
  display: grid;
}

.home-services_item {
  flex-direction: column;
  align-items: center;
}

.home-services_item-icon-wrap {
  border: 1px solid var(--gray200);
  background-color: var(--white);
  width: 3rem;
  height: 3rem;
  color: var(--gray700);
  border-radius: .625rem;
  justify-content: center;
  align-items: center;
  display: flex;
  box-shadow: 0 1px 2px #1018280d;
}

.space-xsmall {
  width: 100%;
  min-height: 1rem;
}

.heading-subheading {
  color: var(--primary600);
  margin-bottom: .75rem;
  font-size: 1rem;
  font-weight: 600;
  line-height: 1.5;
}

.section_calendar.padding-top.padding-huge {
  padding-bottom: 6rem;
  position: relative;
  z-index: 0;
}

.uui-space-xsmall {
  width: 100%;
  min-height: 1rem;
}

.space-medium {
  width: 100%;
  min-height: 2rem;
}

.calendar_content-wrap {
  text-align: center;
}

.calendar_img-wrap {
  border-radius: .75rem;
  margin-top: 4rem;
  overflow: hidden;
}

.calendar_image {
  object-fit: cover;
  object-position: 50% 50%;
  width: 100%;
  height: 25rem;
  max-height: 25rem;
}

.calendar_iframe {
  width: 100%;
  height: 25rem;
  max-height: 25rem;
  border: 0;
  display: block;
  background-color: var(--white);
}

.padding-section_huge {
  padding-top: 6rem;
  padding-bottom: 6rem;
}

.section_contacts {
  z-index: 2;
  background-color: var(--gray100);
  position: relative;
}

.contacts_item-link {
  color: var(--gray900);
  font-weight: 600;
  transition: color .3s;
}

.contacts_item-link:hover {
  color: var(--gray700);
}

.contacts_component {
  grid-column-gap: 2rem;
  grid-row-gap: 2rem;
  grid-template-rows: auto;
  /* auto-fit → cards wrap naturally as the viewport narrows, no hard breakpoints */
  grid-template-columns: repeat(auto-fit, minmax(16rem, 1fr));
  grid-auto-columns: 1fr;
  place-items: stretch start;
  margin-top: 4rem;
  display: grid;
}

.contacts_item {
  background-color: #fff;
  border: 1px solid var(--gray200, #eaecf0);
  flex-direction: column;
  justify-content: space-between;
  align-items: flex-start;
  width: 100%;
  padding: 1.5rem;
  border-radius: 0.75rem;
  display: flex;
}

.contacts_icon-wrap {
  background-color: var(--primary600);
  background-image: linear-gradient(180deg, #1D7B54 0%, #16A75F 100%);
  box-shadow: inset 0 0 12px rgba(0, 0, 0, 0.12);
  width: 3rem;
  height: 3rem;
  color: var(--white);
  border-radius: .625rem;
  justify-content: center;
  align-items: center;
  display: flex;
}

.space-xxlarge {
  width: 100%;
  min-height: 5rem;
}

.footer_wrap {
  justify-content: space-between;
  align-items: center;
  margin-top: 0;
  display: flex;
}

.footer_legal {
  display: flex;
  align-items: center;
  gap: 1.5rem;
}

.footer_legal-link {
  color: inherit;
  text-decoration: none;
  transition: opacity .3s;
  /* reset so a <button> variant reads like the adjacent link */
  background: none;
  border: none;
  padding: 0;
  margin: 0;
  font: inherit;
  cursor: pointer;
}

.footer_legal-link:hover {
  opacity: .7;
}

.footer {
  z-index: 2;
  background-color: var(--white);
  padding-top: 3rem;
  padding-bottom: 3rem;
  position: relative;
}

.contact-page_form-input {
  border: 1px solid var(--gray300);
  background-color: var(--white);
  height: auto;
  min-height: 2.75rem;
  color: var(--gray900);
  border-radius: .5rem;
  margin-bottom: 0;
  padding: .5rem .875rem;
  font-size: 1rem;
  line-height: 1.5;
  transition: all .3s;
  box-shadow: 0 1px 2px #1018280d;
}

.contact-page_form-input:focus {
  border-color: var(--primary300);
  box-shadow: 0 1px 2px 0 #1018280d, 0 0 0 4px var(--primary100);
  color: var(--gray900);
}

.contact-page_form-input::placeholder {
  color: var(--gray500);
}

.contact-page_form-input.text-area {
  height: auto;
  min-height: 11.25rem;
  padding-top: .75rem;
  padding-bottom: .75rem;
  overflow: auto;
}

.footer_social-link {
  color: var(--gray400);
  align-items: center;
  text-decoration: none;
  transition: all .3s;
  display: flex;
}

.footer_social-link:hover {
  color: var(--gray500);
}

/* UntitledUI-style alerts — success / error after form submit */
.success-message,
.error-message {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  text-align: center;
  gap: 1rem;
  padding: 2rem;
  border-radius: 0.75rem;
  border: 1px solid transparent;
  background-clip: padding-box;
  min-height: 100%;
  box-sizing: border-box;
}
.success-message {
  background-color: #E7F4EC;
  border-color: #C3E6D0;
  color: var(--primary700);
}
.error-message {
  background-color: #fef3f2;
  border-color: #fecdca;
  color: #b42318;
  margin-top: 0;
}
.form-alert_icon {
  flex: 0 0 auto;
  width: 3rem;
  height: 3rem;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 999px;
  background-color: var(--success100);
  color: var(--primary700);
  box-shadow: 0 0 0 6px rgba(9, 146, 80, 0.08);
}
.form-alert_icon--error {
  background-color: #fee4e2;
  color: #b42318;
  box-shadow: 0 0 0 6px rgba(240, 68, 56, 0.08);
}
.form-alert_icon svg {
  width: 1.5rem;
  height: 1.5rem;
}
.form-alert_content {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 0.375rem;
  max-width: 28rem;
}
.form-alert_title {
  margin: 0;
  font-family: Inter, Arial, sans-serif;
  font-weight: 600;
  font-size: 1.125rem;
  line-height: 1.4;
  letter-spacing: -0.01em;
}
.form-alert_body {
  margin: 0;
  font-family: Inter, Arial, sans-serif;
  font-weight: 400;
  font-size: 1rem;
  line-height: 1.5;
  color: var(--gray700);
}
.error-message .form-alert_body { color: #7a271a; }

.footer_socials {
  grid-column-gap: 1.5rem;
  grid-row-gap: 0rem;
  white-space: normal;
  grid-template-rows: auto;
  grid-template-columns: max-content;
  grid-auto-columns: max-content;
  grid-auto-flow: column;
  place-items: start;
  display: grid;
}

.footer_social-icon {
  width: 1.5rem;
  height: 1.5rem;
}

.renginiai_wrap {
  grid-column-gap: 3rem;
  grid-row-gap: 3rem;
  flex-flow: column;
  justify-content: flex-start;
  align-items: flex-start;
  display: flex;
}

.renginiai_list {
  grid-column-gap: 2rem;
  grid-row-gap: 4rem;
  grid-template-rows: auto;
  grid-template-columns: 1fr 1fr 1fr;
  grid-auto-columns: 1fr;
  display: grid;
}

.renginiai_item-image {
  object-fit: cover;
  width: 100%;
  height: 100%;
  position: absolute;
  inset: 0%;
}

.renginiai_item-image-wrap {
  width: 100%;
  padding-top: 66%;
  position: relative;
  overflow: hidden;
}

.renginiai_item-image-link {
  border-radius: 1rem;
  width: 100%;
  margin-bottom: 1rem;
  transition: all .3s;
  overflow: hidden;
}

.renginiai_item-image-link:hover {
  box-shadow: 0 24px 48px -12px #1018282e;
}

.renginiai_item-date {
  color: var(--primary700);
  margin-bottom: .5rem;
  margin-right: 1rem;
  font-family: system-ui, -apple-system, BlinkMacSystemFont, Segoe UI, Roboto, Oxygen, Ubuntu, Cantarell, Fira Sans, Droid Sans, Helvetica Neue, sans-serif;
  font-size: .875rem;
  font-weight: 600;
  text-decoration: none;
}

.renginiai_item-date.w--current {
  border-bottom: 2px solid #000;
}

.renginiai_item-title-wrap {
  color: var(--gray900);
  justify-content: space-between;
  margin-bottom: .5rem;
  text-decoration: none;
  display: flex;
}

.renginiai_item-icon {
  justify-content: center;
  align-items: center;
  width: 1.5rem;
  height: 1.5rem;
  margin-top: .25rem;
  margin-left: .5rem;
  display: flex;
}

.renginiai_heading-wrap {
  width: 100%;
  max-width: 48rem;
}

.contact-page_wrap {
  grid-column-gap: 3rem;
  grid-row-gap: 3rem;
  flex-flow: column;
  justify-content: flex-start;
  align-items: flex-start;
  display: flex;
}

.contact-page_form-field-label {
  color: var(--gray700);
  margin-bottom: .5rem;
  font-size: .875rem;
  font-weight: 500;
  line-height: 1.5;
}

.contact-page_form-field-wrap {
  position: relative;
}

.success-text { color: var(--primary700); }
.error-text { color: #b42318; }

.contact-page_form-wrapper {
  display: flex;
  flex-direction: column;
  align-items: stretch;
  height: 100%;
}

.contact-page_component {
  grid-column-gap: 4rem;
  grid-row-gap: 4rem;
  grid-template-rows: auto;
  grid-template-columns: 1fr 1fr;
  grid-auto-columns: 1fr;
  align-items: stretch;
  display: grid;
}

.contact-page_contact-list-item {
  align-items: center;
  display: flex;
}

.contact-page_contact-list-icon-wrap {
  color: var(--white, #fff);
  flex: none;
  align-self: flex-start;
  margin-right: 1rem;
  background-image: linear-gradient(180deg, #1D7B54 0%, #16A75F 100%);
  box-shadow: inset 0 0 12px rgba(0, 0, 0, 0.12);
  border-radius: 0.5rem;
  padding: 0.5rem;
  display: inline-flex;
  align-items: center;
  justify-content: center;
}

/* White stroke so the icon reads cleanly against the gradient chip. */
.contact-page_contact-list-icon-wrap svg [stroke] {
  stroke: currentColor;
}

.contact-page_contact-list {
  grid-column-gap: 1rem;
  grid-row-gap: 1.5rem;
  grid-template-rows: auto;
  grid-template-columns: 1fr;
  grid-auto-columns: 1fr;
  margin-top: 3rem;
  display: grid;
}

.contact-page_form {
  grid-column-gap: 1.5rem;
  grid-row-gap: 1.5rem;
  grid-template-rows: auto auto;
  grid-template-columns: 1fr;
  grid-auto-columns: 1fr;
  display: grid;
}

.contact-page_contact-list-link {
  color: var(--primary600);
  font-family: system-ui, -apple-system, BlinkMacSystemFont, Segoe UI, Roboto, Oxygen, Ubuntu, Cantarell, Fira Sans, Droid Sans, Helvetica Neue, sans-serif;
  font-weight: 600;
  text-decoration: none;
}

.contact-page_form-button-wrap {
  flex-direction: column;
  margin-top: .5rem;
  display: flex;
}

.home-tabs_tab-progress-wrap {
  background-color: var(--gray100);
  width: .25rem;
  height: 100%;
  position: absolute;
  inset: 0% auto 0% 0%;
}

.home-tabs_tab-progress-line {
  background-color: var(--primary600);
  width: .25rem;
  height: 0;
  transition: height .125s;
}

.home-tabs_heading-wrap {
  flex-flow: column;
  justify-content: flex-start;
  align-items: flex-start;
  width: 100%;
  display: flex;
}

.form-radio_item {
  align-items: center;
  margin-bottom: 0;
  padding-left: 1.125rem;
  display: flex;
}

.form-radio_item-icon {
  border: 1px solid var(--gray300);
  background-color: var(--white);
  cursor: pointer;
  border-radius: 100px;
  width: 1.25rem;
  min-width: 1.25rem;
  height: 1.25rem;
  min-height: 1.25rem;
  margin-top: 0;
  margin-left: -1.125rem;
  margin-right: .75rem;
  transition: all .3s;
}

.form-radio_item-icon:hover {
  border-color: var(--primary600);
  background-color: var(--primary50);
}

.form-radio_item-icon.w--redirected-checked {
  border-width: 1px;
  border-color: var(--primary600);
  background-color: var(--primary50);
  background-image: url('../images/check-circle.svg');
  background-position: 50%;
  background-repeat: no-repeat;
  background-size: auto;
}

.form-radio_item-icon.w--redirected-focus {
  border-color: var(--primary600);
  background-color: var(--primary50);
  box-shadow: 0 0 0 4px var(--primary100);
  margin-top: 0;
}

.form-radio_item-icon.tick-icon.w--redirected-checked {
  background-color: var(--primary600);
  background-image: url('../images/check-tick.svg');
}

.form-radio_2col {
  grid-column-gap: 1rem;
  grid-row-gap: 1rem;
  grid-template-rows: auto;
  grid-template-columns: 1fr 1fr;
  grid-auto-columns: 1fr;
  margin-top: 1rem;
  display: grid;
}

.form-radio_item-label {
  color: var(--gray700);
  margin-bottom: 0;
  font-family: system-ui, -apple-system, BlinkMacSystemFont, Segoe UI, Roboto, Oxygen, Ubuntu, Cantarell, Fira Sans, Droid Sans, Helvetica Neue, sans-serif;
  font-weight: 500;
}

.taisykles_wrap {
  grid-column-gap: 6rem;
  grid-row-gap: 6rem;
  flex-flow: column;
  justify-content: space-between;
  align-items: stretch;
  display: flex;
}

.taisykles_wrap.padding-section_huge {
  display: flex;
}

.uui-heading-xlarge-2 {
  color: var(--gray900);
  margin-top: 0;
  margin-bottom: 0;
  font-size: 3.75rem;
  font-weight: 600;
  line-height: 1.2;
}

.uui-text-size-xlarge {
  color: var(--gray600);
  font-family: Lato, Arial, sans-serif;
  font-size: 1.25rem;
  line-height: 1.5;
}

.uui-space-small-2 {
  width: 100%;
  min-height: 1.5rem;
}

.taisykles_heading-wrap {
  text-align: center;
  width: 100%;
  max-width: 64rem;
  margin-left: auto;
  margin-right: auto;
}

.taisykles_content-wrap {
  max-width: 45rem;
  margin-left: auto;
  margin-right: auto;
}

.taisykles_content-section-wrap {
  grid-column-gap: 1.25rem;
  grid-row-gap: 1.25rem;
  flex-flow: column;
  justify-content: flex-start;
  align-items: flex-start;
  margin-top: 2.5rem;
  display: flex;
}

.taisykles_content-section-list {
  margin-top: 0;
  margin-bottom: 0;
  font-family: Lato, Arial, sans-serif;
  font-size: 1.125rem;
  /* Numbers are in the text (e.g. "1.1."); no list marker so it isn't doubled. */
  list-style: none;
  padding-left: 0;
}
.taisykles_content-section-list-item {
  margin-bottom: 0.5rem;
  line-height: 1.6;
}
.taisykles_content-section-list-item:last-child { margin-bottom: 0; }
/* Section 5 confirmation list keeps real bullets. */
.taisykles_content-section-list--bullets {
  list-style: disc;
  padding-left: 1.25rem;
}

.paslaugos-heading_wrap {
  grid-column-gap: 3rem;
  grid-row-gap: 3rem;
  flex-flow: column;
  justify-content: space-between;
  align-items: stretch;
  display: flex;
}

.paslaugos_heading-wrap {
  max-width: 48rem;
}

.paslaugos_disclaimer-wrap {
  background-color: #f9fafb;
  border-radius: 1rem;
  justify-content: space-between;
  align-items: center;
  width: 100%;
  padding: 2rem;
  display: flex;
}

.paslaugos_disclaimer-content {
  grid-column-gap: .5rem;
  grid-row-gap: .5rem;
  flex-flow: column;
  justify-content: flex-start;
  align-items: flex-start;
  max-width: 48rem;
  display: flex;
}

.uui-text-size-large-3 {
  color: var(--gray600);
  letter-spacing: normal;
  font-family: system-ui, -apple-system, BlinkMacSystemFont, Segoe UI, Roboto, Oxygen, Ubuntu, Cantarell, Fira Sans, Droid Sans, Helvetica Neue, sans-serif;
  font-size: 1.125rem;
  line-height: 1.5;
}

.paslaugos-content_factor-list {
  grid-column-gap: 1rem;
  grid-row-gap: 1rem;
  grid-template-rows: auto;
  grid-template-columns: 1fr;
  grid-auto-columns: 1fr;
  margin-top: 2rem;
  margin-bottom: 2.5rem;
  padding-left: 1rem;
  display: grid;
}

.paslaugos-content_factor-list-item {
  grid-column-gap: .75rem;
  grid-row-gap: .75rem;
  justify-content: flex-start;
  align-items: center;
  display: flex;
}

.paslaugos-content_item-image-wrap {
  height: 100%;
  position: relative;
}

.paslaugos-content_item {
  grid-column-gap: 4rem;
  grid-row-gap: 4rem;
  grid-template-rows: auto;
  grid-template-columns: 1fr 1fr;
  grid-auto-columns: 1fr;
  align-items: center;
  min-height: 37.5rem;
  display: grid;
}

.paslaugos-content_item-image {
  object-fit: cover;
  border-radius: .5rem;
  width: 150%;
  max-width: none;
  height: 100%;
  position: absolute;
  top: 0%;
  bottom: 0%;
}

.paslaugos-content_item-image.reverse {
  right: 0;
}

.section_paslaugos-content {
  padding-bottom: 6rem;
  overflow: hidden;
}

.paslaugos-content_list {
  grid-column-gap: 6rem;
  grid-row-gap: 6rem;
  flex-flow: column;
  justify-content: space-between;
  display: flex;
}

.paslaugos-content_item-icon {
  border: 1px solid var(--gray200);
  background-color: var(--white);
  width: 3rem;
  height: 3rem;
  color: var(--gray700);
  border-radius: .625rem;
  justify-content: center;
  align-items: center;
  display: flex;
  box-shadow: 0 1px 2px #1018280d;
}

@media screen and (max-width: 991px) {
  h1 {
    font-size: 3.5rem;
  }

  h2 {
    font-size: 3.25rem;
  }

  h3 {
    font-size: 2.75rem;
  }

  .padding-huge {
    padding: 5rem;
  }

  .padding-top {
    padding-bottom: 0;
    padding-left: 0;
    padding-right: 0;
  }

  .padding-bottom {
    padding-top: 0;
    padding-left: 0;
    padding-right: 0;
  }

  .heading-large {
    font-size: 2.75rem;
  }

  .heading-xlarge {
    font-size: 3.25rem;
  }

  .menu-icon_line-middle-inner {
    width: 4px;
    height: 0;
    padding-bottom: 0;
    padding-right: 0;
  }

  .menu-icon_line-bottom {
    background-color: var(--gray700);
    border-radius: 1rem;
    width: 24px;
    height: 2px;
    padding-bottom: 0;
    padding-right: 0;
  }

  .menu-icon_line-middle {
    background-color: var(--gray700);
    border-radius: 1rem;
    justify-content: center;
    align-items: center;
    width: 24px;
    height: 2px;
    margin-top: 6px;
    margin-bottom: 6px;
    padding-bottom: 0;
    padding-right: 0;
    display: flex;
  }

  .menu-icon_line-top {
    background-color: var(--gray700);
    border-radius: 1rem;
    width: 24px;
    height: 2px;
    padding-bottom: 0;
    padding-right: 0;
  }

  .menu-icon_component {
    flex-direction: column;
    justify-content: center;
    align-items: center;
    width: 48px;
    height: 48px;
    margin-right: -.5rem;
    padding-bottom: 0;
    padding-right: 0;
    display: flex;
  }

  .navbar_menu {
    border-top: 1px solid var(--gray100);
    -webkit-text-fill-color: inherit;
    background-color: #fff;
    background-clip: border-box;
    align-items: flex-start;
    height: 100vh;
    margin-left: 0;
    padding: 1.5rem 2rem 5rem;
    position: absolute;
    overflow: auto;
  }

  .navbar_menu-left {
    grid-column-gap: 0px;
    grid-row-gap: .5rem;
    color: var(--gray900);
    flex-direction: column;
    align-items: flex-start;
    display: flex;
  }

  .navbar_menu-link {
    width: 100%;
    color: var(--gray900);
    padding: .75rem 0;
    font-size: 1.125rem;
  }

  .navbar_menu-link:hover {
    color: var(--gray900);
  }

  .navbar_menu-right {
    flex-direction: column-reverse;
    grid-template-rows: auto auto;
    grid-template-columns: 1fr;
    align-items: stretch;
    margin-top: 1.5rem;
    padding-bottom: 7rem;
  }

  .navbar_menu-button.w--open {
    background-color: #0000;
  }

  .navbar_button-wrap {
    flex-direction: column-reverse;
    align-items: stretch;
    display: flex;
  }

  .space-large {
    min-height: 2.5rem;
  }

  .home-hero_content {
    flex-flow: column-reverse;
  }

  .home-hero_factor-list {
    grid-column-gap: 2rem;
    grid-row-gap: 2rem;
    flex-flow: wrap;
    padding-bottom: 0;
    padding-left: 0;
  }

  .home-tabs_tab-component {
    grid-column-gap: 3rem;
    grid-template-columns: 1fr;
  }

  .home-tabs_tab-image {
    object-fit: cover;
  }

  .padding-section_huge {
    padding-top: 5rem;
    padding-bottom: 5rem;
  }

  .space-xxlarge {
    min-height: 4.5rem;
  }

  .footer_socials {
    margin-bottom: 2rem;
  }

  .renginiai_list {
    grid-template-columns: 1fr 1fr;
  }

  .contact-page_component {
    grid-column-gap: 3rem;
    grid-auto-flow: row;
    min-height: auto;
  }

  .uui-heading-xlarge-2 {
    font-size: 3.25rem;
  }

  .paslaugos_disclaimer-wrap {
    grid-column-gap: 2rem;
    grid-row-gap: 2rem;
    flex-flow: column;
  }

  .paslaugos-content_item {
    grid-column-gap: 2rem;
    grid-row-gap: 2rem;
    grid-template-columns: 1fr;
    grid-auto-flow: row;
    min-height: auto;
  }

  .paslaugos-content_item.reverse {
    flex-flow: column-reverse;
    display: flex;
  }

  .paslaugos-content_item-image {
    width: 100%;
    position: relative;
  }

  .section_paslaugos-content {
    padding-bottom: 5rem;
  }
}

@media screen and (max-width: 767px) {
  h1 {
    font-size: 2.5rem;
  }

  h2 {
    font-size: 2.25rem;
  }

  h3 {
    font-size: 2rem;
  }

  .padding-huge {
    padding: 3.5rem;
  }

  .padding-top {
    padding-bottom: 0;
    padding-left: 0;
    padding-right: 0;
  }

  .padding-bottom {
    padding-top: 0;
    padding-left: 0;
    padding-right: 0;
  }

  .text-size-medium {
    font-size: 1rem;
  }

  .text-size-large {
    font-size: 1.125rem;
  }

  .heading-medium {
    font-size: 1.75rem;
    line-height: 1.4;
  }

  .heading-large {
    font-size: 2.25rem;
  }

  .button {
    padding: .75rem 1.25rem;
    font-size: 1rem;
  }

  .button:hover {
    border-color: var(--primary600);
    background-color: var(--primary600);
  }

  .heading-xsmall {
    font-size: 1.25rem;
  }

  .button-secondary {
    padding: .75rem 1.25rem;
    font-size: 1rem;
  }

  .button-secondary:hover {
    background-color: var(--primary50);
  }

  .heading-small {
    font-size: 1.5rem;
  }

  .heading-xlarge {
    font-size: 2.25rem;
  }

  .button-row {
    align-self: stretch;
  }

  .main-button {
    font-size: 1rem;
  }

  .main-button:hover {
    border-color: var(--primary600);
    background-color: var(--primary600);
  }

  .navbar {
    min-height: 4.5rem;
    padding-left: 1.25rem;
    padding-right: 1.25rem;
  }

  .navbar_menu {
    padding-left: 1rem;
    padding-right: 1rem;
  }

  .navbar_menu-link {
    font-size: 1rem;
  }

  .padding-global {
    padding-left: 1.25rem;
    padding-right: 1.25rem;
  }

  .max-width-full-mobile-landscape-2 {
    width: 100%;
    max-width: none;
  }

  .uui-button-wrapper.max-width-full-mobile-landscape-2 {
    width: 100%;
  }

  .text-size-xlarge {
    font-size: 1.125rem;
  }

  .home-hero_image {
    max-width: none;
    height: 22rem;
  }

  .space-small {
    min-height: 1.25rem;
  }

  .space-large {
    min-height: 2rem;
  }

  .home-hero_factor-list {
    grid-row-gap: 1.25rem;
  }

  .home-tabs_wrap {
    grid-column-gap: 3rem;
    grid-row-gap: 3rem;
  }

  .home-tabs_tab-link {
    padding-left: 1.5rem;
  }

  .home-tabs_tab-component {
    grid-column-gap: 0px;
    grid-row-gap: 3rem;
    grid-template-columns: 1fr;
  }

  .home-tabs_tab-image {
    height: 24rem;
    min-height: auto;
  }

  .heading-xxsmall {
    font-size: 1.25rem;
  }

  .uui-heading-xxsmall {
    font-size: 1.125rem;
  }

  .home-services_list {
    grid-row-gap: 2.5rem;
    grid-template-columns: 1fr;
    margin-top: 3rem;
    margin-bottom: 3rem;
  }

  .space-xsmall, .uui-space-xsmall {
    min-height: .75rem;
  }

  .space-medium {
    min-height: 1.5rem;
  }

  .calendar_img-wrap {
    margin-top: 3rem;
  }

  .padding-section_huge {
    padding-top: 3.5rem;
    padding-bottom: 3.5rem;
  }

  .contacts_component {
    grid-row-gap: 1.5rem;
    margin-top: 3rem;
  }

  .contacts_item {
    padding: 1.5rem;
  }

  .space-xxlarge {
    min-height: 3rem;
  }

  .footer_wrap {
    flex-direction: column-reverse;
    align-items: center;
  }

  /* Mobile: legal links share one row, copyright drops to the bottom */
  .footer_legal {
    flex-wrap: wrap;
    justify-content: center;
    gap: .5rem .875rem;
  }

  .footer_legal .text-size-regular {
    font-size: .875rem;
  }

  .footer_copyright {
    order: 1;
    flex-basis: 100%;
    text-align: center;
  }

  .footer {
    padding-top: 2rem;
    padding-bottom: 2rem;
  }

  .footer_social-link:hover {
    color: var(--gray400);
  }

  .renginiai_wrap {
    grid-column-gap: 2rem;
    grid-row-gap: 2rem;
  }

  .renginiai_list {
    grid-row-gap: 3rem;
    grid-template-columns: 1fr;
  }

  .renginiai_item-image-link {
    margin-bottom: 1.5rem;
  }

  .renginiai_item-image-link:hover {
    box-shadow: none;
  }

  .contact-page_wrap {
    grid-column-gap: 2rem;
    grid-row-gap: 2rem;
  }

  .contact-page_component {
    grid-row-gap: 3rem;
    grid-template-columns: 1fr;
  }

  .contact-page_contact-list {
    margin-top: 2rem;
  }

  .uui-heading-xlarge-2 {
    font-size: 2.25rem;
  }

  .uui-text-size-xlarge {
    font-size: 1.125rem;
  }

  .uui-space-small-2 {
    min-height: 1.25rem;
  }

  .paslaugos-heading_wrap {
    grid-column-gap: 2rem;
    grid-row-gap: 2rem;
  }

  .paslaugos_disclaimer-wrap {
    padding: 1.25rem;
  }

  .uui-text-size-large-3 {
    font-size: 1rem;
  }

  .paslaugos-content_factor-list {
    margin-top: 1.5rem;
    margin-bottom: 2rem;
    padding-left: .5rem;
  }

  .paslaugos-content_item {
    grid-row-gap: 3rem;
  }

  .section_paslaugos-content {
    padding-bottom: 3.5rem;
  }

  .paslaugos-content_wrap {
    grid-column-gap: 2rem;
    grid-row-gap: 2rem;
  }
}

@media screen and (max-width: 479px) {
  h1 {
    font-size: 2.5rem;
  }

  .padding-top {
    padding-bottom: 0;
    padding-left: 0;
    padding-right: 0;
  }

  .padding-bottom {
    padding-top: 0;
    padding-left: 0;
    padding-right: 0;
  }

  .icon-xsmall {
    flex: none;
  }

  .home-hero_image {
    height: 15rem;
  }

  .footer_socials {
    margin-bottom: 1rem;
  }

  .contact-page_component {
    grid-template-columns: 1fr;
  }

  .form-radio_2col {
    grid-template-columns: 1fr;
  }

  .paslaugos-content_factor-list {
    margin-bottom: 1.5rem;
    padding-left: 0;
  }

  .paslaugos-content_factor-list-item {
    grid-column-gap: .5rem;
    grid-row-gap: .5rem;
  }

  .paslaugos-content_item {
    grid-row-gap: 2rem;
  }
}

#w-node-_3a8b014c-688b-0a93-198b-b6611e257016-3aa1e1d4 {
  grid-area: 1 / 1 / 2 / 2;
}

#w-node-_00ae788a-c921-5837-388e-604d0d4dc472-9be44aca, #w-node-_00ae788a-c921-5837-388e-604d0d4dc477-9be44aca, #w-node-_00ae788a-c921-5837-388e-604d0d4dc47c-9be44aca {
  align-self: start;
}

#w-node-_00ae788a-c921-5837-388e-604d0d4dc498-9be44aca {
  grid-area: span 1 / span 1 / span 1 / span 1;
}

#w-node-_00ae788a-c921-5837-388e-604d0d4dc499-9be44aca {
  justify-self: start;
}


/* Snippet gets rid of top margin on first element in any rich text*/
/* Snippet gets rid of bottom margin on last element in any rich text*/
/* Snippet makes all link elements listed below to inherit color from their parent */
a, 
.w-tab-link,
.w-nav-link
{
color: inherit;
}
/* Snippet prevents all click and hover interaction with an element */
/* Snippet enables all click and hover interaction with an element */
/* Snippet enables you to add class of div-square which creates and maintains a 1:1 dimension of a div.*/
/*Hide focus outline for main content element*/
/* Make sure containers never lose their center alignment*/
 .container-small, .container-large {
  margin-right: auto !important;
  margin-left: auto !important;
}
/*Reset selects, buttons, and links styles*/
.w-input, a {
color: inherit;
text-decoration: inherit;
font-size: inherit;
}
/*Apply "..." after 3 lines of text */
/* Apply "..." after 2 lines of text */
/* Apply "..." at 100% width */
/* Removes native scrollbar */
.w-radio-input {box-shadow: none !important;}

/* ============================================
   Post-webflow-js overrides — nav & hovers
   Appended after concat; needed because
   webflow.js no longer wires these behaviours.
   ============================================ */

/* Collapse nav menu at data-collapse="medium" breakpoint (<=991px) */
@media screen and (max-width: 991px) {
  .navbar_logo-image {
    width: calc(10rem + 1px);
    max-width: calc(10rem + 1px);
  }
  .navbar .w-nav-menu { display: none; }
  .navbar .w-nav-menu[data-nav-menu-open] {
    display: flex !important;
    flex-direction: column;          /* stack menu + button vertically */
    justify-content: flex-start;
    align-items: stretch;

    /* Full small viewport height — stable vs. the URL/tab bar dynamics.
       Fall back to 100vh on browsers without svh support. */
    height: 100vh;
    height: 100svh;

    /* Reserve space for iOS home indicator / Android gesture area so the
       "Paremkite iniciatyvą" CTA never hides under system UI. */
    padding-bottom: calc(2rem + env(safe-area-inset-bottom, 0px));

    animation: norb-nav-open 400ms ease both;
  }
  @keyframes norb-nav-open {
    from { opacity: 0; transform: translateY(-12px); }
    to   { opacity: 1; transform: translateY(0); }
  }

  /* Links: full-width column, not half-width left side */
  .navbar .navbar_menu-left {
    display: flex;
    flex-direction: column;
    /* Reset the desktop rule's vertical centering so links sit at the top. */
    justify-content: flex-start;
    align-items: stretch;
    gap: 0;
    width: 100%;
  }
  .navbar .navbar_menu-left .navbar_menu-link {
    display: block;
    width: 100%;
    padding: 0.875rem 0;
  }

  /* "Paremkite iniciatyvą" pinned to the bottom, full width */
  .navbar .navbar_menu-right {
    width: 100%;
    margin-top: auto;
    padding-top: 1.5rem;
    display: block;
  }
  .navbar .navbar_menu-right .navbar_button-wrap,
  .navbar .navbar_menu-right .navbar_button-wrap > a {
    width: 100%;
  }
  .navbar .navbar_menu-right .main-button {
    display: flex;
    justify-content: center;
    align-items: center;
    width: 100%;
    padding-top: 0.875rem;
    padding-bottom: 0.875rem;
  }
}

/* Hamburger-to-X: put the X inside .menu-icon_component so it shares the
   exact same container center as the 3 bars. No horizontal drift on toggle. */
.navbar_menu-button .menu-icon_component {
  position: relative;
  transition: opacity 200ms ease;
}
.navbar_menu-button .menu-icon_line-top,
.navbar_menu-button .menu-icon_line-middle,
.navbar_menu-button .menu-icon_line-middle-inner,
.navbar_menu-button .menu-icon_line-bottom {
  transition: opacity 200ms ease;
}
.navbar_menu-button.w--open .menu-icon_line-top,
.navbar_menu-button.w--open .menu-icon_line-middle,
.navbar_menu-button.w--open .menu-icon_line-bottom {
  opacity: 0;
}

.navbar_menu-button .menu-icon_component::before,
.navbar_menu-button .menu-icon_component::after {
  content: "";
  position: absolute;
  top: 50%;
  left: 50%;
  width: 24px;
  height: 2px;
  background: var(--gray700);
  border-radius: 1rem;
  opacity: 0;
  transform: translate(-50%, -50%);
  transition: opacity 200ms ease, transform 300ms ease;
  pointer-events: none;
}
.navbar_menu-button.w--open .menu-icon_component::before {
  opacity: 1;
  transform: translate(-50%, -50%) rotate(45deg);
}
.navbar_menu-button.w--open .menu-icon_component::after {
  opacity: 1;
  transform: translate(-50%, -50%) rotate(-45deg);
}

/* Event card hover — replaces IX2 on data-w-id on renginiai cards */
.renginiai_item-image-link { overflow: hidden; }
.renginiai_item-image {
  transition: transform 600ms cubic-bezier(0.22, 1, 0.36, 1);
}
.renginiai_item-image-link:hover .renginiai_item-image,
.renginiai_item-image-link:focus-visible .renginiai_item-image {
  transform: scale(1.04);
}
.renginiai_item-title-wrap {
  transition: color 200ms ease;
}
.renginiai_item-icon {
  display: inline-block;
  transition: transform 250ms cubic-bezier(0.22, 1, 0.36, 1);
}
.renginiai_item-title-wrap:hover .renginiai_item-icon,
.renginiai_item-title-wrap:focus-visible .renginiai_item-icon {
  transform: translate(3px, -3px);
}

/* Tab pane transitions get the JS-set inline transitions, but
   provide a sane base so the layout doesn't snap before JS boots. */
.w-tab-pane { transition: opacity 200ms ease; }

/* Services page: plain factor list items (no check icon) — for "Dėl komercinių renginių..." copy on Komerciniai / Privatūs */
.paslaugos-content_factor-list-item--plain {
  padding-left: 0;
}
/* Plain (icon-less) factor lists drop the list indent so the italic line
   stays flush with the heading and description above it. */
.paslaugos-content_factor-list:has(.paslaugos-content_factor-list-item--plain) {
  padding-left: 0;
}
.paslaugos-content_factor-list-item--plain .uui-text-size-large-3 {
  font-style: italic;
}

/* Contact page: clickable Google Maps visual + coordinates. */
.section_contact-map.padding-top.padding-huge {
  padding-top: 3rem;
  padding-bottom: 6rem;
}
/* Keep the heading + intro to ~half width so the line length stays tight. */
.contact-map_heading-wrap {
  max-width: 40rem;
}
.contact-map_embed {
  position: relative;
  width: 100%;
  aspect-ratio: 16 / 7;
  border-radius: .5rem;
  overflow: hidden;
}
.contact-map_embed iframe {
  width: 100%;
  height: 100%;
  border: 0;
  display: block;
}
/* Transparent overlay turns the whole map into a single tap-to-navigate link. */
.contact-map_overlay {
  position: absolute;
  inset: 0;
  cursor: pointer;
}
.contact-map_meta {
  grid-column-gap: 1.5rem;
  grid-row-gap: 1rem;
  flex-wrap: wrap;
  justify-content: space-between;
  align-items: center;
  display: flex;
}
.contact-map_coords {
  color: var(--gray600);
}
@media screen and (max-width: 767px) {
  .contact-map_embed {
    aspect-ratio: 4 / 3;
  }
  .contact-map_meta {
    flex-direction: column;
    align-items: stretch;
    text-align: center;
  }
  .contact-map_meta .button-row,
  .contact-map_meta .main-button {
    width: 100%;
  }
  .contact-map_coords {
    text-align: center;
  }
}


/* Tabs — single static image overlay. The 4 empty panes remain for the
   tabs JS (auto-advance, progress line) but don't hold content. */
.home-tabs_tab-content {
  position: relative;
  height: 35rem;
  border-radius: 1rem;
  overflow: hidden;
}
.home-tabs_tab-pane {
  position: absolute;
  inset: 0;
  height: 100%;
  pointer-events: none;
}
.home-tabs_tab-image-static {
  position: relative;
  z-index: 1;
  width: 100%;
  height: 100%;
  min-height: 0;
  object-fit: cover;
  object-position: center;
  border-radius: 0;
}
@media screen and (max-width: 767px) {
  .home-tabs_tab-content { height: 24rem; }
}

/* Renginiai: "jau greitai" badge + WIP hero-style image */
.renginiai_heading-wrap h1 {
  white-space: nowrap;
}

.renginiai_heading-wrap .text-size-large p {
  margin: 0 0 1rem;
}
.renginiai_heading-wrap .text-size-large p:last-child {
  margin-bottom: 0;
}

/* 404 page */
.section_error { text-align: center; }
.error-page_wrap {
  display: flex;
  flex-direction: column;
  align-items: center;
  max-width: 40rem;
  margin: 0 auto;
}
.error-page_icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 56px;
  height: 56px;
  border-radius: 999px;
  background: var(--gray100);
  color: var(--gray700);
  margin: 0 auto;
  box-shadow: 0 0 0 6px var(--gray50);
}
.error-page_wrap .heading-subheading { text-align: center; }
.error-page_wrap h1 { margin: 0; }
.error-page_wrap p { text-align: center; color: var(--gray600); }

/* ============================================
   Green-tint the primary palette
   Webflow template only overrode --primary600/700 to green but left
   25/50/100/200/300/400/500 as UntitledUI's light purple. That leaks
   into form focus rings, radio check bgs, etc. Re-map to green tints
   derived from the success palette (same green hue family).
   ============================================ */
:root {
  --primary50: #E7F4EC;
  --primary100: #C3E6D0;
  --primary300: #6FBE8C;
}

/* Quote block image is styled in the grid layout above (.home-quote_wrap) */

/* ============================================
   Parama / Support page
   ============================================ */

/* Header ------------------------------------------------------ */
.section_parama-header { text-align: center; }
.parama-header_wrap {
  max-width: 60rem;
  margin: 0 auto;
  text-align: center;
}
.parama-header_wrap .heading-subheading { text-align: center; color: var(--primary600); margin-bottom: 0.75rem; }
.parama-header_wrap h1 { margin: 0; }
.parama-header_wrap p {
  margin: 0 auto;
  max-width: 48rem;
  color: var(--gray600, #475467);
}

/* Pricing section --------------------------------------------- */
.section_parama-pricing { padding-bottom: 4rem; }
.parama-pricing_grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 2rem;
  align-items: stretch;
}
.parama-pricing_card {
  position: relative;
  display: flex;
  flex-direction: column;
  background-color: var(--gray50, #f9fafb);
  border-radius: 0.75rem;
  padding: 3rem 1.5rem 2rem;
  min-height: 30.625rem; /* ~490px */
}
.parama-pricing_badge {
  position: absolute;
  top: -1.5rem;
  left: 50%;
  transform: translateX(-50%);
  width: 3rem;
  height: 3rem;
  display: flex;
  align-items: center;
  justify-content: center;
  background-color: #fff;
  border: 1px solid var(--gray200, #eaecf0);
  border-radius: 0.625rem;
  box-shadow: 0 1px 2px 0 rgba(16, 24, 40, 0.05);
  color: var(--gray700, #344054);
}
.parama-pricing_header {
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  gap: 0.5rem;
}
.parama-pricing_tier {
  font-weight: 600;
  font-size: 1.25rem;
  line-height: 1.875rem;
  color: var(--gray900, #101828);
}
.parama-pricing_amount {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-weight: 600;
  font-size: 3rem;
  line-height: 3.75rem;
  letter-spacing: -0.02em;
  color: var(--gray900, #101828);
  margin: 0;
}
.parama-pricing_currency { font-weight: 600; }
.parama-pricing_description {
  font-size: 1rem;
  line-height: 1.5rem;
  color: var(--gray600, #475467);
  margin: 0;
  text-wrap: balance;
}

/* Stepper (±) — amount gets a reserved fixed width so buttons don't jump */
.parama-pricing_stepper {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 0.25rem;
}
.parama-pricing_stepper-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 2.5rem;
  height: 2.5rem;
  padding: 0;
  background: none;
  border: 0;
  border-radius: 999px;
  color: var(--gray500, #667085);
  cursor: pointer;
  transition: color 0.15s ease, background-color 0.15s ease, transform 0.1s ease;
  /* Suppress mobile double-tap zoom when tapping +/- quickly, and block
     the text-selection highlight that Safari draws on rapid taps. */
  touch-action: manipulation;
  -webkit-tap-highlight-color: transparent;
  user-select: none;
  -webkit-user-select: none;
}
.parama-pricing_stepper-btn:hover {
  color: var(--gray900, #101828);
  background-color: rgba(16, 24, 40, 0.04);
}
.parama-pricing_stepper-btn:active { transform: scale(0.94); }
.parama-pricing_stepper-btn:disabled { opacity: 0.4; cursor: not-allowed; }
.parama-pricing_stepper-btn svg { width: 1.5rem; height: 1.5rem; }
.parama-pricing_stepper .parama-pricing_amount {
  min-width: 9rem;
  font-variant-numeric: tabular-nums;
}
.parama-pricing_value--editable {
  cursor: text;
  border-radius: 0.375rem;
  padding: 0 0.25rem;
  outline: none;
  transition: background-color 0.15s ease, box-shadow 0.15s ease;
}
.parama-pricing_value--editable:hover {
  background-color: rgba(16, 24, 40, 0.04);
}
.parama-pricing_value--editable:focus,
.parama-pricing_value--editable[contenteditable="true"] {
  background-color: #fff;
  box-shadow: 0 0 0 2px var(--primary600, #10633E);
}

/* Middle content: checkmark feature list — left-aligned under a top divider */
.parama-pricing_content {
  flex: 1 0 auto;
  display: flex;
  flex-direction: column;
  padding-top: 1.5rem;
  margin-top: 1.5rem;
  border-top: 1px solid var(--gray200, #eaecf0);
}
.parama-pricing_features {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: 0.4375rem;
  width: 100%;
}
.parama-pricing_feature {
  display: flex;
  align-items: flex-start;
  gap: 0.5625rem;
  font-family: Inter, Arial, sans-serif;
  font-size: 0.9375rem;
  line-height: 1.375rem;
  font-weight: 400;
  color: var(--gray700, #344054);
}
.parama-pricing_feature-icon {
  flex: 0 0 auto;
  width: 1.25rem;
  height: 1.25rem;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  color: var(--primary600, #10633E);
  margin-top: 0.125rem;
}
.parama-pricing_feature-icon svg { width: 100%; height: 100%; }

/* Footer / CTA */
.parama-pricing_footer { margin-top: auto; padding-top: 2rem; }
.parama-pricing_cta {
  width: 100%;
  text-align: center;
  font-weight: 600; /* lock — matches .main-button site-wide */
}
.parama-pricing_cta > div { font-weight: inherit; }

/* GPM strip */
.parama-gpm_wrap {
  display: flex;
  flex-direction: row;
  align-items: flex-start;
  gap: 1.5rem;
  background-color: var(--gray50, #f9fafb);
  border-radius: 1rem;
  padding: 2rem;
  margin-top: 2rem;
}
.parama-gpm_text { flex: 1 1 auto; }
.parama-gpm_text h3 { margin: 0; }
.parama-gpm_text p { margin-top: 0.5rem; color: var(--gray600, #475467); max-width: 62rem; }
.parama-gpm_cta { flex-shrink: 0; }

/* Section separator between newsletter and footer — full-viewport gray rule.
   Also tighten the footer vertical padding (was 3rem top/bottom desktop,
   2rem mobile — felt disproportionately tall). */
.footer {
  border-top: 1px solid var(--gray200);
  padding-top: 1.5rem;
  padding-bottom: 1.5rem;
}
@media screen and (max-width: 767px) {
  .footer { padding-top: 1rem; padding-bottom: 1rem; }
}

/* Newsletter strip — above the footer, UntitledUI-style small CTA */
.section_newsletter {
  border-top: 1px solid var(--gray200);
  padding-top: 3rem;
  padding-bottom: 3rem;
  background-color: var(--white);
  position: relative;
  z-index: 10;
}
.newsletter_wrap {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 2.5rem;
  flex-wrap: wrap;
}
.newsletter_content {
  flex: 1 1 24rem;
  min-width: 0;
}
.newsletter_content h3 { margin: 0 0 0.25rem; }
.newsletter_content p { margin: 0; color: var(--gray600); }
.newsletter_form {
  flex: 0 1 28rem;
  width: 100%;
  max-width: 28rem;
}
.newsletter_field-wrap {
  display: flex;
  gap: 0.75rem;
  align-items: stretch;
}
.newsletter_input {
  flex: 1 1 auto;
  min-width: 0;
  border: 1px solid var(--gray300);
  background-color: var(--white);
  color: var(--gray900);
  border-radius: 0.5rem;
  padding: 0.625rem 0.875rem;
  font-family: inherit;
  font-size: 1rem;
  line-height: 1.5rem;
  box-shadow: 0 1px 2px 0 rgba(16, 24, 40, 0.05);
  transition: border-color 0.15s ease, box-shadow 0.15s ease;
}
.newsletter_input::placeholder { color: var(--gray500); }
.newsletter_input:focus {
  outline: none;
  border-color: var(--primary300);
  box-shadow: 0 1px 2px 0 rgba(16, 24, 40, 0.05), 0 0 0 4px var(--primary100);
}
.newsletter_submit {
  flex: 0 0 auto;
  white-space: nowrap;
}
.newsletter_hint {
  margin: 0.625rem 0 0;
  font-size: 0.875rem;
  color: var(--gray600);
}
.newsletter_hint[data-state="ok"] { color: var(--primary700, #0E7A47); }
.newsletter_hint[data-state="err"] { color: var(--error500, #f04438); }

@media screen and (max-width: 767px) {
  .newsletter_wrap { flex-direction: column; align-items: flex-start; gap: 1.25rem; }
  .newsletter_content, .newsletter_form { flex: 0 0 auto; }
  .newsletter_form, .newsletter_field-wrap { width: 100%; max-width: 100%; }
  .newsletter_field-wrap { flex-direction: column; }
  .newsletter_submit { width: 100%; }
}

/* Renginiai list must fill the container width. The parent .renginiai_wrap
   is a flex column with align-items: flex-start, so children collapse to
   content width without this. (Was previously enforced by the hero image.) */
.renginiai_list-wrap { width: 100%; }

/* Renginiai placeholder cards — not-allowed cursor while no events are live */
.renginiai_item[data-coming-soon],
.renginiai_item[data-coming-soon] .renginiai_item-image-link,
.renginiai_item[data-coming-soon] .renginiai_item-title-wrap,
.renginiai_item[data-coming-soon] .renginiai_item-image-wrap,
.renginiai_item[data-coming-soon] .renginiai_item-image {
  cursor: not-allowed;
}

/* Required-field asterisk on form labels (UntitledUI error-500) */
.form-required {
  color: var(--error500);
  margin-left: 0.125rem;
  font-weight: 500;
}

/* Section divider — thin rule between sections (Figma UntitledUI style) */
.parama-section-divider {
  height: 1px;
  background-color: var(--gray200, #eaecf0);
  width: 100%;
}

/* Dabartinė pažanga — category progress overview. Same ring visual
   language as the modal; layout is a single-column list of rows so the
   numbers have room to breathe. */
.section_parama-progress {
  background-color: #fff;
  /* Override padding-section_huge's 6rem top — flows directly under the
     GPM row with ~4rem total gap (matches 2× the pricing-card gap). */
  padding-top: 0;
}
.parama-progress_heading-wrap {
  max-width: 48rem;
  margin: 0 0 2.5rem 0;
}
.parama-progress_heading-wrap h2 { margin: 0; }
.parama-progress_list {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 1rem;
}
.parama-progress_item {
  display: flex;
  align-items: center;
  gap: 1.25rem;
  padding: 1.25rem 1.5rem;
  border: 1px solid var(--gray200, #eaecf0);
  border-radius: 0.875rem;
  background-color: #fff;
}
.parama-progress_ring {
  --percent: 0;
  flex: 0 0 auto;
  width: 3.5rem;
  height: 3.5rem;
  border-radius: 50%;
  background: conic-gradient(var(--primary600, #10633E) calc(var(--percent) * 1%), var(--gray200, #eaecf0) 0);
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: background 0.4s ease;
}
.parama-progress_ring::before {
  content: '';
  position: absolute;
  inset: 0.3125rem;
  border-radius: 50%;
  background: #fff;
}
.parama-progress_icon {
  position: relative;
  z-index: 1;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  color: var(--primary600, #10633E);
}
.parama-progress_icon svg { width: 1.5rem; height: 1.5rem; }
.parama-progress_body {
  flex: 1 1 auto;
  min-width: 0;
  display: flex;
  flex-direction: column;
  gap: 0.25rem;
}
.parama-progress_body h3 {
  margin: 0;
  font-size: 1.125rem;
  line-height: 1.5rem;
}
.parama-progress_stats {
  font-size: 0.9375rem;
  line-height: 1.375rem;
  color: var(--gray500, #667085);
  font-variant-numeric: tabular-nums;
}
.parama-progress_percent {
  flex: 0 0 auto;
  font-family: Inter, Arial, sans-serif;
  font-size: 1.5rem;
  line-height: 1;
  font-weight: 700;
  font-variant-numeric: tabular-nums;
  color: var(--primary600, #10633E);
  min-width: 3.5rem;
  text-align: right;
}

/* Svarbi informacija — heading + 4 icon items, no intro */
.section_parama-info { background-color: #fff; }
.parama-info_heading-wrap {
  max-width: 48rem;
  margin: 0 0 4rem 0;
}
.parama-info_heading-wrap h2 { margin: 0; }
.parama-info_list {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 2rem;
  align-items: start;
}
.parama-info_item {
  display: flex;
  flex-direction: column;
  gap: 1.25rem;
}
.parama-info_icon {
  width: 3rem;
  height: 3rem;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background-color: #C3E6D0;
  border: 8px solid #E7F4EC;
  border-radius: 1.75rem;
  color: var(--primary600);
  box-sizing: border-box;
}
.parama-info_icon svg { width: 1.25rem; height: 1.25rem; }
.parama-info_body { display: flex; flex-direction: column; gap: 0.5rem; }
.parama-info_body h3 { margin: 0; }
.parama-info_body p { margin: 0; color: var(--gray600, #475467); }

/* Responsive */
@media screen and (max-width: 991px) {
  .parama-pricing_grid { grid-template-columns: 1fr; gap: 3rem; }
  .parama-pricing_card { min-height: 0; padding-bottom: 2rem; }
  .parama-gpm_wrap { flex-direction: column; align-items: flex-start; }
  .parama-info_list { grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 2.5rem; }
  .parama-info_heading-wrap { margin-bottom: 3rem; }
}
@media screen and (max-width: 767px) {
  .section_parama-pricing { padding-bottom: 4rem; }
  .parama-pricing_card { padding: 3rem 1.5rem 1.5rem; }
  .parama-pricing_amount { font-size: 2.5rem; line-height: 3rem; }
  .parama-gpm_wrap { padding: 1.5rem; }
  /* Full-width "Instrukcijos" button on mobile */
  .parama-gpm_cta,
  .parama-gpm_cta .button-wrapper,
  .parama-gpm_cta .button-secondary { width: 100%; }
  .parama-info_list { grid-template-columns: 1fr; gap: 2rem; }
}

/* ============================================================
   Parama donation modal — opened from the pricing-card CTAs
   ============================================================ */
.parama-modal[hidden] { display: none; }
.parama-modal {
  position: fixed;
  inset: 0;
  z-index: 1000;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 1.5rem;
}
.parama-modal_backdrop {
  position: absolute;
  inset: 0;
  background-color: rgba(16, 24, 40, 0.55);
  backdrop-filter: blur(4px);
  animation: parama-fade-in 0.18s ease;
}
.parama-modal_panel {
  position: relative;
  width: 100%;
  max-width: 34rem;
  max-height: calc(100vh - 3rem);
  display: flex;
  flex-direction: column;
  overflow: hidden;
  background-color: #fff;
  border-radius: 1rem;
  box-shadow: 0 20px 40px -8px rgba(16, 24, 40, 0.24), 0 8px 16px -4px rgba(16, 24, 40, 0.12);
  animation: parama-rise 0.22s cubic-bezier(0.2, 0.8, 0.2, 1);
}
.parama-modal_close {
  position: absolute;
  top: 1rem;
  right: 1rem;
  width: 2.25rem;
  height: 2.25rem;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background: none;
  border: 0;
  border-radius: 999px;
  color: var(--gray500, #667085);
  cursor: pointer;
  transition: color 0.15s ease, background-color 0.15s ease;
}
.parama-modal_close:hover {
  color: var(--gray900, #101828);
  background-color: rgba(16, 24, 40, 0.04);
}
.parama-modal_close svg { width: 1.25rem; height: 1.25rem; }

.parama-modal_header {
  flex: 0 0 auto;
  padding: 2rem 2rem 0;
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  gap: 0.25rem;
}
.parama-modal_tier {
  font-size: 0.875rem;
  line-height: 1.25rem;
  font-weight: 600;
  letter-spacing: 0.02em;
  text-transform: uppercase;
  color: var(--primary600, #10633E);
}
.parama-modal_title {
  margin: 0;
  font-size: 1.5rem;
  line-height: 2rem;
  font-weight: 600;
  color: var(--gray900, #101828);
}
.parama-modal_amount {
  display: inline-flex;
  align-items: baseline;
  justify-content: center;
  gap: 0.25rem;
  margin-top: 1rem;
  padding: 0.875rem 2rem;
  border-radius: 1rem;
  background: #E7F4EC;
  border: 1px solid #C3E6D0;
  color: var(--gray900, #101828);
  font-weight: 700;
  font-size: 3.25rem;
  line-height: 1;
  letter-spacing: -0.02em;
}
.parama-modal_currency {
  font-size: 2.5rem;
  font-weight: 700;
  color: var(--gray900, #101828);
}
.parama-modal_value {
  display: inline-block;
  min-width: 1.5rem;
  padding: 0;
  outline: none;
  cursor: text;
  font-variant-numeric: tabular-nums;
  /* Prevent long numbers (e.g. "2000") from wrapping into a
     vertical stack — the grid's auto column should grow with the
     digits instead of breaking them character-by-character. */
  white-space: nowrap;
  touch-action: manipulation;
  -webkit-tap-highlight-color: transparent;
  /* Deliberately no background/border change on hover/focus/edit —
     the user wants the green pill to remain constant while the
     number itself stays editable. */
}
.parama-modal_recurring {
  font-size: 1rem;
  line-height: 1;
  font-weight: 500;
  color: var(--gray500, #667085);
}

/* Attribute selector to defeat .parama-modal_presets { display: flex }
   specificity when JS toggles `hidden`. Without this, hidden = true
   wouldn't actually hide the preset row on monthly/yearly modals. */
.parama-modal_presets[hidden] { display: none; }

.parama-modal_presets {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 0.5rem;
  margin-top: 1rem;
}
.parama-modal_preset {
  appearance: none;
  border: 1px solid var(--gray300, #d0d5dd);
  background: #fff;
  color: var(--gray900, #101828);
  padding: 0.5rem 0.875rem;
  border-radius: 999px;
  font-family: Inter, Arial, sans-serif;
  font-size: 0.875rem;
  line-height: 1.25rem;
  font-weight: 600;
  cursor: pointer;
  transition: background-color 0.15s ease, border-color 0.15s ease, color 0.15s ease;
  touch-action: manipulation;
  -webkit-tap-highlight-color: transparent;
  user-select: none;
  -webkit-user-select: none;
}
.parama-modal_preset:hover {
  background: var(--gray50, #f9fafb);
  border-color: var(--gray400, #98a2b3);
}
.parama-modal_preset:focus-visible {
  outline: none;
  box-shadow: 0 0 0 3px rgba(9, 146, 80, 0.24);
}
.parama-modal_preset--active {
  background: var(--primary600, #10633E);
  color: #fff;
  border-color: var(--primary600, #10633E);
}
.parama-modal_preset--active:hover {
  background: var(--primary700, #0E7A47);
  border-color: var(--primary700, #0E7A47);
}

.parama-modal_description {
  margin: 1rem 0 0;
  font-size: 1rem;
  line-height: 1.5rem;
  color: var(--gray800, #1d2939);
  width: 100%;
}

.parama-modal_divider {
  flex: 0 0 auto;
  height: 1px;
  background-color: var(--gray200, #eaecf0);
  margin: 1.5rem 0 0;
}

.parama-modal_body {
  flex: 1 1 auto;
  overflow-y: auto;
  -webkit-overflow-scrolling: touch;
  padding: 1.5rem 2rem;
}

.parama-modal_caption {
  font-family: Inter, Arial, sans-serif;
  font-size: 0.875rem;
  line-height: 1.25rem;
  font-weight: 600;
  color: var(--gray900, #101828);
  margin-bottom: 0.75rem;
}

/* Category list (radios) -------------------------------------- */
.parama-categories {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
}
.parama-category_label {
  display: flex;
  align-items: center;
  gap: 0.875rem;
  padding: 0.875rem 1rem;
  border: 1px solid var(--gray200, #eaecf0);
  border-radius: 0.75rem;
  background-color: #fff;
  cursor: pointer;
  transition: border-color 0.15s ease, background-color 0.15s ease, box-shadow 0.15s ease;
}
.parama-category_label:hover {
  border-color: var(--gray300, #d0d5dd);
  background-color: var(--gray50, #f9fafb);
}
.parama-category_radio {
  position: absolute;
  opacity: 0;
  pointer-events: none;
  width: 0;
  height: 0;
}
.parama-category_label:has(.parama-category_radio:checked) {
  border-color: var(--primary600, #10633E);
  background-color: #E7F4EC;
  box-shadow: 0 0 0 1px var(--primary600, #10633E) inset;
}
.parama-category_label:has(.parama-category_radio:focus-visible) {
  box-shadow: 0 0 0 3px rgba(9, 146, 80, 0.24);
}

.parama-category_ring {
  --percent: 0;
  flex: 0 0 auto;
  width: 2.75rem;
  height: 2.75rem;
  border-radius: 50%;
  background: conic-gradient(var(--primary600, #10633E) calc(var(--percent) * 1%), var(--gray200, #eaecf0) 0);
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: background 0.4s ease;
}
.parama-category_ring::before {
  content: '';
  position: absolute;
  inset: 0.25rem;
  border-radius: 50%;
  background: #fff;
}
.parama-category_icon {
  position: relative;
  z-index: 1;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  color: var(--primary600, #10633E);
}
.parama-category_icon svg { width: 1.125rem; height: 1.125rem; }

.parama-category_content {
  flex: 1 1 auto;
  min-width: 0;
  display: flex;
  flex-direction: column;
  gap: 0.125rem;
}
.parama-category_name {
  font-family: Inter, Arial, sans-serif;
  font-size: 0.9375rem;
  line-height: 1.375rem;
  font-weight: 600;
  color: var(--gray900, #101828);
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.parama-category_progress {
  font-family: Inter, Arial, sans-serif;
  font-size: 0.8125rem;
  line-height: 1.125rem;
  color: var(--gray500, #667085);
  font-variant-numeric: tabular-nums;
}
.parama-category_percent {
  flex: 0 0 auto;
  font-family: Inter, Arial, sans-serif;
  font-size: 1rem;
  line-height: 1.5rem;
  font-weight: 700;
  font-variant-numeric: tabular-nums;
  color: var(--primary600, #10633E);
}

.parama-modal_footer {
  flex: 0 0 auto;
  padding: 1rem 2rem 1.5rem;
  border-top: 1px solid var(--gray200, #eaecf0);
  background-color: #fff;
  display: flex;
  flex-direction: column;
  gap: 0.75rem;
}
.parama-modal_error {
  font-family: Inter, Arial, sans-serif;
  font-size: 0.875rem;
  line-height: 1.25rem;
  color: #b42318;
  background-color: #fef3f2;
  border: 1px solid #fecdca;
  border-radius: 0.5rem;
  padding: 0.75rem 1rem;
}
.parama-modal_submit {
  width: 100%;
  text-align: center;
  font-weight: 600;
}
.parama-modal_submit > div { font-weight: inherit; }
.parama-modal_submit[aria-busy="true"] {
  opacity: 0.7;
  pointer-events: none;
}

/* Body-scroll lock while modal is open (added via JS). */
body.parama-modal-open {
  overflow: hidden;
}

/* Click-to-copy (email / phone / coordinates): "Nukopijuota!" keeps the
   element's original colour — no highlight. */
[data-copy] { cursor: pointer; }

/* ===== GPM 1,2% instructions modal (reuses .parama-modal base) ===== */
.gpm-modal_panel { max-width: 40rem; }
.gpm-modal_body { padding: 2.5rem 2rem 2rem; }
.gpm-modal_title {
  margin: 0;
  font-size: 1.5rem;
  line-height: 1.3;
  font-weight: 700;
  color: var(--gray900);
}
.gpm-modal_lead {
  margin: 0.5rem 0 1.5rem;
  color: var(--gray600);
}
.gpm-modal_steps {
  margin: 0;
  padding-left: 1.25rem;
  display: flex;
  flex-direction: column;
  gap: 1rem;
  color: var(--gray700);
  line-height: 1.6;
}
.gpm-modal_steps li { padding-left: 0.25rem; }
.gpm-modal_steps a {
  color: var(--primary600);
  font-weight: 600;
  text-decoration: underline;
}
.gpm-modal_recipient {
  display: block;
  margin-top: 0.5rem;
  padding: 0.75rem 1rem;
  background-color: var(--gray50);
  border: 1px solid var(--gray200);
  border-radius: 0.5rem;
  color: var(--gray700);
}
.gpm-modal_img {
  display: block;
  width: 100%;
  height: auto;
  margin-top: 0.75rem;
  border: 1px solid var(--gray200);
  border-radius: 0.5rem;
}
.gpm-modal_cta {
  width: 100%;
  margin-top: 1.75rem;
  text-align: center;
}
.gpm-modal_thanks {
  margin: 1rem 0 0;
  text-align: center;
  color: var(--gray600);
}

@keyframes parama-fade-in {
  from { opacity: 0; }
  to   { opacity: 1; }
}
@keyframes parama-rise {
  from { opacity: 0; transform: translateY(12px) scale(0.98); }
  to   { opacity: 1; transform: translateY(0)    scale(1);    }
}

@media screen and (max-width: 767px) {
  .parama-modal { padding: 0; align-items: flex-end; }
  .parama-modal_panel {
    max-width: none;
    max-height: 92vh;
    border-radius: 1rem 1rem 0 0;
  }
  .parama-modal_header { padding: 1.5rem 1.25rem 0; }
  .parama-modal_body   { padding: 1.25rem; }
  .parama-modal_footer { padding: 0.875rem 1.25rem 1.25rem; }
  .parama-modal_close  { top: .5rem; right: .5rem; }
  .parama-modal_amount {
    font-size: 2.5rem;
    line-height: 3rem;
    padding-left: 1.5rem;
    padding-right: 1.5rem;
  }
  .parama-modal_description { font-size: 0.875rem; line-height: 1.25rem; font-weight: 500; }
  .parama-category_name { white-space: nowrap; width: 100%; }
  .parama-progress_list { grid-template-columns: 1fr; }
  .parama-progress_item { padding: 1rem; gap: 0.875rem; }
  .parama-progress_ring { width: 3rem; height: 3rem; }
  .parama-progress_icon svg { width: 1.25rem; height: 1.25rem; }
  .parama-progress_body h3 { font-size: 1rem; line-height: 1.375rem; }
  .parama-progress_stats { font-size: 0.875rem; line-height: 1.25rem; }
  .parama-progress_percent { font-size: 1.125rem; min-width: 2.5rem; }
  /* Force presets into a 3×2 grid on mobile — flex-wrap's natural wrap
     can leave an orphan on its own row, which looks awkward. */
  .parama-modal_presets {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
  }
  .parama-modal_presets[hidden] { display: none; }
}

/* Post-checkout toast ------------------------------------------ */
.parama-toast[hidden] { display: none; }
.parama-toast {
  position: fixed;
  z-index: 1100;
  bottom: 1.5rem;
  right: 1.5rem;
  max-width: 24rem;
  display: flex;
  align-items: flex-start;
  gap: 0.75rem;
  padding: 1rem 1.25rem 1rem 1rem;
  background-color: #fff;
  border: 1px solid var(--gray200, #eaecf0);
  border-radius: 0.75rem;
  box-shadow: 0 12px 24px -4px rgba(16, 24, 40, 0.16);
  animation: parama-rise 0.22s cubic-bezier(0.2, 0.8, 0.2, 1);
}
.parama-toast[data-state="cancelled"] { border-color: #fecdca; }
.parama-toast_icon {
  flex: 0 0 auto;
  width: 2rem;
  height: 2rem;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background-color: #E7F4EC;
  color: var(--primary600, #10633E);
  border-radius: 999px;
}
.parama-toast[data-state="cancelled"] .parama-toast_icon {
  background-color: #fef3f2;
  color: #b42318;
}
.parama-toast_icon svg { width: 1.125rem; height: 1.125rem; }
.parama-toast_body { flex: 1 1 auto; min-width: 0; }
.parama-toast_title {
  font-family: Inter, Arial, sans-serif;
  font-size: 0.9375rem;
  line-height: 1.375rem;
  font-weight: 600;
  color: var(--gray900, #101828);
}
.parama-toast_desc {
  margin-top: 0.125rem;
  font-family: Inter, Arial, sans-serif;
  font-size: 0.875rem;
  line-height: 1.25rem;
  color: var(--gray600, #475467);
}
.parama-toast_close {
  flex: 0 0 auto;
  width: 1.75rem;
  height: 1.75rem;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background: none;
  border: 0;
  border-radius: 999px;
  color: var(--gray500, #667085);
  cursor: pointer;
  margin-top: -0.125rem;
}
.parama-toast_close:hover {
  color: var(--gray900, #101828);
  background-color: rgba(16, 24, 40, 0.04);
}
@media screen and (max-width: 767px) {
  .parama-toast { left: 1rem; right: 1rem; bottom: 1rem; max-width: none; }
}

/* ============================================================
   Parama success page — /support/success
   ============================================================ */
.section_parama-success { text-align: center; }
.parama-success_wrap {
  width: 100%;
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
}
.parama-success_badge {
  width: 5rem;
  height: 5rem;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background-color: #C3E6D0;
  border: 10px solid #E7F4EC;
  border-radius: 999px;
  color: var(--primary600);
  margin-bottom: 2rem;
  box-sizing: border-box;
  animation: parama-rise 0.4s cubic-bezier(0.2, 0.8, 0.2, 1);
}
.parama-success_badge svg { width: 2.25rem; height: 2.25rem; }
.parama-success_wrap h1 { margin-top: 1rem; max-width: 38rem; }
.parama-success_wrap > p { max-width: 38rem; color: var(--gray600, #475467); }

.parama-success_factors { margin-top: 3.5rem; text-align: left; width: 100%; }

@media screen and (max-width: 767px) {
  .parama-success_badge { width: 4rem; height: 4rem; border-width: 8px; margin-bottom: 1.5rem; }
  .parama-success_badge svg { width: 1.75rem; height: 1.75rem; }
  .parama-success_factors { margin-top: 2.5rem; }
}
