/* ============================================================
   ZENIVDRAX - Neo Brutalist Design System
   Custom CSS - No Framework
   ============================================================ */

/* --- CUSTOM PROPERTIES --- */
:root {
  --color-primary: #1A1A2E;
  --color-secondary: #E63946;
  --color-accent: #F4D35E;
  --color-accent-dark: #D4B53E;
  --color-bg: #FAF8F3;
  --color-bg-alt: #F5F0E8;
  --color-bg-dark: #1A1A2E;
  --color-text: #1C1C2E;
  --color-text-muted: #5A5A7A;
  --color-text-light: #FAF8F3;
  --color-border: #1A1A2E;
  --color-white: #FFFFFF;

  --shadow-hard-sm: 3px 3px 0 var(--color-border);
  --shadow-hard-md: 5px 5px 0 var(--color-border);
  --shadow-hard-lg: 8px 8px 0 var(--color-border);
  --shadow-hard-accent: 5px 5px 0 var(--color-secondary);
  --shadow-hard-yellow: 5px 5px 0 var(--color-accent);

  --border-width: 2px;
  --border-width-thick: 3px;
  --border-radius-sm: 4px;
  --border-radius-md: 8px;
  --border-radius-lg: 16px;
  --border-radius-pill: 999px;

  --space-xs: 0.5rem;
  --space-sm: 1rem;
  --space-md: 1.5rem;
  --space-lg: 2.5rem;
  --space-xl: 4rem;
  --space-2xl: 6rem;

  --font-heading: 'Familjen Grotesk', sans-serif;
  --font-body: 'DM Sans', sans-serif;

  --nav-height: 72px;
  --transition-fast: 150ms ease;
  --transition-med: 280ms ease;
  --transition-slow: 450ms ease;
}

/* --- PACE CUSTOMIZATION --- */
.pace .pace-progress {
  background: var(--color-secondary);
  height: 3px;
}
.pace .pace-progress-inner {
  box-shadow: 0 0 10px var(--color-secondary), 0 0 5px var(--color-secondary);
}

/* --- RESET & BASE --- */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }

html {
  font-size: 16px;
  scroll-behavior: smooth;
  -webkit-text-size-adjust: 100%;
}

body {
  font-family: var(--font-body);
  background-color: var(--color-bg);
  color: var(--color-text);
  line-height: 1.65;
  overflow-x: hidden;
  min-height: 100vh;
  display: flex;
  flex-direction: column;
}

main { flex: 1; }

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

a {
  color: inherit;
  text-decoration: none;
  transition: color var(--transition-fast), opacity var(--transition-fast);
}

ul { list-style: none; }

address { font-style: normal; }

/* --- TYPOGRAPHY --- */
h1, h2, h3, h4, h5, h6 {
  font-family: var(--font-heading);
  font-weight: 700;
  line-height: 1.15;
  color: var(--color-text);
}

h1 { font-size: clamp(2.2rem, 5vw, 4rem); }
h2 { font-size: clamp(1.6rem, 3.5vw, 2.6rem); }
h3 { font-size: clamp(1.2rem, 2.5vw, 1.6rem); }
h4 { font-size: 1.1rem; }

p {
  font-size: clamp(0.95rem, 1.5vw, 1.05rem);
  line-height: 1.75;
  color: var(--color-text-muted);
  max-width: 68ch;
}

strong { color: var(--color-text); font-weight: 600; }

/* --- UTILITIES --- */
.u-container {
  width: 100%;
  max-width: 1240px;
  margin: 0 auto;
  padding: 0 var(--space-md);
}

.u-container--narrow {
  max-width: 860px;
}

.u-text-center { text-align: center; }
.u-text-accent { color: var(--color-secondary); }
.u-hidden { display: none !important; }

/* --- NAVIGATION --- */
.c-nav {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  z-index: 1000;
  background: var(--color-bg);
  border-bottom: var(--border-width-thick) solid var(--color-border);
  height: var(--nav-height);
  transition: transform var(--transition-med);
}

.c-nav.is-hidden {
  transform: translateY(-100%);
}

.c-nav__inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  height: 100%;
  max-width: 1240px;
  margin: 0 auto;
  padding: 0 var(--space-md);
}

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

.c-nav__links {
  display: none;
  gap: var(--space-xs);
  align-items: center;
}

@media (min-width: 1024px) {
  .c-nav__links {
    display: flex;
  }
}

.c-nav__link {
  font-family: var(--font-heading);
  font-weight: 600;
  font-size: 0.9rem;
  padding: 0.5rem 0.75rem;
  border-radius: var(--border-radius-sm);
  color: var(--color-text);
  transition: background var(--transition-fast), color var(--transition-fast), transform var(--transition-fast);
  position: relative;
}

.c-nav__link::after {
  content: '';
  position: absolute;
  bottom: 2px;
  left: 0.75rem;
  right: 0.75rem;
  height: 2px;
  background: var(--color-secondary);
  transform: scaleX(0);
  transform-origin: left;
  transition: transform var(--transition-med);
}

.c-nav__link:hover::after,
.c-nav__link.is-active::after {
  transform: scaleX(1);
}

.c-nav__link:hover {
  color: var(--color-secondary);
  transform: translateY(-1px);
}

.c-nav__link.is-active {
  color: var(--color-secondary);
}

.c-nav__hamburger {
  display: flex;
  flex-direction: column;
  gap: 5px;
  background: none;
  border: none;
  cursor: pointer;
  padding: 10px;
  min-width: 44px;
  min-height: 44px;
  justify-content: center;
  align-items: center;
}

@media (min-width: 1024px) {
  .c-nav__hamburger { display: none; }
}

.c-nav__hamburger span {
  display: block;
  width: 24px;
  height: 2px;
  background: var(--color-text);
  transition: transform var(--transition-med), opacity var(--transition-fast);
  border-radius: 2px;
}

/* --- MOBILE MENU --- */
.c-mobile-menu {
  position: fixed;
  inset: 0;
  z-index: 2000;
  background: var(--color-primary);
  display: flex;
  flex-direction: column;
  padding: var(--space-md);
  opacity: 0;
  pointer-events: none;
  transition: opacity var(--transition-med);
}

.c-mobile-menu.is-open {
  opacity: 1;
  pointer-events: all;
}

.c-mobile-menu__header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding-bottom: var(--space-lg);
  border-bottom: var(--border-width) solid rgba(255,255,255,0.15);
  margin-bottom: var(--space-lg);
}

.c-mobile-menu__close {
  background: none;
  border: var(--border-width) solid rgba(255,255,255,0.3);
  color: var(--color-text-light);
  font-size: 1.4rem;
  width: 44px;
  height: 44px;
  border-radius: var(--border-radius-sm);
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: background var(--transition-fast), border-color var(--transition-fast), transform var(--transition-fast);
}

