/*
Theme Name: 	Marco Pio Mucci
Description: 	Responsive WordPress Theme based on Boostrap and Font Awesome.
Version:     	1.0.0
Author:     	Ivan Franzese
Author URI:   http://www.ivanfranzese.com
Site:         http://www.ivanfranzese.com
Text Domain: 	marcopiomucci
Domain Path: 	/languages
Tags:        	grid-layout, blog, custom-menu, featured-images, right-sidebar
License:    	GNU General Public License v3.0
License URI:	http://www.gnu.org/licenses/gpl-3.0.html
*/

body, html{ font-family: "Nunito Sans", sans-serif; background: #fff;font-size: 16px;color: #000;line-height: 24px;}


/*--------------------------
General
--------------------------*/
*{box-sizing: border-box; letter-spacing: 1px;}
hr{border:none; border-bottom: 1px solid #ddd;}

/* form  */
input{border: 1px solid;}
input[type="submit"] { color: #fff; border: none; background-color: #000; font-weight: 600; width: auto; padding: 10px 40px; }
input, textarea, select, button {
  margin: 0;
  -webkit-box-sizing: border-box;
  -moz-box-sizing: border-box;
  box-sizing: border-box;
  padding: 10px;
  margin: 5px 0;
  display: block;
  width: 100%;
}
textarea{height: 120px;border: 1px solid;}
.wpcf7-spinner{position: absolute;}

.wpcf7-list-item{display: flex;flex-wrap: wrap;margin: 0;}
.wpcf7-list-item input[type="checkbox"] { width: auto; margin: 0; float: left; margin-right: 5px; }

span.wpcf7-form-control.wpcf7-acceptance label{margin: 10px 0; font-size: 12px;line-height: 12px;}

pre{overflow: hidden}

/* Video Resposnive */
figure{margin:0;}
.video-container { position: relative; padding-bottom: 56.25%; padding-top: 25px; height: 0;}
.video-container  iframe { position: absolute; top: 0; left: 0; width: 100%; height: 100%;}


/*--------------------------
Layout
--------------------------*/

h1, h2{font-weight: 600; font-size: 32px;}

a{color: #000;}
a:hover{text-decoration: underline;}

.p-0{padding: 0px;}
.p-10{padding: 10px;}
.p-20{padding: 20px;}
.p-30{padding: 30px;}
.p-40{padding: 40px;}
.p-50{padding: 50px;}
.p-60{padding: 60px;}

.p-0-10{padding:0 10px;}
.p-0-20{padding:0 20px;}
.p-0-30{padding:0 30px;}
.p-0-40{padding:0 40px;}
.p-0-50{padding:0 50px;}
.p-0-60{padding:0 60px;}

.p-10-0{padding:10px 0;}
.p-20-0{padding:20px 0;}
.p-30-0{padding:30px 0;}
.p-40-0{padding:40px 0;}
.p-50-0{padding:50px 0;}
.p-60-0{padding:60px 0;}

.pb-0{padding-bottom: 0;}

.m-0{margin: 0px;}
.m-10{margin: 10px;}
.m-20{margin: 20px;}
.m-30{margin: 30px;}
.m-40{margin: 40px;}
.m-50{margin: 50px;}
.m-60{margin: 60px;}

.m-0-10{margin:0 10mx;}
.m-0-20{margin:0 20px;}
.m-0-30{margin:0 30px;}
.m-0-40{margin:0 40px;}
.m-0-50{margin:0 50px;}
.m-0-60{margin:0 60px;}

.m-10-0{margin:10px 0;}
.m-20-0{margin:20px 0;}
.m-30-0{margin:30px 0;}
.m-40-0{margin:40px 0;}
.m-50-0{margin:50px 0;}
.m-60-0{margin:60px 0;}

.mt-85{margin-top: 85px!important;}

.gap-0{gap: 0!important;}

.width-wrap{width:100%; max-width: 1440px; margin:0 auto;}

.tt-u{text-transform: uppercase;}
.ta-c{text-align: center;}
.ta-l{text-align: left;}
.ta-r{text-align: right;}

.d-f{display: flex;flex-wrap: wrap;}
.fd-c{flex-direction: column;}
.jc-c{justify-content: center;}
.jc-sb{justify-content: space-between;}

.ac-fs{align-content: flex-start;}
.ac-fe{align-items: flex-end;}
.ac-c{align-content: center;}
.ac-sb{align-content: space-between;}

.ai-fs{align-items: flex-start;}
.ai-fe{align-items: flex-end;}
.ai-c{align-items: center;}
.ai-sb{align-items: space-between;}

.h-100{height: 100%;}
.w-100{width: 100%;}

.fw-8{font-weight: 800;}

#page-overlay { position: fixed; top: 0; left: 0; width: 100vw; height: 100dvh; background-color: #fff; /* Colore di sfondo */ z-index: 9999; opacity: 1; transition: opacity 0.8s ease; pointer-events: all; }
#page-overlay.hidden { opacity: 0; pointer-events: none; }

/*Cursor*/

.cursor { position: fixed; top: -2.5px; left: -2.5px; width: 5px; height: 5px; border-radius: 50%; pointer-events: none; z-index: 999;}
.cursor__circle::after{  content: '';position: absolute;left: 0;top: 0;right: 0;bottom: 0;width: 100%;height: 100%;background-image: url('https://www.marcopiomucci.com/wp-content/uploads/2025/03/ufo-1-1.png');background-repeat: no-repeat;background-size: contain;}

@media (hover: hover) and (pointer: fine) {
.cursor__circle { --size: 30px; position: fixed; top: calc(var(--size) / -2); left: calc(var(--size) / -2); width: var(--size); height: var(--size); border-radius: 50%; pointer-events: none; z-index: 999; transition: opacity 0.6s cubic-bezier(0.25, 1, 0.5, 1), background-color 0.6s cubic-bezier(0.25, 1, 0.5, 1), border-color 0.6s cubic-bezier(0.25, 1, 0.5, 1), width 0.6s cubic-bezier(0.25, 1, 0.5, 1), height 0.6s cubic-bezier(0.25, 1, 0.5, 1), transform 0.6s cubic-bezier(0.25, 1, 0.5, 1); }
}


/*--------------------------
Header
--------------------------*/

.header { display: flex ; flex-wrap: wrap; justify-content: space-between; align-items: center; align-content: center; width: 100%; background: #fff;position: fixed;top: 0;z-index: 9;left: 0;right: 0;}
.header .width-wrap{padding: 30px 40px;}
.header__logo{color:#fff; text-decoration: none;}
.header__menu{padding:0;margin:0;list-style-type: none;}
.header__menu .menu-item{display: inline-block;}
.header__menu .menu-item a { padding: 5px 10px; text-decoration: none; font-size: 15px;}
.header__menu .menu-item:last-child a{padding-right: 0;}
.header__menu .menu-item.current-menu-item a { font-weight: 800; }

.header__icon-bar{display: none;}
.header__icon-bar span{display: block;background-color: #fff; height: 2px; width: 23px;margin-bottom:5px}


nav{display: flex;align-items: center;align-content: center;}
.social-links-mobile{display: none;}

#logo a{text-decoration: none;font-size: 18px;}




/*--------------------------
Home
--------------------------*/
.gallery-wrap { display: flex ; flex-wrap: wrap; justify-content: center; padding: 0; align-items: flex-start; }
.filters { width: 20%; position: sticky; top: 110px; }
.filters h4{margin-top: 0; margin-bottom: 0; font-weight: 800;}
a.filter-link{text-decoration: none;margin-bottom: 5px; font-weight: 300;font-size: 14px;}
a.filter-link.active { font-weight: 600; }
a.filter-year-link{text-decoration: none;margin-bottom: 5px; font-weight: 300;font-size: 14px;}
a.filter-year-link.active { font-weight: 800; }
.filter-category{display: flex;flex-wrap: wrap;margin-bottom: 20px;}
.filter-year{display: flex;flex-wrap: wrap;margin-bottom: 20px;}

.filtri-wrap { width: 100%; display: flex ; flex-direction: column; align-items: flex-start; padding-left: 10px; padding-top: 5px;}

.gallery-container { gap: 10px; width: 80%;position: relative;}

.swiper-wrapper-container { width: 80%; max-width: 700px; margin: 0 auto; position: relative;}
.swiper-container{width: 100%; overflow: hidden; position: relative;}

.swiper-wrapper{ align-items:center;}

.swiper-prev, .swiper-next { position: absolute; top: 50%; width: 40px; top: calc(50% - 42px); cursor: pointer;}
.swiper-next { right: -80px; transform: scaleX(-100%) translateY(-50%); }
.swiper-prev { left: -80px; transform: translateY(-50%);}
.swiper-prev img, .swiper-next img {height: auto!important;width: auto!important;}

.gallery-container a { width: calc(50% - 5px); overflow: hidden;}
.gallery-container img {width: auto;height: auto;display: block;margin: 0 auto;max-height: calc(100dvh - 250px);max-width: 100%;}


.titolo { font-size: 14px; padding: 30px 0; text-align:center;}
.titolo h3 { display: inline; font-weight: 400; font-size: 14px; }
.titolo p { display: inline; margin-left: 10px; font-size: 14px;}

.scroll-top { text-decoration: none; width: auto; text-align: center; flex-direction: column; margin: 0 auto; padding: 20px; font-weight: 400; font-size: 16px; display: none;cursor: pointer;}
.scroll-top:hover{text-decoration: none;}
.scroll-top span { font-family: "Bebas Neue", sans-serif; margin-bottom: 10px; font-size: 21px;}


/*--------------------------
Exhibitions
--------------------------*/
aside.exhibitions-filters{width:20%;}
aside.exhibitions-filters h4 { margin: 0; }
ul.macro-menu { list-style-type: none; padding: 0; margin: 0; padding-left: 10px; padding-top: 5px;}
ul.macro-menu .macro-item a { text-decoration: none; margin-bottom: 5px; font-weight: 300; font-size: 14px; }
ul.macro-menu .macro-item a.active{font-weight: 800;}

ul.year-menu { padding: 0; list-style-type: none; padding-left: 10px; padding-top: 5px;}

/*--------------------------
Bio
--------------------------*/
.page-wrap{display: flex;flex-wrap: wrap;align-items: flex-start;align-content: flex-start;}
.left-page{width: 50%;position: sticky;top: 125px;padding: 0 40px 0 0;}
.right-page{width: 50%;}
.right-page-wrap.overflow-scroll{height: auto; padding-bottom: 40px;}
.right-page-wrap h4{margin-bottom: 0;}
.right-page-wrap p{margin: 0;}

.bio-title { position: sticky; bottom: 0; background: #fff; border-top: 1px solid #ccc; padding-top: 40px; padding-bottom: 40px; }

/*--------------------------
Contact
--------------------------*/
.page-wrap.contact-wrap{align-items: flex-start;align-content: flex-start;}
.right-page.right-contact{text-align: center;}

.right-page.right-contact p { display: flex ; flex-wrap: wrap; align-items: center; align-content: center; justify-content: flex-start; font-size: 16px; }
.right-page.right-contact i{font-size: 21px;margin: 0 5px;}
.right-page.right-contact a{text-decoration: none;}

.contact-info { padding: 0 60px; text-align: left;}
.contact-info h3 {  font-size: 32px; font-weight: 600; margin: 20px 0; letter-spacing: 8px;}


/*--------------------------
Index, Single, Page
--------------------------*/


.content__title{letter-spacing: 4px;margin: 20px 0;}

	/* Comments */
	.comments{margin: 40px 0; border-top: 1px solid #eee}
	.commentlist,
	.commentlist .children{list-style-type: none}

	.comment-body{margin: 40px 0}
	.comment-author.vcard img{border-radius: 100%;}

	.comment-form-comment textarea{background: #eee; width:100%;border: 1px solid #ddd;margin-top:5px;}
	.comment-form-author input,
	.comment-form-email input,
	.comment-form-url input{background: #eee; width:200px; max-width:300px;border: 1px solid #ddd;padding:5px}

	.comment-form-author label,
	.comment-form-email label,
	.comment-form-url label{ width:100px;display: inline-block;}

	.form-submit input{background: #333; color:#fff; border:none;font-size: 16px;padding: 10px 15px;width: auto;}

  /* Pagination */
  .pagination{padding:40px;}
  .pagination a,
  .pagination span{padding: 10px 15px; border: 1px solid #ddd; text-decoration: none;}
  .pagination a:hover{background: #eee}

  /* Caption Images */
  .wp-caption { margin-bottom: 20px; padding: 10px; max-width: 97%; border: 1px solid #ddd; text-align: center; }
  .wp-caption img { margin: 0; padding: 0; width: 100%!important; height: auto; border: 0 none; }
  .wp-caption p.wp-caption-text { margin: 0; padding: 8px; font-size: 1em; line-height: 17px; }

  /* Gallery */
  .gallery { padding: 40px 0 40px 0; width: 100%; }
  .gallery-item { width: 33.333333%; text-align: center; }
  .gallery img { margin: 0 5% 0 5%; width: 90%; height: auto; border: none!important; }
  .gallery-caption { width: 90%;margin:10px 0 0 0;}


/*--------------------------
Footer
--------------------------*/
footer { padding: 30px 0; width: 100%; text-align: center; }
footer .width-wrap{padding:0 40px}
footer .width-wrap>p{text-align: center;margin: 0;}
footer .social-links a { text-decoration: none; font-size: 21px; margin: 0 5px; }


/*--------------------------
Tablet
--------------------------*/

@media (max-width: 998px) {
	
	body,html{overflow-x:hidden;}

  .bio-title { position: fixed; left: 0; right: 0; padding: 20px; }
	.page-wrap{padding-bottom:80px;}
.overflow-hidden { overflow: hidden; }

.p-10-mob{padding: 10px;}

  /*header & menu */
  .header .width-wrap { padding: 30px 10px; }
  .header__menu{width:100%;
  }
  nav { width: 100%; -webkit-transition: all 0.5s ease-out; transition: all 0.5s ease-out; position: fixed;left: 0;right: 0; top: 85px; background: #000; transform: translateX(100%); height: calc(var(--dvh, 1dvh) * 100 - 85px); overflow-y: hidden; overflow-x: hidden; z-index: 9; }
   
  .social-links-mobile { position: absolute; bottom: 30px; left: 0; right: 0; display: flex ; z-index: 9; flex-wrap: wrap; justify-content: center; gap: 15px; } 
  .social-links-mobile a { color: #fff; text-decoration: none; font-size: 21px; margin: 0; }

  .header__menu { align-items: flex-start; align-content: flex-start; justify-content: flex-start; height: 100%; display: flex ; flex-wrap: wrap; align-items: center; align-content: center; padding-bottom: 41px;}

  .header__menu .menu-item{padding:10px;width:100%;text-align: center;}
  .header__menu .menu-item a{display: inline-block;padding:0;font-size: 16px; padding: 0;color: #fff;}
  .show-menu{transform: translateX(0);}


  .hamburger {top:50%;left:0;right: 0;width: 20px;height: 2px;background: #000;position: absolute;transition: 0.8s;margin: 0 auto;}
  .hamburger:before {top: -6px;}
  .hamburger:after {top: 6px;}

  /* Icon 1 */
  .icon-one {position: relative;width: 20px;height: 20px;cursor: pointer;}
  .hamburger-one:before,.hamburger-one:after {content: '';position:absolute;left:0;right: 0;width: 20px;height: 2px;background: #000;transition:1s;}
  .icon-one.active-one .hamburger-one {background:rgba(0,0,0,0);transform: scale(1.1) rotate(-180deg);}
  .icon-one.active-one .hamburger-one:before {top: 0;transform:rotate(45deg);}
  .icon-one.active-one .hamburger-one:after {top: 0;transform:rotate(135deg);}


  .swiper-wrapper-container { width: calc(100% - 80px);}
  .swiper-next { right: -40px; }
  .swiper-prev { left: -40px; }
  .swiper-prev, .swiper-next{width: 30px;}


  .gallery-container{width: 100%;}
  .gallery-wrap{padding: 0;}


  .filters { position: relative; top: 0; width: calc(100% - 80px); }
  .filter-year { width: 100%; margin: 0 auto; text-align: center; justify-content: center; }
  aside.exhibitions-filters { width: calc(100% - 80px); text-align: center; }
  ul.macro-menu, .filtri-wrap { padding: 10px 0; text-align: center; align-items: center; flex-direction: row; align-content: center; gap: 10px; justify-content: center; }
  li.macro-item { text-align: center; }

  .titolo{padding: 10px 0;}
  .titolo p { display: inline-block; width: 100%; margin: 0; }

  h1.content__title { margin: 0; padding: 20px 0; text-align: left; font-size: 26px; letter-spacing: 4px;}
  .left-page, .right-page { width: 100%; position: relative; top: 0; padding: 0; }
  .left-page p{margin-top: 0;}
  .right-page img{padding: 10px 0 0;}


  .right-page-wrap.overflow-scroll { height: auto; overflow-y: hidden; }
  .right-page-wrap.overflow-scroll .wp-block-columns, .page-id-23 .wp-block-columns { flex-wrap: wrap !important; margin-bottom: 10px; margin-top: 10px; }
  .right-page-wrap.overflow-scroll .wp-block-column, .page-id-23 .wp-block-column { flex-basis:100%!important;}


  .contact-info{padding: 0;}
  .contact-info h3{font-size: 26px;letter-spacing: 4px;}
  .contact-info h3:last-of-type{margin-top: 30px!important;}
  .page-wrap.contact-wrap .left-page{order: 1;}
  .page-wrap.contact-wrap .content__title{margin-top: 10px; padding-bottom: 15px;letter-spacing: 4px;}

  footer{padding: 10px;}
  footer .width-wrap{padding: 0 10px;justify-content: center;}

}


/*--------------------------
Smartphone
--------------------------*/

@media (max-width: 767px) {

	/* content layout */
	.content,
	.sidebar{width:100%;}

  /* Gallery */
  .gallery-caption{ font-size: 12px;}

}



@media (max-width: 480px) {
  .gallery-container a{width: 100%;}
  .social-links { width: 100%; padding: 10px 0 0; }
  .contact-info .social-links { padding: 0; }
}