@layer base, layout, components, utilities;

@layer base {
  :root {
    --color-pink: #f472b6;
    --color-pink-light: #fce7f3;
    --color-pink-dark: #db2777;
    --color-purple: #a855f7;
    --color-purple-light: #f3e8ff;
    --color-purple-dark: #7e22ce;
    --color-blue: #60a5fa;
    --color-blue-light: #dbeafe;
    --color-teal: #2dd4bf;
    --color-teal-light: #ccfbf1;

    --gradient-main: linear-gradient(135deg, #f472b6 0%, #a855f7 40%, #60a5fa 75%, #2dd4bf 100%);
    --gradient-soft: linear-gradient(135deg, #fce7f3 0%, #f3e8ff 50%, #dbeafe 100%);
    --gradient-hero: linear-gradient(145deg, #fdf4ff 0%, #ede9fe 30%, #dbeafe 65%, #ccfbf1 100%);
    --gradient-dark: linear-gradient(135deg, #1e1b4b 0%, #312e81 50%, #1e3a5f 100%);
    --gradient-text: linear-gradient(90deg, #db2777, #7e22ce, #2563eb);
    --gradient-btn: linear-gradient(90deg, #f472b6, #a855f7, #60a5fa);

    --color-bg: #fdfbff;
    --color-bg-light: #f8f4ff;
    --color-surface: #ffffff;
    --color-text: #1a1033;
    --color-text-muted: #5b4d7a;
    --color-text-light: #8b7aaa;
    --color-border: #e8d9f5;

    --font-heading: 'Newsreader', Georgia, serif;
    --font-body: 'Manrope', system-ui, sans-serif;

    --size-xs: 0.75rem;
    --size-sm: 0.875rem;
    --size-base: 1rem;
    --size-md: 1.125rem;
    --size-lg: 1.25rem;
    --size-xl: 1.5rem;
    --size-2xl: 2rem;
    --size-3xl: 2.5rem;
    --size-4xl: 3.5rem;
    --size-5xl: clamp(2.5rem, 5vw, 4.5rem);
    --size-hero: clamp(2.8rem, 6vw, 5.5rem);

    --radius-sm: 8px;
    --radius-md: 16px;
    --radius-lg: 24px;
    --radius-xl: 36px;
    --radius-full: 9999px;

    --shadow-sm: 0 2px 8px rgba(168, 85, 247, 0.08), 0 1px 3px rgba(0,0,0,0.06);
    --shadow-md: 0 8px 24px rgba(168, 85, 247, 0.12), 0 2px 8px rgba(0,0,0,0.08);
    --shadow-lg: 0 20px 48px rgba(168, 85, 247, 0.16), 0 8px 20px rgba(0,0,0,0.1);
    --shadow-xl: 0 32px 64px rgba(168, 85, 247, 0.2), 0 12px 32px rgba(0,0,0,0.12);
    --shadow-glow: 0 0 32px rgba(168, 85, 247, 0.3);
    --shadow-pink: 0 8px 32px rgba(244, 114, 182, 0.25);
    --shadow-btn: 0 4px 16px rgba(168, 85, 247, 0.35), 0 2px 6px rgba(0,0,0,0.1);

    --space-1: 0.25rem;
    --space-2: 0.5rem;
    --space-3: 0.75rem;
    --space-4: 1rem;
    --space-5: 1.25rem;
    --space-6: 1.5rem;
    --space-8: 2rem;
    --space-10: 2.5rem;
    --space-12: 3rem;
    --space-16: 4rem;
    --space-20: 5rem;
    --space-24: 6rem;
    --space-32: 8rem;

    --transition-fast: 150ms ease;
    --transition-base: 280ms cubic-bezier(0.4, 0, 0.2, 1);
    --transition-slow: 420ms cubic-bezier(0.4, 0, 0.2, 1);
  }

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

  html {
    scroll-behavior: smooth;
    -webkit-text-size-adjust: 100%;
    overflow-x: hidden;
  }

  body {
    font-family: var(--font-body);
    font-size: var(--size-base);
    color: var(--color-text);
    background-color: var(--color-bg);
    line-height: 1.7;
    overflow-x: hidden;
    -webkit-font-smoothing: antialiased;
  }

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

  a {
    color: inherit;
    text-decoration: none;
    transition: color var(--transition-base);
  }

  ul {
    list-style: none;
  }

  address {
    font-style: normal;
  }
}

@layer layout {
  .page-wrapper {
    min-block-size: 100dvh;
    display: flex;
    flex-direction: column;
    transition: transform var(--transition-slow), scale var(--transition-slow);
    transform-origin: right center;
    will-change: transform;
  }

  main {
    flex: 1;
  }

  .container {
    max-inline-size: 1200px;
    margin-inline: auto;
    padding-inline: var(--space-6);
  }

  .section {
    padding-block: var(--space-20);
  }

  .section--light {
    background: var(--color-bg-light);
  }

  .section--gradient-bg {
    background: var(--gradient-main);
    position: relative;
    overflow: hidden;
  }

  .section--gradient-bg::before {
    content: '';
    position: absolute;
    inset: 0;
    background: rgba(255,255,255,0.08);
    pointer-events: none;
  }
}

@layer components {

  
  .section-label {
    display: inline-flex;
    align-items: center;
    gap: var(--space-2);
    font-family: var(--font-body);
    font-size: var(--size-sm);
    font-weight: 600;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    color: var(--color-purple);
    background: var(--color-purple-light);
    padding: var(--space-1) var(--space-3);
    border-radius: var(--radius-full);
    margin-block-end: var(--space-4);
  }

  .section-label--light {
    color: rgba(255,255,255,0.9);
    background: rgba(255,255,255,0.2);
  }

  .section-title {
    font-family: var(--font-heading);
    font-size: clamp(1.8rem, 3.5vw, 2.8rem);
    font-weight: 700;
    line-height: 1.2;
    color: var(--color-text);
    margin-block-end: var(--space-4);
  }

  .section-title--light {
    color: #ffffff;
  }

  .section-desc {
    font-size: var(--size-md);
    color: var(--color-text-muted);
    max-inline-size: 60ch;
    margin-inline: auto;
  }

  .section-header {
    text-align: center;
    margin-block-end: var(--space-12);
  }

  .text--gradient {
    background: var(--gradient-text);
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    background-clip: text;
  }

  .text--light {
    color: rgba(255,255,255,0.88);
  }

  
  .btn {
    display: inline-flex;
    align-items: center;
    gap: var(--space-2);
    padding: var(--space-3) var(--space-6);
    border-radius: var(--radius-full);
    font-family: var(--font-body);
    font-size: var(--size-base);
    font-weight: 600;
    cursor: pointer;
    border: none;
    transition: transform var(--transition-base), box-shadow var(--transition-base), filter var(--transition-base), background var(--transition-base);
    text-decoration: none;
    white-space: nowrap;
    position: relative;
    overflow: hidden;
  }

  .btn--gradient {
    background: var(--gradient-btn);
    color: #ffffff;
    box-shadow: var(--shadow-btn);
  }

  .btn--gradient:hover {
    transform: translateY(-2px) scale(1.02);
    box-shadow: var(--shadow-lg), var(--shadow-glow);
    filter: brightness(1.08);
    color: #ffffff;
  }

  .btn--gradient:active {
    transform: translateY(0) scale(0.98);
  }

  .btn--outline {
    background: transparent;
    color: var(--color-purple);
    border: 2px solid var(--color-purple);
    box-shadow: none;
  }

  .btn--outline:hover {
    background: var(--color-purple-light);
    transform: translateY(-2px);
    box-shadow: var(--shadow-md);
    color: var(--color-purple-dark);
  }

  .btn--white {
    background: #ffffff;
    color: var(--color-purple-dark);
    box-shadow: var(--shadow-md);
  }

  .btn--white:hover {
    transform: translateY(-2px);
    box-shadow: var(--shadow-lg);
    color: var(--color-purple-dark);
  }

  .btn--lg {
    padding: var(--space-4) var(--space-8);
    font-size: var(--size-md);
  }

  
  .nav {
    position: fixed;
    inset-block-start: var(--space-4);
    inset-inline: var(--space-4);
    z-index: 900;
    transition: all var(--transition-base);
  }

  .nav__container {
    display: flex;
    align-items: center;
    gap: var(--space-6);
    background: rgba(255, 255, 255, 0.92);
    border-radius: var(--radius-xl);
    padding: var(--space-3) var(--space-6);
    box-shadow: var(--shadow-md);
    border: 1px solid rgba(168, 85, 247, 0.1);
    backdrop-filter: blur(12px);
    -webkit-backdrop-filter: blur(12px);
    transition: all var(--transition-base);
  }

  .nav.nav--scrolled .nav__container {
    background: rgba(255, 255, 255, 0.75);
    backdrop-filter: blur(20px);
    -webkit-backdrop-filter: blur(20px);
    box-shadow: var(--shadow-lg);
    border-color: rgba(168, 85, 247, 0.15);
  }

  .nav__logo {
    display: flex;
    align-items: center;
    flex-shrink: 0;
  }

  .nav__logo-img {
    block-size: 36px;
    inline-size: auto;
  }

  .nav__menu {
    flex: 1;
  }

  .nav__list {
    display: flex;
    align-items: center;
    gap: var(--space-1);
  }

  .nav__link {
    font-size: var(--size-sm);
    font-weight: 500;
    color: var(--color-text-muted);
    padding: var(--space-2) var(--space-3);
    border-radius: var(--radius-md);
    transition: all var(--transition-base);
    position: relative;
  }

  .nav__link:hover {
    color: var(--color-purple);
    background: var(--color-purple-light);
  }

  .nav__link--active {
    color: var(--color-purple-dark);
    background: var(--color-purple-light);
    font-weight: 600;
  }

  .nav__cta {
    flex-shrink: 0;
    font-size: var(--size-sm);
    padding: var(--space-2) var(--space-5);
  }

  .nav__hamburger {
    display: none;
    flex-direction: column;
    justify-content: center;
    gap: 5px;
    background: none;
    border: none;
    cursor: pointer;
    padding: var(--space-2);
    border-radius: var(--radius-sm);
    transition: background var(--transition-base);
  }

  .nav__hamburger:hover {
    background: var(--color-purple-light);
  }

  .nav__hamburger-line {
    display: block;
    inline-size: 22px;
    block-size: 2px;
    background: var(--color-text);
    border-radius: 2px;
    transition: all var(--transition-base);
  }

  .nav__hamburger.is-open .nav__hamburger-line:nth-child(1) {
    transform: translateY(7px) rotate(45deg);
  }

  .nav__hamburger.is-open .nav__hamburger-line:nth-child(2) {
    opacity: 0;
    transform: scaleX(0);
  }

  .nav__hamburger.is-open .nav__hamburger-line:nth-child(3) {
    transform: translateY(-7px) rotate(-45deg);
  }

  
  .mobile-menu {
    position: fixed;
    inset-block: 0;
    inset-inline-end: 0;
    inline-size: 300px;
    background: #ffffff;
    z-index: 950;
    padding: var(--space-6);
    display: flex;
    flex-direction: column;
    gap: var(--space-6);
    transform: translateX(100%);
    transition: transform var(--transition-slow);
    box-shadow: var(--shadow-xl);
  }

  .mobile-menu.is-open {
    transform: translateX(0);
  }

  .mobile-menu__header {
    display: flex;
    align-items: center;
    justify-content: space-between;
  }

  .mobile-menu__logo {
    block-size: 32px;
    inline-size: auto;
  }

  .mobile-menu__close {
    background: var(--color-purple-light);
    border: none;
    cursor: pointer;
    padding: var(--space-2);
    border-radius: var(--radius-sm);
    font-size: var(--size-lg);
    color: var(--color-purple);
    transition: all var(--transition-base);
    min-block-size: 44px;
    min-inline-size: 44px;
    display: flex;
    align-items: center;
    justify-content: center;
  }

  .mobile-menu__close:hover {
    background: var(--color-purple);
    color: #ffffff;
  }

  .mobile-menu__nav {
    flex: 1;
  }

  .mobile-menu__list {
    display: flex;
    flex-direction: column;
    gap: var(--space-1);
  }

  .mobile-menu__link {
    display: block;
    padding: var(--space-3) var(--space-4);
    border-radius: var(--radius-md);
    font-weight: 500;
    color: var(--color-text-muted);
    transition: all var(--transition-base);
    min-block-size: 44px;
    display: flex;
    align-items: center;
  }

  .mobile-menu__link:hover,
  .mobile-menu__link--active {
    background: var(--color-purple-light);
    color: var(--color-purple-dark);
  }

  .mobile-menu__cta {
    text-align: center;
    justify-content: center;
  }

  
  .page-wrapper.menu-open {
    border-radius: var(--radius-lg);
    overflow: hidden;
  }

  
  .hero {
    position: relative;
    min-block-size: 100dvh;
    display: flex;
    align-items: center;
    overflow: hidden;
    background: var(--gradient-hero);
    padding-block-start: 120px;
    padding-block-end: var(--space-16);
  }

  .hero__bg-gradient {
    position: absolute;
    inset: 0;
    background: radial-gradient(ellipse at 70% 50%, rgba(168, 85, 247, 0.15) 0%, transparent 60%),
                radial-gradient(ellipse at 20% 80%, rgba(244, 114, 182, 0.12) 0%, transparent 50%);
    pointer-events: none;
  }

  .hero__orb {
    position: absolute;
    border-radius: 50%;
    filter: blur(60px);
    opacity: 0.4;
    pointer-events: none;
    animation: float 8s ease-in-out infinite;
  }

  .hero__orb--1 {
    inline-size: 400px;
    block-size: 400px;
    background: radial-gradient(circle, rgba(244, 114, 182, 0.6) 0%, transparent 70%);
    inset-block-start: -100px;
    inset-inline-end: 10%;
    animation-delay: 0s;
  }

  .hero__orb--2 {
    inline-size: 300px;
    block-size: 300px;
    background: radial-gradient(circle, rgba(168, 85, 247, 0.5) 0%, transparent 70%);
    inset-block-end: 10%;
    inset-inline-start: 5%;
    animation-delay: 3s;
  }

  .hero__orb--3 {
    inline-size: 250px;
    block-size: 250px;
    background: radial-gradient(circle, rgba(45, 212, 191, 0.4) 0%, transparent 70%);
    inset-block-start: 40%;
    inset-inline-end: 30%;
    animation-delay: 6s;
  }

  @keyframes float {
    0%, 100% { transform: translateY(0) scale(1); }
    50% { transform: translateY(-24px) scale(1.05); }
  }

  .hero__inner {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: var(--space-12);
    align-items: center;
    position: relative;
    z-index: 2;
  }

  .hero__content {
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    gap: var(--space-5);
  }

  .hero__badge {
    display: inline-flex;
    align-items: center;
    gap: var(--space-2);
    background: rgba(255,255,255,0.8);
    border: 1px solid rgba(168, 85, 247, 0.2);
    border-radius: var(--radius-full);
    padding: var(--space-2) var(--space-4);
    font-size: var(--size-sm);
    font-weight: 600;
    color: var(--color-purple-dark);
    backdrop-filter: blur(8px);
  }

  .hero__badge i {
    color: var(--color-pink);
  }

  .hero__title {
    font-family: var(--font-heading);
    font-size: var(--size-hero);
    font-weight: 700;
    line-height: 1.1;
    color: var(--color-text);
  }

  .hero__subtitle {
    font-size: var(--size-md);
    color: var(--color-text-muted);
    max-inline-size: 52ch;
    line-height: 1.75;
  }

  .hero__actions {
    display: flex;
    gap: var(--space-4);
    flex-wrap: wrap;
  }

  .hero__visual {
    display: flex;
    justify-content: center;
    align-items: center;
  }

  .hero__atropos {
    inline-size: 100%;
    max-inline-size: 480px;
  }

  .hero__atropos-inner {
    position: relative;
    padding: var(--space-4);
  }

  .hero__card {
    border-radius: var(--radius-lg);
    overflow: hidden;
    box-shadow: var(--shadow-xl);
  }

  .hero__card--main {
    position: relative;
  }

  .hero__card-img {
    inline-size: 100%;
    block-size: 360px;
    object-fit: cover;
    border-radius: var(--radius-lg);
  }

  .hero__card-overlay {
    position: absolute;
    inset-block-end: var(--space-4);
    inset-inline-start: var(--space-4);
  }

  .hero__card-tag {
    display: inline-flex;
    align-items: center;
    gap: var(--space-2);
    background: rgba(255,255,255,0.95);
    border-radius: var(--radius-full);
    padding: var(--space-2) var(--space-4);
    font-size: var(--size-sm);
    font-weight: 600;
    color: var(--color-purple-dark);
    box-shadow: var(--shadow-md);
  }

  .hero__card-tag i {
    color: var(--color-teal);
  }

  .hero__floating-badge {
    position: absolute;
    display: flex;
    align-items: center;
    gap: var(--space-2);
    background: #ffffff;
    border-radius: var(--radius-md);
    padding: var(--space-2) var(--space-4);
    font-size: var(--size-sm);
    font-weight: 600;
    box-shadow: var(--shadow-lg);
    white-space: nowrap;
  }

  .hero__floating-badge--1 {
    inset-block-start: var(--space-6);
    inset-inline-end: -var(--space-4);
    color: var(--color-pink-dark);
    border: 1px solid var(--color-pink-light);
  }

  .hero__floating-badge--1 i {
    color: var(--color-pink);
  }

  .hero__floating-badge--2 {
    inset-block-end: var(--space-10);
    inset-inline-end: -var(--space-6);
    color: var(--color-purple-dark);
    border: 1px solid var(--color-purple-light);
  }

  .hero__floating-badge--2 i {
    color: var(--color-purple);
  }

  .hero__scroll-hint {
    position: absolute;
    inset-block-end: var(--space-8);
    inset-inline-start: 50%;
    transform: translateX(-50%);
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: var(--space-2);
    font-size: var(--size-xs);
    color: var(--color-text-light);
    animation: bounce 2s ease-in-out infinite;
  }

  @keyframes bounce {
    0%, 100% { transform: translateX(-50%) translateY(0); }
    50% { transform: translateX(-50%) translateY(6px); }
  }

  
  .intro-strip {
    background: #ffffff;
    border-block: 1px solid var(--color-border);
    padding-block: var(--space-6);
  }

  .intro-strip__inner {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: var(--space-6);
    flex-wrap: wrap;
  }

  .intro-strip__item {
    display: flex;
    align-items: center;
    gap: var(--space-3);
    font-size: var(--size-sm);
    font-weight: 600;
    color: var(--color-text-muted);
  }

  .intro-strip__icon {
    font-size: var(--size-lg);
    background: var(--gradient-main);
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    background-clip: text;
  }

  .intro-strip__divider {
    inline-size: 1px;
    block-size: 32px;
    background: var(--color-border);
  }

  
  .about__inner {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: var(--space-12);
    align-items: center;
  }

  .about__image-wrap {
    position: relative;
    border-radius: var(--radius-lg);
    overflow: visible;
  }

  .about__img {
    border-radius: var(--radius-lg);
    inline-size: 100%;
    block-size: 420px;
    object-fit: cover;
    box-shadow: var(--shadow-lg);
    position: relative;
    z-index: 2;
  }

  .about__image-accent {
    position: absolute;
    inset-block-end: -16px;
    inset-inline-end: -16px;
    inline-size: 200px;
    block-size: 200px;
    background: var(--gradient-soft);
    border-radius: var(--radius-lg);
    z-index: 1;
  }

  .about__content {
    display: flex;
    flex-direction: column;
    gap: var(--space-5);
  }

  .about__lead {
    font-size: var(--size-lg);
    color: var(--color-text-muted);
    line-height: 1.8;
  }

  
  .services__grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: var(--space-6);
  }

  .card--service {
    background: var(--color-surface);
    border-radius: var(--radius-lg);
    padding: var(--space-8);
    border: 1px solid var(--color-border);
    box-shadow: var(--shadow-sm);
    transition: transform var(--transition-base), box-shadow var(--transition-base), border-color var(--transition-base);
    position: relative;
    overflow: hidden;
  }

  .card--service:hover {
    transform: translateY(-6px);
    box-shadow: var(--shadow-lg);
    border-color: var(--color-purple);
  }

  .card--featured {
    grid-column: span 1;
    background: linear-gradient(145deg, #fdf4ff, #ede9fe);
    border-color: rgba(168, 85, 247, 0.3);
  }

  .card__badge {
    position: absolute;
    inset-block-start: var(--space-4);
    inset-inline-end: var(--space-4);
    background: var(--gradient-btn);
    color: #ffffff;
    font-size: var(--size-xs);
    font-weight: 600;
    padding: var(--space-1) var(--space-3);
    border-radius: var(--radius-full);
  }

  .card__icon-wrap {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    inline-size: 52px;
    block-size: 52px;
    border-radius: var(--radius-md);
    margin-block-end: var(--space-5);
  }

  .card__icon-wrap--pink { background: var(--color-pink-light); }
  .card__icon-wrap--purple { background: var(--color-purple-light); }
  .card__icon-wrap--blue { background: var(--color-blue-light); }
  .card__icon-wrap--teal { background: var(--color-teal-light); }

  .card__icon {
    font-size: var(--size-xl);
  }

  .card__icon-wrap--pink .card__icon { color: var(--color-pink-dark); }
  .card__icon-wrap--purple .card__icon { color: var(--color-purple-dark); }
  .card__icon-wrap--blue .card__icon { color: #1d4ed8; }
  .card__icon-wrap--teal .card__icon { color: #0d9488; }

  .card__title {
    font-family: var(--font-heading);
    font-size: var(--size-xl);
    font-weight: 600;
    margin-block-end: var(--space-3);
    color: var(--color-text);
  }

  .card__body {
    color: var(--color-text-muted);
    line-height: 1.7;
  }

  
  .journey__track {
    position: relative;
    max-inline-size: 800px;
    margin-inline: auto;
    padding-inline-start: var(--space-12);
  }

  .journey__line {
    position: absolute;
    inset-block: 0;
    inset-inline-start: 22px;
    inline-size: 2px;
    background: linear-gradient(to bottom, var(--color-pink), var(--color-purple), var(--color-blue), var(--color-teal));
    border-radius: var(--radius-full);
  }

  .journey__step {
    display: flex;
    gap: var(--space-6);
    align-items: flex-start;
    margin-block-end: var(--space-10);
    position: relative;
  }

  .journey__step:last-child {
    margin-block-end: 0;
  }

  .journey__step-marker {
    position: absolute;
    inset-inline-start: -var(--space-12);
    inset-block-start: 0;
    inline-size: 44px;
    block-size: 44px;
    border-radius: 50%;
    background: var(--gradient-btn);
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
    box-shadow: var(--shadow-pink);
    z-index: 2;
  }

  .journey__step-marker--2 {
    background: linear-gradient(135deg, var(--color-purple), var(--color-blue));
  }

  .journey__step-marker--3 {
    background: linear-gradient(135deg, var(--color-blue), var(--color-teal));
  }

  .journey__step-marker--4 {
    background: linear-gradient(135deg, var(--color-teal), var(--color-purple));
  }

  .journey__step-marker--5 {
    background: linear-gradient(135deg, var(--color-pink), var(--color-purple));
  }

  .journey__step-num {
    font-size: var(--size-xs);
    font-weight: 700;
    color: #ffffff;
    letter-spacing: 0.05em;
  }

  .journey__step-content {
    background: var(--color-surface);
    border-radius: var(--radius-lg);
    padding: var(--space-6);
    border: 1px solid var(--color-border);
    box-shadow: var(--shadow-sm);
    flex: 1;
    transition: transform var(--transition-base), box-shadow var(--transition-base);
  }

  .journey__step-content:hover {
    transform: translateX(4px);
    box-shadow: var(--shadow-md);
  }

  .journey__step-title {
    font-family: var(--font-heading);
    font-size: var(--size-xl);
    font-weight: 600;
    margin-block-end: var(--space-3);
    color: var(--color-text);
  }

  .journey__step-desc {
    color: var(--color-text-muted);
    line-height: 1.7;
  }

  .journey__cta {
    text-align: center;
    margin-block-start: var(--space-10);
  }

  
  .why-teaser__inner {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: var(--space-12);
    align-items: center;
    position: relative;
    z-index: 2;
  }

  .why-teaser__content {
    display: flex;
    flex-direction: column;
    gap: var(--space-5);
  }

  .why-teaser__text {
    color: rgba(255,255,255,0.88);
    line-height: 1.8;
  }

  .why-teaser__image {
    border-radius: var(--radius-lg);
    overflow: hidden;
    box-shadow: var(--shadow-xl);
  }

  .why-teaser__img {
    inline-size: 100%;
    block-size: 400px;
    object-fit: cover;
    transition: transform var(--transition-slow);
  }

  .why-teaser__image:hover .why-teaser__img {
    transform: scale(1.03);
  }

  
  .cta-minimal__inner {
    text-align: center;
    max-inline-size: 640px;
    margin-inline: auto;
  }

  .cta-minimal__title {
    font-family: var(--font-heading);
    font-size: clamp(1.8rem, 3vw, 2.5rem);
    font-weight: 700;
    color: var(--color-text);
    margin-block-end: var(--space-4);
  }

  .cta-minimal__text {
    color: var(--color-text-muted);
    font-size: var(--size-md);
    margin-block-end: var(--space-8);
  }

  
  .page-hero {
    position: relative;
    padding-block: 140px var(--space-16);
    background: var(--gradient-hero);
    overflow: hidden;
  }

  .page-hero__bg {
    position: absolute;
    inset: 0;
    background: radial-gradient(ellipse at 80% 50%, rgba(168, 85, 247, 0.15) 0%, transparent 60%),
                radial-gradient(ellipse at 20% 80%, rgba(244, 114, 182, 0.1) 0%, transparent 50%);
    pointer-events: none;
  }

  .page-hero__inner {
    position: relative;
    z-index: 2;
    max-inline-size: 720px;
  }

  .page-hero__title {
    font-family: var(--font-heading);
    font-size: var(--size-5xl);
    font-weight: 700;
    line-height: 1.15;
    color: var(--color-text);
    margin-block-end: var(--space-4);
  }

  .page-hero__desc {
    font-size: var(--size-md);
    color: var(--color-text-muted);
    line-height: 1.75;
  }

  
  .two-col {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: var(--space-12);
    align-items: center;
  }

  .two-col--reverse {
    direction: rtl;
  }

  .two-col--reverse > * {
    direction: ltr;
  }

  .two-col__content {
    display: flex;
    flex-direction: column;
    gap: var(--space-5);
  }

  .two-col__image {
    border-radius: var(--radius-lg);
    overflow: hidden;
    box-shadow: var(--shadow-lg);
  }

  .two-col__img {
    inline-size: 100%;
    block-size: 400px;
    object-fit: cover;
    transition: transform var(--transition-slow);
  }

  .two-col__image:hover .two-col__img {
    transform: scale(1.03);
  }

  
  .pillars__grid {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: var(--space-6);
  }

  .pillar-card {
    background: var(--color-surface);
    border-radius: var(--radius-lg);
    padding: var(--space-8);
    border: 1px solid var(--color-border);
    box-shadow: var(--shadow-sm);
    transition: transform var(--transition-base), box-shadow var(--transition-base);
  }

  .pillar-card:hover {
    transform: translateY(-4px);
    box-shadow: var(--shadow-md);
  }

  .pillar-card__num {
    font-family: var(--font-heading);
    font-size: var(--size-4xl);
    font-weight: 700;
    background: var(--gradient-text);
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    background-clip: text;
    line-height: 1;
    margin-block-end: var(--space-4);
  }

  .pillar-card__title {
    font-family: var(--font-heading);
    font-size: var(--size-xl);
    font-weight: 600;
    margin-block-end: var(--space-3);
    color: var(--color-text);
  }

  .pillar-card__text {
    color: var(--color-text-muted);
    line-height: 1.7;
  }

  
  .comparison__grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: var(--space-6);
  }

  .comparison__card {
    border-radius: var(--radius-lg);
    overflow: hidden;
    border: 1px solid var(--color-border);
    box-shadow: var(--shadow-sm);
    transition: transform var(--transition-base), box-shadow var(--transition-base);
  }

  .comparison__card:hover {
    transform: translateY(-4px);
    box-shadow: var(--shadow-md);
  }

  .comparison__card-header {
    padding: var(--space-5) var(--space-6);
  }

  .comparison__card-header--a {
    background: linear-gradient(135deg, var(--color-pink-light), var(--color-purple-light));
  }

  .comparison__card-header--b {
    background: linear-gradient(135deg, var(--color-purple-light), var(--color-blue-light));
  }

  .comparison__card-header--c {
    background: linear-gradient(135deg, var(--color-blue-light), var(--color-teal-light));
  }

  .comparison__card-header h3 {
    font-family: var(--font-heading);
    font-size: var(--size-lg);
    font-weight: 600;
    color: var(--color-text);
  }

  .comparison__card-body {
    padding: var(--space-6);
    background: var(--color-surface);
  }

  .comparison__card-body p {
    color: var(--color-text-muted);
    line-height: 1.7;
  }

  
  .timeline__detailed {
    display: flex;
    flex-direction: column;
    gap: var(--space-6);
  }

  .timeline__phase {
    border-radius: var(--radius-lg);
    overflow: hidden;
    border: 1px solid var(--color-border);
    box-shadow: var(--shadow-sm);
    transition: box-shadow var(--transition-base);
  }

  .timeline__phase:hover {
    box-shadow: var(--shadow-md);
  }

  .timeline__phase-header {
    display: flex;
    align-items: center;
    gap: var(--space-6);
    padding: var(--space-5) var(--space-6);
  }

  .timeline__phase-header--1 { background: linear-gradient(90deg, var(--color-pink-light), rgba(252,231,243,0.3)); }
  .timeline__phase-header--2 { background: linear-gradient(90deg, var(--color-purple-light), rgba(243,232,255,0.3)); }
  .timeline__phase-header--3 { background: linear-gradient(90deg, var(--color-blue-light), rgba(219,234,254,0.3)); }
  .timeline__phase-header--4 { background: linear-gradient(90deg, var(--color-teal-light), rgba(204,251,241,0.3)); }
  .timeline__phase-header--5 { background: linear-gradient(90deg, #fef9c3, rgba(254,249,195,0.3)); }

  .timeline__phase-num {
    font-family: var(--font-heading);
    font-size: var(--size-sm);
    font-weight: 700;
    color: var(--color-purple);
    background: rgba(255,255,255,0.7);
    padding: var(--space-2) var(--space-4);
    border-radius: var(--radius-full);
    white-space: nowrap;
  }

  .timeline__phase-info {
    display: flex;
    align-items: center;
    gap: var(--space-6);
    flex-wrap: wrap;
  }

  .timeline__phase-title {
    font-family: var(--font-heading);
    font-size: var(--size-lg);
    font-weight: 600;
    color: var(--color-text);
  }

  .timeline__phase-duration {
    font-size: var(--size-sm);
    color: var(--color-text-muted);
    display: flex;
    align-items: center;
    gap: var(--space-2);
  }

  .timeline__phase-body {
    padding: var(--space-6);
    background: var(--color-surface);
    display: flex;
    flex-direction: column;
    gap: var(--space-4);
  }

  .timeline__phase-body p {
    color: var(--color-text-muted);
    line-height: 1.7;
  }

  .timeline__phase-outputs {
    background: var(--color-bg-light);
    border-radius: var(--radius-md);
    padding: var(--space-4) var(--space-5);
  }

  .timeline__phase-outputs h4 {
    font-size: var(--size-sm);
    font-weight: 700;
    color: var(--color-text);
    margin-block-end: var(--space-3);
    text-transform: uppercase;
    letter-spacing: 0.05em;
  }

  .timeline__phase-outputs ul {
    list-style: none;
    display: flex;
    flex-direction: column;
    gap: var(--space-2);
  }

  .timeline__phase-outputs li {
    font-size: var(--size-sm);
    color: var(--color-text-muted);
    padding-inline-start: var(--space-5);
    position: relative;
  }

  .timeline__phase-outputs li::before {
    content: '';
    position: absolute;
    inset-inline-start: 0;
    inset-block-start: 50%;
    transform: translateY(-50%);
    inline-size: 8px;
    block-size: 8px;
    border-radius: 50%;
    background: var(--gradient-btn);
  }

  
  .faq__grid {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: var(--space-6);
  }

  .faq__item {
    background: var(--color-surface);
    border-radius: var(--radius-lg);
    padding: var(--space-6);
    border: 1px solid var(--color-border);
    box-shadow: var(--shadow-sm);
    transition: transform var(--transition-base), box-shadow var(--transition-base);
  }

  .faq__item:hover {
    transform: translateY(-3px);
    box-shadow: var(--shadow-md);
  }

  .faq__question {
    font-family: var(--font-heading);
    font-size: var(--size-lg);
    font-weight: 600;
    color: var(--color-text);
    margin-block-end: var(--space-3);
  }

  .faq__answer {
    color: var(--color-text-muted);
    line-height: 1.7;
  }

  
  .info-banner {
    display: flex;
    gap: var(--space-5);
    align-items: flex-start;
    background: linear-gradient(135deg, var(--color-blue-light), var(--color-purple-light));
    border-radius: var(--radius-lg);
    padding: var(--space-6);
    border: 1px solid rgba(96, 165, 250, 0.3);
  }

  .info-banner__icon {
    font-size: var(--size-2xl);
    color: #2563eb;
    flex-shrink: 0;
    margin-block-start: var(--space-1);
  }

  .info-banner__title {
    font-family: var(--font-heading);
    font-size: var(--size-lg);
    font-weight: 600;
    color: var(--color-text);
    margin-block-end: var(--space-2);
  }

  .info-banner__text {
    color: var(--color-text-muted);
    line-height: 1.7;
  }

  
  .project-types__grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: var(--space-6);
  }

  .project-card {
    background: var(--color-surface);
    border-radius: var(--radius-lg);
    overflow: hidden;
    border: 1px solid var(--color-border);
    box-shadow: var(--shadow-sm);
    transition: transform var(--transition-base), box-shadow var(--transition-base);
  }

  .project-card:hover {
    transform: translateY(-6px);
    box-shadow: var(--shadow-lg);
  }

  .project-card__img-wrap {
    overflow: hidden;
    block-size: 200px;
  }

  .project-card__img {
    inline-size: 100%;
    block-size: 100%;
    object-fit: cover;
    transition: transform var(--transition-slow);
  }

  .project-card:hover .project-card__img {
    transform: scale(1.06);
  }

  .project-card__content {
    padding: var(--space-6);
    display: flex;
    flex-direction: column;
    gap: var(--space-3);
  }

  .project-card__tag {
    display: inline-block;
    font-size: var(--size-xs);
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.08em;
    color: var(--color-purple-dark);
    background: var(--color-purple-light);
    padding: var(--space-1) var(--space-3);
    border-radius: var(--radius-full);
  }

  .project-card__title {
    font-family: var(--font-heading);
    font-size: var(--size-lg);
    font-weight: 600;
    color: var(--color-text);
  }

  .project-card__text {
    color: var(--color-text-muted);
    line-height: 1.7;
    font-size: var(--size-sm);
  }

  
  .industries__grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: var(--space-5);
  }

  .industry-card {
    background: var(--color-surface);
    border-radius: var(--radius-lg);
    padding: var(--space-6);
    border: 1px solid var(--color-border);
    box-shadow: var(--shadow-sm);
    transition: transform var(--transition-base), box-shadow var(--transition-base), border-color var(--transition-base);
  }

  .industry-card:hover {
    transform: translateY(-4px);
    box-shadow: var(--shadow-md);
    border-color: var(--color-purple);
  }

  .industry-card__icon {
    font-size: var(--size-2xl);
    background: var(--gradient-main);
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    background-clip: text;
    margin-block-end: var(--space-4);
    display: block;
  }

  .industry-card__title {
    font-family: var(--font-heading);
    font-size: var(--size-lg);
    font-weight: 600;
    color: var(--color-text);
    margin-block-end: var(--space-3);
  }

  .industry-card p {
    color: var(--color-text-muted);
    font-size: var(--size-sm);
    line-height: 1.7;
  }

  
  .contact-section__inner {
    display: flex;
    flex-direction: column;
    gap: var(--space-12);
  }

  .contact-info {
    display: grid;
    grid-template-columns: 1fr 1.5fr;
    gap: var(--space-12);
    align-items: start;
  }

  .contact-info__title {
    font-family: var(--font-heading);
    font-size: var(--size-2xl);
    font-weight: 700;
    color: var(--color-text);
    margin-block-end: var(--space-6);
    grid-column: 1;
  }

  .contact-info__items {
    display: flex;
    flex-direction: column;
    gap: var(--space-6);
  }

  .contact-info__item {
    display: flex;
    gap: var(--space-4);
    align-items: flex-start;
  }

  .contact-info__icon-wrap {
    inline-size: 44px;
    block-size: 44px;
    border-radius: var(--radius-md);
    background: var(--gradient-soft);
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: var(--size-lg);
    color: var(--color-purple-dark);
    flex-shrink: 0;
    border: 1px solid var(--color-border);
  }

  .contact-info__label {
    font-size: var(--size-sm);
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    color: var(--color-text-light);
    margin-block-end: var(--space-1);
  }

  .contact-info__value {
    color: var(--color-text-muted);
    line-height: 1.6;
  }

  .contact-info__link {
    color: var(--color-purple-dark);
    font-weight: 500;
    transition: color var(--transition-base);
  }

  .contact-info__link:hover {
    color: var(--color-pink-dark);
  }

  
  .contact-form-wrap {
    background: var(--color-surface);
    border-radius: var(--radius-lg);
    padding: var(--space-8);
    border: 1px solid var(--color-border);
    box-shadow: var(--shadow-md);
  }

  .contact-form-wrap__title {
    font-family: var(--font-heading);
    font-size: var(--size-2xl);
    font-weight: 700;
    color: var(--color-text);
    margin-block-end: var(--space-2);
  }

  .contact-form-wrap__desc {
    color: var(--color-text-muted);
    margin-block-end: var(--space-6);
  }

  .contact-form__row {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: var(--space-4);
    margin-block-end: var(--space-4);
  }

  .contact-form__field {
    display: flex;
    flex-direction: column;
    gap: var(--space-2);
    margin-block-end: var(--space-4);
  }

  .contact-form__label {
    font-size: var(--size-sm);
    font-weight: 600;
    color: var(--color-text);
  }

  .contact-form__required {
    color: var(--color-pink-dark);
  }

  .contact-form__input,
  .contact-form__textarea {
    font-family: var(--font-body);
    font-size: var(--size-base);
    color: var(--color-text);
    background: var(--color-bg-light);
    border: 1.5px solid var(--color-border);
    border-radius: var(--radius-md);
    padding: var(--space-3) var(--space-4);
    transition: border-color var(--transition-base), box-shadow var(--transition-base), background var(--transition-base);
    inline-size: 100%;
    outline: none;
  }

  .contact-form__input:focus,
  .contact-form__textarea:focus {
    border-color: var(--color-purple);
    background: #ffffff;
    box-shadow: 0 0 0 3px rgba(168, 85, 247, 0.12);
  }

  .contact-form__textarea {
    resize: vertical;
    min-block-size: 88px;
  }

  .contact-form__footer {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: var(--space-4);
    flex-wrap: wrap;
  }

  .contact-form__privacy {
    display: flex;
    align-items: flex-start;
    gap: var(--space-3);
    cursor: pointer;
    flex: 1;
  }

  .contact-form__checkbox {
    margin-block-start: 3px;
    inline-size: 18px;
    block-size: 18px;
    flex-shrink: 0;
    accent-color: var(--color-purple);
  }

  .contact-form__privacy-text {
    font-size: var(--size-sm);
    color: var(--color-text-muted);
    line-height: 1.5;
  }

  .contact-form__privacy-link {
    color: var(--color-purple-dark);
    text-decoration: underline;
    text-underline-offset: 2px;
  }

  .contact-form__privacy-link:hover {
    color: var(--color-pink-dark);
  }

  .contact-form__submit {
    flex-shrink: 0;
  }

  .contact-form__note {
    font-size: var(--size-xs);
    color: var(--color-text-light);
    margin-block-start: var(--space-3);
  }

  
  .directions__grid {
    display: grid;
    grid-template-columns: 1fr 1.2fr;
    gap: var(--space-10);
    align-items: start;
  }

  .directions__info {
    display: flex;
    flex-direction: column;
    gap: var(--space-6);
  }

  .directions__method {
    display: flex;
    gap: var(--space-4);
    align-items: flex-start;
  }

  .directions__method-icon {
    inline-size: 44px;
    block-size: 44px;
    border-radius: var(--radius-md);
    background: var(--gradient-soft);
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: var(--size-lg);
    color: var(--color-purple-dark);
    flex-shrink: 0;
    border: 1px solid var(--color-border);
  }

  .directions__method-title {
    font-family: var(--font-heading);
    font-size: var(--size-lg);
    font-weight: 600;
    color: var(--color-text);
    margin-block-end: var(--space-2);
  }

  .directions__method p {
    color: var(--color-text-muted);
    font-size: var(--size-sm);
    line-height: 1.7;
  }

  .directions__map {
    border-radius: var(--radius-lg);
    overflow: hidden;
    box-shadow: var(--shadow-lg);
    border: 1px solid var(--color-border);
  }

  .directions__map-iframe {
    inline-size: 100%;
    block-size: 400px;
    border: none;
    display: block;
  }

  
  .thanks-hero {
    position: relative;
    min-block-size: calc(100dvh - 200px);
    display: flex;
    align-items: center;
    justify-content: center;
    background: var(--gradient-main);
    overflow: hidden;
  }

  .thanks-hero__bg {
    position: absolute;
    inset: 0;
    background: radial-gradient(ellipse at center, rgba(255,255,255,0.15) 0%, transparent 70%);
    pointer-events: none;
  }

  .thanks-hero__inner {
    text-align: center;
    position: relative;
    z-index: 2;
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: var(--space-6);
  }

  .thanks-hero__icon {
    font-size: 5rem;
    color: rgba(255,255,255,0.95);
    filter: drop-shadow(0 4px 16px rgba(0,0,0,0.2));
  }

  .thanks-hero__title {
    font-family: var(--font-heading);
    font-size: clamp(2.5rem, 5vw, 4rem);
    font-weight: 700;
    color: #ffffff;
    line-height: 1.1;
  }

  .thanks-hero__text {
    font-size: var(--size-lg);
    color: rgba(255,255,255,0.88);
    max-inline-size: 50ch;
    line-height: 1.75;
  }

  
  .legal-content__inner {
    max-inline-size: 800px;
    margin-inline: auto;
  }

  .legal-content__body {
    display: flex;
    flex-direction: column;
    gap: var(--space-6);
  }

  .legal-content__body h2 {
    font-family: var(--font-heading);
    font-size: var(--size-xl);
    font-weight: 600;
    color: var(--color-text);
    padding-block-start: var(--space-4);
    border-block-start: 2px solid var(--color-border);
    margin-block-start: var(--space-2);
  }

  .legal-content__body p {
    color: var(--color-text-muted);
    line-height: 1.8;
  }

  
  .footer {
    background: linear-gradient(145deg, #0f0a1e, #1a1033, #0d1f3c);
    padding-block: var(--space-16) var(--space-8);
    margin-block-start: auto;
  }

  .footer__top {
    display: grid;
    grid-template-columns: 2fr 1fr 1fr 1.5fr;
    gap: var(--space-8);
    padding-block-end: var(--space-10);
    border-block-end: 1px solid rgba(255,255,255,0.08);
    margin-block-end: var(--space-6);
  }

  .footer__logo {
    block-size: 36px;
    inline-size: auto;
    margin-block-end: var(--space-4);
    filter: brightness(0) invert(1);
  }

  .footer__tagline {
    font-size: var(--size-sm);
    color: rgba(255,255,255,0.55);
    line-height: 1.7;
    margin-block-end: var(--space-3);
  }

  .footer__disclaimer {
    font-size: var(--size-xs);
    color: rgba(255,255,255,0.35);
    line-height: 1.6;
  }

  .footer__nav-title {
    font-size: var(--size-xs);
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.1em;
    color: rgba(255,255,255,0.4);
    margin-block-end: var(--space-4);
  }

  .footer__nav-list {
    display: flex;
    flex-direction: column;
    gap: var(--space-2);
  }

  .footer__nav-link {
    font-size: var(--size-sm);
    color: rgba(255,255,255,0.55);
    transition: color var(--transition-base);
    position: relative;
    display: inline-block;
  }

  .footer__nav-link::after {
    content: '';
    position: absolute;
    inset-block-end: -1px;
    inset-inline-start: 0;
    inline-size: 0;
    block-size: 1px;
    background: var(--gradient-btn);
    transition: inline-size var(--transition-base);
  }

  .footer__nav-link:hover {
    color: rgba(255,255,255,0.9);
  }

  .footer__nav-link:hover::after {
    inline-size: 100%;
  }

  .footer__address {
    display: flex;
    flex-direction: column;
    gap: var(--space-3);
    font-size: var(--size-sm);
    color: rgba(255,255,255,0.55);
    line-height: 1.6;
  }

  .footer__address i {
    color: var(--color-pink);
    margin-inline-end: var(--space-2);
  }

  .footer__contact-link {
    color: rgba(255,255,255,0.55);
    transition: color var(--transition-base);
  }

  .footer__contact-link:hover {
    color: var(--color-pink);
  }

  .footer__contact-link i {
    color: var(--color-purple);
    margin-inline-end: var(--space-2);
  }

  .footer__bottom {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: var(--space-4);
    flex-wrap: wrap;
  }

  .footer__copy {
    font-size: var(--size-xs);
    color: rgba(255,255,255,0.3);
  }

  .footer__legal-note {
    font-size: var(--size-xs);
    color: rgba(255,255,255,0.25);
  }

  
  .sidebar-cta {
    position: fixed;
    inset-inline-end: var(--space-5);
    inset-block-end: var(--space-20);
    z-index: 800;
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: var(--space-2);
  }

  .sidebar-cta__btn {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: var(--space-2);
    background: var(--gradient-btn);
    color: #ffffff;
    border-radius: var(--radius-lg);
    padding: var(--space-3) var(--space-4);
    box-shadow: var(--shadow-btn);
    font-size: var(--size-xs);
    font-weight: 600;
    transition: transform var(--transition-base), box-shadow var(--transition-base);
    min-block-size: 64px;
    text-align: center;
  }

  .sidebar-cta__btn i {
    font-size: var(--size-xl);
  }

  .sidebar-cta__btn:hover {
    transform: translateY(-3px) scale(1.05);
    box-shadow: var(--shadow-lg), var(--shadow-glow);
    color: #ffffff;
  }

  .sidebar-cta__label {
    line-height: 1;
  }

  
  .cookie-trigger {
    position: fixed;
    inset-block-end: var(--space-5);
    inset-inline-end: var(--space-5);
    z-index: 1100;
  }

  .cookie-trigger__btn {
    inline-size: 48px;
    block-size: 48px;
    border-radius: 50%;
    background: var(--gradient-btn);
    border: none;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: var(--size-lg);
    color: #ffffff;
    box-shadow: var(--shadow-btn);
    transition: transform var(--transition-base), box-shadow var(--transition-base);
    position: relative;
  }

  .cookie-trigger__btn:hover {
    transform: scale(1.1);
    box-shadow: var(--shadow-lg), var(--shadow-glow);
  }

  .cookie-trigger__badge {
    position: absolute;
    inset-block-start: -4px;
    inset-inline-end: -4px;
    inline-size: 14px;
    block-size: 14px;
    border-radius: 50%;
    background: var(--color-pink);
    border: 2px solid #ffffff;
    display: none;
  }

  .cookie-trigger__badge.is-visible {
    display: block;
  }

  .cookie-panel {
    position: fixed;
    inset-block-end: 70px;
    inset-inline-end: var(--space-5);
    inline-size: 340px;
    background: #ffffff;
    border-radius: var(--radius-lg);
    box-shadow: var(--shadow-xl);
    border: 1px solid var(--color-border);
    z-index: 1050;
    transform: translateY(20px);
    opacity: 0;
    pointer-events: none;
    transition: transform var(--transition-base), opacity var(--transition-base);
  }

  .cookie-panel.is-open {
    transform: translateY(0);
    opacity: 1;
    pointer-events: all;
  }

  .cookie-panel__header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: var(--space-4) var(--space-5);
    border-block-end: 1px solid var(--color-border);
  }

  .cookie-panel__title {
    font-family: var(--font-heading);
    font-size: var(--size-lg);
    font-weight: 600;
    color: var(--color-text);
    display: flex;
    align-items: center;
    gap: var(--space-2);
  }

  .cookie-panel__title i {
    color: var(--color-purple);
  }

  .cookie-panel__close {
    background: none;
    border: none;
    cursor: pointer;
    font-size: var(--size-lg);
    color: var(--color-text-muted);
    padding: var(--space-1);
    border-radius: var(--radius-sm);
    transition: color var(--transition-base), background var(--transition-base);
    min-block-size: 32px;
    min-inline-size: 32px;
    display: flex;
    align-items: center;
    justify-content: center;
  }

  .cookie-panel__close:hover {
    color: var(--color-text);
    background: var(--color-bg-light);
  }

  .cookie-panel__body {
    padding: var(--space-5);
    display: flex;
    flex-direction: column;
    gap: var(--space-4);
  }

  .cookie-panel__desc {
    font-size: var(--size-sm);
    color: var(--color-text-muted);
    line-height: 1.6;
  }

  .cookie-category {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: var(--space-4);
    padding: var(--space-3);
    background: var(--color-bg-light);
    border-radius: var(--radius-md);
    border: 1px solid var(--color-border);
  }

  .cookie-category__info {
    flex: 1;
  }

  .cookie-category__name {
    font-size: var(--size-sm);
    font-weight: 600;
    color: var(--color-text);
    margin-block-end: var(--space-1);
  }

  .cookie-category__desc {
    font-size: var(--size-xs);
    color: var(--color-text-muted);
  }

  .cookie-toggle {
    position: relative;
    inline-size: 44px;
    block-size: 24px;
    flex-shrink: 0;
  }

  .cookie-toggle input {
    opacity: 0;
    inline-size: 0;
    block-size: 0;
  }

  .cookie-toggle__slider {
    position: absolute;
    inset: 0;
    background: var(--color-border);
    border-radius: var(--radius-full);
    cursor: pointer;
    transition: background var(--transition-base);
  }

  .cookie-toggle__slider::before {
    content: '';
    position: absolute;
    block-size: 18px;
    inline-size: 18px;
    inset-inline-start: 3px;
    inset-block-start: 3px;
    background: #ffffff;
    border-radius: 50%;
    transition: transform var(--transition-base);
    box-shadow: var(--shadow-sm);
  }

  .cookie-toggle input:checked + .cookie-toggle__slider {
    background: var(--gradient-btn);
  }

  .cookie-toggle input:checked + .cookie-toggle__slider::before {
    transform: translateX(20px);
  }

  .cookie-toggle input:disabled + .cookie-toggle__slider {
    opacity: 0.7;
    cursor: not-allowed;
  }

  .cookie-panel__footer {
    padding: var(--space-4) var(--space-5);
    border-block-start: 1px solid var(--color-border);
    display: flex;
    flex-direction: column;
    gap: var(--space-3);
  }

  .cookie-panel__accept-all {
    inline-size: 100%;
    justify-content: center;
  }

  .cookie-panel__save {
    inline-size: 100%;
    justify-content: center;
    background: var(--color-bg-light);
    color: var(--color-text-muted);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-full);
    padding: var(--space-2) var(--space-4);
    font-size: var(--size-sm);
    font-weight: 600;
    cursor: pointer;
    transition: all var(--transition-base);
  }

  .cookie-panel__save:hover {
    background: var(--color-border);
    color: var(--color-text);
  }

  .cookie-panel__link {
    font-size: var(--size-xs);
    color: var(--color-text-light);
    text-align: center;
    display: block;
  }

  .cookie-panel__link a {
    color: var(--color-purple-dark);
    text-decoration: underline;
    text-underline-offset: 2px;
  }
}

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

    .footer__top {
      grid-template-columns: 1fr 1fr;
      gap: var(--space-8);
    }

    .footer__brand {
      grid-column: span 2;
    }

    .hero__inner {
      gap: var(--space-8);
    }

    .industries__grid {
      grid-template-columns: repeat(2, 1fr);
    }

    .project-types__grid {
      grid-template-columns: 1fr 1fr;
    }

    .comparison__grid {
      grid-template-columns: 1fr;
      max-inline-size: 560px;
      margin-inline: auto;
    }
  }

  @media (max-width: 768px) {
    :root {
      --space-20: 3.5rem;
      --space-16: 3rem;
    }

    .nav__menu,
    .nav__cta {
      display: none;
    }

    .nav__hamburger {
      display: flex;
    }

    .nav__container {
      padding: var(--space-3) var(--space-4);
    }

    .hero__inner {
      grid-template-columns: 1fr;
      text-align: center;
    }

    .hero__content {
      align-items: center;
    }

    .hero__visual {
      order: -1;
    }

    .hero__atropos {
      max-inline-size: 320px;
    }

    .hero__card-img {
      block-size: 240px;
    }

    .hero__floating-badge {
      display: none;
    }

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

    .about__img {
      block-size: 300px;
    }

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

    .why-teaser__inner {
      grid-template-columns: 1fr;
    }

    .why-teaser__img {
      block-size: 260px;
    }

    .two-col {
      grid-template-columns: 1fr;
    }

    .two-col--reverse {
      direction: ltr;
    }

    .two-col__img {
      block-size: 260px;
    }

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

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

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

    .project-types__grid {
      grid-template-columns: 1fr;
    }

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

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

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

    .contact-form__footer {
      flex-direction: column;
      align-items: flex-start;
    }

    .contact-form__submit {
      inline-size: 100%;
      justify-content: center;
    }

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

    .directions__map-iframe {
      block-size: 280px;
    }

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

    .footer__brand {
      grid-column: span 1;
    }

    .footer__bottom {
      flex-direction: column;
      align-items: center;
      text-align: center;
    }

    .intro-strip__divider {
      display: none;
    }

    .intro-strip__inner {
      gap: var(--space-4);
    }

    .journey__track {
      padding-inline-start: var(--space-10);
    }

    .journey__step-marker {
      inset-inline-start: calc(-1 * var(--space-10));
    }

    .sidebar-cta {
      inset-inline-end: var(--space-3);
      inset-block-end: var(--space-16);
    }

    .cookie-panel {
      inline-size: calc(100vw - var(--space-8));
      inset-inline-end: var(--space-4);
    }

    .page-hero {
      padding-block: 120px var(--space-10);
    }

    .timeline__phase-info {
      flex-direction: column;
      gap: var(--space-2);
    }
  }

  @media (max-width: 480px) {
    .container {
      padding-inline: var(--space-4);
    }

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

    .hero__actions .btn {
      text-align: center;
      justify-content: center;
    }

    .nav {
      inset-block-start: var(--space-3);
      inset-inline: var(--space-3);
    }

    .mobile-menu {
      inline-size: 280px;
    }
  }
}