/*
Theme Name: Hello Elementor Child
Theme URI: https://elementor.com/hello-theme/?utm_source=wp-themes&utm_campaign=theme-uri&utm_medium=wp-dash
Template: hello-elementor
Author: Elementor Team
Author URI: https://elementor.com/?utm_source=wp-themes&utm_campaign=author-uri&utm_medium=wp-dash
Description: Hello Elementor is a lightweight and minimalist WordPress theme that was built specifically to work seamlessly with the Elementor site builder plugin. The theme is free, open-source, and designed for users who want a flexible, easy-to-use, and customizable website. The theme, which is optimized for performance, provides a solid foundation for users to build their own unique designs using the Elementor drag-and-drop site builder. Its simplicity and flexibility make it a great choice for both beginners and experienced Web Creators.
Tags: accessibility-ready,flexible-header,custom-colors,custom-menu,custom-logo,featured-images,rtl-language-support,threaded-comments,translation-ready
Version: 3.3.0.1745327525
Updated: 2025-04-22 13:12:05

*/

.rete-menu {
	margin-right: 8px !important;
}


ul.elementor-nav-menu li.menu-item ul.sub-menu.elementor-nav-menu--dropdown li.menu-item a.elementor-sub-item {
	font-weight: 400;
}
/* ———————————————————————————————— */
/* a) Keyframes per l’underline animata */
/* ———————————————————————————————— */
@keyframes slide-in {
  0% {
    transform: scaleX(0);
    transform-origin: left;
  }
  100% {
    transform: scaleX(1);
    transform-origin: left;
  }
}

@keyframes slide-out {
  0% {
    transform: scaleX(1);
    transform-origin: right;
  }
  100% {
    transform: scaleX(0);
    transform-origin: right;
  }
}

/* ———————————————————————————————— */
/* b) Base per le voci del dropdown (underline animata) */
/* ———————————————————————————————— */
.elementor-nav-menu--dropdown .elementor-item,
.elementor-nav-menu--dropdown .elementor-sub-item {
  position: relative;
  display: inline-block;
  padding: 5px 0;
}

/* underline inizialmente nascosta */
.elementor-nav-menu--dropdown .elementor-item::after,
.elementor-nav-menu--dropdown .elementor-sub-item::after {
  content: "";
  position: absolute;
  bottom: 0;
  left: 0;
  width: 100%;
  height: 1px;
  background-color: #1be9b2;
  transform: scaleX(0);
  transform-origin: right;
}

/* hover → slide-in */
.elementor-nav-menu--dropdown .elementor-item:hover::after,
.elementor-nav-menu--dropdown .elementor-sub-item:hover::after {
  animation: slide-in 0.5s ease forwards;
}

/* mouse-leave → slide-out */
.elementor-nav-menu--dropdown .elementor-item:not(:hover)::after,
.elementor-nav-menu--dropdown .elementor-sub-item:not(:hover)::after {
  animation: slide-out 0.5s ease forwards;
}


.menu-special {
	    display: flex;
}

.img-menu-special {
	    margin-right: 5px;
	display: flex;
    justify-content: center;

}

.img-menu-special > img {
	width: 30px;

}

.special-item-label {
	    display: flex;
    flex-direction: column;
}

.menu-label {
	font-size: 12px;
    font-weight: 400;
	margin-top: -5px;
}


.under-construction {
  height: 100vh;
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  text-align: center;
  padding: 1rem;
  box-sizing: border-box;
}

.under-construction img {
	height: 150px;
}

.under-construction h2 {
  font-size: 120px;
  line-height: 1.2;
  margin: 0;
  color: #3debb1;
  font-family: "Montserrat", sans-serif;
}

@media (max-width: 768px) {
  .under-construction h2 {
    font-size: 2rem;
  }
}


.gsatelite.gt-current-lang img {
	box-shadow: none !important;
}

a.nturl.gsatelite,
a.nturl.gsatelite.gt-current-lang {
	left: -28px !important;
}

.elementor-nav-menu .sub-arrow {
	display: flex !important;
}

@media screen and (min-width:1024px){
.elementor-nav-menu .sub-arrow {
	display: none !important;
	}
}

