/* Pin & Claw v1 stylesheet
   Source of truth for live pages: home, shotbook, privacy, terms */

/* 01. Vendor Imports */
@import url('../webfonts/font-family-anton.css');
@import url('https://fonts.googleapis.com/css2?family=Montserrat:ital,wght@0,100..900;1,100..900&display=swap');
@import url('../css/vendor/bootstrap.min.css');
@import url('../css/vendor/fontawesome.css');
@import url('../css/vendor/solid.css');
@import url('../css/vendor/regular.css');
@import url('../css/vendor/brands.css');
@import url('../css/vendor/swiper-bundle.min.css');

/* 02. Design Tokens */
:root {
  --primary: #ffffff;
  --secondary: #121212;
  --text-color: #d0d0d0;
  --accent-color: #3563c5;
  --accent-color-2: #244a9f;
  --accent-color-3: #2a2a2a;
  --accent-color-4: #02010100;
  --accent-color-5: #1a1a1a;
  --accent-color-6: #d5d8dc;
  --accent-sidebar-overlay: #33333380;
  --font-family-1: "Anton", sans-serif;
  --font-family-2: "Montserrat", sans-serif;
}

/* 03. Base Typography + Reset */
* {
  margin: 0;
  padding: 0;
  box-sizing: border-box;
}

body {
  font-family: var(--font-family-2);
  font-size: 16px;
  font-weight: 400;
  font-optical-sizing: auto;
  color: var(--primary);
  background-color: var(--secondary);
}

.montserrat-light {
  font-family: var(--font-family-2);
  font-optical-sizing: auto;
  font-weight: 300;
  font-style: normal;
}

.montserrat-regular {
  font-family: var(--font-family-2);
  font-optical-sizing: auto;
  font-weight: 400;
  font-style: normal;
}

h1 {
  font-size: 115px;
  font-weight: 400;
  text-transform: uppercase;
  line-height: 1.1em;
}

h2 {
  font-size: 80px;
  font-weight: 400;
  text-transform: uppercase;
  line-height: 1em;
}

h3 {
  font-size: 48px;
  font-weight: 500;
  text-transform: uppercase;
  line-height: 1em;
}

h4 {
  font-size: 32px;
  font-weight: 500;
  text-transform: uppercase;
  line-height: 1.2em;
}

h5 {
  font-size: 21px;
  font-weight: 500;
  text-transform: uppercase;
  line-height: 1.2em;
}

h6 {
  font-size: 18px;
  font-weight: 400;
  text-transform: uppercase;
  line-height: 1;
}

h1,
h2,
h3,
h4,
h5,
h6 {
  font-family: var(--font-family-1);
  margin-bottom: 0;
}

p {
  font-family: var(--font-family-2);
  font-size: 18px;
  font-weight: 400;
  line-height: 1.6em;
  color: var(--text-color);
}

button,
a {
  font-family: var(--font-family-1);
  font-size: 16px;
  font-weight: 500;
  text-transform: uppercase;
  line-height: 1em;
  letter-spacing: 1px;
  text-decoration: none;
}

ul {
  list-style: none;
}

/* 04. Layout Primitives */
.section {
  padding: 120px 20px 120px 20px;
}

.section-banner-home {
  padding: 0;
  position: relative;
  overflow: hidden;
}

.section-footer {
  padding: 120px 20px 20px 20px;
  background-color: var(--accent-color);
  color: var(--primary);
}

.hero-container {
  max-width: 1280px;
  margin-left: auto;
  margin-right: auto;
  width: 100%;
}

/* 05. Buttons */
.btn {
  display: inline-flex;
  flex-direction: row;
  align-items: center;
  font-family: var(--font-family-1);
  font-size: 16px;
  font-weight: 500;
  text-transform: uppercase;
  line-height: 1em;
  letter-spacing: 1px;
  text-decoration: none;
  text-align: center;
  border-radius: 0;
  padding: 17px 34px 17px 34px;
  transition: all 300ms;
}

.btn-accent {
  background-color: var(--accent-color);
  color: var(--primary);
}

.btn-accent:hover {
  background-color: var(--accent-color-2);
}

.btn-accent-primary {
  background-color: var(--primary);
  color: var(--accent-color);
}

.btn-accent-primary:hover {
  background-color: var(--accent-color-2);
  color: var(--primary);
}

/* 06. Header + Nav */
.navbar-container {
  padding: 20px 20px 0 20px;
  position: absolute;
  top: 0;
  left: 50%;
  width: 100%;
  transform: translateX(-50%);
  z-index: 10;
}

.navbar {
  background-color: transparent;
  border-radius: 20px;
  position: relative;
  padding: 0;
  z-index: 1;
}

.navbar-nav-container {
  display: flex;
  flex-direction: row;
  align-items: center;
  justify-content: space-between;
  width: 100%;
  padding: 20px;
}

.navbar-nav {
  flex-wrap: wrap;
  justify-content: center;
}

.navbar .logo-container {
  width: 18%;
  display: flex;
  flex-direction: column;
  justify-content: center;
}

.navbar .nav-link-container {
  width: 64%;
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
}

.nav-link {
  font-family: var(--font-family-2);
  font-size: 18px;
  font-weight: 500;
  line-height: 1em;
  text-transform: capitalize;
  color: var(--primary);
  padding: 15px;
}

