:root {
  --color-cream: #faf6f0;
  --color-warm-white: #fff9f2;
  --color-parchment: #f2ead8;
  --color-caramel: #c8956a;
  --color-caramel-dark: #a97348;
  --color-bark: #6b4c2a;
  --color-bark-light: #8c6540;
  --color-sage: #7a8c6a;
  --color-sage-light: #a3b890;
  --color-text: #2e1f0e;
  --color-text-muted: #7a6555;
  --color-text-light: #a89080;
  --color-border: #e0d5c5;
  --color-polaroid-bg: #fffdf8;
  --color-accent: #c8956a;
  --color-accent-hover: #a97348;

  --shadow-polaroid: 0 4px 8px rgba(46,31,14,0.08), 0 12px 32px rgba(46,31,14,0.12), 0 2px 4px rgba(46,31,14,0.06);
  --shadow-card: 0 2px 8px rgba(46,31,14,0.06), 0 8px 24px rgba(46,31,14,0.09);
  --shadow-nav: 0 2px 16px rgba(46,31,14,0.10);
  --shadow-btn: 0 4px 16px rgba(200,149,106,0.30);

  --radius-sm: 4px;
  --radius-md: 10px;
  --radius-lg: 18px;
  --radius-xl: 28px;

  --space-xs: 0.5rem;
  --space-sm: 1rem;
  --space-md: 2rem;
  --space-lg: 4rem;
  --space-xl: 7rem;

  --font-hand: 'Caveat', cursive;
  --font-body: 'Rubik', sans-serif;

  --transition-fast: 0.18s ease;
  --transition-med: 0.32s ease;
  --transition-slow: 0.55s cubic-bezier(0.22, 1, 0.36, 1);
}

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

html {
  scroll-behavior: smooth;
  font-size: 16px;
}

body {
  font-family: var(--font-body);
  background-color: var(--color-cream);
  color: var(--color-text);
  line-height: 1.7;
  overflow-x: hidden;
}

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

a {
  color: var(--color-caramel);
  text-decoration: none;
  transition: color var(--transition-fast);

  &:hover {
    color: var(--color-caramel-dark);
  }
}

ul { list-style: none; }

.c-page-wrapper {
  transition: transform var(--transition-slow);
  transform-origin: left center;
  min-height: 100vh;
  display: flex;
  flex-direction: column;
}

.u-label {
  display: inline-block;
  font-family: var(--font-hand);
  font-size: 1.15rem;
  color: var(--color-caramel);
  letter-spacing: 0.03em;
  margin-bottom: 0.5rem;
}

.u-text-center { text-align: center; }
.u-hidden { display: none !important; }

.c-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 0.5rem;
  padding: 0.85rem 2rem;
  border-radius: 50px;
  font-family: var(--font-body);
  font-size: 0.95rem;
  font-weight: 500;
  cursor: pointer;
  border: 2px solid transparent;
  transition: background var(--transition-fast), color var(--transition-fast), box-shadow var(--transition-fast), transform var(--transition-fast);
  text-decoration: none;
  white-space: nowrap;

  &:hover {
    transform: translateY(-2px);
  }

  &--primary {
    background: var(--color-caramel);
    color: #fff;
    border-color: var(--color-caramel);
    box-shadow: var(--shadow-btn);

    &:hover {
      background: var(--color-caramel-dark);
      border-color: var(--color-caramel-dark);
      color: #fff;
      box-shadow: 0 6px 24px rgba(200,149,106,0.40);
    }
  }

  &--ghost {
    background: transparent;
    color: var(--color-bark);
    border-color: var(--color-bark);

    &:hover {
      background: var(--color-bark);
      color: #fff;
    }
  }

  &--outline {
    background: transparent;
    color: var(--color-caramel);
    border-color: var(--color-caramel);

    &:hover {
      background: var(--color-caramel);
      color: #fff;
    }
  }

  &--sm {
    padding: 0.55rem 1.3rem;
    font-size: 0.88rem;
  }

  &--full {
    width: 100%;
  }
}

