html {
    font-size: 100%;
    color-scheme: light dark;
    overflow-x: clip;
  }
  
  *,*::before,
  *::after {
    box-sizing: border-box;
  }
  
  /* Remove default margin */
  body,
  h1,
  h2,
  h3,
  h4,
  p,
  figure,
  blockquote,
  dl,
  dd {
    margin: 0;
  }
  
  /* Remove list styles on ul, ol elements with a list role, which suggests default styling will be removed */
  ul[role='list'],
  ol[role='list'] {
    list-style: none;
  }
  
  /* Set core root defaults */
  html:focus-within {
    scroll-behavior: smooth;
  }
  
  /* Set core body defaults */
  body {
    min-height: 100vh;
    text-rendering: optimizeSpeed;
    cursor: pointer;
    scroll-behavior: smooth;
  }
  
  /* A elements that don't have a class get default styles */
  a:not([class]) {
    text-decoration-skip-ink: auto;
  }
  
  /* Make images easier to work with */
  img,
  picture {
    max-width: 100%;
    display: block;
  }
  
  img {
    display: inline-block;
    max-width: 100%;
    vertical-align: middle;
  }
  
  /* Inherit fonts for inputs and buttons */
  input,
  button,
  textarea,
  select {
    font: inherit;
  }
  
  /* Remove all animations, transitions and smooth scroll for people that prefer not to see them */
  @media (prefers-reduced-motion: reduce) {
    html:focus-within {
      scroll-behavior: auto;
    }
  
    *,
    *::before,
    *::after {
      animation-duration: 0.01ms !important;
      animation-iteration-count: 1 !important;
      transition-duration: 0.01ms !important;
      scroll-behavior: auto !important;
    }
  }

    @font-face{
        font-family:stretch;
        src:url("stretch.ttf");
    }
    @font-face{
        font-family:j2;
        src:url("coco.ttf");
    }

:root{
    --h1-font:clamp(1.75rem,2vw + 1rem,3rem);
    --bg-1:white;
    --bg-2:white   ;
    --bg-3:#ecfc56;
    --bg-4:#151515;
    --bg-5:white;
    --bg-p:#787786;
    --bg-slider:black;
    --nav-p:#0e2954;
    --nav-a:white;
    --m-g:5rem;
    --btn-2:black;
    --btn-1:#b4b4b4;
    --nav-bg1:#dbdbdb;
    --nav-bg2:#e4e8ed;
    --r-fncy:white;
    --l-fncy:black;
    --ms-text: clamp(2rem, 1.5vw + .65rem, 2.25rem);
    --h2-text: clamp(2rem, 1.5vw + 0.75rem, 2.5rem);
    --l-text: clamp(1.5rem, 0.75vw + 0.875rem, 1.75rem);
    --p-text:clamp(1.15rem, 0.7vw + 0.5rem, 1.35rem);
    --p1-text:clamp(1.35rem, 1vw + 0.25rem, 1.45rem);
    --h1-text: clamp(2.8rem, 4vw + 1rem, 4rem);
    --m-text: clamp(1.35rem, 0.75vw + 0.75rem, 1.5rem);
  --ml-text: clamp(1.35rem, 2vw + 1rem, 1.75rem);
--brg-heading: clamp(2rem, 2vw + 2rem, 3.5rem);
--xl-text: 10vw;
  
}

body{
    text-rendering: optimizeSpeed;
    line-height:1.6;
    overflow-x: clip;
    min-height:100vh;
    width:100%;
    font-family:j2;
    color:black;
    scrollbar-width:thin;
    scrollbar-color:#760026;
    background:var(--bg-1);
    text-wrap:balance;
}

a{
    text-decoration:none;
    color:black;
}

li{
    list-style:none;
}

h1{
    font-family:stretch;
    transition:all .3s ease-in-out;
}


