/*
Theme Name: ArfaVision Halo
Theme URI: https://arfavision.com/
Author: ArfaVision
Author URI: https://arfavision.com/
Description: Marketing-first landing theme for ArfaVision with DMS/RMS gateway buttons + Book a Demo form. Fully customizable via WordPress Customizer (colors, typography, sections, feature cards, testimonials, CTA).
Version: 1.0.0
Requires at least: 6.0
Tested up to: 6.5
Requires PHP: 7.4
License: GPLv2 or later
License URI: https://www.gnu.org/licenses/gpl-2.0.html
Text Domain: arfavision-halo
Tags: custom-colors, custom-logo, one-column, two-columns, flexible-header, editor-style, featured-images, block-styles
*/

/* Core reset + base */
:root{
  --av-bg:#070A10;
  --av-surface:#0C1220;
  --av-surface2:#0F172A;
  --av-text:#E7E9EE;
  --av-muted:rgba(231,233,238,.72);
  --av-border:rgba(255,255,255,.10);

  --av-primary:#E11D48; /* red */
  --av-accent:#F59E0B;  /* amber */
  --av-link:#60A5FA;

  --av-radius:18px;
  --av-shadow: 0 24px 60px rgba(0,0,0,.55);
  --av-container: 1180px;
  --av-font: ui-sans-serif, system-ui, -apple-system, Segoe UI, Roboto, Helvetica, Arial, "Apple Color Emoji","Segoe UI Emoji";
}

*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{
  font-family: var(--av-font);
  background: var(--av-bg);
  color: var(--av-text);
  line-height:1.6;
}

a{color:var(--av-link);text-decoration:none}
a:hover{text-decoration:underline}

.av-container{
  width:min(var(--av-container), calc(100% - 32px));
  margin-inline:auto;
}

