/*
Theme Name: Arocco
Theme URI: https://arocco.net
Author: Arocco
Author URI: https://arocco.net
Description: Arocco Linear — a dark product-development SaaS WordPress theme with Elementor-editable pages. Persian-first (RTL) with English-ready (LTR) structure. Built for software development companies with a futuristic, product-focused aesthetic, native editable page sections, custom post types (Services, Portfolio, Case Studies, FAQ, Testimonials), SEO + Schema (JSON-LD), Elementor & Rank Math compatibility, and a lightweight performance footprint.
Version: 6.0.0
Requires at least: 6.0
Tested up to: 6.6
Requires PHP: 7.4
License: GNU General Public License v2 or later
License URI: http://www.gnu.org/licenses/gpl-2.0.html
Text Domain: arocco
Tags: rtl-language-support, translation-ready, custom-colors, custom-menu, custom-logo, featured-images, full-width-template, theme-options, threaded-comments, blog, portfolio
*/

/* =========================================================================
   AROCCO DESIGN SYSTEM — DESIGN TOKENS
   All colors, spacing, radii, shadows are CSS variables.
   ========================================================================= */
:root {
  /* Base surfaces */
  --ar-bg:            #060814;
  --ar-bg-2:          #0a0e1f;
  --ar-surface:       #0d1226;
  --ar-surface-2:     #11172f;
  --ar-card:          rgba(255, 255, 255, 0.025);
  --ar-card-solid:    #0f1530;
  --ar-elevated:      #141b38;

  /* Brand palette: navy / electric blue / violet */
  --ar-violet:        #7c5cff;
  --ar-violet-2:      #9d7bff;
  --ar-indigo:        #5b6cff;
  --ar-blue:          #3d7bff;
  --ar-cyan:          #34d6ff;
  --ar-electric:      #38bdf8;

  /* Text */
  --ar-text:          #f4f6ff;
  --ar-text-soft:     #c2c8e0;
  --ar-text-muted:    #8b91b4;
  --ar-text-faint:    #5d6488;

  /* Lines / borders */
  --ar-border:        rgba(255, 255, 255, 0.07);
  --ar-border-strong: rgba(255, 255, 255, 0.12);
  --ar-divider:       rgba(255, 255, 255, 0.05);

  /* Gradients */
  --ar-grad-brand:    linear-gradient(135deg, #7c5cff 0%, #5b6cff 45%, #34d6ff 100%);
  --ar-grad-violet:   linear-gradient(135deg, #9d7bff 0%, #5b6cff 100%);
  --ar-grad-text:     linear-gradient(120deg, #ffffff 0%, #c2c8e0 40%, #9d7bff 100%);
  --ar-glow-violet:   radial-gradient(closest-side, rgba(124,92,255,0.55), rgba(124,92,255,0) 70%);
  --ar-glow-cyan:     radial-gradient(closest-side, rgba(52,214,255,0.40), rgba(52,214,255,0) 70%);

  /* Shadows */
  --ar-shadow-sm:     0 1px 2px rgba(0,0,0,0.4);
  --ar-shadow:        0 12px 40px rgba(0,0,0,0.45);
  --ar-shadow-lg:     0 30px 80px rgba(2,4,16,0.65);
  --ar-glow-ring:     0 0 0 1px rgba(124,92,255,0.35), 0 12px 50px rgba(124,92,255,0.25);

  /* Radii */
  --ar-r-sm:  10px;
  --ar-r-md:  16px;
  --ar-r-lg:  22px;
  --ar-r-xl:  28px;
  --ar-r-pill: 999px;

  /* Spacing scale */
  --ar-s1: 4px;  --ar-s2: 8px;  --ar-s3: 12px; --ar-s4: 16px;
  --ar-s5: 24px; --ar-s6: 32px; --ar-s7: 48px; --ar-s8: 64px;
  --ar-s9: 96px; --ar-s10: 128px;

  /* Layout */
  --ar-container: 1200px;
  --ar-container-wide: 1340px;
  --ar-header-h: 72px;

  /* Type */
  --ar-font-fa: "Yekan Bakh", "Vazirmatn", "IRANSansX", -apple-system, "Segoe UI", Tahoma, sans-serif;
  --ar-font-en: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;
  --ar-font: var(--ar-font-fa);

  /* Motion */
  --ar-ease: cubic-bezier(0.22, 1, 0.36, 1);
  --ar-fast: 0.18s;
  --ar-mid:  0.32s;
}

/* Light scheme support hook (kept dark by default; opt-in) */
html[data-arocco-scheme="light"] {
  --ar-bg: #f6f7fb; --ar-bg-2:#eef0f7; --ar-surface:#ffffff;
}

/* =========================================================================
   RESET / BASE
   ========================================================================= */
*, *::before, *::after { box-sizing: border-box; }
html { -webkit-text-size-adjust: 100%; scroll-behavior: smooth; }
body {
  margin: 0;
  font-family: var(--ar-font);
  background: var(--ar-bg);
  color: var(--ar-text-soft);
  line-height: 1.75;
  font-size: 16px;
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
  overflow-x: hidden;
}
body.ltr, html[lang="en"] body, [dir="ltr"] { --ar-font: var(--ar-font-en); }

img, svg, video { max-width: 100%; height: auto; display: block; }
a { color: inherit; text-decoration: none; transition: color var(--ar-fast) var(--ar-ease); }
a:hover { color: var(--ar-text); }
button { font-family: inherit; cursor: pointer; }
ul, ol { padding-inline-start: 1.2em; }

h1, h2, h3, h4, h5, h6 {
  color: var(--ar-text);
  line-height: 1.2;
  font-weight: 700;
  letter-spacing: -0.01em;
  margin: 0 0 var(--ar-s4);
}
h1 { font-size: clamp(2.2rem, 5vw, 3.8rem); }
h2 { font-size: clamp(1.7rem, 3.6vw, 2.6rem); }
h3 { font-size: clamp(1.25rem, 2.2vw, 1.6rem); }
p { margin: 0 0 var(--ar-s4); }

::selection { background: rgba(124,92,255,0.35); color: #fff; }

/* =========================================================================
   LAYOUT HELPERS
   ========================================================================= */
.ar-container { width: 100%; max-width: var(--ar-container); margin-inline: auto; padding-inline: var(--ar-s5); }
.ar-wide { max-width: var(--ar-container-wide); }
.ar-section { padding-block: var(--ar-s9); position: relative; }
.ar-section--tight { padding-block: var(--ar-s8); }
.ar-center { text-align: center; }
.ar-grid { display: grid; gap: var(--ar-s5); }
.ar-cols-2 { grid-template-columns: repeat(2, 1fr); }
.ar-cols-3 { grid-template-columns: repeat(3, 1fr); }
.ar-cols-4 { grid-template-columns: repeat(4, 1fr); }
.ar-flex { display: flex; gap: var(--ar-s4); }
.ar-items-center { align-items: center; }
.ar-justify-between { justify-content: space-between; }

.ar-kicker {
  display: inline-flex; align-items: center; gap: var(--ar-s2);
  font-size: 0.82rem; font-weight: 600; letter-spacing: 0.04em;
  color: var(--ar-violet-2);
  padding: 6px 14px; border-radius: var(--ar-r-pill);
  background: rgba(124,92,255,0.10);
  border: 1px solid rgba(124,92,255,0.22);
  margin-bottom: var(--ar-s4);
}
.ar-kicker .dot { width: 6px; height: 6px; border-radius: 50%; background: var(--ar-cyan); box-shadow: 0 0 10px var(--ar-cyan); }

.ar-eyebrow { color: var(--ar-text-muted); font-size: 1.05rem; max-width: 620px; margin-inline: auto; }
.ar-section-head { max-width: 720px; margin: 0 auto var(--ar-s7); text-align: center; }

.ar-gradient-text {
  background: var(--ar-grad-text);
  -webkit-background-clip: text; background-clip: text;
  -webkit-text-fill-color: transparent; color: transparent;
}
.ar-accent-text {
  background: var(--ar-grad-violet);
  -webkit-background-clip: text; background-clip: text;
  -webkit-text-fill-color: transparent; color: transparent;
}

/* =========================================================================
   BUTTONS
   ========================================================================= */
.ar-btn {
  display: inline-flex; align-items: center; justify-content: center; gap: var(--ar-s2);
  padding: 13px 26px; border-radius: var(--ar-r-pill);
  font-weight: 600; font-size: 0.98rem; line-height: 1;
  border: 1px solid transparent; white-space: nowrap;
  transition: transform var(--ar-fast) var(--ar-ease), box-shadow var(--ar-mid) var(--ar-ease), background var(--ar-mid) var(--ar-ease);
}
.ar-btn svg { width: 18px; height: 18px; }
.ar-btn--primary {
  color: #fff; background: var(--ar-grad-brand);
  box-shadow: 0 8px 30px rgba(91,108,255,0.35);
}
.ar-btn--primary:hover { transform: translateY(-2px); box-shadow: 0 14px 40px rgba(91,108,255,0.5); color: #fff; }
.ar-btn--ghost {
  color: var(--ar-text); background: rgba(255,255,255,0.04);
  border-color: var(--ar-border-strong);
}
.ar-btn--ghost:hover { background: rgba(255,255,255,0.08); transform: translateY(-2px); color:#fff; }
.ar-btn--lg { padding: 16px 32px; font-size: 1.05rem; }
.ar-btn--block { width: 100%; }

/* =========================================================================
   HEADER / NAV
   ========================================================================= */
.ar-header {
  position: sticky; top: 0; z-index: 100;
  height: var(--ar-header-h);
  display: flex; align-items: center;
  backdrop-filter: blur(14px);
  background: rgba(6,8,20,0.72);
  border-bottom: 1px solid var(--ar-divider);
  transition: background var(--ar-mid) var(--ar-ease), border-color var(--ar-mid) var(--ar-ease);
}
.ar-header.is-scrolled { background: rgba(6,8,20,0.92); border-bottom-color: var(--ar-border); }
.ar-header__inner { display: flex; align-items: center; justify-content: space-between; width: 100%; gap: var(--ar-s5); }
.ar-logo { display: inline-flex; align-items: center; gap: 10px; font-weight: 800; font-size: 1.25rem; color: var(--ar-text); letter-spacing: -0.02em; }
.ar-logo img, .ar-logo svg { height: 30px; width: auto; }

.ar-nav { display: flex; align-items: center; gap: var(--ar-s2); }
.ar-nav ul { list-style: none; display: flex; align-items: center; gap: 2px; margin: 0; padding: 0; }
.ar-nav li { position: relative; }
.ar-nav a { display: block; padding: 9px 14px; border-radius: var(--ar-r-sm); color: var(--ar-text-soft); font-size: 0.95rem; font-weight: 500; }
.ar-nav a:hover, .ar-nav .current-menu-item > a { color: var(--ar-text); background: rgba(255,255,255,0.05); }
.ar-nav .menu-item-has-children > a::after { content: ""; display: inline-block; width: 6px; height: 6px; margin-inline-start: 6px; border-inline-end: 1.5px solid currentColor; border-bottom: 1.5px solid currentColor; transform: rotate(45deg) translateY(-2px); opacity: 0.6; }
.ar-nav .sub-menu {
  position: absolute; inset-inline-start: 0; top: calc(100% + 10px);
  min-width: 230px; padding: 8px; margin: 0;
  background: var(--ar-elevated); border: 1px solid var(--ar-border);
  border-radius: var(--ar-r-md); box-shadow: var(--ar-shadow);
  opacity: 0; visibility: hidden; transform: translateY(8px);
  transition: all var(--ar-mid) var(--ar-ease); flex-direction: column; gap: 2px; display: flex;
}
.ar-nav li:hover > .sub-menu { opacity: 1; visibility: visible; transform: translateY(0); }
.ar-nav .sub-menu a { padding: 10px 12px; }

.ar-header__actions { display: flex; align-items: center; gap: var(--ar-s3); }
.ar-burger { display: none; width: 42px; height: 42px; border-radius: var(--ar-r-sm); background: rgba(255,255,255,0.05); border: 1px solid var(--ar-border); align-items: center; justify-content: center; }
.ar-burger span, .ar-burger span::before, .ar-burger span::after { content: ""; display: block; width: 18px; height: 2px; background: var(--ar-text); border-radius: 2px; position: relative; transition: var(--ar-fast); }
.ar-burger span::before { position: absolute; top: -6px; }
.ar-burger span::after { position: absolute; top: 6px; }

/* Mobile drawer */
.ar-mobile-nav { position: fixed; inset: 0; z-index: 200; background: rgba(6,8,20,0.98); backdrop-filter: blur(8px); transform: translateY(-100%); transition: transform var(--ar-mid) var(--ar-ease); padding: var(--ar-s7) var(--ar-s5); overflow-y: auto; }
.ar-mobile-nav.is-open { transform: translateY(0); }
.ar-mobile-nav ul { list-style: none; padding: 0; margin: 0; }
.ar-mobile-nav a { display: block; padding: 14px 8px; font-size: 1.1rem; border-bottom: 1px solid var(--ar-divider); color: var(--ar-text); }
.ar-mobile-nav .sub-menu { padding-inline-start: 16px; }
.ar-mobile-close { position: absolute; top: 20px; inset-inline-end: 20px; width: 44px; height: 44px; font-size: 1.6rem; background: rgba(255,255,255,0.05); border:1px solid var(--ar-border); border-radius: var(--ar-r-sm); color: var(--ar-text); }

/* =========================================================================
   HERO
   ========================================================================= */
.ar-hero { position: relative; padding-block: var(--ar-s10) var(--ar-s9); overflow: hidden; }
.ar-hero__bg { position: absolute; inset: 0; z-index: 0; pointer-events: none; }
.ar-hero__glow { position: absolute; width: 900px; height: 900px; top: -340px; inset-inline-start: 50%; transform: translateX(-50%); background: var(--ar-glow-violet); opacity: 0.7; filter: blur(20px); animation: ar-pulse 9s var(--ar-ease) infinite; }
.ar-hero__glow--2 { width: 560px; height: 560px; top: 120px; inset-inline-start: 8%; background: var(--ar-glow-cyan); opacity: 0.5; animation-delay: 2s; }
.ar-hero__grid { position: absolute; inset: 0; background-image: linear-gradient(var(--ar-divider) 1px, transparent 1px), linear-gradient(90deg, var(--ar-divider) 1px, transparent 1px); background-size: 56px 56px; mask-image: radial-gradient(ellipse 70% 60% at 50% 30%, #000 30%, transparent 75%); opacity: 0.5; }
@keyframes ar-pulse { 0%,100% { opacity: 0.55; transform: translateX(-50%) scale(1); } 50% { opacity: 0.85; transform: translateX(-50%) scale(1.08); } }

.ar-hero__inner { position: relative; z-index: 2; text-align: center; max-width: 880px; margin-inline: auto; }
.ar-hero h1 { margin-bottom: var(--ar-s5); }
.ar-hero__sub { font-size: clamp(1.05rem, 2vw, 1.3rem); color: var(--ar-text-muted); max-width: 660px; margin: 0 auto var(--ar-s6); }
.ar-hero__cta { display: flex; gap: var(--ar-s4); justify-content: center; flex-wrap: wrap; margin-bottom: var(--ar-s8); }

.ar-hero__mockup { position: relative; z-index: 2; max-width: 1040px; margin: 0 auto; border-radius: var(--ar-r-xl); border: 1px solid var(--ar-border-strong); background: var(--ar-surface); box-shadow: var(--ar-shadow-lg), var(--ar-glow-ring); overflow: hidden; }
.ar-hero__mockup::after { content:""; position:absolute; inset:0; background: linear-gradient(180deg, transparent 60%, rgba(6,8,20,0.6) 100%); pointer-events:none; }
.ar-hero__mockup img, .ar-hero__mockup svg { width: 100%; display: block; }

.ar-marquee { margin-top: var(--ar-s8); }
.ar-marquee__label { text-align: center; color: var(--ar-text-faint); font-size: 0.85rem; letter-spacing: 0.08em; margin-bottom: var(--ar-s5); text-transform: uppercase; }
.ar-logos { display: flex; flex-wrap: wrap; align-items: center; justify-content: center; gap: var(--ar-s7); opacity: 0.65; }
.ar-logos span { color: var(--ar-text-muted); font-weight: 700; font-size: 1.1rem; letter-spacing: 0.02em; }

/* =========================================================================
   CARDS / FEATURES
   ========================================================================= */
.ar-card {
  position: relative; background: var(--ar-card); border: 1px solid var(--ar-border);
  border-radius: var(--ar-r-lg); padding: var(--ar-s6);
  transition: transform var(--ar-mid) var(--ar-ease), border-color var(--ar-mid) var(--ar-ease), background var(--ar-mid) var(--ar-ease);
  overflow: hidden;
}
.ar-card::before { content: ""; position: absolute; inset: 0; border-radius: inherit; padding: 1px; background: var(--ar-grad-brand); -webkit-mask: linear-gradient(#000 0 0) content-box, linear-gradient(#000 0 0); -webkit-mask-composite: xor; mask-composite: exclude; opacity: 0; transition: opacity var(--ar-mid) var(--ar-ease); pointer-events: none; }
.ar-card:hover { transform: translateY(-4px); background: rgba(255,255,255,0.04); }
.ar-card:hover::before { opacity: 0.5; }
.ar-card__icon { width: 52px; height: 52px; border-radius: var(--ar-r-md); display: flex; align-items: center; justify-content: center; background: rgba(124,92,255,0.12); border: 1px solid rgba(124,92,255,0.2); margin-bottom: var(--ar-s4); }
.ar-card__icon svg { width: 26px; height: 26px; color: var(--ar-violet-2); }
.ar-card h3 { font-size: 1.2rem; margin-bottom: var(--ar-s2); }
.ar-card p { color: var(--ar-text-muted); font-size: 0.96rem; margin: 0; }
.ar-card__link { margin-top: var(--ar-s4); display: inline-flex; align-items: center; gap: 6px; color: var(--ar-violet-2); font-weight: 600; font-size: 0.92rem; }
.ar-card__link svg { width: 16px; height: 16px; transition: transform var(--ar-fast) var(--ar-ease); }
.ar-card:hover .ar-card__link svg { transform: translateX(-4px); }
[dir="ltr"] .ar-card:hover .ar-card__link svg { transform: translateX(4px); }

/* Feature split */
.ar-feature-row { display: grid; grid-template-columns: 1fr 1fr; gap: var(--ar-s8); align-items: center; }
.ar-feature-row:nth-child(even) .ar-feature-row__media { order: -1; }
.ar-feature-row__media { border-radius: var(--ar-r-lg); border: 1px solid var(--ar-border); overflow: hidden; background: var(--ar-surface); box-shadow: var(--ar-shadow); }
.ar-feature-list { list-style: none; padding: 0; margin: var(--ar-s5) 0 0; }
.ar-feature-list li { display: flex; gap: var(--ar-s3); align-items: flex-start; margin-bottom: var(--ar-s3); color: var(--ar-text-soft); }
.ar-feature-list li svg { width: 22px; height: 22px; flex-shrink: 0; color: var(--ar-cyan); margin-top: 2px; }

/* Stats */
.ar-stats { display: grid; grid-template-columns: repeat(4, 1fr); gap: var(--ar-s5); }
.ar-stat { text-align: center; padding: var(--ar-s5); border-radius: var(--ar-r-md); border: 1px solid var(--ar-border); background: var(--ar-card); }
.ar-stat__num { font-size: clamp(2rem, 4vw, 2.8rem); font-weight: 800; }
.ar-stat__label { color: var(--ar-text-muted); font-size: 0.95rem; }

/* Process / steps */
.ar-steps { counter-reset: step; display: grid; grid-template-columns: repeat(4,1fr); gap: var(--ar-s5); }
.ar-step { position: relative; padding: var(--ar-s6) var(--ar-s5); border-radius: var(--ar-r-md); border: 1px solid var(--ar-border); background: var(--ar-card); }
.ar-step__num { counter-increment: step; width: 44px; height: 44px; border-radius: var(--ar-r-sm); display: flex; align-items: center; justify-content: center; font-weight: 800; color:#fff; background: var(--ar-grad-violet); margin-bottom: var(--ar-s4); }
.ar-step__num::before { content: counter(step, decimal); }
.ar-step h3 { font-size: 1.1rem; }
.ar-step p { color: var(--ar-text-muted); font-size: 0.92rem; margin: 0; }

/* Testimonials */
.ar-quote { padding: var(--ar-s6); border-radius: var(--ar-r-lg); border: 1px solid var(--ar-border); background: var(--ar-card); }
.ar-quote p { font-size: 1.05rem; color: var(--ar-text-soft); }
.ar-quote__author { display: flex; align-items: center; gap: var(--ar-s3); margin-top: var(--ar-s5); }
.ar-quote__avatar { width: 46px; height: 46px; border-radius: 50%; background: var(--ar-grad-violet); display: flex; align-items: center; justify-content: center; color: #fff; font-weight: 700; }
.ar-quote__name { color: var(--ar-text); font-weight: 700; line-height: 1.2; }
.ar-quote__role { color: var(--ar-text-muted); font-size: 0.85rem; }

/* Pricing */
.ar-price-card { display: flex; flex-direction: column; padding: var(--ar-s6); border-radius: var(--ar-r-lg); border: 1px solid var(--ar-border); background: var(--ar-card); }
.ar-price-card.is-featured { border-color: rgba(124,92,255,0.4); box-shadow: var(--ar-glow-ring); background: rgba(124,92,255,0.05); }
.ar-price-card__badge { align-self: flex-start; font-size: 0.78rem; font-weight: 600; padding: 4px 12px; border-radius: var(--ar-r-pill); background: var(--ar-grad-brand); color: #fff; margin-bottom: var(--ar-s3); }
.ar-price-card__price { font-size: 2.4rem; font-weight: 800; color: var(--ar-text); margin: var(--ar-s3) 0; }
.ar-price-card__price small { font-size: 0.9rem; color: var(--ar-text-muted); font-weight: 500; }
.ar-price-card ul { list-style: none; padding: 0; margin: var(--ar-s4) 0 var(--ar-s6); }
.ar-price-card li { display: flex; gap: var(--ar-s2); padding: 8px 0; border-bottom: 1px solid var(--ar-divider); color: var(--ar-text-soft); font-size: 0.95rem; }
.ar-price-card li svg { width: 18px; height: 18px; color: var(--ar-cyan); flex-shrink: 0; }

/* FAQ accordion */
.ar-faq { max-width: 820px; margin-inline: auto; }
.ar-faq__item { border: 1px solid var(--ar-border); border-radius: var(--ar-r-md); margin-bottom: var(--ar-s3); background: var(--ar-card); overflow: hidden; }
.ar-faq__q { display: flex; align-items: center; justify-content: space-between; gap: var(--ar-s4); width: 100%; padding: var(--ar-s5); background: none; border: 0; color: var(--ar-text); font-size: 1.05rem; font-weight: 600; text-align: start; }
.ar-faq__q .ic { width: 22px; height: 22px; flex-shrink: 0; position: relative; transition: transform var(--ar-mid) var(--ar-ease); }
.ar-faq__q .ic::before, .ar-faq__q .ic::after { content: ""; position: absolute; top: 50%; inset-inline-start: 0; width: 100%; height: 2px; background: var(--ar-violet-2); }
.ar-faq__q .ic::after { transform: rotate(90deg); transition: transform var(--ar-mid) var(--ar-ease); }
.ar-faq__item.is-open .ic::after { transform: rotate(0); }
.ar-faq__a { max-height: 0; overflow: hidden; transition: max-height var(--ar-mid) var(--ar-ease); }
.ar-faq__a-inner { padding: 0 var(--ar-s5) var(--ar-s5); color: var(--ar-text-muted); }

/* CTA band */
.ar-cta-band { position: relative; border-radius: var(--ar-r-xl); padding: var(--ar-s9) var(--ar-s6); text-align: center; overflow: hidden; border: 1px solid var(--ar-border-strong); background: linear-gradient(135deg, rgba(124,92,255,0.12), rgba(52,214,255,0.08)); }
.ar-cta-band__glow { position: absolute; width: 600px; height: 600px; inset-inline-start: 50%; top: -50%; transform: translateX(-50%); background: var(--ar-glow-violet); opacity: 0.5; }
.ar-cta-band > * { position: relative; z-index: 2; }
.ar-cta-band h2 { max-width: 700px; margin-inline: auto; }
.ar-cta-band .ar-hero__cta { margin-bottom: 0; margin-top: var(--ar-s5); }

/* =========================================================================
   POSTS / ARCHIVE / SINGLE
   ========================================================================= */
.ar-post-card { display: flex; flex-direction: column; border: 1px solid var(--ar-border); border-radius: var(--ar-r-lg); overflow: hidden; background: var(--ar-card); transition: transform var(--ar-mid) var(--ar-ease), border-color var(--ar-mid) var(--ar-ease); }
.ar-post-card:hover { transform: translateY(-4px); border-color: var(--ar-border-strong); }
.ar-post-card__thumb { aspect-ratio: 16/9; overflow: hidden; background: var(--ar-surface-2); }
.ar-post-card__thumb img { width: 100%; height: 100%; object-fit: cover; transition: transform var(--ar-mid) var(--ar-ease); }
.ar-post-card:hover .ar-post-card__thumb img { transform: scale(1.05); }
.ar-post-card__body { padding: var(--ar-s5); display: flex; flex-direction: column; gap: var(--ar-s2); flex: 1; }
.ar-post-card__meta { font-size: 0.82rem; color: var(--ar-text-faint); }
.ar-post-card h3 { font-size: 1.2rem; margin: 0; }
.ar-post-card p { color: var(--ar-text-muted); font-size: 0.95rem; margin: 0; }
.ar-tax-pill { display: inline-block; font-size: 0.75rem; padding: 3px 10px; border-radius: var(--ar-r-pill); background: rgba(124,92,255,0.12); color: var(--ar-violet-2); border: 1px solid rgba(124,92,255,0.2); }

.ar-page-hero { padding-block: var(--ar-s8) var(--ar-s7); text-align: center; position: relative; overflow: hidden; border-bottom: 1px solid var(--ar-divider); }
.ar-page-hero .ar-hero__glow { width: 700px; height: 700px; opacity: 0.4; }
.ar-breadcrumbs { font-size: 0.85rem; color: var(--ar-text-faint); margin-bottom: var(--ar-s3); }
.ar-breadcrumbs a:hover { color: var(--ar-violet-2); }
.ar-breadcrumbs .sep { margin-inline: 6px; opacity: 0.5; }

.ar-content { max-width: 760px; margin-inline: auto; }
.ar-content :is(h2,h3,h4) { margin-top: var(--ar-s6); }
.ar-content img { border-radius: var(--ar-r-md); margin-block: var(--ar-s4); }
.ar-content blockquote { border-inline-start: 3px solid var(--ar-violet); padding-inline-start: var(--ar-s4); color: var(--ar-text-soft); font-style: italic; margin-inline: 0; }
.ar-content pre { background: var(--ar-surface-2); padding: var(--ar-s4); border-radius: var(--ar-r-md); overflow-x: auto; border: 1px solid var(--ar-border); }
.ar-content code { background: rgba(255,255,255,0.06); padding: 2px 6px; border-radius: 6px; font-size: 0.9em; }
.ar-content a { color: var(--ar-violet-2); text-decoration: underline; text-underline-offset: 3px; }

.ar-layout { display: grid; grid-template-columns: 1fr 300px; gap: var(--ar-s7); align-items: start; }
.ar-layout--full { grid-template-columns: 1fr; }
.ar-sidebar .widget { background: var(--ar-card); border: 1px solid var(--ar-border); border-radius: var(--ar-r-md); padding: var(--ar-s5); margin-bottom: var(--ar-s5); }
.ar-sidebar .widget-title { font-size: 1.05rem; margin-bottom: var(--ar-s3); color: var(--ar-text); }
.ar-sidebar ul { list-style: none; padding: 0; margin: 0; }
.ar-sidebar li { padding: 7px 0; border-bottom: 1px solid var(--ar-divider); color: var(--ar-text-muted); }

/* Pagination */
.ar-pagination { display: flex; gap: var(--ar-s2); justify-content: center; margin-top: var(--ar-s7); flex-wrap: wrap; }
.ar-pagination a, .ar-pagination span { padding: 10px 16px; border-radius: var(--ar-r-sm); border: 1px solid var(--ar-border); color: var(--ar-text-soft); }
.ar-pagination .current { background: var(--ar-grad-brand); color: #fff; border-color: transparent; }

/* Forms / comments */
.ar-input, input[type=text], input[type=email], input[type=url], input[type=search], input[type=tel], textarea, select {
  width: 100%; padding: 13px 16px; border-radius: var(--ar-r-sm);
  background: var(--ar-surface-2); border: 1px solid var(--ar-border);
  color: var(--ar-text); font-family: inherit; font-size: 0.98rem;
  transition: border-color var(--ar-fast) var(--ar-ease), box-shadow var(--ar-fast) var(--ar-ease);
}
.ar-input:focus, input:focus, textarea:focus, select:focus { outline: none; border-color: var(--ar-violet); box-shadow: 0 0 0 3px rgba(124,92,255,0.18); }
label { display: block; margin-bottom: 6px; color: var(--ar-text-soft); font-size: 0.92rem; }
.ar-field { margin-bottom: var(--ar-s4); }
.comment-list { list-style: none; padding: 0; }
.comment-list .children { list-style: none; padding-inline-start: var(--ar-s5); }
.comment-body { background: var(--ar-card); border: 1px solid var(--ar-border); border-radius: var(--ar-r-md); padding: var(--ar-s5); margin-bottom: var(--ar-s4); }

/* =========================================================================
   FOOTER
   ========================================================================= */
.ar-footer { border-top: 1px solid var(--ar-divider); background: var(--ar-bg-2); padding-block: var(--ar-s8) var(--ar-s5); margin-top: var(--ar-s9); }
.ar-footer__grid { display: grid; grid-template-columns: 1.6fr 1fr 1fr 1.2fr; gap: var(--ar-s6); margin-bottom: var(--ar-s7); }
.ar-footer__brand p { color: var(--ar-text-muted); max-width: 320px; margin-top: var(--ar-s3); }
.ar-footer h4 { font-size: 1rem; color: var(--ar-text); margin-bottom: var(--ar-s4); }
.ar-footer ul { list-style: none; padding: 0; margin: 0; }
.ar-footer li { margin-bottom: 10px; }
.ar-footer li a { color: var(--ar-text-muted); font-size: 0.95rem; }
.ar-footer li a:hover { color: var(--ar-text); }
.ar-footer__social { display: flex; gap: var(--ar-s3); margin-top: var(--ar-s4); }
.ar-footer__social a { width: 40px; height: 40px; border-radius: var(--ar-r-sm); background: rgba(255,255,255,0.04); border: 1px solid var(--ar-border); display: flex; align-items: center; justify-content: center; color: var(--ar-text-soft); }
.ar-footer__social a:hover { background: rgba(124,92,255,0.15); color: var(--ar-text); }
.ar-footer__social svg { width: 18px; height: 18px; }
.ar-footer__bottom { display: flex; align-items: center; justify-content: space-between; padding-top: var(--ar-s5); border-top: 1px solid var(--ar-divider); color: var(--ar-text-faint); font-size: 0.88rem; flex-wrap: wrap; gap: var(--ar-s3); }
.ar-newsletter { display: flex; gap: var(--ar-s2); margin-top: var(--ar-s4); }
.ar-newsletter input { flex: 1; }

/* =========================================================================
   UTIL / MOTION / ACCESSIBILITY
   ========================================================================= */
.ar-reveal { opacity: 0; transform: translateY(24px); transition: opacity 0.7s var(--ar-ease), transform 0.7s var(--ar-ease); }
.ar-reveal.is-visible { opacity: 1; transform: none; }
.screen-reader-text { position: absolute !important; width: 1px; height: 1px; overflow: hidden; clip: rect(1px,1px,1px,1px); white-space: nowrap; }
.skip-link { position: absolute; inset-inline-start: -9999px; }
.skip-link:focus { inset-inline-start: 12px; top: 12px; z-index: 999; background: var(--ar-violet); color: #fff; padding: 10px 16px; border-radius: 8px; }
.ar-divider { height: 1px; background: var(--ar-divider); border: 0; margin-block: var(--ar-s7); }

@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after { animation-duration: 0.001ms !important; transition-duration: 0.001ms !important; scroll-behavior: auto !important; }
  .ar-reveal { opacity: 1; transform: none; }
}

/* =========================================================================
   RESPONSIVE
   ========================================================================= */
@media (max-width: 1024px) {
  .ar-footer__grid { grid-template-columns: 1fr 1fr; }
  .ar-stats, .ar-steps { grid-template-columns: repeat(2, 1fr); }
  .ar-cols-4 { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 880px) {
  .ar-nav, .ar-header__actions .ar-btn { display: none; }
  .ar-burger { display: flex; }
  .ar-feature-row { grid-template-columns: 1fr; gap: var(--ar-s5); }
  .ar-feature-row__media { order: 0 !important; }
  .ar-layout { grid-template-columns: 1fr; }
}
@media (max-width: 640px) {
  :root { --ar-s9: 64px; --ar-s10: 80px; }
  .ar-cols-2, .ar-cols-3, .ar-cols-4, .ar-stats, .ar-steps, .ar-footer__grid { grid-template-columns: 1fr; }
  .ar-container { padding-inline: var(--ar-s4); }
  .ar-hero__cta { flex-direction: column; }
  .ar-hero__cta .ar-btn { width: 100%; }
}

/* =========================================================================
   ELEMENTOR COMPATIBILITY (additive — native theme untouched)
   Aligns Elementor Global Colors with the Arocco palette and removes the
   default content container for Elementor-built pages so the builder gets
   full width while the Arocco header/footer remain.
========================================================================= */
:root{
  /* Requested Elementor Global Colors, also available to native CSS. */
  --ar-el-bg:        #08090D;
  --ar-el-surface:   #11131A;
  --ar-el-surface-2: #171A23;
  --ar-el-border:    rgba(255,255,255,0.10);
  --ar-el-text:      #F7F8FA;
  --ar-el-muted:     #9CA3AF;
  --ar-el-primary:   #7C5CFF;
  --ar-el-secondary: #4EA1FF;
  --ar-el-glow:      rgba(124,92,255,0.35);
}

/* Full-width Elementor pages keep header/footer, drop content padding. */
.ar-elementor-full{ width:100%; }
.ar-elementor-full > .elementor{ width:100%; }

/* Canvas template: page background + safe defaults. */
.ar-elementor-canvas{ background:var(--ar-bg); color:var(--ar-text); }
.ar-canvas-wrap{ min-height:100vh; }

/* Elementor buttons inherit the Arocco pill + brand gradient by default. */
.elementor-button.ar-btn--primary,
.elementor .ar-btn--primary{
  background:var(--ar-grad-brand); color:#fff; border:0;
}

/* Keep Elementor headings/typography on the dark theme. */
.elementor-widget-heading .elementor-heading-title{ color:var(--ar-text); }
.elementor-widget-text-editor{ color:var(--ar-text-soft); }

/* Reusable on-brand utility classes selectable from Elementor's "CSS Classes". */
.ar-el-panel{ background:var(--ar-card-solid); border:1px solid var(--ar-border); border-radius:var(--ar-r-lg); }
.ar-el-grid-bg{ background-image:radial-gradient(circle at 1px 1px, rgba(255,255,255,.05) 1px, transparent 0); background-size:28px 28px; }
.ar-el-glow-wrap{ position:relative; overflow:hidden; }
.ar-el-glow-wrap::before{
  content:""; position:absolute; inset:-20% -10% auto -10%; height:70%;
  background:var(--ar-glow-violet); filter:blur(48px); pointer-events:none; z-index:0;
}
.ar-el-glow-wrap > *{ position:relative; z-index:1; }