.warn{
    position:fixed;
    z-index:1100;
    background:black;
    color:red;
    font-size:3vw;
    padding-inline:2rem;
    place-items:center;
    text-align:center;
    height:100vh;
    width:100%;
    overflow:clip;
    display:none;
}
.nav{
    position:fixed;
    height:100vh;
    width:100%;
    overflow:clip;
    z-index:998;
    display:none;
}
.firstNav,.secondNav{
    position: absolute;
    height:100%;
    width:100%;
}
.firstNav{
    background:black;
    height:0vh;
}
.secondNav{
    background:red;
    overflow:clip;
    height:0vh;
    
}
.primaryNav{
    padding-top:20vh;
    display:flex;
    position:relative;
    z-index:11;
    justify-content:space-between;
    margin-bottom:2rem;
    max-width:62rem;
    margin-inline: auto;
    align-items:center;
    
}
.navQuote{
    max-width:22.5rem;
    color:white;
}
.primaryUl{
    display:flex;
    flex-direction: column;
    gap:1rem;
}
.primaryUl a{
    font-size:var(--brg-heading);
    font-family: stretch;
    color:white;
}
.primaryUl a:hover{
    color:black;
}


.movie{
    position: absolute;
    height:100%;
    width:100%;
    inset:0;
    overflow:clip;
    z-index:10;
    opacity:0;
    background-size:cover;
    background-position:center center;
    background-repeat:no-repeat;
    animation: backgroundEffect 30s linear infinite;
}

@keyframes backgroundEffect {
  0% {
    background-position: 0% 0%;
  }
  25% {
    background-position: 40% 10%;
  }
  50% {
    background-position: 0 10%;
  }
  75% {
    background-position: 10% 40%;
  }
  100% {
    background-position: 0% 0%;
  }
}
.movieBtnBlock{
    display:flex;
    gap:1rem;
    position:relative;
    z-index:11;
    max-width:62rem;
    margin-inline: auto;
    align-items:center;
}
.movieBtnBlock p{
    margin-left:1rem;
}
.movieBtn{
    border-radius:.5rem;
    padding:.5rem 2rem;
    text-align:center;
    transition:all .35s ease-in-out;
}
.movieBtn:hover{
   background:black; 
    color:white;
}

.header{
    display:flex;
    justify-content:space-between;
    position:fixed;
    top:0;
    padding:1rem 2rem;
    z-index:999;
    width:100%;
    font-size:var(--p-text);
    font-weight:bold;
}

.menu{
    background: none;
    border:none;
    outline:none;
    color:black;
}
.root,.allContent{
    height:100%;
    width:100%;
    background: var(--bg-2) ;
    overflow:clip;
    position: relative;
}
.scrollDown{
    height:400vh;
    background: var(--bg-2) ;
    overflow:clip;
    position: relative;
    width:100%;
}
.mainSection {
  position: relative;
  min-height: 100vh;
  overflow: hidden;
    display:flex;
    flex-direction:column;
    margin-bottom:30vh;
}

.emptyDiv{
    min-height:50vh;
    width:100%;
}
.mainSection>*{
    flex:1;
}

.introAnim{
    position: relative;
    display:flex;
    overflow:clip;
    min-height:50vh;
    width:100%;
    z-index:105;
    pointer-events:none;
}
.introAnim>*{
    flex:1;
    background:black;
}




.archBlock{
    display:flex;
    overflow:clip;
    
}
.archCase{
    flex:1;
    height:50vh;
    overflow:clip;
    position: relative;
}

.archCase img{
    position: absolute;
    height:100%;
    width:100%;
    object-fit:cover;
}


.layer{
    position: absolute;
    height:100%;
    width:100%;
    background:black
}

    
.lineh{
    position: absolute;
    top:17vh;
    left:10%;
    z-index:106;
    color:white;
    mix-blend-mode: difference;
            font-size:var(--p-text);
    font-family:j2;
    font-weight:bold;
    overflow:clip;
}

