/* * RESET.CSS - Strict Version 2026 -
* Obiectiv: Eliminarea stilurilor implicite ale browserului.
* Fără culori, fără font-size-uri specifice, fără layout.
* Author: EVO Studio
*/

/* --- 1. Box-Model & Global Reset --- */
*, *::before, *::after {
    box-sizing: border-box;
}

html {
    -webkit-text-size-adjust: none;
    text-size-adjust: none;
    -moz-tab-size: 4;
    tab-size: 4;
    /*scroll-behavior: smooth;*/
}

body {
    margin: 0;
    padding: 0;
    min-height: 100vh;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
}

/* --- 2. Elementele de Structură & Text --- */
h1, h2, h3, h4, p, ul, li, figure, blockquote, dl, dd {
    margin: 0;
    padding: 0;
}

h1, h2, h3, h4 {
    font-size: inherit;
    font-weight: inherit;
}

ul, ol {
    list-style: none;
}

a {
    text-decoration: none;
    color: inherit;
}

/*
span {
    display: inline-block;
}
*/

/* --- 3. Elemente Media --- */
img, picture, svg, video, canvas {
    display: block;
    max-width: 100%;
    height: auto;
}

/* --- 4. Formulare & Butoane (Reset pentru Contact Form 7) --- */
input, 
textarea, 
button{
    font: inherit;
    color: inherit;
    background: transparent;
    border: none;
    border-radius: 0;
    margin: 0;
    padding: 0;
    appearance: none;
    -webkit-appearance: none;
    outline: none;
}

/* Prevenire redimensionare orizontală care strică layout-ul */
textarea {
    resize: vertical;
}

/* Reset specific pentru butoane */
button {
    cursor: pointer;
    text-align: inherit;
}

/* Cursor pointer pentru elemente de selecție */
label[for],
select,
input[type="checkbox"],
input[type="radio"] {
    cursor: pointer;
}

/* --- 5. WordPress & Plugin Helper Resets --- */

/* Clasa standard WP pentru accesibilitate */
.screen-reader-text {
    border: 0;
    clip: rect(1px, 1px, 1px, 1px);
    clip-path: inset(50%);
    height: 1px;
    margin: -1px;
    overflow: hidden;
    padding: 0;
    position: absolute;
    width: 1px;
    word-wrap: normal !important;
}

/* Reset pentru Slick Slider / Swiper JS (prevenire highlight pe mobil) */
.slick-slider, .swiper {
    -webkit-tap-highlight-color: transparent;
    touch-action: pan-y;
}

/* Eliminare spațieri automate WP la imagini */
.alignnone, .aligncenter, .alignleft, .alignright {
    margin: 0;
}

/* Respectăm setările de motion ale utilizatorului */
@media (prefers-reduced-motion: reduce) {
  html:focus-within { scroll-behavior: auto; }
  *, *::before, *::after {
    animation-duration: 0.01ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: 0.01ms !important;
    scroll-behavior: auto !important;
  }
}

/**
* TOKENS.CSS - MASTER FILE
* Viewport: 360px - 2560px
* Ratio: 1.25 (Major Third) - Rotunjit Superior
* Author: EVO Studio
*/

/* poppins-regular - latin_latin-ext */
@font-face {
  font-display: swap;
  font-family: 'Poppins';
  font-style: normal;
  font-weight: 400;
  src: url('../fonts/poppins-v24-latin_latin-ext-regular.woff2') format('woff2');
}

/* poppins-500 - latin_latin-ext */
@font-face {
  font-display: swap;
  font-family: 'Poppins';
  font-style: normal;
  font-weight: 500;
  src: url('../fonts/poppins-v24-latin_latin-ext-500.woff2') format('woff2');
}

/* poppins-600 - latin_latin-ext */
@font-face {
  font-display: swap;
  font-family: 'Poppins';
  font-style: normal;
  font-weight: 600;
  src: url('../fonts/poppins-v24-latin_latin-ext-600.woff2') format('woff2');
}

/* poppins-700 - latin_latin-ext */
@font-face {
  font-display: swap;
  font-family: 'Poppins';
  font-style: normal;
  font-weight: 700;
  src: url('../fonts/poppins-v24-latin_latin-ext-700.woff2') format('woff2');
}

/* nunito-sans-300 - latin_latin-ext */
@font-face {
  font-display: swap;
  font-family: 'Nunito Sans';
  font-style: normal;
  font-weight: 300;
  src: url('../fonts/nunito-sans-v19-latin_latin-ext-300.woff2') format('woff2');
}

/* nunito-sans-300italic - latin_latin-ext */
@font-face {
  font-display: swap;
  font-family: 'Nunito Sans';
  font-style: italic;
  font-weight: 300;
  src: url('../fonts/nunito-sans-v19-latin_latin-ext-300italic.woff2') format('woff2');
}

/* nunito-sans-regular - latin_latin-ext */
@font-face {
  font-display: swap;
  font-family: 'Nunito Sans';
  font-style: normal;
  font-weight: 400;
  src: url('../fonts/nunito-sans-v19-latin_latin-ext-regular.woff2') format('woff2');
}

/* nunito-sans-italic - latin_latin-ext */
@font-face {
  font-display: swap; 
  font-family: 'Nunito Sans';
  font-style: italic;
  font-weight: 400;
  src: url('../fonts/nunito-sans-v19-latin_latin-ext-italic.woff2') format('woff2');
}

/* nunito-sans-500 - latin_latin-ext */
@font-face {
  font-display: swap;
  font-family: 'Nunito Sans';
  font-style: normal;
  font-weight: 500;
  src: url('../fonts/nunito-sans-v19-latin_latin-ext-500.woff2') format('woff2');
}

/* nunito-sans-600 - latin_latin-ext */
@font-face {
  font-display: swap;
  font-family: 'Nunito Sans';
  font-style: normal;
  font-weight: 600;
  src: url('../fonts/nunito-sans-v19-latin_latin-ext-600.woff2') format('woff2');
}

/* nunito-sans-700 - latin_latin-ext */
@font-face {
  font-display: swap;
  font-family: 'Nunito Sans';
  font-style: normal;
  font-weight: 700;
  src: url('../fonts/nunito-sans-v19-latin_latin-ext-700.woff2') format('woff2');
}

/* nunito-sans-800 - latin_latin-ext */
@font-face {
  font-display: swap; 
  font-family: 'Nunito Sans';
  font-style: normal;
  font-weight: 800;
  src: url('../fonts/nunito-sans-v19-latin_latin-ext-800.woff2') format('woff2');
}

/* nunito-sans-900 - latin_latin-ext */
@font-face {
  font-display: swap; 
  font-family: 'Nunito Sans';
  font-style: normal;
  font-weight: 900;
  src: url('../fonts/nunito-sans-v19-latin_latin-ext-900.woff2') format('woff2');
}

