/* ======================================================
   Fonts
====================================================== */
/* ======================================================
    DM Serif Display 
====================================================== */
@font-face {
  font-family: "DM Serif Display";
  src: url("../fonts/dm-serif-display/dm-serif-display-400.woff2") format("woff2");
  font-weight: 400;
  font-style: normal;
  font-display: swap;
}
/* ======================================================
   Inter Font
====================================================== */
@font-face {
  font-family:"Inter";
  src:url("../fonts/inter/Inter-Regular.woff2") format("woff2");
  font-weight:400;
  font-style:normal;
  font-display:swap;
}

@font-face {
  font-family:"Inter";
  src:url("../fonts/inter/Inter-Italic.woff2") format("woff2");
  font-weight:400;
  font-style:italic;
  font-display:swap;
}

@font-face {
  font-family:"Inter";
  src:url("../fonts/inter/Inter-Medium.woff2") format("woff2");
  font-weight:500;
  font-style:normal;
  font-display:swap;
}

@font-face {
  font-family:"Inter";
  src:url("../fonts/inter/Inter-MediumItalic.woff2") format("woff2");
  font-weight:500;
  font-style:italic;
  font-display:swap;
}

@font-face {
  font-family:"Inter";
  src:url("../fonts/inter/Inter-SemiBold.woff2") format("woff2");
  font-weight:600;
  font-style:normal;
  font-display:swap;
}

@font-face {
  font-family:"Inter";
  src:url("../fonts/inter/Inter-SemiBoldItalic.woff2") format("woff2");
  font-weight:600;
  font-style:italic;
  font-display:swap;
}

@font-face {
  font-family:"Inter";
  src:url("../fonts/inter/Inter-Bold.woff2") format("woff2");
  font-weight:700;
  font-style:normal;
  font-display:swap;
}

@font-face {
  font-family:"Inter";
  src:url("../fonts/inter/Inter-BoldItalic.woff2") format("woff2");
  font-weight:700;
  font-style:italic;
  font-display:swap;
}

/* ======================================================
   1. Color System (variables)
====================================================== */

:root {
  --white:#ffffff;
  --black:#1a1a1a;
  --body-bg:#f7f6f3;
  --body-color:#2b2b2b;

  --base: #556149; /*   --base:#6f8f88; */
  --accent:#7c9ab0;
  --accent2:#a8bfb7;

  --primary:#045e93; /*   --primary:#c98f6b; */

  --primary2:#f1ebe6;
  --primary3:#e7e2dc;
  --primary4:#d6d1cb;

  --body-size: 1.15rem;
  --border-radius-sm: 10px;
  --border-radius: 16px;
  --border-radius-lg: 500px;

  --font-body: "Inter", system-ui, -apple-system, sans-serif;
  --font-heading: "DM Serif Display", serif;
}


/* ======================================================
   2. Bootstrap Variable Overrides
====================================================== */

:root {
  --bs-body-bg: var(--body-bg);
  --bs-body-color: var(--body-color);

  --bs-primary: var(--primary);
  --bs-secondary: var(--base);
  --bs-info: var(--accent);
  --bs-success: var(--accent2);

  --bs-link-color: var(--primary);
  --bs-link-hover-color: var(--base);

  --bs-border-color: var(--primary4);

  --bs-border-radius-sm: var(--border-radius-sm);
  --bs-border-radius: var(--border-radius);
  --bs-border-radius-pill: var(--border-radius-lg);

  --bs-body-font-size: var(--body-size);
}


/* ======================================================
   3. Global Elements
====================================================== */

body {
  background: var(--body-bg);
  color: var(--body-color);
  font-family:var(--font-body);
  font-weight:400;
  line-height:1.65;
  -webkit-font-smoothing:antialiased;

}

h1,h2,h3,h4,h5,h6 {
  font-family:var(--font-heading);
  font-weight:400;
  letter-spacing:.02em;
}

/* Utility classes for ACF background choices */
.bg-base { background: var(--base); }
.bg-accent { background: var(--accent); }
.bg-primary-soft { background: var(--primary2); }

.text-base { color: var(--base); }
.text-accent { color: var(--accent); }

/* Text helpers (theme-safe) */
.text-dark { color: var(--body-color); }
.text-white { color: var(--white); }

.bg-primary { background: var(--primary); }

.bg-black { background: var(--black); }
.bg-white { background: var(--white); }


/* ======================================================
   4. Components Improvements
====================================================== */

a {
  text-underline-offset: 20%;
}
/* Anchor scrolling with sticky header */
[id] {
  scroll-margin-top: 100px;
}