@media screen and (max-width: 1024px) {
	.elementor-nav-menu--dropdown .elementor-item, 
	.elementor-nav-menu--dropdown .elementor-sub-item {
		display: flex;
		justify-content: space-between;
	}
}

ul.sub-menu li a.elementor-sub-item {
	font-size: 14px !important;
}

/* ─────────── Canvas fissato a sfondo ─────────── */
.canvas-fixed-bg {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  z-index: 0;
  overflow: hidden;
background: radial-gradient(circle, rgba(97, 97, 97, 1) 0%, rgba(26, 26, 26, 1) 5%, rgba(0, 0, 0, 1) 60%);
	   /* background: radial-gradient(circle, rgb(23 23 23 / 1%) 0%, rgb(0 0 0 / 2%) 3%, rgb(0 0 0 / 3%) 6%, rgba(0, 0, 0, 1) 40%);  */
}

.canvas-fixed-bg {
  transition: opacity 0.5s ease-in-out;
  opacity: 1;
}

.canvas-fixed-bg.hide-scroll-elements {
  opacity: 0;
}

.canvas-fixed-bg.hide-scroll-elements {
  height: 0 !important;
  transition: opacity 0.5s ease-in-out, height 0s 0.5s !important;
}

#particles-header {
  width: 100%;
  height: 100%;
}

/* ─────────── Scroll-pin + scala ─────────── */
.scroll-pin-wrapper {
  position: relative;
  height: 150vh;
  z-index: 0;
  pointer-events: none;
	overflow: hidden;
}

.scroll-pin-wrapper .canvas-content-hedaer-home {
  position: fixed;
  top: 50%;
  transform: translateY(-50%) scale(0.2);
  transform-origin: center center;
  transition: transform 0.2s ease-out;
  width: 100%;
  text-align: center;
  pointer-events: none;
  color: #3C3C3B;
	 z-index: 0;
}

/* ─────────── Sfera e styling ─────────── */
#sfera {
  position: relative;
  width: 200px;
  height: 200px;
  margin: 0 auto;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: 50%;
  background-color: #3deaae;
	flex-direction: column;
}
@media screen and (min-width: 1200px) {
  #sfera {
    width: 50vw;
    aspect-ratio: 1 / 1;
    max-height: 100vh;
	height: 100%;  
  }
}

.canvas-content-hedaer-home, #sfera {
  transition: opacity 0.5s ease-in-out;
  will-change: opacity;
}

/* ─────────── Tipografia ─────────── */
.title-header h1 {
  margin: 0;
  font-family: 'Sibylla', sans-serif;
  font-weight: 700;
  font-size: 24px;
  line-height: 1;
  color: #fff;
  letter-spacing: -2px;
}
.title-header h1 span { font-weight: 300; }
.claim-header {
  margin-top: 40px;
  font-family: 'Montserrat', sans-serif;
  font-size: 20px;
  line-height: 1;
  color: #fff;
}

/* transizione di base per titolo e span */
.title-header,
.claim-header {
  opacity: 1;
  transition: opacity 0.5s ease;
}

/* quando #sfera ha questa classe, testo e span diventano trasparenti */
#sfera.fade-text .title-header,
#sfera.fade-text .claim-header {
  opacity: 0;
}


/* ─────────── Responsive Typography ─────────── */
@media (min-width: 768px)  { .title-header h1 { font-size: 24px; } }
@media (min-width: 1024px) { .title-header h1 { font-size: 56px; } }
@media (min-width: 1240px) { .title-header h1 { font-size: 64px; } }
@media (min-width: 1400px) { .title-header h1 { font-size: 72px; } }
@media (min-width: 1600px) { .title-header h1 { font-size: 120px; } }
@media (min-width: 1024px) { .claim-header { font-size: 42px; } }

/* ─── Mobile (<1200px) overrides ───────────────── */
@media (max-width: 1199px) {
  /* sfondo statico */
  .canvas-fixed-bg {
    background: url('/wp-content/uploads/2025/06/bg-mobile-cpu-01-scaled.jpg') center center / cover no-repeat;
  }

	#particles-header {
	  display: none;
	}

  /* annulla scroll-pin e scaling */
  .scroll-pin-wrapper {
        height: 100vh;
        margin-bottom: 0 !important;
        display: flex;
        flex-direction: column;
        justify-content: center;
  }
  .scroll-pin-wrapper .canvas-content-hedaer-home {
    position: fixed !important;
    transform: none !important;
    top: auto !important;
  }

  /* dimensioni responsive della sfera */
  #sfera {
    width: 80vw;
    height: 80vw;
    max-width: 250px;
    max-height: 250px;
    margin: 20px auto;
  }
}

