/*
Theme Name:   nakopneme Child
Theme URI:    https://nakopneme.sk
Description:  Hello Elementor Child Theme pre nakopneme creative agency
Author:       nakopneme creative agency
Author URI:   https://nakopneme.sk
Template:     hello-elementor
Version:      1.0.0
Text Domain:  nakopneme-child
*/

/* ═══════════════════════════════════════════
   NAKOPNEME — GLOBÁLNE CSS PREMENNÉ
═══════════════════════════════════════════ */
:root {
  --nk-purple-dark:    #3C235F;
  --nk-purple-mid:     #6923AF;
  --nk-orange:         #FF7300;
  --nk-yellow:         #FFE600;
  --nk-light-purple:   #F4F0FA;
  --nk-text-primary:   #1A1A2E;
  --nk-text-secondary: #666666;
  --nk-border:         #E0D6F0;
  --nk-white:          #ffffff;
  --nk-grad:           linear-gradient(135deg, #FF7300, #FFE600);
  --nk-grad-purple:    linear-gradient(135deg, #3C235F, #6923AF);
  --nk-shadow:         0 8px 32px rgba(60, 35, 95, 0.12);
  --nk-shadow-hover:   0 20px 60px rgba(60, 35, 95, 0.18);
  --nk-radius:         20px;
  --nk-radius-sm:      12px;
  --nk-radius-pill:    50px;
}

/* ═══════════════════════════════════════════
   TYPOGRAFIA — POPPINS
═══════════════════════════════════════════ */
body,
body * {
  font-family: 'Poppins', sans-serif !important;
}

h1, h2, h3, h4, h5, h6 {
  font-family: 'Poppins', sans-serif !important;
  color: var(--nk-purple-dark);
  line-height: 1.15;
}

h1 { font-size: 64px; font-weight: 800; }
h2 { font-size: 42px; font-weight: 700; }
h3 { font-size: 26px; font-weight: 600; }

p {
  font-size: 16px;
  line-height: 1.75;
  color: var(--nk-text-secondary);
}

@media (max-width: 768px) {
  h1 { font-size: 38px; }
  h2 { font-size: 28px; }
  h3 { font-size: 20px; }
}

/* ═══════════════════════════════════════════
   GLOBÁLNE FARBY — ELEMENTOR OVERRIDE
═══════════════════════════════════════════ */
.elementor-section {
  position: relative;
}

/* Pozadie sekcií */
.nk-bg-dark     { background: var(--nk-purple-dark) !important; }
.nk-bg-light    { background: var(--nk-light-purple) !important; }
.nk-bg-grad     { background: var(--nk-grad-purple) !important; }
.nk-bg-orange   { background: var(--nk-orange) !important; }
.nk-text-white  * { color: #fff !important; }

/* ═══════════════════════════════════════════
   NAVBAR / HEADER
═══════════════════════════════════════════ */
.elementor-location-header {
  background: var(--nk-white);
  border-bottom: 1px solid var(--nk-border);
  box-shadow: 0 2px 20px rgba(60, 35, 95, 0.06);
  position: sticky;
  top: 0;
  z-index: 999;
  transition: box-shadow 0.3s ease;
}

.elementor-location-header.scrolled {
  box-shadow: 0 4px 30px rgba(60, 35, 95, 0.14);
}

/* Nav links */
.elementor-nav-menu a {
  font-size: 14px !important;
  font-weight: 500 !important;
  color: var(--nk-text-secondary) !important;
  transition: color 0.2s ease !important;
}

.elementor-nav-menu a:hover,
.elementor-nav-menu .current > a {
  color: var(--nk-purple-mid) !important;
}

/* ═══════════════════════════════════════════
   HERO SEKCIA — PARTICLES
═══════════════════════════════════════════ */
.nk-hero {
  position: relative;
  min-height: 90vh;
  display: flex;
  align-items: center;
  background: var(--nk-purple-dark);
  overflow: hidden;
}

#nk-particle-canvas {
  position: absolute;
  top: 0; left: 0;
  width: 100%;
  height: 100%;
  z-index: 0;
  pointer-events: none;
}

.nk-hero-overlay {
  position: absolute;
  inset: 0;
  background: radial-gradient(ellipse at 65% 50%, rgba(105,35,175,0.5) 0%, transparent 70%);
  z-index: 1;
  pointer-events: none;
}

.nk-hero .elementor-container {
  position: relative;
  z-index: 2;
}

/* Hero nadpis */
.nk-hero-title {
  font-size: 64px !important;
  font-weight: 800 !important;
  color: #fff !important;
  line-height: 1.08 !important;
}

.nk-hero-title .nk-gradient-text {
  background: var(--nk-grad);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
}

/* Typewriter wrapper */
.nk-typewriter-wrap {
  display: inline-block;
}

#nk-typewriter {
  border-right: 3px solid var(--nk-orange);
  padding-right: 4px;
  animation: nk-blink 0.75s step-end infinite;
}

@keyframes nk-blink {
  0%, 100% { border-color: var(--nk-orange); }
  50%       { border-color: transparent; }
}

/* Hero pulse dot */
.nk-pulse-dot {
  display: inline-block;
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: var(--nk-orange);
  animation: nk-pulse 2s infinite;
}

@keyframes nk-pulse {
  0%, 100% { opacity: 1; transform: scale(1); }
  50%       { opacity: 0.6; transform: scale(1.4); }
}

/* ═══════════════════════════════════════════
   TLAČIDLÁ / BUTTONS
═══════════════════════════════════════════ */
.elementor-button {
  font-family: 'Poppins', sans-serif !important;
  font-weight: 600 !important;
  border-radius: var(--nk-radius-pill) !important;
  transition: all 0.25s ease !important;
  letter-spacing: 0 !important;
}

/* Primárne — fialové */
.elementor-button.nk-btn-primary,
.elementor-button-wrapper .elementor-button {
  background: var(--nk-purple-mid) !important;
  color: #fff !important;
  border: none !important;
}

.elementor-button.nk-btn-primary:hover,
.elementor-button-wrapper .elementor-button:hover {
  background: var(--nk-purple-dark) !important;
  transform: translateY(-3px) !important;
  box-shadow: 0 8px 24px rgba(105, 35, 175, 0.35) !important;
}

/* Oranžové */
.elementor-button.nk-btn-orange {
  background: var(--nk-orange) !important;
  color: #fff !important;
}

.elementor-button.nk-btn-orange:hover {
  background: #e06600 !important;
  transform: translateY(-3px) !important;
  box-shadow: 0 8px 24px rgba(255, 115, 0, 0.35) !important;
}

/* Ghost — transparentné */
.elementor-button.nk-btn-ghost {
  background: transparent !important;
  color: #fff !important;
  border: 2px solid rgba(255,255,255,0.5) !important;
}

.elementor-button.nk-btn-ghost:hover {
  border-color: #fff !important;
  background: rgba(255,255,255,0.1) !important;
}

/* Biele (na gradiente) */
.elementor-button.nk-btn-white {
  background: #fff !important;
  color: var(--nk-purple-dark) !important;
}

.elementor-button.nk-btn-white:hover {
  transform: translateY(-3px) !important;
  box-shadow: 0 8px 24px rgba(255,255,255,0.3) !important;
}

/* ═══════════════════════════════════════════
   KARTY / CARDS
═══════════════════════════════════════════ */
.nk-card {
  background: var(--nk-white);
  border-radius: var(--nk-radius) !important;
  border: 1px solid var(--nk-border) !important;
  transition: all 0.25s ease !important;
  padding: 36px !important;
}

.nk-card:hover {
  border-color: var(--nk-purple-mid) !important;
  box-shadow: var(--nk-shadow-hover) !important;
  transform: translateY(-6px) !important;
}

/* Icon Box */
.elementor-icon-box-wrapper.nk-card {
  border-radius: var(--nk-radius) !important;
  border: 1px solid var(--nk-border) !important;
  transition: all 0.25s ease !important;
}

.elementor-icon-box-wrapper.nk-card:hover {
  border-color: var(--nk-purple-mid) !important;
  box-shadow: var(--nk-shadow-hover) !important;
  transform: translateY(-6px) !important;
}

/* Card ikona — gradient */
.nk-card .elementor-icon {
  background: var(--nk-grad);
  border-radius: 14px !important;
  width: 56px !important;
  height: 56px !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  margin-bottom: 20px !important;
}

.nk-card .elementor-icon i {
  color: #fff !important;
  font-size: 24px !important;
}

/* Tmavé karty (na fialovom pozadí) */
.nk-card-dark {
  background: rgba(255,255,255,0.06) !important;
  border: 1px solid rgba(255,255,255,0.12) !important;
  border-radius: var(--nk-radius) !important;
  transition: all 0.25s ease !important;
}

.nk-card-dark:hover {
  background: rgba(255,255,255,0.1) !important;
  border-color: rgba(255,255,255,0.3) !important;
}

.nk-card-dark h3,
.nk-card-dark .elementor-icon-box-title {
  color: #fff !important;
}

.nk-card-dark p,
.nk-card-dark .elementor-icon-box-description {
  color: rgba(255,255,255,0.7) !important;
}

/* ═══════════════════════════════════════════
   TEAM MEMBER KARTY
═══════════════════════════════════════════ */
.nk-team-card {
  text-align: center;
  border-radius: var(--nk-radius) !important;
  border: 1px solid var(--nk-border) !important;
  padding: 40px 28px !important;
  background: #fff;
  transition: all 0.25s ease !important;
}

.nk-team-card:hover {
  border-color: var(--nk-purple-mid) !important;
  box-shadow: var(--nk-shadow-hover) !important;
  transform: translateY(-6px) !important;
}

.nk-team-card .elementor-image-box-img img {
  border-radius: 50% !important;
  border: 3px solid var(--nk-border) !important;
  width: 100px !important;
  height: 100px !important;
  object-fit: cover !important;
}

.nk-team-card .elementor-image-box-title {
  font-size: 18px !important;
  font-weight: 700 !important;
  color: var(--nk-purple-dark) !important;
}

.nk-team-card .nk-team-role {
  font-size: 13px !important;
  font-weight: 600 !important;
  color: var(--nk-orange) !important;
  display: block;
  margin: 4px 0 12px;
}

/* ═══════════════════════════════════════════
   LOGO BAR — KLIENTI
═══════════════════════════════════════════ */
.nk-logo-item img {
  filter: grayscale(100%) opacity(0.5);
  transition: filter 0.3s ease;
  max-height: 60px;
  width: auto;
}

.nk-logo-item:hover img {
  filter: grayscale(0%) opacity(1);
}

/* ═══════════════════════════════════════════
   TESTIMONIAL
═══════════════════════════════════════════ */
.nk-testimonial {
  background: var(--nk-white);
  border-radius: var(--nk-radius) !important;
  border: 1px solid var(--nk-border) !important;
  padding: 36px !important;
  position: relative;
}

.nk-testimonial::before {
  content: '"';
  position: absolute;
  top: 16px; right: 24px;
  font-size: 80px;
  color: var(--nk-border);
  font-family: serif;
  line-height: 1;
}

.elementor-testimonial-content {
  font-style: italic;
  font-size: 16px;
  line-height: 1.7;
  color: var(--nk-text-primary) !important;
}

.elementor-testimonial-name {
  font-weight: 600 !important;
  color: var(--nk-purple-dark) !important;
}

.elementor-testimonial-job {
  color: var(--nk-text-secondary) !important;
  font-size: 12px !important;
}

/* ═══════════════════════════════════════════
   CTA BANNER
═══════════════════════════════════════════ */
.nk-cta-banner {
  background: var(--nk-grad) !important;
  border-radius: 28px !important;
  padding: 80px !important;
  position: relative;
  overflow: hidden;
}

.nk-cta-banner::before {
  content: '';
  position: absolute;
  top: -40px; right: -40px;
  width: 300px; height: 300px;
  border-radius: 50%;
  background: rgba(255,255,255,0.08);
  pointer-events: none;
}

.nk-cta-banner h2 {
  color: #fff !important;
  font-size: 44px !important;
}

.nk-cta-banner p {
  color: rgba(255,255,255,0.85) !important;
  font-size: 18px !important;
}

/* ═══════════════════════════════════════════
   PORTFÓLIO — KLIENTSKÉ KARTY
═══════════════════════════════════════════ */
.nk-portfolio-card {
  border-radius: var(--nk-radius) !important;
  border: 1px solid var(--nk-border) !important;
  overflow: hidden;
  transition: all 0.3s ease !important;
  cursor: pointer;
  display: block;
  text-decoration: none;
  color: inherit;
}

.nk-portfolio-card:hover {
  transform: translateY(-8px) !important;
  box-shadow: var(--nk-shadow-hover) !important;
  border-color: var(--nk-purple-mid) !important;
}

.nk-portfolio-thumb {
  height: 220px;
  display: flex;
  align-items: center;
  justify-content: center;
  position: relative;
  overflow: hidden;
  font-size: 48px;
}

.nk-portfolio-thumb .nk-overlay {
  position: absolute;
  inset: 0;
  background: var(--nk-grad-purple);
  opacity: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  color: #fff;
  font-size: 15px;
  font-weight: 600;
  transition: opacity 0.25s ease;
}

.nk-portfolio-card:hover .nk-overlay {
  opacity: 0.92;
}

/* Klientská stránka — full overlay */
.nk-client-page {
  display: none;
  position: fixed;
  inset: 0;
  z-index: 9999;
  background: #fff;
  overflow-y: auto;
}

.nk-client-page.nk-open {
  display: block;
  animation: nk-slide-in 0.35s ease;
}

@keyframes nk-slide-in {
  from { opacity: 0; transform: translateY(30px); }
  to   { opacity: 1; transform: none; }
}

/* ═══════════════════════════════════════════
   FADE IN ANIMÁCIE — scroll triggered
═══════════════════════════════════════════ */
.nk-fade-up {
  opacity: 0;
  transform: translateY(30px);
  transition: opacity 0.7s ease, transform 0.7s ease;
}

.nk-fade-up.nk-visible {
  opacity: 1;
  transform: none;
}

.nk-fade-up-delay-1 { transition-delay: 0.1s; }
.nk-fade-up-delay-2 { transition-delay: 0.2s; }
.nk-fade-up-delay-3 { transition-delay: 0.3s; }
.nk-fade-up-delay-4 { transition-delay: 0.4s; }

/* ═══════════════════════════════════════════
   KONTAKTNÝ FORMULÁR
═══════════════════════════════════════════ */
.wpcf7-form input[type="text"],
.wpcf7-form input[type="email"],
.wpcf7-form input[type="tel"],
.wpcf7-form select,
.wpcf7-form textarea {
  width: 100%;
  padding: 14px 18px;
  border: 1.5px solid var(--nk-border);
  border-radius: var(--nk-radius-sm);
  font-size: 15px;
  font-family: 'Poppins', sans-serif;
  color: var(--nk-text-primary);
  background: #fff;
  transition: border-color 0.2s ease;
  margin-bottom: 16px;
}

.wpcf7-form input:focus,
.wpcf7-form select:focus,
.wpcf7-form textarea:focus {
  outline: none;
  border-color: var(--nk-purple-mid);
  box-shadow: 0 0 0 3px rgba(105,35,175,0.1);
}

.wpcf7-form input[type="submit"] {
  background: var(--nk-purple-mid);
  color: #fff;
  border: none;
  border-radius: var(--nk-radius-pill);
  padding: 16px 40px;
  font-size: 16px;
  font-weight: 600;
  cursor: pointer;
  width: 100%;
  transition: all 0.25s ease;
}

.wpcf7-form input[type="submit"]:hover {
  background: var(--nk-purple-dark);
  transform: translateY(-2px);
  box-shadow: 0 8px 24px rgba(105,35,175,0.35);
}

/* ═══════════════════════════════════════════
   FAQ ACCORDION
═══════════════════════════════════════════ */
.elementor-accordion .elementor-accordion-item {
  border: 1px solid var(--nk-border) !important;
  border-radius: var(--nk-radius-sm) !important;
  margin-bottom: 12px !important;
  overflow: hidden;
  transition: border-color 0.2s ease;
}

.elementor-accordion .elementor-accordion-item:hover {
  border-color: var(--nk-purple-mid) !important;
}

.elementor-accordion .elementor-tab-title {
  font-size: 16px !important;
  font-weight: 600 !important;
  color: var(--nk-purple-dark) !important;
  padding: 20px 24px !important;
  background: #fff !important;
}

.elementor-accordion .elementor-tab-title.elementor-active {
  color: var(--nk-purple-mid) !important;
  background: var(--nk-light-purple) !important;
}

.elementor-accordion .elementor-tab-content {
  font-size: 15px !important;
  color: var(--nk-text-secondary) !important;
  line-height: 1.7 !important;
  padding: 16px 24px 24px !important;
}

/* ═══════════════════════════════════════════
   FOOTER
═══════════════════════════════════════════ */
.elementor-location-footer {
  background: var(--nk-purple-dark) !important;
}

.elementor-location-footer * {
  color: rgba(255,255,255,0.75) !important;
}

.elementor-location-footer h4,
.elementor-location-footer .footer-brand-name {
  color: rgba(255,255,255,0.5) !important;
  font-size: 13px !important;
  font-weight: 600 !important;
  letter-spacing: 0.08em !important;
  text-transform: uppercase !important;
  margin-bottom: 16px !important;
}

.elementor-location-footer a {
  color: rgba(255,255,255,0.75) !important;
  text-decoration: none !important;
  transition: color 0.2s ease !important;
  display: block;
  margin-bottom: 10px;
}

.elementor-location-footer a:hover {
  color: var(--nk-orange) !important;
}

.nk-footer-divider {
  border-top: 1px solid rgba(255,255,255,0.1) !important;
  margin: 40px 0 24px !important;
}

/* Social buttony v footeri */
.nk-social-btn {
  width: 36px !important;
  height: 36px !important;
  border-radius: 8px !important;
  background: rgba(255,255,255,0.08) !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  transition: background 0.2s ease !important;
  margin-right: 8px;
}

.nk-social-btn:hover {
  background: var(--nk-orange) !important;
}

/* ═══════════════════════════════════════════
   SECTION TITLE TAG (oranžový text nad nadpisom)
═══════════════════════════════════════════ */
.nk-section-tag {
  font-size: 13px !important;
  font-weight: 600 !important;
  color: var(--nk-orange) !important;
  letter-spacing: 0.08em !important;
  text-transform: uppercase !important;
  display: block;
  margin-bottom: 12px;
}

/* ═══════════════════════════════════════════
   SERVICE ITEMS
═══════════════════════════════════════════ */
.nk-service-item {
  display: flex;
  gap: 32px;
  align-items: flex-start;
  padding: 40px;
  border-radius: var(--nk-radius);
  background: #fff;
  border: 1px solid var(--nk-border);
  margin-bottom: 20px;
  transition: all 0.25s ease;
}

.nk-service-item:hover {
  border-color: var(--nk-purple-mid);
  box-shadow: var(--nk-shadow);
}

.nk-service-num {
  font-size: 52px;
  font-weight: 800;
  color: var(--nk-border);
  line-height: 1;
  min-width: 64px;
}

.nk-service-tag {
  font-size: 12px;
  font-weight: 500;
  padding: 4px 12px;
  border-radius: 20px;
  background: var(--nk-light-purple);
  color: var(--nk-purple-mid);
  display: inline-block;
  margin: 4px 4px 0 0;
}

/* ═══════════════════════════════════════════
   FILTER TABS (portfólio)
═══════════════════════════════════════════ */
.nk-filter-tabs {
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
  margin-bottom: 32px;
}

.nk-filter-tab {
  padding: 8px 20px;
  border-radius: 24px;
  font-size: 13px;
  font-weight: 500;
  cursor: pointer;
  border: 1.5px solid var(--nk-border);
  background: #fff;
  color: var(--nk-text-secondary);
  transition: all 0.2s ease;
  font-family: 'Poppins', sans-serif;
}

.nk-filter-tab.active,
.nk-filter-tab:hover {
  background: var(--nk-purple-mid);
  color: #fff;
  border-color: var(--nk-purple-mid);
}

/* ═══════════════════════════════════════════
   RESULT / STATS KARTY
═══════════════════════════════════════════ */
.nk-stat-card {
  background: var(--nk-light-purple);
  border-radius: 16px;
  padding: 28px;
  text-align: center;
  border: 1px solid var(--nk-border);
}

.nk-stat-num {
  font-size: 36px;
  font-weight: 800;
  color: var(--nk-purple-mid);
  display: block;
}

.nk-stat-label {
  font-size: 13px;
  color: var(--nk-text-secondary);
  margin-top: 4px;
}

/* ═══════════════════════════════════════════
   MOBILNÁ RESPONZIVITA
═══════════════════════════════════════════ */
@media (max-width: 768px) {
  .nk-hero-title { font-size: 38px !important; }
  .nk-cta-banner { padding: 40px 24px !important; }
  .nk-cta-banner h2 { font-size: 28px !important; }
  .nk-service-item { flex-direction: column; gap: 16px; padding: 24px; }
  .nk-service-num { font-size: 36px; }
}