.c-mobile-menu__close:hover {
  background: rgba(255,255,255,0.1);
  border-color: rgba(255,255,255,0.6);
  transform: rotate(90deg);
}

.c-mobile-menu__grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--space-sm);
  flex: 1;
  align-content: start;
}

.c-mobile-menu__item {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 0.6rem;
  padding: var(--space-md);
  border: var(--border-width) solid rgba(255,255,255,0.15);
  border-radius: var(--border-radius-md);
  color: var(--color-text-light);
  font-family: var(--font-heading);
  font-weight: 600;
  font-size: 0.9rem;
  text-align: center;
  min-height: 100px;
  transition: background var(--transition-fast), border-color var(--transition-fast), transform var(--transition-fast), box-shadow var(--transition-fast);
}

.c-mobile-menu__item i {
  font-size: 1.5rem;
  color: var(--color-accent);
}

.c-mobile-menu__item:hover {
  background: rgba(255,255,255,0.08);
  border-color: var(--color-accent);
  transform: translateY(-3px);
  box-shadow: 0 6px 20px rgba(0,0,0,0.3);
}

/* --- BUTTONS --- */
.c-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 0.5rem;
  font-family: var(--font-heading);
  font-weight: 700;
  font-size: 0.95rem;
  padding: 0.85rem 1.75rem;
  border-radius: var(--border-radius-sm);
  border: var(--border-width-thick) solid var(--color-border);
  cursor: pointer;
  transition:
    transform var(--transition-fast),
    box-shadow var(--transition-fast),
    background var(--transition-fast),
    color var(--transition-fast);
  text-decoration: none;
  min-height: 48px;
  position: relative;
  overflow: hidden;
}

.c-btn--primary {
  background: var(--color-secondary);
  color: var(--color-white);
  border-color: var(--color-secondary);
  box-shadow: var(--shadow-hard-md);
}

.c-btn--primary:hover {
  transform: translate(-3px, -3px);
  box-shadow: 8px 8px 0 var(--color-border);
  background: #c8303c;
}

.c-btn--primary:active {
  transform: translate(2px, 2px);
  box-shadow: 2px 2px 0 var(--color-border);
}

.c-btn--outline {
  background: transparent;
  color: var(--color-text);
  border-color: var(--color-border);
  box-shadow: var(--shadow-hard-md);
}

.c-btn--outline:hover {
  background: var(--color-text);
  color: var(--color-bg);
  transform: translate(-3px, -3px);
  box-shadow: 8px 8px 0 var(--color-accent);
}

.c-btn--outline:active {
  transform: translate(2px, 2px);
  box-shadow: 2px 2px 0 var(--color-accent);
}

.c-btn--full { width: 100%; }

/* --- LABELS --- */
.c-label {
  display: inline-block;
  font-family: var(--font-heading);
  font-weight: 700;
  font-size: 0.75rem;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  padding: 0.3rem 0.75rem;
  background: var(--color-accent);
  color: var(--color-text);
  border: var(--border-width) solid var(--color-border);
  border-radius: var(--border-radius-sm);
  margin-bottom: var(--space-sm);
  box-shadow: var(--shadow-hard-sm);
}

.c-label--dark {
  background: var(--color-primary);
  color: var(--color-text-light);
}

.c-label--light {
  background: var(--color-bg-alt);
  color: var(--color-text);
}

/* --- HERO SECTION --- */
.s-hero {
  padding-top: calc(var(--nav-height) + var(--space-xl));
  padding-bottom: 0;
  background: var(--color-bg);
  overflow: hidden;
}

.s-hero__inner {
  max-width: 1240px;
  margin: 0 auto;
  padding: 0 var(--space-md);
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-xl);
  align-items: center;
}

@media (min-width: 900px) {
  .s-hero__inner {
    grid-template-columns: 1fr 1fr;
  }
}

.s-hero__content { max-width: 560px; }

.s-hero__headline {
  font-size: clamp(2.8rem, 6vw, 5rem);
  font-weight: 700;
  line-height: 1.05;
  margin-bottom: var(--space-md);
  color: var(--color-text);
}

.s-hero__sub {
  font-size: clamp(1rem, 1.8vw, 1.15rem);
  color: var(--color-text-muted);
  margin-bottom: var(--space-lg);
  max-width: 50ch;
}

.s-hero__cta-group {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-sm);
}

/* Bento Grid */
.s-hero__bento {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 12px;
}

.c-bento-card {
  padding: var(--space-md);
  border: var(--border-width-thick) solid var(--color-border);
  border-radius: var(--border-radius-md);
  display: flex;
  flex-direction: column;
  gap: 0.4rem;
  transition: transform var(--transition-fast), box-shadow var(--transition-fast);
}

.c-bento-card:hover {
  transform: translate(-3px, -3px);
}

.c-bento-card i {
  font-size: 1.5rem;
  margin-bottom: 0.25rem;
}

.c-bento-card strong {
  font-family: var(--font-heading);
  font-size: 1.1rem;
  font-weight: 700;
  display: block;
}

.c-bento-card span {
  font-size: 0.82rem;
  color: inherit;
  opacity: 0.8;
  line-height: 1.4;
}

.c-bento-card--accent {
  background: var(--color-secondary);
  color: var(--color-white);
  box-shadow: var(--shadow-hard-md);
}

.c-bento-card--accent:hover {
  box-shadow: 8px 8px 0 var(--color-border);
}

.c-bento-card--dark {
  background: var(--color-primary);
  color: var(--color-text-light);
  box-shadow: var(--shadow-hard-md);
  grid-column: span 2;
}

.c-bento-card--dark:hover {
  box-shadow: 8px 8px 0 var(--color-secondary);
}

.c-bento-card--light {
  background: var(--color-bg-alt);
  color: var(--color-text);
  box-shadow: var(--shadow-hard-md);
}

.c-bento-card--light:hover {
  box-shadow: 8px 8px 0 var(--color-accent);
}

.c-bento-card--yellow {
  background: var(--color-accent);
  color: var(--color-text);
  box-shadow: var(--shadow-hard-md);
}

.c-bento-card--yellow:hover {
  box-shadow: 8px 8px 0 var(--color-secondary);
}

/* Hero Image Strip */
.s-hero__image-strip {
  margin-top: var(--space-xl);
  position: relative;
  height: 380px;
  overflow: hidden;
  border-top: var(--border-width-thick) solid var(--color-border);
}

.s-hero__img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center 30%;
}

/* --- WAVE DIVIDER --- */
.c-wave-divider {
  display: block;
  line-height: 0;
  background: var(--color-bg);
}