.wrapper-hor {
  position: relative;
  z-index: 2; /* Assicura che sia sopra la sfera (z-index: 0) */
}

.nav-bar {
	-webkit-box-shadow: 0px 5px 10px 0px rgba(0, 0, 0, 0.1);
    box-shadow: 0px 5px 10px 0px rgba(0, 0, 0, 0.1);

}

.elementor-field-group .elementor-field-textual:focus {
    box-shadow: none !important;
    outline: 0;
}

.elementor-field-type-acceptance label {
    font-size: 10px !important;
    line-height: 1.3;
}

.elementor-field-type-acceptance label a {
    color: #9b9b9b;
    text-decoration: underline;
}

.elementor-field-type-acceptance .elementor-field-option {
    display: flex;
	align-items: center;
}

.elementor-field-type-acceptance .elementor-field-option input {
    margin-right: 10px;
	padding: 10px !important;
}

.elementor-field-type-acceptance .elementor-field-option input[type="checkbox"] {
  appearance: none !important;
  -webkit-appearance: none !important;
  -moz-appearance: none !important;
  width: 30px !important;
  height: 30px !important;
  background-color: #ffffff !important;
  border: 2px solid #f1f1f1 !important;
  border-radius: 4px !important;
  cursor: pointer !important;
  position: relative !important;
  transition: all 0.25s ease !important;
  box-shadow: 0 0 0 0 rgba(255, 255, 255, 0.3) !important;
}

.elementor-field-type-acceptance .elementor-field-option input[type="checkbox"]:hover {
  border-color: #f1f1f1 !important;
  box-shadow: 0 0 8px rgba(255, 0, 0, 0.5) !important;
}

.elementor-field-type-acceptance .elementor-field-option input[type="checkbox"]:checked {
  background-color: #fff !important;
  border-color: #f1f1f1 !important;
}

.elementor-field-type-acceptance .elementor-field-option input[type="checkbox"]::after {
    content: "" !important;
    position: absolute !important;
    top: 0;
    left: 4px;
    width: 16px !important;
    height: 16px !important;
    border-style: solid !important;
    border-color: #00ff7f !important;
    border-width: 0 2px 2px 0 !important;
    transform: scale(0) rotate(45deg) !important;
    transition: transform 0.2s ease-in-out !important;
}

.elementor-field-type-acceptance .elementor-field-option input[type="checkbox"]:checked::after {
  transform: scale(1) rotate(45deg) !important;
}

.elementor-field-type-acceptance .elementor-field-option input[type="checkbox"]:focus {
  outline: none !important;
  box-shadow: 0 0 0 4px rgba(0, 255, 127, 0.6) !important;
}

.elementor-field-type-acceptance > label {
	display: none;
}

:root {
  --glow-hue: 222deg;
  --shadow-hue: 180deg;
  --spring-easing: linear(
    0, 0.002, 0.01 0.9%, 0.038 1.8%, 0.156, 0.312 5.8%, 0.789 11.1%, 1.015 14.2%,
    1.096, 1.157, 1.199, 1.224 20.3%, 1.231, 1.231, 1.226, 1.214 24.6%,
    1.176 26.9%, 1.057 32.6%, 1.007 35.5%, 0.984, 0.968, 0.956, 0.949 42%,
    0.946 44.1%, 0.95 46.5%, 0.998 57.2%, 1.007, 1.011 63.3%, 1.012 68.3%,
    0.998 84%, 1
  );
  --spring-duration: 1.33s;
}

@property --shimmer {
  syntax: "<angle>";
  inherits: false;
  initial-value: 33deg;
}

/* Keyframes */
@keyframes shimmer {
  0%   { --shimmer: 0deg;   }
  100% { --shimmer: 360deg; }
}
@keyframes shine {
  0%   { opacity: 0; }
  15%  { opacity: 1; }
  55%  { opacity: 1; }
  100% { opacity: 0; }
}
@keyframes text {
  0%   { background-position: 100% center; }
  100% { background-position: -100% center; }
}