.c-polaroid {
  background: var(--color-polaroid-bg);
  padding: 14px 14px 40px 14px;
  box-shadow: var(--shadow-polaroid);
  border-radius: var(--radius-sm);
  display: inline-block;
  position: relative;
  transition: transform var(--transition-med), box-shadow var(--transition-med);

  & img {
    width: 100%;
    height: 220px;
    object-fit: cover;
    display: block;
    filter: sepia(12%) saturate(110%) brightness(0.97);
    transition: filter var(--transition-med);
  }

  &:hover {
    transform: rotate(0deg) scale(1.03) !important;
    box-shadow: 0 8px 24px rgba(46,31,14,0.16), 0 24px 48px rgba(46,31,14,0.14);

    & img {
      filter: sepia(0%) saturate(120%) brightness(1.02);
    }
  }

  &__caption {
    font-family: var(--font-hand);
    font-size: 1.05rem;
    color: var(--color-text-muted);
    position: absolute;
    bottom: 10px;
    left: 0;
    right: 0;
    text-align: center;
  }

  &--rotated-left {
    transform: rotate(-3deg);
  }

  &--rotated-right {
    transform: rotate(2.5deg);
  }

  &--slide {
    transform: rotate(-1.5deg);
    width: 100%;

    & img {
      height: 260px;
    }
  }
}

.c-nav {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  z-index: 900;
  transition: background var(--transition-med), box-shadow var(--transition-med);
  padding: 0;

  &__inner {
    max-width: 1200px;
    margin: 0 auto;
    padding: 1.2rem 2rem;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 2rem;
  }

  &__logo-img {
    height: 44px;
    width: auto;
  }

  &__links {
    display: flex;
    align-items: center;
    gap: 0.25rem;
  }

  &__link {
    padding: 0.5rem 0.9rem;
    color: var(--color-cream);
    font-size: 0.92rem;
    font-weight: 500;
    border-radius: 50px;
    transition: background var(--transition-fast), color var(--transition-fast);
    text-decoration: none;

    &:hover {
      background: rgba(255,255,255,0.15);
      color: #fff;
    }
  }

  &__hamburger {
    display: none;
    flex-direction: column;
    gap: 5px;
    background: none;
    border: none;
    cursor: pointer;
    padding: 8px;
    border-radius: var(--radius-sm);

    & span {
      display: block;
      width: 26px;
      height: 2px;
      background: var(--color-cream);
      border-radius: 2px;
      transition: background var(--transition-fast);
    }
  }

  &.is-scrolled {
    background: var(--color-polaroid-bg);
    box-shadow: var(--shadow-nav);

    .c-nav__link {
      color: var(--color-text);

      &:hover {
        background: var(--color-parchment);
        color: var(--color-caramel);
      }
    }

    .c-nav__hamburger span {
      background: var(--color-text);
    }
  }
}

.c-mobile-menu {
  position: fixed;
  top: 0;
  right: 0;
  width: 300px;
  height: 100%;
  background: var(--color-warm-white);
  z-index: 1000;
  transform: translateX(100%);
  transition: transform var(--transition-slow);
  padding: 2rem 1.5rem;
  display: flex;
  flex-direction: column;
  gap: 2rem;
  box-shadow: -8px 0 32px rgba(46,31,14,0.15);

  &.is-active {
    transform: translateX(0);
  }

  &__close {
    align-self: flex-end;
    background: none;
    border: none;
    font-size: 1.4rem;
    color: var(--color-text-muted);
    cursor: pointer;
    padding: 8px;
    transition: color var(--transition-fast);

    &:hover {
      color: var(--color-caramel);
    }
  }

  &__links {
    display: flex;
    flex-direction: column;
    gap: 0.25rem;
  }

  &__link {
    display: block;
    padding: 0.9rem 1rem;
    color: var(--color-text);
    font-size: 1.1rem;
    font-weight: 500;
    border-radius: var(--radius-md);
    text-decoration: none;
    transition: background var(--transition-fast), color var(--transition-fast);

    &:hover {
      background: var(--color-parchment);
      color: var(--color-caramel);
    }
  }

  &__contact {
    display: flex;
    flex-direction: column;
    gap: 0.75rem;
    margin-top: auto;

    & a {
      display: flex;
      align-items: center;
      gap: 0.6rem;
      color: var(--color-text-muted);
      font-size: 0.9rem;
      text-decoration: none;
      transition: color var(--transition-fast);

      &:hover {
        color: var(--color-caramel);
      }

      & i {
        color: var(--color-caramel);
        width: 16px;
      }
    }
  }
}