.c-wave-divider svg {
  display: block;
  width: 100%;
}

/* --- PROBLEM SECTION --- */
.s-problem {
  background: var(--color-bg-alt);
  padding: var(--space-2xl) 0;
}

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

@media (min-width: 768px) {
  .s-problem__grid {
    grid-template-columns: 1fr 1fr;
  }
}

.s-problem__title {
  margin-bottom: var(--space-md);
}

.s-problem__text p {
  margin-bottom: var(--space-sm);
}

.s-problem__img {
  width: 100%;
  height: 380px;
  object-fit: cover;
  border: var(--border-width-thick) solid var(--color-border);
  border-radius: var(--border-radius-md);
  box-shadow: var(--shadow-hard-lg);
  transition: transform var(--transition-med), box-shadow var(--transition-med);
}

.s-problem__img:hover {
  transform: translate(-4px, -4px);
  box-shadow: 12px 12px 0 var(--color-border);
}

.c-pull-quote {
  margin-top: var(--space-md);
  padding: var(--space-md) var(--space-lg);
  border-left: 5px solid var(--color-secondary);
  background: var(--color-white);
  border-radius: 0 var(--border-radius-md) var(--border-radius-md) 0;
  box-shadow: var(--shadow-hard-sm);
}

.c-pull-quote p {
  font-family: var(--font-heading);
  font-style: italic;
  font-size: 1rem;
  color: var(--color-text);
  max-width: none;
  line-height: 1.6;
}

/* --- WHAT SECTION --- */
.s-what {
  padding: var(--space-2xl) 0;
  background: var(--color-bg);
}

.s-what__header {
  margin-bottom: var(--space-xl);
  max-width: 700px;
}

.s-what__header h2 {
  margin-top: 0.5rem;
}

.s-what__columns {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-xl);
}

@media (min-width: 900px) {
  .s-what__columns {
    grid-template-columns: 1.3fr 1fr;
  }
}

.s-what__lead {
  font-size: clamp(1.05rem, 1.8vw, 1.2rem);
  color: var(--color-text);
  font-weight: 500;
  margin-bottom: var(--space-md);
  max-width: none;
}

.s-what__col-main p {
  margin-bottom: var(--space-sm);
}

.c-info-box {
  display: flex;
  gap: var(--space-sm);
  align-items: flex-start;
  margin-top: var(--space-lg);
  padding: var(--space-md);
  background: var(--color-accent);
  border: var(--border-width-thick) solid var(--color-border);
  border-radius: var(--border-radius-md);
  box-shadow: var(--shadow-hard-sm);
}

.c-info-box i {
  font-size: 1.2rem;
  color: var(--color-text);
  flex-shrink: 0;
  margin-top: 0.1rem;
}

.c-info-box p {
  font-size: 0.9rem;
  color: var(--color-text);
  max-width: none;
  margin: 0;
}

.c-info-box--large {
  padding: var(--space-lg);
  gap: var(--space-md);
}

.c-info-box--large h3 {
  font-size: 1.1rem;
  margin-bottom: 0.5rem;
}

.c-info-box--large p {
  font-size: 0.95rem;
}

.s-what__col-side {
  display: flex;
  flex-direction: column;
  gap: var(--space-sm);
}

.c-card--feature {
  padding: var(--space-md);
  border: var(--border-width-thick) solid var(--color-border);
  border-radius: var(--border-radius-md);
  background: var(--color-white);
  box-shadow: var(--shadow-hard-sm);
  transition: transform var(--transition-fast), box-shadow var(--transition-fast);
}

.c-card--feature:hover {
  transform: translate(-3px, -3px);
  box-shadow: 8px 8px 0 var(--color-border);
}

.c-card__icon {
  width: 44px;
  height: 44px;
  background: var(--color-primary);
  border-radius: var(--border-radius-sm);
  display: flex;
  align-items: center;
  justify-content: center;
  margin-bottom: var(--space-sm);
}

.c-card__icon i {
  color: var(--color-accent);
  font-size: 1.1rem;
}

.c-card--feature h3 {
  font-size: 1rem;
  margin-bottom: 0.4rem;
}

.c-card--feature p {
  font-size: 0.88rem;
  max-width: none;
  margin: 0;
}

/* --- HOW IT WORKS --- */
.s-how {
  padding: var(--space-2xl) 0;
  background: var(--color-primary);
}

.s-how .c-label {
  background: var(--color-accent);
}

.s-how__title {
  color: var(--color-text-light);
  margin-bottom: var(--space-xl);
  margin-top: 0.5rem;
}

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

@media (min-width: 900px) {
  .s-how__steps {
    grid-template-columns: 1fr auto 1fr auto 1fr;
  }
}

.c-step {
  background: var(--color-bg);
  border: var(--border-width-thick) solid var(--color-bg-alt);
  border-radius: var(--border-radius-lg);
  padding: var(--space-lg);
  box-shadow: var(--shadow-hard-lg);
  transition: transform var(--transition-fast), box-shadow var(--transition-fast);
}

.c-step:hover {
  transform: translateY(-6px);
  box-shadow: 8px 14px 0 rgba(0,0,0,0.4);
}

.c-step__number {
  font-family: var(--font-heading);
  font-size: 3rem;
  font-weight: 700;
  color: var(--color-secondary);
  line-height: 1;
  margin-bottom: var(--space-sm);
}

.c-step__icon {
  width: 48px;
  height: 48px;
  background: var(--color-accent);
  border-radius: var(--border-radius-sm);
  display: flex;
  align-items: center;
  justify-content: center;
  margin-bottom: var(--space-sm);
  border: var(--border-width) solid var(--color-border);
}

.c-step__icon i {
  font-size: 1.3rem;
  color: var(--color-text);
}

.c-step h3 {
  font-size: 1.15rem;
  margin-bottom: 0.5rem;
}

.c-step p {
  font-size: 0.9rem;
  max-width: none;
  margin: 0;
}

.c-step__connector {
  display: none;
  color: var(--color-accent);
  font-size: 1.5rem;
  justify-content: center;
  align-items: center;
}

@media (min-width: 900px) {
  .c-step__connector {
    display: flex;
  }
}

/* --- TOPICS SECTION --- */
.s-topics {
  padding: var(--space-2xl) 0;
  background: var(--color-bg-alt);
}

.s-topics__intro {
  margin-bottom: var(--space-xl);
}

.s-topics__intro h2 {
  margin-top: 0.5rem;
}

.s-topics__grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-md);
}

@media (min-width: 600px) {
  .s-topics__grid {
    grid-template-columns: 1fr 1fr;
  }
}

