/*
 Theme Name:   Nordic Dendrit
 Theme URI:    https://tst.dendrit.dk
 Description:  Professionelt nordisk theme for Dendrit - Sundheds-IT konsulentvirksomhed.
 Author:       Dendrit
 Author URI:   https://dendrit.dk
 Template:     astra
 Version:      1.0.0
 Text Domain:  nordic-dendrit
*/

:root {
  --nordic-bg-primary: #F7F8FA;
  --nordic-bg-secondary: #EDF0F4;
  --nordic-text-primary: #1A2332;
  --nordic-text-secondary: #5A6A7A;
  --nordic-accent: #1B6B93;
  --nordic-accent-hover: #145272;
  --nordic-accent-warm: #2E8B6F;
  --nordic-border: #D8DDE5;
  --nordic-white: #FFFFFF;
  --nordic-radius: 6px;
  --nordic-radius-pill: 24px;
  --nordic-font: Inter, -apple-system, BlinkMacSystemFont, Segoe UI, sans-serif;
}

*, *::before, *::after { box-sizing: border-box; }

body {
  background-color: var(--nordic-bg-primary) !important;
  color: var(--nordic-text-primary) !important;
  font-family: var(--nordic-font) !important;
  line-height: 1.7;
  margin: 0;
  -webkit-font-smoothing: antialiased;
}

/* Hide Astra defaults */
.ast-primary-header-bar, .site-header:not(.nordic-site-header),
#ast-desktop-header, #ast-mobile-header,
.ast-above-header, .ast-below-header { display: none !important; }
.ast-footer-overlay, .site-footer:not(.nordic-site-footer),
.ast-small-footer { display: none !important; }
.nordic-front-page .ast-container,
.nordic-page .ast-container { max-width: none; padding: 0; }

/* Container */
.nordic-container { max-width: 1140px; margin: 0 auto; padding: 0 24px; }

/* Typography */
h1, h2, h3, h4, h5, h6 {
  color: var(--nordic-text-primary) !important;
  font-family: var(--nordic-font) !important;
  letter-spacing: -0.02em; line-height: 1.3;
}
h1 { font-weight: 600; font-size: 2.5rem; }
h2 { font-weight: 600; font-size: 2rem; margin-bottom: 1rem; }
h3 { font-weight: 500; font-size: 1.5rem; }
p, li, td, th, label, span { font-family: var(--nordic-font) !important; }
a { color: var(--nordic-accent); text-decoration: none; transition: color 0.2s ease; }
a:hover, a:focus { color: var(--nordic-accent-hover); }

/* ===== SITE HEADER ===== */
.nordic-site-header {
  background-color: var(--nordic-white);
  border-bottom: 1px solid var(--nordic-border);
  position: sticky; top: 0; z-index: 1000;
}
.nordic-header-inner {
  display: flex; align-items: center; justify-content: space-between;
  padding-top: 16px; padding-bottom: 16px;
}
.nordic-site-branding { display: flex; align-items: center; gap: 12px; }
.nordic-logo-wrap { flex-shrink: 0; }
.nordic-logo-wrap .custom-logo-link { display: block; line-height: 0; }
.nordic-logo-wrap .custom-logo { height: 40px; width: auto; border-radius: 4px; object-fit: contain; }
.nordic-site-title-link { text-decoration: none !important; }
.nordic-site-title {
  font-family: var(--nordic-font) !important; font-weight: 600;
  font-size: 1.2rem; color: var(--nordic-text-primary); letter-spacing: -0.01em;
}
.nordic-site-title-link:hover .nordic-site-title { color: var(--nordic-accent); }

/* Navigation */
.nordic-menu-list {
  list-style: none; display: flex; gap: 8px; margin: 0; padding: 0;
}
.nordic-menu-list li a {
  display: block; padding: 8px 16px;
  color: var(--nordic-text-primary) !important;
  font-family: var(--nordic-font) !important; font-weight: 400; font-size: 0.9375rem;
  border-radius: var(--nordic-radius);
  transition: background-color 0.2s ease, color 0.2s ease;
  text-decoration: none !important;
}
.nordic-menu-list li a:hover,
.nordic-menu-list li.current-menu-item > a {
  color: var(--nordic-accent) !important; background-color: var(--nordic-bg-secondary);
}
.nordic-menu-toggle {
  display: none; background: none; border: none; cursor: pointer;
  padding: 8px; color: var(--nordic-text-primary);
}

/* ===== SITE FOOTER ===== */
.nordic-site-footer {
  background-color: var(--nordic-bg-secondary);
  border-top: 1px solid var(--nordic-border);
  padding: 32px 0; text-align: center;
  color: var(--nordic-text-secondary); font-size: 0.875rem;
}
.nordic-site-footer p { margin: 0 0 4px; color: var(--nordic-text-secondary); }