.nav-link:hover {
  color: var(--accent-color);
}

.nav-link:focus,
.nav-link.active,
.navbar-nav .nav-link.show {
  color: var(--accent-color-2) !important;
}

.navbar-cta-container {
  width: 18%;
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: flex-end;
}

.nav-btn {
  display: none;
  padding: 16px 16px;
  background-color: var(--accent-color);
  color: var(--primary);
  transition: all 300ms ease;
  border: none;
  border-radius: 0;
  box-shadow: none;
  font-size: 18px;
}

.nav-btn:hover {
  background-color: var(--primary);
  color: var(--accent-color);
}

.navbar-brand {
  text-decoration: none;
}

/* 07. Sidebar */
.sidebar-overlay {
  position: fixed;
  top: 0;
  left: -100%;
  width: 100%;
  height: 100%;
  min-height: 100vh;
  background: var(--accent-sidebar-overlay);
  transition: left 0.4s ease-in-out;
  z-index: 10;
}

.sidebar-overlay.active {
  left: 0;
}

.sidebar {
  position: fixed;
  top: 0;
  left: -300px;
  width: 300px;
  height: 100%;
  background: var(--secondary);
  color: var(--primary);
  transition: transform 0.4s ease-in-out;
  z-index: 1000;
  overflow-y: auto;
  max-height: 100vh;
  padding: 0 16px 0 5px;
}

.sidebar.active {
  transform: translateX(300px);
}

.sidebar-header {
  display: flex;
  flex-direction: row;
  justify-content: space-between;
  align-items: center;
  padding: 20px;
}

.close-btn {
  display: inline-block;
  justify-content: center;
  background-color: var(--accent-color);
  border-radius: 8px;
  color: var(--primary);
  font-weight: 600;
  position: relative;
  font-family: var(--font-family-2);
  font-size: 16px;
  cursor: pointer;
  padding: 8px 18px;
  transition: all 300ms;
  border: none;
  outline: none;
}

.close-btn:hover {
  background-color: var(--primary);
  color: var(--accent-color);
}

.menu {
  list-style: none;
  padding: 0;
  margin-top: 20px;
}

.menu li {
  padding: 10px 15px 10px 15px;
}

.menu a {
  color: var(--primary);
  text-decoration: none;
  display: block;
  border-radius: 5px;
  transition: 0.3s;
  font-family: var(--font-family-2);
  text-transform: capitalize;
  font-size: 16px;
  font-weight: 500;
  line-height: 1.5em;
  letter-spacing: 0;
}

.menu a:hover,
.menu a.active,
.menu a:focus {
  color: var(--accent-color);
}

.sidebar::-webkit-scrollbar {
  width: 5px;
}

.sidebar::-webkit-scrollbar-thumb {
  background: gray;
  border-radius: 5px;
}

/* 08. Forms + Newsletter */
.form {
  display: flex;
  flex-direction: column;
  gap: 20px 20px;
}

.form input,
.form select,
.form textarea {
  font-family: var(--font-family-2);
  font-weight: 500;
  line-height: 1.5em;
  padding: 20px 0 20px 0;
  background-color: transparent;
  color: var(--primary);
  outline: none;
  border: none;
  border-bottom: 1px solid var(--accent-color-3);
  width: 100%;
  transition: all 300ms;
}

.form input:focus,
.form textarea:focus {
  border-bottom: 1px solid var(--accent-color);
}

.form input:autofill,
.form textarea:autofill {
  background-color: transparent;
  color: var(--primary);
  transition: background-color 5000s ease-in-out;
  -webkit-text-fill-color: var(--primary);
  font-family: var(--font-family-2);
}

.form input::placeholder,
.form textarea::placeholder {
  color: var(--primary);
}

#newsletter-form {
  display: flex;
  flex-direction: row;
  gap: 0 0;
  align-items: flex-end;
  flex-wrap: nowrap;
  width: 100%;
}

#newsletter-form input {
  font-family: var(--font-family-1);
  font-size: 16px;
  border: none;
  border-bottom: 1px solid var(--primary);
  outline: none;
  background-color: transparent;
  color: var(--primary);
  padding: 10px 0 0 0;
  width: 65%;
}

#newsletter-form input::placeholder {
  font-family: var(--font-family-1);
  font-size: 32px;
  font-weight: 400;
  line-height: 1.2em;
  text-transform: lowercase;
  color: var(--primary);
}

#newsletter-form button {
  width: 35%;
  flex-wrap: nowrap;
  text-align: center;
  display: flex;
  flex-direction: row;
  justify-content: center;
}

.alert {
  display: flex;
  flex-direction: column;
  align-items: center;
  padding: 2em;
  border-radius: 6px;
  margin-bottom: 15px;
}

.success {
  display: flex;
  flex-direction: column;
  gap: 16px;
  background-color: var(--primary);
  color: var(--secondary);
}

.success span,
.success p {
  color: var(--secondary);
}

.error {
  display: flex;
  flex-direction: column;
  gap: 1em;
  background-color: var(--primary);
  color: var(--secondary);
}

.error span,
.error p {
  color: var(--secondary);
}

.check-icon,
.cross-icon {
  font-size: 1.5rem;
  margin-right: 10px;
}

.hidden {
  display: none;
}

