/* ============================================
   Custom styles for client landing page
   Minimal — only what Tailwind can't handle
   ============================================ */

/* --- Fade-in animation --- */

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

.fade-in {
    animation: fadeInUp 600ms ease-out both;
}

.fade-in-delay {
    animation-delay: 150ms;
}

/* --- Card padding (responsive) --- */

.card-padding {
    padding: 1.5rem 1.25rem 2rem;
}

@media (min-width: 640px) {
    .card-padding {
        padding: 2rem 2rem 2.5rem;
    }
}

/* --- Logo inversion for dark backgrounds --- */

.logo-invert {
    filter: brightness(0) invert(1);
}

/* --- Form input focus refinements --- */

.form-input {
    font-size: 16px; /* Prevents iOS zoom on focus */
}

.form-input:focus {
    border-color: var(--brand-primary);
    box-shadow: 0 0 0 3px var(--brand-primary-ring);
}

/* --- Selection color --- */

::selection {
    background-color: var(--theme-selection-bg, rgba(45, 212, 168, 0.3));
    color: var(--theme-selection-text, #ffffff);
}

/* --- Ambient light glow --- */

body::before {
    content: '';
    position: fixed;
    top: -30%;
    right: -20%;
    width: 80vw;
    height: 80vw;
    max-width: 900px;
    max-height: 900px;
    background: radial-gradient(ellipse at center, rgba(13, 59, 53, 0.5) 0%, rgba(13, 59, 53, 0.12) 40%, transparent 70%);
    pointer-events: none;
    z-index: 0;
}

body::after {
    content: '';
    position: fixed;
    bottom: -20%;
    left: -25%;
    width: 70vw;
    height: 70vw;
    max-width: 800px;
    max-height: 800px;
    background: radial-gradient(ellipse at center, rgba(10, 42, 37, 0.4) 0%, transparent 65%);
    pointer-events: none;
    z-index: 0;
}

/* --- Floating orbs --- */

@keyframes floatOrb1 {
    0%, 100% { transform: translate(0, 0) scale(1); }
    33% { transform: translate(12px, -18px) scale(1.05); }
    66% { transform: translate(-8px, 8px) scale(0.95); }
}

@keyframes floatOrb2 {
    0%, 100% { transform: translate(0, 0) scale(1); }
    50% { transform: translate(-15px, 12px) scale(1.08); }
}

@keyframes floatOrb3 {
    0%, 100% { transform: translate(0, 0); }
    40% { transform: translate(20px, -10px); }
    80% { transform: translate(-10px, 15px); }
}

.ambient-orb {
    position: fixed;
    border-radius: 50%;
    pointer-events: none;
    z-index: 0;
}

.ambient-orb--lg {
    width: clamp(200px, 30vw, 400px);
    height: clamp(200px, 30vw, 400px);
    top: 8%;
    right: -5%;
    background: radial-gradient(circle at 40% 40%, rgba(45, 212, 168, 0.08) 0%, rgba(13, 59, 53, 0.15) 50%, transparent 70%);
    animation: floatOrb1 20s ease-in-out infinite;
}

.ambient-orb--md {
    width: clamp(80px, 12vw, 160px);
    height: clamp(80px, 12vw, 160px);
    bottom: 15%;
    right: 10%;
    background: radial-gradient(circle at 50% 50%, rgba(45, 212, 168, 0.06) 0%, rgba(20, 80, 70, 0.1) 60%, transparent 80%);
    animation: floatOrb2 15s ease-in-out infinite;
}

.ambient-orb--sm {
    width: clamp(40px, 6vw, 80px);
    height: clamp(40px, 6vw, 80px);
    top: 30%;
    left: 8%;
    background: radial-gradient(circle, rgba(45, 212, 168, 0.05) 0%, transparent 70%);
    border: 1px solid rgba(45, 212, 168, 0.06);
    animation: floatOrb3 18s ease-in-out infinite;
}

/* --- Diagonal light streaks (top-right corner) --- */

.light-streaks {
    position: fixed;
    top: -10%;
    right: -10%;
    width: 50vw;
    height: 50vw;
    max-width: 600px;
    max-height: 600px;
    pointer-events: none;
    z-index: 0;
    transform: rotate(-35deg);
    opacity: 0.4;
}

.light-streaks::before,
.light-streaks::after {
    content: '';
    position: absolute;
    background: linear-gradient(180deg, rgba(45, 212, 168, 0.06) 0%, transparent 100%);
}

.light-streaks::before {
    width: 2px;
    height: 100%;
    top: 0;
    right: 30%;
}

.light-streaks::after {
    width: 1px;
    height: 80%;
    top: 10%;
    right: 45%;
}

/* --- Bottom-left diagonal streaks --- */

.light-streaks-bl {
    position: fixed;
    bottom: -10%;
    left: -10%;
    width: 40vw;
    height: 40vw;
    max-width: 500px;
    max-height: 500px;
    pointer-events: none;
    z-index: 0;
    transform: rotate(-35deg);
    opacity: 0.3;
}

.light-streaks-bl::before,
.light-streaks-bl::after {
    content: '';
    position: absolute;
    background: linear-gradient(0deg, rgba(45, 212, 168, 0.05) 0%, transparent 100%);
}

.light-streaks-bl::before {
    width: 2px;
    height: 100%;
    bottom: 0;
    left: 25%;
}

.light-streaks-bl::after {
    width: 1px;
    height: 70%;
    bottom: 5%;
    left: 40%;
}

/* --- Home page layout --- */

@media (min-width: 768px) {
    .home-grid {
        padding-left: 4vw;
    }
}

/* --- Smooth scroll --- */

html {
    scroll-behavior: smooth;
}

/* --- Checkbox/radio checked accent --- */

input[type="checkbox"]:checked,
input[type="radio"]:checked {
    accent-color: var(--accent-teal, #2DD4A8);
}

/* --- Tom Select dark theme overrides --- */

.ts-wrapper.form-input {
    padding: 0;
    border: none !important;
    background: none !important;
    height: auto;
    position: relative;
    z-index: 10;
}

.ts-wrapper.dropdown-active {
    z-index: 1000;
}

.ts-wrapper .ts-control {
    background: var(--theme-input-bg, rgba(255, 255, 255, 0.06)) !important;
    border: 1px solid var(--theme-border, rgba(255, 255, 255, 0.16)) !important;
    border-radius: var(--theme-input-radius, 10px);
    color: var(--theme-text, #E8EDEC) !important;
    font-family: var(--theme-body-font);
    font-size: 1rem;
    min-height: 3rem;
    padding: 0.5rem 1rem;
    box-shadow: none !important;
    transition: border-color 200ms ease-out, box-shadow 200ms ease-out;
    display: flex;
    align-items: center;
}

.ts-wrapper .ts-control:hover {
    border-color: rgba(255, 255, 255, 0.25);
}

.ts-wrapper.focus .ts-control {
    border-color: var(--accent-teal, #2DD4A8) !important;
    box-shadow: 0 0 0 3px rgba(45, 212, 168, 0.15) !important;
    background: var(--theme-input-bg, rgba(255, 255, 255, 0.06)) !important;
}

.ts-wrapper .ts-control,
.ts-wrapper .ts-control input,
.ts-wrapper.single.input-active .ts-control {
    background: var(--theme-input-bg, rgba(255, 255, 255, 0.06)) !important;
    color: var(--theme-text, #E8EDEC) !important;
    font-size: 1rem;
}

.ts-wrapper .ts-control input::placeholder {
    color: var(--theme-text-subtle, #5E7A75) !important;
}

/* Selected items / tags */
.ts-wrapper.multi .ts-control > .item {
    background: rgba(45, 212, 168, 0.15);
    border: 1px solid rgba(45, 212, 168, 0.3);
    color: var(--accent-teal, #2DD4A8);
    border-radius: 6px;
    padding: 0.2rem 0.5rem;
    font-size: 0.875rem;
    font-weight: 500;
    margin: 0.15rem 0.25rem 0.15rem 0;
}

.ts-wrapper.single .ts-control > .item {
    color: var(--theme-text, #E8EDEC) !important;
    background: none !important;
    border: none !important;
    margin: 0;
    padding: 0;
    max-width: 100%;
}

.ts-wrapper.single .ts-control {
    padding-right: 2rem;
}

/* Hide default caret, use cleaner one */
.ts-wrapper.single .ts-control::after {
    content: '';
    position: absolute;
    right: 1rem;
    top: 50%;
    transform: translateY(-50%);
    border: none;
    width: 0.5rem;
    height: 0.5rem;
    border-right: 2px solid var(--theme-text-subtle, #5E7A75);
    border-bottom: 2px solid var(--theme-text-subtle, #5E7A75);
    transform: translateY(-65%) rotate(45deg);
}

/* Remove button on tags */
.ts-wrapper .ts-control > .item .remove {
    color: rgba(45, 212, 168, 0.6);
    border-left: 1px solid rgba(45, 212, 168, 0.2);
    margin-left: 0.375rem;
    padding: 0 0.25rem 0 0.375rem;
}

.ts-wrapper .ts-control > .item .remove:hover {
    color: #ff6b6b;
}

/* Dropdown panel */
.ts-dropdown {
    background: #0a1412 !important;
    border: 1px solid var(--theme-border, rgba(255, 255, 255, 0.16)) !important;
    border-radius: var(--theme-input-radius, 10px) !important;
    box-shadow: 0 8px 32px rgba(0, 0, 0, 0.6) !important;
    margin-top: 4px;
    color: var(--theme-text-muted, #9BADA8);
    z-index: 10000 !important;
    position: absolute !important;
}

.ts-dropdown .option {
    background: #0a1412 !important;
}

.ts-dropdown .ts-dropdown-content {
    max-height: 240px;
    padding: 0.25rem;
}

/* Dropdown options */
.ts-dropdown .option {
    color: var(--theme-text-muted, #9BADA8);
    padding: 0.625rem 0.75rem;
    border-radius: 6px;
    font-size: 0.9rem;
    cursor: pointer;
    transition: background 100ms;
}

.ts-dropdown .option:hover,
.ts-dropdown .option.active {
    background: #122b25 !important;
    color: var(--theme-text, #E8EDEC);
}

.ts-dropdown .option.selected {
    background: #0f2019 !important;
    color: var(--accent-teal, #2DD4A8);
}

/* No results */
.ts-dropdown .no-results {
    color: var(--theme-text-subtle, #5E7A75);
    padding: 0.75rem;
    font-size: 0.875rem;
}

/* Clear button (single select) */
.ts-wrapper .clear-button {
    color: var(--theme-text-subtle, #5E7A75);
}

.ts-wrapper .clear-button:hover {
    color: #ff6b6b;
}

/* --- Mobile logo sizing --- */

@media (max-width: 639px) {
    .header-logo {
        position: static !important;
        display: block;
        height: 3.5rem !important;
        margin-bottom: 1rem;
        margin-left: auto;
    }
}

/* --- Form field spacing boost on mobile --- */

@media (max-width: 639px) {
    .form-field-wrap {
        margin-bottom: 2.25rem !important;
    }
}

/* --- Body text rendering --- */

body {
    text-rendering: optimizeLegibility;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
}

/* ============================================
   Landing prose — styles for rendered markdown
   ============================================ */

/* Use double class for specificity over Tailwind preflight reset */

.landing-prose.landing-prose h1 {
    font-family: 'Playfair Display', Georgia, serif !important;
    font-size: clamp(1.75rem, 3vw, 2.25rem) !important;
    font-weight: 600 !important;
    letter-spacing: -0.02em;
    line-height: 1.2 !important;
    color: var(--theme-text) !important;
    margin-bottom: 1.5rem !important;
}

.landing-prose.landing-prose h2 {
    font-family: 'Playfair Display', Georgia, serif !important;
    font-size: 1.35rem !important;
    font-weight: 600 !important;
    color: var(--theme-text) !important;
    margin-top: 2rem !important;
    margin-bottom: 1rem !important;
}

.landing-prose.landing-prose h3 {
    font-family: 'Playfair Display', Georgia, serif !important;
    font-size: 1.15rem !important;
    font-weight: 600 !important;
    color: var(--theme-text) !important;
    margin-top: 1.5rem !important;
    margin-bottom: 0.75rem !important;
}

.landing-prose.landing-prose p {
    font-size: 1.05rem !important;
    font-weight: 300 !important;
    line-height: 1.75 !important;
    color: var(--theme-text-muted) !important;
    margin-bottom: 1rem !important;
}

.landing-prose.landing-prose p:last-child {
    margin-bottom: 0 !important;
}

.landing-prose.landing-prose strong {
    font-weight: 500 !important;
    color: var(--theme-text) !important;
}

.landing-prose.landing-prose em {
    font-style: italic !important;
}

/* Blockquotes render as styled glass cards */
.landing-prose.landing-prose blockquote {
    background: var(--theme-blockquote-bg) !important;
    backdrop-filter: blur(12px);
    -webkit-backdrop-filter: blur(12px);
    border: 1px solid var(--theme-border) !important;
    border-left: 3px solid var(--accent-teal, #2DD4A8) !important;
    border-radius: var(--theme-radius, 16px);
    padding: 1.5rem !important;
    margin: 2rem 0 !important;
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.04);
}

.landing-prose.landing-prose blockquote p {
    font-size: 1rem !important;
    margin-bottom: 0.75rem !important;
}

.landing-prose.landing-prose blockquote p:last-child {
    margin-bottom: 0 !important;
}

/* Lists inside blockquotes */
.landing-prose.landing-prose blockquote ul {
    list-style: none !important;
    padding: 0 !important;
    margin: 0.75rem 0 !important;
}

.landing-prose.landing-prose blockquote ul li {
    position: relative;
    padding-left: 1.25rem !important;
    font-size: 1rem !important;
    font-weight: 300 !important;
    line-height: 1.75 !important;
    color: var(--theme-text-muted);
    margin-bottom: 0.5rem !important;
}

.landing-prose.landing-prose blockquote ul li::before {
    content: '';
    position: absolute;
    left: 0;
    top: 0.6rem;
    width: 6px;
    height: 6px;
    border-radius: 50%;
    background-color: var(--accent-teal, #2DD4A8);
}

/* Regular lists (outside blockquotes) */
.landing-prose.landing-prose ul,
.landing-prose.landing-prose ol {
    padding-left: 1.25rem !important;
    margin: 1rem 0 !important;
    list-style: disc !important;
}

.landing-prose.landing-prose ol {
    list-style: decimal !important;
}

.landing-prose.landing-prose li {
    font-size: 1.05rem !important;
    font-weight: 300 !important;
    line-height: 1.75 !important;
    color: var(--theme-text-muted);
    margin-bottom: 0.5rem !important;
}

/* Override list-style for blockquote lists specifically */
.landing-prose.landing-prose blockquote ul {
    list-style: none !important;
}

/* Horizontal rules */
.landing-prose.landing-prose hr {
    border: none !important;
    border-top: 1px solid var(--theme-border) !important;
    margin: 2.5rem 0 !important;
    height: 0 !important;
}
