/*
Theme Name: IPTV Norway - Fjord Clarity
Theme URI: http://iptvfjord.com/
Author: IPTV Norway
Author URI: http://iptvfjord.com/
Description: Production-ready, mobile-first WordPress theme for IPTV Norway (iptvfjord.com). Nordic Minimal "Fjord Clarity" design system. Localized for Norway (nb_NO), conversion-focused, accessible and SEO-clean.
Version: 1.0.0
Requires at least: 6.0
Tested up to: 6.7
Requires PHP: 7.4
License: GNU General Public License v2 or later
License URI: http://www.gnu.org/licenses/gpl-2.0.html
Text Domain: iptvfjord
Tags: custom-theme, iptv, streaming, mobile-first, accessibility-ready
*/

/* ==========================================================================
   1. Design tokens (Fjord Clarity)
   ========================================================================== */
:root {
  --fjord-bg: #ffffff;
  --fjord-soft: #f3f6fb;          /* mist */
  --fjord-soft-2: #eaf0f8;
  --fjord-navy: #0a2540;          /* heading / brand */
  --fjord-navy-700: #143456;
  --fjord-body: #44566b;          /* body text */
  --fjord-muted: #6b7a8d;
  --fjord-red: #e11d2a;           /* primary CTA (signal red from logo) */
  --fjord-red-700: #c01622;
  --fjord-blue: #1f6fb2;          /* secondary accent (fjord blue) */
  --fjord-blue-700: #185a90;
  --fjord-teal: #15a89a;          /* aurora / live accent */
  --fjord-success: #1aa179;
  --fjord-highlight: #f0a500;
  --fjord-whatsapp: #25d366;
  --fjord-whatsapp-700: #1da851;
  --fjord-border: #e4eaf2;
  --fjord-border-strong: #cdd8e6;

  --fjord-shadow-sm: 0 1px 2px rgba(10, 37, 64, .06);
  --fjord-shadow: 0 8px 24px rgba(10, 37, 64, .08);
  --fjord-shadow-lg: 0 24px 60px rgba(10, 37, 64, .12);

  --fjord-radius-sm: 10px;
  --fjord-radius: 18px;
  --fjord-radius-lg: 26px;
  --fjord-pill: 999px;

  --fjord-maxw: 1180px;
  --fjord-gap: clamp(1rem, 3vw, 2rem);

  --fjord-font-head: "Space Grotesk", system-ui, -apple-system, "Segoe UI", Roboto, sans-serif;
  --fjord-font-body: "DM Sans", system-ui, -apple-system, "Segoe UI", Roboto, sans-serif;

  --fjord-header-h: 76px;
}

/* ==========================================================================
   2. Reset & base
   ========================================================================== */
*, *::before, *::after { box-sizing: border-box; }
html { scroll-behavior: smooth; -webkit-text-size-adjust: 100%; }
@media (prefers-reduced-motion: reduce) {
  html { scroll-behavior: auto; }
  *, *::before, *::after { animation-duration: .001ms !important; animation-iteration-count: 1 !important; transition-duration: .001ms !important; scroll-behavior: auto !important; }
}
body {
  margin: 0;
  font-family: var(--fjord-font-body);
  font-size: 1.0625rem;       /* 17px base, never below 15px for content */
  line-height: 1.65;
  color: var(--fjord-body);
  background: var(--fjord-bg);
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
}
h1, h2, h3, h4, h5 {
  font-family: var(--fjord-font-head);
  color: var(--fjord-navy);
  line-height: 1.15;
  margin: 0 0 .5em;
  font-weight: 600;
  letter-spacing: -.02em;
}
h1 { font-size: clamp(2.1rem, 5vw, 3.3rem); }
h2 { font-size: clamp(1.7rem, 3.6vw, 2.5rem); }
h3 { font-size: clamp(1.25rem, 2.2vw, 1.5rem); }
p { margin: 0 0 1rem; }
a { color: var(--fjord-blue); text-decoration: none; }
a:hover { text-decoration: underline; }
img { max-width: 100%; height: auto; display: block; }
ul, ol { margin: 0 0 1rem; padding-left: 1.2rem; }
figure { margin: 0; }
strong { color: var(--fjord-navy); }
hr { border: 0; border-top: 1px solid var(--fjord-border); margin: 2.5rem 0; }

/* ==========================================================================
   3. Accessibility helpers
   ========================================================================== */
