/* ============================================================
   Catalysator – stylesheet
   Sections:
   1. Design tokens (:root)
   2. Base / reset
   3. Components (nav, buttons, hero, sections, cards, footer …)
   4. Extracted utilities & components (promoted from inline styles)
   5. Responsive (mobile + desktop)
   ============================================================ */

/* 1. DESIGN TOKENS ------------------------------------------- */
:root {
  --magenta: #F47B20;
  --magenta-dark: #C05A0E;
  --magenta-light: #FDEBD5;
  --blue: #2BAAE1;
  --blue-dark: #1A7FAF;
  --blue-light: #D0EFFA;
  --purple: #8B86E0;
  --purple-dark: #5A55B5;
  --purple-light: #E6E5FA;
  --green: #2EAA5F;
  --green-dark: #1C7A40;
  --green-light: #D5F0E0;
  --orange: #F47B20;
  --orange-dark: #C05A0E;
  --orange-light: #FDEBD5;
  --yellow: #F0C820;
  --ink: #1A1A18;
  --ink-light: #3D3D3A;
  --white: #FFFFFF;
  --cream: #F8F6F1;
  --sand: #EEE9E0;
  --border: #DDD9D0;
  --muted: #6B6860;
  --font: 'DM Sans', sans-serif;
  --display: 'DM Serif Display', serif;
}

/* 2. BASE / RESET ------------------------------------------- */
* { margin:0; padding:0; box-sizing:border-box; }

body { font-family:var(--font); background:var(--white); color:var(--ink); font-size:17px; line-height:1.65; }

/* 3. COMPONENTS --------------------------------------------- */

/* NAV */
nav {
  position:sticky; top:0; z-index:100;
  background:var(--white);
  border-bottom:1px solid var(--border);
  display:flex; align-items:center; justify-content:space-between;
  padding:0 3rem; height:62px;
}
.nav-logo { font-family:var(--display); font-size:1.4rem; color:var(--ink); cursor:pointer; letter-spacing:0.01em; text-decoration:none; }
.nav-links { display:flex; gap:0; list-style:none; }
.nav-links li a {
  display:block; padding:0.4rem 0.9rem;
  color:var(--muted); text-decoration:none;
  font-size:0.9rem; font-weight:500;
  transition:color 0.15s; cursor:pointer;
}
.nav-links li a:hover { color:var(--ink); }
.nav-links li a.active { color:var(--ink); font-weight:700; }
.nav-cta { background:var(--magenta) !important; color:var(--white) !important; border-radius:4px; padding:0.4rem 1.1rem !important; transition:background 0.15s !important; }
.nav-cta:hover { background:var(--magenta-dark) !important; }
.nav-hamburger { display:none; background:none; border:none; }

/* BUTTONS */
.btn-primary { display:inline-block; background:var(--magenta); color:var(--white); padding:0.85rem 2rem; border-radius:4px; font-size:0.95rem; font-weight:700; cursor:pointer; transition:background 0.15s, transform 0.1s; border:none; font-family:var(--font); text-decoration:none; }
.btn-primary:hover { background:var(--magenta-dark); transform:translateY(-1px); }
.btn-outline-dark { display:inline-block; background:transparent; color:var(--ink); padding:0.85rem 2rem; border-radius:4px; font-size:0.95rem; font-weight:500; cursor:pointer; transition:background 0.15s; border:1.5px solid var(--border); font-family:var(--font); text-decoration:none; }
.btn-outline-dark:hover { background:var(--cream); }
.btn-dark { display:inline-block; background:var(--ink); color:var(--white); padding:0.9rem 2.2rem; border-radius:4px; font-size:0.95rem; font-weight:700; cursor:pointer; white-space:nowrap; transition:background 0.15s; border:none; font-family:var(--font); text-decoration:none; }
.btn-dark:hover { background:var(--ink-light); }
.btn-white { display:inline-block; background:var(--white); color:var(--magenta-dark); padding:0.9rem 2.2rem; border-radius:4px; font-size:0.95rem; font-weight:700; cursor:pointer; white-space:nowrap; transition:background 0.15s; border:none; font-family:var(--font); text-decoration:none; }
.btn-white:hover { background:var(--cream); }
/* Button colour + size modifiers (promoted from inline styles) */
.btn-primary.blue { background:var(--blue-dark); }
.btn-primary.green { background:var(--green-dark); }
.btn-block { width:100%; text-align:center; }
.btn-sm { font-size:0.88rem; padding:0.6rem 1.3rem; }

