*,
*::before,
*::after {
  box-sizing: border-box;
}

* {
    margin: 0;
    padding: 0;
}

body {
  margin: 0;
  overflow-x: hidden;
}

.page-center {
    max-width: 1280px;
    width: 100%;
    margin: 0 auto;
    padding: 0 20px;
}

.flex {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
}

.justify-between {
    -webkit-box-pack: justify;
    -ms-flex-pack: justify;
    justify-content: space-between;
}

.grid {
    display: -ms-grid;
    display: grid;
}

.items-center {
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
}

/** Background **/
.bg-dark { background-color: var(--bg-dark); }
.bg-primary { background-color: var(--bg-primary) }

/** Divider **/
.divider {
    width: 100%;
    height: 1px;
    background-color: var(--verylight);
    margin: 50px 0;
}
.divider.dark {
  background-color: rgba(52, 52, 52, 0.25);
}

.hidden {
  display: none;
}

.hero-pill {
  border: 1px solid var(--white);
  border-radius: 50px;
  padding: 16px 32px;
  font-family: var(--text);
  display: inline-block;
}

@media screen and (max-width: 768px) {
    .divider {
    margin: 30px 0;
}
}
:root {
    --head: 'Fraunces', serif;
    --text: muli, sans-serif;

    --primary: #FA6000;
    --primary-light: #FEE7D9;
    --secondary: #FEA724;
    --contrast: #000F41;
    --light-contrast: #333F67;

    --white: #FFFFFF;
    --lightgrey: #F4F4F4;
    --verylight: rgba(164, 174, 198, .2);
    --darkgrey: #1C1C1C;
    --mediumgrey: #b5b5b5;
    --black: #000000;
  
    --warning: #dd0000;

    --glass-bg: rgba(255,255,255,.14);
    --glass-bd: rgba(255,255,255,.35);
    --glass-glow: rgba(255,255,255,.45);
    --glass-shadow: 0 10px 30px rgba(0,0,0,.25);
  
  /** Portfolio **/
  --pf-base-bg: #E0EAEC;
  
  /* Border Radius */
  --br-xl: 80px;
  --br-lrg: 40px;
  --br-med: 24px;
  --br-sml: 8px;
  
    /* Padding */
  --p-xl: 80px;
  --p-lrg: 40px;
  --p-med: 32px;
  --p-sml: 24px;

  --p-page-full: 96px; 
  --p-page-half: 48px; 
  --p-page-0: 0px; 

  }
}
/* 
textarea,
input[type="text"],
input[type="password"],
input[type="datetime"],
input[type="datetime-local"],
input[type="date"],
input[type="month"],
input[type="time"],
input[type="week"],
input[type="number"],
input[type="email"],
input[type="url"],
input[type="tel"],
input[type="color"],
select,
.hs-input,
.hs-form-field {
    -webkit-appearance: none;
    -moz-appearance: none;
    box-sizing: border-box;
    height: 50px;
    width: 100%!important;
    border: 1px solid var(--lightgrey);
    background: var(--verylight);
    padding: 10px 15px;
    margin-bottom: 10px;
    font-size: 16px;
    font-family: var(--text);
    color: var(--darkgrey);
}

ul.hs-error-msgs {
  list-style-type: none;
  margin: 0;
}

ul.hs-error-msgs li {
  padding-bottom: 15px;
  font-size: 14px;
  line-height: 20px;
}

ul.hs-error-msgs li label {
  font-family: var(--text);
  color: var(--warning);
}

.submitted-message {
  color: var(--primary);
}

input:focus,
textarea:focus {
    background: var(--lightgrey);
    border: 1px solid var(--contrast);
}

textarea,
footer textarea {
    height: auto;
}

*::-webkit-input-placeholder {
  font-size: 14px;
}

*:-moz-placeholder {
  font-size: 14px;
}

*::-moz-placeholder {
  font-size: 14px;
}

*:-ms-input-placeholder {
  font-size: 14px;
}

*::-ms-input-placeholder {
  font-size: 14px;
}

*::placeholder {
  font-size: 14px;
}

input[type=reset],
input[type=submit] {
    -webkit-appearance: button;
    cursor: pointer;
    background: var(--contrast);
    color: #fff;
    border-radius: 8px;
    border: none;
    font-family: var(--text);
    font-size: 16px;
    height: 50px;
    font-weight: 600;
    padding: 10px 20px;
    transition: all .2s;
}

input[type=reset]:hover,
input[type=submit]:hover {
  background: var(--primary);
}
 */
@import url('https://fonts.googleapis.com/css2?family=Fraunces:ital,opsz,wght@0,9..144,300;0,9..144,400;0,9..144,500;0,9..144,700;1,9..144,300;1,9..144,400;1,9..144,500;1,9..144,700&display=swap');
@import url("https://use.typekit.net/otg4pjc.css");

h1,
h2,
h3,
h4 {
    font-family: var(--head);
    font-style: normal;
    display: inline-block;
}

h1 {
    font-size: 3.8em;
    font-weight: bold;
    color: var(--white);
    margin: 25px 0 40px 0;
    opacity: 1;
}

h2 {
    font-size: 50px;
    font-weight: 600;
    color: var(--darkgrey);
    line-height: 58px;
    font-style: normal;
    margin-bottom: 20px;
}

h2 span {
    display: block;
    font-family: var(--text);
    font-size: 20px;
    line-height: 28px;
    letter-spacing: 0.8px;
    font-weight: 400;
    color: var(--primary);
    text-transform: uppercase;
    margin-bottom: 25px;
}