.c-topic-card {
  background: var(--color-white);
  border: var(--border-width-thick) solid var(--color-border);
  border-radius: var(--border-radius-md);
  padding: var(--space-lg);
  box-shadow: var(--shadow-hard-md);
  transition: transform var(--transition-fast), box-shadow var(--transition-fast);
}

.c-topic-card:hover {
  transform: translate(-4px, -4px);
  box-shadow: 9px 9px 0 var(--color-border);
}

.c-topic-card__day {
  display: inline-block;
  font-family: var(--font-heading);
  font-size: 0.72rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  color: var(--color-secondary);
  background: rgba(230, 57, 70, 0.08);
  padding: 0.2rem 0.6rem;
  border-radius: var(--border-radius-sm);
  margin-bottom: var(--space-sm);
}

.c-topic-card h3 {
  font-size: 1.05rem;
  margin-bottom: var(--space-sm);
}

.c-topic-card ul {
  list-style: disc;
  padding-left: 1.2rem;
}

.c-topic-card ul li {
  font-size: 0.88rem;
  color: var(--color-text-muted);
  margin-bottom: 0.35rem;
  line-height: 1.5;
}

/* --- TEAM SECTION --- */
.s-team {
  padding: var(--space-2xl) 0;
  background: var(--color-bg);
}

.s-team__title {
  margin-top: 0.5rem;
  margin-bottom: var(--space-sm);
}

.s-team__sub {
  margin-bottom: var(--space-xl);
  max-width: 60ch;
}

.s-team__grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-lg);
}

@media (min-width: 768px) {
  .s-team__grid {
    grid-template-columns: repeat(3, 1fr);
  }
}

.c-team-card {
  border: var(--border-width-thick) solid var(--color-border);
  border-radius: var(--border-radius-md);
  overflow: hidden;
  background: var(--color-white);
  box-shadow: var(--shadow-hard-md);
  transition: transform var(--transition-fast), box-shadow var(--transition-fast);
}

.c-team-card:hover {
  transform: translate(-4px, -4px);
  box-shadow: 9px 9px 0 var(--color-border);
}

.c-team-card__img-wrap {
  height: 240px;
  overflow: hidden;
  border-bottom: var(--border-width-thick) solid var(--color-border);
}

.c-team-card__img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center top;
  transition: transform var(--transition-slow);
}

.c-team-card:hover .c-team-card__img {
  transform: scale(1.04);
}

.c-team-card__info {
  padding: var(--space-md);
}

.c-team-card__info h3 {
  font-size: 1.1rem;
  margin-bottom: 0.3rem;
}

.c-team-card__role {
  display: block;
  font-size: 0.8rem;
  font-weight: 600;
  color: var(--color-secondary);
  text-transform: uppercase;
  letter-spacing: 0.06em;
  margin-bottom: var(--space-sm);
}

.c-team-card__info p {
  font-size: 0.88rem;
  max-width: none;
  margin: 0;
}

/* --- CTA SECTION --- */
.s-cta {
  padding: var(--space-2xl) 0;
  background: var(--color-bg-alt);
}

.s-cta__grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-xl);
  align-items: start;
}

@media (min-width: 900px) {
  .s-cta__grid {
    grid-template-columns: 1.2fr 1fr;
  }
}

.s-cta__info h2 {
  margin-top: 0.5rem;
  margin-bottom: var(--space-lg);
}

.c-detail-list {
  display: flex;
  flex-direction: column;
  gap: var(--space-md);
}

.c-detail-item {
  display: flex;
  gap: var(--space-md);
  align-items: flex-start;
}

.c-detail-item i {
  font-size: 1.1rem;
  color: var(--color-secondary);
  width: 24px;
  flex-shrink: 0;
  margin-top: 0.15rem;
}

.c-detail-item div {
  display: flex;
  flex-direction: column;
  gap: 0.2rem;
}

.c-detail-item strong {
  font-size: 0.85rem;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  font-family: var(--font-heading);
}

.c-detail-item span {
  font-size: 0.95rem;
  color: var(--color-text-muted);
}

.c-card--cta {
  background: var(--color-primary);
  border: var(--border-width-thick) solid var(--color-border);
  border-radius: var(--border-radius-lg);
  padding: var(--space-xl);
  box-shadow: var(--shadow-hard-lg);
}

.c-card--cta h3 {
  color: var(--color-text-light);
  font-size: 1.4rem;
  margin-bottom: var(--space-sm);
}

.c-card--cta p {
  color: rgba(250,248,243,0.75);
  max-width: none;
  margin-bottom: var(--space-lg);
}

.c-card__contact {
  margin-top: var(--space-md);
  display: flex;
  flex-direction: column;
  gap: 0.6rem;
  border-top: 1px solid rgba(255,255,255,0.15);
  padding-top: var(--space-md);
}

.c-card__contact a {
  color: rgba(250,248,243,0.7);
  font-size: 0.9rem;
  display: flex;
  align-items: center;
  gap: 0.5rem;
  transition: color var(--transition-fast);
}

.c-card__contact a:hover {
  color: var(--color-accent);
}

.c-card__contact i {
  font-size: 0.9rem;
  color: var(--color-accent);
}

/* --- PAGE HERO --- */
.s-page-hero {
  padding-top: calc(var(--nav-height) + var(--space-2xl));
  padding-bottom: var(--space-xl);
  background: var(--color-bg);
  border-bottom: var(--border-width-thick) solid var(--color-border);
}

.s-page-hero--about {
  background: var(--color-primary);
}

.s-page-hero--about h1,
.s-page-hero--about .s-page-hero__sub {
  color: var(--color-text-light);
}

.s-page-hero--about .c-label {
  background: var(--color-accent);
}

.s-page-hero--public {
  background: var(--color-bg-alt);
}

.s-page-hero h1 {
  margin-top: 0.5rem;
  max-width: 700px;
}

.s-page-hero__sub {
  margin-top: var(--space-md);
  font-size: clamp(1rem, 1.8vw, 1.15rem);
  max-width: 60ch;
}

/* --- ABOUT STORY --- */
.s-about-story {
  padding: var(--space-2xl) 0;
}

.s-about-story__grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-xl);
  align-items: center;
}

@media (min-width: 900px) {
  .s-about-story__grid {
    grid-template-columns: 1.2fr 1fr;
  }
}

.s-about-story__text h2 {
  margin-bottom: var(--space-md);
}

.s-about-story__text p {
  margin-bottom: var(--space-sm);
}

.s-about-story__img {
  width: 100%;
  height: 400px;
  object-fit: cover;
  border: var(--border-width-thick) solid var(--color-border);
  border-radius: var(--border-radius-md);
  box-shadow: var(--shadow-hard-lg);
  transition: transform var(--transition-med), box-shadow var(--transition-med);
}

