/*
 * Simplest1 Marketing v2
 * Minimal landing page for /2/
 * Extends style.css with /2/-specific components.
 */

/* ==========================================================================
   Landing Page Layout
   ========================================================================== */

.landing {
  min-height: 100dvh;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: var(--space-8);
  background-color: var(--color-bg);
}

.landing__content {
  width: 100%;
  max-width: 40rem;
}

/* ==========================================================================
   Header
   ========================================================================== */

.landing__header {
  text-align: left;
  margin-bottom: var(--space-12);
}

.logo-link {
  display: inline-block;
  text-decoration: none;
}

.logo {
  display: block;
  height: 36px;
  width: auto;
  margin-bottom: var(--space-2);
}

.logo__accent {
  color: #e53935;
}

.tagline {
  font-size: var(--text-sm);
  font-weight: var(--weight-regular);
  color: var(--color-fg-subtle);
  letter-spacing: 0.02em;
}

/* ==========================================================================
   The Pitch - Feature Paragraph
   ========================================================================== */

.pitch {
  font-size: var(--text-md);
  font-weight: var(--weight-regular);
  line-height: 1.6;
  letter-spacing: -0.01em;
  color: var(--color-fg);
  text-align: left;
  margin-bottom: var(--space-8);
  max-width: 36rem;

  @media (min-width: 640px) {
    font-size: 1.1875rem;
    line-height: 1.65;
  }
}

.pitch__demo {
  position: relative;
  color: var(--color-fg);
  text-decoration: none;
  white-space: nowrap;
}

.pitch__demo::after {
  content: '';
  position: absolute;
  left: 0;
  right: -2px;
  bottom: -2px;
  height: 4px;
  background: rgba(220, 90, 90, 0.5);
  border-radius: 2px 3px 2px 4px;
  transform: rotate(-0.5deg) skewX(-4deg);
  transition: transform var(--duration) var(--ease),
              background var(--duration) var(--ease);
}

.pitch__demo:hover::after {
  background: rgba(220, 90, 90, 0.75);
  transform: rotate(-1deg) skewX(-5deg);
}

@media (prefers-color-scheme: dark) {
  .pitch__demo::after {
    background: rgba(200, 85, 85, 0.45);
  }
  .pitch__demo:hover::after {
    background: rgba(200, 85, 85, 0.65);
  }
}

/* ==========================================================================
   Highlighted Features - Pen/Marker Effect
   ========================================================================== */

.hl {
  position: relative;
  cursor: help;
  white-space: nowrap;
  padding: 0 0.1em;
  transition: transform var(--duration) var(--ease);
}

.hl::before {
  content: '';
  position: absolute;
  left: -3px;
  right: -3px;
  top: -1px;
  bottom: -1px;
  z-index: -1;
  transition: transform var(--duration) var(--ease);
}

.hl--blue::before {
  background: rgba(140, 170, 220, 0.3);
  border-radius: 2px 8px 3px 12px;
  transform: rotate(-1.2deg) skewX(-4deg);
  left: -5px;
  right: -2px;
}
.hl--blue:hover::before { transform: rotate(-1.8deg) skewX(-5deg) scale(1.02); }

.hl--green::before {
  background: rgba(140, 190, 150, 0.32);
  border-radius: 10px 2px 8px 3px;
  transform: rotate(0.8deg) skewX(3deg);
  top: -2px;
  bottom: 0;
}
.hl--green:hover::before { transform: rotate(1.2deg) skewX(4deg) scale(1.02); }

.hl--yellow::before {
  background: rgba(220, 200, 110, 0.35);
  border-radius: 3px 12px 2px 6px;
  transform: rotate(-0.4deg) skewX(-2deg) scaleY(0.95);
  left: -2px;
  right: -6px;
}
.hl--yellow:hover::before { transform: rotate(-0.8deg) skewX(-3deg) scaleY(0.95) scale(1.02); }

.hl--pink::before {
  background: rgba(220, 160, 175, 0.32);
  border-radius: 8px 3px 10px 2px;
  transform: rotate(1.5deg) skewX(5deg);
  top: 0;
  bottom: -2px;
}
.hl--pink:hover::before { transform: rotate(2deg) skewX(6deg) scale(1.02); }

.hl--purple::before {
  background: rgba(175, 155, 210, 0.3);
  border-radius: 4px 10px 6px 2px;
  transform: rotate(-2deg) skewX(-6deg);
  left: -4px;
  right: -1px;
}
.hl--purple:hover::before { transform: rotate(-2.5deg) skewX(-7deg) scale(1.02); }

.hl--orange::before {
  background: rgba(220, 175, 130, 0.34);
  border-radius: 12px 4px 2px 8px;
  transform: rotate(0.6deg) skewX(2deg) scaleY(1.05);
  left: -3px;
  right: -4px;
}
.hl--orange:hover::before { transform: rotate(1deg) skewX(3deg) scaleY(1.05) scale(1.02); }