/* Classe unica */
.sib-btn {
  position: relative;
  display: inline-block;
  padding: 0;
  color: var(--bg, #333);
  font-weight: 600;
  text-decoration: none;
  background-image: linear-gradient(
    315deg,
    #ffc4ec -10%,
    #efdbfd 50%,
    #ffedd6 110%
  );
  border-radius: 40px;
  isolation: isolate;
  box-shadow:
    0 2px 3px 1px hsl(var(--glow-hue) 50% 20% / 50%),
    inset 0 -10px 20px -10px hsla(var(--shadow-hue),10%,90%,.95);
  transition: all var(--spring-duration) var(--spring-easing);
  transform: scale(1);
  overflow: hidden;
}

/* Hover/Active states */
.sib-btn:hover:not(:active),
.sib-btn.active {
  transition-duration: calc(var(--spring-duration) * .5);
  transform: scale(1.2);
  box-shadow:
    0 4px 8px -2px hsl(var(--glow-hue) 50% 20% / 50%),
    inset 0 0 0 transparent;
}
.sib-btn:active {
  transition-duration: calc(var(--spring-duration) * .5);
  transform: scale(1.1);
}

.sib-btn a.elementor-button.elementor-button-link.elementor-size-sm {
	width: 100%;
}

.sib-btn .elementor-button {
	display: flex;
	justify-content: center;
		    padding: 24px;

}

/* Text shimmer */
.sib-btn .text {
  position: relative;
  z-index: 2;
  color: #3b3c37;
  background-clip: text;
  background-image: linear-gradient(
    120deg,
    transparent,
    hsla(var(--glow-hue),100%,80%,.66) 40%,
    hsla(var(--glow-hue),100%,90%,.9) 50%,
    transparent 52%
  );
  background-size: 300% 300%;
  background-repeat: no-repeat;
}
.sib-btn:hover .text,
.sib-btn.active .text {
  animation: text .66s ease-in 1 both;
}

/* Shimmer overlay */
.sib-btn .shimmer {
  position: absolute;
  inset: -40px;
  border-radius: inherit;
  mask-image: conic-gradient(
    from var(--shimmer, 0deg),
    transparent 0%, transparent 10%,
    black 36%, black 45%,
    transparent 50%, transparent 60%,
    black 85%, black 95%, transparent 100%
  );
  mask-size: cover;
  mix-blend-mode: plus-lighter;
  animation: shimmer 1s linear infinite both;
  pointer-events: none;
}

/* Glowing rays */
.sib-btn:hover .shimmer::before,
.sib-btn.active .shimmer::before {
  content: "";
  position: absolute;
  inset: 40px;
  border-radius: inherit;
  mix-blend-mode: color;
  box-shadow:
    0 0 3px 2px hsl(var(--glow-hue) 20% 95%),
    0 0 7px 4px hsl(var(--glow-hue) 20% 80%),
    0 0 13px 4px hsl(var(--glow-hue) 50% 70%),
    0 0 25px 5px hsl(var(--glow-hue) 100% 70%);
  opacity: 1;
  animation: shine 1.2s ease-in 1 forwards;
}
.sib-btn:hover .shimmer::after,
.sib-btn.active .shimmer::after {
  content: "";
  position: absolute;
  inset: 40px;
  border-radius: inherit;
  mix-blend-mode: color;
  box-shadow:
    inset 0 0 0 1px hsl(var(--glow-hue) 70% 95%),
    inset 0 0 2px 1px hsl(var(--glow-hue) 100% 80%),
    inset 0 0 5px 2px hsl(var(--glow-hue) 100% 70%);
  opacity: 1;
  animation: shine 1.2s ease-in 1 forwards;
}


#author-archive-menu,
#monthly-archive-menu,
#category-archive-menu {
    font-size: 16px;
    font-weight: 500;
    color: #03EAB0;
}

#author-archive-menu a,
#monthly-archive-menu a,
#category-archive-menu a {
	color: #1a1a1a;
	transition: all .3s;
}

#author-archive-menu a:hover,
#monthly-archive-menu a:hover,
#category-archive-menu a:hover {
	color: #03EAB0;
	transition: all .3s;
}