/* HERO */
.hero {
  background:var(--cream);
  min-height:88vh;
  display:grid; grid-template-columns:1fr 1fr;
  overflow:hidden;
}
.hero-left { padding:7rem 3rem 5rem 5rem; display:flex; flex-direction:column; justify-content:center; }
.hero-kicker { font-size:0.78rem; font-weight:700; letter-spacing:0.15em; text-transform:uppercase; color:var(--magenta); margin-bottom:1.5rem; }
.hero-h1 { font-family:var(--display); font-size:clamp(3rem, 5vw, 4.8rem); color:var(--ink); line-height:1.05; margin-bottom:1.8rem; }
.hero-h1 em { font-style:italic; color:var(--magenta); }
.hero-sub { font-size:1.1rem; color:var(--muted); max-width:460px; line-height:1.7; margin-bottom:2.8rem; }
.hero-btns { display:flex; gap:1rem; flex-wrap:wrap; }

.hero-right { position:relative; overflow:hidden; background:var(--sand); }
.hero-blob-wrap { position:absolute; inset:0; display:flex; align-items:center; justify-content:center; }
.sticky-stack { position:relative; width:360px; height:380px; }
.sticky { position:absolute; border-radius:3px; display:flex; align-items:center; justify-content:center; font-family:var(--display); color:var(--ink); padding:1.5rem 2rem; line-height:1.2; }
.sticky-1 { background:var(--magenta); color:var(--white); width:200px; height:190px; top:20px; left:20px; transform:rotate(-4deg); font-size:1.5rem; }
.sticky-2 { background:var(--blue); width:180px; height:170px; top:60px; left:160px; transform:rotate(3deg); font-size:1.1rem; }
.sticky-3 { background:var(--purple); color:var(--white); width:200px; height:130px; top:200px; left:60px; transform:rotate(-2deg); font-size:1rem; }
.sticky-4 { background:var(--green); color:var(--white); width:160px; height:150px; top:180px; left:200px; transform:rotate(5deg); font-size:0.95rem; }

/* SVG hero bubbles (promoted from inline <style> inside the SVG) */
.bubble { animation: float 6s ease-in-out infinite; }
.b1 { animation-delay: 0s; }
.b2 { animation-delay: 1.2s; }
.b3 { animation-delay: 2.4s; }
.b4 { animation-delay: 0.7s; }
.b5 { animation-delay: 1.8s; }
@keyframes float {
  0%, 100% { transform: translateY(0px); }
  50% { transform: translateY(-10px); }
}
.bubble-text { font-family: 'DM Serif Display', Georgia, serif; font-style: italic; fill: white; text-anchor: middle; dominant-baseline: middle; pointer-events: none; }

/* TAGLINE */
.tagline-bar { background:var(--magenta); padding:1.2rem 5rem; font-family:var(--display); font-size:1.4rem; color:var(--white); font-style:italic; }

/* SECTIONS */
.section { padding:6rem 5rem; }
.section-kicker { font-size:0.78rem; font-weight:700; letter-spacing:0.15em; text-transform:uppercase; color:var(--muted); margin-bottom:1rem; }
.section-title { font-family:var(--display); font-size:clamp(2rem, 3vw, 2.8rem); line-height:1.1; margin-bottom:3.5rem; max-width:600px; }

/* SERVICES GRID */
.services-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:1.5px; background:var(--border); }
.service-card { background:var(--white); padding:2.8rem 2.5rem; cursor:pointer; transition:background 0.15s; position:relative; overflow:hidden; text-decoration:none; color:inherit; display:block; }
.service-card::before { content:''; position:absolute; top:0; left:0; right:0; height:5px; }
.service-card.motstand::before { background:var(--magenta); }
.service-card.ledarboost::before { background:var(--blue); }
.service-card.individuell::before { background:var(--green); }
.service-card:hover { background:var(--cream); }
.service-icon { width:48px; height:48px; border-radius:50%; margin-bottom:1.5rem; display:flex; align-items:center; justify-content:center; font-size:1.3rem; }
.service-card.motstand .service-icon { background:var(--magenta-light); }
.service-card.ledarboost .service-icon { background:var(--blue-light); }
.service-card.individuell .service-icon { background:var(--green-light); }
.service-card h3 { font-family:var(--display); font-size:1.5rem; margin-bottom:0.8rem; line-height:1.1; }
.service-card p { font-size:0.95rem; color:var(--muted); line-height:1.6; margin-bottom:1.5rem; }
.service-link { font-size:0.88rem; font-weight:700; text-decoration:none; letter-spacing:0.05em; text-transform:uppercase; cursor:pointer; }
.service-card.motstand .service-link { color:var(--magenta); }
.service-card.ledarboost .service-link { color:var(--blue-dark); }
.service-card.individuell .service-link { color:var(--green-dark); }
.service-card--lg { padding:3rem; }