.s-about-story__img:hover {
  transform: translate(-4px, -4px);
  box-shadow: 12px 12px 0 var(--color-border);
}

/* --- VALUES --- */
.s-values {
  padding: var(--space-2xl) 0;
  background: var(--color-bg-alt);
}

.s-values__title {
  margin-bottom: var(--space-xl);
}

.s-values__grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-md);
}

@media (min-width: 600px) {
  .s-values__grid {
    grid-template-columns: 1fr 1fr;
  }
}

.c-value-card {
  background: var(--color-white);
  border: var(--border-width-thick) solid var(--color-border);
  border-radius: var(--border-radius-md);
  padding: var(--space-lg);
  box-shadow: var(--shadow-hard-sm);
  transition: transform var(--transition-fast), box-shadow var(--transition-fast);
}

.c-value-card:hover {
  transform: translate(-3px, -3px);
  box-shadow: 8px 8px 0 var(--color-border);
}

.c-value-card__icon {
  width: 52px;
  height: 52px;
  background: var(--color-primary);
  border-radius: var(--border-radius-sm);
  display: flex;
  align-items: center;
  justify-content: center;
  margin-bottom: var(--space-md);
  border: var(--border-width) solid var(--color-border);
}

.c-value-card__icon i {
  font-size: 1.3rem;
  color: var(--color-accent);
}

.c-value-card h3 {
  font-size: 1.05rem;
  margin-bottom: 0.5rem;
}

.c-value-card p {
  font-size: 0.9rem;
  max-width: none;
  margin: 0;
}

/* --- MISSION --- */
.s-mission {
  padding: var(--space-2xl) 0;
  background: var(--color-bg);
}

.s-mission__inner {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-xl);
  align-items: start;
}

@media (min-width: 900px) {
  .s-mission__inner {
    grid-template-columns: 1fr 1fr;
  }
}

.c-big-quote {
  position: relative;
  padding: var(--space-xl) var(--space-lg);
  background: var(--color-primary);
  border: var(--border-width-thick) solid var(--color-border);
  border-radius: var(--border-radius-lg);
  box-shadow: var(--shadow-hard-lg);
}

.c-big-quote__mark {
  display: block;
  font-family: var(--font-heading);
  font-size: 6rem;
  line-height: 0.6;
  color: var(--color-secondary);
  margin-bottom: var(--space-md);
}

.c-big-quote p {
  font-family: var(--font-heading);
  font-size: 1.1rem;
  color: var(--color-text-light);
  line-height: 1.7;
  max-width: none;
}

.s-mission__text h2 {
  margin-bottom: var(--space-md);
}

.s-mission__text p {
  margin-bottom: var(--space-sm);
}

/* --- FEATURE DETAIL (caratteristiche) --- */
.s-feature-detail {
  padding: var(--space-2xl) 0;
  background: var(--color-bg);
}

.s-feature-detail--alt {
  background: var(--color-bg-alt);
}

.s-feature-detail__grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-xl);
  align-items: center;
}

@media (min-width: 900px) {
  .s-feature-detail__grid {
    grid-template-columns: 1fr 1fr;
  }

  .s-feature-detail__grid--reverse {
    direction: rtl;
  }

  .s-feature-detail__grid--reverse > * {
    direction: ltr;
  }
}

.s-feature-detail__lead {
  font-size: 1.1rem;
  color: var(--color-text);
  font-weight: 500;
  margin-bottom: var(--space-md);
  max-width: none;
}

.s-feature-detail__content p {
  margin-bottom: var(--space-sm);
}

.s-feature-detail__img {
  width: 100%;
  height: 380px;
  object-fit: cover;
  border: var(--border-width-thick) solid var(--color-border);
  border-radius: var(--border-radius-md);
  box-shadow: var(--shadow-hard-lg);
  transition: transform var(--transition-med), box-shadow var(--transition-med);
}

.s-feature-detail__img:hover {
  transform: translate(-4px, -4px);
  box-shadow: 12px 12px 0 var(--color-border);
}

.c-feature-list {
  margin-top: var(--space-lg);
  display: flex;
  flex-direction: column;
  gap: 0.6rem;
}

.c-feature-list li {
  display: flex;
  gap: 0.75rem;
  align-items: flex-start;
  font-size: 0.95rem;
  color: var(--color-text-muted);
}

.c-feature-list li i {
  color: var(--color-secondary);
  flex-shrink: 0;
  margin-top: 0.2rem;
}

/* --- CASES --- */
.s-cases {
  padding: var(--space-2xl) 0;
  background: var(--color-primary);
}

.s-cases__header {
  margin-bottom: var(--space-xl);
  max-width: 700px;
}

.s-cases__header h2 {
  color: var(--color-text-light);
  margin-bottom: var(--space-sm);
}

.s-cases__header p {
  color: rgba(250,248,243,0.7);
  max-width: none;
}

.s-cases__header .c-label {
  background: var(--color-accent);
}

.s-cases__grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-md);
}

@media (min-width: 768px) {
  .s-cases__grid {
    grid-template-columns: repeat(3, 1fr);
  }
}

.c-case-card {
  background: var(--color-bg);
  border: var(--border-width-thick) solid var(--color-bg-alt);
  border-radius: var(--border-radius-md);
  padding: var(--space-lg);
  box-shadow: var(--shadow-hard-md);
  transition: transform var(--transition-fast), box-shadow var(--transition-fast);
}

.c-case-card:hover {
  transform: translateY(-5px);
  box-shadow: 5px 10px 0 rgba(0,0,0,0.35);
}

.c-case-card__sector {
  font-family: var(--font-heading);
  font-size: 0.78rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--color-secondary);
  margin-bottom: var(--space-sm);
  display: flex;
  align-items: center;
  gap: 0.4rem;
}

.c-case-card h3 {
  font-size: 1rem;
  margin-bottom: 0.5rem;
}

.c-case-card p {
  font-size: 0.88rem;
  max-width: none;
  margin: 0;
}

/* --- CTA PAGE --- */
.s-cta-page {
  padding: var(--space-2xl) 0;
  background: var(--color-accent);
  border-top: var(--border-width-thick) solid var(--color-border);
  border-bottom: var(--border-width-thick) solid var(--color-border);
  text-align: center;
}

.s-cta-page h2 {
  margin-bottom: var(--space-sm);
}

.s-cta-page p {
  margin: 0 auto var(--space-lg);
  max-width: 55ch;
}

/* --- PUBLIC PAGE --- */
.s-public-context {
  padding: var(--space-2xl) 0;
}

.s-public-context__grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-xl);
  align-items: center;
}

@media (min-width: 900px) {
  .s-public-context__grid {
    grid-template-columns: 1.2fr 1fr;
  }
}