/* 09. Home Sections */
.banner-home-video {
  display: flex;
  flex-direction: row;
  align-items: flex-end;
  min-height: 100vh;
  padding: 120px 20px 0 20px;
  position: relative;
  overflow: hidden;
  z-index: 2;
}

.banner-home-video::before {
  content: "";
  position: absolute;
  inset: 0;
  background-color: transparent;
  background-image: radial-gradient(at top left, #12121259 0%, var(--secondary) 100%);
  z-index: 1;
}

.banner-home-content {
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  width: 100%;
  height: 100%;
  padding-bottom: 80px;
}

.home-title-container {
  display: flex;
  flex-direction: column;
  width: 67%;
  text-align: start;
  align-items: start;
  height: 100%;
}

.home-avatar-container {
  width: 30%;
  display: flex;
  flex-direction: column;
  align-self: flex-end;
  text-align: start;
  align-items: start;
  gap: 20px 20px;
}

.banner-avatar {
  display: inline-block;
  vertical-align: middle;
  background-color: var(--accent-color);
  width: 50px;
  min-height: 50px;
  border-radius: 100px;
  object-fit: cover;
  border: 5px solid var(--accent-color);
}

.banner-avatar:not(:nth-child(1)) {
  margin-left: -15px;
}

.home-divider {
  width: 100%;
  border-bottom: 3px solid var(--primary);
}

.service-content-banner {
  display: flex;
  flex-direction: column;
  position: relative;
  z-index: 1;
}

.service-content-banner::before {
  content: '';
  position: absolute;
  background-color: transparent;
  background-image: radial-gradient(at top center, var(--accent-color) 0%, var(--accent-color-4) 31%);
  width: 100%;
  height: 100%;
  top: 0;
  left: 0;
  opacity: 0.22;
  z-index: -1;
}

/* 10. Product Grid + Accordion */
.service-content-container {
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
  width: 100%;
  min-height: 500px;
  padding: 0;
  background-color: var(--secondary);
  position: relative;
  overflow: hidden;
  z-index: 2;
}

.service-video-content {
  display: flex;
  flex-direction: column;
  align-self: flex-end;
  background-color: #1212122b;
  color: var(--primary);
  padding: 30px;
  position: relative;
  overflow: hidden;
  z-index: 1;
}

.service-video-content::before {
  content: "";
  width: 100%;
  height: 100%;
  position: absolute;
  left: 0;
  top: 0;
  -webkit-backdrop-filter: blur(6px);
  backdrop-filter: blur(6px);
  border-radius: inherit;
  background-color: inherit;
  z-index: -1;
}

.service-description-content {
  width: 56%;
}

.service-tag-container {
  width: 33%;
  display: flex;
  flex-direction: row;
  flex-wrap: wrap;
  align-self: center;
  gap: 5px 5px;
}

.service-tag {
  display: inline-block;
  background-color: var(--accent-color-4);
  color: var(--primary);
  padding: 5px 10px;
  border: 1px solid var(--accent-color);
  border-radius: 100px;
  white-space: nowrap;
  font-size: 14px;
  font-weight: 400;
  line-height: 1em;
  font-family: var(--font-family-2);
}

.accordion {
  display: flex;
  flex-direction: column;
  gap: 30px 30px;
}

.accordion .accordion-item {
  background-color: transparent;
  border: none;
  outline: none;
  overflow: hidden;
}

.accordion .accordion-item .accordion-header {
  border: none;
  border-bottom: 1px solid var(--accent-color-6);
  position: relative;
  overflow: hidden;
}

.accordion .accordion-item .accordion-body {
  padding: 30px 0 30px 0;
}

.accordion .accordion-item .service-accordion-header {
  padding-left: 0;
}

.accordion-item.service-acc-1 .service-accordion-header {
  padding-left: 350px;
}

.accordion-item.service-acc-2 .service-accordion-header {
  padding-left: 170px;
}

.accordion-item.service-acc-3 .service-accordion-header {
  padding-left: 450px;
}

.accordion-item.service-acc-4 .service-accordion-header {
  padding-left: 250px;
}

.accordion-item .service-accordion-header .accordion-button {
  background-color: transparent;
  border: 0;
  font-family: var(--font-family-1);
  font-size: 115px;
  font-weight: 400;
  text-transform: uppercase;
  line-height: 1.1em;
  box-shadow: none;
  -webkit-text-stroke-width: 2px;
  stroke-width: 2px;
  -webkit-text-stroke-color: var(--primary);
  stroke: var(--primary);
  color: var(--accent-color-4);
  margin-block-end: -30px;
  padding: 0;
}

.accordion-item .service-accordion-header .accordion-button::after {
  display: none;
}

.accordion-item .service-accordion-header .accordion-button:not(.collapsed) {
  color: var(--primary) !important;
}

/* 11. Icons + Lists */
.social-icon {
  width: 45px;
  min-height: 45px;
  display: inline-flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  padding: 0.5em;
  border-radius: 50%;
  background-color: var(--accent-color);
  color: var(--primary);
  font-size: 16px;
  line-height: 1;
  transition: all 300ms;
}

.social-icon:hover {
  background-color: var(--accent-color-2);
  transform: scale(0.9);
}

.footer-icon {
  width: 45px;
  min-height: 45px;
  display: inline-flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  padding: 0.5em;
  border-radius: 50%;
  background-color: var(--primary);
  color: var(--accent-color);
  font-size: 21px;
  line-height: 1;
  transition: all 300ms;
}

.footer-icon:hover {
  background-color: var(--accent-color-2);
  color: var(--primary);
}

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

.chevron-circle-list li {
  position: relative;
  display: flex;
  flex-direction: row;
  align-items: center;
  justify-content: start;
  margin-bottom: 10px;
}

.chevron-circle-list a {
  color: var(--primary);
  font-family: var(--font-family-2);
  font-size: 18px;
  font-weight: 500;
  text-transform: capitalize;
  line-height: 1.5em;
}

.chevron-circle-list li:last-child {
  margin-bottom: 0;
}

.chevron-circle-list li::before {
  content: "\f138";
  font-family: "Font Awesome 7 Free";
  font-weight: 900;
  color: var(--primary);
  margin-right: 0.5em;
  font-size: 18px;
  display: inline-block;
}

/* 12. Footer */
.footer-container {
  display: flex;
  flex-direction: column;
  gap: 65px 50px;
}

.social-footer-container {
  display: flex;
  flex-direction: row;
  align-items: center;
  gap: 10px 10px;
}

.footer-newsletter-container {
  display: flex;
  flex-direction: column;
  gap: 40px 0;
  width: 100%;
}

.footer-title-container {
  display: flex;
  flex-direction: column;
  min-height: 150px;
  justify-content: flex-end;
  overflow: hidden;
  border-bottom: 5px solid var(--primary);
  padding: 0;
}

.footer-title {
  text-align: center;
  font-family: var(--font-family-1);
  font-size: 200px;
  font-weight: 400;
  line-height: 1em;
  margin-bottom: -59px;
  text-transform: uppercase;
}

.footer-newsletter-container .container-title {
  width: 42%;
}

.footer-copyright-container {
  background-color: var(--accent-color-2);
  width: 100%;
  color: var(--primary);
  display: flex;
  flex-direction: row;
  gap: 10px 10px;
  justify-content: space-between;
  align-items: center;
  padding: 30px 40px 30px 40px;
  border-radius: 40px 0 40px 0;
}

.legallink,
.copyright {
  font-family: var(--font-family-2);
  color: var(--primary);
  font-size: 14px;
  font-weight: 500;
  line-height: 1.5em;
  text-transform: capitalize;
  text-align: start;
  letter-spacing: 0;
}

/* 13. Spacing Utilities (Used) */
.gspace-1 {
  gap: 10px 10px;
}

.gspace-2 {
  gap: 20px 20px;
}

.gspace-3 {
  gap: 30px 30px;
}

.gspace-x-1 {
  column-gap: 10px;
}

.gspace-y-0 {
  row-gap: 0;
}

.grid-spacer-2 {
  --bs-gutter-x: 20px;
  --bs-gutter-y: 20px;
}

.grid-spacer-3 {
  --bs-gutter-x: 30px;
  --bs-gutter-y: 30px;
}

.grid-spacer-80 {
  --bs-gutter-x: 80px;
  --bs-gutter-y: 80px;
}

/* 14. Pin & Claw Product Styles */
.pinclaw-wordmark {
  color: var(--primary);
  font-family: var(--font-family-1);
  font-size: 28px;
  letter-spacing: 1px;
  line-height: 1;
  text-transform: uppercase;
}

.pinclaw-wordmark span {
  color: #3563c5;
}

@keyframes pinclaw-circle-spin {
  from {
    transform: rotate(0deg);
  }

  to {
    transform: rotate(360deg);
  }
}

.pinclaw-who-badge-container {
  margin-top: 20px;
  max-width: 170px;
}

.pinclaw-who-badge {
  width: 100%;
  animation: pinclaw-circle-spin 6s linear infinite;
  transform-origin: center center;
}

.pinclaw-who-badge svg {
  width: 100%;
  height: 100%;
  display: block;
  overflow: visible;
}

.pinclaw-who-badge circle {
  fill: var(--accent-color);
}

.pinclaw-who-badge text {
  font-family: var(--font-family-1);
  font-size: 15px;
  font-weight: 400;
  line-height: 1.2em;
  fill: var(--primary);
}

.pinclaw-who-badge textPath {
  letter-spacing: 2px;
  dominant-baseline: middle;
}

.pinclaw-who-badge-image {
  animation: none;
  transform: none;
}

.pinclaw-parallax {
  position: relative;
  isolation: isolate;
  background-attachment: fixed;
  background-position: center;
  background-repeat: no-repeat;
  background-size: cover;
}

.pinclaw-parallax::before {
  content: "";
  position: absolute;
  inset: 0;
  z-index: 1;
  background: linear-gradient(140deg, rgba(7, 7, 7, 0.86), rgba(9, 9, 9, 0.7));
  pointer-events: none;
}

.pinclaw-parallax > .hero-container {
  position: relative;
  z-index: 2;
}

.pinclaw-parallax-hero {
  background-image: url('/assets/images/fiddleleaf1.jpg');
}

.pinclaw-parallax-build {
  background-image: url('/assets/images/fiddleleaf4.jpg');
}

.pinclaw-kicker {
  font-family: var(--font-family-1);
  color: #3563c5;
  font-size: 15px;
  letter-spacing: 2px;
  text-transform: uppercase;
}

.pinclaw-hero-title {
  max-width: 1080px;
  margin: 20px 0 24px;
}

.pinclaw-hero-copy {
  max-width: 920px;
  color: var(--primary);
  font-size: 22px;
}

.pinclaw-app-accordion .accordion-item .service-accordion-header .accordion-button {
  font-size: clamp(2.2rem, 9vw, 6rem);
  line-height: 1;
  margin-block-end: -12px;
}

.pinclaw-app-accordion .accordion-item .service-accordion-header {
  padding-left: 0;
}

.pinclaw-app-accordion .accordion-item.service-acc-1 .service-accordion-header {
  padding-left: 300px;
}

.pinclaw-app-accordion .accordion-item.service-acc-2 .service-accordion-header {
  padding-left: 140px;
}

.pinclaw-app-accordion .accordion-item.service-acc-3 .service-accordion-header {
  padding-left: 380px;
}

.pinclaw-app-accordion .accordion-item.service-acc-4 .service-accordion-header {
  padding-left: 210px;
}

.pinclaw-app-accordion .service-content-container {
  min-height: auto;
  border-radius: 16px;
  background: rgba(20, 20, 20, 0.1);
  border: 0 solid rgba(255, 255, 255, 0);
  backdrop-filter: blur(4px);
}

.pinclaw-app-accordion .service-video-content {
  width: 100%;
  padding: 26px;
  background-color: transparent;
}

.pinclaw-app-accordion .service-video-content::before {
  display: none;
}

.pinclaw-app-accordion .service-description-content {
  width: 64%;
}

.pinclaw-app-accordion .service-tag-container {
  width: 34%;
  align-self: flex-start;
}

.pinclaw-app-accordion .service-tag {
  border-color: #3563c5;
  color: #dce5ff;
}

.banner-inner {
  position: relative;
  padding: 180px 20px 120px 20px;
  overflow: hidden;
  display: flex;
  flex-direction: column;
  text-align: center;
}

.banner-inner::before {
  content: "";
  position: absolute;
  inset: 0;
  background-size: cover;
  background-position: center center;
  background-repeat: no-repeat;
  z-index: 0;
}

.banner-inner-container {
  position: relative;
  display: flex;
  flex-direction: column;
  gap: 20px 20px;
  justify-content: center;
  align-items: center;
  color: var(--primary);
  z-index: 1;
}

.heading-container {
  display: flex;
  flex-direction: row;
  padding-left: 20px;
  border-left: 5px solid var(--accent-color);
  position: relative;
  overflow: hidden;
}

.breadcrumb {
  display: flex;
  flex-direction: row;
  align-items: center;
  justify-content: center;
  gap: 10px;
  margin: 0;
  padding: 0;
}

.breadcrumb-item {
  font-family: var(--font-family-2);
  font-size: 18px;
  font-weight: 500;
  text-transform: capitalize;
  line-height: 1.5em;
  color: var(--accent-color);
  margin: 0;
  padding: 0;
}

.breadcrumb .separator {
  font-family: var(--font-family-1);
  font-size: 21px;
  line-height: 1.3em;
  color: var(--primary);
}

.breadcrumb-item.current {
  color: var(--primary);
}

.project-detail-content-container {
  display: flex;
  flex-direction: column;
  gap: 80px 80px;
  position: relative;
  overflow: hidden;
}

.card-project-detail {
  background-color: var(--accent-color-5);
  color: var(--primary);
  display: flex;
  flex-direction: column;
  gap: 20px 20px;
  padding: 30px 30px 30px 30px;
  border: none;
  border-radius: 0;
}

.project-detail-video-container {
  display: flex;
  flex-direction: column;
  position: relative;
  overflow: hidden;
}

.project-detail-video-spacer {
  min-height: 470px;
}

.project-result {
  color: var(--primary);
  font-family: var(--font-family-1);
  font-size: 32px;
  font-weight: 500;
  line-height: 1.3em;
  text-transform: uppercase;
}

.project-result .result-link {
  color: var(--accent-color);
  transition: color 300ms;
}

.project-result .result-link:hover {
  color: var(--accent-color-2);
}

.pinclaw-list {
  margin: 18px 0 0;
  padding-left: 18px;
  list-style: disc;
}

.pinclaw-list li {
  margin-bottom: 10px;
  color: var(--text-color);
  font-size: 18px;
}

.pinclaw-shotbook-banner::before {
  background-image: linear-gradient(145deg, rgba(8, 12, 23, 0.92), rgba(6, 10, 18, 0.55)),
    radial-gradient(circle at 80% 20%, rgba(53, 99, 197, 0.3), transparent 46%);
}

.pinclaw-shotbook-banner {
  background-image: url('/assets/images/yosemite3.jpg');
  background-size: cover;
  background-position: center center;
  background-repeat: no-repeat;
  background-attachment: fixed;
}

.pinclaw-shotbook-banner .banner-inner-container {
  max-width: 1020px;
  align-items: flex-start;
  text-align: start;
}

.pinclaw-banner-copy {
  max-width: 880px;
  color: var(--primary);
  font-size: 24px;
  line-height: 1.45em;
}

.pinclaw-shotbook-overview {
  border: 1px solid #31456f;
}

.pinclaw-shotbook-overview .project-detail-video-spacer {
  display: flex;
  align-items: flex-end;
  padding: 40px;
  position: relative;
  overflow: hidden;
  min-height: 460px;
  background-image: linear-gradient(180deg, rgba(6, 7, 10, 0.35), rgba(6, 7, 10, 0.8)),
    url('/assets/images/fiddleleaf4.jpg');
  background-size: cover;
  background-position: center center;
}

.pinclaw-overview-content {
  max-width: 760px;
  position: relative;
  z-index: 1;
}

.pinclaw-overview-content p {
  color: #f0f4ff;
}

.pinclaw-shotbook-section {
  padding-bottom: 120px;
}

.contact-cta-banner {
  background-color: var(--accent-color);
  color: var(--primary);
  padding: 80px 80px 80px 80px;
  border-radius: 100px 0 100px 0;
  position: relative;
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  overflow: hidden;
  z-index: 0;
}

.contact-cta-title-container {
  position: relative;
  width: 87%;
  z-index: auto;
}

.contact-cta-title {
  font-size: 115px;
  font-weight: 400;
  text-transform: uppercase;
  line-height: 1.1em;
  text-align: start;
}

.contact-cta-title.heading-fill {
  position: relative;
  color: var(--primary);
  z-index: 1;
}

.contact-cta-title.heading-stroke {
  position: absolute;
  top: 0;
  left: 0;
  -webkit-text-stroke-width: 2px;
  stroke-width: 2px;
  -webkit-text-stroke-color: var(--primary);
  stroke: var(--primary);
  color: var(--accent-color-4);
  z-index: 3;
}

.contact-cta-text-container {
  display: flex;
  flex-direction: column;
  gap: 20px;
  margin-top: -80px;
  margin-left: auto;
  width: 47%;
  align-self: end;
  text-align: start;
  z-index: 3;
}

.contact-cta-image {
  position: absolute;
  left: -50px;
  bottom: 0;
  width: 58%;
  z-index: 2;
}

.pinclaw-panel {
  background-color: #191919;
  border: 1px solid #2f2f2f;
  border-radius: 16px;
  padding: 30px;
}

.pinclaw-shotbook-waitlist {
  margin-top: 0;
  overflow: hidden;
}

.pinclaw-shotbook-waitlist .pinclaw-waitlist-form label {
  color: #f7f9ff;
}

.pinclaw-shotbook-waitlist .pinclaw-waitlist-form input,
.pinclaw-shotbook-waitlist .pinclaw-waitlist-form select {
  border-color: rgba(255, 255, 255, 0.4);
  background: rgba(10, 19, 44, 0.42);
}

.pinclaw-shotbook-waitlist .pinclaw-waitlist-form input.pinclaw-waitlist-email {
  font-family: var(--font-family-1);
  font-size: 16px;
  border: none;
  border-bottom: 1px solid var(--primary);
  border-radius: 0;
  outline: none;
  background: transparent;
  color: var(--primary);
  padding: 10px 0 0 0;
  margin-top: 0;
}

.pinclaw-shotbook-waitlist .pinclaw-waitlist-email::placeholder {
  font-family: var(--font-family-1);
  font-size: 32px;
  font-weight: 400;
  line-height: 1.2em;
  text-transform: lowercase;
  color: var(--primary);
}

.pinclaw-role-dropdown {
  position: relative;
}

.pinclaw-role-trigger {
  width: 100%;
  border: none;
  border-bottom: 1px solid var(--primary);
  border-radius: 0;
  outline: none;
  background-color: transparent;
  color: var(--primary);
  padding: 10px 0 0 0;
  display: flex;
  flex-direction: row;
  justify-content: space-between;
  align-items: center;
  cursor: pointer;
  overflow: hidden;
}

.pinclaw-role-label {
  font-family: var(--font-family-1);
  font-size: 32px;
  font-weight: 400;
  line-height: 1.2em;
  text-transform: lowercase;
  letter-spacing: 0;
  transform: translateY(6px);
}

.pinclaw-role-trigger i {
  font-size: 14px;
  transition: transform 200ms ease;
}

.pinclaw-role-dropdown.is-open .pinclaw-role-trigger i {
  transform: rotate(180deg);
}

.pinclaw-role-menu {
  margin: 0;
  padding: 6px;
  list-style: none;
  position: fixed;
  top: var(--role-menu-top, 0);
  left: var(--role-menu-left, 0);
  width: var(--role-menu-width, 280px);
  z-index: 2000;
  border: 1px solid rgba(255, 255, 255, 0.4);
  border-radius: 12px;
  background: rgba(8, 15, 35, 0.96);
  backdrop-filter: blur(6px);
  box-shadow: 0 10px 24px rgba(0, 0, 0, 0.3);
  max-height: 220px;
  overflow-y: auto;
}

.pinclaw-role-option {
  width: 100%;
  border: none;
  background: transparent;
  color: #ffffff;
  text-align: left;
  font-family: var(--font-family-2);
  font-size: 10px;
  font-weight: 500;
  line-height: 1.35em;
  letter-spacing: 0;
  text-transform: none;
  padding: 5px 10px;
  border-radius: 8px;
  cursor: pointer;
}

.pinclaw-role-option:hover,
.pinclaw-role-option:focus-visible {
  background: rgba(255, 255, 255, 0.12);
  outline: none;
}

.pinclaw-role-option.is-selected {
  background: rgba(255, 255, 255, 0.2);
}

.pinclaw-shotbook-waitlist .pinclaw-consent-row {
  color: #eef3ff;
}

.pinclaw-shotbook-waitlist .pinclaw-consent-row a {
  color: #ffffff;
}

.pinclaw-shotbook-waitlist .pinclaw-consent-row input {
  border-color: #bdd0ff;
  background-color: rgba(10, 19, 44, 0.42);
}

.pinclaw-shotbook-waitlist .pinclaw-consent-row input:hover {
  border-color: #ffffff;
}

.pinclaw-shotbook-waitlist .pinclaw-consent-row input:checked {
  border-color: #ffffff;
  background-color: #ffffff;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 20 20'%3E%3Cpath fill='%233563c5' d='M7.6 13.6 4.4 10.4 3 11.8l4.6 4.6L17 7l-1.4-1.4z'/%3E%3C/svg%3E");
}

.pinclaw-spec-card h5 {
  display: flex;
  flex-wrap: wrap;
  align-items: baseline;
  gap: 6px;
}

.pinclaw-spec-label {
  font-family: var(--font-family-1);
}

.pinclaw-spec-value {
  font-family: var(--font-family-2);
  font-size: 15px;
  font-weight: 400;
  line-height: 1.5em;
  letter-spacing: 0;
  text-transform: none;
  color: var(--text-color);
}

.pinclaw-waitlist-form {
  display: grid;
  gap: 14px;
}

.pinclaw-waitlist-form label {
  font-family: var(--font-family-1);
  letter-spacing: 0.5px;
  text-transform: uppercase;
  font-size: 12px;
  color: #efefef;
}

.pinclaw-waitlist-form input,
.pinclaw-waitlist-form select {
  width: 100%;
  border: 1px solid #3a3a3a;
  border-radius: 8px;
  background: #101010;
  color: #fff;
  padding: 12px;
  margin-top: 6px;
}

.pinclaw-consent-row {
  display: flex;
  align-items: center;
  gap: 10px;
  font-family: var(--font-family-2);
  text-transform: none;
  color: var(--text-color);
  font-size: 16px;
  line-height: 1.5;
}

.pinclaw-consent-row input {
  margin-top: 0;
  width: 18px;
  height: 18px;
  padding: 0;
  box-sizing: border-box;
  -webkit-appearance: none;
  appearance: none;
  border: 1.5px solid #6f87bc;
  border-radius: 50%;
  background-color: #101010;
  background-repeat: no-repeat;
  background-position: center;
  background-size: 11px 11px;
  cursor: pointer;
  transition: all 200ms ease;
  flex-shrink: 0;
}

.pinclaw-consent-row input:hover {
  border-color: #91a8da;
}

.pinclaw-consent-row input:checked {
  border-color: var(--accent-color);
  background-color: var(--accent-color);
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 20 20'%3E%3Cpath fill='%23ffffff' d='M7.6 13.6 4.4 10.4 3 11.8l4.6 4.6L17 7l-1.4-1.4z'/%3E%3C/svg%3E");
}

.pinclaw-consent-row input:focus-visible {
  outline: 2px solid #ffffff;
  outline-offset: 2px;
}

.pinclaw-consent-row a {
  color: var(--accent-color-6);
  text-transform: none;
  letter-spacing: 0;
  font-size: inherit;
  font-family: var(--font-family-2);
}

.pinclaw-honeypot {
  position: absolute;
  left: -9999px;
}

.pinclaw-waitlist-message {
  margin: 6px 0 0;
  font-size: 15px;
}

.pinclaw-waitlist-message.success {
  color: #73d87a;
}

.pinclaw-waitlist-message.error {
  color: #ff7f7f;
}

.pinclaw-privacy {
  max-width: 980px;
  margin: 0 auto;
}

.pinclaw-privacy h4 {
  margin: 28px 0 12px;
}

/* 15. Responsive */
@media screen and (max-width: 991.98px) {
  h1 {
    font-size: 80px;
  }

  h2 {
    font-size: 60px;
  }

  h3 {
    font-size: 36px;
  }

  h4 {
    font-size: 24px;
  }

  h5 {
    font-size: 19px;
  }

  p {
    font-size: 16px;
  }

  .nav-btn {
    display: block;
  }

  .navbar-nav {
    display: none;
  }

  .navbar-cta-container {
    display: none;
  }

  .btn {
    padding: 15px 30px 15px 30px;
  }

  .home-title-container {
    width: 52%;
  }

  .home-avatar-container {
    width: 46%;
  }

  .banner-home-video {
    padding: 120px 20px 0 20px;
    min-height: 93vh;
  }

  .service-description-content {
    width: 100%;
  }

  .service-tag-container {
    width: 100%;
  }

  .accordion-item .service-accordion-header .accordion-button {
    font-size: 80px;
  }

  .footer-icon {
    font-size: 18px;
    width: 40px;
    min-height: 40px;
  }

  .footer-title {
    font-size: 150px;
    margin-bottom: -36px;
  }

  .chevron-circle-list a {
    font-size: 16px;
  }

  #newsletter-form input::placeholder {
    font-size: 24px;
  }

  .pinclaw-parallax {
    background-attachment: scroll;
  }

  .pinclaw-wordmark {
    font-size: 24px;
  }

  .pinclaw-who-badge-container {
    max-width: 150px;
  }

  .pinclaw-shotbook-banner {
    background-attachment: scroll;
  }

  .pinclaw-app-accordion .service-description-content {
    width: 100%;
  }

  .pinclaw-app-accordion .service-tag-container {
    width: 100%;
  }

  .pinclaw-app-accordion .accordion-item.service-acc-1 .service-accordion-header,
  .pinclaw-app-accordion .accordion-item.service-acc-2 .service-accordion-header,
  .pinclaw-app-accordion .accordion-item.service-acc-3 .service-accordion-header,
  .pinclaw-app-accordion .accordion-item.service-acc-4 .service-accordion-header {
    padding-left: 0;
  }

  .grid-spacer-80 {
    --bs-gutter-x: 40px;
    --bs-gutter-y: 40px;
  }

  .banner-inner {
    padding: 160px 20px 100px 20px;
  }

  .breadcrumb-item {
    font-size: 16px;
  }

  .project-detail-content-container {
    gap: 60px 60px;
  }

  .project-detail-video-spacer {
    min-height: 400px;
  }

  .project-result {
    font-size: 24px;
  }

  .pinclaw-banner-copy {
    font-size: 19px;
  }

  .contact-cta-banner {
    padding: 50px 20px 50px 20px;
  }

  .contact-cta-title-container {
    width: 100%;
  }

  .contact-cta-title {
    font-size: 80px;
  }

  .contact-cta-text-container {
    width: 54%;
    margin-top: -54px;
  }

  .contact-cta-image {
    left: 0;
    width: 69%;
  }

  .pinclaw-shotbook-waitlist .pinclaw-waitlist-email::placeholder {
    font-size: 24px;
  }

  .pinclaw-role-label {
    font-size: 24px;
    transform: translateY(2px);
  }
}