:root {
  /* --- 1. VIEWPORT ENGINE --- */
  --vp-min: 360;
  --vp-max: 2560;
  --vp-diff: calc(var(--vp-max) - var(--vp-min));

  /* --- 2. FAMILII FONTURI --- */
  --font-title: 'Poppins', sans-serif;
  --font-main: 'Nunito Sans', sans-serif;

  /* --- 3. TITLURI FONT-SIZE (XL, LEAD, H1-H4) --- */
  /* Calculate: Base 16/18 * 1.25^n (Ceiling) */

  /* TITLE XL */
  --title-xl-min: 62; --title-xl-max: 69;
  --title-xl-slope: calc((var(--title-xl-max) - var(--title-xl-min)) / var(--vp-diff));
  --title-xl-y: calc((var(--title-xl-min) - (var(--title-xl-slope) * var(--vp-min))) / 16);
  --title-xl: clamp(calc(var(--title-xl-min)/16*1rem), calc(var(--title-xl-y)*1rem + (var(--title-xl-slope)*100vw)), calc(var(--title-xl-max)/16*1rem));

  /* TITLE LEAD */
  --title-lead-min: 28; --title-lead-max: 52;
  --title-lead-slope: calc((var(--title-lead-max) - var(--title-lead-min)) / var(--vp-diff));
  --title-lead-y: calc((var(--title-lead-min) - (var(--title-lead-slope) * var(--vp-min))) / 16);
  --title-lead: clamp(calc(var(--title-lead-min)/16*1rem), calc(var(--title-lead-y)*1rem + (var(--title-lead-slope)*100vw)), calc(var(--title-lead-max)/16*1rem));

  /* TITLE H1 */
  --title-h1-min: 40; --title-h1-max: 44;
  --title-h1-slope: calc((var(--title-h1-max) - var(--title-h1-min)) / var(--vp-diff));
  --title-h1-y: calc((var(--title-h1-min) - (var(--title-h1-slope) * var(--vp-min))) / 16);
  --title-h1: clamp(calc(var(--title-h1-min)/16*1rem), calc(var(--title-h1-y)*1rem + (var(--title-h1-slope)*100vw)), calc(var(--title-h1-max)/16*1rem));

  /* TITLE H2 */
  --title-h2-min: 22; --title-h2-max: 38;
  --title-h2-slope: calc((var(--title-h2-max) - var(--title-h2-min)) / var(--vp-diff));
  --title-h2-y: calc((var(--title-h2-min) - (var(--title-h2-slope) * var(--vp-min))) / 16);
  --title-h2: clamp(calc(var(--title-h2-min)/16*1rem), calc(var(--title-h2-y)*1rem + (var(--title-h2-slope)*100vw)), calc(var(--title-h2-max)/16*1rem));

  /* TITLE H3 */
  --title-h3-min: 25; --title-h3-max: 29;
  --title-h3-slope: calc((var(--title-h3-max) - var(--title-h3-min)) / var(--vp-diff));
  --title-h3-y: calc((var(--title-h3-min) - (var(--title-h3-slope) * var(--vp-min))) / 16);
  --title-h3: clamp(calc(var(--title-h3-min)/16*1rem), calc(var(--title-h3-y)*1rem + (var(--title-h3-slope)*100vw)), calc(var(--title-h3-max)/16*1rem));

  /* TITLE H4 */
  --title-h4-min: 18; --title-h4-max: 23;
  --title-h4-slope: calc((var(--title-h4-max) - var(--title-h4-min)) / var(--vp-diff));
  --title-h4-y: calc((var(--title-h4-min) - (var(--title-h4-slope) * var(--vp-min))) / 16);
  --title-h4: clamp(calc(var(--title-h4-min)/16*1rem), calc(var(--title-h4-y)*1rem + (var(--title-h4-slope)*100vw)), calc(var(--title-h4-max)/16*1rem));

  /* --- 4. SUPRA TITLURI --- */

  --supra-title-xl-min: 20; --supra-title-xl-max: 23;
  --supra-title-xl-slope: calc((var(--supra-title-xl-max) - var(--supra-title-xl-min)) / var(--vp-diff));
  --supra-title-xl-y: calc((var(--supra-title-xl-min) - (var(--supra-title-xl-slope) * var(--vp-min))) / 16);
  --supra-title-xl: clamp(calc(var(--supra-title-xl-min)/16*1rem), calc(var(--supra-title-xl-y)*1rem + (var(--supra-title-xl-slope)*100vw)), calc(var(--supra-title-xl-max)/16*1rem));

  --supra-title-min: 13; --supra-title-max: 15;
  --supra-title-slope: calc((var(--supra-title-max) - var(--supra-title-min)) / var(--vp-diff));
  --supra-title-y: calc((var(--supra-title-min) - (var(--supra-title-slope) * var(--vp-min))) / 16);
  --supra-title: clamp(calc(var(--supra-title-min)/16*1rem), calc(var(--supra-title-y)*1rem + (var(--supra-title-slope)*100vw)), calc(var(--supra-title-max)/16*1rem));

  /* --- 5. SUB TITLURI --- */

  --sub-title-xl-min: 25; --sub-title-xl-max: 29;
  --sub-title-xl-slope: calc((var(--sub-title-xl-max) - var(--sub-title-xl-min)) / var(--vp-diff));
  --sub-title-xl-y: calc((var(--sub-title-xl-min) - (var(--sub-title-xl-slope) * var(--vp-min))) / 16);
  --sub-title-xl: clamp(calc(var(--sub-title-xl-min)/16*1rem), calc(var(--sub-title-xl-y)*1rem + (var(--sub-title-xl-slope)*100vw)), calc(var(--sub-title-xl-max)/16*1rem));

  --sub-title-min: 16; --sub-title-max: 18;
  --sub-title-slope: calc((var(--sub-title-max) - var(--sub-title-min)) / var(--vp-diff));
  --sub-title-y: calc((var(--sub-title-min) - (var(--sub-title-slope) * var(--vp-min))) / 16);
  --sub-title: clamp(calc(var(--sub-title-min)/16*1rem), calc(var(--sub-title-y)*1rem + (var(--sub-title-slope)*100vw)), calc(var(--sub-title-max)/16*1rem));

  /* --- 6. TEXTE (Body, XL, LG, MD, SM, XS, Lead) --- */

  --text-body-min: 16; --text-body-max: 20;
  --text-body-slope: calc((var(--text-body-max) - var(--text-body-min)) / var(--vp-diff));
  --text-body-y: calc((var(--text-body-min) - (var(--text-body-slope) * var(--vp-min))) / 16);
  --text-body: clamp(calc(var(--text-body-min)/16*1rem), calc(var(--text-body-y)*1rem + (var(--text-body-slope)*100vw)), calc(var(--text-body-max)/16*1rem));

  --text-xl-min: 25; --text-xl-max: 29;
  --text-xl-slope: calc((var(--text-xl-max) - var(--text-xl-min)) / var(--vp-diff));
  --text-xl-y: calc((var(--text-xl-min) - (var(--text-xl-slope) * var(--vp-min))) / 16);
  --text-xl: clamp(calc(var(--text-xl-min)/16*1rem), calc(var(--text-xl-y)*1rem + (var(--text-xl-slope)*100vw)), calc(var(--text-xl-max)/16*1rem));

  --text-lg-min: 20; --text-lg-max: 23;
  --text-lg-slope: calc((var(--text-lg-max) - var(--text-lg-min)) / var(--vp-diff));
  --text-lg-y: calc((var(--text-lg-min) - (var(--text-lg-slope) * var(--vp-min))) / 16);
  --text-lg: clamp(calc(var(--text-lg-min)/16*1rem), calc(var(--text-lg-y)*1rem + (var(--text-lg-slope)*100vw)), calc(var(--text-lg-max)/16*1rem));

  --text-md-min: 14; --text-md-max: 16;
  --text-md-slope: calc((var(--text-md-max) - var(--text-md-min)) / var(--vp-diff));
  --text-md-y: calc((var(--text-md-min) - (var(--text-md-slope) * var(--vp-min))) / 16);
  --text-md: clamp(calc(var(--text-md-min)/16*1rem), calc(var(--text-md-y)*1rem + (var(--text-md-slope)*100vw)), calc(var(--text-md-max)/16*1rem));

  --text-sm-min: 13; --text-sm-max: 15;
  --text-sm-slope: calc((var(--text-sm-max) - var(--text-sm-min)) / var(--vp-diff));
  --text-sm-y: calc((var(--text-sm-min) - (var(--text-sm-slope) * var(--vp-min))) / 16);
  --text-sm: clamp(calc(var(--text-sm-min)/16*1rem), calc(var(--text-sm-y)*1rem + (var(--text-sm-slope)*100vw)), calc(var(--text-sm-max)/16*1rem));

  --text-xs-min: 10; --text-xs-max: 12;
  --text-xs-slope: calc((var(--text-xs-max) - var(--text-xs-min)) / var(--vp-diff));
  --text-xs-y: calc((var(--text-xs-min) - (var(--text-xs-slope) * var(--vp-min))) / 16);
  --text-xs: clamp(calc(var(--text-xs-min)/16*1rem), calc(var(--text-xs-y)*1rem + (var(--text-xs-slope)*100vw)), calc(var(--text-xs-max)/16*1rem));

  --text-navd-tit-min: 12; --text-navd-tit-max: 16;
  --text-navd-tit-slope: calc((var(--text-navd-tit-max) - var(--text-navd-tit-min)) / var(--vp-diff));
  --text-navd-tit-y: calc((var(--text-navd-tit-min) - (var(--text-navd-tit-slope) * var(--vp-min))) / 16);
  --text-navd-tit: clamp(calc(var(--text-navd-tit-min)/16*1rem), calc(var(--text-navd-tit-y)*1rem + (var(--text-navd-tit-slope)*100vw)), calc(var(--text-navd-tit-max)/16*1rem));

  --text-btnul-min: 10; --text-btnul-max: 14;
  --text-btnul-slope: calc((var(--text-btnul-max) - var(--text-btnul-min)) / var(--vp-diff));
  --text-btnul-y: calc((var(--text-btnul-min) - (var(--text-btnul-slope) * var(--vp-min))) / 16);
  --text-btnul: clamp(calc(var(--text-btnul-min)/16*1rem), calc(var(--text-btnul-y)*1rem + (var(--text-btnul-slope)*100vw)), calc(var(--text-btnul-max)/16*1rem));

  --text-btnmenu-min: 10; --text-btnmenu-max: 12;
  --text-btnmenu-slope: calc((var(--text-btnmenu-max) - var(--text-btnmenu-min)) / var(--vp-diff));
  --text-btnmenu-y: calc((var(--text-btnmenu-min) - (var(--text-btnmenu-slope) * var(--vp-min))) / 16);
  --text-btnmenu: clamp(calc(var(--text-btnmenu-min)/16*1rem), calc(var(--text-btnmenu-y)*1rem + (var(--text-btnmenu-slope)*100vw)), calc(var(--text-btnmenu-max)/16*1rem));

  --nume-comp-min: 16; --nume-comp-max: 18;
  --nume-comp-slope: calc((var(--nume-comp-max) - var(--nume-comp-min)) / var(--vp-diff));
  --nume-comp-y: calc((var(--nume-comp-min) - (var(--nume-comp-slope) * var(--vp-min))) / 16);
  --nume-comp: clamp(calc(var(--nume-comp-min)/16*1rem), calc(var(--nume-comp-y)*1rem + (var(--nume-comp-slope)*100vw)), calc(var(--nume-comp-max)/16*1rem));

  --text-btn-cta-min: 14; --text-btn-cta-max: 16;
  --text-btn-cta-slope: calc((var(--text-btn-cta-max) - var(--text-btn-cta-min)) / var(--vp-diff));
  --text-btn-cta-y: calc((var(--text-btn-cta-min) - (var(--text-btn-cta-slope) * var(--vp-min))) / 16);
  --text-btn-cta: clamp(calc(var(--text-btn-cta-min)/16*1rem), calc(var(--text-btn-cta-y)*1rem + (var(--text-btn-cta-slope)*100vw)), calc(var(--text-btn-cta-max)/16*1rem));

  --acc-title-min: 14; --acc-title-max: 16;
  --acc-title-slope: calc((var(--acc-title-max) - var(--acc-title-min)) / var(--vp-diff));
  --acc-title-y: calc((var(--acc-title-min) - (var(--acc-title-slope) * var(--vp-min))) / 16);
  --acc-title: clamp(calc(var(--acc-title-min)/16*1rem), calc(var(--acc-title-y)*1rem + (var(--acc-title-slope)*100vw)), calc(var(--acc-title-max)/16*1rem));

  /* --- 7. STATIC WEIGHTS & DECORATION --- */
  --fw-light: 300; --fw-regular: 400; --fw-medium: 500; --fw-semibold: 600; --fw-bold: 700; --fw-extrabold: 800; --fw-black: 900;
  --fs-normal: normal; --fs-italic: italic;
  --td-none: none; --td-underline: underline;

  /* --- 8. LINE HEIGHTS (Fluid) --- */
  --lh-xl-min: 1.2; --lh-xl-max: 1.1;
  --lh-xl-slope: calc((var(--lh-xl-max) - var(--lh-xl-min)) / var(--vp-diff));
  --lh-xl-y: calc(var(--lh-xl-min) - (var(--lh-xl-slope) * var(--vp-min)));
  --lh-xl: calc(var(--lh-xl-y) + (var(--lh-xl-slope) * 100vw));

  --lh-text-body: 1.6;

  /* --- 9. LETTER SPACING (Fluid) --- */
  --ls-neg-min: 0; --ls-neg-max: -0.02;
  --ls-neg-slope: calc((var(--ls-neg-max) - var(--ls-neg-min)) / var(--vp-diff));
  --ls-neg-y: calc(var(--ls-neg-min) - (var(--ls-neg-slope) * var(--vp-min)));
  --ls-neg: calc(var(--ls-neg-y) * 1em + (var(--ls-neg-slope) * 100vw));

  --ls-txt-min: 0.4; --ls-txt-max: 0.8;
  --ls-txt-slope: calc((var(--ls-txt-max) - var(--ls-txt-min)) / var(--vp-diff));
  --ls-txt-y: calc(var(--ls-txt-min) - (var(--ls-txt-slope) * var(--vp-min)));
  --ls-txt: calc((var(--ls-txt-y) * 1px) + (var(--ls-txt-slope) * 100vw));

  /* --- 10. SPATIERI (Fluid) --- */
  --space-xs-min: 10; --space-xs-max: 15;
  --space-xs-slope: calc((var(--space-xs-max) - var(--space-xs-min)) / var(--vp-diff));
  --space-xs-y: calc((var(--space-xs-min) - (var(--space-xs-slope) * var(--vp-min))) / 16);
  --space-xs: clamp(calc(var(--space-xs-min)/16*1rem), calc(var(--space-xs-y)*1rem + (var(--space-xs-slope)*100vw)), calc(var(--space-xs-max)/16*1rem));

  --space-sm-min: 20; --space-sm-max: 35;
  --space-sm-slope: calc((var(--space-sm-max) - var(--space-sm-min)) / var(--vp-diff));
  --space-sm-y: calc((var(--space-sm-min) - (var(--space-sm-slope) * var(--vp-min))) / 16);
  --space-sm: clamp(calc(var(--space-sm-min)/16*1rem), calc(var(--space-sm-y)*1rem + (var(--space-sm-slope)*100vw)), calc(var(--space-sm-max)/16*1rem));

  --space-md-min: 32; --space-md-max: 52;
  --space-md-slope: calc((var(--space-md-max) - var(--space-md-min)) / var(--vp-diff));
  --space-md-y: calc((var(--space-md-min) - (var(--space-md-slope) * var(--vp-min))) / 16);
  --space-md: clamp(calc(var(--space-md-min)/16*1rem), calc(var(--space-md-y)*1rem + (var(--space-md-slope)*100vw)), calc(var(--space-md-max)/16*1rem));

  --space-lg-min: 52; --space-lg-max: 100;
  --space-lg-slope: calc((var(--space-lg-max) - var(--space-lg-min)) / var(--vp-diff));
  --space-lg-y: calc((var(--space-lg-min) - (var(--space-lg-slope) * var(--vp-min))) / 16);
  --space-lg: clamp(calc(var(--space-lg-min)/16*1rem), calc(var(--space-lg-y)*1rem + (var(--space-lg-slope)*100vw)), calc(var(--space-lg-max)/16*1rem));

  --space-xlg-min: 80; --space-xlg-max: 100;
  --space-xlg-slope: calc((var(--space-xlg-max) - var(--space-xlg-min)) / var(--vp-diff));
  --space-xlg-y: calc((var(--space-xlg-min) - (var(--space-xlg-slope) * var(--vp-min))) / 16);
  --space-xlg: clamp(calc(var(--space-xlg-min)/16*1rem), calc(var(--space-xlg-y)*1rem + (var(--space-xlg-slope)*100vw)), calc(var(--space-xlg-max)/16*1rem));

  --space-colab-min: 110; --space-colab-max: 100;
  --space-colab-slope: calc((var(--space-colab-max) - var(--space-colab-min)) / var(--vp-diff));
  --space-colab-y: calc((var(--space-colab-min) - (var(--space-colab-slope) * var(--vp-min))) / 16);
  --space-colab: clamp(calc(var(--space-colab-min)/16*1rem), calc(var(--space-colab-y)*1rem + (var(--space-colab-slope)*100vw)), calc(var(--space-colab-max)/16*1rem));

  /* --- 11. IMAGINI & LOGO (Fluid) --- */
  --logo-width-min: 110; --logo-width-max: 180;
  --logo-width-slope: calc((var(--logo-width-max) - var(--logo-width-min)) / var(--vp-diff));
  --logo-width-y: calc((var(--logo-width-min) - (var(--logo-width-slope) * var(--vp-min))) / 16);
  --logo-width: clamp(calc(var(--logo-width-min)/16*1rem), calc(var(--logo-width-y)*1rem + (var(--logo-width-slope)*100vw)), calc(var(--logo-width-max)/16*1rem));

  --img-section-height-min: 300; --img-section-height-max: 600;
  --img-section-height-slope: calc((var(--img-section-height-max) - var(--img-section-height-min)) / var(--vp-diff));
  --img-section-height-y: calc((var(--img-section-height-min) - (var(--img-section-height-slope) * var(--vp-min))) / 16);
  --img-section-height: clamp(calc(var(--img-section-height-min)/16*1rem), calc(var(--img-section-height-y)*1rem + (var(--img-section-height-slope)*100vw)), calc(var(--img-section-height-max)/16*1rem));

  /* --- 12. GAPS (Fluid) --- */
  --gap-lg-min: 60; --gap-lg-max: 120;
  --gap-lg-slope: calc((var(--gap-lg-max) - var(--gap-lg-min)) / var(--vp-diff));
  --gap-lg-y: calc((var(--gap-lg-min) - (var(--gap-lg-slope) * var(--vp-min))) / 16);
  --gap-lg: clamp(calc(var(--gap-lg-min)/16*1rem), calc(var(--gap-lg-y)*1rem + (var(--gap-lg-slope)*100vw)), calc(var(--gap-lg-max)/16*1rem));

  --gap-md-min: 24; --gap-md-max: 48;
  --gap-md-slope: calc((var(--gap-md-max) - var(--gap-md-min)) / var(--vp-diff));
  --gap-md-y: calc((var(--gap-md-min) - (var(--gap-md-slope) * var(--vp-min))) / 16);
  --gap-md: clamp(calc(var(--gap-md-min)/16*1rem), calc(var(--gap-md-y)*1rem + (var(--gap-md-slope)*100vw)), calc(var(--gap-md-max)/16*1rem));

  --gap-sm-min: 14; --gap-sm-max: 24;
  --gap-sm-slope: calc((var(--gap-sm-max) - var(--gap-sm-min)) / var(--vp-diff));
  --gap-sm-y: calc((var(--gap-sm-min) - (var(--gap-sm-slope) * var(--vp-min))) / 16);
  --gap-sm: clamp(calc(var(--gap-sm-min)/16*1rem), calc(var(--gap-sm-y)*1rem + (var(--gap-sm-slope)*100vw)), calc(var(--gap-sm-max)/16*1rem));

  /* --- PADDING BUTOANE (Fluid) --- */
  /* Top-Bottom: 12px -> 18px */
  --btn-pv-min: 10; --btn-pv-max: 18;
  --btn-pv-slope: calc((var(--btn-pv-max) - var(--btn-pv-min)) / var(--vp-diff));
  --btn-pv-y: calc((var(--btn-pv-min) - (var(--btn-pv-slope) * var(--vp-min))) / 16);
  --btn-pv: clamp(calc(var(--btn-pv-min)/16*1rem), calc(var(--btn-pv-y)*1rem + (var(--btn-pv-slope)*100vw)), calc(var(--btn-pv-max)/16*1rem));

  /* Left-Right: 24px -> 40px */
  --btn-ph-min: 14; --btn-ph-max: 40;
  --btn-ph-slope: calc((var(--btn-ph-max) - var(--btn-ph-min)) / var(--vp-diff));
  --btn-ph-y: calc((var(--btn-ph-min) - (var(--btn-ph-slope) * var(--vp-min))) / 16);
  --btn-ph: clamp(calc(var(--btn-ph-min)/16*1rem), calc(var(--btn-ph-y)*1rem + (var(--btn-ph-slope)*100vw)), calc(var(--btn-ph-max)/16*1rem));

  /* --- BORDER RADIUS (Fluid) --- */
  /* 4px -> 12px */
  --btn-br-min: 4; --btn-br-max: 12;
  --btn-br-slope: calc((var(--btn-br-max) - var(--btn-br-min)) / var(--vp-diff));
  --btn-br-y: calc((var(--btn-br-min) - (var(--btn-br-slope) * var(--vp-min))) / 16);
  --btn-br: clamp(calc(var(--btn-br-min)/16*1rem), calc(var(--btn-br-y)*1rem + (var(--btn-br-slope)*100vw)), calc(var(--btn-br-max)/16*1rem));

  --btn-cta-min: 30; --btn-cta-max: 50;
  --btn-cta-slope: calc((var(--btn-cta-max) - var(--btn-cta-min)) / var(--vp-diff));
  --btn-cta-y: calc((var(--btn-cta-min) - (var(--btn-cta-slope) * var(--vp-min))) / 16);
  --btn-cta: clamp(calc(var(--btn-cta-min)/16*1rem), calc(var(--btn-cta-y)*1rem + (var(--btn-cta-slope)*100vw)), calc(var(--btn-cta-max)/16*1rem));

  /* --- BORDER RADIUS SWIPER SLIDER CARDS --- */
  --card-padding: 15px;      /* Padding-ul cardului */
  --inner-radius: 8px;       /* Raza imaginii (interior) */
  /* Calculăm automat raza exterioară */
  --outer-radius: calc(var(--inner-radius) + var(--card-padding));

  /* --- WIDTH PROCENTUAL (Fluid) --- */
  /* 60% -> 100% */
  --w-mobile-px: 360;  /* 100% din 360 */
  --w-desktop-px: 624; /* 60% din 1040 */
  --div-w-slope: calc((var(--w-desktop-px) - var(--w-mobile-px)) / var(--vp-diff));
  --div-w-y: calc((var(--w-mobile-px) - (var(--div-w-slope) * var(--vp-min))) / 16);
  --div-width: clamp(
    60%, 
    calc(var(--div-w-y) * 1rem + (var(--div-w-slope) * 100vw)), 
    100%
  );

  /* 50% -> 100% */
  --w2-mobile-px: 360;  /* 100% din 360px */
  --w2-desktop-px: 520; /* 50% din 1040px (1040 * 0.5) */
  --div-w2-slope: calc((var(--w2-desktop-px) - var(--w2-mobile-px)) / var(--vp-diff));
  --div-w2-y: calc((var(--w2-mobile-px) - (var(--div-w2-slope) * var(--vp-min))) / 16);
  --div-width2: clamp(
    50%, 
    calc(var(--div-w2-y) * 1rem + (var(--div-w2-slope) * 100vw)), 
    100%
  );

  /* --- 13. CULORI --- */
  --color-brand-accent: #55B18F;
  --color-brand-standard: #4E5153;
  --color-brand-standard-inchis: #3D4042;
  /* Variante optimizate pentru text (lizibilitate) */
  --color-brand-accent-deschis:#85D4B4;
  --color-brand-accent-inchis:#2D755E; /* Pt desktop */
  --color-neutral: #FDFDFD;
  --color-optim: #F7EAD7;
  --color-gri-deschis: #F4F5F3;
  --color-financial: #2B4262;
  --color-yallow: #FAD36C;
  /* premium */
  --color-premium-standard: #3D4042;
  --color-premium-accent: #FAD36C;
  --color-premium-text: #F6F0DB;
  --color-ideal-standard: #55B18F;
  --color-ideal-accent: #3D4042;
  --color-ideal-text: #F7EAD7;
  --color-optim-standard: #F7EAD7;
  --color-optim-accent: #55B18F;
  --color-optim-text: #3D4042;
  /* cards & sections */
  --color-bk-card: #F7F3E3;

  /* --- 14. LAYOUT --- */
  --grid-cols-main: 12;
  --container-width: 1440px;
  --trans-base: 0.3s cubic-bezier(0.4, 0, 0.2, 1);
}

