/*
Theme Name: Niro Law
Theme URI: https://bastardreklam.se/
Author: Oskar Nilsson
Author URI: https://bastardreklam.se/
Description: Opinionated block theme focusing on native + ACF blocks only. Includes patterns, template parts, style variations, and sensible theme.json defaults.
Version: 1.0.0
Text Domain: bastard-native-blocks
License: GPL-2.0-or-later
*/

@font-face {
  font-family: 'Special Gothic';
  src: url('assets/fonts/SpecialGothic-Regular.woff2') format('woff2');
  font-weight: 400;
  font-style: normal;
  font-display: swap;
}

@font-face {
  font-family: 'Special Gothic';
  src: url('assets/fonts/SpecialGothic-Medium.woff2') format('woff2');
  font-weight: 500;
  font-style: normal;
  font-display: swap;
}


@font-face {
  font-family: 'Special Gothic';
  src: url('assets/fonts/SpecialGothic-Bold.woff2') format('woff2');
  font-weight: 700;
  font-style: normal;
  font-display: swap;
}




/* Fast, överst, full bredd */
.site-header{
  position: fixed;
  top: 0; left: 0; right: 0;
  z-index: 9999;
  transform: translateY(0);
  transition: transform .25s ease, box-shadow .25s ease, background .25s ease;
  will-change: transform;
}

/* Admin bar (WP) – desktop */
.admin-bar .site-header{
  top: 32px;
}

/* Admin bar – mobil breakpoint (WP använder ~46px under 782px) */
@media (max-width: 782px){
  .admin-bar .site-header{ top: 46px; }
}

/* iOS safe area */
.site-header{ padding-top: env(safe-area-inset-top); }

/* Lägg “spacer” på body = headerhöjd, sätts via JS nedan */
body.has-fixed-header{
  padding-top: var(--header-h, 64px);
}

/* Scroll upp/ner – du sätter .nav-up / .nav-down på body eller header */
body.nav-up  .site-header{ transform: translateY(calc(-100% - 1px)); }
body.nav-down .site-header{ transform: translateY(0); box-shadow: 0 2px 10px rgba(0,0,0,.06); }

/* När mobilmeny/overlay är öppen: lås header synlig */
body.menu-open .site-header{ transform: none !important; }



.hero-slider {
  margin:0;
}

.banner-outer {
  background-color: var(--wp--preset--color--paper);
  color:black;
  padding:15px 0;
}

.site-header-outer {
  background-color: var(--wp--preset--color--primary);
  padding:20px 0;
  margin-top:0;
}

.site-header-inner {
  padding:0 20px;
}


.wp-block-navigation .wp-block-navigation-item {
  color: white;
}

/* Bara query-loops med klassen btc-service-loop */
.btc-service-loop .wp-block-post-template {
  display: flex;
  flex-wrap: wrap;
  gap: 1.5rem;
  list-style: none;
  margin: 0;
  padding: 0;
}

.btc-service-loop .wp-block-post-template > li {
  flex: 1 1 min(320px, 100%);
  border:2px solid var(--wp--preset--color--primary);
  padding:16px;
  border-radius: 12px;
}

.btc-service-loop .wp-block-post-template.is-layout-flow > li {
  margin-block-start: 0;
  margin-block-end: 0;
}

.btc-service-loop a {
  color:black;
}

.btc-service-loop .wp-block-post-excerpt {
  margin-top: 6px;
}

/* Frontend */
.has-highlight-text {
  color: var(--wp--preset--color--primary);
}

/* Editor (block-editorn) */
.editor-styles-wrapper .has-highlight-text {
  color: var(--wp--preset--color--primary);
}

/* CONTACT FORM */

.contact-form {
  width:100%;
}

.contact-form input {
  padding:10px;
  border:none;
  border-radius: 4px;
  width:calc(100% - 20px);
  font-family: 'Special Gothic';
}

.contact-name-adress {
  display: flex;
  margin-bottom: 20px;
}

.contact-name-adress div {
  width: 50%;
}

.contact-name-adress div:first-child {
  margin-right: 10px;
}

.contact-name-adress div:last-child {
  margin-left: 10px;
}

.contact-form textarea {
  width: calc(100% - 20px);
  padding:10px;
  border:none;
  border-radius: 4px;
  font-family: 'Special Gothic';
}

.contact-form input.theme-btn {
  background-color:var(--wp--preset--color--accent);
  display: inline-block;
  padding:14px 22px;
  width: auto;
  color: black;
  font-weight: 500;
}

.padding20, .ti-widget {
  padding:0 20px;
}

.padding40 {
  padding:0 40px;
}

.padding60 {
  padding:60px;
}

.page-hero {
  position: relative;
  min-height: 50vh;          /* justera efter smak: 40–70vh */
  overflow: hidden;
  display: flex;             /* nyckeln */
  align-items: flex-end;     /* tryck ned innehållet mot botten */
}

/* Bakgrund (bild/video) täcker hela hero:n */
.page-hero__media {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  margin: 0;
}