/* ===== HERO ===== */
.nordic-hero {
  position: relative; min-height: 70vh;
  display: flex; align-items: center; justify-content: center;
  background-size: cover; background-position: center;
}
.nordic-hero-overlay {
  position: absolute; inset: 0;
  background: linear-gradient(to bottom, rgba(26,35,50,0.5) 0%, rgba(26,35,50,0.7) 100%);
}
.nordic-hero-content {
  position: relative; z-index: 1; text-align: center; padding: 40px 24px;
}
.nordic-hero-title {
  color: var(--nordic-white) !important; font-size: 3.5rem; font-weight: 600;
  margin: 0 0 8px; text-shadow: 0 2px 20px rgba(0,0,0,0.2);
}
.nordic-hero-subtitle {
  color: rgba(255,255,255,0.95) !important; font-size: 1.5rem; font-weight: 400;
  margin: 0 0 8px;
}
.nordic-hero-desc {
  color: rgba(255,255,255,0.8) !important; font-size: 1.05rem; font-weight: 400;
  margin: 0 0 32px;
}
.nordic-hero-cta {
  display: inline-block; background-color: var(--nordic-white) !important;
  color: var(--nordic-text-primary) !important; padding: 14px 36px !important;
  border-radius: var(--nordic-radius-pill) !important;
  font-weight: 500 !important; font-size: 1rem !important;
  text-decoration: none !important;
  transition: transform 0.2s ease, box-shadow 0.2s ease;
  box-shadow: 0 4px 20px rgba(0,0,0,0.15);
}
.nordic-hero-cta:hover {
  transform: translateY(-2px); box-shadow: 0 6px 28px rgba(0,0,0,0.2);
  color: var(--nordic-accent) !important;
}

/* ===== SERVICES / EXPERTISE ===== */
.nordic-services { padding: 80px 0; background-color: var(--nordic-white); }
.nordic-services h2 { text-align: center; margin-bottom: 48px; }
.nordic-services-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 32px; }
.nordic-service-card {
  background: var(--nordic-bg-primary); border: 1px solid var(--nordic-border);
  border-radius: var(--nordic-radius); padding: 40px 28px; text-align: center;
  transition: transform 0.2s ease, box-shadow 0.2s ease;
}
.nordic-service-card:hover {
  transform: translateY(-4px); box-shadow: 0 8px 30px rgba(0,0,0,0.06);
}
.nordic-service-icon {
  display: flex; align-items: center; justify-content: center;
  width: 56px; height: 56px; margin: 0 auto 20px;
  background-color: rgba(27,107,147,0.08); border-radius: 50%;
  color: var(--nordic-accent);
}
.nordic-service-card h3 { font-size: 1.15rem; font-weight: 600; margin: 0 0 12px; }
.nordic-service-card p { font-size: 0.9375rem; color: var(--nordic-text-secondary) !important; margin: 0; line-height: 1.6; }

/* ===== ABOUT SECTION ===== */
.nordic-about { padding: 80px 0; background-color: var(--nordic-bg-secondary); }
.nordic-about-grid {
  display: grid; grid-template-columns: 1fr 1fr; gap: 48px; align-items: center;
}
.nordic-about h2 { margin-bottom: 20px; }
.nordic-about p { font-size: 1rem; color: var(--nordic-text-secondary) !important; line-height: 1.8; margin-bottom: 16px; }
.nordic-about-cta {
  display: inline-block; margin-top: 8px;
  color: var(--nordic-accent) !important; font-weight: 500;
  border-bottom: 2px solid var(--nordic-accent);
  padding-bottom: 2px;
}
.nordic-about-cta:hover { color: var(--nordic-accent-hover) !important; border-color: var(--nordic-accent-hover); }
.nordic-about-image img {
  width: 100%; border-radius: var(--nordic-radius);
  box-shadow: 0 8px 30px rgba(0,0,0,0.08);
}

