/*
Theme Name: ONS Vision
Theme URI: https://onsvision.ae
Author: ONS VISION FZCO
Author URI: https://onsvision.ae
Description: Bilingual (EN/TR) single-page theme for ONS VISION FZCO — a Dubai-based full-service digital agency. Ink/white design system with a flag-coloured swoosh motif, performance-focused, accessible (WCAG AA), and built for recruitment credibility and ad-platform business verification (Meta/Google/TikTok). Includes a Web3Forms-powered contact form, Privacy/Terms overlays, and Customizer settings.
Version: 1.0.0
Requires at least: 6.0
Tested up to: 6.5
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: ons-vision
Tags: business, one-page, custom-colors, custom-logo, custom-menu, featured-images, translation-ready, rtl-language-support, blog
*/

/* ============================================================
   ONS VISION FZCO — design system
   Ink black / white / neutral; flag-coloured swoosh accent.
   Space Grotesk (heads) + Inter (body).
   ============================================================ */
:root{
  --ink:#0E0E0E;
  --bg:#FFFFFF;
  --surface:#F6F6F4;
  --surface-2:#F0F0ED;
  --muted:#5A5A5A;
  --muted-2:#8A8A86;
  --border:#E6E6E3;
  --border-strong:#D7D7D2;
  --red:#CE1126;          /* UAE/TR-flag red */
  --green:#007A3D;        /* UAE-flag green */
  --accent:1;             /* 0..1, controls swoosh intensity */

  --font-head:'Space Grotesk',-apple-system,system-ui,sans-serif;
  --font-body:'Inter',-apple-system,system-ui,sans-serif;

  --fs-eyebrow:.8125rem;
  --fs-body:1.0625rem;
  --fs-lead:1.25rem;
  --fs-h3:1.5rem;
  --fs-h2:clamp(2rem,4vw,3rem);
  --fs-h1:clamp(2.75rem,6.2vw,5.25rem);

  --maxw:1240px;
  --gutter:clamp(20px,5vw,64px);
  --section-y:clamp(72px,9vw,140px);

  --radius:4px;
  --radius-lg:10px;
  --radius-pill:999px;

  --shadow-sm:0 1px 2px rgba(14,14,14,.04),0 2px 8px rgba(14,14,14,.04);
  --shadow-md:0 10px 30px -12px rgba(14,14,14,.18);

  --ease:cubic-bezier(.22,.61,.36,1);
}