/**
* LANDING-MAIN.CSS - MAIN THEME FILE
* Viewport: 360px - 2560px
* Ratio: 1.25 (Major Third) - Rotunjit Superior
* Author: EVO Studio
*/
/* --- 1. CONFIGURARE GLOBALĂ & PADDING DINAMIC --- */
:root {
    /* Padding lateral conform cerinței */
    --site-gutter: 20px; /*a fost 25px*/
    /* Valoare de siguranță până când JS-ul face prima măsurătoare */
    --header-real-height: 70px; 
}

.has-header-offset {
    /* Aplică margin-top egal cu înălțimea calculată de JS */
    margin-top: var(--header-real-height);
}

@media (min-width: 1040px) {
    :root {
        --site-gutter: 30px; /*a fost 50px*/
    }
}

body {
    font-family: var(--font-main);
    color: var(--color-brand-standard);
    background-color: var(--color-neutral);
    overflow-x: hidden; /* Siguranță pentru layout full-width */
}

/* --- 2. TIPOGRAFIE (Poppins & Nunito) --- */
h1, h2, h3, h4, .font-title {
    font-family: 'Poppins', sans-serif;
    line-height: var(--lh-xl);
}

/* --- 3. GRID SYSTEM (Mobile-First) --- */
.layout-grid, .layout-grid2, .layout-grid-extra {
    display: grid;
    grid-template-columns: repeat(var(--grid-cols-main), 1fr);
    width: 100%;
}