.portfolio h2 span {
    display: inline-block;
    font-family: var(--head);
    font-size: inherit;
    line-height: inherit;
    letter-spacing: inherit;
    font-weight: inherit;
    color: var(--primary);
    text-transform: none;
    margin-bottom: 0;
}

h2.x-large {
    font-size: 100px;
    line-height: 100px;
}

h2.smaller {
      font-size: 38px;
    line-height: 48px;
}

h3 {
    font-size: 40px;
    line-height: 50px;
}

h4 {
    font-size: 32px;
    line-height: 38px;
}

h5 {
    font-family: var(--text);
    font-weight: 500;
    text-transform: uppercase;
    letter-spacing: 3px;
    font-size: 26px;
    line-height: 33px;
    font-style: normal;
    margin-bottom: 20px;
}

h6 {
    font-family: var(--head);
    color: rgba(255, 255, 255, 0.65);
    text-transform: uppercase;
    font-size: 20px;
    font-weight: 400;
    letter-spacing: 0.8px;
    line-height: 25px;
    margin-bottom: 15px;
}

p, ul li {
    font-family: var(--text);
    font-weight: 300;
    font-style: normal;
    font-size: 22px;
    line-height: 36px;
    color: #343434;
    padding-bottom: 15px;
}

p:last-of-type {
  padding-bottom: 0;
}

p.medium {
    font-size: 20px;
  line-height: 32px;
}

p.small {
    font-size: 16px;
    line-height: 22px;
}

.highlight {
color: var(--primary);
}

.italic {
    font-style: italic;
}

.sub {
    font-family: var(--text);
    font-size: 1.125rem;
    font-weight: normal;
    text-transform: uppercase;
    letter-spacing: 4px;
    line-height: 40px;
    margin-bottom: 15px;
    display: inline-block;
}

.primary-text {
  color: var(--primary);
}

.list-unstyled {
   padding-left: 0;
   list-style: none;
}

.link-white, .text-white {
    color: var(--white);
}

.link-hover, .footer .hs-menu-item a {
    border-bottom: 1px solid rgba(0, 0, 0, 0);
    transition: border-color .2s, color .2s, transform .2s;
}

.link-hover.link-white:hover, .footer .hs-menu-item a:hover {
    color: #fff;
    border-bottom-color: #fff;
    transform:scale(1.01);
}

@media only screen and (max-width: 768px) {
  h1 {
    font-size: 2.2em;
    margin-bottom: 25px;
  }
  
  h2 {
    font-size: 38px;
    line-height: 42px;
  }
  
  h2.x-large {
    font-size: 60px;
    line-height: 60px;
}
  
  h3 {
    font-size: 30px;
    line-height: 40px;
  }

  h5 {
    font-size: 1.2em;
    margin-bottom: 25px;
  }

  p, ul li  {
    font-size: 16px;
    line-height: 24px;
  }

  .sub {
      font-size: 0.9rem;
      letter-spacing: 2.5px;
      line-height: 35px;
      padding-bottom: 30px;
  }

}
/* @import url('http://example.com/example_style.css'); */

/***********************************************/
/* CSS @imports must be at the top of the file */
/* Add them above this section                 */
/***********************************************/

/* ========================================
   Base Glass Button
======================================== */ 
.btn-glass {
   display: inline-block;
  padding: 18px 32px;
  border-radius: 50px;
  font-family: var(--text);
  font-size: 1rem;
  font-weight: 600;
  letter-spacing: 0.5px;
  border: none;
  margin: 40px 0 0 0;
  text-decoration: none;
  cursor: pointer;
  -webkit-appearance: none;
  -moz-appearance: none;
  border: 1px solid rgba(255, 255, 255, 0.2);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
  text-decoration: none;
  cursor: pointer;
  transition: background 0.3s ease, transform 0.3s ease;
}


/* ========================================
   Light Version
======================================== */

.btn-glass.light {
  background: rgba(255, 255, 255, 0.1);
  color: var(--white);
}

.btn-glass.light:hover {
  background: rgba(255, 255, 255, 0.2);
  transform: translateY(-2px);
}


/* ========================================
   Dark Version
======================================== */

.btn-glass.dark {
  background: rgba(250, 96, 0, 0.9);
  color: var(--white);
}

.btn-glass.dark:hover {
  background: rgba(250, 96, 0, 1);
  transform: translateY(-2px);
}


/* ========================================
   Press Effect
======================================== */

.btn-glass:active {
  transform: scale(0.98);
}


/* ========================================
   Icon Animation (Smooth + Controlled)
======================================== */

.btn-glass i {
  transition: transform 0.3s ease;
}

.btn-glass:hover i {
  transform: translateX(6px);
}


/* ========================================
   Mobile Adjustment
======================================== */

@media (max-width: 768px) {
  .btn-glass {
    padding: 16px 24px;
  }
}

.btn-portfolio {
  border: 1px solid var(--darkgrey);
  border-radius: var(--br-lrg);
  color: var(--darkgrey);
  margin-bottom: 0;
  padding: 20px 40px;
  text-transform: none;
  position: relative;
  display: inline-block;
  text-align: center;
  text-decoration: none;
  line-height: 1.2;
  cursor: pointer;
  transition: all 0.3s ease;
  font-family: var(--text);
  font-size: 1.125rem;
  font-weight: normal;
  letter-spacing: 4px;
}