.c-overlay {
  position: fixed;
  inset: 0;
  background: rgba(46,31,14,0.35);
  z-index: 999;
  opacity: 0;
  pointer-events: none;
  transition: opacity var(--transition-med);

  &.is-active {
    opacity: 1;
    pointer-events: all;
  }
}

.s-hero {
  min-height: 100vh;
  background: linear-gradient(145deg, #3d2610 0%, #6b4c2a 40%, #8c6540 70%, #c8956a 100%);
  position: relative;
  display: flex;
  align-items: center;
  overflow: hidden;
  padding: 7rem 2rem 5rem;

  &::before {
    content: '';
    position: absolute;
    inset: 0;
    background: url("data:image/svg+xml,%3Csvg width='60' height='60' viewBox='0 0 60 60' xmlns='http://www.w3.org/2000/svg'%3E%3Cg fill='none' fill-rule='evenodd'%3E%3Cg fill='%23ffffff' fill-opacity='0.03'%3E%3Cpath d='M36 34v-4h-2v4h-4v2h4v4h2v-4h4v-2h-4zm0-30V0h-2v4h-4v2h4v4h2V6h4V4h-4zM6 34v-4H4v4H0v2h4v4h2v-4h4v-2H6zM6 4V0H4v4H0v2h4v4h2V6h4V4H6z'/%3E%3C/g%3E%3C/g%3E%3C/svg%3E");
    pointer-events: none;
  }

  &__canvas {
    position: absolute;
    inset: 0;
    pointer-events: none;
  }

  &__polaroid {
    position: absolute;

    &--1 {
      top: 12%;
      right: 8%;
      width: 220px;
      transform: rotate(4deg);
      opacity: 0.92;
    }

    &--2 {
      bottom: 10%;
      right: 22%;
      width: 200px;
      transform: rotate(-3deg);
      opacity: 0.85;
    }

    &--3 {
      top: 55%;
      right: 5%;
      width: 180px;
      transform: rotate(2deg);
      opacity: 0.78;
    }
  }

  &__content {
    position: relative;
    z-index: 2;
    max-width: 620px;
  }

  &__eyebrow {
    font-family: var(--font-hand);
    font-size: 1.2rem;
    color: rgba(255,255,255,0.75);
    margin-bottom: 1rem;
  }

  &__title {
    font-size: clamp(2.2rem, 5vw, 4rem);
    font-weight: 700;
    color: #fff;
    line-height: 1.15;
    margin-bottom: 1.5rem;
    text-shadow: 0 2px 16px rgba(46,31,14,0.25);
  }

  &__subtitle {
    font-size: clamp(1rem, 2vw, 1.15rem);
    color: rgba(255,255,255,0.85);
    max-width: 520px;
    margin-bottom: 2.5rem;
    line-height: 1.75;
  }

  &__actions {
    display: flex;
    gap: 1rem;
    flex-wrap: wrap;
  }
}

.s-despre {
  padding: var(--space-xl) var(--space-md);

  &__island {
    max-width: 1100px;
    margin: 0 auto;
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 5rem;
    align-items: center;
  }

  &__text {
    & h2 {
      font-size: clamp(1.8rem, 3.5vw, 2.8rem);
      font-weight: 700;
      color: var(--color-bark);
      margin-bottom: 1.5rem;
      line-height: 1.2;
    }

    & p {
      color: var(--color-text-muted);
      margin-bottom: 1.1rem;
      font-size: 1.02rem;
      line-height: 1.8;

      &:last-child { margin-bottom: 0; }
    }
  }

  &__visual {
    display: flex;
    justify-content: center;
    align-items: center;
    padding: 2rem;

    & .c-polaroid {
      width: 100%;
      max-width: 360px;

      & img {
        height: 300px;
      }
    }
  }
}

.s-servicii {
  padding: var(--space-xl) var(--space-md);
  background: var(--color-parchment);
  position: relative;

  &::before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    height: 3px;
    background: linear-gradient(90deg, transparent, var(--color-caramel), transparent);
  }

  &__header {
    max-width: 700px;
    margin: 0 auto 4rem;
    text-align: center;

    & h2 {
      font-size: clamp(1.8rem, 3.5vw, 2.6rem);
      font-weight: 700;
      color: var(--color-bark);
      margin-bottom: 1rem;
    }
  }

  &__intro {
    color: var(--color-text-muted);
    font-size: 1.05rem;
    line-height: 1.75;
  }

  &__features {
    max-width: 1100px;
    margin: 0 auto;
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 0 4rem;
  }

  &__col {
    display: flex;
    flex-direction: column;
    gap: 0;
  }
}