/* APPROACH – now light */
.approach-section {
  background:var(--cream);
  padding:6rem 5rem;
  display:grid; grid-template-columns:1fr 1fr; gap:5rem; align-items:center;
  border-top:1.5px solid var(--border);
  border-bottom:1.5px solid var(--border);
}
.approach-section--top { align-items:start; }
.approach-left h2 { font-family:var(--display); font-size:clamp(2rem,3vw,3rem); color:var(--ink); line-height:1.1; margin-bottom:1.5rem; }
.approach-left h2 em { color:var(--magenta); font-style:italic; }
.approach-left p { color:var(--muted); font-size:1.05rem; line-height:1.75; margin-bottom:1rem; }
.approach-pills { display:flex; flex-wrap:wrap; gap:0.5rem; margin-top:2rem; }
.pill { padding:0.4rem 1rem; border-radius:100px; font-size:0.85rem; font-weight:500; }
.pill-magenta { background:var(--magenta-light); color:var(--magenta-dark); }
.pill-blue { background:var(--blue-light); color:var(--blue-dark); }
.pill-green { background:var(--green-light); color:var(--green-dark); }
.pill-orange { background:var(--orange-light); color:var(--orange-dark); }

.approach-right { display:grid; grid-template-columns:1fr 1fr; gap:1.5px; background:var(--border); }
.approach-item { background:var(--white); padding:2rem 1.8rem; }
.approach-num { font-family:var(--display); font-size:3rem; color:var(--border); line-height:1; margin-bottom:0.5rem; }
.approach-item h4 { color:var(--ink); font-size:1rem; font-weight:700; margin-bottom:0.5rem; }
.approach-item p { color:var(--muted); font-size:0.88rem; line-height:1.5; }

/* ABOUT PREVIEW */
.about-preview { padding:6rem 5rem; display:grid; grid-template-columns:1fr 1fr; gap:6rem; align-items:center; }
.about-preview--top { align-items:start; }
.about-text h2 { font-family:var(--display); font-size:2.5rem; line-height:1.1; margin-bottom:1.5rem; }
.about-text p { color:var(--muted); font-size:1rem; line-height:1.75; margin-bottom:1rem; }
.about-visual { display:grid; grid-template-columns:1fr 1fr; gap:12px; }
.about-blob { border-radius:16px; aspect-ratio:1; display:flex; align-items:center; justify-content:center; font-family:var(--display); font-size:1.1rem; text-align:center; padding:1.5rem; line-height:1.3; }
.about-blob.magenta { background:var(--magenta-light); color:var(--magenta-dark); }
.about-blob.blue { background:var(--blue-light); color:var(--blue-dark); }

/* ARTICLES PREVIEW on home */
.articles-preview { background:var(--cream); border-top:1.5px solid var(--border); padding:6rem 5rem; }
.articles-row { display:grid; grid-template-columns:repeat(3,1fr); gap:1.5rem; margin-top:2.5rem; }
.article-card { background:var(--white); border:1.5px solid var(--border); border-radius:12px; overflow:hidden; cursor:pointer; transition:border-color 0.15s, transform 0.15s; text-decoration:none; color:inherit; display:block; }
.article-card:hover { border-color:var(--magenta); transform:translateY(-2px); }
.article-tag-strip { height:5px; }
.article-tag-strip.magenta { background:var(--magenta); }
.article-tag-strip.blue { background:var(--blue); }
.article-tag-strip.purple { background:var(--purple); }
.article-tag-strip.green { background:var(--green); }
.article-tag-strip.orange { background:var(--orange); }
.article-card-body { padding:1.6rem 1.8rem 2rem; }
.article-meta { font-size:0.78rem; font-weight:700; letter-spacing:0.1em; text-transform:uppercase; color:var(--muted); margin-bottom:0.7rem; }
.article-card h3 { font-family:var(--display); font-size:1.3rem; line-height:1.2; margin-bottom:0.7rem; color:var(--ink); }
.article-card p { font-size:0.92rem; color:var(--muted); line-height:1.6; }
.article-read-more { display:inline-block; margin-top:1rem; font-size:0.85rem; font-weight:700; color:var(--magenta); text-transform:uppercase; letter-spacing:0.05em; }

/* CTA BAND */
.cta-band { background:var(--magenta); padding:4rem 5rem; display:flex; align-items:center; justify-content:space-between; gap:2rem; }
.cta-band h2 { font-family:var(--display); font-size:2.2rem; color:var(--white); max-width:500px; line-height:1.15; }
.cta-band.blue { background:var(--blue); }
.cta-band.green { background:var(--green); }
.cta-band.purple { background:var(--purple-light); }
.cta-band.blue .btn-white { color:var(--blue-dark); }
.cta-band.green .btn-white { color:var(--green-dark); }
.cta-band.purple h2 { color:var(--purple-dark); }