.screen-reader-text {
  position: absolute !important; width: 1px; height: 1px; padding: 0; margin: -1px;
  overflow: hidden; clip: rect(0,0,0,0); white-space: nowrap; border: 0;
}
.fjord-skip-link {
  position: absolute; left: -999px; top: 0; z-index: 1000;
  background: var(--fjord-navy); color: #fff; padding: .8rem 1.2rem; border-radius: 0 0 var(--fjord-radius-sm) 0;
}
.fjord-skip-link:focus { left: 0; }
:focus-visible { outline: 3px solid var(--fjord-blue); outline-offset: 2px; border-radius: 4px; }

/* ==========================================================================
   4. Layout primitives
   ========================================================================== */
.fjord-container { width: 100%; max-width: var(--fjord-maxw); margin-inline: auto; padding-inline: clamp(1rem, 4vw, 2rem); }
.fjord-section { padding-block: clamp(3rem, 7vw, 5.5rem); position: relative; }
.fjord-section--soft { background: var(--fjord-soft); }
.fjord-section--navy { background: var(--fjord-navy); color: #cfe0f0; }
.fjord-section--navy h2, .fjord-section--navy h3 { color: #fff; }
.fjord-grid { display: grid; gap: var(--fjord-gap); }
.fjord-eyebrow {
  display: inline-block; font-family: var(--fjord-font-head); font-weight: 600;
  text-transform: uppercase; letter-spacing: .14em; font-size: .78rem;
  color: var(--fjord-blue); margin-bottom: .6rem; position: relative; padding-bottom: .5rem;
}
.fjord-eyebrow::after { content: ""; position: absolute; left: 0; bottom: 0; width: 34px; height: 3px; background: var(--fjord-red); border-radius: 3px; }
.fjord-section__head { max-width: 720px; margin-bottom: clamp(2rem, 4vw, 3rem); }
.fjord-section__head--center { margin-inline: auto; text-align: center; }
.fjord-section__head--center .fjord-eyebrow::after { left: 50%; transform: translateX(-50%); }
.fjord-lead { font-size: 1.15rem; color: var(--fjord-muted); }

/* Fjord horizon divider */
.fjord-horizon { display: block; width: 100%; height: auto; color: var(--fjord-soft); }
.fjord-horizon--navy { color: var(--fjord-navy); }

/* ==========================================================================
   5. Buttons
   ========================================================================== */
.fjord-btn {
  display: inline-flex; align-items: center; justify-content: center; gap: .55rem;
  font-family: var(--fjord-font-head); font-weight: 600; font-size: 1rem;
  padding: .85rem 1.5rem; border-radius: var(--fjord-pill); border: 2px solid transparent;
  cursor: pointer; transition: transform .15s ease, box-shadow .2s ease, background .2s ease, color .2s ease;
  text-decoration: none; line-height: 1; min-height: 48px;
}
.fjord-btn:hover { text-decoration: none; transform: translateY(-2px); }
.fjord-btn:active { transform: translateY(0); }
.fjord-btn--primary { background: var(--fjord-red); color: #fff; box-shadow: 0 10px 24px rgba(225,29,42,.28); }
.fjord-btn--primary:hover { background: var(--fjord-red-700); color: #fff; }
.fjord-btn--ghost { background: transparent; color: var(--fjord-navy); border-color: var(--fjord-border-strong); }
.fjord-btn--ghost:hover { border-color: var(--fjord-navy); color: var(--fjord-navy); }
.fjord-btn--navy { background: var(--fjord-navy); color: #fff; }
.fjord-btn--navy:hover { background: var(--fjord-navy-700); color: #fff; }
.fjord-btn--whatsapp { background: var(--fjord-whatsapp); color: #07351b; }
.fjord-btn--whatsapp:hover { background: var(--fjord-whatsapp-700); color: #fff; }
.fjord-btn--light { background: #fff; color: var(--fjord-navy); }
.fjord-btn--light:hover { background: var(--fjord-soft); color: var(--fjord-navy); }
.fjord-btn--block { width: 100%; }
.fjord-btn svg { width: 20px; height: 20px; flex: none; }

/* ==========================================================================
   6. Header
   ========================================================================== */
.fjord-header {
  position: sticky; top: 0; z-index: 100; background: rgba(255,255,255,.92);
  backdrop-filter: saturate(150%) blur(10px); border-bottom: 1px solid var(--fjord-border);
}
.fjord-header__inner { display: flex; align-items: center; gap: 1rem; min-height: var(--fjord-header-h); }
.fjord-brand { display: flex; align-items: center; gap: .6rem; flex: none; }
.fjord-brand img { height: 40px; width: auto; }
.fjord-brand__text { font-family: var(--fjord-font-head); font-weight: 700; color: var(--fjord-navy); font-size: 1.1rem; letter-spacing: -.01em; }
.fjord-nav { margin-left: auto; }
.fjord-nav ul { list-style: none; display: flex; gap: .35rem; margin: 0; padding: 0; align-items: center; }
.fjord-nav a { font-family: var(--fjord-font-head); font-weight: 500; color: var(--fjord-navy); padding: .55rem .7rem; border-radius: var(--fjord-radius-sm); font-size: .98rem; }
.fjord-nav a:hover { background: var(--fjord-soft); text-decoration: none; }
.fjord-nav .current-menu-item > a, .fjord-nav .current_page_item > a { color: var(--fjord-blue); }
.fjord-nav .menu-item-has-children > a::after { content: "▾"; margin-left: .25rem; font-size: .7em; opacity: .6; }
.fjord-nav .sub-menu {
  position: absolute; background: #fff; border: 1px solid var(--fjord-border); border-radius: var(--fjord-radius);
  box-shadow: var(--fjord-shadow); padding: .5rem; min-width: 230px; display: none; flex-direction: column; gap: .1rem; margin-top: .4rem;
}
.fjord-nav li { position: relative; }
.fjord-nav li:hover > .sub-menu, .fjord-nav li:focus-within > .sub-menu { display: flex; }
.fjord-header__cta { display: flex; align-items: center; gap: .6rem; flex: none; }
.fjord-burger {
  display: none; width: 48px; height: 48px; border: 1px solid var(--fjord-border-strong); background: #fff;
  border-radius: var(--fjord-radius-sm); cursor: pointer; align-items: center; justify-content: center; flex: none;
}
.fjord-burger span { display: block; width: 22px; height: 2px; background: var(--fjord-navy); position: relative; }
.fjord-burger span::before, .fjord-burger span::after { content: ""; position: absolute; left: 0; width: 22px; height: 2px; background: var(--fjord-navy); transition: .2s; }
.fjord-burger span::before { top: -7px; } .fjord-burger span::after { top: 7px; }
.fjord-burger[aria-expanded="true"] span { background: transparent; }
.fjord-burger[aria-expanded="true"] span::before { top: 0; transform: rotate(45deg); }
.fjord-burger[aria-expanded="true"] span::after { top: 0; transform: rotate(-45deg); }

/* ==========================================================================
   7. Hero
   ========================================================================== */
.fjord-hero { position: relative; overflow: hidden; background: linear-gradient(180deg, #fff 0%, var(--fjord-soft) 100%); }
.fjord-hero__inner { display: grid; grid-template-columns: 1.05fr .95fr; gap: clamp(1.5rem, 4vw, 3.5rem); align-items: center; padding-block: clamp(2.5rem, 6vw, 5rem); }
.fjord-hero__badge { display: inline-flex; align-items: center; gap: .5rem; background: #fff; border: 1px solid var(--fjord-border); border-radius: var(--fjord-pill); padding: .4rem .9rem; font-size: .85rem; font-weight: 600; color: var(--fjord-navy); box-shadow: var(--fjord-shadow-sm); margin-bottom: 1.2rem; }
.fjord-hero__badge .dot { width: 9px; height: 9px; border-radius: 50%; background: var(--fjord-teal); box-shadow: 0 0 0 4px rgba(21,168,154,.18); }
.fjord-hero h1 { margin-bottom: 1rem; }
.fjord-hero h1 .accent { color: var(--fjord-red); }
.fjord-hero__sub { font-size: 1.18rem; color: var(--fjord-body); max-width: 36ch; margin-bottom: 1.6rem; }
.fjord-hero__actions { display: flex; flex-wrap: wrap; gap: .8rem; margin-bottom: 1.6rem; }
.fjord-hero__ticks { display: grid; grid-template-columns: repeat(2, minmax(0,1fr)); gap: .6rem 1.4rem; padding: 0; margin: 0; list-style: none; }
.fjord-hero__ticks li { display: flex; align-items: flex-start; gap: .5rem; font-weight: 500; color: var(--fjord-navy); font-size: .98rem; }
.fjord-hero__ticks svg { width: 20px; height: 20px; flex: none; color: var(--fjord-success); margin-top: .1rem; }
.fjord-hero__media { position: relative; }
.fjord-hero__device { border-radius: var(--fjord-radius-lg); overflow: hidden; box-shadow: var(--fjord-shadow-lg); border: 1px solid var(--fjord-border); background: #061528; aspect-ratio: 16 / 10; }
.fjord-hero__device img, .fjord-hero__device video { width: 100%; height: 100%; object-fit: cover; display: block; }
.fjord-hero__floating { position: absolute; background: #fff; border: 1px solid var(--fjord-border); border-radius: var(--fjord-radius); box-shadow: var(--fjord-shadow); padding: .7rem .9rem; display: flex; align-items: center; gap: .6rem; font-weight: 600; color: var(--fjord-navy); font-size: .9rem; }
.fjord-hero__floating--a { left: -12px; bottom: 22px; }
.fjord-hero__floating--b { right: -10px; top: 26px; }
.fjord-hero__floating .ico { width: 34px; height: 34px; border-radius: 10px; display: grid; place-items: center; background: var(--fjord-soft-2); color: var(--fjord-blue); }
.fjord-hero__floating .ico svg { width: 18px; height: 18px; }

/* ==========================================================================
   8. Trust strip / stats
   ========================================================================== */
.fjord-trust { background: var(--fjord-navy); color: #cfe0f0; }
.fjord-trust__grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 1rem; text-align: center; padding-block: clamp(1.8rem, 4vw, 2.6rem); }
.fjord-stat__num { font-family: var(--fjord-font-head); font-size: clamp(1.6rem, 3vw, 2.2rem); font-weight: 700; color: #fff; line-height: 1; }
.fjord-stat__label { font-size: .92rem; color: #9fb6cd; margin-top: .35rem; }
.fjord-trust__grid > div { padding: .4rem; border-right: 1px solid rgba(255,255,255,.08); }
.fjord-trust__grid > div:last-child { border-right: 0; }

/* ==========================================================================
   9. Cards & feature grids
   ========================================================================== */
.fjord-cards { display: grid; gap: var(--fjord-gap); }
.fjord-cards--3 { grid-template-columns: repeat(3, 1fr); }
.fjord-cards--2 { grid-template-columns: repeat(2, 1fr); }
.fjord-cards--4 { grid-template-columns: repeat(4, 1fr); }
.fjord-card {
  background: #fff; border: 1px solid var(--fjord-border); border-radius: var(--fjord-radius);
  padding: 1.6rem; box-shadow: var(--fjord-shadow-sm); transition: box-shadow .25s ease, transform .25s ease, border-color .25s ease;
}
.fjord-card:hover { box-shadow: var(--fjord-shadow); transform: translateY(-3px); border-color: var(--fjord-border-strong); }
.fjord-card h3 { margin-bottom: .5rem; }
.fjord-card p:last-child { margin-bottom: 0; }
.fjord-icon-tile { width: 50px; height: 50px; border-radius: 14px; display: grid; place-items: center; background: var(--fjord-soft-2); color: var(--fjord-blue); margin-bottom: 1rem; }
.fjord-icon-tile svg { width: 26px; height: 26px; }
.fjord-icon-tile--red { background: #fde7e9; color: var(--fjord-red); }
.fjord-icon-tile--teal { background: #def5f2; color: var(--fjord-teal); }
.fjord-icon-tile--gold { background: #fdf0d6; color: #b07d00; }

/* ==========================================================================
   10. Pricing
   ========================================================================== */
.fjord-pricing { display: grid; grid-template-columns: repeat(4, 1fr); gap: 1.2rem; align-items: stretch; }
.fjord-plan {
  background: #fff; border: 1px solid var(--fjord-border); border-radius: var(--fjord-radius);
  padding: 1.6rem 1.4rem; display: flex; flex-direction: column; position: relative; box-shadow: var(--fjord-shadow-sm);
  transition: transform .2s ease, box-shadow .2s ease;
}
.fjord-plan:hover { transform: translateY(-4px); box-shadow: var(--fjord-shadow); }
.fjord-plan--featured { border-color: var(--fjord-navy); box-shadow: var(--fjord-shadow); }
.fjord-plan--featured::before {
  content: "Mest populær"; position: absolute; top: -13px; left: 50%; transform: translateX(-50%);
  background: var(--fjord-red); color: #fff; font-family: var(--fjord-font-head); font-weight: 600; font-size: .76rem;
  letter-spacing: .04em; padding: .35rem .9rem; border-radius: var(--fjord-pill); white-space: nowrap; box-shadow: 0 6px 16px rgba(225,29,42,.3);
}
.fjord-plan__name { font-family: var(--fjord-font-head); font-weight: 600; color: var(--fjord-navy); font-size: 1.2rem; }
.fjord-plan__price { display: flex; align-items: baseline; gap: .3rem; margin: .6rem 0 .2rem; }
.fjord-plan__price .amt { font-family: var(--fjord-font-head); font-size: 2.4rem; font-weight: 700; color: var(--fjord-navy); line-height: 1; }
.fjord-plan__price .cur { font-weight: 600; color: var(--fjord-navy); }
.fjord-plan__per { font-size: .9rem; color: var(--fjord-muted); margin-bottom: 1rem; }
.fjord-plan__per strong { color: var(--fjord-teal); }
.fjord-plan ul { list-style: none; padding: 0; margin: 0 0 1.4rem; display: grid; gap: .55rem; }
.fjord-plan li { display: flex; align-items: flex-start; gap: .5rem; font-size: .96rem; }
.fjord-plan li svg { width: 18px; height: 18px; color: var(--fjord-success); flex: none; margin-top: .15rem; }
.fjord-plan .fjord-btn { margin-top: auto; }

/* ==========================================================================
   11. Steps / timeline
   ========================================================================== */
.fjord-steps { display: grid; grid-template-columns: repeat(3, 1fr); gap: var(--fjord-gap); counter-reset: step; }
.fjord-step { position: relative; padding-left: 0; }
.fjord-step__num { width: 44px; height: 44px; border-radius: 50%; background: var(--fjord-navy); color: #fff; font-family: var(--fjord-font-head); font-weight: 700; display: grid; place-items: center; margin-bottom: 1rem; }
.fjord-timeline { list-style: none; padding: 0; margin: 0; display: grid; gap: 1.2rem; }
.fjord-timeline li { display: grid; grid-template-columns: 40px 1fr; gap: 1rem; align-items: start; }
.fjord-timeline .t { width: 40px; height: 40px; border-radius: 12px; background: var(--fjord-soft-2); color: var(--fjord-blue); display: grid; place-items: center; }
.fjord-timeline .t svg { width: 20px; height: 20px; }

/* ==========================================================================
   12. Content showcase / media rows
   ========================================================================== */
.fjord-split { display: grid; grid-template-columns: 1fr 1fr; gap: clamp(1.5rem, 4vw, 3.5rem); align-items: center; }
.fjord-split--reverse .fjord-split__media { order: 2; }
.fjord-split__media img { border-radius: var(--fjord-radius-lg); box-shadow: var(--fjord-shadow); border: 1px solid var(--fjord-border); width: 100%; }
.fjord-checklist { list-style: none; padding: 0; margin: 1.2rem 0; display: grid; gap: .7rem; }
.fjord-checklist li { display: flex; gap: .6rem; align-items: flex-start; }
.fjord-checklist svg { width: 22px; height: 22px; color: var(--fjord-success); flex: none; margin-top: .1rem; }

/* ==========================================================================
   13. FAQ accordion
   ========================================================================== */
.fjord-faq { display: grid; gap: .8rem; max-width: 820px; margin-inline: auto; }
.fjord-faq__item { border: 1px solid var(--fjord-border); border-radius: var(--fjord-radius); background: #fff; overflow: hidden; }
.fjord-faq__q { width: 100%; text-align: left; background: none; border: 0; cursor: pointer; padding: 1.1rem 1.3rem; font-family: var(--fjord-font-head); font-weight: 600; font-size: 1.05rem; color: var(--fjord-navy); display: flex; justify-content: space-between; gap: 1rem; align-items: center; }
.fjord-faq__q .ico { flex: none; width: 26px; height: 26px; border-radius: 50%; background: var(--fjord-soft-2); color: var(--fjord-blue); display: grid; place-items: center; transition: transform .25s ease, background .2s; }
.fjord-faq__q .ico svg { width: 16px; height: 16px; }
.fjord-faq__item[aria-expanded="true"] .ico, .fjord-faq__q[aria-expanded="true"] .ico { transform: rotate(45deg); background: var(--fjord-red); color: #fff; }
.fjord-faq__a { max-height: 0; overflow: hidden; transition: max-height .3s ease; }
.fjord-faq__a .inner { padding: 0 1.3rem 1.2rem; color: var(--fjord-body); }

/* ==========================================================================
   14. CTA banner
   ========================================================================== */
.fjord-cta {
  background: radial-gradient(120% 140% at 0% 0%, var(--fjord-navy-700) 0%, var(--fjord-navy) 55%);
  color: #d7e6f4; border-radius: var(--fjord-radius-lg); padding: clamp(2rem, 5vw, 3.4rem); text-align: center; position: relative; overflow: hidden;
}
.fjord-cta h2 { color: #fff; margin-bottom: .6rem; }
.fjord-cta p { max-width: 56ch; margin-inline: auto; margin-bottom: 1.6rem; }
.fjord-cta__actions { display: flex; flex-wrap: wrap; gap: .8rem; justify-content: center; }
.fjord-cta::after { content: ""; position: absolute; inset: auto -10% -60% auto; width: 380px; height: 380px; background: radial-gradient(circle, rgba(21,168,154,.35), transparent 70%); }

/* ==========================================================================
   15. Comparison table -> cards on mobile
   ========================================================================== */
.fjord-table-wrap { overflow-x: auto; border: 1px solid var(--fjord-border); border-radius: var(--fjord-radius); }
table.fjord-table { width: 100%; border-collapse: collapse; min-width: 560px; }
.fjord-table th, .fjord-table td { padding: .9rem 1rem; text-align: left; border-bottom: 1px solid var(--fjord-border); }
.fjord-table thead th { background: var(--fjord-soft); font-family: var(--fjord-font-head); color: var(--fjord-navy); }
.fjord-table tbody tr:last-child td { border-bottom: 0; }
.fjord-yes { color: var(--fjord-success); font-weight: 700; }
.fjord-no { color: var(--fjord-muted); }

/* ==========================================================================
   16. Testimonials / scenario cards
   ========================================================================== */
.fjord-quote { background: #fff; border: 1px solid var(--fjord-border); border-left: 4px solid var(--fjord-teal); border-radius: var(--fjord-radius); padding: 1.6rem; box-shadow: var(--fjord-shadow-sm); }
.fjord-quote p { font-size: 1.02rem; }
.fjord-quote__who { display: flex; align-items: center; gap: .7rem; margin-top: 1rem; }
.fjord-quote__av { width: 42px; height: 42px; border-radius: 50%; background: var(--fjord-soft-2); color: var(--fjord-blue); display: grid; place-items: center; font-family: var(--fjord-font-head); font-weight: 700; }
.fjord-quote__name { font-weight: 600; color: var(--fjord-navy); }
.fjord-quote__role { font-size: .85rem; color: var(--fjord-muted); }
.fjord-tag { display: inline-block; font-size: .72rem; font-weight: 600; letter-spacing: .04em; text-transform: uppercase; color: var(--fjord-blue); background: var(--fjord-soft-2); padding: .2rem .55rem; border-radius: var(--fjord-pill); }

/* ==========================================================================
   17. Forms
   ========================================================================== */
.fjord-field { margin-bottom: 1.1rem; }
.fjord-field label { display: block; font-weight: 600; color: var(--fjord-navy); margin-bottom: .35rem; font-size: .95rem; }
.fjord-input, .fjord-textarea, .fjord-select {
  width: 100%; padding: .85rem 1rem; border: 1px solid var(--fjord-border-strong); border-radius: var(--fjord-radius-sm);
  font: inherit; color: var(--fjord-navy); background: #fff; min-height: 50px;
}
.fjord-input:focus, .fjord-textarea:focus, .fjord-select:focus { border-color: var(--fjord-blue); outline: none; box-shadow: 0 0 0 3px rgba(31,111,178,.18); }
.fjord-textarea { min-height: 140px; resize: vertical; }
.fjord-form-card { background: #fff; border: 1px solid var(--fjord-border); border-radius: var(--fjord-radius); padding: clamp(1.4rem, 3vw, 2.2rem); box-shadow: var(--fjord-shadow-sm); }

/* ==========================================================================
   18. Breadcrumbs
   ========================================================================== */
.fjord-breadcrumbs { font-size: .88rem; color: var(--fjord-muted); padding: 1rem 0 0; }
.fjord-breadcrumbs ol { list-style: none; display: flex; flex-wrap: wrap; gap: .4rem; padding: 0; margin: 0; }
.fjord-breadcrumbs li::after { content: "/"; margin-left: .4rem; color: var(--fjord-border-strong); }
.fjord-breadcrumbs li:last-child::after { content: ""; }
.fjord-breadcrumbs a { color: var(--fjord-blue); }

/* ==========================================================================
   19. Page hero (inner pages)
   ========================================================================== */
.fjord-pagehero { background: var(--fjord-soft); border-bottom: 1px solid var(--fjord-border); }
.fjord-pagehero__inner { padding-block: clamp(2rem, 5vw, 3.4rem); max-width: 780px; }
.fjord-pagehero h1 { margin-bottom: .6rem; }
.fjord-pagehero p { font-size: 1.12rem; color: var(--fjord-muted); margin-bottom: 0; }

/* ==========================================================================
   20. Blog
   ========================================================================== */
.fjord-postgrid { display: grid; grid-template-columns: repeat(3, 1fr); gap: var(--fjord-gap); }
.fjord-postcard { background: #fff; border: 1px solid var(--fjord-border); border-radius: var(--fjord-radius); overflow: hidden; display: flex; flex-direction: column; box-shadow: var(--fjord-shadow-sm); transition: transform .2s, box-shadow .2s; }
.fjord-postcard:hover { transform: translateY(-3px); box-shadow: var(--fjord-shadow); }
.fjord-postcard__thumb { aspect-ratio: 16/9; overflow: hidden; background: var(--fjord-soft-2); }
.fjord-postcard__thumb img { width: 100%; height: 100%; object-fit: cover; }
.fjord-postcard__body { padding: 1.3rem; display: flex; flex-direction: column; flex: 1; }
.fjord-postcard__meta { font-size: .82rem; color: var(--fjord-muted); margin-bottom: .5rem; }
.fjord-postcard h3 { font-size: 1.18rem; }
.fjord-postcard h3 a { color: var(--fjord-navy); }
.fjord-postcard .more { margin-top: auto; font-weight: 600; color: var(--fjord-blue); padding-top: .8rem; }

.fjord-article { max-width: 760px; margin-inline: auto; }
.fjord-article img { border-radius: var(--fjord-radius); }
.fjord-article h2, .fjord-article h3 { margin-top: 2rem; }
.fjord-article__meta { color: var(--fjord-muted); font-size: .9rem; margin-bottom: 1.4rem; display: flex; gap: 1rem; flex-wrap: wrap; }
.fjord-article__feat { margin-bottom: 1.6rem; }
.fjord-sidebar-cta { background: var(--fjord-soft); border: 1px solid var(--fjord-border); border-radius: var(--fjord-radius); padding: 1.4rem; position: sticky; top: calc(var(--fjord-header-h) + 16px); }

.fjord-layout { display: grid; grid-template-columns: 1fr 300px; gap: clamp(1.5rem, 4vw, 3rem); align-items: start; }
.fjord-author { display: flex; gap: 1rem; align-items: center; background: var(--fjord-soft); border-radius: var(--fjord-radius); padding: 1.2rem; margin: 2rem 0; }
.fjord-author__av { width: 64px; height: 64px; border-radius: 50%; flex: none; }

.fjord-pagination { display: flex; gap: .4rem; flex-wrap: wrap; justify-content: center; margin-top: 2.5rem; }
.fjord-pagination a, .fjord-pagination span { display: grid; place-items: center; min-width: 44px; min-height: 44px; padding: 0 .6rem; border: 1px solid var(--fjord-border); border-radius: var(--fjord-radius-sm); font-family: var(--fjord-font-head); color: var(--fjord-navy); }
.fjord-pagination a:hover { background: var(--fjord-soft); text-decoration: none; }
.fjord-pagination .current { background: var(--fjord-navy); color: #fff; border-color: var(--fjord-navy); }

/* ==========================================================================
   21. Legal / prose pages
   ========================================================================== */
.fjord-prose { max-width: 820px; margin-inline: auto; }
.fjord-prose h2 { margin-top: 2.2rem; }
.fjord-prose ul { display: grid; gap: .4rem; }
.fjord-updated { display: inline-flex; align-items: center; gap: .5rem; background: var(--fjord-soft); border: 1px solid var(--fjord-border); border-radius: var(--fjord-pill); padding: .45rem 1rem; font-size: .88rem; color: var(--fjord-muted); margin-bottom: 1.6rem; }

/* ==========================================================================
   22. Footer
   ========================================================================== */
.fjord-footer { background: var(--fjord-navy); color: #9fb6cd; padding-block: clamp(2.5rem, 6vw, 4rem) 1.5rem; }
.fjord-footer a { color: #cfe0f0; }
.fjord-footer a:hover { color: #fff; }
.fjord-footer__grid { display: grid; grid-template-columns: 1.5fr 1fr 1fr 1.2fr; gap: 2rem; }
.fjord-footer__brand img { height: 38px; margin-bottom: 1rem; background: #fff; padding: 6px 10px; border-radius: 10px; }
.fjord-footer h4 { color: #fff; font-size: .95rem; text-transform: uppercase; letter-spacing: .08em; margin-bottom: 1rem; }
.fjord-footer ul { list-style: none; padding: 0; margin: 0; display: grid; gap: .55rem; }
.fjord-footer__bottom { border-top: 1px solid rgba(255,255,255,.1); margin-top: 2.5rem; padding-top: 1.4rem; display: flex; flex-wrap: wrap; gap: 1rem; justify-content: space-between; font-size: .85rem; }
.fjord-footer__legal { display: flex; flex-wrap: wrap; gap: 1rem; }
.fjord-disclaimer { font-size: .8rem; color: #7f97b0; margin-top: 1rem; max-width: 70ch; }

/* ==========================================================================
   23. Sticky mobile action bar + floating WhatsApp
   ========================================================================== */
.fjord-mobilebar { position: fixed; left: 0; right: 0; bottom: 0; z-index: 95; display: none; gap: .6rem; padding: .6rem .8rem calc(.6rem + env(safe-area-inset-bottom)); background: rgba(255,255,255,.97); border-top: 1px solid var(--fjord-border); box-shadow: 0 -6px 20px rgba(10,37,64,.08); }
.fjord-mobilebar .fjord-btn { flex: 1; padding: .8rem 1rem; }
.fjord-wa-float { position: fixed; right: 16px; bottom: 16px; z-index: 90; width: 56px; height: 56px; border-radius: 50%; background: var(--fjord-whatsapp); color: #fff; display: grid; place-items: center; box-shadow: 0 10px 24px rgba(37,211,102,.45); }
.fjord-wa-float svg { width: 30px; height: 30px; }

/* ==========================================================================
   24. Utilities & motion
   ========================================================================== */
.fjord-reveal { opacity: 0; transform: translateY(18px); transition: opacity .6s ease, transform .6s ease; }
.fjord-reveal.is-visible { opacity: 1; transform: none; }
.fjord-center { text-align: center; }
.fjord-mt { margin-top: 1.5rem; }
.fjord-mt-2 { margin-top: 2.5rem; }
.fjord-hide { display: none !important; }
.fjord-pill-list { display: flex; flex-wrap: wrap; gap: .5rem; padding: 0; margin: 1rem 0; list-style: none; }
.fjord-pill-list li { background: #fff; border: 1px solid var(--fjord-border); border-radius: var(--fjord-pill); padding: .45rem 1rem; font-weight: 500; color: var(--fjord-navy); font-size: .92rem; }

/* ==========================================================================
   25. Responsive
   ========================================================================== */
@media (max-width: 980px) {
  .fjord-hero__inner { grid-template-columns: 1fr; }
  .fjord-hero__media { order: -1; max-width: 540px; }
  .fjord-cards--4 { grid-template-columns: repeat(2, 1fr); }
  .fjord-pricing { grid-template-columns: repeat(2, 1fr); }
  .fjord-trust__grid { grid-template-columns: repeat(2, 1fr); }
  .fjord-trust__grid > div:nth-child(2) { border-right: 0; }
  .fjord-footer__grid { grid-template-columns: 1fr 1fr; }
  .fjord-layout { grid-template-columns: 1fr; }
  .fjord-sidebar-cta { position: static; }
  .fjord-split--reverse .fjord-split__media { order: 0; }
}
@media (max-width: 720px) {
  body { font-size: 1rem; }
  .fjord-nav { display: none; position: fixed; inset: var(--fjord-header-h) 0 0; background: #fff; margin: 0; overflow-y: auto; border-top: 1px solid var(--fjord-border); }
  .fjord-nav.is-open { display: block; }
  .fjord-nav ul { flex-direction: column; align-items: stretch; gap: 0; padding: .6rem; }
  .fjord-nav a { padding: .9rem 1rem; border-radius: var(--fjord-radius-sm); font-size: 1.05rem; }
  .fjord-nav .sub-menu { position: static; display: flex; box-shadow: none; border: 0; padding-left: 1rem; }
  .fjord-burger { display: inline-flex; }
  .fjord-header__cta .fjord-btn--ghost { display: none; }
  .fjord-cards--3, .fjord-cards--2, .fjord-cards--4, .fjord-steps, .fjord-postgrid, .fjord-split { grid-template-columns: 1fr; }
  .fjord-split--reverse .fjord-split__media { order: -1; }
  .fjord-pricing { grid-template-columns: 1fr; }
  .fjord-plan--featured { order: -1; }
  .fjord-trust__grid { grid-template-columns: repeat(2,1fr); }
  .fjord-footer__grid { grid-template-columns: 1fr; }
  .fjord-mobilebar { display: flex; }
  .fjord-wa-float { display: none; }
  body { padding-bottom: 76px; }
  .fjord-hero__floating { display: none; }
}
@media (min-width: 721px) { .fjord-wa-float { display: grid; } }