.c-feature {
  display: flex;
  gap: 1.25rem;
  padding: 1.75rem 0;
  border-bottom: 1px solid var(--color-border);

  &:last-child {
    border-bottom: none;
  }

  &__icon {
    flex-shrink: 0;
    width: 48px;
    height: 48px;
    background: var(--color-warm-white);
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    color: var(--color-caramel);
    font-size: 1.1rem;
    box-shadow: var(--shadow-card);
    transition: background var(--transition-fast), color var(--transition-fast);
  }

  &:hover .c-feature__icon {
    background: var(--color-caramel);
    color: #fff;
  }

  &__body {
    & h3 {
      font-size: 1.05rem;
      font-weight: 600;
      color: var(--color-bark);
      margin-bottom: 0.4rem;
    }

    & p {
      font-size: 0.93rem;
      color: var(--color-text-muted);
      line-height: 1.7;
    }
  }
}

.s-galerie {
  padding: var(--space-xl) var(--space-md);

  &__header {
    max-width: 600px;
    margin: 0 auto 3rem;
    text-align: center;

    & h2 {
      font-size: clamp(1.6rem, 3vw, 2.4rem);
      font-weight: 700;
      color: var(--color-bark);
      margin-bottom: 0.5rem;
    }
  }

  &__swiper {
    max-width: 1200px;
    margin: 0 auto;
    padding: 1rem 1rem 4rem;
  }
}

.swiper-pagination-bullet {
  background: var(--color-caramel) !important;
  opacity: 0.4;
}

.swiper-pagination-bullet-active {
  opacity: 1 !important;
}

.swiper-button-next,
.swiper-button-prev {
  color: var(--color-caramel) !important;

  &::after {
    font-size: 1.2rem !important;
  }
}

.s-proces {
  padding: var(--space-xl) var(--space-md);
  background: var(--color-warm-white);

  &__header {
    max-width: 680px;
    margin: 0 auto 4rem;
    text-align: center;

    & h2 {
      font-size: clamp(1.8rem, 3.5vw, 2.6rem);
      font-weight: 700;
      color: var(--color-bark);
      margin-bottom: 1rem;
    }

    & p {
      color: var(--color-text-muted);
      font-size: 1.05rem;
    }
  }

  &__flow {
    max-width: 1100px;
    margin: 0 auto;
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 1.5rem;
    align-items: start;
  }
}

.c-step {
  position: relative;
  background: var(--color-cream);
  border-radius: var(--radius-lg);
  padding: 2rem 1.5rem;
  box-shadow: var(--shadow-card);
  border: 1px solid var(--color-border);
  transition: transform var(--transition-med), box-shadow var(--transition-med);

  &:hover {
    transform: translateY(-4px);
    box-shadow: 0 8px 32px rgba(46,31,14,0.12);
  }

  &__number {
    font-family: var(--font-hand);
    font-size: 2.5rem;
    font-weight: 600;
    color: var(--color-caramel);
    line-height: 1;
    margin-bottom: 1rem;
  }

  &__content {
    & h3 {
      font-size: 1.05rem;
      font-weight: 600;
      color: var(--color-bark);
      margin-bottom: 0.6rem;
    }

    & p {
      font-size: 0.91rem;
      color: var(--color-text-muted);
      line-height: 1.7;
    }
  }

  &__arrow {
    display: none;
  }
}

.s-pachete {
  padding: var(--space-xl) var(--space-md);

  &__header {
    max-width: 680px;
    margin: 0 auto 3.5rem;
    text-align: center;

    & h2 {
      font-size: clamp(1.8rem, 3.5vw, 2.6rem);
      font-weight: 700;
      color: var(--color-bark);
      margin-bottom: 1rem;
    }

    & p {
      color: var(--color-text-muted);
      font-size: 1.05rem;
    }
  }

  &__table-wrap {
    max-width: 1000px;
    margin: 0 auto;
    overflow-x: auto;
    border-radius: var(--radius-lg);
    box-shadow: var(--shadow-card);
  }
}

