/*
 * Gravity Projex — Theme Stylesheet
 * PROPRIETARY SOFTWARE LICENSE — GRAVITY PROJEX
 * Copyright (c) 2026 Gravity Projex. All Rights Reserved.
 * Contact: admin@gravityprojex.com | https://gravityprojex.com
 */

/* ========================================
   CSS CUSTOM PROPERTIES
   ======================================== */

:root {
    --gp-coral:       #ff6b6b;
    --gp-coral-light: #ff8a8a;
    --gp-coral-dark:  #e55a5a;
    --gp-navy:        #0d1b2a;
}


/* ========================================
   BASE / RESET
   ======================================== */

html {
    scroll-behavior: smooth;
    margin-top: 0 !important;
}

body {
    margin: 0;
    padding: 0;
    color: #ffffff;
    font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif;
    background-color: var(--gp-navy) !important;
}

body #page {
    background-color: var(--gp-navy) !important;
}

/* Grain Texture Overlay */
body::after {
    content: '';
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    pointer-events: none;
    z-index: 9999;
    opacity: 0.035;
    background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
    mix-blend-mode: overlay;
}


/* ========================================
   ACCESSIBILITY UTILITIES
   ======================================== */

.sr-only {
    position: absolute;
    width: 1px;
    height: 1px;
    padding: 0;
    margin: -1px;
    overflow: hidden;
    clip: rect(0, 0, 0, 0);
    white-space: nowrap;
    border-width: 0;
}

.focus\:not-sr-only:focus {
    position: absolute;
    width: auto;
    height: auto;
    padding: 0;
    margin: 0;
    overflow: visible;
    clip: auto;
    white-space: normal;
}


/* ========================================
   HEADINGS — Syne Font + Coral
   ======================================== */

h1, h2, h3,
.text-4xl, .text-5xl, .text-6xl, .text-7xl {
    font-family: 'Syne', -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif !important;
}

/* Coral headings: see full .gp-prose block below with !important overrides */

h1.text-white,
h2.text-white,
h3.text-white,
[class*="bg-clip-text"] {
    color: inherit !important;
}


/* ========================================
   CTA BUTTONS — Coral Gradient
   ======================================== */

a.bg-gradient-to-r.from-violet-600.to-cyan-500,
a.bg-gradient-to-r.from-violet-500.to-cyan-400,
a[class*="from-violet-600"][class*="to-cyan-500"],
a[class*="from-violet-500"][class*="to-cyan-400"],
button[class*="from-violet-600"][class*="to-cyan-500"],
.gp-btn-coral {
    background: linear-gradient(135deg, var(--gp-coral) 0%, var(--gp-coral-light) 100%) !important;
    box-shadow: 0 10px 40px -10px rgba(255, 107, 107, 0.4) !important;
}

a.bg-gradient-to-r.from-violet-600.to-cyan-500:hover,
a.bg-gradient-to-r.from-violet-500.to-cyan-400:hover,
a[class*="from-violet-600"][class*="to-cyan-500"]:hover,
a[class*="from-violet-500"][class*="to-cyan-400"]:hover,
button[class*="from-violet-600"][class*="to-cyan-500"]:hover,
.gp-btn-coral:hover {
    background: linear-gradient(135deg, var(--gp-coral-light) 0%, var(--gp-coral) 100%) !important;
    box-shadow: 0 15px 50px -10px rgba(255, 107, 107, 0.5) !important;
    transform: translateY(-2px);
}

.bg-gradient-to-br.from-violet-500.to-cyan-500,
.bg-gradient-to-br.from-violet-600.to-cyan-500,
div[class*="from-violet-500"][class*="to-cyan-500"]:not(nav *):not(#main-navigation *):not(a *) {
    background: linear-gradient(135deg, var(--gp-coral) 0%, var(--gp-coral-light) 100%) !important;
}

.shadow-violet-500\/30,
.shadow-violet-500\/40 {
    box-shadow: 0 10px 40px -10px rgba(255, 107, 107, 0.4) !important;
}