/* Brand button polish */
.btn {
  border-radius: var(--border-radius);
  padding: .75rem 1.25rem;
}
.btn,
.navbar,
.urge-prislista__price {
  font-weight:800;
}

strong, b {
  font-weight:600;
}

/* Primary */
.btn-primary {
  background-color: var(--primary);
  border-color: var(--primary);
  color: #fff;
}

.btn-primary:hover,
.btn-primary:focus {
  background-color: var(--base);
  border-color: var(--base);
  color: #fff;
}

/* Secondary */
.btn-secondary {
  background-color: var(--base);
  border-color: var(--base);
  color: #fff;
}

.btn-secondary:hover,
.btn-secondary:focus {
  background-color: var(--accent);
  border-color: var(--accent);
  color: #fff;
}

/* Outline primary (used by your ACF "outline") */
.btn-outline-primary {
  border-color: var(--primary);
  color: var(--primary);
}

.btn-outline-primary:hover,
.btn-outline-primary:focus {
  background-color: var(--primary);
  border-color: var(--primary);
  color: #fff;
}

/* Light button (used by your ACF "light") */
.btn-light {
  background-color: var(--primary2);
  border-color: var(--primary3);
  color: var(--body-color);
}

.btn-light:hover,
.btn-light:focus {
  background-color: var(--primary3);
  border-color: var(--primary4);
  color: var(--body-color);
}

/* Accessible focus ring */
.btn:focus-visible {
  box-shadow: 0 0 0 .25rem rgba(111, 143, 136, .35);
}

/* Cards */
.card {
  border-color: var(--primary4);
  border-radius: var(--border-radius);
}

/* Soft background helper */
.bg-soft {
  background: var(--primary2);
}

/* ======================================================
   Menu: Primary menu / Header Navigation
====================================================== */
.navbar-toggler {
  border: none;
}
.navbar-toggler:focus {
  box-shadow: none;
}

a.navbar-brand.logo {
    margin-right: 18rem;
    margin-left: 4rem;
}
@media (max-width: 1399.98px) {
  a.navbar-brand.logo {
    margin-right: unset;
    margin-left: unset;
  }
}

/* ======================================================
   Header Navigation
====================================================== */
.navbar-nav .nav-link {
  position: relative;
  font-family: var(--font-body);
  font-weight: 800;
  color: var(--base);
  padding: .5rem 1rem;
  transition: color .25s ease;
}

/* Hover color */

.navbar-nav .nav-link:hover,
.navbar-nav .nav-link:focus {
  color: var(--primary);
}

/* Elegant underline animation */

.navbar-nav .nav-link::after {
  content:"";
  position:absolute;
  left:1rem;
  bottom:.25rem;
  width:0;
  height:2px;
  background:var(--primary);
  transition:width .25s ease;
}

.navbar-nav .nav-link:hover::after {
  width:calc(100% - 2rem);
}

/* Active menu */
.navbar-nav .current-menu-item > .nav-link {
  color:var(--primary);
}

.navbar-nav .current-menu-item > .nav-link::after {
  width:calc(100% - 2rem);
}

@media (min-width: 1400px) {
    .navbar.navbar-expand-lg .container {
        max-width: 1698px;
    }
}

/* ======================================================
   Section: Page Header
====================================================== */

.urge-page-header {
  background-color: var(--black); /* fallback */
  background-size: cover;
  background-position: center;
  padding: clamp(3rem, 6vw, 6rem) 0;
}

.urge-page-header--sm { padding: clamp(2.5rem, 4vw, 4rem) 0; }
.urge-page-header--md { padding: clamp(3rem, 6vw, 6rem) 0; }
.urge-page-header--lg { padding: clamp(4rem, 8vw, 8rem) 0; }

.urge-page-header__overlay {
  position: absolute;
  inset: 0;
  background: rgba(0,0,0,.65);
  pointer-events: none;
}

.urge-page-header__title {
  font-weight: 700;
  letter-spacing: -0.02em;
  line-height: 1.1;
  font-size: clamp(2rem, 4vw, 3.25rem);
}

.urge-page-header__subtitle {
  font-weight: 600;
  letter-spacing: 0.02em;
}

.urge-page-header__description {
  font-size: 1.1rem;
  max-width: 60ch;
}


/* ======================================================
   Section: Half/Half Full Width (Repeater rows)
====================================================== */

.urge-half-half-full__grid {
  display: grid;
  grid-template-columns: 1fr;
  min-height: 420px;
}

@media (min-width: 992px) {
  .urge-half-half-full__grid {
    grid-template-columns: 1fr 1fr;
    min-height: 520px;
  }
}

