:root{
  --brand:#ff5700;
  --mega-bg:#d9d6cf;
  --text:#1f1f1f;
  --muted:rgba(31,31,31,.72);
  --line:rgba(255,87,0,.55);
  --container:1280px;
  --radius:18px;
}

/* =========================
   HEADER
   ========================= */
.site-header{ position:relative; z-index:999; }

.header-inner{
  display:flex;
  align-items:flex-end;
  gap:16px;
  padding:0 5%;
  position:relative;
  max-width:1200px;
  margin:0 auto;
}

/* Logo */
.site-logo{ display:flex; align-items:center; gap:12px; color:#fff; }
.site-logo img{ height:44px; width:auto; display:block; }
.logo-text{ font-weight:900; font-size:22px; color:#fff; }

/* Toggle (burger) */
.menu-toggle{
  margin-left:auto;
  width:44px;
  height:44px;
  border:0;
  background:transparent;
  display:none; /* desktop hidden */
  cursor:pointer;
  position:relative;
  z-index:10001;
}

.burger{
  display:block;
  width:26px;
  height:2px;
  background:#fff;
  position:relative;
  border-radius:2px;
}
.burger::before,
.burger::after{
  content:"";
  position:absolute;
  left:0;
  width:26px;
  height:2px;
  background:#fff;
  border-radius:2px;
  transition:transform .2s ease, top .2s ease, opacity .2s ease;
}
.burger::before{ top:-8px; }
.burger::after{ top:8px; }

/* =========================
   NAV BASE (DESKTOP)
   ========================= */
.site-nav{ margin-left:auto; }

.primary-menu{
  list-style:none;
  margin:0;
  padding:0;
  display:flex;
  align-items:center;
  gap:10px;
}

.primary-menu > li{ position:relative; }

.primary-menu > li > a{
  display:block;
  padding:18px 12px;
  color:var(--brand);
  font-weight:800;
  font-size:15px;
  letter-spacing:.2px;
  border-radius:0;
  transition:background .18s ease, transform .18s ease;
}

.home .primary-menu > li > a,
.page-template-Service-page .primary-menu > li > a,
.page-template-about .primary-menu > li > a{
  color:#fff;
}

.primary-menu > li > a:hover{
  background:rgba(0,0,0,0);
  transform:translateY(-1px);
}

/* =========================
   ARROWS (A::AFTER) — single source of truth
   ========================= */
.primary-menu > li.menu-item-has-children > a{
  position:relative;
  padding-right:30px; /* space for mobile pill */
}

/* Desktop chevron */
@media (min-width:1025px){
  .primary-menu > li.menu-item-has-children > a::after{
    content:"▾";
    position:absolute;
    right:10px;
    top:50%;
    transform:translateY(-50%);
    font-weight:900;
    font-size:14px;
    opacity:.9;
    line-height:1;
    transition:transform .18s ease;
    pointer-events:none;
  }
  .primary-menu > li.menu-item-has-children:hover > a::after{
    transform:translateY(-50%) rotate(180deg);
  }
}

/* Mobile chevron pill (rotate only on vv-acc-open) */
@media (max-width:1024px){
  .primary-menu > li.menu-item-has-children > a::after{
    content:"▾";
    position:absolute;
    right:10px;
    top:50%;
    transform:translateY(-50%) rotate(0deg);

    width:40px;
    height:40px;
    display:inline-flex;
    align-items:center;
    justify-content:center;

    border-radius:12px;
    background:rgba(255,87,0,.14);
    color:var(--brand);
    font-size:18px;
    font-weight:900;
    line-height:1;

    transition:transform .18s ease, background .18s ease;
    pointer-events:none;
  }

  .primary-menu > li.menu-item-has-children.vv-acc-open > a::after{
    transform:translateY(-50%) rotate(180deg);
    background:rgba(255,87,0,.22);
  }
}

/* =========================
   NORMAL DROPDOWNS (NON-MEGA) — DESKTOP
   ========================= */
.primary-menu > li:not(.mega-menu) > ul.sub-menu{
  position:absolute;
  top:100%;
  left:0;

  min-width:260px;
  max-width:320px;

  background:var(--mega-bg);
  border-top:1px solid rgba(0,0,0,.08);
  box-shadow:0 22px 60px rgba(0,0,0,.22);

  padding:5px 15px;
  margin:0;
  list-style:none;

  opacity:0;
  visibility:hidden;
  transform:translateY(10px);
  transition:opacity .18s ease, transform .18s ease, visibility .18s ease;

  z-index:9999;
}

@media (min-width:1025px){
  .primary-menu > li:not(.mega-menu):hover > ul.sub-menu{
    opacity:1;
    visibility:visible;
    transform:translateY(0);
  }
}

.primary-menu > li:not(.mega-menu) > ul.sub-menu > li{
  border-bottom:solid 1px #80808052;
  padding:5px 0;
}
.primary-menu > li:not(.mega-menu) > ul.sub-menu > li:last-child{
  border-bottom:0;
}

.primary-menu > li:not(.mega-menu) > ul.sub-menu > li > a{
  display:block;
  padding:5px 0;
  color:#222;
  font-weight:700;
  font-size:13px;
  text-decoration:none;
  white-space:nowrap;
}
.primary-menu > li:not(.mega-menu) > ul.sub-menu > li > a:hover{
  color:var(--brand);
}

/* =========================
   MEGA MENU (DESKTOP)
   ========================= */
/* Hide WP sub-menu under mega item ALWAYS (desktop + mobile) */
.primary-menu > li.mega-menu > ul.sub-menu{ display:none !important; }

.primary-menu > li.mega-menu{ position:static !important; }

.primary-menu > li.mega-menu > .mega-dropdown{
  width:100%;
  max-width:100%;
  position:absolute;
  top:100%;
  left:0;

  background:var(--mega-bg);
  border-top:1px solid rgba(0,0,0,.08);
  box-shadow:0 22px 60px rgba(0,0,0,.22);

  z-index:9999;
  opacity:0;
  visibility:hidden;
  transition:opacity .18s ease, transform .18s ease, visibility .18s ease;

  max-height:75vh;
  overflow:auto;
}

@media (min-width:1025px){
  .primary-menu > li.mega-menu:hover > .mega-dropdown{
    opacity:1;
    visibility:visible;
    transform:translateY(0);
  }
}

.mega-inner{
  max-width:var(--container);
  margin:0 auto;
  padding:42px 44px;

  display:flex;
  flex-wrap:wrap;
  flex-direction:row;
  justify-content:space-between;
  row-gap:10px;
}

.mega-column.mega-title{
  width:100% !important;
  border-bottom:2px solid var(--brand);
  margin-bottom:25px !important;
}
.mega-title h4{
  font-size:44px !important;
  font-weight:900;
  color:var(--brand);
  margin:0 0 14px 0;
  line-height:1.05;
}
.mega-lead{ display:none; }

.mega-column h4{
  margin:0 0 10px 0;
  font-size:18px;
  font-weight:900;
  color:var(--brand);
  max-width:150px;
}
.mega-column h4 a{
  color:var(--brand);
  text-decoration:none;
}
.mega-column h4 a:hover{ text-decoration:underline; }

@media (min-width:1025px){
  .primary-menu > li.mega-menu > .mega-dropdown .mega-column:not(.mega-title){
    width:15% !important;
    display:inline-block;
    vertical-align:top;
  }
}

.mega-post-list{
  list-style:none;
  margin:0;
  padding:0;
}
.mega-post-list li{
  margin:0;
  line-height:100% !important;
  border-bottom:solid 1px #80808052;
  padding:5px 0;
}
.mega-post-list a{
  color:var(--text);
  font-weight:500;
  font-size:12px;
  text-decoration:none;
  position:relative;
  transition:color .15s ease;
}
.mega-post-list a:hover{ color:var(--brand); }

.mega-empty{
  font-size:12px;
  font-weight:700;
  color:rgba(31,31,31,.55);
}

/* =========================
   BACKDROP (MOBILE)
   ========================= */
.menu-backdrop{
  position:fixed;
  inset:0;
  background:rgba(0,0,0,.35);
  z-index:9999;
  opacity:0;
  transition:opacity .18s ease;
}
.menu-backdrop.is-open{ opacity:1; }

/* =========================
   MOBILE DRAWER + ACCORDION
   ========================= */
@media (max-width:1024px){

  /* show burger */
  .menu-toggle{
    display:inline-flex;
    align-items:center;
    justify-content:center;
    position:absolute;
    right:0;
    top:0;
    width:52px;
    height:52px;
    background:var(--brand);
    border:0;
    padding:10px;
  }

  /* burger -> X when open */
  body.vv-menu-open .burger{ background:transparent; }
  body.vv-menu-open .burger::before{ top:0; transform:rotate(45deg); }
  body.vv-menu-open .burger::after{ top:0; transform:rotate(-45deg); }

  /* drawer */
  #site-nav.site-nav{
    position:fixed;
    top:0;
    right:0;
    height:100vh;
    width:min(100vw, 460px);
    background:var(--mega-bg);
    box-shadow:-18px 0 50px rgba(0,0,0,.22);
    transform:translateX(105%);
    transition:transform .22s ease;
    z-index:10000;
    padding:35px 67px 24px 18px;
    overflow:auto;
    display:block;
    margin-left:0;
  }
  #site-nav.site-nav.is-open{ transform:translateX(0); }

  /* stack items */
  #site-nav .primary-menu{
    flex-direction:column;
    align-items:stretch;
    gap:14px;
  }

  #site-nav .primary-menu > li > a{
    background:transparent !important;
    border-radius:0 !important;
    padding:14px 6px 20px !important;
    line-height:110% !important;
    color:var(--brand) !important;
    font-weight:900 !important;
    letter-spacing:.3px;
    border-bottom:1px solid rgba(255,87,0,.25);
  }

  /* hide dropdowns by default */
  #site-nav .primary-menu > li > ul.sub-menu,
  #site-nav .primary-menu > li > .mega-dropdown{
    display:none;
  }

  /* show on vv-acc-open */
  #site-nav .primary-menu > li.vv-acc-open > ul.sub-menu,
  #site-nav .primary-menu > li.vv-acc-open > .mega-dropdown{
    display:block !important;
    animation:vvFadeUp .2s ease;
  }

  /* NORMAL submenu in drawer — make links visible */
  #site-nav .primary-menu > li > ul.sub-menu{
    list-style:none !important;
    margin:8px 0 0 0 !important;
    padding:0 6px 0 6px !important;
    background:transparent !important;

    position:static !important;
    max-width:100% !important;
    min-width:0 !important;
    box-shadow:none !important;
    border-top:0 !important;
  }

  #site-nav .primary-menu > li > ul.sub-menu > li{
    border-bottom:1px solid rgba(0,0,0,.08);
    padding:10px 0;
  }
  #site-nav .primary-menu > li > ul.sub-menu > li:last-child{
    border-bottom:0;
  }

  #site-nav .primary-menu > li > ul.sub-menu > li > a{
    display:block !important;
    color:var(--text) !important;
    font-weight:800 !important;
    font-size:16px !important;
    text-decoration:none !important;
    padding:0 !important;
    line-height:1.2 !important;
  }
  #site-nav .primary-menu > li > ul.sub-menu > li > a:hover{
    color:var(--brand) !important;
  }

  /* MEGA in drawer: flatten */
  #site-nav .primary-menu > li.mega-menu > .mega-dropdown{
    position:static !important;
    width:auto !important;
    background:transparent !important;
    box-shadow:none !important;
    border:0 !important;
    max-height:none !important;
    overflow:visible !important;
    transform:none !important;
    opacity:1 !important;
    visibility:visible !important;
    margin-top:10px !important;
  }

  #site-nav .mega-inner{
    padding:8px 6px 0 6px !important;
    background:transparent !important;
    display:block !important;
  }
  #site-nav .mega-title{ display:none !important; }

  #site-nav .mega-column{
    width:auto !important;
    margin:0 0 12px 0 !important;
  }

  #site-nav .mega-column h4,
  #site-nav .mega-column h4 a{
    color:var(--brand) !important;
    font-weight:900 !important;
    font-size:22px !important;
    text-decoration:none !important;
    max-width:100% !important;
  }

  #site-nav .mega-column h4{ margin:30px 0 20px 0; }

  #site-nav .mega-post-list li{
    padding-bottom:10px;
    margin:10px 0 !important;
  }
  #site-nav .mega-post-list a{
    font-size:16px !important;
    color:var(--text) !important;
    font-weight:800 !important;
  }
  #site-nav .mega-empty{
    color:rgba(31,31,31,.65) !important;
    font-weight:700 !important;
  }


  /* 1) ÄRA näita mega itemi WP sub-menu'd (duplikaat) */
  #site-nav .primary-menu > li.mega-menu > ul.sub-menu{
    display:none !important;
  }

  /* 2) Kindlusta, et avatud itemi sub-menu ON nähtav (võidab teema !important) */
  #site-nav.site-nav.is-open .primary-menu > li.vv-acc-open > ul.sub-menu{
    display:block;
    opacity:1 !important;
    visibility:visible !important;
    transform:none !important;

    position:static !important;
    height:auto !important;
    max-height:none !important;
    overflow:visible !important;

    margin:8px 0 0 0 !important;
    padding:0 6px 0 6px !important;
    background:transparent !important;
    box-shadow:none !important;
    border:0 !important;
  }

  /* 3) Väldi parenti poolt “ära lõikamist” */
  #site-nav.site-nav.is-open .primary-menu > li{
    overflow:visible !important;
  }

  /* 4) Sub-menu stiil (et Lastegalerii jms oleks kindlasti nähtav) */
  #site-nav.site-nav.is-open .primary-menu > li > ul.sub-menu{
    list-style:none !important;
  }

  #site-nav.site-nav.is-open .primary-menu > li > ul.sub-menu > li{
    border-bottom:1px solid rgba(0,0,0,.08) !important;
    padding:10px 0 !important;
  }
  #site-nav.site-nav.is-open .primary-menu > li > ul.sub-menu > li:last-child{
    border-bottom:0 !important;
  }

  #site-nav.site-nav.is-open .primary-menu > li > ul.sub-menu > li > a{
    display:block !important;
    color:var(--text) !important;
    font-weight:800 !important;
    font-size:16px !important;
    line-height:1.2 !important;
    text-decoration:none !important;
    padding:0 !important;
  }
	li.mega-menu > ul.sub-menu{
		display:none !important;
	}
}
/* =========================
   ANIMATION
   ========================= */
@keyframes vvFadeUp{
  from{ opacity:0; transform:translateY(8px); }
  to{ opacity:1; transform:translateY(0); }
}