/* ========================================
   CUSTOM SCROLLBAR
   ======================================== */

::-webkit-scrollbar { width: 8px; }
::-webkit-scrollbar-track { background: var(--gp-navy); }
::-webkit-scrollbar-thumb { background: #334155; border-radius: 4px; }
::-webkit-scrollbar-thumb:hover { background: #475569; }


/* ========================================
   SELECTION & FOCUS
   ======================================== */

::selection { background-color: rgba(255, 107, 107, 0.3); color: #ffffff; }
::-moz-selection { background-color: rgba(255, 107, 107, 0.3); color: #ffffff; }

a:focus, button:focus, input:focus, textarea:focus, select:focus {
    outline: 2px solid var(--gp-coral);
    outline-offset: 2px;
}


/* ========================================
   WORDPRESS ADMIN BAR OFFSET
   ======================================== */

.admin-bar #main-navigation { top: 32px; }
.admin-bar #mobile-menu { top: 112px; }

@media screen and (max-width: 782px) {
    .admin-bar #main-navigation { top: 46px; }
    .admin-bar #mobile-menu { top: 126px; }
}


/* ========================================
   WORDPRESS BLOCK OVERRIDES
   ======================================== */

.wp-block-image img { border-radius: 0.5rem; }
.alignleft { float: left; margin-right: 1.5rem; margin-bottom: 1rem; }
.alignright { float: right; margin-left: 1.5rem; margin-bottom: 1rem; }
.aligncenter { display: block; margin-left: auto; margin-right: auto; }


/* ========================================
   UTILITY CLASSES
   ======================================== */

.line-clamp-2 { display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden; }
.line-clamp-3 { display: -webkit-box; -webkit-line-clamp: 3; -webkit-box-orient: vertical; overflow: hidden; }

.services-wrapper { width: 100%; max-width: 100vw; margin-left: calc(-50vw + 50%); margin-right: calc(-50vw + 50%); }

.cta-wrapper * { box-sizing: border-box; }
.cta-wrapper h2, .cta-wrapper p, .cta-wrapper a { margin: 0; padding: 0; text-decoration: none; }


/* ========================================
   ANIMATIONS — Float / Pulse
   ======================================== */

@keyframes float { 0%, 100% { transform: translate(0, 0); } 50% { transform: translate(50px, 30px); } }
@keyframes float-slow { 0%, 100% { transform: translate(0, 0); } 50% { transform: translate(-30px, 50px); } }
@keyframes pulse-slow { 0%, 100% { transform: translate(-50%, -50%) scale(1); } 50% { transform: translate(-50%, -50%) scale(1.2); } }

.animate-float { animation: float 20s ease-in-out infinite; }
.animate-float-slow { animation: float-slow 15s ease-in-out infinite; }
.animate-pulse-slow { animation: pulse-slow 10s ease-in-out infinite; }


/* ========================================
   ANIMATIONS — Fade In
   ======================================== */

@keyframes fadeIn { from { opacity: 0; } to { opacity: 1; } }
@keyframes fadeInUp { from { opacity: 0; transform: translateY(30px); } to { opacity: 1; transform: translateY(0); } }

.fade-in { animation: fadeIn 0.6s ease-out forwards; }
.fade-in-up { animation: fadeInUp 0.8s ease-out forwards; }
.animate-fade-in { animation: fadeIn 0.4s ease forwards; }

.animation-delay-200 { animation-delay: 0.2s; opacity: 0; animation-fill-mode: forwards; }
.animation-delay-400 { animation-delay: 0.4s; opacity: 0; animation-fill-mode: forwards; }
.animation-delay-600 { animation-delay: 0.6s; opacity: 0; animation-fill-mode: forwards; }


/* ========================================
   ANIMATIONS — Spin
   ======================================== */

@keyframes spin-slow { from { transform: rotate(0deg); } to { transform: rotate(360deg); } }
@keyframes spin-reverse { from { transform: rotate(360deg); } to { transform: rotate(0deg); } }

.animate-spin-slow { animation: spin-slow 60s linear infinite; }
.animate-spin-reverse { animation: spin-reverse 45s linear infinite; }


/* ========================================
   ANIMATIONS — Rocket
   ======================================== */

@keyframes rocketPulse { 0%, 100% { transform: translateY(0); } 50% { transform: translateY(-8px); } }
.animate-rocket { animation: rocketPulse 3s ease-in-out infinite; }


/* ========================================
   SCROLL REVEAL — Intersection Observer
   ======================================== */

.gp-reveal {
    opacity: 0;
    transform: translateY(40px);
    transition: opacity 0.7s cubic-bezier(0.16, 1, 0.3, 1), transform 0.7s cubic-bezier(0.16, 1, 0.3, 1);
    will-change: opacity, transform;
}

.gp-reveal.gp-reveal--left {
    transform: translateX(-50px);
}

.gp-reveal.gp-reveal--right {
    transform: translateX(50px);
}

.gp-reveal.gp-reveal--scale {
    transform: scale(0.92) translateY(20px);
}

.gp-reveal.is-visible {
    opacity: 1;
    transform: translateY(0) translateX(0) scale(1);
}

/* Staggered children — parent gets .gp-stagger, children get .gp-stagger-child */
.gp-stagger .gp-stagger-child {
    opacity: 0;
    transform: translateY(30px);
    transition: opacity 0.6s cubic-bezier(0.16, 1, 0.3, 1), transform 0.6s cubic-bezier(0.16, 1, 0.3, 1);
    will-change: opacity, transform;
}

.gp-stagger.is-visible .gp-stagger-child:nth-child(1)  { opacity: 1; transform: none; transition-delay: 0.05s; }
.gp-stagger.is-visible .gp-stagger-child:nth-child(2)  { opacity: 1; transform: none; transition-delay: 0.12s; }
.gp-stagger.is-visible .gp-stagger-child:nth-child(3)  { opacity: 1; transform: none; transition-delay: 0.19s; }
.gp-stagger.is-visible .gp-stagger-child:nth-child(4)  { opacity: 1; transform: none; transition-delay: 0.26s; }
.gp-stagger.is-visible .gp-stagger-child:nth-child(5)  { opacity: 1; transform: none; transition-delay: 0.33s; }
.gp-stagger.is-visible .gp-stagger-child:nth-child(6)  { opacity: 1; transform: none; transition-delay: 0.40s; }
.gp-stagger.is-visible .gp-stagger-child:nth-child(7)  { opacity: 1; transform: none; transition-delay: 0.47s; }
.gp-stagger.is-visible .gp-stagger-child:nth-child(8)  { opacity: 1; transform: none; transition-delay: 0.54s; }
.gp-stagger.is-visible .gp-stagger-child:nth-child(9)  { opacity: 1; transform: none; transition-delay: 0.61s; }
.gp-stagger.is-visible .gp-stagger-child:nth-child(10) { opacity: 1; transform: none; transition-delay: 0.68s; }
.gp-stagger.is-visible .gp-stagger-child:nth-child(n+11) { opacity: 1; transform: none; transition-delay: 0.75s; }

/* Safety net — any child of a visible stagger parent becomes visible.
   nth-child rules above provide timed delays; this catches any overflow. */
.gp-stagger.is-visible .gp-stagger-child { opacity: 1; transform: none; }

/* Line reveal — horizontal ink-draw effect */
.gp-line-reveal {
    position: relative;
    overflow: hidden;
}

.gp-line-reveal::after {
    content: '';
    position: absolute;
    bottom: 0;
    left: 0;
    width: 0;
    height: 2px;
    background: var(--gp-coral);
    transition: width 0.8s cubic-bezier(0.16, 1, 0.3, 1);
    transition-delay: 0.4s;
}

.gp-line-reveal.is-visible::after {
    width: 100%;
}

/* Counter animation — numbers count up on scroll */
.gp-counter {
    display: inline-block;
    transition: all 0.1s linear;
}

/* Respect reduced motion */
@media (prefers-reduced-motion: reduce) {
    .gp-reveal,
    .gp-stagger .gp-stagger-child {
        opacity: 1 !important;
        transform: none !important;
        transition: none !important;
    }
    .gp-line-reveal::after {
        width: 100% !important;
        transition: none !important;
    }
}


/* ========================================
   FORM STYLES
   ======================================== */

.form-input, .form-textarea, .form-select {
    width: 100%;
    padding: 0.875rem 1rem;
    background: rgba(15, 23, 42, 0.8);
    border: 1px solid rgba(255, 255, 255, 0.1);
    border-radius: 0.75rem;
    color: #ffffff;
    font-size: 1rem;
    font-family: inherit;
    transition: all 0.2s ease;
}

.form-input:focus, .form-textarea:focus, .form-select:focus {
    outline: none;
    border-color: var(--gp-coral);
    box-shadow: 0 0 0 3px rgba(255, 107, 107, 0.2);
}

.form-input::placeholder, .form-textarea::placeholder { color: #64748b; }

.form-select {
    appearance: none;
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='24' height='24' viewBox='0 0 24 24' fill='none' stroke='%2394a3b8' stroke-width='2'%3E%3Cpath d='m6 9 6 6 6-6'/%3E%3C/svg%3E");
    background-repeat: no-repeat;
    background-position: right 0.75rem center;
    background-size: 1.25rem;
    padding-right: 2.5rem;
}

.form-select option { background: var(--gp-navy); color: #ffffff; }


/* ========================================
   PROSE TYPOGRAPHY (Blog / Single Post)
   ======================================== */

.gp-prose h1,
.gp-prose h2,
.gp-prose h3,
.gp-prose .wp-block-heading {
    color: var(--gp-coral) !important;
}

/* ---- Block element display fixes (Gutenberg strips default display) ---- */
.gp-prose p,
.gp-prose h1,
.gp-prose h2,
.gp-prose h3,
.gp-prose h4,
.gp-prose ul,
.gp-prose ol,
.gp-prose blockquote,
.gp-prose pre,
.gp-prose figure,
.gp-prose .wp-block-heading,
.gp-prose .wp-block-paragraph,
.gp-prose .wp-block-list,
.gp-prose .wp-block-quote,
.gp-prose .wp-block-preformatted,
.gp-prose .wp-block-image {
    display: block !important;
}

.gp-prose h1 {
    font-family: 'Syne', -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif !important;
    font-size: 2.25rem !important;
    font-weight: 800 !important;
    margin-top: 2.5rem !important;
    margin-bottom: 1rem !important;
    color: var(--gp-coral) !important;
    line-height: 1.3 !important;
}
.gp-prose h2,
.gp-prose .wp-block-heading {
    font-family: 'Syne', -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif !important;
    font-size: 1.875rem !important;
    font-weight: 700 !important;
    margin-top: 2.5rem !important;
    margin-bottom: 1rem !important;
    color: var(--gp-coral) !important;
    line-height: 1.3 !important;
}
.gp-prose h3 {
    font-family: 'Syne', -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif !important;
    font-size: 1.5rem !important;
    font-weight: 600 !important;
    margin-top: 2rem !important;
    margin-bottom: 0.75rem !important;
    color: #cbd5e1 !important;
    line-height: 1.4 !important;
}
.gp-prose h4 {
    font-size: 1.25rem !important;
    font-weight: 600 !important;
    margin-top: 1.5rem !important;
    margin-bottom: 0.5rem !important;
    color: #cbd5e1 !important;
}
.gp-prose p,
.gp-prose .wp-block-paragraph {
    margin-bottom: 1.25rem !important;
    margin-top: 0 !important;
    color: #94a3b8 !important;
    line-height: 1.8 !important;
    font-size: 1.0625rem !important;
}
.gp-prose ul,
.gp-prose ol,
.gp-prose .wp-block-list {
    margin-bottom: 1.25rem !important;
    margin-top: 0 !important;
    padding-left: 1.5rem !important;
}
.gp-prose ul,
.gp-prose .wp-block-list:not(ol) { list-style-type: disc !important; }
.gp-prose ol { list-style-type: decimal !important; }
.gp-prose li { margin-bottom: 0.75rem !important; color: #94a3b8 !important; line-height: 1.7 !important; }
.gp-prose li::marker { color: var(--gp-coral) !important; }
.gp-prose strong, .gp-prose b { color: #e2e8f0 !important; font-weight: 600 !important; }
.gp-prose em, .gp-prose i { color: #cbd5e1 !important; }
.gp-prose a { color: var(--gp-coral) !important; text-decoration: underline !important; text-decoration-color: rgba(255, 107, 107, 0.3) !important; transition: all 0.2s; }
.gp-prose a:hover { color: var(--gp-coral-light) !important; text-decoration-color: rgba(255, 107, 107, 0.6) !important; }
.gp-prose blockquote,
.gp-prose .wp-block-quote {
    border-left: 4px solid var(--gp-coral) !important;
    padding-left: 1.5rem !important;
    margin: 2rem 0 !important;
    font-style: italic !important;
    color: #cbd5e1 !important;
}
.gp-prose blockquote p,
.gp-prose .wp-block-quote p { color: #cbd5e1 !important; }
.gp-prose pre,
.gp-prose .wp-block-preformatted {
    background: #0f172a !important;
    border: 1px solid rgba(255,255,255,0.1) !important;
    border-radius: 0.75rem !important;
    padding: 1.5rem !important;
    overflow-x: auto !important;
    margin: 1.5rem 0 !important;
    white-space: pre !important;
}
.gp-prose code { background: rgba(255, 107, 107, 0.15) !important; color: #ffb4b4 !important; padding: 0.15rem 0.4rem !important; border-radius: 0.25rem !important; font-size: 0.9em !important; }
.gp-prose pre code { background: transparent !important; color: #e2e8f0 !important; padding: 0 !important; }
.gp-prose img { max-width: 100% !important; height: auto !important; border-radius: 1rem !important; margin: 2rem 0 !important; }
.gp-prose figure { margin: 2rem 0 !important; }
.gp-prose figcaption { text-align: center !important; color: #64748b !important; font-size: 0.875rem !important; margin-top: 0.75rem !important; }
.gp-prose table { width: 100% !important; border-collapse: collapse !important; margin: 1.5rem 0 !important; }
.gp-prose th { background: rgba(255, 107, 107, 0.1) !important; color: #e2e8f0 !important; padding: 0.75rem 1rem !important; text-align: left !important; border-bottom: 2px solid rgba(255,255,255,0.1) !important; }
.gp-prose td { padding: 0.75rem 1rem !important; color: #94a3b8 !important; border-bottom: 1px solid rgba(255,255,255,0.05) !important; }
.gp-prose hr { border: none !important; border-top: 1px solid rgba(255,255,255,0.1) !important; margin: 2.5rem 0 !important; }
.gp-prose .wp-block-image { margin: 2rem 0 !important; }
.gp-prose .wp-block-image img { border-radius: 1rem !important; }
.gp-prose .wp-block-quote { border-left: 4px solid var(--gp-coral) !important; padding-left: 1.5rem !important; margin: 2rem 0 !important; }

/* Gutenberg separator block */
.gp-prose .wp-block-separator {
    border: none !important;
    border-top: 1px solid rgba(255,255,255,0.1) !important;
    margin: 2.5rem 0 !important;
}

/* Gutenberg cover/group blocks */
.gp-prose .wp-block-group {
    margin-bottom: 1.5rem !important;
}

/* Numbered list items from Gutenberg */
.gp-prose .wp-block-list li {
    margin-bottom: 0.75rem !important;
    color: #94a3b8 !important;
    line-height: 1.7 !important;
}


/* ========================================
   BLOG — Reading progress bar
   ======================================== */

#gp-reading-progress {
    position: fixed;
    top: 0;
    left: 0;
    width: 0%;
    height: 3px;
    background: linear-gradient(90deg, var(--gp-coral), var(--gp-coral-light));
    z-index: 9998;
    transition: width 0.1s linear;
}


/* ========================================
   GALAXY PAGE — Starfield Background
   ======================================== */

.galaxy-bg { position: relative; overflow: hidden; }

.galaxy-bg::before {
    content: '';
    position: absolute;
    inset: 0;
    background-image:
        radial-gradient(1px 1px at 10% 20%, rgba(255,255,255,0.4) 0%, transparent 100%),
        radial-gradient(1px 1px at 30% 60%, rgba(255,255,255,0.3) 0%, transparent 100%),
        radial-gradient(1px 1px at 50% 10%, rgba(255,255,255,0.5) 0%, transparent 100%),
        radial-gradient(1px 1px at 70% 80%, rgba(255,255,255,0.3) 0%, transparent 100%),
        radial-gradient(1px 1px at 90% 40%, rgba(255,255,255,0.4) 0%, transparent 100%),
        radial-gradient(1.5px 1.5px at 15% 75%, rgba(139,92,246,0.6) 0%, transparent 100%),
        radial-gradient(1.5px 1.5px at 85% 25%, rgba(6,182,212,0.6) 0%, transparent 100%),
        radial-gradient(1px 1px at 25% 45%, rgba(255,255,255,0.2) 0%, transparent 100%),
        radial-gradient(1px 1px at 60% 35%, rgba(255,255,255,0.3) 0%, transparent 100%),
        radial-gradient(1px 1px at 45% 90%, rgba(255,255,255,0.2) 0%, transparent 100%),
        radial-gradient(1px 1px at 80% 15%, rgba(255,255,255,0.4) 0%, transparent 100%),
        radial-gradient(1px 1px at 5% 55%, rgba(255,255,255,0.3) 0%, transparent 100%);
    pointer-events: none;
    z-index: 0;
}


/* ========================================
   FAQ ACCORDION
   ======================================== */

.faq-answer {
    max-height: 0;
    overflow: hidden;
    transition: max-height 0.3s ease, opacity 0.3s ease;
    opacity: 0;
}

.faq-item.active .faq-answer { max-height: 500px; opacity: 1; }
.faq-item .chevron { transition: transform 0.3s ease; }
.faq-item.active .chevron { transform: rotate(180deg); }


/* ========================================
   PORTFOLIO PAGE
   ======================================== */

@keyframes portfolioFadeIn {
    from { opacity: 0; transform: translateY(10px); }
    to { opacity: 1; transform: translateY(0); }
}

.portfolio-card { animation: portfolioFadeIn 0.4s ease forwards; }


/* ========================================
   UNDERLINE LINK
   ======================================== */

.underline-link {
    color: var(--gp-coral);
    text-decoration: none;
    font-weight: 600;
    font-size: inherit;
    display: inline-flex;
    align-items: center;
    gap: 0.5rem;
    position: relative;
    padding-bottom: 2px;
    transition: gap 0.3s ease;
}

.underline-link::after {
    content: '';
    position: absolute;
    bottom: 0;
    left: 0;
    width: 0;
    height: 2px;
    background: var(--gp-coral);
    transition: width 0.3s cubic-bezier(0.4, 0, 0.2, 1);
}

.underline-link:hover::after { width: 100%; }
.underline-link:hover { gap: 0.75rem; }
.underline-link .arrow { transition: transform 0.3s ease; display: inline-block; }
.underline-link:hover .arrow { transform: translateX(4px); }


/* ========================================
   REDUCED MOTION
   ======================================== */

@media (prefers-reduced-motion: reduce) {
    *, *::before, *::after {
        animation-duration: 0.001ms !important;
        animation-iteration-count: 1 !important;
        transition-duration: 0.001ms !important;
    }
}


/* ========================================
   PRINT STYLES
   ======================================== */

@media print {
    nav, footer, .no-print { display: none !important; }
}