.hl--mint::before {
  background: rgba(130, 195, 180, 0.32);
  border-radius: 2px 6px 12px 4px;
  transform: rotate(-0.7deg) skewX(4deg);
  top: -1px;
  bottom: -1px;
}
.hl--mint:hover::before { transform: rotate(-1.1deg) skewX(5deg) scale(1.02); }

.hl--coral::before {
  background: rgba(205, 130, 120, 0.32);
  border-radius: 6px 2px 4px 10px;
  transform: rotate(1.8deg) skewX(-3deg);
  left: -6px;
  right: -2px;
}
.hl--coral:hover::before { transform: rotate(2.2deg) skewX(-4deg) scale(1.02); }

@media (prefers-color-scheme: dark) {
  .hl--blue::before { background: rgba(120, 150, 200, 0.22); }
  .hl--green::before { background: rgba(120, 170, 130, 0.22); }
  .hl--yellow::before { background: rgba(200, 180, 90, 0.26); }
  .hl--pink::before { background: rgba(200, 140, 155, 0.22); }
  .hl--purple::before { background: rgba(155, 135, 190, 0.22); }
  .hl--orange::before { background: rgba(200, 155, 110, 0.24); }
  .hl--mint::before { background: rgba(110, 175, 160, 0.22); }
  .hl--coral::before { background: rgba(185, 115, 105, 0.24); }
}

/* ==========================================================================
   Tooltip
   ========================================================================== */

.tooltip {
  position: fixed;
  z-index: 1000;
  max-width: 280px;
  padding: var(--space-3) var(--space-4);
  font-size: var(--text-sm);
  line-height: var(--leading-relaxed);
  color: var(--color-fg);
  background-color: var(--color-bg);
  border: var(--border);
  border-radius: var(--radius);
  box-shadow: var(--shadow);
  transform: translateY(4px);
  opacity: 0;
  visibility: hidden;
  pointer-events: none;
  transition: opacity var(--duration) var(--ease),
              transform var(--duration) var(--ease),
              visibility var(--duration);
}

.tooltip--visible {
  opacity: 1;
  visibility: visible;
  transform: translateY(0);
}

/* ==========================================================================
   Launch Form
   ========================================================================== */

.launch-form {
  background-color: var(--color-bg-secondary);
  border: var(--border);
  border-radius: var(--radius);
  padding: var(--space-6);
  margin-bottom: var(--space-8);

  @media (min-width: 640px) {
    padding: var(--space-8);
  }
}

.launch-form__error {
  background-color: var(--color-danger-bg);
  border: 1px solid var(--color-danger);
  color: var(--color-danger-fg);
  padding: var(--space-4);
  border-radius: var(--radius);
  margin-bottom: var(--space-6);
  font-size: var(--text-sm);
}

.launch-form__row {
  display: flex;
  flex-direction: column;
  gap: var(--space-4);

  @media (min-width: 640px) {
    flex-direction: row;
    align-items: flex-end;
  }

  & + & {
    margin-top: var(--space-4);
  }
}

.launch-form__field {
  flex: 1;
}

.launch-form__field--subdomain {
  flex: 1.5;
}

.launch-form__label {
  display: block;
  font-size: var(--text-xs);
  font-weight: var(--weight-medium);
  color: var(--color-fg-muted);
  text-transform: uppercase;
  letter-spacing: 0.05em;
  margin-bottom: var(--space-2);
}

.launch-form__input,
.launch-form__select {
  width: 100%;
  padding: var(--space-3) var(--space-4);
  font-size: var(--text-md);
  color: var(--color-fg);
  background-color: var(--color-bg);
  border: var(--border);
  border-radius: var(--radius);
  transition: border-color var(--duration) var(--ease),
              box-shadow var(--duration) var(--ease);

  &::placeholder {
    color: var(--color-fg-subtle);
  }

  &:hover {
    border-color: var(--color-fg-subtle);
  }

  &:focus {
    outline: none;
    border-color: var(--color-link);
    box-shadow: 0 0 0 3px rgba(0, 102, 204, 0.1);
  }
}

.launch-form__select {
  appearance: none;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%2386868b' d='M6 8L2 4h8z'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: right var(--space-3) center;
  padding-right: 2.5rem;
  cursor: pointer;
}


.launch-form__subdomain-wrap {
  display: flex;
  align-items: stretch;
}

.launch-form__subdomain-wrap .launch-form__input {
  border-top-right-radius: 0;
  border-bottom-right-radius: 0;
  border-right: none;
}