.page-hero__media img,
.page-hero__media video,
.post-header-video {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

/* Innehåll ovanpå, längst ned, med maxbredd */
.page-hero__inner {
  position: relative;
  z-index: 1;
  width: min(1100px, 100% - 3rem);
  padding-bottom: 60px;
}

.page-hero__title {
  margin: 0;
  color: #fff;
  font-size: clamp(2rem, 3vw, 2.8rem);
  text-shadow: 0 2px 6px rgba(0, 0, 0, .7);

}

/* Vanlig sidtitel i content-läget */
.page-content .page-title-plain {
  margin-top: 0;
  margin-bottom: 1.5rem;
}

/* Om sidan har hero: dölj plain-titeln (vi använder titeln i hero istället) */
.niro-has-page-hero .page-content .page-title-plain {
  display: none;
}

.niro-page-main {
  margin-top: 0;
}



.btc-breadcrumb {
  font-size: .9rem;
  margin: 0 0 1rem;
}

.btc-breadcrumb__list {
  list-style: none;
  padding: 0;
  margin: 0;
  display: flex;
  flex-wrap: wrap;
  gap: .35rem;
  border-bottom: 1px solid grey;
  padding-bottom: 10px;
}

.btc-breadcrumb__item a {
  text-decoration: none;
  color: var(--wp--preset--color--secondary);
}

.btc-breadcrumb__item a:hover {
  text-decoration: underline;
}

.btc-breadcrumb__item + .btc-breadcrumb__item::before {
  content: "›";
  margin: 0 .25rem 0 .15rem;
  opacity: .6;
}

.btc-breadcrumb__item--current {
  font-weight: 500;
}

strong {
  background-color:rgba(217, 153, 35, 0.15);
  font-weight: 500;
  padding:0 3px;
  display: inline-block;
}


.footer {
  padding:60px 20px;
  color:black;
}

.footer-inner {
  border-top:1px solid grey;
  padding: 30px 0;
  display: flex;
  flex-wrap: wrap;
  gap: 2rem;
}

.footer-col {
  flex: 1 1 1 220px; /* minbredd, sen växer de och radbryts snyggt */
}

.flex-header-right {
  display: flex;
  align-items: center;
}

/* Lite finputs */
.footer-col--brand {
  max-width: 260px;
}

.footer-logo img {
  display: block;
  max-width: 200px;
  height: auto;
}

.footer a {
  color:black;
}

.footer ul {
  list-style-type: none;
  padding:0;
  margin:0;
}

iframe {
  width: 100%;
}

@media (max-width: 1100px) { 

  .padding60 {
    padding:40px 20px;
  }


  .single-service .entry-content, .single-service .wp-block-post-title, .page-content, .single-employee, .btc-breadcrumb {
  padding:0 20px;
  }

 

}

/* ============================
   Mobile menu
   ============================ */

/* Desktop: dölj mobil-UI */
.mobile-menu-toggle,
.mobile-menu,
.mobile-menu-overlay {
  display: none;
}

/* Mobile */
@media (max-width: 800px) {
  /* Dölj WordPress navigation-blocket i headern på mobil */
  .site-header-inner .wp-block-navigation {
    display: none;
  }

  

  .mobile-menu-inner .wp-block-navigation {
        display: block;
    }

  /* Hamburger-knapp */
  .mobile-menu-toggle {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 44px;
    height: 44px;
    border: 0;
    background: transparent;
    cursor: pointer;
    position: relative;
    z-index: 10000; /* över overlay */
  }

  /* Hamburger-ikon */
  .hamburger {
    width: 22px;
    height: 2px;
    background: white;
    position: relative;
    display: inline-block;
  }
  .hamburger::before,
  .hamburger::after {
    content: "";
    position: absolute;
    left: 0;
    width: 22px;
    height: 2px;
    background: white;
  }
  .hamburger::before { top: -7px; }
  .hamburger::after  { top: 7px; }

  /* Overlay: finns, men är "av" tills .is-open */
  .mobile-menu-overlay {
    display: block;
    position: fixed;
    inset: 0;
    background: rgba(0, 0, 0, 0.45);
    z-index: 9998;
    height: 100vh;
    opacity: 0;
    pointer-events: none; /* blockerar inte klick när stängd */
    transition: opacity 0.25s ease;
  }
  .mobile-menu-overlay.is-open {
    opacity: 1;
    pointer-events: auto; /* fångar klick när öppen */
  }

  /* Panel */
  .mobile-menu {
    display: block;
    position: fixed;
    top: 0;
    right: 0;
    height: 100dvh;
    width: min(86vw, 360px);
    background: #fff;
    z-index: 10001; /* över overlay */
    transform: translateX(100%);
    transition: transform 0.25s ease;
    box-shadow: -10px 0 30px rgba(0, 0, 0, 0.15);
    padding: 16px;
  }

  .mobile-menu.is-open {
    transform: translateX(0);
  }

  .mobile-menu-close {
    border: 0;
    background: transparent;
    font-size: 32px;
    line-height: 1;
    cursor: pointer;
    margin-left: auto;
    display: block;
  }

  .mobile-menu-inner ul {
    list-style: none;
    padding: 0;
    margin: 12px 0 0;
  }

  .mobile-menu-inner li {
    border-bottom: 1px solid rgba(0, 0, 0, 0.08);
  }

  .mobile-menu-inner a {
    display: block;
    padding: 14px 6px;
    text-decoration: none;
    color: black !important;
  }

  /* Scroll lock */
  body.menu-open {
    overflow: hidden;
    touch-action: none;
  }
}