.moreA{
    color:black;
    position: absolute;
    top:40vh;
    right:10%;
    z-index:102;
    font-size:var(--p-text);
    font-family:j2;
    font-weight:bold;
    overflow:clip;
    display:flex;
    align-items:center;
    gap:.75rem;
}
.moreA i {
    font-size:.9rem;
    height:2rem;
    width:2rem;
    border-radius:2rem;
    border:1px solid black;
    display:flex;
    align-items:center;
    justify-content:center;
    transition:all .35s ease-in-out;
}
.moreA:hover i{
    background:black;
    color: white;
}
.topC{
    gap:2rem;
    max-width:75rem;
}
.p{
    max-width:30rem;
}
.topContent{
    display:flex;
    flex-direction:column;
    justify-content:space-between;
}
.topContent h1{
    max-width:30rem;
    transform:translateX(-25%);
    
}
.trigger{
    width:100%;
    display:flex;
    min-height:70vh;
    padding-bottom:3rem;
    padding-inline:1rem;
    margin-inline:auto;
    overflow:clip;
}
.topC>*{
    flex:1;
      }
.img{
    height:100%;
    position:relative;
}
.img1{
    background:url(arch27.jpg);
    background-size:cover;
    height:70vh;
    background-position:center center;
}
.gsapImg{
    justify-content:space-evenly;
    align-items:center;
    height:100vh;
}
.over{
    position: absolute;
    height:100%;
    width:100%;
    background: var(--bg-2) ;
}
.img2{
    background:url(arch31.jpg);
    background-size:cover;
    margin-top:4rem;
    width:30vw;
    height:60vh;
    background-position:center center;
}
.img3{
    background:url(arch17.jpg);
    background-size:cover;
    height:40vh;
    width:30vw;
    background-position:center center;
}

.clippy{
    min-height:100vh;
    width:100%;
    display:flex;
    flex-direction: column;
    padding-block:2rem;
}
.clippySection{
    border-radius:1rem;
    margin-bottom:2rem;
    clip-path: polygon(0 30%, 70% 30%, 70% 0, 100% 0, 100% 28%, 100% 67%, 100% 100%, 84% 100%, 65% 100%, 35% 100%, 22% 100%, 0 100%);
}
.clippy h2{
    font-size:var(--l-text);
    transform:translateY(12vh);
    width:55%;
    padding-inline:2rem;
    font-weight:bold;
}
.clippy p{
    min-height:40vh;
    padding-bottom:5rem;
    padding-inline:2rem;
}
.pinSection{
    width:100%;
    height:100%;
}
.pinContainer{
    display:grid;
    grid-template-columns:repeat(2,1fr);
    gap:.5rem;
    width:100%;
}

.pinContent{
    width:100%;
    padding-inline:1rem;
}
.pinContent h1{
    height:100vh;
    display:flex;
    align-items:center;
    justify-content:center;
    font-size:var(--h1-text);
    line-height:1.3;
}

.pinImg{
    height:100vh;
    overflow:clip;
    width:100%;
    position:relative;
    order:-1;
}


.imgDiv{
    position: absolute;
    height:100%;
    width:100%;
}
.imgDiv img{
    position: absolute;
    height:100%;
    width:100%;
    object-fit:cover;
}
.imgDiv1{
    z-index:11;
}
.imgDiv2{
    z-index:12;
}
.imgDiv3{
    z-index:13;
}
.imgDiv4{
    z-index:14;
}
.service-container{
    min-height:40vh;
    width:100%;
    display:grid;
    place-items:center;
    padding-inline: 2rem;
    background:var(--bg-2);
}
.service-content{
    max-width:50rem;
    padding-block:5rem;
}


.service-content p {
    margin-top:1rem;
}


.prlx-section{
    height:100vh;
    overflow:clip; 
    position:relative;
    margin-inline:2rem;
    border-radius:1rem;
}
.prlx-item{
    position: absolute;
    height:150%;
    width:100%;
    object-fit:cover;
}

    .footer{
        width:100%;
        min-height:100vh;
        display:grid;
        position:relative;
        z-index:10;
        margin-top:5rem;
        background:var(--bg-2);
        grid-template-rows:1.25fr 1fr .65fr;
        border-top:2px solid black;
    }
.topFooter{
    padding-inline: 2rem;
}
.topFooter h1{
    font-size:var(--xl-text);
    text-align:center;
    padding-block:2rem;
}
.topFooter p{
    padding-block:1rem;
    border-top:2px solid black;
}