.launch-form__domain {
  display: flex;
  align-items: center;
  padding: 0 var(--space-3);
  font-size: var(--text-sm);
  color: var(--color-fg-subtle);
  background-color: var(--color-bg-secondary);
  border: var(--border);
  border-left: none;
  border-radius: 0 var(--radius) var(--radius) 0;
  white-space: nowrap;
}

.launch-form__submit {
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: var(--space-2);
  padding: var(--space-3) var(--space-6);
  font-size: var(--text-md);
  font-weight: var(--weight-medium);
  color: white;
  background: transparent;
  border: none;
  cursor: pointer;
  transition: transform var(--duration) var(--ease);
  margin: var(--space-6) auto 0;
  width: fit-content;
}

/* Double blackish hand-drawn strikes */
.launch-form__submit::before,
.launch-form__submit::after {
  content: '';
  position: absolute;
  z-index: -1;
  transition: transform var(--duration) var(--ease),
              background var(--duration) var(--ease);
}

.launch-form__submit::before {
  left: -6px;
  right: -3px;
  top: -1px;
  bottom: 0;
  background: rgba(35, 35, 40, 0.9);
  border-radius: 3px 10px 4px 8px;
  transform: rotate(-1.5deg) skewX(-4deg);
}

.launch-form__submit::after {
  left: -2px;
  right: -5px;
  top: 1px;
  bottom: -2px;
  background: rgba(35, 35, 40, 0.8);
  border-radius: 8px 3px 10px 4px;
  transform: rotate(1.2deg) skewX(3deg);
}

.launch-form__submit:hover::before {
  background: rgba(25, 25, 30, 0.95);
  transform: rotate(-2deg) skewX(-5deg) scale(1.02);
}

.launch-form__submit:hover::after {
  background: rgba(25, 25, 30, 0.85);
  transform: rotate(1.6deg) skewX(4deg) scale(1.02);
}

.launch-form__submit:active::before {
  transform: rotate(-1deg) skewX(-3deg) scale(0.98);
}

.launch-form__submit:active::after {
  transform: rotate(0.8deg) skewX(2deg) scale(0.98);
}

@media (prefers-color-scheme: dark) {
  .launch-form__submit::before {
    background: rgba(50, 50, 55, 0.9);
  }
  .launch-form__submit::after {
    background: rgba(50, 50, 55, 0.8);
  }
  .launch-form__submit:hover::before {
    background: rgba(60, 60, 65, 0.95);
  }
  .launch-form__submit:hover::after {
    background: rgba(60, 60, 65, 0.85);
  }
}

.launch-form__note {
  margin-top: var(--space-4);
  font-size: var(--text-sm);
  color: var(--color-fg-subtle);
  text-align: center;
}

/* ==========================================================================
   Footer
   ========================================================================== */

.landing__footer {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: var(--space-3);
  font-size: var(--text-sm);
  color: var(--color-fg-subtle);

  & a {
    color: var(--color-fg-muted);
    transition: color var(--duration) var(--ease);

    &:hover {
      color: var(--color-fg);
    }
  }
}

.landing__footer-sep {
  color: var(--color-fg-subtle);
}

/* ==========================================================================
   Animations (reduced motion respected)
   ========================================================================== */

@media (prefers-reduced-motion: no-preference) {
  .landing__header,
  .pitch,
  .launch-form {
    animation: fadeIn 0.6s var(--ease) forwards;
  }

  .pitch {
    animation-delay: 0.1s;
    opacity: 0;
  }

  .launch-form {
    animation-delay: 0.2s;
    opacity: 0;
  }

  @keyframes fadeIn {
    from {
      opacity: 0;
      transform: translateY(10px);
    }
    to {
      opacity: 1;
      transform: translateY(0);
    }
  }
}

/* ==========================================================================
   Mobile Adjustments
   ========================================================================== */

@media (max-width: 639px) {
  .landing {
    padding: var(--space-6);
    align-items: flex-start;
    padding-top: var(--space-12);
  }

  .pitch {
    text-align: left;
  }

  /* Use inline background for mobile instead of pseudo-element */
  .hl {
    white-space: normal;
    padding: 2px 4px;
    margin: -2px -4px;
    border-radius: 3px;
    -webkit-box-decoration-break: clone;
    box-decoration-break: clone;
  }

  .hl::before {
    display: none;
  }

  .hl--blue { background: rgba(140, 170, 220, 0.3); }
  .hl--green { background: rgba(140, 190, 150, 0.32); }
  .hl--yellow { background: rgba(220, 200, 110, 0.35); }
  .hl--pink { background: rgba(220, 160, 175, 0.32); }
  .hl--purple { background: rgba(175, 155, 210, 0.3); }
  .hl--orange { background: rgba(220, 175, 130, 0.34); }
  .hl--mint { background: rgba(130, 195, 180, 0.32); }
  .hl--coral { background: rgba(205, 130, 120, 0.32); }
}