*{box-sizing:border-box;}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%;}
body{
  margin:0;
  font-family:var(--font-body);
  font-size:var(--fs-body);
  line-height:1.6;
  color:var(--ink);
  background:var(--bg);
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
img{max-width:100%;display:block;height:auto;}
a{color:inherit;text-decoration:none;}
button{font-family:inherit;cursor:pointer;}
::selection{background:var(--ink);color:#fff;}

h1,h2,h3,h4{font-family:var(--font-head);font-weight:700;line-height:1.04;letter-spacing:-.02em;margin:0;text-wrap:balance;}
p{margin:0;text-wrap:pretty;}

/* Skip link */
.skip{position:absolute;left:-9999px;top:auto;width:1px;height:1px;overflow:hidden;}
.skip:focus{left:16px;top:16px;width:auto;height:auto;background:var(--ink);color:#fff;padding:10px 14px;border-radius:6px;z-index:200;font-weight:600;}

/* ---------- Layout ---------- */
.wrap{max-width:var(--maxw);margin-inline:auto;padding-inline:var(--gutter);}
.section{padding-block:var(--section-y);}
.section--surface{background:var(--surface);}
.section--ink{background:var(--ink);color:#fff;}

.eyebrow{
  font-family:var(--font-head);
  font-size:var(--fs-eyebrow);
  font-weight:600;
  letter-spacing:.28em;
  text-transform:uppercase;
  color:var(--muted);
  display:inline-flex;align-items:center;gap:.7em;
  margin:0;
}
.eyebrow::before{
  content:"";width:26px;height:2px;border-radius:2px;
  background:linear-gradient(90deg,var(--red),var(--green));
  opacity:var(--accent);
}
.section--ink .eyebrow{color:rgba(255,255,255,.62);}

.lead{font-size:var(--fs-lead);color:var(--muted);line-height:1.55;}
.section--ink .lead{color:rgba(255,255,255,.7);}

/* ---------- Swoosh motif ---------- */
.swoosh{display:block;overflow:visible;}
.swoosh path{fill:url(#swooshGrad);}
.swoosh--mono path{fill:currentColor;}

@media (prefers-reduced-motion:no-preference){
  .swoosh--reveal{
    clip-path:inset(0 100% 0 0);
    animation:swooshWipe 1.15s var(--ease) .3s forwards;
  }
}
@keyframes swooshWipe{to{clip-path:inset(0 0 0 0);}}

/* ---------- Logo lockup ---------- */
.logo{display:inline-flex;flex-direction:column;line-height:1;gap:2px;color:var(--ink);position:relative;}
.logo__img{height:38px;width:auto;display:block;}
.logo__swoosh{width:54px;height:16px;margin-bottom:1px;}
.logo__ons{font-family:var(--font-head);font-weight:700;font-size:1.45rem;letter-spacing:-.01em;}
.logo__sub{display:flex;align-items:baseline;gap:.5em;}
.logo__vision{font-family:var(--font-head);font-weight:500;font-size:.62rem;letter-spacing:.42em;color:var(--ink);}
.logo__fzco{font-family:var(--font-head);font-weight:500;font-size:.52rem;letter-spacing:.34em;color:var(--muted);}
.footer .logo,.logo--light{color:#fff;}
.logo--light .logo__vision{color:#fff;}
.logo--light .logo__fzco{color:rgba(255,255,255,.55);}

/* ---------- Header ---------- */
.header{position:sticky;top:0;z-index:60;background:rgba(255,255,255,.82);backdrop-filter:blur(14px) saturate(1.4);-webkit-backdrop-filter:blur(14px) saturate(1.4);border-bottom:1px solid var(--border);}
.header__inner{display:flex;align-items:center;justify-content:space-between;gap:24px;height:76px;}
.nav{display:flex;align-items:center;gap:4px;}
.nav a{
  position:relative;font-size:.95rem;font-weight:500;color:var(--ink);
  padding:8px 14px;border-radius:var(--radius);transition:color .2s;
}
.nav a .nav__line{
  position:absolute;left:14px;right:14px;bottom:3px;height:2px;border-radius:2px;
  background:linear-gradient(90deg,var(--red),var(--green));
  transform:scaleX(0);transform-origin:left;transition:transform .32s var(--ease);
  opacity:var(--accent);
}
.nav a:hover .nav__line,.nav a[aria-current="true"] .nav__line{transform:scaleX(1);}
.nav a[aria-current="true"]{font-weight:600;}

.header__actions{display:flex;align-items:center;gap:14px;}

/* Language toggle */
.langtoggle{display:inline-flex;border:1px solid var(--border-strong);border-radius:var(--radius-pill);overflow:hidden;background:var(--bg);}
.langtoggle button{
  border:0;background:transparent;padding:6px 13px;font-size:.78rem;font-weight:600;
  font-family:var(--font-head);letter-spacing:.08em;color:var(--muted);transition:.2s;
}
.langtoggle button[aria-pressed="true"]{background:var(--ink);color:#fff;}

/* Mobile menu */
.menu-btn{display:none;border:1px solid var(--border-strong);background:var(--bg);border-radius:var(--radius);width:44px;height:44px;align-items:center;justify-content:center;}
.menu-btn span{display:block;width:18px;height:2px;background:var(--ink);position:relative;}
.menu-btn span::before,.menu-btn span::after{content:"";position:absolute;left:0;width:18px;height:2px;background:var(--ink);transition:.25s;}
.menu-btn span::before{top:-6px;}
.menu-btn span::after{top:6px;}

/* ---------- Buttons ---------- */
.btn{
  --btnbg:var(--ink);--btnfg:#fff;
  position:relative;display:inline-flex;align-items:center;gap:.6em;
  font-family:var(--font-head);font-weight:600;font-size:.98rem;letter-spacing:.01em;
  padding:15px 26px;border-radius:var(--radius);border:1px solid var(--btnbg);
  background:var(--btnbg);color:var(--btnfg);overflow:hidden;
  transition:transform .2s var(--ease),box-shadow .25s,border-color .2s;
  isolation:isolate;
}
.btn::before{
  content:"";position:absolute;inset:0;z-index:-1;opacity:0;
  background:linear-gradient(100deg,var(--red),#9c1733 38%,var(--green));
  transition:opacity .3s;
}
.btn:hover{transform:translateY(-2px);box-shadow:var(--shadow-md);}
.btn:hover::before{opacity:calc(.92*var(--accent));}
.btn:focus-visible{outline:3px solid #5b8def;outline-offset:2px;}
.btn .arrow{transition:transform .25s var(--ease);}
.btn:hover .arrow{transform:translateX(4px);}
.btn--ghost{--btnbg:transparent;--btnfg:var(--ink);border-color:var(--border-strong);}
.btn--ghost:hover{border-color:var(--ink);}
.btn--ghost::before{opacity:0 !important;}
.btn--lg{padding:18px 32px;font-size:1.05rem;}
.btn[disabled]{opacity:.6;cursor:default;transform:none;box-shadow:none;}
.btn-row{display:flex;flex-wrap:wrap;gap:14px;}

/* text link */
.tlink{display:inline-flex;align-items:center;gap:.45em;font-weight:600;position:relative;font-family:var(--font-head);font-size:.95rem;}
.tlink::after{content:"";position:absolute;left:0;right:0;bottom:-3px;height:2px;background:linear-gradient(90deg,var(--red),var(--green));transform:scaleX(0);transform-origin:left;transition:transform .3s var(--ease);opacity:var(--accent);}
.tlink:hover::after{transform:scaleX(1);}
.tlink .arrow{transition:transform .25s var(--ease);}
.tlink:hover .arrow{transform:translateX(3px);}

/* ---------- Cards ---------- */
.grid{display:grid;gap:1px;background:var(--border);border:1px solid var(--border);border-radius:var(--radius-lg);overflow:hidden;}
.grid--3{grid-template-columns:repeat(3,1fr);}
.grid--2{grid-template-columns:repeat(2,1fr);}

.card{
  position:relative;background:var(--bg);padding:38px 34px 34px;
  transition:background .25s;overflow:hidden;
}
.card::after{
  content:"";position:absolute;left:0;bottom:0;height:3px;width:100%;
  background:linear-gradient(90deg,var(--red),var(--green));
  transform:scaleX(0);transform-origin:left;transition:transform .4s var(--ease);opacity:var(--accent);
}
.card:hover{background:var(--surface);}
.card:hover::after{transform:scaleX(1);}
.card__num{font-family:var(--font-head);font-size:.8rem;font-weight:600;letter-spacing:.2em;color:var(--muted-2);}
.card__title{font-size:var(--fs-h3);margin:18px 0 12px;}
.card__body{color:var(--muted);font-size:1rem;line-height:1.6;}

/* ---------- Values strip ---------- */
.values{display:grid;grid-template-columns:repeat(4,1fr);gap:0;}
.value{padding:34px 30px;border-left:1px solid var(--border);}
.value:first-child{border-left:0;}
.value__k{font-family:var(--font-head);font-size:2.4rem;font-weight:700;color:var(--ink);letter-spacing:-.03em;display:flex;}
.value__t{font-family:var(--font-head);font-weight:600;font-size:1.12rem;margin:16px 0 8px;}
.value__d{color:var(--muted);font-size:.97rem;line-height:1.55;}
.section--ink .value{border-color:rgba(255,255,255,.12);}
.section--ink .value__k{color:#fff;}
.section--ink .value__t{color:#fff;}
.section--ink .value__d{color:rgba(255,255,255,.65);}

/* ---------- Stats ---------- */
.stats{display:grid;grid-template-columns:repeat(4,1fr);gap:0;}
.stat{padding:8px 26px;border-left:1px solid rgba(255,255,255,.14);}
.stat:first-child{border-left:0;padding-left:0;}
.stat__k{font-family:var(--font-head);font-weight:700;font-size:clamp(2.4rem,4.5vw,3.4rem);letter-spacing:-.03em;line-height:1;}
.stat__l{margin-top:12px;color:rgba(255,255,255,.62);font-size:.95rem;}

/* ---------- Hero ---------- */
.hero{position:relative;overflow:hidden;padding-top:clamp(48px,7vw,96px);padding-bottom:var(--section-y);}
.hero__swoosh{position:absolute;top:clamp(-40px,2vw,40px);right:-4%;width:min(64vw,920px);opacity:calc(.16 + .84*var(--accent));pointer-events:none;z-index:0;}
.hero__inner{position:relative;z-index:1;max-width:920px;}
.hero h1{font-size:var(--fs-h1);letter-spacing:-.035em;}
.hero h1 .grad{background:linear-gradient(100deg,var(--red),var(--green));-webkit-background-clip:text;background-clip:text;color:transparent;}
.hero__sub{font-size:var(--fs-lead);color:var(--muted);max-width:620px;margin-top:26px;}
.hero__cta{margin-top:38px;}

/* ---------- Misc ---------- */
.split{display:grid;grid-template-columns:1.05fr .95fr;gap:clamp(40px,6vw,90px);align-items:center;}
.kicker-h2{margin-top:18px;}
.section-head{max-width:680px;margin-bottom:clamp(40px,5vw,64px);}
.section-head .lead{margin-top:18px;}
.tag{display:inline-flex;align-items:center;gap:.5em;font-family:var(--font-head);font-size:.78rem;font-weight:600;letter-spacing:.06em;padding:6px 13px;border:1px solid var(--border-strong);border-radius:var(--radius-pill);color:var(--muted);white-space:nowrap;}

/* ---------- Roles list ---------- */
.roles{display:flex;flex-direction:column;border-top:1px solid var(--border);}
.role{display:grid;grid-template-columns:1fr auto;align-items:center;gap:24px;padding:24px 4px;border-bottom:1px solid var(--border);transition:background .2s,padding .25s var(--ease);}
.role:hover{background:var(--surface);padding-inline:20px;}
.role__t{font-family:var(--font-head);font-weight:600;font-size:1.25rem;letter-spacing:-.01em;}
.role__tag{font-family:var(--font-head);font-size:.78rem;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--muted);border:1px solid var(--border-strong);border-radius:var(--radius-pill);padding:8px 16px;white-space:nowrap;}

/* ---------- Contact ---------- */
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(40px,6vw,80px);align-items:start;}
.contact-info{display:flex;flex-direction:column;gap:30px;}
.info-block .info-label{font-family:var(--font-head);font-size:.78rem;font-weight:600;letter-spacing:.16em;text-transform:uppercase;color:var(--muted);margin-bottom:8px;}
.info-block .info-val{font-size:1.08rem;line-height:1.6;}
.info-block .info-val a:hover{color:var(--red);}

/* ---------- Forms ---------- */
.field{display:flex;flex-direction:column;gap:8px;margin-bottom:20px;}
.field label{font-family:var(--font-head);font-size:.82rem;font-weight:600;letter-spacing:.04em;text-transform:uppercase;color:var(--ink);}
.field input,.field textarea{
  font-family:var(--font-body);font-size:1rem;color:var(--ink);
  padding:14px 16px;border:1px solid var(--border-strong);border-radius:var(--radius);
  background:var(--bg);transition:border-color .2s,box-shadow .2s;width:100%;
}
.field textarea{min-height:150px;resize:vertical;}
.field input:focus,.field textarea:focus{
  outline:none;border-color:var(--ink);box-shadow:0 0 0 3px rgba(14,14,14,.07);
}
.field--error input,.field--error textarea{border-color:var(--red);}
.field__err{color:var(--red);font-size:.82rem;display:none;}
.field--error .field__err{display:block;}
.form-note{font-size:.9rem;color:var(--muted);}
.form-ok,.form-err{display:none;align-items:center;gap:10px;padding:16px 18px;border-radius:var(--radius);font-weight:500;}
.form-ok{background:var(--surface);border:1px solid var(--border);border-left:3px solid var(--green);color:var(--ink);}
.form-err{background:#FEF1F3;border:1px solid #F4C8CF;border-left:3px solid var(--red);color:var(--ink);}
.form-ok.show,.form-err.show{display:flex;}
.dot{width:12px;height:12px;border-radius:50%;background:linear-gradient(135deg,var(--red),var(--green));flex:none;}
/* honeypot */
.hp{position:absolute;left:-10000px;width:1px;height:1px;opacity:0;pointer-events:none;}

/* ---------- Footer ---------- */
.footer{background:var(--ink);color:rgba(255,255,255,.7);position:relative;overflow:hidden;}
.footer__sweep{position:absolute;top:-40px;right:-60px;width:560px;opacity:.5;pointer-events:none;color:rgba(255,255,255,.05);}
.footer__top{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:48px;padding-block:clamp(56px,7vw,88px);position:relative;}
.footer h4{color:#fff;font-size:.82rem;letter-spacing:.2em;text-transform:uppercase;font-weight:600;margin-bottom:18px;}
.footer__links{display:flex;flex-direction:column;gap:11px;}
.footer__links a{color:rgba(255,255,255,.66);font-size:.97rem;width:fit-content;transition:color .2s;background:transparent;border:0;padding:0;text-align:left;font-family:var(--font-body);}
.footer__links a:hover{color:#fff;}
.footer__entity{font-size:.9rem;line-height:1.8;color:rgba(255,255,255,.6);}
.footer__entity strong{color:#fff;font-weight:600;}
.footer__entity a:hover{color:#fff;}
.footer__bottom{border-top:1px solid rgba(255,255,255,.12);padding-block:24px;display:flex;justify-content:space-between;gap:16px;flex-wrap:wrap;font-size:.86rem;color:rgba(255,255,255,.5);position:relative;}
.footer__bottom button.linklike{background:transparent;border:0;color:inherit;padding:0;font:inherit;cursor:pointer;}
.footer__bottom button.linklike:hover{color:#fff;}
.footer__legal{position:relative;border-top:1px solid rgba(255,255,255,.12);padding-block:22px;font-size:.86rem;line-height:1.7;color:rgba(255,255,255,.55);}
.footer__legal a{color:inherit;text-decoration:underline;text-underline-offset:2px;}
.footer__tag{margin:18px 0 20px;color:rgba(255,255,255,.6);font-size:.97rem;max-width:32ch;}

/* ---------- Reveal animation ---------- */
@media (prefers-reduced-motion:no-preference){
  .reveal{opacity:0;transform:translateY(20px);transition:opacity .7s var(--ease),transform .7s var(--ease);}
  .reveal.in{opacity:1;transform:none;}
  .reveal[data-d="1"]{transition-delay:.08s;}
  .reveal[data-d="2"]{transition-delay:.16s;}
  .reveal[data-d="3"]{transition-delay:.24s;}
}

/* ---------- Legal overlay (Privacy / Terms) ---------- */
.legal-overlay{
  position:fixed;inset:0;z-index:100;background:rgba(14,14,14,.55);
  display:none;align-items:flex-start;justify-content:center;
  padding:max(20px,4vh) 16px;overflow-y:auto;
  backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);
}
.legal-overlay.open{display:flex;}
.legal-card{
  background:var(--bg);max-width:820px;width:100%;border-radius:var(--radius-lg);
  box-shadow:0 30px 80px -20px rgba(0,0,0,.5);overflow:hidden;
  position:relative;border:1px solid var(--border);
}
.legal-card__head{
  display:flex;align-items:center;justify-content:space-between;gap:16px;
  padding:22px 28px;border-bottom:1px solid var(--border);position:sticky;top:0;background:var(--bg);z-index:2;
}
.legal-card__head h2{font-size:1.35rem;}
.legal-card__close{
  border:0;background:transparent;width:36px;height:36px;border-radius:var(--radius);
  font-size:1.4rem;line-height:1;color:var(--muted);transition:.2s;
}
.legal-card__close:hover{background:var(--surface);color:var(--ink);}
.legal-card__body{padding:28px clamp(20px,4vw,36px) 36px;}
.prose h3{font-size:1.05rem;margin:26px 0 8px;font-family:var(--font-head);}
.prose p{color:var(--muted);margin-bottom:14px;line-height:1.7;}
.prose p strong{color:var(--ink);}
.legal-meta{display:flex;flex-wrap:wrap;gap:8px 20px;font-size:.85rem;color:var(--muted);margin-bottom:16px;}

/* ---------- WordPress generic content (fallback / posts / pages) ---------- */
.wp-content-area{padding-block:var(--section-y);}
.wp-content-area .entry-title{font-size:var(--fs-h2);margin-bottom:24px;}
.wp-content-area .entry-content p{margin-bottom:18px;color:var(--muted);}
.wp-content-area a{color:var(--red);text-decoration:underline;text-underline-offset:2px;}
.alignright{float:right;margin:0 0 1em 1.5em;}
.alignleft{float:left;margin:0 1.5em 1em 0;}
.aligncenter{display:block;margin-inline:auto;}
.wp-caption{max-width:100%;}
.wp-caption-text{font-size:.85rem;color:var(--muted-2);}
.sticky,.gallery-caption,.bypostauthor{}
.screen-reader-text{border:0;clip:rect(1px,1px,1px,1px);clip-path:inset(50%);height:1px;margin:-1px;overflow:hidden;padding:0;position:absolute;width:1px;word-wrap:normal!important;}

/* ---------- Responsive ---------- */
@media (max-width:980px){
  .footer__top{grid-template-columns:1.2fr 1fr 1fr;gap:36px;}
}
@media (max-width:900px){
  .footer__top{grid-template-columns:1fr 1fr;gap:36px;}
  .split{grid-template-columns:1fr;gap:40px;}
  .values{grid-template-columns:repeat(2,1fr);}
  .value:nth-child(odd){border-left:0;}
  .stats{grid-template-columns:repeat(2,1fr);gap:32px 0;}
  .stat{border-left:0;padding-left:0;}
  .contact-grid{grid-template-columns:1fr;}
}
@media (max-width:760px){
  .menu-btn{display:flex;}
  .nav{
    position:fixed;inset:76px 0 auto 0;flex-direction:column;align-items:stretch;gap:0;
    background:var(--bg);border-bottom:1px solid var(--border);padding:8px var(--gutter) 20px;
    transform:translateY(-12px);opacity:0;visibility:hidden;transition:.25s var(--ease);box-shadow:var(--shadow-md);
  }
  .nav.open{transform:none;opacity:1;visibility:visible;}
  .nav a{padding:14px 4px;border-bottom:1px solid var(--border);font-size:1.05rem;}
  .nav a .nav__line{display:none;}
  .grid--3,.grid--2{grid-template-columns:1fr;}
  .footer__top{grid-template-columns:1fr;gap:30px;}
  .role{grid-template-columns:1fr;align-items:flex-start;}
  .role__tag{justify-self:start;}
}
@media (max-width:480px){
  .values{grid-template-columns:1fr;}
  .value{border-left:0;}
}
