/* ============================================================
   Livet enligt kroppen — Design tokens
   Ported from the Claude Design handoff's design system
   (tokens/colors.css, typography.css, spacing.css, effects.css,
   fonts.css, base.css). Author against the semantic aliases.
   ============================================================ */

@import url('https://fonts.googleapis.com/css2?family=Familjen+Grotesk:wght@400;500;600;700&display=swap');

@font-face {
  font-family: 'Arial Black';
  src: local('Arial Black'), local('Arial-Black'), local('ArialBlack'),
       url('../fonts/arial_black.ttf') format('truetype');
  font-weight: 400 900;
  font-style: normal;
  font-display: swap;
}

:root {
  /* ---- Plum / aubergine (primary brand ground) ---- */
  --plum-900: #322A45;
  --plum-800: #3E3559;
  --plum-700: #4E476C;
  --plum-600: #6A4F76;
  --plum-500: #7E5C86;
  --plum-400: #9A7BA1;
  --plum-300: #B8A0BD;
  --plum-200: #D8C9DC;
  --plum-100: #ECE2EE;
  --plum-50:  #F6F0F7;

  /* ---- Jade / teal (secondary brand) ---- */
  --jade-800: #166659;
  --jade-700: #1E8470;
  --jade-600: #2C9580;
  --jade-500: #38A088;
  --jade-400: #5FB6A0;
  --jade-300: #8ACBB9;
  --jade-200: #BFE2D8;
  --jade-100: #E0F1EB;

  /* ---- Marigold / saffron (warm accent) ---- */
  --saffron-600: #E08A1E;
  --saffron-500: #F2A535;
  --saffron-400: #F7B84E;
  --saffron-300: #FBCE80;
  --saffron-100: #FCEBCC;

  /* ---- Ochre gold ---- */
  --gold-600: #C2974A;
  --gold-500: #D9AE5A;
  --gold-400: #E4C079;
  --gold-300: #EDD49E;
  --gold-100: #F7ECCF;

  /* ---- Coral ---- */
  --coral-600: #C24238;
  --coral-500: #D5544C;
  --coral-400: #E27A72;
  --coral-300: #EFA8A2;
  --coral-100: #F8DDDA;

  /* ---- Warm neutrals ---- */
  --cream-50:  #FBF8F1;
  --cream-100: #F4EFE3;
  --cream-200: #ECE5D4;
  --sand-300:  #DCD2BC;
  --sand-400:  #C7BBA0;
  --ink-900:   #2B2530;
  --ink-700:   #463E4F;
  --ink-600:   #5E5566;
  --ink-500:   #756C7E;
  --ink-400:   #948B9C;
  --ink-300:   #B6AEBE;

  /* ---- Semantic aliases ---- */
  --surface-page:    var(--cream-50);
  --surface-card:    #FFFFFF;
  --surface-sunken:  var(--cream-100);
  --surface-raised:  #FFFFFF;
  --surface-inverse: var(--plum-700);
  --surface-jade:    var(--jade-500);
  --surface-plum:    var(--plum-600);

  --text-strong:  var(--ink-900);
  --text-body:    var(--ink-700);
  --text-muted:   var(--ink-500);
  --text-faint:   var(--ink-400);
  --text-inverse: var(--cream-50);
  --text-on-jade: #0F3A33;
  --text-on-plum: var(--cream-50);

  --brand-primary:   var(--plum-600);
  --brand-secondary: var(--jade-500);
  --brand-accent:    var(--saffron-500);
  --brand-gold:      var(--gold-500);
  --brand-coral:     var(--coral-500);

  --link:        var(--jade-700);
  --link-hover:  var(--jade-800);

  --border-subtle: #E7DFD0;
  --border-soft:   #DED5C3;
  --border-strong: var(--sand-400);
  --border-plum:   var(--plum-200);

  --focus-ring: var(--saffron-500);

  --success: var(--jade-600);
  --warning: var(--saffron-600);
  --danger:  var(--coral-600);
  --info:    var(--plum-500);

  /* ---- Typography ---- */
  --font-display: 'Arial Black', 'Archivo Black', sans-serif;
  --font-sans: 'Familjen Grotesk', system-ui, -apple-system, 'Segoe UI', sans-serif;
  --font-body: var(--font-sans);

  --fw-regular: 400;
  --fw-medium: 500;
  --fw-semibold: 600;
  --fw-bold: 700;

  --text-display-2xl: clamp(3rem, 7vw, 6rem);
  --text-display-xl:  clamp(2.5rem, 5.5vw, 4.5rem);
  --text-display-lg:  clamp(2rem, 4vw, 3.25rem);

  --text-h1: 2.5rem;
  --text-h2: 2rem;
  --text-h3: 1.5rem;
  --text-h4: 1.25rem;
  --text-h5: 1.0625rem;

  --text-lead: 1.25rem;
  --text-base: 1rem;
  --text-sm: 0.875rem;
  --text-xs: 0.75rem;
  --text-overline: 0.6875rem;

  --leading-tight: 1.05;
  --leading-snug: 1.2;
  --leading-normal: 1.5;
  --leading-relaxed: 1.65;

  --tracking-tight: -0.01em;
  --tracking-normal: 0;
  --tracking-wide: 0.04em;
  --tracking-caps: 0.14em;

  /* ---- Spacing ---- */
  --space-0: 0;
  --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;

  --container-sm: 40rem;
  --container-md: 56rem;
  --container-lg: 72rem;
  --container-xl: 80rem;
  --gutter: clamp(1.25rem, 5vw, 4rem);
  --section-y: clamp(3.5rem, 9vw, 8rem);

  /* ---- Radius / shadow / motion ---- */
  --radius-xs: 6px;
  --radius-sm: 10px;
  --radius-md: 16px;
  --radius-lg: 24px;
  --radius-xl: 32px;
  --radius-2xl: 44px;
  --radius-pill: 999px;
  --radius-circle: 50%;

  --border-w: 1px;
  --border-w-2: 2px;

  --shadow-xs: 0 1px 2px rgba(50, 42, 69, 0.06);
  --shadow-sm: 0 2px 6px rgba(50, 42, 69, 0.07);
  --shadow-md: 0 8px 20px rgba(50, 42, 69, 0.09);
  --shadow-lg: 0 16px 36px rgba(50, 42, 69, 0.12);
  --shadow-xl: 0 28px 60px rgba(50, 42, 69, 0.16);
  --shadow-jade: 0 14px 30px rgba(30, 132, 112, 0.22);
  --shadow-saffron: 0 14px 30px rgba(224, 138, 30, 0.24);

  --ring: 0 0 0 3px rgba(242, 165, 53, 0.45);

  --ease-out: cubic-bezier(0.22, 1, 0.36, 1);
  --ease-in-out: cubic-bezier(0.65, 0, 0.35, 1);
  --ease-soft: cubic-bezier(0.34, 1.2, 0.64, 1);
  --dur-fast: 120ms;
  --dur-base: 200ms;
  --dur-slow: 360ms;
  --dur-slower: 600ms;
}

/* ---- Base reset & element defaults ---- */
*, *::before, *::after { box-sizing: border-box; }

html { -webkit-text-size-adjust: 100%; }

body {
  margin: 0;
  font-family: var(--font-body);
  font-size: var(--text-base);
  line-height: var(--leading-normal);
  color: var(--text-body);
  background-color: var(--surface-page);
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
}

h1, h2, h3, h4, h5 {
  margin: 0 0 0.5em;
  color: var(--text-strong);
  font-family: var(--font-sans);
  font-weight: var(--fw-bold);
  line-height: var(--leading-snug);
  letter-spacing: var(--tracking-tight);
  text-wrap: balance;
}

p { margin: 0 0 1em; text-wrap: pretty; }

a {
  color: var(--link);
  text-decoration-thickness: 1px;
  text-underline-offset: 2px;
  transition: color var(--dur-fast) var(--ease-out);
}
a:hover { color: var(--link-hover); }

strong, b { font-weight: var(--fw-semibold); }

img, svg, video { display: block; max-width: 100%; }

button { font: inherit; }

:focus-visible {
  outline: none;
  box-shadow: var(--ring);
  border-radius: var(--radius-xs);
}

::selection { background: var(--saffron-300); color: var(--ink-900); }