.s-public-context__text h2 {
  margin-bottom: var(--space-md);
}

.s-public-context__text p {
  margin-bottom: var(--space-sm);
}

.s-public-context__img {
  width: 100%;
  height: 380px;
  object-fit: cover;
  border: var(--border-width-thick) solid var(--color-border);
  border-radius: var(--border-radius-md);
  box-shadow: var(--shadow-hard-lg);
  transition: transform var(--transition-med), box-shadow var(--transition-med);
}

.s-public-context__img:hover {
  transform: translate(-4px, -4px);
  box-shadow: 12px 12px 0 var(--color-border);
}

.s-public-profiles {
  padding: var(--space-2xl) 0;
  background: var(--color-bg-alt);
}

.s-public-profiles__title {
  margin-bottom: var(--space-xl);
}

.s-public-profiles__grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-md);
}

@media (min-width: 600px) {
  .s-public-profiles__grid {
    grid-template-columns: 1fr 1fr;
  }
}

.c-profile-card {
  background: var(--color-white);
  border: var(--border-width-thick) solid var(--color-border);
  border-radius: var(--border-radius-md);
  padding: var(--space-lg);
  box-shadow: var(--shadow-hard-sm);
  transition: transform var(--transition-fast), box-shadow var(--transition-fast);
}

.c-profile-card:hover {
  transform: translate(-3px, -3px);
  box-shadow: 8px 8px 0 var(--color-border);
}

.c-profile-card__icon {
  width: 52px;
  height: 52px;
  background: var(--color-secondary);
  border-radius: var(--border-radius-sm);
  display: flex;
  align-items: center;
  justify-content: center;
  margin-bottom: var(--space-md);
  border: var(--border-width) solid var(--color-border);
  box-shadow: var(--shadow-hard-sm);
}

.c-profile-card__icon i {
  font-size: 1.3rem;
  color: var(--color-white);
}

.c-profile-card h3 {
  font-size: 1.05rem;
  margin-bottom: 0.5rem;
}

.c-profile-card p {
  font-size: 0.9rem;
  max-width: none;
  margin: 0;
}

.s-public-adapt {
  padding: var(--space-2xl) 0;
}

.s-public-adapt__inner {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-xl);
  align-items: center;
}

@media (min-width: 900px) {
  .s-public-adapt__inner {
    grid-template-columns: 1.2fr 1fr;
  }
}

.s-public-adapt__text h2 {
  margin-bottom: var(--space-md);
}

.s-public-adapt__text p {
  margin-bottom: var(--space-sm);
}

.s-public-adapt__img {
  width: 100%;
  height: 380px;
  object-fit: cover;
  border: var(--border-width-thick) solid var(--color-border);
  border-radius: var(--border-radius-md);
  box-shadow: var(--shadow-hard-lg);
  transition: transform var(--transition-med), box-shadow var(--transition-med);
}

.s-public-adapt__img:hover {
  transform: translate(-4px, -4px);
  box-shadow: 12px 12px 0 var(--color-border);
}

.s-public-note {
  padding: var(--space-xl) 0;
  background: var(--color-bg-alt);
}

/* --- CONTACT PAGE --- */
.s-contact {
  padding: var(--space-2xl) 0;
}

.s-contact__grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-xl);
  align-items: start;
}

@media (min-width: 900px) {
  .s-contact__grid {
    grid-template-columns: 1.3fr 1fr;
  }
}

/* --- FORM --- */
.c-form {
  background: var(--color-white);
  border: var(--border-width-thick) solid var(--color-border);
  border-radius: var(--border-radius-lg);
  padding: var(--space-xl);
  box-shadow: var(--shadow-hard-lg);
}

.c-form__group {
  margin-bottom: var(--space-md);
}

.c-form__label {
  display: block;
  font-family: var(--font-heading);
  font-weight: 700;
  font-size: 0.85rem;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  color: var(--color-text);
  margin-bottom: 0.5rem;
}

.c-form__input,
.c-form__textarea {
  width: 100%;
  padding: 0.85rem 1rem;
  font-family: var(--font-body);
  font-size: 1rem;
  color: var(--color-text);
  background: var(--color-bg);
  border: var(--border-width-thick) solid var(--color-border);
  border-radius: var(--border-radius-sm);
  outline: none;
  transition: border-color var(--transition-fast), box-shadow var(--transition-fast), background var(--transition-fast);
  min-height: 48px;
}

.c-form__textarea {
  resize: vertical;
  min-height: 140px;
}

.c-form__input:focus,
.c-form__textarea:focus {
  border-color: var(--color-secondary);
  box-shadow: 0 0 0 3px rgba(230, 57, 70, 0.15), var(--shadow-hard-sm);
  background: var(--color-white);
}

.c-form:has(.c-form__input:focus),
.c-form:has(.c-form__textarea:focus) {
  border-color: var(--color-secondary);
}

.c-form__group--check {
  display: flex;
  align-items: flex-start;
  gap: 0.75rem;
}

.c-form__check-label {
  display: flex;
  align-items: flex-start;
  gap: 0.75rem;
  cursor: pointer;
  font-size: 0.88rem;
  color: var(--color-text-muted);
  line-height: 1.5;
}

.c-form__check-label input[type="checkbox"] {
  width: 20px;
  height: 20px;
  min-width: 20px;
  border: var(--border-width-thick) solid var(--color-border);
  border-radius: var(--border-radius-sm);
  cursor: pointer;
  accent-color: var(--color-secondary);
  margin-top: 0.1rem;
}

.c-form__check-label a {
  color: var(--color-secondary);
  text-decoration: underline;
  transition: color var(--transition-fast);
}

.c-form__check-label a:hover {
  color: var(--color-primary);
}

/* --- CONTACT INFO --- */
.c-contact-info {
  background: var(--color-primary);
  border: var(--border-width-thick) solid var(--color-border);
  border-radius: var(--border-radius-lg);
  padding: var(--space-xl);
  box-shadow: var(--shadow-hard-lg);
}

.c-contact-info h2 {
  color: var(--color-text-light);
  font-size: 1.4rem;
  margin-bottom: var(--space-lg);
}

.c-contact-info__item {
  display: flex;
  gap: var(--space-md);
  align-items: flex-start;
  margin-bottom: var(--space-lg);
}

.c-contact-info__item i {
  font-size: 1.1rem;
  color: var(--color-accent);
  width: 24px;
  flex-shrink: 0;
  margin-top: 0.1rem;
}

.c-contact-info__item div {
  display: flex;
  flex-direction: column;
  gap: 0.25rem;
}

.c-contact-info__item strong {
  font-size: 0.78rem;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: rgba(250,248,243,0.5);
  font-family: var(--font-heading);
}