.layout-grid, .layout-grid2 {
    gap: var(--gap-md);
}

.layout-grid-extra{
    row-gap: var(--gap-lg);
}

@media(min-width: 1040px){
    .layout-grid-extra{
        gap: var(--gap-lg);
    }
}

.layout-grid{
    padding-left: var(--site-gutter);
    padding-right: var(--site-gutter);
}

.span-12, .span-3-6-12, .span-3-12, .span-4-12, .span-6-12, .span-8-12 { grid-column: span 12; }
.span-11 { grid-column: span 11; }
.span-10 { grid-column: span 10; }
.span-9 { grid-column: span 9; }
.span-8 { grid-column: span 8; }
.span-7 { grid-column: span 7; }
.span-6, .span-4-6, .span-3-6 { grid-column: span 6; }
.span-5 { grid-column: span 5; }
.span-4 { grid-column: span 4; }
.span-3 { grid-column: span 3; }
.span-2 { grid-column: span 2; }

@media (min-width: 1040px){
    .span-8-12{
        grid-column: span 8;
    }
    .span-6-12{
        grid-column: span 6;
    }
    .span-4-6, .span-4-12{
        grid-column: span 4;
    }
    .span-3-6, .span-3-6-12, .span-3-12{
        grid-column: span 3;
    }
}

@media (min-width: 992px) and (max-width: 1039px) {
    .span-3-6-12{
        grid-column: span 6;
    }
}

/* --- UTILITY: 2 COLUMNS FLEX GRID --- */
.flex-2-cols {
    width: 100%;
    display: flex;
    flex-wrap: wrap;
    gap: var(--gap-md);
    /*
    align-items: stretch;
    */
}

.flex-col {
    flex: 1 1 100%; /* Mobil: Full width */
    display: flex;
    flex-direction: column;
}

.flex-1-col, .flex-1-col-end{
    width: 100%;
    display: flex;
    flex-wrap: wrap;
    flex-direction: column;
}

@media (min-width: 1040px) {
    .flex-col {
        flex: 1 1 calc(50% - (var(--gap-md) / 2));
    }
    .flex-2-cols.is-reversed {
        flex-direction: row-reverse;
    }
    .flex-1-col{
        width: 50%; 
        flex-basis: 50%;
    }
    .flex-1-col-end{
        width: 50%; 
        flex-basis: 50%;
        align-self: flex-end;
    }
}

.equal-height-text {
    flex-grow: 1;
    width: 100%;
}