.av-header{
  position: sticky; top:0; z-index:1000;
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  background: rgba(7,10,16,.55);
  border-bottom:1px solid rgba(255,255,255,.06);
}
.av-nav{
  display:flex;align-items:center;justify-content:space-between;
  padding:14px 0;
}
.av-brand{
  display:flex;align-items:center;gap:10px;font-weight:900;letter-spacing:.2px;
}
.av-logo{width:34px;height:34px;border-radius:10px;background:rgba(255,255,255,.06);display:grid;place-items:center;border:1px solid rgba(255,255,255,.10)}
.av-logo span{font-weight:900;color:var(--av-primary)}
.av-menu{
  display:flex;gap:18px;align-items:center;
}
.av-menu a{color:rgba(255,255,255,.82);font-weight:700;font-size:14px}
.av-menu a:hover{color:#fff;text-decoration:none}

.av-top-actions{display:flex;gap:10px;align-items:center}
.av-btn{
  display:inline-flex;align-items:center;justify-content:center;gap:10px;
  padding:12px 16px;border-radius:14px;border:1px solid rgba(255,255,255,.12);
  background: rgba(255,255,255,.04);
  color:#fff;font-weight:800;font-size:14px;
  cursor:pointer;transition:.18s;
  text-decoration:none;
}
.av-btn:hover{transform:translateY(-1px);background:rgba(255,255,255,.07);text-decoration:none}
.av-btn.primary{
  background: linear-gradient(135deg, rgba(225,29,72,1), rgba(239,68,68,1));
  border:none;
  box-shadow: 0 16px 40px rgba(225,29,72,.35);
}
.av-btn.primary:hover{box-shadow: 0 22px 55px rgba(225,29,72,.48)}
.av-btn.ghost{
  background: transparent;
}
.av-btn.small{padding:10px 14px;border-radius:12px;font-size:13px}

.av-hero{
  position:relative;
  padding: 86px 0 64px;
  overflow:hidden;
}
.av-hero::before{
  content:"";
  position:absolute; inset:-2px;
  background:
    radial-gradient(1200px 700px at 20% 10%, rgba(225,29,72,.28), transparent 60%),
    radial-gradient(900px 600px at 82% 18%, rgba(245,158,11,.16), transparent 55%),
    radial-gradient(700px 520px at 70% 80%, rgba(96,165,250,.14), transparent 55%),
    linear-gradient(180deg, rgba(255,255,255,.04), transparent 55%);
  pointer-events:none;
}
.av-hero::after{
  content:"";
  position:absolute; inset:0;
  background-image: radial-gradient(rgba(255,255,255,.08) 1px, transparent 1px);
  background-size: 26px 26px;
  opacity:.12;
  pointer-events:none;
}
.av-hero-grid{
  position:relative;
  display:grid;
  grid-template-columns: 1.15fr .85fr;
  gap:42px;
  align-items:center;
}
@media (max-width: 980px){
  .av-hero-grid{grid-template-columns:1fr;gap:28px}
  .av-menu{display:none}
}

.av-kicker{
  display:inline-flex;align-items:center;gap:10px;
  padding:7px 14px;border-radius:999px;
  background: rgba(255,255,255,.06);
  border:1px solid rgba(255,255,255,.10);
  font-size:13px;font-weight:900;color:rgba(255,255,255,.86);
}
.av-dot{width:8px;height:8px;border-radius:999px;background: #22C55E; box-shadow: 0 0 16px rgba(34,197,94,.75)}
.av-title{
  margin:16px 0 10px;
  font-size: clamp(2.2rem, 4.4vw, 3.35rem);
  line-height:1.08;
  font-weight: 950;
  letter-spacing:-.02em;
}
.av-subtitle{
  margin:0 0 22px;
  color: var(--av-muted);
  font-size: 1.08rem;
  max-width: 62ch;
}
.av-cta-row{display:flex;gap:12px;flex-wrap:wrap;margin-top:18px}
.av-pill-row{display:flex;gap:10px;flex-wrap:wrap;margin-top:18px}
.av-pill{
  padding:8px 12px;border-radius:999px;
  background: rgba(255,255,255,.04);
  border:1px solid rgba(255,255,255,.10);
  color: rgba(255,255,255,.84);
  font-weight:800;font-size:13px;
}

.av-card{
  background: rgba(12,18,32,.62);
  border:1px solid rgba(255,255,255,.10);
  border-radius: var(--av-radius);
  box-shadow: var(--av-shadow);
  backdrop-filter: blur(18px);
  -webkit-backdrop-filter: blur(18px);
}
.av-portal{
  padding:18px;
}
.av-portal-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:10px}
.av-portal-title{font-weight:950}
.av-portal-sub{color:var(--av-muted);font-size:13px;margin-top:-2px}
.av-access{
  display:grid;gap:12px;margin-top:14px
}
.av-access-item{
  display:flex;gap:14px;align-items:flex-start;
  padding:14px;border-radius:16px;
  background: rgba(0,0,0,.18);
  border:1px solid rgba(255,255,255,.08);
  cursor:pointer; transition:.18s;
}
.av-access-item:hover{transform:translateY(-1px);background: rgba(255,255,255,.06)}
.av-icon{
  width:44px;height:44px;border-radius:14px;display:grid;place-items:center;
  color:#fff;font-weight:950;
}
.av-icon.dms{background: linear-gradient(135deg, #EF4444, #B91C1C)}
.av-icon.rms{background: linear-gradient(135deg, #F59E0B, #D97706)}
.av-item h4{margin:0;font-size:15px;font-weight:950}
.av-item p{margin:4px 0 0;color:var(--av-muted);font-size:12.8px}
.av-arrow{margin-left:auto;color:rgba(255,255,255,.65);font-weight:950;margin-top:4px}

.av-section{padding:70px 0}
.av-sec-head{text-align:center;margin-bottom:34px}
.av-sec-head h2{margin:0 0 8px;font-weight:950;letter-spacing:-.01em}
.av-sec-head p{margin:0;color:var(--av-muted);max-width:72ch;margin-inline:auto}

.av-grid-3{
  display:grid;
  grid-template-columns: repeat(3, 1fr);
  gap:16px;
}
@media (max-width: 980px){ .av-grid-3{grid-template-columns:1fr} }

.av-feat{
  padding:18px;border-radius:18px;
  background: rgba(255,255,255,.03);
  border:1px solid rgba(255,255,255,.08);
  transition:.18s;
}
.av-feat:hover{transform:translateY(-2px);background: rgba(255,255,255,.05)}
.av-feat .ic{
  width:42px;height:42px;border-radius:14px;display:grid;place-items:center;
  background: rgba(225,29,72,.18);
  border: 1px solid rgba(225,29,72,.25);
  margin-bottom:12px;
}
.av-feat h3{margin:0 0 6px;font-weight:950;font-size:16px}
.av-feat p{margin:0;color:var(--av-muted);font-size:13.5px}

.av-testimonials{
  display:grid;gap:16px;
  grid-template-columns: repeat(3, 1fr);
}
@media (max-width: 980px){ .av-testimonials{grid-template-columns:1fr} }
.av-quote{
  padding:18px;border-radius:18px;
  background: rgba(255,255,255,.03);
  border:1px solid rgba(255,255,255,.08);
}
.av-quote p{margin:0 0 12px;color:rgba(255,255,255,.86)}
.av-quote .who{display:flex;align-items:center;gap:10px;color:var(--av-muted);font-weight:800;font-size:13px}
.av-avatar{width:34px;height:34px;border-radius:12px;background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.10)}

.av-demo{
  display:grid;grid-template-columns: 1fr 1fr;
  gap:16px;align-items:stretch;
}
@media (max-width: 980px){ .av-demo{grid-template-columns:1fr} }
.av-form{
  padding:18px;
}
.av-field{display:flex;flex-direction:column;gap:7px;margin-bottom:12px}
.av-field label{font-weight:900;font-size:13px;color:rgba(255,255,255,.86)}
.av-field input,.av-field textarea, .av-field select{
  width:100%;
  padding:12px 12px;border-radius:14px;
  background:#050814;
  color:#fff;
  border:1px solid rgba(255,255,255,.14);
  outline:none;
}
.av-field input:focus,.av-field textarea:focus, .av-field select:focus{
  border-color: rgba(225,29,72,.55);
  box-shadow: 0 0 0 4px rgba(225,29,72,.16);
}

.av-footer{
  border-top:1px solid rgba(255,255,255,.08);
  padding:28px 0;
  color: var(--av-muted);
}
.av-footer-grid{display:flex;flex-wrap:wrap;gap:12px;align-items:center;justify-content:space-between}
.av-footer a{color:rgba(255,255,255,.78)}
.av-footer a:hover{color:#fff}

/* Popup */
.av-popup-overlay{
  position:fixed; inset:0;
  background: rgba(0,0,0,.68);
  display:none; align-items:center; justify-content:center;
  z-index: 9999;
  padding: 18px;
}
.av-popup{
  width:min(440px, 100%);
  padding:20px;
}
.av-popup h3{margin:0 0 6px;font-weight:950}
.av-popup p{margin:0 0 12px;color:var(--av-muted);font-size:13.5px}
.av-popup-actions{display:flex;gap:10px;justify-content:flex-end;margin-top:12px;flex-wrap:wrap}
.av-err{display:none;color:#FF7B7B;margin-top:8px;font-weight:800;font-size:13px}