.c-contact-info__item span,
.c-contact-info__item a {
  color: var(--color-text-light);
  font-size: 0.95rem;
  line-height: 1.5;
  transition: color var(--transition-fast);
}

.c-contact-info__item a:hover {
  color: var(--color-accent);
}

.c-contact-info__note {
  border-top: 1px solid rgba(255,255,255,0.12);
  padding-top: var(--space-md);
  margin-top: var(--space-sm);
}

.c-contact-info__note p {
  font-size: 0.82rem;
  color: rgba(250,248,243,0.55);
  max-width: none;
  margin: 0;
}

/* --- MAP --- */
.s-map {
  padding: var(--space-xl) 0 var(--space-2xl);
}

.s-map__title {
  margin-bottom: var(--space-lg);
}

.s-map__wrap {
  border: var(--border-width-thick) solid var(--color-border);
  border-radius: var(--border-radius-md);
  overflow: hidden;
  box-shadow: var(--shadow-hard-lg);
}

/* --- THANKS PAGE --- */
.s-thanks {
  flex: 1;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: var(--space-2xl) var(--space-md);
  padding-top: calc(var(--nav-height) + var(--space-2xl));
  text-align: center;
}

.s-thanks__inner {
  max-width: 560px;
}

.s-thanks__icon {
  font-size: 4rem;
  color: var(--color-secondary);
  margin-bottom: var(--space-lg);
}

.s-thanks h1 {
  margin-bottom: var(--space-md);
}

.s-thanks p {
  margin: 0 auto var(--space-lg);
  max-width: none;
}

/* --- LEGAL PAGES --- */
.s-legal {
  padding-top: calc(var(--nav-height) + var(--space-2xl));
  padding-bottom: var(--space-2xl);
}

.s-legal__header {
  margin-bottom: var(--space-xl);
  padding-bottom: var(--space-xl);
  border-bottom: var(--border-width-thick) solid var(--color-border);
}

.s-legal__header h1 {
  margin-top: 0.5rem;
}

.s-legal__meta {
  margin-top: var(--space-sm);
  font-size: 0.85rem;
  color: var(--color-text-muted);
  max-width: none;
}

.s-legal__body h2 {
  font-size: 1.3rem;
  margin-top: var(--space-xl);
  margin-bottom: var(--space-sm);
  padding-bottom: 0.4rem;
  border-bottom: var(--border-width) solid var(--color-bg-alt);
}

.s-legal__body h3 {
  font-size: 1.05rem;
  margin-top: var(--space-lg);
  margin-bottom: var(--space-sm);
}

.s-legal__body p {
  margin-bottom: var(--space-sm);
  max-width: none;
}

.s-legal__body ul {
  list-style: disc;
  padding-left: 1.5rem;
  margin-bottom: var(--space-md);
}

.s-legal__body ul li {
  margin-bottom: 0.4rem;
  font-size: 0.95rem;
  color: var(--color-text-muted);
  line-height: 1.6;
}

.s-legal__body a {
  color: var(--color-secondary);
  text-decoration: underline;
  transition: color var(--transition-fast);
}

.s-legal__body a:hover {
  color: var(--color-primary);
}

.c-legal-dl {
  display: grid;
  grid-template-columns: auto 1fr;
  gap: 0.5rem var(--space-md);
  background: var(--color-bg-alt);
  border: var(--border-width) solid var(--color-border);
  border-radius: var(--border-radius-md);
  padding: var(--space-md) var(--space-lg);
  margin-bottom: var(--space-md);
}

.c-legal-dl dt {
  font-family: var(--font-heading);
  font-weight: 700;
  font-size: 0.85rem;
  color: var(--color-text);
  padding: 0.3rem 0;
}

.c-legal-dl dd {
  font-size: 0.9rem;
  color: var(--color-text-muted);
  padding: 0.3rem 0;
}

.c-terms-dl {
  display: flex;
  flex-direction: column;
  gap: var(--space-sm);
  margin-bottom: var(--space-lg);
}

.c-terms-dl dt {
  font-family: var(--font-heading);
  font-weight: 700;
  font-size: 0.95rem;
  color: var(--color-secondary);
  margin-bottom: 0.2rem;
}

.c-terms-dl dd {
  font-size: 0.92rem;
  color: var(--color-text-muted);
  padding-left: var(--space-md);
  border-left: 3px solid var(--color-accent);
  margin-bottom: var(--space-sm);
}

.c-table-wrap {
  overflow-x: auto;
  margin: var(--space-md) 0;
  border: var(--border-width-thick) solid var(--color-border);
  border-radius: var(--border-radius-md);
  box-shadow: var(--shadow-hard-sm);
}

.c-legal-table {
  width: 100%;
  border-collapse: collapse;
  font-size: 0.88rem;
  min-width: 600px;
}

.c-legal-table th {
  background: var(--color-primary);
  color: var(--color-text-light);
  font-family: var(--font-heading);
  font-weight: 700;
  padding: 0.75rem 1rem;
  text-align: left;
  border-bottom: var(--border-width-thick) solid var(--color-border);
}

.c-legal-table td {
  padding: 0.7rem 1rem;
  border-bottom: 1px solid var(--color-bg-alt);
  color: var(--color-text-muted);
  vertical-align: top;
  line-height: 1.5;
}

.c-legal-table tr:last-child td {
  border-bottom: none;
}

.c-legal-table tr:nth-child(even) td {
  background: var(--color-bg-alt);
}

/* --- FOOTER --- */
.c-footer {
  background: var(--color-primary);
  border-top: var(--border-width-thick) solid var(--color-border);
  margin-top: auto;
}

.c-footer__main {
  padding: var(--space-2xl) 0 var(--space-xl);
}

.c-footer__grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-xl);
}

@media (min-width: 768px) {
  .c-footer__grid {
    grid-template-columns: 1.5fr 1fr 1fr 1fr;
  }
}

.c-footer__brand img {
  margin-bottom: var(--space-sm);
  filter: brightness(0) invert(1);
}

.c-footer__tagline {
  color: rgba(250,248,243,0.6);
  font-size: 0.88rem;
  margin-bottom: var(--space-md);
  max-width: 30ch;
}

.c-footer__address {
  font-size: 0.85rem;
  color: rgba(250,248,243,0.55);
  line-height: 1.8;
}

.c-footer__address a {
  color: rgba(250,248,243,0.55);
  transition: color var(--transition-fast);
}

.c-footer__address a:hover {
  color: var(--color-accent);
}

.c-footer__col h4 {
  font-family: var(--font-heading);
  font-size: 0.78rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  color: rgba(250,248,243,0.4);
  margin-bottom: var(--space-md);
}