/* ===== CONTACT STRIP ===== */
.nordic-contact-strip {
  padding: 64px 0; background-color: var(--nordic-accent); text-align: center;
}
.nordic-contact-strip h2 { color: var(--nordic-white) !important; margin-bottom: 12px; }
.nordic-contact-strip p { color: rgba(255,255,255,0.85) !important; margin-bottom: 24px; font-size: 1.05rem; }
.nordic-contact-strip .nordic-cta-btn {
  display: inline-block; background-color: var(--nordic-white) !important;
  color: var(--nordic-accent) !important; padding: 14px 36px !important;
  border-radius: var(--nordic-radius-pill) !important;
  font-weight: 500 !important; font-size: 1rem !important;
  text-decoration: none !important;
  transition: transform 0.2s ease, box-shadow 0.2s ease;
}
.nordic-contact-strip .nordic-cta-btn:hover {
  transform: translateY(-2px); box-shadow: 0 4px 20px rgba(0,0,0,0.15);
}
.nordic-contact-strip .nordic-contact-meta {
  margin-top: 24px; color: rgba(255,255,255,0.65) !important; font-size: 0.875rem;
}

/* ===== PAGE TEMPLATE ===== */
.nordic-page-header {
  background-color: var(--nordic-bg-secondary); padding: 48px 0;
  border-bottom: 1px solid var(--nordic-border);
}
.nordic-page-title { font-size: 2.25rem; margin: 0; }
.nordic-page-content {
  padding: 48px 0 80px; background-color: var(--nordic-white); min-height: 50vh;
}
.nordic-page-content > .nordic-container { max-width: 960px; }

/* Astra overrides inside our templates */
.nordic-page .ast-article-single,
.nordic-page .ast-article-post {
  background: none !important; border: none !important;
  box-shadow: none !important; padding: 0 !important; margin: 0 !important;
}
.nordic-page .entry-title { display: none; }
.nordic-page .entry-content { margin: 0; font-size: 1rem; line-height: 1.7; }

/* ===== BUTTONS ===== */
button[type=submit], input[type=submit] {
  background-color: var(--nordic-accent) !important;
  color: var(--nordic-white) !important;
  border-radius: var(--nordic-radius-pill) !important;
  border: none !important; padding: 12px 32px !important;
  font-family: var(--nordic-font) !important; font-weight: 500 !important;
  cursor: pointer; transition: background-color 0.2s ease;
}
button[type=submit]:hover, input[type=submit]:hover {
  background-color: var(--nordic-accent-hover) !important;
}

/* ===== FORMS ===== */
input[type=text], input[type=email], input[type=password],
input[type=tel], input[type=url], select, textarea {
  border: 1px solid var(--nordic-border) !important;
  border-radius: 6px !important; padding: 12px 16px !important;
  font-family: var(--nordic-font) !important; font-size: 0.9375rem !important;
  background-color: var(--nordic-white) !important;
  transition: border-color 0.2s ease, box-shadow 0.2s ease !important;
  width: 100%;
}
input:focus, select:focus, textarea:focus {
  border-color: var(--nordic-accent) !important; outline: none !important;
  box-shadow: 0 0 0 3px rgba(27,107,147,0.12) !important;
}

/* ===== LOGIN PAGE ===== */
body.login { background-color: var(--nordic-bg-primary) !important; font-family: var(--nordic-font) !important; }
.login form {
  background: var(--nordic-white) !important; border-radius: var(--nordic-radius) !important;
  border: 1px solid var(--nordic-border) !important;
  box-shadow: 0 2px 16px rgba(0,0,0,0.06) !important;
}
.login .button-primary {
  background-color: var(--nordic-accent) !important;
  border-color: var(--nordic-accent) !important;
  border-radius: var(--nordic-radius-pill) !important;
}
.login .button-primary:hover {
  background-color: var(--nordic-accent-hover) !important;
}

/* ===== RESPONSIVE ===== */
@media (max-width: 921px) {
  .nordic-menu-toggle { display: block; }
  .nordic-menu-list {
    display: none; flex-direction: column; position: absolute;
    top: 100%; left: 0; right: 0; background: var(--nordic-white);
    border-bottom: 1px solid var(--nordic-border);
    padding: 8px 24px 16px; box-shadow: 0 8px 20px rgba(0,0,0,0.06);
  }
  .nordic-menu-list.is-open { display: flex; }
  .nordic-hero { min-height: 50vh; }
  .nordic-hero-title { font-size: 2.25rem; }
  .nordic-hero-subtitle { font-size: 1.15rem; }
  .nordic-services-grid { grid-template-columns: 1fr; }
  .nordic-about-grid { grid-template-columns: 1fr; }
  .nordic-services, .nordic-about { padding: 48px 0; }
  .nordic-contact-strip { padding: 40px 0; }
  .nordic-page-header { padding: 32px 0; }
  .nordic-page-title { font-size: 1.75rem; }
}
@media (max-width: 544px) {
  .nordic-hero { min-height: 40vh; }
  .nordic-hero-title { font-size: 1.75rem; }
  .nordic-hero-cta { padding: 12px 28px !important; }
  .nordic-services, .nordic-about { padding: 32px 0; }
}