.c-table {
  width: 100%;
  border-collapse: collapse;
  background: var(--color-warm-white);
  border-radius: var(--radius-lg);
  overflow: hidden;

  & th, & td {
    padding: 1.1rem 1.5rem;
    text-align: center;
    font-size: 0.95rem;
    border-bottom: 1px solid var(--color-border);
  }

  & th {
    background: var(--color-parchment);
    font-weight: 600;
    color: var(--color-bark);
    font-size: 1rem;
  }

  &__feature-col {
    text-align: left !important;
    font-weight: 600;
    color: var(--color-text) !important;
    background: var(--color-parchment) !important;
  }

  & td:first-child {
    text-align: left;
    color: var(--color-text-muted);
    font-size: 0.92rem;
  }

  & tr:last-child td {
    border-bottom: none;
  }

  & tr:hover td {
    background: rgba(200,149,106,0.04);
  }

  &__recommended {
    background: rgba(200,149,106,0.08) !important;
    position: relative;
  }

  &__badge {
    display: inline-block;
    background: var(--color-caramel);
    color: #fff;
    font-size: 0.7rem;
    font-weight: 600;
    padding: 0.2rem 0.6rem;
    border-radius: 50px;
    margin-bottom: 0.4rem;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    display: block;
    margin-bottom: 0.3rem;
  }

  &__check {
    color: var(--color-sage);
    font-size: 1rem;
  }

  &__minus {
    color: var(--color-border);
    font-size: 1rem;
  }

  &__cta-row td {
    padding-top: 1.5rem;
    padding-bottom: 1.5rem;
  }
}