/* FOOTER */
footer { background:var(--ink); color:rgba(255,255,255,0.45); padding:3rem 5rem; display:flex; justify-content:space-between; align-items:flex-end; font-size:0.88rem; }
.footer-logo { font-family:var(--display); font-size:1.5rem; color:var(--white); margin-bottom:0.5rem; margin-top:0; text-decoration:none; display:inline-block; cursor:pointer; }
footer a { color:rgba(255,255,255,0.45); text-decoration:none; display:block; margin-top:0.3rem; cursor:pointer; transition:color 0.15s; }
footer a:hover { color:var(--white); }
/* Footer internals (promoted from inline styles) */
.footer-grid { display:grid; grid-template-columns:2fr 1fr 1fr; gap:3rem; width:100%; }
.footer-tagline { font-size:0.9rem; margin-top:0.5rem; max-width:260px; line-height:1.6; }
.footer-links { margin-top:1.2rem; }
.footer-col-title { font-size:0.75rem; font-weight:700; letter-spacing:0.12em; text-transform:uppercase; color:rgba(255,255,255,0.3); margin-bottom:0.8rem; }
.footer-bottom { width:100%; border-top:1px solid rgba(255,255,255,0.1); margin-top:2.5rem; padding-top:1.5rem; display:flex; justify-content:space-between; font-size:0.82rem; }

/* INNER PAGES */
.inner-hero { padding:6rem 5rem 4rem; position:relative; overflow:hidden; }
.inner-hero.magenta { background:var(--magenta); }
.inner-hero.blue { background:var(--blue); }
.inner-hero.green { background:var(--green); }
.inner-hero.cream { background:var(--cream); border-bottom:1.5px solid var(--border); }
.inner-hero.sand { background:var(--sand); border-bottom:1.5px solid var(--border); }
.inner-hero.purple { background:var(--purple); }
.inner-hero-kicker { font-size:0.78rem; font-weight:700; letter-spacing:0.15em; text-transform:uppercase; margin-bottom:1rem; }
.inner-hero.cream .inner-hero-kicker,
.inner-hero.sand .inner-hero-kicker { color:var(--muted); }
.inner-hero.magenta .inner-hero-kicker,
.inner-hero.blue .inner-hero-kicker,
.inner-hero.green .inner-hero-kicker { color:rgba(0,0,0,0.45); }
.inner-hero.purple .inner-hero-kicker { color:rgba(255,255,255,0.65); }
.inner-hero h1 { font-family:var(--display); font-size:clamp(2.5rem,5vw,4rem); line-height:1.05; max-width:700px; }
.inner-hero.purple h1 { color:var(--white); }
.inner-hero-sub { font-size:1.1rem; max-width:600px; margin-top:1.2rem; line-height:1.7; }
.inner-hero.cream .inner-hero-sub,
.inner-hero.sand .inner-hero-sub { color:var(--muted); }
.inner-hero.magenta .inner-hero-sub,
.inner-hero.blue .inner-hero-sub,
.inner-hero.green .inner-hero-sub { color:rgba(0,0,0,0.6); }
.inner-hero.purple .inner-hero-sub { color:rgba(255,255,255,0.8); }
/* Accent (magenta) kicker, overriding the per-background colour rules above */
.inner-hero .inner-hero-kicker.accent { color:var(--magenta); }
/* Decorative SVG in inner hero (promoted from inline styles) */
.inner-hero-deco { position:absolute; right:4rem; top:50%; transform:translateY(-50%); opacity:0.2; pointer-events:none; width:200px; height:200px; }
.inner-hero-deco.deco-strong { opacity:0.3; }

/* SERVICE PAGE */
.service-body { padding:5rem 5rem; display:grid; grid-template-columns:2fr 1fr; gap:5rem; align-items:start; }
.service-main h2 { font-family:var(--display); font-size:2rem; margin-bottom:1.2rem; }
.service-main p { font-size:1.02rem; line-height:1.8; color:var(--muted); margin-bottom:1.2rem; }
.service-main p strong { color:var(--ink); font-weight:700; }
.service-sidebar { position:sticky; top:80px; }
.sidebar-card { border:1.5px solid var(--border); border-radius:12px; padding:2rem; margin-bottom:1.5rem; }
.sidebar-card h4 { font-size:0.78rem; font-weight:700; letter-spacing:0.12em; text-transform:uppercase; color:var(--muted); margin-bottom:1rem; }
.sidebar-card p { font-size:0.95rem; line-height:1.65; color:var(--muted); }
/* Coloured sidebar-card variants (promoted from inline styles) */
.sidebar-card.magenta { background:var(--magenta-light); border-color:var(--magenta-light); }
.sidebar-card.blue { background:var(--blue-light); border-color:var(--blue-light); }
.sidebar-card.green { background:var(--green-light); border-color:var(--green-light); }
.sidebar-card.magenta h4 { color:var(--magenta-dark); }
.sidebar-card.blue h4 { color:var(--blue-dark); }
.sidebar-card.green h4 { color:var(--green-dark); }
.sidebar-card.magenta p { color:var(--magenta-dark); margin-bottom:1.2rem; }
.sidebar-card.blue p { color:var(--blue-dark); margin-bottom:1.2rem; }
.sidebar-card.green p { color:var(--green-dark); margin-bottom:1.2rem; }