.c-footer__col ul {
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
}

.c-footer__col ul li a {
  font-size: 0.9rem;
  color: rgba(250,248,243,0.7);
  transition: color var(--transition-fast), transform var(--transition-fast);
  display: inline-block;
}

.c-footer__col ul li a:hover {
  color: var(--color-accent);
  transform: translateX(3px);
}

.c-footer__legal {
  border-top: 1px solid rgba(255,255,255,0.1);
  padding: var(--space-md) 0;
}

.c-footer__legal-grid {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  gap: var(--space-sm);
}

.c-footer__legal p {
  font-size: 0.78rem;
  color: rgba(250,248,243,0.35);
  max-width: none;
}

/* --- SCROLL REVEAL --- */
.js-reveal {
  opacity: 0;
  transform: translateY(24px);
  transition: opacity var(--transition-slow), transform var(--transition-slow);
}

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

/* --- :has() POWERED STYLES --- */
.c-card--feature:has(.c-card__icon) {
  border-left: 5px solid var(--color-secondary);
}

.c-form:has(input:invalid:not(:placeholder-shown)) {
  border-color: var(--color-secondary);
}

.s-hero__bento:has(.c-bento-card--accent:hover) {
  filter: saturate(1.05);
}

section:has(.c-label--light) {
  position: relative;
}

.c-team-card:has(img) {
  overflow: hidden;
}

/* --- RESPONSIVE ADJUSTMENTS --- */
@media (max-width: 599px) {
  .s-hero__headline {
    font-size: 2.5rem;
  }

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

  .c-bento-card--dark {
    grid-column: span 1;
  }

  .s-hero__image-strip {
    height: 240px;
  }

  .c-form {
    padding: var(--space-lg);
  }

  .c-contact-info {
    padding: var(--space-lg);
  }

  .c-card--cta {
    padding: var(--space-lg);
  }

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

  .c-step__connector {
    display: none;
  }

  .s-legal {
    padding-top: calc(var(--nav-height) + var(--space-xl));
  }
}

@media (min-width: 600px) and (max-width: 899px) {
  .s-hero__bento {
    grid-template-columns: 1fr 1fr;
  }
}

/* --- COOKIE CONSENT --- */
.c-cookie-pill {
  position: fixed;
  bottom: 24px;
  left: 50%;
  transform: translateX(-50%);
  z-index: 9999;
  background: var(--color-primary);
  border: var(--border-width-thick) solid var(--color-border);
  border-radius: var(--border-radius-pill);
  padding: 0.7rem 1.4rem;
  display: flex;
  align-items: center;
  gap: var(--space-sm);
  box-shadow: var(--shadow-hard-lg);
  white-space: nowrap;
  transition: all var(--transition-med);
  max-width: calc(100vw - 2rem);
}

.c-cookie-pill__text {
  font-family: var(--font-heading);
  font-size: 0.85rem;
  color: var(--color-text-light);
  font-weight: 600;
  flex-shrink: 1;
  white-space: normal;
}

.c-cookie-pill__btn {
  background: var(--color-secondary);
  color: var(--color-white);
  border: var(--border-width) solid var(--color-border);
  border-radius: var(--border-radius-pill);
  font-family: var(--font-heading);
  font-weight: 700;
  font-size: 0.8rem;
  padding: 0.4rem 1rem;
  cursor: pointer;
  transition: background var(--transition-fast), transform var(--transition-fast);
  white-space: nowrap;
  min-height: 36px;
}

.c-cookie-pill__btn:hover {
  background: #c8303c;
  transform: scale(1.04);
}

.c-cookie-pill__btn--settings {
  background: transparent;
  color: rgba(250,248,243,0.7);
  border-color: rgba(255,255,255,0.2);
}

.c-cookie-pill__btn--settings:hover {
  background: rgba(255,255,255,0.08);
  color: var(--color-text-light);
  transform: none;
}

.c-cookie-modal {
  position: fixed;
  bottom: 24px;
  left: 50%;
  transform: translateX(-50%);
  z-index: 9999;
  background: var(--color-primary);
  border: var(--border-width-thick) solid var(--color-border);
  border-radius: var(--border-radius-lg);
  padding: var(--space-lg);
  box-shadow: var(--shadow-hard-lg);
  width: min(500px, calc(100vw - 2rem));
  display: none;
}

.c-cookie-modal.is-open {
  display: block;
  animation: slideUp var(--transition-med) forwards;
}

@keyframes slideUp {
  from { opacity: 0; transform: translateX(-50%) translateY(20px); }
  to { opacity: 1; transform: translateX(-50%) translateY(0); }
}

.c-cookie-modal__title {
  font-family: var(--font-heading);
  font-size: 1.1rem;
  color: var(--color-text-light);
  margin-bottom: var(--space-sm);
}

.c-cookie-modal__desc {
  font-size: 0.85rem;
  color: rgba(250,248,243,0.65);
  margin-bottom: var(--space-md);
  max-width: none;
}

.c-cookie-modal__category {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 0.75rem 0;
  border-bottom: 1px solid rgba(255,255,255,0.1);
}

.c-cookie-modal__category:last-of-type {
  border-bottom: none;
}

.c-cookie-modal__cat-info strong {
  display: block;
  font-size: 0.9rem;
  color: var(--color-text-light);
  margin-bottom: 0.2rem;
}

.c-cookie-modal__cat-info span {
  font-size: 0.78rem;
  color: rgba(250,248,243,0.5);
}

.c-cookie-toggle {
  position: relative;
  width: 44px;
  height: 24px;
  flex-shrink: 0;
}

.c-cookie-toggle input {
  opacity: 0;
  width: 0;
  height: 0;
}

.c-cookie-toggle__slider {
  position: absolute;
  inset: 0;
  background: rgba(255,255,255,0.15);
  border-radius: var(--border-radius-pill);
  cursor: pointer;
  transition: background var(--transition-fast);
  border: 1px solid rgba(255,255,255,0.2);
}

.c-cookie-toggle__slider::before {
  content: '';
  position: absolute;
  width: 18px;
  height: 18px;
  left: 3px;
  top: 2px;
  background: var(--color-white);
  border-radius: 50%;
  transition: transform var(--transition-fast);
}

.c-cookie-toggle input:checked + .c-cookie-toggle__slider {
  background: var(--color-secondary);
}

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

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

.c-cookie-modal__actions {
  display: flex;
  gap: var(--space-sm);
  margin-top: var(--space-md);
  flex-wrap: wrap;
}

.c-cookie-modal__actions .c-cookie-pill__btn {
  flex: 1;
  min-width: 120px;
  border-radius: var(--border-radius-sm);
  padding: 0.6rem 1rem;
}

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