.s-banner {
  padding: var(--space-xl) var(--space-md);
  background: linear-gradient(135deg, #3d2610 0%, #6b4c2a 100%);
  position: relative;
  overflow: hidden;

  &::before {
    content: '';
    position: absolute;
    inset: 0;
    background: url("data:image/svg+xml,%3Csvg width='80' height='80' viewBox='0 0 80 80' xmlns='http://www.w3.org/2000/svg'%3E%3Cg fill='%23ffffff' fill-opacity='0.03'%3E%3Ccircle cx='40' cy='40' r='30'/%3E%3C/g%3E%3C/svg%3E");
    pointer-events: none;
  }

  &__inner {
    max-width: 1100px;
    margin: 0 auto;
    display: grid;
    grid-template-columns: auto 1fr;
    gap: 5rem;
    align-items: center;
    position: relative;
    z-index: 1;
  }

  &__polaroid {
    & .c-polaroid {
      width: 260px;

      & img {
        height: 240px;
      }
    }
  }

  &__text {
    & h2 {
      font-size: clamp(1.8rem, 3.5vw, 2.8rem);
      font-weight: 700;
      color: #fff;
      margin-bottom: 1.25rem;
      line-height: 1.2;
    }

    & p {
      color: rgba(255,255,255,0.8);
      font-size: 1.05rem;
      line-height: 1.8;
      margin-bottom: 2rem;
      max-width: 520px;
    }
  }
}

.s-contact {
  padding: var(--space-xl) var(--space-md);
  background: var(--color-parchment);

  &__header {
    max-width: 680px;
    margin: 0 auto 3.5rem;
    text-align: center;

    & h2 {
      font-size: clamp(1.8rem, 3.5vw, 2.6rem);
      font-weight: 700;
      color: var(--color-bark);
      margin-bottom: 1rem;
    }

    & p {
      color: var(--color-text-muted);
      font-size: 1.05rem;
    }
  }

  &__body {
    max-width: 1100px;
    margin: 0 auto 3rem;
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 3rem;
    background: var(--color-warm-white);
    border-radius: var(--radius-xl);
    overflow: hidden;
    box-shadow: var(--shadow-card);
  }

  &__map {
    min-height: 500px;

    & iframe {
      width: 100%;
      height: 100%;
      display: block;
    }
  }

  &__form-wrap {
    padding: 2.5rem;
  }

  &__info {
    max-width: 1100px;
    margin: 0 auto;
    display: flex;
    flex-wrap: wrap;
    gap: 2rem;
    justify-content: center;
  }
}

.c-info-item {
  display: flex;
  align-items: center;
  gap: 0.75rem;
  color: var(--color-text-muted);
  font-size: 0.95rem;

  & i {
    color: var(--color-caramel);
    width: 18px;
    flex-shrink: 0;
  }

  & a {
    color: var(--color-text-muted);
    text-decoration: none;

    &:hover {
      color: var(--color-caramel);
    }
  }
}

.c-form {
  display: flex;
  flex-direction: column;
  gap: 1.25rem;

  &__row {
    display: flex;
    flex-direction: column;
    gap: 0.4rem;

    &--check {
      flex-direction: row;
      align-items: flex-start;
      gap: 0.75rem;

      & input[type="checkbox"] {
        margin-top: 3px;
        flex-shrink: 0;
        width: 18px;
        height: 18px;
        accent-color: var(--color-caramel);
        cursor: pointer;
      }
    }
  }

  &__label {
    font-size: 0.88rem;
    font-weight: 500;
    color: var(--color-bark);
  }

  &__check-label {
    font-size: 0.87rem;
    color: var(--color-text-muted);
    line-height: 1.5;
    cursor: pointer;

    & a {
      color: var(--color-caramel);
      text-decoration: underline;
    }
  }

  &__input {
    padding: 0.85rem 1rem;
    border: 1.5px solid var(--color-border);
    border-radius: var(--radius-md);
    font-family: var(--font-body);
    font-size: 0.95rem;
    color: var(--color-text);
    background: var(--color-cream);
    transition: border-color var(--transition-fast), box-shadow var(--transition-fast);
    outline: none;
    width: 100%;

    &::placeholder {
      color: var(--color-text-light);
    }

    &:focus {
      border-color: var(--color-caramel);
      box-shadow: 0 0 0 3px rgba(200,149,106,0.15);
    }
  }

  &__textarea {
    resize: vertical;
    min-height: 130px;
  }
}

.c-footer {
  border-top: 1px solid var(--color-border);
  background: var(--color-warm-white);
  padding: 1.1rem 2rem;
  margin-top: auto;

  &__inner {
    max-width: 1200px;
    margin: 0 auto;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1.5rem;
    flex-wrap: wrap;
  }

  &__logo-img {
    height: 32px;
    width: auto;
  }

  &__nav {
    display: flex;
    gap: 1.5rem;

    & a {
      font-size: 0.85rem;
      color: var(--color-text-muted);
      text-decoration: none;
      transition: color var(--transition-fast);

      &:hover {
        color: var(--color-caramel);
      }
    }
  }

  &__copy {
    font-size: 0.82rem;
    color: var(--color-text-light);
  }
}

.s-legal {
  padding: 8rem 2rem 5rem;
  max-width: 820px;
  margin: 0 auto;

  & h1 {
    font-size: clamp(1.8rem, 3.5vw, 2.6rem);
    font-weight: 700;
    color: var(--color-bark);
    margin-bottom: 0.5rem;
  }

  &__date {
    font-size: 0.88rem;
    color: var(--color-text-light);
    margin-bottom: 3rem;
    font-family: var(--font-hand);
  }

  & h2 {
    font-size: 1.25rem;
    font-weight: 600;
    color: var(--color-bark);
    margin-top: 2.5rem;
    margin-bottom: 0.75rem;
  }

  & h3 {
    font-size: 1.05rem;
    font-weight: 600;
    color: var(--color-bark-light);
    margin-top: 1.75rem;
    margin-bottom: 0.5rem;
  }

  & p {
    color: var(--color-text-muted);
    line-height: 1.85;
    margin-bottom: 1.1rem;
    font-size: 0.97rem;
  }

  & ul {
    list-style: disc;
    padding-left: 1.5rem;
    margin-bottom: 1.1rem;

    & li {
      color: var(--color-text-muted);
      line-height: 1.8;
      font-size: 0.97rem;
      margin-bottom: 0.3rem;
    }
  }
}

.s-thanks {
  min-height: 100vh;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  padding: 8rem 2rem 5rem;
  text-align: center;

  &__title {
    font-size: clamp(1.8rem, 3.5vw, 2.6rem);
    font-weight: 700;
    color: var(--color-bark);
    margin-bottom: 1rem;
  }

  &__subtitle {
    color: var(--color-text-muted);
    font-size: 1.05rem;
    max-width: 480px;
    margin: 0 auto 2.5rem;
    line-height: 1.75;
  }

  &__timeline {
    display: flex;
    flex-direction: column;
    gap: 0;
    align-items: flex-start;
    max-width: 380px;
    width: 100%;
    margin: 3rem auto 2.5rem;
    text-align: left;
  }
}

.c-timeline-item {
  display: flex;
  align-items: flex-start;
  gap: 1.25rem;
  position: relative;
  padding-bottom: 2.5rem;

  &:last-child {
    padding-bottom: 0;
  }

  &::before {
    content: '';
    position: absolute;
    left: 19px;
    top: 40px;
    bottom: 0;
    width: 2px;
    background: var(--color-border);
  }

  &:last-child::before {
    display: none;
  }

  &__dot {
    flex-shrink: 0;
    width: 40px;
    height: 40px;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 0.9rem;
    z-index: 1;
    background: var(--color-parchment);
    color: var(--color-text-light);
    border: 2px solid var(--color-border);

    &.is-done {
      background: var(--color-sage-light);
      color: #fff;
      border-color: var(--color-sage);
    }

    &.is-active {
      background: var(--color-caramel);
      color: #fff;
      border-color: var(--color-caramel-dark);
      box-shadow: 0 4px 16px rgba(200,149,106,0.35);
    }
  }

  &__text {
    padding-top: 0.5rem;

    & strong {
      display: block;
      font-weight: 600;
      color: var(--color-bark);
      font-size: 1rem;
    }

    & span {
      font-size: 0.88rem;
      color: var(--color-text-light);
    }
  }
}

@media (max-width: 1024px) {
  .s-proces__flow {
    grid-template-columns: repeat(2, 1fr);
  }

  .s-banner__inner {
    grid-template-columns: 1fr;
    gap: 3rem;
    text-align: center;

    & .s-banner__polaroid {
      display: flex;
      justify-content: center;
    }
  }
}

@media (max-width: 768px) {
  .c-nav__links {
    display: none;
  }

  .c-nav__hamburger {
    display: flex;
  }

  .s-hero {
    padding: 6rem 1.5rem 4rem;

    &__polaroid {
      &--1 {
        width: 130px;
        top: 8%;
        right: 3%;
      }
      &--2 { display: none; }
      &--3 { display: none; }
    }

    &__content {
      max-width: 100%;
    }
  }

  .s-despre__island {
    grid-template-columns: 1fr;
    gap: 3rem;
  }

  .s-servicii__features {
    grid-template-columns: 1fr;
    gap: 0;
  }

  .s-servicii__col:first-child .c-feature:last-child {
    border-bottom: 1px solid var(--color-border);
  }

  .s-proces__flow {
    grid-template-columns: 1fr;
    gap: 1.25rem;
  }

  .s-contact__body {
    grid-template-columns: 1fr;
  }

  .s-contact__map {
    min-height: 280px;
  }

  .s-banner__inner {
    grid-template-columns: 1fr;
    gap: 2.5rem;
    text-align: center;

    & .s-banner__polaroid .c-polaroid {
      width: 200px;
      margin: 0 auto;
    }
  }

  .c-footer__inner {
    flex-direction: column;
    align-items: center;
    text-align: center;
    gap: 0.75rem;
  }

  .s-hero__actions {
    flex-direction: column;
    align-items: flex-start;
  }

  .s-hero__polaroid--1 {
    opacity: 0.5;
  }

  .s-galerie__swiper {
    padding: 1rem 0.5rem 4rem;
  }
}

@media (max-width: 480px) {
  .s-hero__title {
    font-size: 2rem;
  }

  .s-despre, .s-servicii, .s-galerie, .s-proces, .s-pachete, .s-banner, .s-contact {
    padding: 4rem 1.25rem;
  }

  .s-contact__form-wrap {
    padding: 1.5rem;
  }

  .c-table th, .c-table td {
    padding: 0.85rem 0.75rem;
    font-size: 0.85rem;
  }
}

.c-cookie-consent {
  position: fixed;
  bottom: 1.5rem;
  right: 1.5rem;
  width: 320px;
  background: var(--color-warm-white);
  border-radius: var(--radius-xl);
  box-shadow: 0 8px 32px rgba(46,31,14,0.18), 0 2px 8px rgba(46,31,14,0.10);
  z-index: 9999;
  padding: 1.5rem;
  transform: translateY(120%);
  opacity: 0;
  transition: transform var(--transition-slow), opacity var(--transition-med);
  border: 1px solid var(--color-border);

  &.is-visible {
    transform: translateY(0);
    opacity: 1;
  }

  &__icon {
    font-size: 2rem;
    margin-bottom: 0.75rem;
    color: var(--color-caramel);
    text-align: center;
  }

  &__title {
    font-size: 1rem;
    font-weight: 600;
    color: var(--color-bark);
    margin-bottom: 0.5rem;
    text-align: center;
  }

  &__text {
    font-size: 0.83rem;
    color: var(--color-text-muted);
    line-height: 1.6;
    margin-bottom: 1rem;
    text-align: center;
  }

  &__toggles {
    display: none;
    flex-direction: column;
    gap: 0.6rem;
    margin-bottom: 1rem;
    padding-top: 0.5rem;
    border-top: 1px solid var(--color-border);

    &.is-visible {
      display: flex;
    }
  }

  &__toggle-row {
    display: flex;
    align-items: center;
    justify-content: space-between;
    font-size: 0.83rem;
    color: var(--color-text-muted);
  }

  &__toggle-label {
    font-weight: 500;
    color: var(--color-bark);
    font-size: 0.83rem;
  }

  &__toggle {
    position: relative;
    width: 36px;
    height: 20px;

    & input {
      opacity: 0;
      width: 0;
      height: 0;

      &:checked + .c-cookie-consent__slider {
        background: var(--color-caramel);
      }

      &:checked + .c-cookie-consent__slider::before {
        transform: translateX(16px);
      }

      &:disabled + .c-cookie-consent__slider {
        opacity: 0.6;
        cursor: not-allowed;
      }
    }
  }

  &__slider {
    position: absolute;
    cursor: pointer;
    inset: 0;
    background: var(--color-border);
    border-radius: 20px;
    transition: background var(--transition-fast);

    &::before {
      content: '';
      position: absolute;
      width: 14px;
      height: 14px;
      left: 3px;
      top: 3px;
      background: #fff;
      border-radius: 50%;
      transition: transform var(--transition-fast);
    }
  }

  &__buttons {
    display: flex;
    flex-direction: column;
    gap: 0.5rem;
  }

  &__btn-accept {
    width: 100%;
    padding: 0.7rem;
    background: var(--color-caramel);
    color: #fff;
    border: none;
    border-radius: 50px;
    font-family: var(--font-body);
    font-size: 0.88rem;
    font-weight: 500;
    cursor: pointer;
    transition: background var(--transition-fast);

    &:hover {
      background: var(--color-caramel-dark);
    }
  }

  &__btn-customize {
    width: 100%;
    padding: 0.6rem;
    background: transparent;
    color: var(--color-text-muted);
    border: 1.5px solid var(--color-border);
    border-radius: 50px;
    font-family: var(--font-body);
    font-size: 0.83rem;
    cursor: pointer;
    transition: border-color var(--transition-fast), color var(--transition-fast);

    &:hover {
      border-color: var(--color-caramel);
      color: var(--color-caramel);
    }
  }

  &__btn-save {
    width: 100%;
    padding: 0.6rem;
    background: transparent;
    color: var(--color-sage);
    border: 1.5px solid var(--color-sage-light);
    border-radius: 50px;
    font-family: var(--font-body);
    font-size: 0.83rem;
    cursor: pointer;
    transition: background var(--transition-fast), color var(--transition-fast);
    display: none;

    &:hover {
      background: var(--color-sage-light);
      color: #fff;
    }

    &.is-visible {
      display: block;
    }
  }
}

@media (max-width: 380px) {
  .c-cookie-consent {
    width: calc(100vw - 2rem);
    right: 1rem;
    bottom: 1rem;
  }
}