/* --- Content text areas --- */
.content-text, 
.content-text2, 
.content-text-simple{
    flex-direction: column;
    font-size: var(--text-body);
    line-height: 1.4;
    letter-spacing: var(--ls-txt);
}

.content-text, 
.content-text2{
    display: flex;
}

.content-text2{
    flex-grow: 1;
}

.content-text-simple span{
    font-weight: var(--fw-bold);
}

/* Footer: Ascuns pe mobil, vizibil de la 1040px */
footer {
    /*display: none;*/
    background-color: var(--color-brand-standard);
    color: white;
}

.footer-mic{
    background-color: #383A3C;
    padding-top: 16px;
    padding-bottom: 16px;
}

.copy-desk{
    display: flex;
    align-items: center;
}

.copy-desk p{
    color: var(--color-neutral);
    font-size: var(--text-xs);
}

.anpc-menu{
    width: 100%;
    display: flex;
    flex-direction: row;
    justify-content: flex-end;
}

.anpc-menu li:not(:last-child){
    margin-right: 25px;
}

.anpc-menu li a img{
    width: auto;
    height: 30px;
    object-fit: contain;
    display: block;
}

.acordads{
    width: 100%;
    display: flex;
    flex-direction: column;
    justify-content: flex-end;
}

.acordads li{
    display:block;
}

.acordads li a{
    color: var(--color-neutral);
    font-size: var(--text-xs);
}

@media (min-width: 1040px) {
    footer {
        display: block;
    }
    .anpc-desk{
        display:flex;
        justify-content: flex-end;
    }
    .anpc-menu, .acordads{
        width:auto;
        display:inline-flex;
        vertical-align:middle;
    }
    .acordads{
        flex-direction: row;
        justify-content: flex-end;
        align-items: center;
        margin-right:25px;
    }
    .acordads li {
        display:inline-flex;
    }
    .acordads li:not(:last-child){
        margin-right:25px;
    }
}

@media (max-width:1039px){
    .footer-mic{
        padding-bottom: 46px;
    }
    .acordads{
        margin-bottom:20px;
    }
}

/* Bara de acțiuni mobil: Vizibilă doar sub 1040px */
.mobile-action-bar {
    display: flex;
    flex-direction: column;
    position: fixed;
    bottom: 0;
    left: 0;
    width: 100%;
    z-index: 1000;
}

@media (min-width: 1040px) {
    .mobile-action-bar {
        display: none;
    }
}

.main-mobile-cta2{
    color: var(--color-brand-accent-deschis);
    background-color: var(--color-brand-standard-inchis);
    text-align: center;
    padding: 5px 0px;
    font-family: var(--font-title);
    font-weight: var(--fw-bold);
    font-size: 11px;
}

/* --- SITE HEADER BASE --- */
.site-header {
    position: fixed; /* Fixat pentru a putea fi controlat la scroll */
    top: 0;
    left: 0;
    width: 100%;
    z-index: 2000;
    transition: transform 0.4s cubic-bezier(0.165, 0.84, 0.44, 1), 
                background-color 0.3s ease, 
                box-shadow 0.3s ease;
    padding: 15px 0;
    background-color: transparent; /* Default Desktop */
}

/* Starea ascunsă (când facem scroll în jos) */
.site-header.header-hidden {
    transform: translateY(-100%);
}

/* Starea vizibilă la scroll-up (Sticky) */
.site-header.header-sticky {
    transform: translateY(0);
    box-shadow: 0 4px 15px rgba(0, 0, 0, 0.05);
}

.header-container {
    display: flex;
    justify-content: space-between;
    align-items: flex-end;
    width: 100%;
}

.logo-wrapper {
    margin-right: auto; /* Forțează tot ce urmează să se ducă la dreapta ecranului */
    line-height: 0;
}

/* --- LOGO STYLING --- */
.logo-svg {
    width: 100%;
    height: auto;
    /* Folosim variabila de lățime din tokens.css */
    max-width: var(--logo-width);
    display: block;
}

/* Stiluri de bază pentru culorile logo-ului */
.logo-svg .svg-standard {
    fill: var(--color-brand-standard); /* #4E5153 */
    transition: fill var(--trans-base);
}

.logo-svg .svg-accent {
    fill: var(--color-brand-accent); /* #55B18F */
    transition: fill var(--trans-base);
}

/* --- LOGO STICKY BEHAVIOR (Desktop > 1040px) --- */
@media (min-width: 1040px) {
    /* Când header-ul primește clasa sticky, întreg logo-ul devine Gri */
    .site-header.header-sticky .logo-svg .svg-standard,
    .site-header.header-sticky .logo-svg .svg-accent {
        fill: #4E5153; /* Culoarea cerută la scroll-up */
    }
}

/* --- LOGICĂ MOBIL (< 1040px) --- */
@media (max-width: 1039px) {
    .site-header {
        background-color: var(--color-neutral);
        padding: 10px 0;
    }
    .site-header-hero{
        background-color: transparent;
    }
    .site-header.header-sticky {
        background-color: #FDFDFD;
    }
}

/* --- LOGICĂ DESKTOP (> 1040px) --- */
@media (min-width: 1040px) {
    .site-header.header-sticky {
        /*background-color: #55B18F;*/
        background-color: var(--color-brand-accent-deschis);
    }
    /* Schimbare culoare siglă pe desktop la scroll-up */
    .site-header.header-sticky .logo-svg {
        color: #4E5153; /* Sigla devine griul declarat */
    }
}

/* Blocare scroll pe body */
body.no-scroll {
    overflow: hidden !important;
    height: 100vh;
}

.mobil-copy{
    font-family: var(--font-main);
    font-size: var(--text-xs);
}

.mobil-anpc{
    margin-top: 30px;
}

.mobil-anpc ul{
    display: flex;
}

/* --- Butoane --- */

.btn-oferta1{
    color: #fdfdfd;
    background-color: var(--color-brand-standard);
    font-weight: var(--fw-bold);
}

.btn-cta1{
    display: inline-flex;
    /*margin-top: auto;*/
    align-self: flex-start;
    text-align: center;
    padding: var(--btn-pv) var(--btn-ph);
    border-radius: var(--btn-cta);
    font-weight: var(--fw-bold);
    font-size: var(--text-btn-cta);
    text-transform: uppercase;
    transition: all 0.3s ease;
    white-space: nowrap;
}

.icdeviz{
    width: 100px;
    height: auto;
    position: absolute;
    top: 0;
    left: 50%;
    transform: translate(-50%, -50%);
}

@media (min-width: 1040px){
    .icdeviz{
        width: 160px;
    }
}

.marginbottom{
    margin-bottom: var(--space-md);
}

.marginbottom2{
    margin-bottom: var(--space-lg);
}

.marginbottomsmall{
    margin-bottom: var(--space-sm);
}

.marginblockmd{
    margin-block: var(--space-sm);
}

.marginblocksmall{
    margin-block: var(--space-xs);
}

.marginblockxs{
    margin-block: var(--space-xs);
}

.margintopsmall{
    margin-top: var(--space-xs);
}

@media (min-width: 1040px){
    .marginbottom{
        margin-bottom: var(--space-md);
    }
    .marginblocksmall{
        margin-block: var(--space-sm);
    }
    .margintopsmall{
        margin-top: var(--space-sm);
    }
    .marginblockmd{
        margin-block: var(--space-md);
    }
    .marginbottomsmall{
        margin-bottom: var(--space-sm);
    }
}

/**
* LANDING-RENOVARE.CSS
* Viewport: 360px - 2560px
* Ratio: 1.25 (Major Third) - Rotunjit Superior
* Author: EVO Studio
*/

.head-oferta h1, 
.head-oferta2 h1, 
.oferta-proces h2, 
.oferta-servicii h2, 
.oferta-servicii-extra h2, 
.oferta-lucrari h2, 
.oferta-dece h2, 
.oferta-dece2 h2, 
.oferta-consultanta h2, 
.cere-deviz h2, 
.cere-deviz2 h2{
    font-family: var(--font-main);
    font-size: var(--title-lead);
    font-weight: var(--fw-regular);
    text-transform: uppercase;
}

.head-oferta h1 span, 
.head-oferta2 h1 span, 
.oferta-proces h2 span, 
.oferta-servicii h2 span, 
.oferta-servicii-extra h2 span, 
.oferta-lucrari h2 span, 
.oferta-dece h2 span, 
.oferta-dece2 h2 span, 
.oferta-consultanta h2 span, 
.cere-deviz h2 span, 
.cere-deviz2 h2 span, 
.info-santier h2 span{
    font-family: var(--font-title);
    font-weight: var(--fw-bold);
}

.head-oferta h2, 
.head-oferta2 h2, 
.oferta-consultanta h3, 
.cere-deviz h3, 
.cere-deviz2 h3, 
.info-santier h2{
    font-family: var(--font-main);
    font-size: var(--title-h2);
}

.head-oferta h2, 
.head-oferta2 h2, 
.oferta-consultanta h3, 
.cere-deviz h3, 
.cere-deviz2 h3{
    font-weight: var(--fw-extrabold);
}