/* OM OSS */
.team-section { padding:5rem 5rem; background:var(--cream); border-top:1.5px solid var(--border); }
.team-grid { display:grid; grid-template-columns:1fr 1fr; gap:3rem; margin-top:3rem; }
.team-card { background:var(--white); border:1.5px solid var(--border); border-radius:16px; overflow:hidden; }
.team-photo { height:260px; display:flex; align-items:center; justify-content:center; font-family:var(--display); font-size:3rem; color:var(--ink); }
.team-photo.magenta { background:var(--magenta-light); }
.team-photo.blue { background:var(--blue-light); }
.team-info { padding:2rem; }
.team-info h3 { font-family:var(--display); font-size:1.8rem; margin-bottom:0.3rem; }
.team-info .team-title { font-size:0.82rem; font-weight:700; letter-spacing:0.1em; text-transform:uppercase; color:var(--muted); margin-bottom:1rem; }
.team-info p { font-size:0.97rem; line-height:1.7; color:var(--muted); }
.team-info p + p { margin-top:0.8rem; }

/* METOD */
.metod-intro { padding:5rem 5rem 2rem; }
.metod-intro p { font-size:1.15rem; line-height:1.85; color:var(--muted); margin-bottom:1.5rem; }
.metod-blocks { display:grid; grid-template-columns:1fr 1fr; gap:1.5px; background:var(--border); margin:0 5rem; }
.metod-block { background:var(--white); padding:3rem; }
.metod-block-num { font-family:var(--display); font-size:3.5rem; color:var(--border); line-height:1; margin-bottom:0.5rem; }
.metod-block h3 { font-family:var(--display); font-size:1.5rem; margin-bottom:1rem; }
.metod-block p { font-size:0.97rem; line-height:1.75; color:var(--muted); }
.metod-quote { background:var(--purple-light); padding:5rem; }
.metod-quote blockquote { font-family:var(--display); font-size:2rem; color:var(--purple-dark); line-height:1.3; max-width:700px; font-style:italic; }
.metod-quote-cite { margin-top:1.5rem; color:var(--purple-dark); font-size:0.95rem; }

/* FAQ */
.faq-section { padding:5rem 5rem; max-width:820px; }
.faq-item { border-top:1.5px solid var(--border); padding:1.5rem 0; }
.faq-item:last-child { border-bottom:1.5px solid var(--border); }
.faq-q { font-size:1.05rem; font-weight:700; margin-bottom:0.8rem; cursor:pointer; display:flex; justify-content:space-between; align-items:start; gap:1rem; }
.faq-q .faq-arrow { font-size:1.2rem; color:var(--magenta); flex-shrink:0; margin-top:2px; }
.faq-a { font-size:0.98rem; color:var(--muted); line-height:1.75; }
.faq-cat { font-family:var(--display); font-size:1.5rem; margin:2.5rem 0 1.5rem; color:var(--muted); }

/* KONTAKT */
.kontakt-grid { padding:5rem 5rem; display:grid; grid-template-columns:1fr 1fr; gap:5rem; align-items:start; }
.kontakt-info h2 { font-family:var(--display); font-size:2rem; margin-bottom:1.2rem; }
.kontakt-info p { font-size:1rem; color:var(--muted); line-height:1.75; margin-bottom:1.5rem; }
.kontakt-detail { display:flex; gap:1rem; align-items:flex-start; margin-bottom:1rem; font-size:0.97rem; }
.kontakt-detail-icon { width:36px; height:36px; background:var(--magenta-light); border-radius:8px; display:flex; align-items:center; justify-content:center; font-size:1rem; flex-shrink:0; }
.kontakt-detail-title { font-weight:700; margin-bottom:0.2rem; }
.kontakt-detail a { color:var(--muted); text-decoration:none; transition:color 0.15s; }
.kontakt-detail a:hover { color:var(--magenta); }
.kontakt-form label { display:block; font-size:0.82rem; font-weight:700; letter-spacing:0.05em; text-transform:uppercase; color:var(--muted); margin-bottom:0.4rem; }
.form-group { margin-bottom:1.5rem; }
.kontakt-form input,.kontakt-form select,.kontakt-form textarea { width:100%; padding:0.8rem 1rem; border:1.5px solid var(--border); border-radius:6px; font-family:var(--font); font-size:1rem; background:var(--white); color:var(--ink); transition:border-color 0.15s; outline:none; }
.kontakt-form input:focus,.kontakt-form select:focus,.kontakt-form textarea:focus { border-color:var(--magenta); }
.kontakt-form textarea { resize:vertical; min-height:130px; }
.kontakt-form .btn-primary { padding:1rem; font-size:1rem; }
.form-row { display:grid; grid-template-columns:1fr 1fr; gap:1rem; }
.form-note { font-size:0.83rem; color:var(--muted); margin-top:0.8rem; text-align:center; }
.contact-quote { margin-top:2.5rem; padding:1.8rem; background:var(--cream); border-radius:12px; border:1.5px solid var(--border); }
.contact-quote-text { font-family:var(--display); font-size:1.15rem; line-height:1.4; color:var(--ink); font-style:italic; }
.contact-quote-cite { font-size:0.88rem; color:var(--muted); margin-top:0.8rem; }

