/* Lapland Lucky — core tokens · cool emerald/teal */
:root {
  --srf-base: #eef6f4;
  --srf-soft: #e2f0ec;
  --srf-tint: #d4ebe5;
  --srf-card: rgba(255, 255, 255, 0.72);
  --srf-glass: rgba(255, 255, 255, 0.55);
  --srf-elevate: #ffffff;
  --line-soft: rgba(20, 58, 52, 0.1);
  --line-mid: rgba(20, 58, 52, 0.18);
  --line-glow: rgba(78, 201, 168, 0.35);

  --brand-1: #2d7a5f;
  --brand-1-h: #3a9474;
  --brand-1-d: #1e5242;
  --brand-2: #2d9a8f;
  --brand-2-h: #3bb3a7;
  --accent-mint: #4ec9a8;
  --accent-lime: #8fd694;
  --accent-teal: #2d9a8f;
  --accent-eucalypt: #2d7a5f;

  --ink-strong: #0c1f1a;
  --ink: #1a3830;
  --ink-mute: #3d5c54;
  --ink-soft: #5a7a72;

  --st-ok: #2d9a8f;
  --st-err: #c64545;

  --grd-brand: linear-gradient(135deg, #2d7a5f 0%, #1e5242 100%);
  --grd-cool: linear-gradient(135deg, #2d7a5f 0%, #4ec9a8 55%, #8fd694 100%);
  --grd-cool-deep: linear-gradient(
    145deg,
    #1e5242 0%,
    #2d9a8f 50%,
    #4ec9a8 100%
  );
  --grd-page: linear-gradient(180deg, #eef6f4 0%, #e2f0ec 100%);
  --grd-card: linear-gradient(
    145deg,
    rgba(255, 255, 255, 0.9) 0%,
    rgba(238, 246, 244, 0.95) 100%
  );
  --grd-section: linear-gradient(180deg, #eef6f4 0%, #dceee8 100%);
  --grd-section-alt: linear-gradient(180deg, #f8fcfb 0%, #e2f0ec 100%);
  --grd-hero: linear-gradient(155deg, #eef6f4 0%, #d8efe8 45%, #c5e8df 100%);
  --grd-cta: linear-gradient(135deg, #1e5242 0%, #2d7a5f 40%, #2d9a8f 100%);
  --grd-border: linear-gradient(135deg, #4ec9a8, #2d9a8f, #2d7a5f);

  --grd-warm: var(--grd-cool);
  --grd-sky: var(--grd-cool);
  --accent-sun: var(--accent-lime);
  --accent-coral: var(--accent-mint);

  --clr-bg: var(--srf-base);
  --clr-primary: var(--brand-1);
  --clr-accent: var(--brand-2);
  --clr-text: var(--ink-strong);
  --clr-text-muted: var(--ink-mute);
  --clr-success: var(--st-ok);
  --clr-error: var(--st-err);
  --grad-primary: var(--grd-brand);
  --grad-gold: var(--grd-cool);

  --font-primary: "Manrope", system-ui, -apple-system, sans-serif;
  --font-display: "Manrope", Georgia, serif;
  --font-mono: ui-monospace, monospace;

  --fs-xs: 0.75rem;
  --fs-sm: 0.875rem;
  --fs-base: 1rem;
  --fs-md: 1.125rem;
  --fs-lg: 1.25rem;
  --fs-xl: 1.5rem;
  --fs-2xl: 2rem;
  --fs-3xl: 2.5rem;
  --fs-4xl: 3rem;
  --fs-5xl: 3.75rem;

  --fw-medium: 500;
  --fw-semi: 600;
  --fw-bold: 700;
  --fw-extra: 800;

  --lh-tight: 1.15;
  --lh-normal: 1.6;
  --lh-loose: 1.8;

  --sp-xs: 0.25rem;
  --sp-sm: 0.5rem;
  --sp-md: 1rem;
  --sp-lg: 1.5rem;
  --sp-xl: 2rem;
  --sp-2xl: 3rem;
  --sp-3xl: 4rem;
  --sp-4xl: 6rem;

  --container-max: 1200px;
  --header-h: 76px;
  --section-py: clamp(4.5rem, 9vw, 8.5rem);

  --radius-sm: 6px;
  --radius-md: 12px;
  --radius-lg: 20px;
  --radius-xl: 28px;
  --radius-full: 9999px;

  --glass-blur: 16px;
  --shadow-sm: 0 2px 8px rgba(20, 58, 52, 0.06);
  --shadow-md: 0 8px 24px rgba(20, 58, 52, 0.1);
  --shadow-lg: 0 20px 48px rgba(20, 58, 52, 0.14);
  --shadow-card: 0 12px 32px rgba(45, 122, 95, 0.12);
  --shadow-glow: 0 8px 28px rgba(78, 201, 168, 0.28);

  --ease-fast: 0.15s ease;
  --ease-base: 0.32s cubic-bezier(0.4, 0, 0.2, 1);
  --ease-spring: 0.45s cubic-bezier(0.34, 1.45, 0.64, 1);

  --z-header: 1000;
  --z-overlay: 1100;
  --z-modal: 2000;
}

@font-face {
  font-family: "Manrope";
  src: url("../fonts/Manrope-Regular.woff2") format("woff2");
  font-weight: 400;
  font-display: swap;
}
@font-face {
  font-family: "Manrope";
  src: url("../fonts/Manrope-Bold.woff2") format("woff2");
  font-weight: 700;
  font-display: swap;
}

*,
*::before,
*::after {
  box-sizing: border-box;
  margin: 0;
  padding: 0;
}

html {
  scroll-behavior: smooth;
  font-size: 16px;
}

body {
  font-family: var(--font-primary);
  font-size: var(--fs-base);
  line-height: var(--lh-normal);
  color: var(--ink);
  background: var(--grd-page);
  overflow-x: hidden;
  -webkit-font-smoothing: antialiased;
}

body::before {
  content: "";
  position: fixed;
  inset: 0;
  pointer-events: none;
  z-index: 9998;
  opacity: 0.04;
  background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
}

body.page-enter {
  animation: ll-page-in 0.45s ease;
}

@keyframes ll-page-in {
  from {
    opacity: 0;
    transform: translateY(8px);
  }
  to {
    opacity: 1;
    transform: none;
  }
}

img,
svg {
  display: block;
  max-width: 100%;
}

a {
  color: inherit;
  text-decoration: none;
}

button {
  font-family: inherit;
  cursor: pointer;
  border: none;
  background: none;
}

ul,
ol {
  list-style: none;
}

h1,
h2,
h3,
h4 {
  font-family: var(--font-display);
  color: var(--ink-strong);
  line-height: var(--lh-tight);
  font-weight: 700;
}

::selection {
  background: rgba(78, 201, 168, 0.35);
  color: var(--ink-strong);
}

.ll-wrap_z3a9b {
  width: 100%;
  max-width: var(--container-max);
  margin-inline: auto;
  padding-inline: clamp(1rem, 4vw, 2rem);
}

.ll-section_z3a9b {
  padding-block: var(--section-py);
  position: relative;
  overflow: hidden;
}

main {
  overflow-x: hidden;
}

.ll-section_z3a9b--center {
  text-align: center;
}

.ll-section__eyebrow_z3a9b {
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  font-size: var(--fs-xs);
  font-weight: var(--fw-bold);
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: var(--brand-2);
  margin-bottom: var(--sp-md);
  font-family: var(--font-primary);
}

.ll-section__eyebrow_z3a9b::before {
  content: "";
  width: 32px;
  height: 2px;
  background: var(--grd-cool);
  border-radius: var(--radius-full);
}

.ll-section__heading_z3a9b {
  font-size: clamp(2rem, 4.5vw, var(--fs-4xl));
  font-weight: 700;
  margin-bottom: var(--sp-lg);
  letter-spacing: -0.02em;
}

.ll-section__heading_z3a9b span {
  background: var(--grd-cool);
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
}

.ll-section__heading_z3a9b--line::after {
  content: "";
  display: block;
  width: 72px;
  height: 4px;
  margin-top: 0.75rem;
  background: var(--grd-cool);
  border-radius: var(--radius-full);
}

.ll-section_z3a9b--center .ll-section__heading_z3a9b--line::after {
  margin-inline: auto;
}

.ll-section__lede_z3a9b {
  font-size: var(--fs-md);
  color: var(--ink-mute);
  line-height: var(--lh-loose);
  max-width: 640px;
}

.ll-section_z3a9b--center .ll-section__lede_z3a9b {
  margin-inline: auto;
}

/* Buttons */
.ll-btn_k5m3n {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 0.5rem;
  padding: 0.9rem 1.85rem;
  font-size: var(--fs-sm);
  font-weight: var(--fw-bold);
  border-radius: var(--radius-full);
  border: 2px solid transparent;
  transition:
    transform var(--ease-spring),
    box-shadow var(--ease-base),
    background var(--ease-base);
  position: relative;
  overflow: hidden;
  font-family: var(--font-primary);
}

.ll-btn_k5m3n--magnetic {
  transition: transform 0.2s ease;
}

.ll-btn_k5m3n--primary {
  background: var(--grd-cool-deep);
  color: #fff;
  box-shadow: var(--shadow-glow);
}

.ll-btn_k5m3n--primary:hover {
  transform: translateY(-3px);
  box-shadow: 0 14px 36px rgba(45, 154, 143, 0.35);
}

.ll-btn_k5m3n--ghost {
  background: var(--srf-glass);
  backdrop-filter: blur(var(--glass-blur));
  color: var(--brand-1-d);
  border-color: var(--line-mid);
}

.ll-btn_k5m3n--outline {
  background: transparent;
  color: var(--brand-1);
  border-color: var(--brand-2);
}

.ll-btn_k5m3n--lg {
  padding: 1.05rem 2.25rem;
  font-size: var(--fs-base);
}

.ll-btn_k5m3n--sm {
  padding: 0.55rem 1.2rem;
  font-size: var(--fs-xs);
}

.ll-btn_k5m3n--block {
  width: 100%;
}

.ll-btn_k5m3n__arrow {
  transition: transform var(--ease-spring);
}

.ll-btn_k5m3n:hover .ll-btn_k5m3n__arrow {
  transform: translateX(4px);
}

.ll-badge_j3h7w {
  display: inline-flex;
  padding: 0.28rem 0.75rem;
  font-size: var(--fs-xs);
  font-weight: var(--fw-bold);
  text-transform: uppercase;
  letter-spacing: 0.08em;
  border-radius: var(--radius-full);
  font-family: var(--font-primary);
}

.ll-badge_j3h7w--primary {
  background: rgba(45, 122, 95, 0.12);
  color: var(--brand-1-d);
  border: 1px solid rgba(45, 154, 143, 0.25);
}

.ll-badge_j3h7w--gold {
  background: rgba(78, 201, 168, 0.15);
  color: var(--brand-1-d);
  border: 1px solid rgba(78, 201, 168, 0.35);
}

[data-aos] {
  opacity: 0;
  transition:
    opacity 0.55s ease,
    transform 0.55s cubic-bezier(0.22, 1, 0.36, 1);
}

[data-aos].aos-animate {
  opacity: 1;
  transform: none !important;
}

[data-aos="fade-up"] {
  transform: translateY(32px);
}

[data-aos="fade-left"] {
  transform: translateX(32px);
}

[data-aos="fade-right"] {
  transform: translateX(-32px);
}

[data-aos="zoom-in"] {
  transform: scale(0.94);
}