.oferta-consultanta h3, 
.cere-deviz h3, 
.cere-deviz2 h3, 
.info-santier h2{
    text-transform: uppercase;
}

.oferta-consultanta h3{
    color: var(--color-brand-standard-inchis);
}

.head-oferta h2, 
.head-oferta2 h2{
    color: var(--color-brand-accent-inchis);
}

.head-oferta, .oferta-detalii, .oferta-proces, .oferta-servicii, .oferta-servicii-extra, .oferta-lucrari{
    padding-inline: var(--site-gutter);
    padding-block: var(--space-md);
}

.oferta-dece{
    padding-inline: var(--site-gutter);
    padding-top: var(--space-md);
    padding-bottom: var(--space-colab);
}

.head-oferta2{
    padding-inline: var(--site-gutter);
    /*padding-block: var(--space-xs);*/
}

.head-oferta-l {
    position: relative;
}

.head-oferta-l-i{
    display: flex;
    flex-direction: row;
    gap: 20px;
    align-items: center;
    margin-top: 15px;
    position: relative;
}

.oferta-cover{
    width: 30% !important;
    height: auto;
}

.head-oferta-l-i img {
    width: 40px;
    height: auto;
    display: block;
}

.oferta-trust h3{
    color: var(--color-brand-standard-inchis);
    font-family: var(--font-main);
    font-size: var(--text-btnul);
    font-weight: var(--fw-bold);
}

.oferta-trust h3 span{
    display: block;
    font-size: var(--text-md);
    margin-bottom: 4px;
}

.icserv{
    width: 56px;
    height: auto;
}

@media (min-width: 1040px){
    .head-oferta, .oferta-detalii, .oferta-proces, .oferta-servicii, .oferta-servicii-extra, .oferta-lucrari, .oferta-dece2, .oferta-consultanta, .info-santier{
        padding-block: var(--space-lg);
    }
    .oferta-dece{
        padding-top: var(--space-lg);
    }
    .head-oferta2{
        padding-block: var(--space-md);
    }
    .head-oferta, .head-oferta2{
        align-items: center;
        justify-content: space-between;
    }
    .head-oferta-l{
        justify-content: center;
        align-items: center;
    }
    .oferta-cover{
        width: 36% !important;
        height: auto;
    }
    .head-oferta-l-i{
        justify-content: center;
    }
    .head-oferta-l-i img {
        width: 90px;
        height: auto;
        display: block;
    }
    .icserv{
        width: auto;
        height: 70px;
    }
}

.buttons-container {
    pointer-events: auto;
    width: 100%;
    display: flex;
    flex-wrap: wrap;
    gap: 12px;
}

.btn-oferta1, .btn-pachete1 {
    display: inline-flex;
    justify-content: center;
    align-items: center;
    text-align: center;
    padding: var(--btn-pv) var(--btn-ph);
    border-radius: var(--btn-cta);
    font-weight: var(--fw-bold);
    font-size: var(--text-btn-cta);
    text-transform: uppercase;
    transition: all 0.3s ease;
    white-space: nowrap;
    flex: 1 1 auto;
}

.head-oferta .btn-oferta1, 
.head-oferta2 .btn-oferta1{
    color: #fdfdfd;
    background-color: var(--color-brand-standard);
}

.head-oferta .btn-pachete1, 
.head-oferta2 .btn-pachete1{
    color: var(--color-brand-accent-inchis);
}

@media (min-width: 1040px) {
    .buttons-container {
        flex-wrap: nowrap;
        width: fit-content;
        gap: 16px;
    }
}

.oferta-detalii{
    padding-inline: var(--site-gutter);
    padding-bottom: var(--space-md);
}

@media (min-width: 1040px){
    .oferta-detalii{
        padding-bottom: var(--space-lg);
    }
}

.lnk-servicii{
    color: var(--color-brand-standard-inchis);
    margin-top: var(--space-md);
    display: flex;
    align-items: center;
    font-weight: var(--fw-bold);
    font-size: var(--text-btn-cta);
}

.lnk-servicii span{
    width: 18px;
    height: auto;
    display: inline-flex;
    margin-right: 10px;
    transform-origin: center;
    transition: transform 0.4s cubic-bezier(0.4, 0, 0.2, 1);
}

.lnk-servicii:hover span{
    transform: rotate(180deg);
}

@media (min-width: 1040px){
    .lnk-servicii span{
        width: 24px;
    }
}

.oferta-proces{
    background-color: var(--color-bk-card);
}

.oferta-proces h2{
    color: var(--color-brand-standard-inchis);
}

.oferta-proces h2 span{
    color: var(--color-brand-accent-inchis);
}

.oferta-proces-grid{
    color: var(--color-brand-standard-inchis);
    font-size: var(--text-body);
    font-weight: var(--fw-bold);
    line-height: 1.4;
    letter-spacing: var(--ls-txt);
}

.oferta-proces-grid span{
    color: var(--color-brand-accent-inchis);
    font-size: var(--title-h4);
    font-weight: var(--fw-extrabold);
}

.oferta-proces .btn-oferta1{
    color: var(--color-bk-card);
    background-color: var(--color-brand-accent-inchis);
}

.oferta-proces .btn-pachete1{
    color: var(--color-brand-accent-inchis);
}

.oferta-servicii-extra, .oferta-dece, .oferta-dece2{
    background-color: var(--color-gri-deschis);
}

.oferta-servicii h2 span, 
.oferta-servicii h3,  
.oferta-lucrari h2 span{
    color: var(--color-brand-accent-inchis);
}

.oferta-servicii h3, 
.oferta-servicii-extra h3{
    font-size: var(--title-h4);
    font-weight: var(--fw-bold);
}

.oferta-servicii .btn-oferta1, 
.oferta-lucrari .btn-oferta1{
    color: #fdfdfd;
}

.oferta-lucrari .btn-pachete1{
    color: var(--color-brand-accent-inchis);
}

.oferta-servicii-extra h2{
    color: var(--color-brand-accent-inchis);
}

.oferta-servicii-extra h2 span, 
.oferta-servicii-extra h3, 
.oferta-servicii-extra .btn-pachete1{
    color: var(--color-brand-standard-inchis);
}

.oferta-servicii h3, 
.oferta-servicii-extra h3{
    margin-block: 15px;
}

@media (min-width: 1040px){
    .oferta-servicii h3, 
    .oferta-servicii-extra h3{
        margin-block: 20px;
    }
}

.oferta-servicii-extra .btn-oferta1{
    color: #f4f5f3;
    background-color: var(--color-brand-accent-inchis);
}

.grid-txt{
    font-size: var(--text-md);
    line-height: 1.4;
    letter-spacing: var(--ls-txt);
}

.oferta-pachete{
    display: grid;
    grid-template-columns: repeat(var(--grid-cols-main), 1fr);
    width: 100%;
}


.grid-pachete, .recomend {
    display: flex;
    flex-wrap: wrap;
    gap: 0;
    margin: 0;
    padding: 0;
}

.grid-pachete > *, .recomend > * {
    box-sizing: border-box;
    flex: 1 1 100%; 
}

@media (min-width: 1040px) {
    .grid-pachete > * {
        flex: 1 1 33.3333%;
    }
    .recomend > * {
        flex: 1 1 50%;
    }
}

.premium-card, .ideal-card, .optim-card{
    padding-inline: var(--site-gutter);
    padding-block: var(--space-sm);
    display: flex;
    flex-direction: column;
    height: 100%;
}

.premium-card h2, .ideal-card h2, .optim-card h2{
    font-family: var(--font-title);
    font-size: var(--title-h4);
    font-weight: var(--fw-bold);
    text-transform: uppercase;
}

.text-card{
    font-size: var(--text-md);
    line-height: 1.4;
    letter-spacing: var(--ls-txt);
    display: flex;
    flex-direction: column;
    flex-grow: 0;
    box-sizing: border-box;
}

.premium-card .icpac, 
.ideal-card .icpac, 
.optim-card .icpac{
    width: auto; 
    height: 16px;
    display: inline-block;
    vertical-align: middle;
    margin-right: 8px;
}

.premium-card{
    background-color: var(--color-premium-standard);
}

.premium-card h2{
    color: var(--color-premium-accent);
}

.premium-card .btn-card{
    color: var(--color-premium-standard);
    background-color: var(--color-premium-accent);
}

.premium-card ul li, 
.premium-card .icpac, 
.premium-card .text-card{
    color: var(--color-premium-text);
}

.ideal-card{
    background-color: #91e2c3;
}

.ideal-card h2{
    color: var(--color-ideal-accent);
}

.ideal-card ul li, 
.ideal-card .icpac,
.ideal-card .text-card{
    color: var(--color-ideal-accent);
}

.ideal-card .btn-card{
    color: #91e2c3;
    background-color: var(--color-ideal-accent);
}

.optim-card{
    background-color: #fff8f0;
}

.optim-card h2{
    color: var(--color-brand-accent-inchis);
}

.optim-card ul li, 
.optim-card .icpac,
.optim-card .text-card{
    color: var(--color-optim-text);
}