/* ARTICLES PAGE */
.articles-page-grid { padding:3rem 5rem 6rem; }
.articles-full-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:1.5rem; margin-top:2.5rem; }
.article-featured { grid-column:span 3; display:grid; grid-template-columns:1fr 1fr; gap:0; border:1.5px solid var(--border); border-radius:12px; overflow:hidden; cursor:pointer; transition:border-color 0.15s; margin-bottom:0.5rem; text-decoration:none; color:inherit; }
.article-featured:hover { border-color:var(--magenta); }
.article-featured-img { background:var(--sand); display:flex; align-items:center; justify-content:center; padding:3rem; font-family:var(--display); font-size:2.5rem; color:var(--muted); }
.article-featured-img.magenta { background:var(--magenta-light); }
.article-featured-body { padding:3rem; background:var(--white); display:flex; flex-direction:column; justify-content:center; }
.article-featured-body .article-meta { font-size:0.78rem; font-weight:700; letter-spacing:0.1em; text-transform:uppercase; color:var(--muted); margin-bottom:0.8rem; }
.article-featured-body h2 { font-family:var(--display); font-size:2rem; line-height:1.15; margin-bottom:1rem; color:var(--ink); }
.article-featured-body p { font-size:1rem; color:var(--muted); line-height:1.7; }

/* ARTICLE SINGLE */
.article-back { padding:2.5rem 5rem 0; border-bottom:1px solid var(--border); }
.article-single { max-width:740px; margin:0 auto; padding:4rem 5rem 6rem; }
.article-single h1 { font-family:var(--display); font-size:clamp(2rem,4vw,3rem); line-height:1.1; margin-bottom:1.5rem; }
.article-single .article-meta { font-size:0.8rem; font-weight:700; letter-spacing:0.1em; text-transform:uppercase; color:var(--muted); margin-bottom:2.5rem; padding-bottom:2rem; border-bottom:1.5px solid var(--border); }
.article-single p { font-size:1.08rem; line-height:1.85; color:var(--ink-light); margin-bottom:1.5rem; }
.article-single h2 { font-family:var(--display); font-size:1.7rem; margin:3rem 0 1rem; }
.article-single blockquote { border-left:4px solid var(--magenta); padding:1rem 1.5rem; margin:2rem 0; font-family:var(--display); font-size:1.3rem; font-style:italic; color:var(--magenta-dark); line-height:1.4; }
.article-cta { margin-top:2.5rem; padding-top:2rem; border-top:1.5px solid var(--border); font-size:0.95rem; }
.back-link { display:inline-flex; align-items:center; gap:0.5rem; font-size:0.88rem; font-weight:700; color:var(--muted); text-transform:uppercase; letter-spacing:0.08em; cursor:pointer; margin-bottom:2rem; text-decoration:none; transition:color 0.15s; }
.back-link:hover { color:var(--magenta); }