@media screen and (max-width: 767.98px) {
  h1 {
    font-size: 60px;
  }

  h2 {
    font-size: 39px;
  }

  h3 {
    font-size: 28px;
  }

  h4 {
    font-size: 21px;
  }

  h5 {
    font-size: 18px;
  }

  p {
    font-size: 14px;
  }

  .banner-home-video {
    padding: 120px 20px 120px 20px;
  }

  .pinclaw-who-badge-container {
    max-width: 132px;
  }

  .btn {
    font-size: 14px;
    padding: 13px 26px 13px 26px;
  }

  .home-title-container {
    width: 100%;
    text-align: center;
    align-items: center;
  }

  .home-avatar-container {
    width: 100%;
    flex-direction: column-reverse;
    text-align: center;
    align-items: center;
  }

  .navbar .logo-container {
    width: 50%;
  }

  .accordion-item .service-accordion-header .accordion-button {
    font-size: 60px;
  }

  .accordion-item.service-acc-1 .service-accordion-header,
  .accordion-item.service-acc-2 .service-accordion-header,
  .accordion-item.service-acc-3 .service-accordion-header,
  .accordion-item.service-acc-4 .service-accordion-header {
    padding-left: 0;
  }

  #newsletter-form {
    flex-direction: column;
    gap: 20px 20px;
  }

  #newsletter-form input {
    width: 100%;
  }

  #newsletter-form button {
    width: 100%;
  }

  #newsletter-form input::placeholder {
    font-size: 21px;
  }

  .footer-copyright-container {
    flex-direction: column;
    justify-content: center;
  }

  .footer-icon {
    font-size: 16px;
    width: 35px;
    min-height: 35px;
  }

  .footer-title {
    font-size: 80px;
  }

  .legalink,
  .copyright {
    font-size: 12px;
    text-align: center;
  }

  .chevron-circle-list a {
    font-size: 14px;
  }

  .grid-spacer-80 {
    --bs-gutter-x: 20px;
    --bs-gutter-y: 40px;
  }

  .banner-inner {
    padding: 130px 20px 90px 20px;
  }

  .banner-inner-container {
    gap: 16px 16px;
  }

  .breadcrumb-item {
    font-size: 14px;
  }

  .project-detail-content-container {
    gap: 40px 40px;
  }

  .project-detail-video-spacer {
    min-height: 320px;
    padding: 24px;
  }

  .project-result {
    font-size: 21px;
  }

  .pinclaw-banner-copy {
    font-size: 16px;
  }

  .heading-container {
    padding-left: 14px;
    border-left-width: 4px;
  }

  .pinclaw-list li {
    font-size: 14px;
  }

  .pinclaw-spec-value {
    font-size: 13px;
  }

  .contact-cta-banner {
    border-radius: 50px 0 50px 0;
    gap: 20px;
    padding: 50px 20px;
  }

  .contact-cta-title {
    font-size: 60px;
    text-align: center;
  }

  .contact-cta-text-container {
    width: 100%;
    margin-top: 0;
    text-align: center;
  }

  .contact-cta-image {
    width: 100%;
  }

  .pinclaw-shotbook-waitlist .pinclaw-waitlist-email::placeholder {
    font-size: 21px;
  }

  .pinclaw-role-label {
    font-size: 21px;
    transform: translateY(0);
  }

  .pinclaw-panel {
    padding: 22px;
  }
}

@media (prefers-reduced-motion: reduce) {
  .pinclaw-who-badge {
    animation: none;
  }
}