.optim-card .btn-card{
    color: #fff8f0;
    background-color: var(--color-brand-accent-inchis);
}

.icgarantie{
    display: flex;
    flex-direction: column;
    flex-grow: 0;
    box-sizing: border-box;
    align-items: flex-start;
}

.icgarantie img{
    width: auto;
    height: 40px;
}

.optiuni-card li:not(:last-child){
    margin-bottom: 12px;
}

@media (min-width: 1040px){
    .premium-card .icpac, 
    .ideal-card .icpac, 
    .optim-card .icpac{
        height: 20px;
        margin-right: 10px;
    }
    .optiuni-card li:not(:last-child){
        margin-bottom: 20px;
    }
    .icgarantie img{
        height: 60px;
    }
}

.btn-card{
    display: inline-flex;
    /*margin-top: auto;*/
    align-self: flex-start;
    text-align: center;
    padding: 10px 15px;
    border-radius: var(--btn-cta);
    font-weight: var(--fw-bold);
    font-size: var(--text-sm);
    text-transform: uppercase;
    transition: all 0.3s ease;
    white-space: nowrap;
    margin-bottom: 22px;
}

.oferta-dece h2, 
.oferta-dece2 h2{
    color: var(--color-brand-standard-inchis);
}

.oferta-dece h2 span, 
.oferta-dece2 h2 span{
    color: var(--color-brand-accent-inchis);
}

.oferta-dece .btn-cta1, 
.oferta-dece2 .btn-cta1{
    color: #f4f5f3;
    background-color: var(--color-brand-accent-inchis);
}

.oferta-consultanta, .oferta-dece2{
    padding-inline: var(--site-gutter);
    padding-top: var(--space-lg);
    padding-bottom: var(--space-colab);
}

.oferta-consultanta h2 span{
    color: var(--color-brand-accent);
}

.oferta-consultanta .btn-cta1{
    color: #fdfdfd;
    background-color: var(--color-brand-accent);
}

.consultanta-lnk{
    display: inline-flex;
    font-size: var(--text-sm);
    font-weight: var(--fw-extrabold);
    text-transform: uppercase;
    align-self: flex-start;
    white-space: nowrap;
}

.consultanta-lnk .svg-icon{
    color: var(--color-brand-accent-inchis);
}

.cere-deviz, .cere-deviz2{
    background-color: var(--color-brand-accent-deschis);
    display: flex;
    flex-direction: column;
    position: relative;
    padding-inline: var(--site-gutter);
    padding-top: var(--space-xlg);
}

.cere-deviz{
    padding-bottom: var(--space-lg);
}

.cere-deviz2{
    padding-bottom: var(--space-lg);
}

.cere-deviz h2, 
.cere-deviz2 h2, 
.cere-deviz h3, 
.cere-deviz2 h3{
    color: var(--color-brand-standard-inchis);
}

.deviz-contact{
    display: flex;
    flex-direction: row;
    width: 100%;
    gap: 30px;
}

.deviz-contact a{
    color: var(--color-brand-standard-inchis);
    display: inline-flex;
    align-self: center;
    justify-self: center;
    gap: 10px;
    font-size: var(--text-body);
    font-weight: var(--fw-extrabold);
}

.deviz-contact a img{
    width: auto;
    height: 18px;
}

@media (min-width: 1040px){
    .deviz-contact a img{
        height: 24px;
    }
}

.estimator .btn-cta1{
    color: var(--color-brand-accent-deschis);
    background-color: var(--color-brand-standard-inchis);
}

@media (max-width: 1039px){
    .estimator .btn-cta1{
        margin-top: 30px;
    }    
}

.form-oferta{
    background-color: var(--color-gri-deschis);
    border-radius: 10px;
    padding: 20px 10px;
}

.info-santier{
    background-color: #fbd26c;
    padding-inline: var(--site-gutter);
    padding-top: var(--space-lg);
    padding-bottom: var(--space-colab);
}

.info-santier h2{
    color: var(--color-brand-standard-inchis);
    display: flex;
    align-items: flex-start;
}

.info-santier .content-text-simple{
    margin-top: 24px;
    margin-bottom: 30px;
}

.info-santier .btn-cta1{
    color: #fbd26c;
    background-color: var(--color-brand-standard-inchis);
}

@media(max-width: 1039px){
    .head-oferta .buttons-container{
        margin-top: var(--space-xs);
    }
    .extrabottom{
        margin-bottom: var(--space-md);
    }
}

.slider-galerie-wrapper{
    position: relative;
    padding-left: 15px;   /* Spațiu pentru săgeata stânga */
    padding-right: 15px;  /* Spațiu pentru săgeata dreapta */
}

.swiper-galerie {
    width: 100%;
    overflow: hidden; 
    padding-left: 0 !important;
    padding-right: 0 !important;
}

.swiper-wrapper{
    padding-left: 0px !important;
}

.swiper-slide {
    height: auto !important; 
    display: flex;
}

.swiper-button-next, .swiper-button-prev {
    color: var(--color-brand-standard) !important;
}

.swiper-button-prev, 
.swiper-button-next {
    width: 10px !important;  /* Lățimea reală a săgeții (fără spațiu gol) */
    height: 20px !important; /* Înălțimea proporțională */
    background: none !important;
    display: flex !important;
    align-items: center;
}

.swiper-button-prev svg, 
.swiper-button-next svg {
    width: 100% !important;
    height: 100% !important;
    display: block;
}

.swiper-button-prev {
    left: 0 !important;
}

.swiper-button-next {
    right: 0 !important;
}

@media (min-width: 1040px) {
    .slider-galerie-wrapper{
        padding-left: 30px;
        padding-right: 30px;
    }
    .swiper-button-prev, 
    .swiper-button-next {
        width: 14px !important;
        height: 28px !important;
    }
}

.svg-icon {
    width: auto;
    height: 16px;
    /*color: #55B18F;*/
    transition: color 0.3s ease;
    display: inline-flex;
    align-self: center;
    margin-right: 10px;
}

.lottie-card{
    position: relative;
}

.lottie-placeholder, 
.lottie-placeholder2{
    max-width: 100px;
    height: auto;
    display: block;
    opacity: 1;
    transition: opacity 0.8s ease-in-out; 
    z-index: 1;
}

.lottie-target2 {
    position: absolute;
    top: 0;
    left: 0;
    width: 100px;
    height: auto;
    display: flex;
    justify-content: inherit; 
    align-items: center;
    z-index: 2;
    pointer-events: none;
}

.js-lottie-wrapper.is-loaded .lottie-placeholder, 
.js-lottie-wrapper.is-loaded .lottie-placeholder2{
    opacity: 0;
}

@media (min-width: 1040px){
    .lottie-placeholder {
        max-width: 300px;
    }
    .lottie-placeholder2, .lottie-placeholder-consultanta {
        max-width: 130px;
    }
    .lottie-target2{
        width: auto;
        height: 100%;
    }
}

/* Forțăm galeria și fundalul ei să stea peste absolut orice element din site */
.lg-backdrop {
    z-index: 20000 !important;
}

.lg-outer {
    z-index: 20001 !important;
}

/* Formularistica - formular contact */
.wpcf7 label, .wpcf7 ::placeholder{
	color:#3D4042;
	opacity: 1;
	text-transform:uppercase;
	display:block;
  font-weight: 500;
}

.wpcf7-text, .wpcf7 select{
	border: 1.5px solid #3D4042;
	border-top: none !important;
	border-left: none !important;
	border-right: none !important;
	width: 100%;
	height:50px;
	color:#3D4042;
	background:#f0f0f0;
	margin-top:5px;
	margin-bottom:25px;
	transition:all 300ms ease;
    box-sizing: border-box;
    padding: 8px 8px;
}

.wpcf7 select{
  width: 100%;
  height: 50px;
  /*background-image: url("data:image/svg+xml;utf8,<svg fill='white' height='24' viewBox='0 0 24 24' width='24' xmlns='http://www.w3.org/2000/svg'><path d='M7 10l5 5 5-5z'/><path d='M0 0h24v24H0z' fill='none'/></svg>");*/
  /*
  background-image: url("../img/arrow-d.svg");
  background-repeat: no-repeat;
  background-position-x: 100%;
  background-position-y: 5px;
  background-size: 20px 20px;
  */
  outline: none;
  /*
  border-radius: 2px;
  margin-right: 2rem;
  padding: 1rem;
  padding-right: 2rem;
  */
}

.wpcf7 select:focus{
	outline: none;
}

.wpcf7 select::after{
	content: 'p';
	display: block;
	position: absolute;
	width: 15px;
	height: 15px;
	background: #ff0000;
	left: 0;
	bottom: 0;
}

input:focus, textarea:focus{
	border-bottom: 2px solid #59b18f;
	outline: none;
}

.wpcf7-date{
	border-bottom: 1.5px solid #3D4042 !important;
	color:#3D4042 !important;
	background:#f0f0f0;
	border:none;
	width:100%;
	height:50px;
	margin-top:5px;
	margin-bottom:35px;
	padding:10px;
}

.wpcf7-list-item{
	display:block;
	width:100%;
	margin-left:0px !important;
	font-weight:200;
	margin-bottom:10px !important;
}