/* DRAFT NOTICE */
.draft-notice { background:#fffbea; border:1px solid #f0d060; border-radius:8px; padding:1rem 1.5rem; font-size:0.88rem; color:#7a6000; margin:2rem 5rem; display:flex; gap:0.7rem; align-items:center; }
.draft-notice.flush { margin:2rem 0; }

/* SCROLL TOP */
.scroll-top-btn { position:fixed; bottom:2rem; right:2rem; background:var(--ink); color:var(--white); border:none; width:44px; height:44px; border-radius:50%; font-size:1.2rem; cursor:pointer; display:none; align-items:center; justify-content:center; z-index:200; transition:background 0.15s; }
.scroll-top-btn:hover { background:var(--magenta); }
.scroll-top-btn.visible { display:flex; }

/* MINI FOOTER */
.mini-footer { background:var(--ink); color:rgba(255,255,255,0.45); padding:2rem 5rem; font-size:0.88rem; display:flex; justify-content:space-between; }
.mini-footer span { color:rgba(255,255,255,0.7); cursor:pointer; font-family:var(--display); font-size:1.1rem; }

/* 4. EXTRACTED UTILITIES & COMPONENTS ------------------------ */

/* Inline text link (was a coloured <span> with onclick) */
.text-link { color:var(--magenta); font-weight:700; text-decoration:none; cursor:pointer; }
.text-link:hover { color:var(--magenta-dark); }

/* Generic typography helpers */
.text-muted { color:var(--muted); }
.lead { font-size:1.1rem; line-height:1.85; color:var(--muted); margin-bottom:1.2rem; }
.section-lead { color:var(--muted); margin-top:-2rem; margin-bottom:3rem; max-width:560px; }
.section-text { color:var(--muted); max-width:650px; font-size:1rem; line-height:1.75; }
.section-kicker.accent { color:var(--magenta); }
.section-title.tight { margin-bottom:2.5rem; }
.section.alt { background:var(--cream); border-top:1.5px solid var(--border); border-bottom:1.5px solid var(--border); }
.section.narrow { max-width:900px; }
.section.bordered { border-top:1.5px solid var(--border); }
.about-method { padding:5rem 5rem 2rem; border-top:1.5px solid var(--border); }
.section-actions { padding:2rem 5rem 5rem; }
.emoji-lg { font-size:4rem; }

/* Spacing utilities (one-off margin nudges promoted from inline styles) */
.mt-1 { margin-top:1rem; }
.mt-15 { margin-top:1.5rem; }
.mt-2 { margin-top:2rem; }
.mt-3 { margin-top:3rem; }
.mb-2 { margin-bottom:2rem; }
.mb-25 { margin-bottom:2.5rem; }
.pb-3 { padding-bottom:3rem; }

/* Quote band (purple variant of the tagline bar) */
.quote-band { background:var(--purple); padding:1.4rem 5rem; font-family:var(--display); font-size:1.4rem; color:var(--white); font-style:italic; }

/* Two-column content grid */
.grid-2 { display:grid; grid-template-columns:1fr 1fr; gap:1.5rem; }

/* Split grid (white cells on a hairline border background) */
.split-grid { display:grid; grid-template-columns:1fr 1fr; gap:1.5px; background:var(--border); }
.split-cell { background:var(--white); padding:2rem; }
.split-num { font-family:var(--display); font-size:2.5rem; color:var(--border); line-height:1; margin-bottom:0.5rem; }
.split-cell h3 { font-family:var(--display); font-size:1.3rem; margin-bottom:0.8rem; }
.split-cell p { font-size:0.95rem; line-height:1.75; color:var(--muted); }

/* Approach value list (home) */
.value-list { display:flex; flex-direction:column; gap:1.5px; background:var(--border); }
.value-item { background:var(--white); padding:1.2rem 1.5rem; display:flex; gap:1rem; align-items:flex-start; }
.value-dot { width:12px; height:12px; border-radius:50%; background:var(--magenta); flex-shrink:0; margin-top:5px; }
.value-dot.yellow { background:var(--yellow); }
.value-dot.green { background:var(--green); }
.value-dot.blue { background:var(--blue); }
.value-title { font-weight:700; font-size:0.95rem; margin-bottom:0.2rem; }
.value-text { font-size:0.88rem; color:var(--muted); line-height:1.55; }

/* Event cards */
.event-grid { display:grid; grid-template-columns:1fr 1fr; gap:1.5rem; max-width:860px; }
.event-card { background:var(--white); border:1.5px solid var(--border); border-radius:12px; padding:2rem; border-top:4px solid var(--magenta); }
.event-card.blue { border-top-color:var(--blue); }
.event-card h3 { font-family:var(--display); font-size:1.4rem; margin-bottom:1rem; line-height:1.2; }
.event-card-label { font-size:0.75rem; font-weight:700; letter-spacing:0.12em; text-transform:uppercase; color:var(--muted); margin-bottom:0.8rem; }
.event-card-meta { font-size:0.9rem; color:var(--muted); margin-bottom:0.3rem; }
.event-card .btn-primary { margin-top:1.2rem; }
.event-more { margin-top:1.5rem; }
/* Larger event cards (event page) */
.event-card-lg { background:var(--white); border:1.5px solid var(--border); border-radius:16px; padding:2.5rem; border-top:5px solid var(--magenta); }
.event-card-lg.blue { border-top-color:var(--blue); }
.event-card-lg h2 { font-family:var(--display); font-size:1.8rem; line-height:1.1; margin-bottom:1rem; }
.event-card-desc { color:var(--muted); font-size:0.97rem; line-height:1.7; margin-bottom:1.5rem; }
.event-card-info { font-size:0.9rem; color:var(--ink); font-weight:500; margin-bottom:0.4rem; }

/* Articles list "view all" row */
.articles-more { margin-top:2rem; text-align:right; }

/* 5. RESPONSIVE --------------------------------------------- */

/* ============================================
   MOBILE – allt under 768px
   ============================================ */
@media (max-width: 768px) {

  /* NAV – hamburgermeny */
  nav { padding:0 1.5rem; height:56px; position:relative; }
  .nav-links { display:none; flex-direction:column; position:absolute; top:56px; left:0; right:0; background:var(--white); border-bottom:1px solid var(--border); padding:1rem 0; z-index:99; box-shadow:0 4px 12px rgba(0,0,0,0.08); }
  .nav-links.open { display:flex; }
  .nav-links li a { padding:0.75rem 1.5rem; font-size:1rem; border-bottom:1px solid var(--border); }
  .nav-links li:last-child a { border-bottom:none; }
  .nav-cta { margin:0.5rem 1.5rem !important; border-radius:4px !important; text-align:center; padding:0.75rem 1.5rem !important; }
  .nav-hamburger { display:flex; flex-direction:column; gap:5px; cursor:pointer; padding:6px; }
  .nav-hamburger span { display:block; width:24px; height:2px; background:var(--ink); border-radius:2px; transition:all 0.2s; }

  /* HERO */
  .hero { grid-template-columns:1fr; min-height:auto; }
  .hero-left { padding:4rem 1.5rem 3rem; }
  .hero-h1 { font-size:2.6rem; }
  .hero-sub { font-size:1rem; }
  .hero-right { min-height:280px; }
  .hero-blob-wrap { padding:1.5rem; }
  .hero-btns { flex-direction:column; }
  .btn-primary, .btn-outline-dark, .btn-dark, .btn-white { width:100%; text-align:center; padding:1rem; }

  /* TAGLINE */
  .tagline-bar, .quote-band { padding:1rem 1.5rem; font-size:1.1rem; }

  /* SECTIONS */
  .section { padding:3.5rem 1.5rem; }
  .section-title { margin-bottom:2rem; }

  /* SERVICES */
  .services-grid { grid-template-columns:1fr; }
  .service-card { padding:2rem 1.5rem; }

  /* APPROACH */
  .approach-section { grid-template-columns:1fr; gap:2.5rem; padding:3.5rem 1.5rem; }

  /* ABOUT */
  .about-preview { grid-template-columns:1fr; gap:2.5rem; padding:3.5rem 1.5rem; }
  .about-visual { grid-template-columns:1fr 1fr; }
  .about-blob { font-size:1rem; }

  /* ARTICLES PREVIEW */
  .articles-preview { padding:3.5rem 1.5rem; }
  .articles-row { grid-template-columns:1fr; }

  /* CTA BAND */
  .cta-band { flex-direction:column; padding:3rem 1.5rem; gap:1.5rem; }
  .cta-band h2 { font-size:1.7rem; }

  /* FOOTER */
  footer { flex-direction:column; padding:2.5rem 1.5rem; gap:2rem; }
  .footer-grid { grid-template-columns:1fr !important; gap:2rem !important; }
  footer > div:last-child { text-align:left; }

  /* INNER HERO */
  .inner-hero { padding:3.5rem 1.5rem 2.5rem; }
  .inner-hero h1 { font-size:2.2rem; }
  .inner-hero-sub { font-size:1rem; }
  .inner-hero-deco { display:none; } /* Hide decorative icons on mobile */

  /* SERVICE BODY */
  .service-body { grid-template-columns:1fr; gap:2.5rem; padding:3rem 1.5rem; }
  .service-sidebar { position:static; }

  /* TEAM */
  .team-section { padding:3rem 1.5rem; }
  .team-grid { grid-template-columns:1fr; }

  /* METOD */
  .metod-intro { padding:3rem 1.5rem 1.5rem; }
  .metod-blocks { grid-template-columns:1fr; margin:0 1.5rem; }
  .metod-quote { padding:3rem 1.5rem; }
  .metod-quote blockquote { font-size:1.4rem; }

  /* FAQ */
  .faq-section { padding:3rem 1.5rem; }

  /* KONTAKT */
  .kontakt-grid { grid-template-columns:1fr; gap:3rem; padding:3rem 1.5rem; }
  .form-row { grid-template-columns:1fr; }

  /* ARTICLES PAGE */
  .articles-page-grid { padding:2rem 1.5rem 4rem; }
  .articles-full-grid { grid-template-columns:1fr; }
  .article-featured { grid-template-columns:1fr; }
  .article-featured-img { min-height:160px; }

  /* ARTICLE SINGLE */
  .article-single { padding:2.5rem 1.5rem 4rem; }
  .article-single blockquote { font-size:1.1rem; }
  .article-back { padding:2.5rem 1.5rem 0; }

  /* DRAFT NOTICE */
  .draft-notice { margin:1.5rem; }
  .draft-notice.flush { margin:1.5rem 0; }

  /* BACK LINK */
  .back-link { padding-left:1.5rem; padding-top:1.5rem; }

  /* MINI FOOTER */
  .mini-footer { flex-direction:column; padding:1.5rem; gap:0.5rem; }

  /* TWO-COLUMN CONTENT GRIDS */
  .grid-2, .event-grid, .split-grid { grid-template-columns:1fr !important; }

  /* SCROLL TOP */
  .scroll-top-btn { bottom:1.2rem; right:1.2rem; }
}

/* Desktop – hide hamburger, always show nav links */
@media (min-width: 769px) {
  .nav-hamburger { display:none; }
  .nav-links { display:flex !important; }
}