/* media */
.urge-half-half-full__media {
  position: relative;
  min-height: 320px;
}

@media (min-width: 992px) {
  .urge-half-half-full__media {
    min-height: 520px;
  }
}

.urge-half-half-full__media img {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

/* content */
.urge-half-half-full__content {
  display: flex;
  align-items: center;
  padding: clamp(2rem, 5vw, 4rem) 0;
  background: var(--body-bg);
}

.urge-half-half-full__inner {
  width: 100%;
  max-width: 620px;
  margin: 0 auto;
  padding: 0 clamp(1rem, 3vw, 2.5rem);
}

/* Alternate ONLY on desktop */
@media (min-width: 992px) {
  .urge-half-half-full__row.is-even .urge-half-half-full__media {
    order: 2;
  }
  .urge-half-half-full__row.is-even .urge-half-half-full__content {
    order: 1;
  }
}

/* Read more / Less */
.urge-half-half-full__toggle{ 
  display: inline;
  text-decoration: none;
  font-weight: 600;
}

.urge-half-half-full__toggle:hover{
  /* text-decoration: underline; */
}

.label-more, .label-less {
  text-decoration: underline;
  text-underline-offset: 20%
}

/* ======================================================
   Section: Half Content
====================================================== */

.urge-half-content {
  position: relative;
}

.urge-half-content.bg-base,
.urge-half-content.bg-accent {
  color: #fff;
}

.urge-half-content.bg-base a,
.urge-half-content.bg-accent a {
  color: #fff;
  text-decoration: underline;
}

/* Media grid (simple masonry-like, stable on all screens) */
.urge-media-grid {
  display: grid;
  gap: 12px;
}

.urge-media-grid__item {
  border-radius: var(--border-radius);
  overflow: hidden;
}

.urge-media-grid__item img {
  width: 100%;
  height: 100%;
  display: block;
  object-fit: cover;
  object-position: center; /* Change to position / add right or left */
}

/* 1 image */
.urge-media-grid--1 {
  grid-template-columns: 1fr;
}
.urge-media-grid--1 .urge-media-grid__item img {
  aspect-ratio: 4 / 3;
}

/* 2 images: two stacked */
.urge-media-grid--2 {
  grid-template-columns: 1fr;
}
.urge-media-grid--2 .urge-media-grid__item img {
  aspect-ratio: 16 / 10;
}

/* 3 images: 1+2 stacked in column 1, image 3 tall in column 2 */
@media (min-width: 576px) {
  .urge-media-grid--3 {
    grid-template-columns: 1fr 1fr;
    grid-auto-rows: 170px;
    align-items: stretch;
  }

  .urge-media-grid--3 .urge-media-grid__item:nth-child(1) {
    grid-column: 1 / 2;
    grid-row: 1 / 2;
  }

  .urge-media-grid--3 .urge-media-grid__item:nth-child(2) {
    grid-column: 1 / 2;
    grid-row: 2 / 3;
  }

  .urge-media-grid--3 .urge-media-grid__item:nth-child(3) {
    grid-column: 2 / 3;
    grid-row: 1 / 3; /* spans both rows */
  }
}

/* a bit taller on large screens */
@media (min-width: 992px) {
  .urge-media-grid--3 {
    grid-auto-rows: 190px;
  }
}

/* ==========================================
   CTA FULL WIDTH
========================================== */

.urge-cta-full {
  position: relative;
  background-size: cover;
  background-position: center;
  padding: 100px 0;
  overflow: hidden;
}

@media (min-width: 992px) {
  .urge-cta-full {
    padding: 140px 0;
  }
}

.urge-cta-full__overlay {
  position: absolute;
  inset: 0;
  background: #000;
  z-index: 1;
}

.urge-cta-full .container {
  z-index: 2;
}

.urge-cta-full__title {
  font-weight: 700;
  font-size: clamp(28px, 4vw, 48px);
  color: inherit;
}

.urge-cta-full__text {
  font-size: 1.1rem;
  opacity: 0.95;
  color: inherit;
}

.urge-cta-full .btn {
  border-radius: var(--border-radius);
}

/* ======================================================
   Section: Contact Split (Fluent Forms)
====================================================== */

.urge-contact-split {
  position: relative;
}

/* Card that holds title + text + form */
.urge-contact-card {
  background: #fff;
  border: 1px solid var(--primary4);
  border-radius: var(--border-radius);
  padding: clamp(1.25rem, 3vw, 2.25rem);
  height: 100%;
}

/* If section background is dark, keep card readable */
.urge-contact-split.bg-base .urge-contact-card,
.urge-contact-split.bg-accent .urge-contact-card {
  background: #fff;
}

.urge-contact-intro {
  color: rgba(0,0,0,.65);
  line-height: 1.6;
}

.urge-contact-privacy {
  color: rgba(0,0,0,.55);
}

/* Media */
.urge-contact-media {
  border-radius: var(--border-radius);
  overflow: hidden;
  height: 100%;
  min-height: 280px;
}

@media (min-width: 992px) {
  .urge-contact-media {
    min-height: 520px;
  }
}

.urge-contact-media img {
  width: 100%;
  height: 100%;
  display: block;
  object-fit: cover;
  object-position: left center;
}

/* Fluent Forms: make inputs feel like the theme (safe, non-destructive) */
.urge-contact-form .ff-el-form-control {
  border-radius: var(--border-radius-sm);
  border-color: var(--primary4);
}

.urge-contact-form .ff-btn {
  border-radius: var(--border-radius);
  padding: .75rem 1.25rem;
  font-weight: 600;
}

/* Make Fluent Forms button use your palette (common class names) */
.urge-contact-form .ff-btn-primary {
  background: var(--primary);
  border-color: var(--primary);
  color: #fff;
}
.urge-contact-form .ff-btn-primary:hover {
  background: var(--base);
  border-color: var(--base);
}


/* ======================================================
   Footer – Urge
====================================================== */
.urge-footer {
  /* background already set via bg-primary-soft */
}

/* Make footer text feel calm and readable */
.urge-footer__text {
  color: rgba(0,0,0,.65);
  font-size: 1.05rem; /* close to lead, but nicer */
  line-height: 1.6;
}
.urge-footer__text.lead {
  margin-bottom: 0;
}

/* Titles */
.urge-footer h3.h4 {
  margin-bottom: 1rem;
}

/* Footer links color + hover */
.urge-footer a,
.urge-footer__link {
  color: var(--base);
}
.urge-footer a:hover,
.urge-footer__link:hover {
  color: var(--accent);
}

/* Contact icons color */
.urge-footer__icon {
  color: var(--base);
  font-size: 1.1rem;
  line-height: 1.4;
  margin-top: .1rem;
}

/* Muted text in footer (address etc.) */
.urge-footer__muted {
  color: rgba(0,0,0,.65);
}

/* Footer menu */
.urge-footer__menu li {
  margin-bottom: .5rem;
}
.urge-footer__menu a {
  text-decoration: none;
}
.urge-footer__menu a:hover {
  /* text-decoration: underline; */
}

/* Social icons (icon-only in circle) */
.urge-social-link {
  /*
  width: 42px;
  height: 42px;
  */
  border-radius: 999px;

  display: inline-flex;
  align-items: center;
  justify-content: center;

  background: transparent; /* background: var(--primary); */
  color: var(--primary) !important;   /* force color of icon #fff */
  text-decoration: none;

  transition: transform .15s ease, background-color .15s ease, opacity .15s ease;
}

/* Icon inside link */
.urge-social-link i {
  color: inherit;           /* inherit white from parent */
  font-size: 2.1rem;        /* 1.1rem; */
  line-height: 1;
}

/* Hover */
.urge-social-link:hover,
.urge-social-link:focus {
  background: var(--accent);
  color: #fff !important;
  transform: translateY(-2px);
  opacity: .95;
}

/* Accessibility focus */
.urge-social-link:focus-visible {
  outline: none;
  box-shadow: 0 0 0 .25rem rgba(111, 143, 136, .35);
}

/*  Social icons on header */
@media (max-width: 991.98px) {
  .urge-header__social .urge-social-link {
    padding: .5rem 1rem;
  }
}

/* Copyright area */
.urge-footer__copyright {
  font-size: .875rem; /* Bootstrap small-ish */
  color: rgba(0,0,0,.6);
}

.urge-footer__copyright-text,
.urge-footer__copyright-credit {
  color: inherit;
  font-style: italic;
  opacity: 0.64;
}

/* ======================================================
   Footer Navigation
====================================================== */
.urge-footer__menu a{
  position: relative;
  font-family: var(--font-body);
  font-weight: 800;
  color: var(--base);
  text-decoration: none;
  display: inline-block;
  padding: .2rem 0;
  transition: color .25s ease;
}

/* Hover */
.urge-footer__menu a:hover,
.urge-footer__menu a:focus {
  color: var(--primary);
}

/* Underline animation (same as header but adjusted) */
.urge-footer__menu a::after {
  content: "";
  position: absolute;
  left: 0;
  bottom: -2px;
  width: 0;
  height: 2px;
  background: var(--primary);
  transition: width .25s ease;
}

.urge-footer__menu a:hover::after {
  width: 100%;
}

/* Active footer menu item */
.urge-footer__menu .current-menu-item > a {
  color: var(--primary);
}

.urge-footer__menu .current-menu-item > a::after {
  width: 100%;
}


/* ======================================================
   Modal: Prislista
====================================================== */

.urge-prislista-modal{
  border: 0;
  border-radius: var(--border-radius);
  overflow: hidden;
  background: var(--white);
}

.urge-prislista-modal .modal-header,
.urge-prislista-modal .modal-footer{
  background: var(--primary2);
}

.urge-prislista-modal .modal-header{
  position: relative;
  padding: 1.5rem 1.5rem 0;
}

.urge-prislista-modal .modal-footer{
  padding: 0 1.5rem 1.5rem;
}

.urge-prislista-modal .modal-title{
  color: var(--base);
  font-weight: 400;
  font-family: var(--font-heading);
}

.urge-prislista-modal .btn-close{
  position: absolute;
  top: 1rem;
  right: 1rem;
  z-index: 5;
}

/* Body background image */
.urge-prislista__body{
  position: relative;
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
  padding: 0;
}

/* Soft overlay so image is visible but text stays readable */
.urge-prislista__body::before{
  content: "";
  position: absolute;
  inset: 0;
  background: rgba(255,255,255,.75);
}

.urge-prislista__body-inner{
  position: relative;
  z-index: 2;
  padding: clamp(1.5rem, 3vw, 2.5rem);
}

.urge-prislista__text{
  color: rgba(0,0,0,.72);
  line-height: 1.65;
  max-width: 60ch;
  margin-left: auto;
  margin-right: auto;
}

/* Therapy-style aligned list */
.urge-prislista__list{
  display: flex;
  flex-direction: column;
  gap: .85rem;
}

.urge-prislista__item{
  padding: .15rem 0;
}

.urge-prislista__item + .urge-prislista__item{
  border-top: 1px solid rgba(0,0,0,.12);
  padding-top: 1rem;
  margin-top: .15rem;
}

.urge-prislista__row{
  display: grid;
  grid-template-columns: minmax(0, 1.4fr) minmax(90px, .7fr) auto;
  align-items: center;
  column-gap: 1.5rem;
  row-gap: .25rem;
}

.urge-prislista__name{
  font-weight: 600;
  font-size: 1.15rem;
  line-height: 1.35;
  color: var(--body-color);
}

.urge-prislista__time{
  font-size: 1rem;
  line-height: 1.35;
  color: rgba(0,0,0,.62);
  white-space: nowrap;
}

.urge-prislista__price{
  font-weight: 700;
  font-size: 1.1rem;
  line-height: 1.35;
  color: var(--base);
  white-space: nowrap;
  text-align: right;
}

.urge-prislista__note{
  color: rgba(0,0,0,.6);
  line-height: 1.6;
  max-width: 60ch;
  margin-left: auto;
  margin-right: auto;
}

/* Mobile: name on first line, time + price on same line */
@media (max-width: 575.98px){
  .urge-prislista__row{
    grid-template-columns: 1fr auto;
    row-gap: .35rem;
  }

  .urge-prislista__name{
    grid-column: 1 / 3;
  }

  .urge-prislista__time{
    grid-column: 1 / 2;
    grid-row: 2;
    align-self: center;
  }

  .urge-prislista__price{
    grid-column: 2 / 3;
    grid-row: 2;
    text-align: right;
    align-self: center;
  }
}

/* ======================================================
   Prislista Text Blocks
====================================================== */

.urge-prislista__text{
  font-family: var(--font-body);
  font-size: 1.05rem;
  line-height: 1.7;
  color: rgba(0,0,0,.75);
  margin-top: 2rem;
  margin-bottom: 1rem;
  max-width: 65ch;
  margin-left: auto;
  margin-right: auto;
}

.urge-prislista__text p{
  margin-bottom: .75rem;
}

.urge-prislista__note{
  font-family: var(--font-body);
  font-size: .95rem;
  font-style: italic;
  line-height: 1.6;
  color: rgba(0,0,0,.55);
  margin-top: 1.25rem;
  padding-top: .75rem;
  border-top: 1px solid rgba(0,0,0,.12);
  max-width: 60ch;
  margin-left: auto;
  margin-right: auto;
}

.urge-prislista__note strong{
  font-weight: 600;
  color: var(--base);
}
