/* =====================================================================
   Frimai IT — frimai.dk
   Stylesheet bygget 1:1 på Frimai IT's designmanual (designmanual/index.html).
   Ingen nye brandfarver: kun navy #010D2B + teal #12A6A8 og manualens
   afledte UI-toner. Fonte: Sora (overskrifter) + Inter (brødtekst).
   ===================================================================== */

:root{
  /* ── Brandfarver (de eneste to, taget direkte fra logoet) ── */
  --navy:#010D2B;          /* primær */
  --teal:#12A6A8;          /* accent */

  /* ── Afledte toner (kun til UI — ikke "nye" brandfarver) ── */
  --navy-800:#0E1B39;
  --teal-700:#0E8889;       /* teal til hover/dekoration (fra manualen) */
  --teal-tint:#E7F6F6;
  /* Mørkere teal til TEKST/fokus på lys baggrund — sikrer WCAG AA-kontrast
     (#0E8889 giver kun 4,28:1 på hvid). Eneste tilføjede tone; i tråd med
     manualens egen note om at bruge en kraftigere farve til lille tekst. */
  --teal-ink:#0A6E6F;
  /* Manual-toner løftet til tokens (stod hardcodet i manualen): */
  --teal-soft:#7fd6d7;      /* lys teal til labels på mørk baggrund */
  --teal-line:#cfeceb;      /* teal-tonet kant */
  --ink:#1B2436;
  --muted:#5B6472;
  --line:#E4E7EC;
  --paper:#FFFFFF;
  --paper-2:#F5F7FA;

  --maxw:1180px;
  --r:16px;
  --shadow:0 1px 2px rgba(1,13,43,.04), 0 12px 40px -16px rgba(1,13,43,.18);
  --font-display:'Sora', system-ui, sans-serif;
  --font-body:'Inter', system-ui, sans-serif;
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  font-family:var(--font-body);
  color:var(--ink);
  background:var(--paper);
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
h1,h2,h3,h4{font-family:var(--font-display);line-height:1.08;letter-spacing:-.02em;color:var(--navy)}
a{color:inherit}
img{max-width:100%;display:block}

/* Tydeligt fokus for tastatur-navigation (tilgængelighed) */
a:focus-visible,button:focus-visible{
  outline:3px solid var(--teal-ink);outline-offset:3px;border-radius:6px;
}

/* Skip-link til skærmlæsere / tastatur */
.skip{
  position:absolute;left:-9999px;top:0;z-index:100;
  background:var(--navy);color:#fff;padding:12px 18px;border-radius:0 0 10px 0;
  font-family:var(--font-display);font-weight:600;font-size:.9rem;
}
.skip:focus{left:0}

/* ───────────────────────── Layout ───────────────────────── */
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 28px}
section{padding:104px 0;border-bottom:1px solid var(--line)}
/* Den sticky topbar må ikke dække sektionens overskrift ved in-page-spring (menu/skip-link) */
section[id],#top{scroll-margin-top:100px}
/* Skip-link-målet (hero) skal kunne få fokus uden at vise en stor outline-ramme */
.hero[tabindex]:focus{outline:none}
.eyebrow{
  display:inline-flex;align-items:center;gap:10px;
  font-family:var(--font-display);font-weight:600;font-size:.74rem;
  letter-spacing:.22em;text-transform:uppercase;color:var(--teal-ink);
  margin-bottom:18px;
}
.eyebrow .num{
  font-variant-numeric:tabular-nums;color:var(--navy);
  background:var(--teal-tint);border-radius:6px;padding:2px 8px;
}
.sec-title{font-size:clamp(2rem,4.4vw,3.1rem);font-weight:700;margin-bottom:14px}
.sec-lead{font-size:1.12rem;color:var(--muted);max-width:62ch}

/* ───────────────────────── Knapper ───────────────────────── */
/* Primær = teal, sekundær = navy. Bløde hjørner, Sora-tekst. (jf. manual) */
.btn{
  display:inline-flex;align-items:center;gap:10px;
  font-family:var(--font-display);font-weight:600;font-size:.98rem;
  border:none;cursor:pointer;text-decoration:none;
  padding:14px 26px;border-radius:10px;transition:.18s;
}
.btn .arrow{transition:transform .18s}
.btn:hover .arrow{transform:translateX(3px)}
/* Navy tekst på teal (6,44:1) — bestås WCAG AA. Hvid på teal er kun 2,98:1.
   Hover giver feedback via løft + skygge, ikke farveskift (bevarer kontrast). */