.midFooter{
    display: flex;
    gap:2rem;
    justify-content:center;
    align-items:center;
    padding-inline: 2rem;
}
.footlink{
    flex:1;
    display:flex;
    flex-direction:column;
    gap:2rem;
    text-align:center;
}
.footlink a{
    text-align:center;
    background:var(--bg-3);
    border-radius:1rem;
    padding-block:var(--brg-heading);
    transition:all .35s ease-in-out;
}
.footlink a:hover {
    background:black;
    color:white;
} 
.botFooter{
    display:flex;
    height:100%;
    justify-content:space-between;
    align-items:center;
    background:var(--bg-3);
    border-top-left-radius:1rem;
    border-top-right-radius:1rem;
    padding-inline: 2rem;
}
.goTop{
    background:black;
    color:white;
    height:3rem;
    width:3rem;
    border-radius:3rem;
    display:grid;
    place-items:center;
    font-size:1rem;
    box-shadow: rgba(99, 99, 99, 0.2) 0px 2px 8px 0px;
}

.archContainer{
    position:fixed;
    width:100%;
    height:100%;
    overflow:clip;
    perspective:1500px;
}
.archGallery{
    position: absolute;
    height:100%;
    width:100%;
    top:-5%;
    left:50%;
    transform:translateX(-50%) rotateX(55deg);
    transform-style:preserve-3d;
}
.archItem{
    position: absolute;
    width:45px;
    height:30px;
    margin:0px;
    top:0%;
    left:50%;
    transform:translateX(-50%) ;
    transform-style:preserve-3d;
}
.archItem img{
    width:100%;
    height:100%;
    object-fit:cover;
}

.previewImg{
    position:fixed;
    width:220px;
    height:220px;
    top:50%;
    left:50%;
    transform:translate(-50%,-50%) ;
    z-index:0;
    overflow:clip;
}
.previewImg img{
    width:100%;
    height:100%;
    object-fit:cover;
}
.parallaxSlider{
    height:100vh;
    width:100%;
    margin-top:25vh;
}
.parallaxRace{
    width:fit-content;
    height:50vh;
    display:flex;
    gap:3rem;
    margin-block:auto;
    align-items:center;
    padding-inline:50vh;
}
.parallaxDiv{
    height:50vh;
    width:45vw;
    overflow:clip;
    position:relative;
    background:var(--bg-1);
}
.parallaxDiv img{
    position: absolute;
    width:67.5vw;
    min-width:67.5vw;
    height:100%;
}
.mainGallery{
    height:100%;
    width:100%;
}
.galleries{
    height:120vh;
    overflow:clip;
    position:relative;
    clip-path:polygon(0 0, 100% 0, 100% 100%,0 100%);
}
.galleriesItem{
    height:100%;
    width:100%;
    position:relative;
}
.galleriesItem img{
    width:100%;
    height:100%;
    object-fit:cover;
}

.vignette {
    position: fixed;
    height:30vw;
    width:25vw;
    overflow: clip;
    border-radius:1.5vw;
    top:50%;
    left:50%;
    display: grid;
    place-items:center;
    transform:translate(-50%,-50%);

}
.vignette img{
    object-fit:cover;
    width:100%;
    height:100%;
    position: absolute;
}
.aboutTop{
    height:100vh;
    width:100%;
    position:relative;
    overflow:clip;
    display:grid; 
    z-index:10;
    grid-template-columns:repeat(2,1fr);
}