.checkbox-754, .check-servicii{
	margin-bottom:35px !important;
	display:block;
}

.wpcf7-list-item-label{
	font-weight:400;
}

.wpcf7-textarea{
	border: 1.5px solid #3D4042;
	border-top: none !important;
	border-left: none !important;
	border-right: none !important;
	width:100%;
	height:100px;
	resize:vertical;
	color:#3D4042;
	background:#f0f0f0;
	margin-bottom:15px;
	padding-top:10px;
	font-weight:200;
	transition:all 300ms ease;
    box-sizing: border-box;
    padding: 8px 8px;
}

.wpcf7-submit{
	color: #F0F0F0;
	font-weight: 600;
	text-decoration: none;
	background:#3D4042;
	border: none;
  outline: none;
	transition:all 300ms ease;
	display: table;
	position: relative;
  width: 100%;
  padding: 15px 0px;
  border-radius: 10px;
  text-transform: uppercase;
  letter-spacing: 1px;
	}


.wpcf7-submit:hover{
	background:#000;
	text-decoration: none;
}

.wpcf7-not-valid{
	border:1px solid #ff0000;
	margin-bottom:0px;
  box-sizing: border-box;
}

.wpcf7-not-valid-tip, .nf-error-required-error{
	background:#ff0000;
	color:#fff !important;
	font-weight:400;
	font-size:12px !important;
	padding:15px;
	width:100%;
  box-sizing: border-box;
}

/* =========================================================
   STILIZARE CHECKBOX ACORD (.facord) - Identic cu CF7 List
   ========================================================= */

/* 1. Containerul principal pentru acord */
.facord {
  display: block !important;
  position: relative !important;
  margin-bottom: 35px;
  cursor: pointer;
  width: 100% !important;
  font-size: 12px !important;
  text-transform: none !important;
  font-weight: 300 !important;
  user-select: none;
  -webkit-user-select: none;
  -moz-user-select: none;
  -ms-user-select: none;
  min-height: 18px; /* Asigură înălțimea minimă pentru casetă */
}

/* 2. Ascunde inputul original al browserului */
.facord input[type="checkbox"] {
  position: absolute !important;
  opacity: 0 !important;
  cursor: pointer !important;
  height: 0 !important;
  width: 0 !important;
  margin: 0 !important;
}

/* 3. Textul acordului (facem loc casetei în stânga) */
.facord .acord-text,
.facord .ftxt {
  display: inline-block;
  padding-left: 28px !important; /* 16px caseta + 12px spațiu */
  line-height: 18px; /* Aliniază perfect textul cu caseta */
  margin-top: 0 !important;
  margin-left: 0 !important; /* Resetează vechiul margin ca să prevină decalajele */
  vertical-align: top;
}

/* 4. Caseta custom */
.facord .checkmark-contact {
  position: absolute;
  left: 0;
  top: 0; /* Aliniată sus cu textul */
  width: 16px;
  height: 16px;
  border: 1.5px solid #3d4042;
  background-color: #f0f0f0;
  border-radius: 0;
  box-sizing: border-box;
  transition: background-color 0.15s ease-in-out, border-color 0.15s ease-in-out;
  z-index: 1;
}

/* 5. Bifa (ascunsă inițial folosind opacity pentru o tranziție lină) */
.facord .checkmark-contact::after {
  content: "";
  position: absolute;
  left: 5px;
  top: 2px;
  width: 4px;
  height: 8px;
  border: solid #3d4042;
  border-width: 0 1.5px 1.5px 0;
  transform: rotate(45deg);
  opacity: 0; /* Invizibilă inițial */
  transition: opacity 0.15s ease-in-out;
}

/* 6. Afișează bifa când checkbox-ul este selectat */
.facord input[type="checkbox"]:checked ~ .checkmark-contact::after {
  opacity: 1; /* Afișează bifa vizual */
}

/* 7. (Opțional) Efect de hover doar pe casetă pentru o experiență mai bună */
.facord:hover .checkmark-contact {
  background-color: #e8e8e8;
}

/* Curățare clase inutile (pentru elemente care nu mai au nevoie de display separat) */
.acord {
  vertical-align: middle;
}
.facord .wpcf7-list-item {
  width: auto !important;
  margin: 0 !important;
}

.form-note{
    font-size:12px;
    margin-bottom:30px;
}

.boxuri{
    width:100%;
    display:block;
    margin-top:35px;
    margin-bottom:35px;
}

.wpcf7 label, .wpcf7 ::placeholder{
    font-size: 12px;
    line-height: 1.8;
    margin-top:35px;
  }
  .wpcf7-text, .wpcf7 select, .wpcf7-date, .wpcf7 select, .wpcf7-list-item, .wpcf7-list-item-label, .wpcf7-textarea{
    font-size:12px;
  }
  .checkmark-contact{
    height: 10px;
    width: 10px;
  }
  
  /* 1. Container pentru fiecare item (checkbox + label) */
.wpcf7-form .wpcf7-list-item {
  display: block; /* Afișează fiecare checkbox pe rândul său */
  margin-bottom: 10px; /* Spațiu între checkbox-uri */
  position: relative; /* Necesar pentru poziționarea elementelor ::before și ::after */
}

/* 2. Stilizează label-ul pentru a permite click */
.wpcf7-form .wpcf7-list-item label {
  display: inline-flex; /* Aliniază textul cu caseta custom */
  align-items: center;
  cursor: pointer;
  position: relative; /* Necesar dacă inputul este în interior */
  user-select: none; /* Previne selectarea textului la click */
  min-height: 18px; /* Asigură o înălțime minimă */
}

/* 3. Ascunde checkbox-ul original al browserului */
.wpcf7-form .wpcf7-list-item input[type="checkbox"] {
  position: absolute; /* Scoate din flux */
  opacity: 0; /* Fă-l invizibil */
  cursor: pointer;
  height: 0;
  width: 0;
  margin: 0; /* Elimină orice spațiu ocupat */
}

/* 4. Span-ul care conține textul label-ului - aici vom atașa stilul custom */
.wpcf7-form .wpcf7-list-item .wpcf7-list-item-label {
  display: inline-block; /* Comportament de bloc în linie */
  padding-left: 28px; /* Spațiu la stânga pentru caseta custom (18px + 10px padding) */
  position: relative; /* Necesar pentru ::before și ::after */
  line-height: 18px; /* Aliniază vertical cu caseta */
}

/* 5. Creează caseta custom (înainte de textul label-ului) */
.wpcf7-form .wpcf7-list-item .wpcf7-list-item-label::before {
  content: ''; /* Obligatoriu pentru pseudo-elemente */
  position: absolute;
  left: 0; /* Poziționează la început */
  top: 0; /* Aliniază cu partea de sus a textului */
  width: 16px; /* Lățimea casetei */
  height: 16px; /* Înălțimea casetei */
  border: 1.5px solid #3d4042; /* Border conform cerinței */
  background-color: #f0f0f0; /* Background conform cerinței */
  border-radius: 0; /* Fără colțuri rotunjite */
  box-sizing: border-box; /* Include border-ul în dimensiuni */
  transition: background-color 0.15s ease-in-out, border-color 0.15s ease-in-out; /* Tranziție fină */
}

/* 6. Creează bifa (ascunsă inițial) */
.wpcf7-form .wpcf7-list-item .wpcf7-list-item-label::after {
  content: '';
  position: absolute;
  left: 5px; /* Poziționare orizontală în interiorul casetei */
  top: 2px;  /* Poziționare verticală în interiorul casetei */
  width: 4px;
  height: 8px;
  border: solid #3d4042; /* Culoarea bifei (aceeași cu border-ul) */
  border-width: 0 1.5px 1.5px 0; /* Creează forma bifei */
  transform: rotate(45deg); /* Rotește pentru a forma bifa */
  opacity: 0; /* Ascunde bifa inițial */
  transition: opacity 0.15s ease-in-out; /* Tranziție fină */
}

/* 7. Afișează bifa când checkbox-ul (input-ul ascuns precedent) este bifat */
.wpcf7-form .wpcf7-list-item input[type="checkbox"]:checked + .wpcf7-list-item-label::after {
  opacity: 1; /* Afișează bifa */
}

/* 8. (Opțional) Adaugă un stil de focus pentru accesibilitate */
.wpcf7-form .wpcf7-list-item input[type="checkbox"]:focus + .wpcf7-list-item-label::before {
  outline: none;
}

@media (min-width: 1040px){
	.form-container{
    padding: 0px 50px;
    background-image: url('../img/oferta-d.jpg');
    background-position:center;
  }
  .wpcf7 label, .wpcf7 ::placeholder{
    font-size: 14px;
    line-height: 1.5;
  }
  .wpcf7-text, .wpcf7 select, .wpcf7-date, .wpcf7 select, .wpcf7-list-item, .wpcf7-list-item-label, .wpcf7-textarea{
    font-size:14px;
  }
  .checkmark-contact{
    height: 13px;
    width: 13px;
  }
}

.recap{
    display:block;
    width:100%;
    float:left;
    margin-bottom:30px;
}