.btn-primary{background:var(--teal);color:var(--navy)}
.btn-primary:hover{transform:translateY(-1px);box-shadow:0 10px 26px -10px rgba(18,166,168,.55)}
.btn-navy{background:var(--navy);color:#fff}
.btn-navy:hover{background:var(--navy-800)}
.btn-ghost{background:transparent;color:#fff;border:1px solid rgba(255,255,255,.3)}
.btn-ghost:hover{background:rgba(255,255,255,.08)}
.btn-outline{background:transparent;color:var(--navy);border:1px solid var(--line)}
.btn-outline:hover{border-color:var(--teal);color:var(--teal-ink)}

/* ───────────────────────── Topbar ───────────────────────── */
header.bar{
  position:sticky;top:0;z-index:50;
  background:rgba(251,252,253,.82);backdrop-filter:blur(14px);
  border-bottom:1px solid var(--line);
  transition:box-shadow .3s ease,background .3s ease;
}
/* Krympet tilstand — sættes af main.js når man scroller (stort logo i toppen, kompakt bar nede) */
header.bar.scrolled{background:rgba(251,252,253,.92);box-shadow:0 6px 24px -12px rgba(1,13,43,.22)}
header.bar.scrolled .bar-inner{height:68px}
header.bar.scrolled .bar-logo img{height:46px}
.bar-inner{display:flex;align-items:center;justify-content:space-between;height:124px;gap:18px;transition:height .3s cubic-bezier(.4,0,.2,1)}
.bar-logo{display:flex;align-items:center;text-decoration:none}
.bar-logo img{height:104px;width:auto;display:block;transition:height .3s cubic-bezier(.4,0,.2,1)}
.bar-right{display:flex;align-items:center;gap:8px}
.bar nav{display:flex;gap:6px}
.bar nav a{
  text-decoration:none;color:var(--muted);font-size:.9rem;font-weight:500;
  padding:8px 13px;border-radius:9px;transition:.18s;
}
.bar nav a:hover{color:var(--navy);background:var(--paper-2)}
.bar .btn{padding:9px 18px;font-size:.9rem}
@media(max-width:880px){.bar nav{display:none}}

/* ───────────────────────── Hero (editorial — lys, typografi-drevet) ───────────────────────── */
.hero{
  position:relative;overflow:hidden;min-height:92vh;
  display:flex;flex-direction:column;justify-content:center;
  border-bottom:1px solid var(--line);
  padding:clamp(48px,8vw,84px) 0;
  background:
    radial-gradient(70% 55% at 88% 6%, rgba(18,166,168,.14), transparent 60%),
    radial-gradient(60% 50% at 0% 100%, rgba(18,166,168,.07), transparent 55%),
    var(--paper);
}
/* Kæmpe, beskåret FM-mærke i baggrunden — diskret brand-præg, driver ganske let */
.bg-mark{position:absolute;right:-10vw;bottom:-16vh;z-index:0;pointer-events:none;width:min(44vw,560px);opacity:.05;animation:floatmark 26s ease-in-out infinite}
.bg-mark img{width:100%;height:auto;display:block}
@keyframes floatmark{0%,100%{transform:translate(0,0)}50%{transform:translate(-1.5%,-2.5%)}}
/* Fin lodret hairline, der markerer tekstspalten (kun desktop) */
.hero::after{content:"";position:absolute;left:50%;top:0;bottom:0;width:1px;background:linear-gradient(180deg,transparent,rgba(1,13,43,.06) 18%,rgba(1,13,43,.06) 82%,transparent);z-index:0;display:none}
@media(min-width:1024px){.hero::after{display:block}}
.hero-inner{position:relative;z-index:2}
/* Editorial byline-linje */
.topline{display:flex;align-items:center;gap:14px;border-bottom:1px solid var(--line);padding-bottom:16px;margin-bottom:clamp(26px,5vw,48px);font-family:var(--font-display);font-weight:600;font-size:.74rem;letter-spacing:.2em;text-transform:uppercase;color:var(--muted)}
.topline .b{color:var(--navy)}
.topline .pip{width:7px;height:7px;border-radius:50%;background:var(--teal);box-shadow:0 0 0 4px var(--teal-tint);flex:0 0 auto}
.topline .grow{flex:1}
.topline .est{color:var(--teal-ink)}
@media(max-width:640px){.topline .est{display:none}}
/* Kæmpe overskrift + teal-shine på nøgleordet */
.hero h1{font-weight:800;color:var(--navy);font-size:clamp(2.9rem,9vw,7rem);line-height:.95;letter-spacing:-.035em;max-width:16ch}
.hero h1 .lead{display:block;color:var(--navy)}
.flow{background:linear-gradient(100deg,var(--teal-ink) 0%,var(--teal) 28%,#5ad6d7 50%,var(--teal) 72%,var(--teal-ink) 100%);background-size:240% 100%;-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;color:transparent;animation:shine 7s linear infinite}
@keyframes shine{from{background-position:0 0}to{background-position:240% 0}}
/* Meta-række: undertekst + CTA, adskilt af hairline */
.hero-meta{display:grid;grid-template-columns:minmax(0,46ch) 1fr;gap:clamp(24px,5vw,64px);align-items:end;margin-top:clamp(30px,5vw,52px);padding-top:26px;border-top:1px solid var(--line)}
@media(max-width:760px){.hero-meta{grid-template-columns:1fr;align-items:start;gap:24px}}
.hero-meta .sub{font-size:1.16rem;color:var(--muted)}
.hero-cta{display:flex;flex-wrap:wrap;gap:12px;justify-content:flex-end}
@media(max-width:760px){.hero-cta{justify-content:flex-start}}

/* ───────── Mobil-tilpasning af den nye editorial-top ───────── */
@media(max-width:760px){
  /* Hero: drop 92vh-centreringen, så der ikke er stort tomt felt øverst */
  .hero{min-height:auto;justify-content:flex-start;padding:36px 0 48px}
  .hero-meta{margin-top:28px;padding-top:22px;gap:22px}
  .hero::after{display:none} /* den lodrette hairline giver ikke mening på smal skærm */
}
@media(max-width:640px){
  /* Logoet har hele toplinjen for sig selv på mobil → gør det stort */
  .bar-inner{height:80px}
  .bar-logo img{height:60px}
  header.bar.scrolled .bar-inner{height:64px}
  header.bar.scrolled .bar-logo img{height:46px}
  .bar .btn{padding:9px 15px}
}
@media(max-width:560px){
  .wrap{padding:0 20px}                 /* lidt mere indholdsbredde på mobil */
  .hero h1{font-size:1.85rem;max-width:none;line-height:1.08;letter-spacing:-.02em}
  /* Ren logo-topbar på mobil: nav er allerede skjult, og CTA findes i hero + kontakt */
  .bar-right{display:none}
}
@media(max-width:370px){
  .hero h1{font-size:1.62rem}           /* meget små skærme (fx iPhone SE/mini) */
}

/* ───────────────────────── Ydelser ───────────────────────── */
.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:26px;margin-top:46px}
@media(max-width:760px){.grid-2{grid-template-columns:1fr}}
.services{display:grid;grid-template-columns:repeat(2,1fr);gap:24px;margin-top:46px}
@media(max-width:760px){.services{grid-template-columns:1fr}}
.card{
  background:var(--paper);border:1px solid var(--line);border-radius:var(--r);
  padding:30px;box-shadow:var(--shadow);
}
.card h3{font-size:1.18rem;margin-bottom:8px}
.card p{color:var(--muted);font-size:.98rem}
/* Ydelseskort: teal-nummer + titel + tekst */
.service{position:relative;transition:transform .18s,border-color .18s}
.service:hover{transform:translateY(-3px);border-color:var(--teal-line)}
.service .ic{
  width:48px;height:48px;border-radius:12px;background:var(--teal-tint);
  display:flex;align-items:center;justify-content:center;margin-bottom:18px;
}
.service .ic svg{width:24px;height:24px;stroke:var(--teal-700);fill:none;stroke-width:1.8}
/* Lille fag-label over hver ydelses-overskrift: overskriften sælger udbyttet,
   labelen bevarer den tekniske kategori (klarhed + SEO). Samme stil som .pt-num. */
.service .svc-tag{
  display:block;font-family:var(--font-display);font-weight:700;
  color:var(--teal-ink);font-size:.74rem;letter-spacing:.18em;
  text-transform:uppercase;margin-bottom:8px;
}
.service h3{font-size:1.22rem;margin-bottom:10px}
.service p{color:var(--muted);font-size:.98rem}

/* ───────────────────────── Udvalgt arbejde / Case ───────────────────────── */
.case{
  display:grid;grid-template-columns:1.15fr 1fr;gap:40px;align-items:center;
  background:var(--paper);border:1px solid var(--line);border-radius:calc(var(--r) + 4px);
  padding:32px;box-shadow:var(--shadow);margin-top:46px;
}
@media(max-width:820px){.case{grid-template-columns:1fr;gap:24px;padding:22px}}
.case-media{
  border-radius:12px;overflow:hidden;border:1px solid var(--line);
  box-shadow:0 18px 50px -22px rgba(1,13,43,.4);
}
.case-media img{display:block;width:100%;height:auto}
.case-body .case-tag{
  font-family:var(--font-display);font-weight:600;font-size:.74rem;letter-spacing:.18em;
  text-transform:uppercase;color:var(--teal-ink);
}
.case-body h3{font-size:1.6rem;margin:8px 0 12px}
.case-body p{color:var(--muted);font-size:1.02rem;margin-bottom:22px}

/* ───────────────────────── Citat / Hvorfor ───────────────────────── */
.quote{
  margin-top:44px;background:var(--navy-800);color:#fff;border-radius:var(--r);
  padding:46px 48px;position:relative;overflow:hidden;
}
/* (teal venstre-stribe fjernet — boksen er nu ensfarvet) */
.quote p{font-family:var(--font-display);font-weight:600;font-size:clamp(1.3rem,3vw,1.85rem);line-height:1.25;letter-spacing:-.01em}
.quote p em{font-style:normal;color:var(--teal)}
.quote .by{margin-top:16px;color:rgba(255,255,255,.55);font-size:.9rem;font-family:var(--font-body)}

/* Punkter under "Hvorfor os" */
.why-points{display:grid;grid-template-columns:repeat(2,1fr);gap:22px;margin-top:44px}
@media(max-width:760px){.why-points{grid-template-columns:1fr}}
.why-point{display:flex;flex-direction:column;gap:8px}
.why-point .pt-num{font-family:var(--font-display);font-weight:700;color:var(--teal-ink);font-size:.8rem;letter-spacing:.18em;text-transform:uppercase}
.why-point h3{font-size:1.1rem}
.why-point p{color:var(--muted);font-size:.95rem}

/* ───────────────────────── Domænetjek (lead-magnet) ───────────────────────── */
.leadmagnet{background:var(--paper-2)}
/* Lyst lead-magnet-kort: let teal-tonet baggrund + teal-accenter (ikke længere navy) */
.lm-card{
  position:relative;background:var(--teal-tint);color:var(--ink);
  border:1px solid var(--teal-line);border-radius:calc(var(--r) + 4px);
  padding:54px 56px;overflow:hidden;box-shadow:var(--shadow);
}
.lm-card::before{ /* fint teal-skær, nu meget diskret på lys baggrund */
  content:"";position:absolute;inset:0;pointer-events:none;
  background:radial-gradient(700px 420px at 95% -20%, rgba(18,166,168,.12), transparent 60%);
}
.lm-card .ring{position:absolute;border-radius:50%;border:1.5px solid rgba(18,166,168,.22);pointer-events:none}
.lm-card .ring.a{width:360px;height:360px;right:-110px;bottom:-150px}
.lm-grid{position:relative;z-index:2;display:grid;grid-template-columns:1.5fr 1fr;gap:36px;align-items:center}
@media(max-width:820px){.lm-grid{grid-template-columns:1fr}}
.lm-card .eyebrow{color:var(--teal-ink)}
.lm-card .eyebrow .num{background:#fff;color:var(--navy)}
.lm-card h2{color:var(--navy);font-size:clamp(1.7rem,3.4vw,2.4rem);font-weight:700;margin-bottom:12px}
.lm-card p{color:var(--muted);font-size:1.05rem;max-width:52ch}
.lm-checks{list-style:none;display:flex;flex-wrap:wrap;gap:10px 18px;margin-top:20px}
.lm-checks li{display:flex;align-items:center;gap:8px;font-size:.9rem;color:var(--ink);font-family:var(--font-display);font-weight:600}
.lm-checks li::before{content:"";width:7px;height:7px;border-radius:50%;background:var(--teal)}
.lm-cta{display:flex;flex-direction:column;gap:12px;align-items:flex-start}
.lm-cta .note{margin:0;background:transparent;border:none;padding:0;color:var(--muted);font-size:.82rem}

/* ───────────────────────── Kontakt (venstrestillet + trekant-grafik) ───────────────────────── */
.contact{position:relative;overflow:hidden;text-align:left}
.contact .wrap{position:relative;z-index:2}
.contact .eyebrow{justify-content:flex-start}
.contact .sec-lead{margin:0 0 30px;max-width:46ch}
.contact .customer-line{text-align:left}
.contact-cta{display:flex;flex-wrap:wrap;gap:14px;justify-content:flex-start;align-items:center}
/* Trekant-grafikken beskåret i højre kant (skjules på smalle skærme) */
.contact-gfx{position:absolute;right:0;top:0;height:100%;width:auto;z-index:0;pointer-events:none}
@media(max-width:900px){.contact-gfx{display:none}}
.contact-mail{
  font-family:var(--font-display);font-weight:700;color:var(--navy);font-size:1.15rem;
  text-decoration:none;border-bottom:2px solid var(--teal);padding-bottom:2px;
}
.contact-mail:hover{color:var(--teal-ink)}

/* Diskret "allerede kunde"-link */
.customer-line{margin-top:40px;text-align:center;font-size:.9rem;color:var(--muted)}
.customer-line a{color:var(--teal-ink);font-weight:600;text-decoration:none}
.customer-line a:hover{text-decoration:underline}

/* ───────────────────────── Footer ───────────────────────── */
footer{background:var(--navy);color:rgba(255,255,255,.7);padding:60px 0 48px;text-align:center;border:none}
footer img{height:32px;width:auto;margin:0 auto 22px;opacity:.95}
footer .f-tag{font-size:.92rem;max-width:48ch;margin:0 auto 22px;color:rgba(255,255,255,.6)}
footer .f-links{display:flex;flex-wrap:wrap;gap:8px 22px;justify-content:center;font-size:.88rem;margin-bottom:18px}
footer .f-links a{color:rgba(255,255,255,.8);text-decoration:none}
footer .f-links a:hover{color:#fff;text-decoration:underline}
footer .meta{margin-top:8px;font-size:.78rem;color:rgba(255,255,255,.55);font-family:var(--font-display);letter-spacing:.1em;text-transform:uppercase}

/* ───────────────────────── Privatlivspolitik (undeside) ───────────────────────── */
.doc{padding:72px 0}
.doc .wrap{max-width:760px}
.doc h1{font-size:clamp(2rem,4vw,2.8rem);margin-bottom:8px}
.doc .updated{color:var(--muted);font-size:.9rem;margin-bottom:36px}
.doc h2{font-size:1.3rem;margin:36px 0 10px}
.doc p,.doc li{color:var(--ink);font-size:1rem;margin-bottom:12px}
.doc ul{padding-left:22px}
.doc a{color:var(--teal-ink);font-weight:600}
.doc .back{display:inline-block;margin-top:40px;color:var(--teal-ink);font-weight:600;text-decoration:none}

/* ───────────────────────── Reveal-on-scroll (progressiv) ───────────────────────── */
/* Standard: alt er synligt. Kun hvis JS er aktivt (html.js) skjules og
   animeres indhold — så siden virker 100% uden JavaScript. */
.js .reveal{opacity:0;transform:translateY(20px);transition:opacity .6s ease,transform .6s ease}
.js .reveal.in{opacity:1;transform:none}

/* Respektér brugere der har slået bevægelse fra */
@media(prefers-reduced-motion:reduce){
  html{scroll-behavior:auto}
  .js .reveal{opacity:1;transform:none;transition:none}
  *{transition:none !important;animation:none !important}
}