.aboutTop img,.aboutModal img{
    height:100%;
    width:100%;
    object-fit: cover;
}
.aboutModal{
    position: absolute;
    width:21.5vw;
    height:50vh;
    top:50%;
    left:50%;
    overflow:hidden;
    transform:translate(-50%,-50%);
    display:grid;
    background:rgba(220,212,204,0.3);
    padding:.75rem;
    gap:.3rem;
    backdrop-filter:blur(5rem);
    grid-template-rows:.65fr .35fr;
}
.modalContent{
    display: flex;
    gap:.2rem;
    flex-direction:column;
    justify-content: center;
    align-items:center;
    color:#f8f7ff;
}
.modalContent span,.modalContent p{
    font-size:.75rem;
}
.modalContent p{
    text-transform:lowercase;
    text-align:center;
}
.modalContent h4{
    font-size:1rem;
}
.aboutTopContent{
    order:-1;
    padding:15vh 3rem;
    background:#aba39f;
}
.aboutTopContent p{
    max-width:30rem;
    margin-top:1rem;
}
.vigContent{
    max-width:35rem;
    position: absolute;
    right:15vh;
    top:50%;
    color:white;
    background:rgba(0,0,0,0.15);
    border-radius:1rem;
    padding:2rem;
    transform:translateY(-50%);
}
.vigP{
    font-size:var(--h2-text);
   color:red;
    font-weight:bold;
    position:relative;
    z-index:5;
}
.aboutSticky{
    margin-block:-100vh;
    height:300vh;
    overflow:clip;
    position: relative;
}
.aboutStickyDiv{
    height:100vh;
    width:100%;
    top:0;
    position:sticky;
    background:url(arch100.jpg);
    background-size:100% 100%;
    background-repeat:no-repeat;
    display:grid;
    place-items:center;
    color:white;
}
.aboutStickyDiv h1{
    max-width:35rem;
}

.mask-container{
    height:100vh;
    width:100%;
    position:relative;
    display:flex;
    
}
.mask-content{
    width:100%;
    position: absolute;
    height:100%;
    font-size:var(--h2-text); 
    display:flex;
    align-items:center;
    justify-content:center;
    text-align: center;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
}
.mask-content p{
    max-width:50rem;
}
.mask{
    color:white;
    background:black;
    mask-repeat:no-repeat;
    mask-image:url(mask.svg);
    mask-size:2.5rem;
    opacity:0;
}
.formContainer{
   width:46vw;
    height:46vh;
    padding:1rem;
    position: fixed;
    overflow:clip;
    background: indianred;
    text-align:center;
    top:50%;
    left:50%;
    display:none;
    z-index:200;
    transform:translate(-50%,-50%);
}
.form{
  position: relative;
   width:100%;
    height:100%;
    display:flex;
    overflow:clip;
}
.form>*{
    flex:1;
}
.fline{
    position: absolute;
}
.fline1{
   height:100%;
    left:0;
    width:1.5px;
    background:black;
}
.fline2{
   height:100%;
    right:0;
    width:1.5px;
    background:black;
}
.fline3{
   height:1.5px;
    top:0;
    width:100%;
    background:black;
}
.fline4{
   height:1.5px;
    bottom:0;
    width:100%;
    background:black;
}
.fline5{
    height:100%;
    left:0;
    width:1.5px;
    background:black;
}
.formcont{
    position:relative;
    font-size:.85rem;
    display:flex;
    flex-direction:column;
    align-items:center;
    gap:2rem;
    padding-top:10vh;
    padding-inline:.25rem;
}

.formcont p{
    max-width:15rem;
}
.formLog{
    display:flex;
    flex-direction:column;
    position:relative;
}
.formLog>*{
    flex:1;
}
#email,#name{
background:inherit;
    text-align:center;
    border: none;
    outline:none;
    color:black;
    font-size:1rem;
    border-bottom:1.5px solid black;
}
.formLog div{
    font-size:1.1rem;
    display: grid;
    align-items:center;
}
.formbtn{
    width:4.2rem;
    height:9rem;
    background:indianred;
    color:black;
    position:fixed;
    top:50%;
    z-index:200;
    left:0;
    display:grid;
    place-items:center;
    font-size:1rem;
    transform:translateY(-50%);
    box-shadow: rgba(99, 99, 99, 0.2) 0px 2px 8px 0px;
}
.formbtn p{
    transform:rotate(-90deg);
}
.abtservice-container{
    min-height:100vh;
}
.abtservice-container p{
    font-size:var(--p1-text);
    margin-top:3rem;
}
@media (max-width:1001px){
.warn{
    display:grid;
}
.mainSection{
    display: grid;
}
.archBlock{
    display:grid;
}
.toplayer1,.toplayer2{
    display:none;
}
    .archBlock{
        display:block;
        height:100%;
    }
    
    .prlx-section{
        height:60vh;
        margin-inline:1rem;
    }
    .service-container{
        padding-inline: 1rem;
    }
    
}

