/*
Theme Name:  Armand Yomi — Creative Portfolio v2
Theme URI:   https://armandyomi.com
Author:      Armand Yomi
Author URI:  https://armandyomi.com
Description: Cinematic creative portfolio for Armand Yomi. Bilingual EN/FR, WCAG 2.1 AA, SEO-optimised, ultra-responsive.
Version:     2.4.2
Requires at least: 6.4
Tested up to: 6.7
Requires PHP: 8.1
License:     GPL-2.0-or-later
License URI: https://www.gnu.org/licenses/gpl-2.0.html
Text Domain: armandyomi
Domain Path: /languages
Tags: portfolio, dark, bilingual, animation, responsive, accessibility-ready
*/

/* ══════════════════════════════════════════════════════════════
   CSS CUSTOM PROPERTIES
══════════════════════════════════════════════════════════════ */
:root {
  --ay-blue:      #2785C4;
  --ay-navy:      #274B78;
  --ay-gold:      #FBC926;
  --ay-gold-dark: #d4a710;
  --ay-black:  #09111b;
  --ay-dark:   #0d1a27;
  --ay-mid:    #13243a;
  --ay-card:   #162e47;
  --ay-white:  #f0f6fc;
  --ay-muted:  rgba(240,246,252,.72);  /* was .45 → contrast ~5.1:1 ✓ WCAG AA */
  --ay-soft:   rgba(240,246,252,.88);  /* was .65 → contrast ~6.8:1 ✓ WCAG AA */
  --ay-border: rgba(39,133,196,.15);
  --ay-border-h: rgba(39,133,196,.35);
  --ay-font-display: 'Bebas Neue', sans-serif;
  --ay-font-body:    'DM Sans', sans-serif;
  --ay-font-mono:    'Space Mono', monospace;
  --ay-font-size-base: 16px;
  --ay-font-weight-body: 400;   /* was 300 — 300 fails WCAG 1.4.3 for small text */
  --ay-radius:    8px;
  --ay-radius-lg: 16px;
  --ay-transition: cubic-bezier(.25,.46,.45,.94);
  --ay-section-py: clamp(4.5rem, 8vw, 8rem);
  --ay-shadow-sm:   0 4px 20px rgba(9,17,27,.45);
  --ay-shadow-md:   0 12px 40px rgba(9,17,27,.6);
  --ay-shadow-glow: 0 0 30px rgba(39,133,196,.2);
}

/* ══════════════════════════════════════════════════════════════
   RESET & BASE
══════════════════════════════════════════════════════════════ */
*, *::before, *::after { margin:0; padding:0; box-sizing:border-box; }
html { scroll-behavior:smooth; font-size:var(--ay-font-size-base); -webkit-text-size-adjust:100%; }
body {
  background:var(--ay-black); color:var(--ay-white);
  font-family:var(--ay-font-body); font-weight:var(--ay-font-weight-body);
  line-height:1.65; overflow-x:hidden;
  -webkit-font-smoothing:antialiased; -moz-osx-font-smoothing:grayscale;
}
img, video { max-width:100%; height:auto; display:block; }
a { color:inherit; text-decoration:none; }
ul { list-style:none; }
button, input, textarea, select { font-family:inherit; }
:focus-visible { outline:2px solid var(--ay-gold); outline-offset:3px; border-radius:3px; }
::selection { background:rgba(251,201,38,.25); color:var(--ay-white); }

/* ══════════════════════════════════════════════════════════════
   ACCESSIBILITY
══════════════════════════════════════════════════════════════ */
.skip-link {
  position:absolute; top:-100%; left:1rem;
  background:var(--ay-gold); color:var(--ay-black);
  padding:.5rem 1rem; font-weight:700; z-index:10000;
  border-radius:0 0 6px 6px; transition:top .2s;
}
.skip-link:focus { top:0; }
.sr-only { position:absolute; width:1px; height:1px; padding:0; margin:-1px; overflow:hidden; clip:rect(0,0,0,0); white-space:nowrap; border:0; }

/* ══════════════════════════════════════════════════════════════
   LOADER
══════════════════════════════════════════════════════════════ */
#ay-loader {
  position:fixed; inset:0; background:var(--ay-black);
  z-index:99999; display:flex; align-items:center; justify-content:center;
  transition:opacity .6s .2s, visibility .6s .2s;
}
#ay-loader.done { opacity:0; visibility:hidden; pointer-events:none; }
.loader-inner { text-align:center; }
.loader-logo { font-family:var(--ay-font-display); font-size:3rem; letter-spacing:.3em; color:var(--ay-white); margin-bottom:1.5rem; }
.loader-logo span { color:var(--ay-gold); }
.loader-bar-wrap { width:160px; height:2px; background:rgba(255,255,255,.08); margin:0 auto; border-radius:2px; overflow:hidden; }
.loader-bar { height:100%; width:0; background:linear-gradient(90deg,var(--ay-blue),var(--ay-gold)); animation:loader-fill 1.2s var(--ay-transition) forwards; }
@keyframes loader-fill { to { width:100%; } }

/* ══════════════════════════════════════════════════════════════
   CUSTOM CURSOR
══════════════════════════════════════════════════════════════ */
#ay-cursor {
  position:fixed; width:10px; height:10px;
  background:var(--ay-gold); border-radius:50%;
  pointer-events:none; z-index:9999;
  transform:translate(-50%,-50%);
  transition:width .3s, height .3s, background .3s;
  will-change:left,top;
}
#ay-cursor-ring {
  position:fixed; width:36px; height:36px;
  border:1.5px solid rgba(39,133,196,.5); border-radius:50%;
  pointer-events:none; z-index:9998;
  transform:translate(-50%,-50%); transition:opacity .3s;
  will-change:left,top;
}
body.cursor-hover #ay-cursor { width:44px; height:44px; background:var(--ay-blue); }
body.cursor-hover #ay-cursor-ring { opacity:0; }
@media (pointer:coarse) { #ay-cursor, #ay-cursor-ring { display:none; } }

/* ══════════════════════════════════════════════════════════════
   PAGE TRANSITION
══════════════════════════════════════════════════════════════ */
#ay-transition {
  position:fixed; inset:0; background:var(--ay-navy);
  z-index:9990; pointer-events:none; transform:translateY(100%);
}
#ay-transition.entering { animation:page-wipe .85s var(--ay-transition) forwards; }
@keyframes page-wipe {
  0%{transform:translateY(100%)} 45%{transform:translateY(0)} 55%{transform:translateY(0)} 100%{transform:translateY(-100%)}
}

/* ══════════════════════════════════════════════════════════════
   NAVIGATION — auto-hide on scroll, reappear on hover/scroll-up
══════════════════════════════════════════════════════════════ */
#masthead {
  position:fixed; top:0; left:0; right:0; z-index:1000;
  display:flex; align-items:center; justify-content:space-between;
  padding:1.2rem clamp(1.25rem,4vw,3rem);
  transition:transform .45s var(--ay-transition), background .4s, padding .4s, box-shadow .4s;
  background:transparent;
}
#masthead.scrolled {
  background:rgba(9,17,27,.94);
  backdrop-filter:blur(14px); -webkit-backdrop-filter:blur(14px);
  box-shadow:0 1px 0 var(--ay-border);
  padding-top:.9rem; padding-bottom:.9rem;
}
#masthead.nav-hidden { transform:translateY(-100%); }
#masthead:hover, #masthead.nav-visible { transform:translateY(0) !important; }

/* Logo */
.site-logo { display:flex; align-items:center; z-index:1001; position:relative; }
.site-logo img { height:44px; width:auto; transition:opacity .3s; }
.site-logo img:hover { opacity:.85; }
.site-logo-text { font-family:var(--ay-font-display); font-size:1.5rem; letter-spacing:.2em; color:var(--ay-white); }
.site-logo-text .accent { color:var(--ay-gold); }

/* Desktop nav links */
.primary-nav { display:flex; align-items:center; gap:2rem; }
.nav-menu { display:flex; gap:2rem; align-items:center; }
.nav-menu > li { position:relative; }
.nav-menu a {
  font-family:var(--ay-font-mono); font-size:.68rem;
  letter-spacing:.14em; text-transform:uppercase;
  color:rgba(240,246,252,.6); transition:color .3s;
  display:flex; align-items:center; gap:.35rem; padding:.25rem 0;
}
.nav-menu a:hover, .nav-menu .current-menu-item > a { color:var(--ay-white); }
.nav-menu > li > a::after {
  content:''; position:absolute; bottom:-2px; left:0;
  width:0; height:1.5px; background:var(--ay-gold); transition:width .3s;
}
.nav-menu > li > a:hover::after { width:100%; }

/* Dropdown — desktop */
.nav-menu .sub-menu {
  position:absolute; top:100%; left:50%;          /* top:100% = collé au parent, plus de gap */
  transform:translateX(-50%) translateY(-6px);
  background:var(--ay-card); border:1px solid var(--ay-border);
  border-radius:var(--ay-radius);
  padding:calc(.5rem + 10px) .5rem .5rem;         /* padding-top inclut le pont invisible (10px) */
  margin-top:-10px;                               /* remonte de 10px → crée un pont invisible */
  min-width:210px; opacity:0; visibility:hidden;
  /* délai de 180ms sur la fermeture — donne le temps de traverser le pont */
  transition:opacity .25s .18s, transform .25s .18s, visibility .25s .18s;
  pointer-events:none; box-shadow:var(--ay-shadow-md);
}
.nav-menu li:hover > .sub-menu,
.nav-menu li:focus-within > .sub-menu {
  opacity:1; visibility:visible;
  transform:translateX(-50%) translateY(0); pointer-events:auto;
  /* ouverture instantanée — pas de délai */
  transition:opacity .2s 0s, transform .2s 0s, visibility .2s 0s;
}
.nav-menu .sub-menu a {
  display:block; padding:.55rem .9rem; border-radius:5px;
  font-size:.63rem; letter-spacing:.1em; white-space:nowrap;
  transition:background .2s, color .2s; color:rgba(240,246,252,.65);
}
.nav-menu .sub-menu a:hover { background:rgba(39,133,196,.15); color:var(--ay-gold); }
.nav-menu .sub-menu a::after { display:none !important; }
/* Chevron indicator for items with sub-menus */
.nav-menu > li.menu-item-has-children > a::before {
  content:''; display:inline-block; width:0; height:0;
  border-left:4px solid transparent; border-right:4px solid transparent;
  border-top:4px solid currentColor; margin-left:4px;
  transition:transform .25s; vertical-align:middle;
}
.nav-menu > li.menu-item-has-children:hover > a::before { transform:rotate(180deg); }

/* CTA button */
.nav-cta {
  font-family:var(--ay-font-mono); font-size:.65rem;
  letter-spacing:.14em; text-transform:uppercase;
  background:var(--ay-gold); color:var(--ay-black) !important;
  padding:.65rem 1.4rem; border-radius:100px; font-weight:700;
  transition:background .3s, transform .2s, box-shadow .3s; white-space:nowrap;
}
.nav-cta:hover { background:var(--ay-gold-dark); transform:translateY(-1px); box-shadow:0 6px 20px rgba(251,201,38,.3); }
.nav-cta::after { display:none !important; }
.nav-cta::before { display:none !important; }

/* Lang switcher */
.lang-switcher { display:flex; gap:.4rem; align-items:center; }
.lang-switcher a {
  font-family:var(--ay-font-mono); font-size:.58rem; letter-spacing:.12em; text-transform:uppercase;
  color:var(--ay-muted); padding:.28rem .55rem;
  border:1px solid transparent; border-radius:100px; transition:all .3s;
}
.lang-switcher a.active, .lang-switcher a:hover { color:var(--ay-gold); border-color:rgba(251,201,38,.35); }

/* ── Hamburger button ──────────────────────────────────────────────── */
.menu-toggle {
  display:none; flex-direction:column; gap:5px;
  background:none; border:none; cursor:pointer;
  padding:.5rem; z-index:1002; position:relative;
}
.menu-toggle span {
  display:block; width:22px; height:1.5px;
  background:var(--ay-white); transition:all .35s; transform-origin:center;
}
.menu-toggle.active span:nth-child(1) { transform:rotate(45deg) translate(4.5px,4.5px); }
.menu-toggle.active span:nth-child(2) { opacity:0; transform:scaleX(0); }
.menu-toggle.active span:nth-child(3) { transform:rotate(-45deg) translate(4.5px,-4.5px); }

/* ══════════════════════════════════════════════════════════════
   MOBILE NAVIGATION — Rebuilt completely
   Full-screen drawer, slides from right, all items visible
══════════════════════════════════════════════════════════════ */
@media (max-width:900px) {
  .menu-toggle { display:flex; }

  /* Hide desktop nav elements inline */
  .primary-nav .lang-switcher,
  .primary-nav .nav-cta { display:none; }

  /* Full screen overlay drawer — Fix #6: full viewport height on iOS/Android */
  .primary-nav {
    display:block;
    position:fixed;
    top:0; right:0;
    width:min(320px, 85vw);
    height:100vh;
    height:100dvh; /* dynamic viewport — accounts for mobile browser chrome */
    min-height:-webkit-fill-available;
    background:var(--ay-dark);
    border-left:1px solid var(--ay-border);
    z-index:1001;
    transform:translateX(100%);
    transition:transform .4s var(--ay-transition);
    overflow-y:auto;
    padding:5rem 0 2rem;
    box-shadow:-20px 0 60px rgba(0,0,0,.5);
  }
  .primary-nav.open { transform:translateX(0); }

  /* Mobile backdrop */
  .nav-backdrop {
    display:none; position:fixed; inset:0;
    background:rgba(9,17,27,.75); z-index:1000;
    backdrop-filter:blur(4px); -webkit-backdrop-filter:blur(4px);
  }
  .nav-backdrop.visible { display:block; }

  /* Nav menu in mobile */
  .nav-menu {
    flex-direction:column; gap:0;
    padding:0 1.25rem 1.5rem; width:100%;
  }
  .nav-menu > li {
    width:100%;
    border-bottom:1px solid rgba(39,133,196,.1);
  }
  .nav-menu > li:first-child { border-top:1px solid rgba(39,133,196,.1); }

  /* Top-level links — large, readable */
  .nav-menu > li > a {
    font-size:.85rem; letter-spacing:.16em;
    padding:1rem .5rem;
    color:rgba(240,246,252,.8);
    display:flex; justify-content:space-between; align-items:center;
    width:100%;
  }
  .nav-menu > li > a:hover,
  .nav-menu > li.sub-open > a { color:var(--ay-gold); }
  .nav-menu > li > a::after { display:none !important; }

  /* Chevron for mobile sub-menu toggle */
  .nav-menu > li.menu-item-has-children > a .sub-arrow {
    display:inline-flex; align-items:center; justify-content:center;
    width:28px; height:28px; border-radius:50%;
    background:rgba(39,133,196,.12); flex-shrink:0;
    transition:transform .3s, background .3s;
  }
  .nav-menu > li.menu-item-has-children > a .sub-arrow::after {
    content:''; display:block; width:0; height:0;
    border-left:5px solid transparent; border-right:5px solid transparent;
    border-top:5px solid var(--ay-blue);
  }
  .nav-menu > li.menu-item-has-children.sub-open > a .sub-arrow {
    transform:rotate(180deg); background:rgba(251,201,38,.15);
  }
  .nav-menu > li.menu-item-has-children.sub-open > a .sub-arrow::after {
    border-top-color:var(--ay-gold);
  }

  /* Sub-menu — inline reveal */
  .nav-menu .sub-menu {
    position:static; transform:none;
    background:rgba(39,133,196,.06);
    border:none; border-radius:var(--ay-radius);
    padding:0; margin:.25rem 0 .5rem;
    opacity:1; visibility:visible; pointer-events:auto;
    display:none; /* toggled by JS */
    box-shadow:none; min-width:auto;
  }
  .nav-menu li.sub-open > .sub-menu { display:block; }
  .nav-menu .sub-menu li { border-bottom:1px solid rgba(39,133,196,.07); }
  .nav-menu .sub-menu li:last-child { border-bottom:none; }
  .nav-menu .sub-menu a {
    font-size:.72rem; letter-spacing:.12em;
    padding:.75rem 1rem .75rem 1.25rem;
    color:rgba(240,246,252,.6);
    display:flex; align-items:center; gap:.5rem;
    white-space:normal;
  }
  .nav-menu .sub-menu a::before {
    content:''; width:5px; height:5px; border-radius:50%;
    background:var(--ay-blue); flex-shrink:0;
  }
  .nav-menu .sub-menu a:hover { color:var(--ay-gold); background:none; }
  .nav-menu .sub-menu a::after { display:none !important; }

  /* Mobile CTA and lang inside drawer — Fix #1: visible inside drawer */
  .mobile-nav-footer {
    padding:1.5rem 1.75rem;
    display:flex !important; flex-direction:column; gap:1rem;
    border-top:1px solid var(--ay-border); margin-top:.5rem;
  }
  .mobile-nav-cta {
    display:inline-flex; align-items:center; justify-content:center; gap:.5rem;
    background:var(--ay-gold); color:var(--ay-black);
    font-family:var(--ay-font-mono); font-size:.7rem; letter-spacing:.14em;
    text-transform:uppercase; font-weight:700;
    padding:.9rem 1.5rem; border-radius:100px;
    transition:background .3s;
  }
  .mobile-nav-cta:hover { background:var(--ay-gold-dark); }
  .mobile-lang { display:flex; gap:.5rem; }
  .mobile-lang a {
    font-family:var(--ay-font-mono); font-size:.6rem; letter-spacing:.12em;
    text-transform:uppercase; color:var(--ay-muted);
    border:1px solid transparent; border-radius:100px; padding:.3rem .6rem;
    transition:all .3s;
  }
  .mobile-lang a.active, .mobile-lang a:hover { color:var(--ay-gold); border-color:rgba(251,201,38,.35); }
}

/* Mobile nav footer hidden by default on desktop */
.mobile-nav-footer { display:none; }


#scroll-progress {
  position:fixed; top:0; left:0; height:2px;
  background:linear-gradient(90deg,var(--ay-blue),var(--ay-gold));
  z-index:10001; width:0%; transition:width .1s; pointer-events:none;
}

/* ══════════════════════════════════════════════════════════════
   HERO SECTION
══════════════════════════════════════════════════════════════ */
#hero {
  min-height:100vh; display:flex; flex-direction:column;
  align-items:center; justify-content:center; text-align:center;
  padding:clamp(6rem,12vw,9rem) clamp(1.5rem,5vw,4rem) clamp(3rem,5vw,5rem);
  position:relative; overflow:hidden;
}
.hero-bg-grid {
  position:absolute; inset:0; pointer-events:none;
  background-image:linear-gradient(rgba(39,133,196,.04) 1px, transparent 1px),
    linear-gradient(90deg,rgba(39,133,196,.04) 1px, transparent 1px);
  background-size:70px 70px; animation:grid-drift 28s linear infinite;
}
@keyframes grid-drift { to { background-position:70px 70px; } }
.hero-bg-glow {
  position:absolute; inset:0; pointer-events:none;
  background:radial-gradient(ellipse 70% 60% at 50% 40%, rgba(39,133,196,.12) 0%, transparent 70%);
}
.hero-bg-image {
  position:absolute; inset:0; background-size:cover; background-position:center;
  opacity:.08; filter:grayscale(1) blur(1px); pointer-events:none; transition:opacity 1s;
}
.hero-eyebrow {
  font-family:var(--ay-font-mono); font-size:.68rem; letter-spacing:.28em; text-transform:uppercase;
  color:var(--ay-blue); margin-bottom:1.4rem; position:relative; z-index:2;
  display:flex; align-items:center; justify-content:center; gap:12px;
  animation:fade-up .9s .3s both;
}
.hero-eyebrow::before, .hero-eyebrow::after {
  content:''; display:inline-block; width:28px; height:1px; background:var(--ay-blue);
}
.hero-title {
  font-family:var(--ay-font-display); font-size:clamp(3.5rem,12vw,11rem);
  line-height:.9; letter-spacing:-.01em; color:var(--ay-white);
  position:relative; z-index:2; animation:fade-up .9s .5s both;
}
.hero-title .accent {
  color:var(--ay-gold); display:inline-block;
  animation:accent-pulse 3s ease-in-out 1.4s infinite; position:relative;
}
.hero-title .accent::after {
  content:''; position:absolute; bottom:-4px; left:0; right:0; height:3px;
  background:linear-gradient(90deg,var(--ay-blue),var(--ay-gold),var(--ay-blue));
  background-size:200% 100%; border-radius:2px;
  animation:shimmer-line 2.5s linear 1.4s infinite;
}
@keyframes accent-pulse {
  0%,100%{text-shadow:0 0 0px transparent} 50%{text-shadow:0 0 40px rgba(251,201,38,.35),0 0 80px rgba(251,201,38,.12)}
}
@keyframes shimmer-line { 0%{background-position:200% 0} 100%{background-position:-200% 0} }
.hero-desc {
  font-size:clamp(.9rem,1.4vw,1.1rem); line-height:1.75; color:var(--ay-soft);
  max-width:560px; margin:1.8rem auto 0; position:relative; z-index:2;
  animation:fade-up .9s .7s both;
}
.hero-cta-group {
  display:flex; gap:1rem; justify-content:center; flex-wrap:wrap;
  margin-top:2.5rem; position:relative; z-index:2; animation:fade-up .9s .9s both;
}
.hero-scroll-hint {
  display:flex; flex-direction:column; align-items:center; gap:8px;
  font-family:var(--ay-font-mono); font-size:.58rem; letter-spacing:.2em;
  text-transform:uppercase; color:var(--ay-muted); text-decoration:none;
  margin-top:3.5rem; position:relative; z-index:2; animation:fade-up .9s 1.1s both;
}
.scroll-line { width:1px; height:50px; background:linear-gradient(var(--ay-blue),transparent); animation:scroll-pulse 2.2s ease-in-out infinite; }
@keyframes scroll-pulse { 0%,100%{opacity:1}50%{opacity:.2} }

/* ══════════════════════════════════════════════════════════════
   BUTTONS
══════════════════════════════════════════════════════════════ */
.btn-primary {
  display:inline-flex; align-items:center; gap:10px;
  background:var(--ay-gold); color:var(--ay-black);
  font-family:var(--ay-font-mono); font-size:.7rem; letter-spacing:.14em;
  text-transform:uppercase; padding:.95rem 2rem; border-radius:100px;
  font-weight:700; transition:background .3s, transform .2s, box-shadow .3s;
  border:none; cursor:pointer;
}
.btn-primary:hover { background:var(--ay-gold-dark); transform:translateY(-2px); box-shadow:0 8px 24px rgba(251,201,38,.3); }
.btn-secondary {
  display:inline-flex; align-items:center; gap:8px;
  font-family:var(--ay-font-mono); font-size:.7rem; letter-spacing:.14em;
  text-transform:uppercase; color:var(--ay-white); background:transparent;
  border:1.5px solid rgba(39,133,196,.45); padding:.9rem 2rem;
  border-radius:100px; transition:all .3s; cursor:pointer;
}
.btn-secondary:hover { border-color:var(--ay-blue); background:rgba(39,133,196,.1); transform:translateY(-2px); }
.btn-ghost {
  display:inline-flex; align-items:center; gap:6px;
  font-family:var(--ay-font-mono); font-size:.68rem; letter-spacing:.12em;
  text-transform:uppercase; color:var(--ay-soft);
  border-bottom:1px solid rgba(240,246,252,.2); padding-bottom:3px;
  transition:color .3s, border-color .3s;
}
.btn-ghost:hover { color:var(--ay-gold); border-color:var(--ay-gold); }
/* btn-outline: bordered accent ring, filled on hover */
.btn-outline {
  display:inline-flex; align-items:center; gap:8px;
  font-family:var(--ay-font-mono); font-size:.7rem; letter-spacing:.14em;
  text-transform:uppercase; color:var(--ay-gold); background:transparent;
  border:1.5px solid var(--ay-gold); padding:.9rem 2rem;
  border-radius:100px; transition:all .3s; cursor:pointer;
}
.btn-outline:hover { background:var(--ay-gold); color:var(--ay-black); transform:translateY(-2px); box-shadow:0 8px 24px rgba(251,201,38,.25); }

/* Multi-CTA group: wrap on mobile */
.hero-cta-group { display:flex; flex-wrap:wrap; gap:1rem; align-items:center; margin-top:2.5rem; }

/* ══════════════════════════════════════════════════════════════
   MARQUEE
══════════════════════════════════════════════════════════════ */
.ay-marquee-wrap { padding:1rem 0; overflow:hidden; background:var(--ay-mid); border-top:1px solid var(--ay-border); border-bottom:1px solid var(--ay-border); }
.ay-marquee-track { display:flex; animation:marquee-scroll 24s linear infinite; white-space:nowrap; }
.ay-marquee-track:hover { animation-play-state:paused; }
@keyframes marquee-scroll { to { transform:translateX(-50%); } }
.ay-marquee-item { display:inline-flex; align-items:center; gap:1.2rem; padding:0 1.2rem; font-family:var(--ay-font-mono); font-size:.72rem; letter-spacing:.12em; text-transform:uppercase; color:rgba(240,246,252,.22); }
.ay-marquee-item .dot { color:var(--ay-gold); font-size:.4rem; }

/* ══════════════════════════════════════════════════════════════
   SECTION COMMONS
══════════════════════════════════════════════════════════════ */
.ay-section { padding:var(--ay-section-py) clamp(1.25rem,5vw,3rem); border-top:1px solid var(--ay-border); }
.ay-section--dark  { background:var(--ay-dark); }
.ay-section--mid   { background:var(--ay-mid); }
.ay-section--navy  { background:var(--ay-navy); }
.ay-section--accent { background:var(--ay-gold); color:var(--ay-black); }
.section-label {
  font-family:var(--ay-font-mono); font-size:.62rem; letter-spacing:.25em; text-transform:uppercase;
  color:var(--ay-blue); margin-bottom:2rem; display:flex; align-items:center; gap:10px;
}
.section-label::after { content:''; flex:1; max-width:45px; height:1px; background:var(--ay-blue); opacity:.5; }
.ay-section--accent .section-label { color:rgba(9,17,27,.55); }
.ay-section--accent .section-label::after { background:rgba(9,17,27,.3); }

/* ══════════════════════════════════════════════════════════════
   ABOUT
══════════════════════════════════════════════════════════════ */
.about-grid { display:grid; grid-template-columns:1fr 1fr; gap:clamp(3rem,6vw,7rem); align-items:center; }
@media(max-width:768px){.about-grid{grid-template-columns:1fr;gap:3rem;}}
.about-title { font-family:var(--ay-font-display); font-size:clamp(2.8rem,7vw,7rem); line-height:.9; letter-spacing:-.01em; }
.about-title .accent { color:var(--ay-gold); }
.about-text { font-size:clamp(.85rem,1.1vw,1rem); line-height:1.8; color:var(--ay-soft); margin-bottom:1.25rem; }
.about-photo { position:relative; border-radius:var(--ay-radius-lg); overflow:hidden; aspect-ratio:4/5; transition:transform .5s, box-shadow .5s; }
.about-photo:hover { transform:scale(1.01); box-shadow:var(--ay-shadow-glow); }
.about-photo img { width:100%; height:100%; object-fit:cover; }
.about-badge { position:absolute; bottom:1.25rem; right:1.25rem; background:var(--ay-gold); color:var(--ay-black); font-family:var(--ay-font-mono); font-size:.6rem; letter-spacing:.12em; text-transform:uppercase; font-weight:700; padding:.5rem 1.1rem; border-radius:100px; }

/* ══════════════════════════════════════════════════════════════
   STATS — animated single instance
══════════════════════════════════════════════════════════════ */
.stats-row { display:flex; gap:clamp(1.5rem,3vw,3rem); flex-wrap:wrap; margin-top:2.5rem; }
.stat-item { min-width:70px; }
.stat-num { font-family:var(--ay-font-display); font-size:clamp(2.2rem,4vw,3.5rem); color:var(--ay-gold); line-height:1; }
.stat-label { font-family:var(--ay-font-mono); font-size:.58rem; letter-spacing:.12em; text-transform:uppercase; color:var(--ay-muted); margin-top:5px; }

/* ══════════════════════════════════════════════════════════════
   PORTFOLIO GRID
══════════════════════════════════════════════════════════════ */
.work-header { display:flex; align-items:flex-end; justify-content:space-between; margin-bottom:2rem; flex-wrap:wrap; gap:1rem; }
.work-title { font-family:var(--ay-font-display); font-size:clamp(2.5rem,6vw,6rem); line-height:.9; }
.portfolio-filter { display:flex; gap:.6rem; flex-wrap:wrap; margin-bottom:2.5rem; }
.filter-btn { font-family:var(--ay-font-mono); font-size:.6rem; letter-spacing:.12em; text-transform:uppercase; background:none; border:1px solid var(--ay-border); color:var(--ay-muted); padding:.5rem 1.1rem; border-radius:100px; cursor:pointer; transition:all .3s; }
.filter-btn:hover, .filter-btn.active { background:var(--ay-gold); color:var(--ay-black); border-color:var(--ay-gold); }
.projects-grid { display:grid; grid-template-columns:repeat(12,1fr); gap:3px; }
.project-card { position:relative; overflow:hidden; background:var(--ay-mid); cursor:pointer; border-radius:3px; transform-style:preserve-3d; transition:transform .5s var(--ay-transition), box-shadow .5s; }
.project-card.card-lg { grid-column:span 8; aspect-ratio:16/8; }
.project-card.card-sm { grid-column:span 4; aspect-ratio:4/4; }
.project-card.card-md { grid-column:span 6; aspect-ratio:4/3; }
@media(max-width:900px){.project-card{grid-column:span 12 !important; aspect-ratio:4/3 !important;}}
.project-card:hover { box-shadow:var(--ay-shadow-glow), var(--ay-shadow-md); z-index:2; }
.project-img { position:absolute; inset:0; width:100%; height:100%; object-fit:cover; transition:transform .7s var(--ay-transition), filter .5s; }
.project-card:hover .project-img { transform:scale(1.05); filter:brightness(.85); }
.project-overlay { position:absolute; inset:0; background:linear-gradient(transparent 25%, rgba(9,17,27,.88) 100%); display:flex; flex-direction:column; justify-content:flex-end; padding:1.75rem; transition:background .4s; }
.project-card:hover .project-overlay { background:linear-gradient(transparent 10%, rgba(9,17,27,.8) 100%); }
.project-cat { font-family:var(--ay-font-mono); font-size:.57rem; letter-spacing:.18em; text-transform:uppercase; color:var(--ay-gold); margin-bottom:.45rem; opacity:0; transform:translateY(8px); transition:all .4s .05s; }
.project-card:hover .project-cat { opacity:1; transform:translateY(0); }
.project-name { font-family:var(--ay-font-display); font-size:clamp(1.4rem,2.5vw,2.2rem); letter-spacing:.02em; transform:translateY(6px); transition:transform .4s; }
.project-card.card-lg .project-name { font-size:clamp(2rem,3.5vw,3rem); }
.project-card:hover .project-name { transform:translateY(0); }
.project-arrow { position:absolute; top:1.25rem; right:1.25rem; width:38px; height:38px; border:1px solid rgba(255,255,255,.22); border-radius:50%; display:flex; align-items:center; justify-content:center; opacity:0; transform:scale(.7); transition:all .4s; background:rgba(9,17,27,.4); }
.project-card:hover .project-arrow { opacity:1; transform:scale(1); }
.project-arrow svg { width:13px; height:13px; fill:none; stroke:var(--ay-white); stroke-width:1.5; }

/* ══════════════════════════════════════════════════════════════
   GALLERY GRID — tiles are full links
══════════════════════════════════════════════════════════════ */
.gallery-filter { display:flex; gap:.6rem; flex-wrap:wrap; margin-bottom:2.5rem; }
.gallery-grid { display:grid; grid-template-columns:repeat(auto-fill,minmax(280px,1fr)); gap:3px; }
.gallery-item {
  position:relative; overflow:hidden; aspect-ratio:4/3;
  background:var(--ay-mid); border-radius:3px;
  transform-style:preserve-3d;
  transition:transform .5s var(--ay-transition), box-shadow .5s;
  display:block; /* make the anchor itself the tile */
  text-decoration:none; color:inherit;
}
.gallery-item:hover { transform:scale(1.02) rotateY(1deg); box-shadow:var(--ay-shadow-glow); }
.gallery-item img { width:100%; height:100%; object-fit:cover; transition:transform .6s var(--ay-transition), filter .5s; }
.gallery-item:hover img { transform:scale(1.07); filter:brightness(.75); }
.gallery-overlay { position:absolute; inset:0; background:linear-gradient(transparent 40%, rgba(9,17,27,.9) 100%); display:flex; flex-direction:column; justify-content:flex-end; padding:1.5rem; opacity:0; transition:opacity .4s; }
.gallery-item:hover .gallery-overlay { opacity:1; }
.gallery-cat { font-family:var(--ay-font-mono); font-size:.57rem; letter-spacing:.15em; text-transform:uppercase; color:var(--ay-gold); margin-bottom:.4rem; }
.gallery-title { font-family:var(--ay-font-display); font-size:1.3rem; line-height:1.1; color:var(--ay-white); }
/* Arrow icon on gallery tile */
.gallery-link-arrow { position:absolute; top:1rem; right:1rem; width:34px; height:34px; border:1px solid rgba(255,255,255,.2); border-radius:50%; display:flex; align-items:center; justify-content:center; background:rgba(9,17,27,.4); opacity:0; transform:scale(.7); transition:all .4s; }
.gallery-item:hover .gallery-link-arrow { opacity:1; transform:scale(1); }
.gallery-link-arrow svg { width:12px; height:12px; fill:none; stroke:var(--ay-white); stroke-width:1.5; }

/* Fix #5: Full-card clickable link */
.gallery-card-link {
  position:absolute; inset:0; z-index:2;
  display:block; cursor:pointer;
}
.gallery-item .project-arrow { z-index:3; }

/* ══════════════════════════════════════════════════════════════
   SERVICES — two-tier
══════════════════════════════════════════════════════════════ */
.services-header-grid { display:grid; grid-template-columns:1fr 1fr; gap:4rem; margin-bottom:3.5rem; align-items:end; }
@media(max-width:768px){.services-header-grid{grid-template-columns:1fr;gap:2rem;}}
.services-title { font-family:var(--ay-font-display); font-size:clamp(2.5rem,5.5vw,6rem); line-height:.92; }
.services-intro { font-size:clamp(.85rem,1.1vw,1rem); line-height:1.8; color:var(--ay-soft); }
.services-main-grid { display:grid; grid-template-columns:1fr 1fr; gap:1rem; margin-bottom:2.5rem; }
@media(max-width:700px){.services-main-grid{grid-template-columns:1fr;}}
.service-main-card { background:var(--ay-card); border:1px solid var(--ay-border); border-radius:var(--ay-radius-lg); padding:2.5rem 2rem; position:relative; overflow:hidden; cursor:pointer; transition:transform .4s var(--ay-transition), box-shadow .4s, border-color .4s; transform-style:preserve-3d; }
.service-main-card:hover { transform:translateY(-4px) rotateX(1deg); box-shadow:var(--ay-shadow-glow); border-color:var(--ay-border-h); }
.service-main-card::before { content:''; position:absolute; top:0; left:0; right:0; height:3px; background:linear-gradient(90deg,var(--ay-blue),var(--ay-gold)); transform:scaleX(0); transform-origin:left; transition:transform .4s; }
.service-main-card:hover::before { transform:scaleX(1); }
.service-card-num { font-family:var(--ay-font-display); font-size:5rem; line-height:1; color:rgba(39,133,196,.07); position:absolute; top:.5rem; right:1.2rem; transition:color .4s; }
.service-main-card:hover .service-card-num { color:rgba(39,133,196,.14); }
.service-card-title { font-family:var(--ay-font-display); font-size:clamp(1.8rem,3vw,2.8rem); letter-spacing:.02em; margin-bottom:1.5rem; position:relative; z-index:1; transition:color .3s; }
.service-main-card:hover .service-card-title { color:var(--ay-gold); }
.service-sub-list { display:flex; flex-direction:column; gap:.6rem; position:relative; z-index:1; }
.service-sub-item { display:flex; align-items:center; gap:.7rem; font-size:.88rem; color:var(--ay-soft); transition:color .3s, transform .3s; }
.service-sub-item:hover { color:var(--ay-white); transform:translateX(4px); }
.service-sub-item::before { content:''; width:5px; height:5px; border-radius:50%; background:var(--ay-blue); flex-shrink:0; transition:background .3s; }
.service-sub-item:hover::before { background:var(--ay-gold); }
.service-card-link { display:inline-flex; align-items:center; gap:6px; margin-top:2rem; font-family:var(--ay-font-mono); font-size:.62rem; letter-spacing:.12em; text-transform:uppercase; color:var(--ay-blue); transition:color .3s, gap .3s; }
.service-main-card:hover .service-card-link { color:var(--ay-gold); gap:10px; }
.services-list { display:flex; flex-direction:column; }
.service-row { display:grid; grid-template-columns:60px 1fr auto; align-items:center; gap:2rem; padding:1.8rem 0; border-bottom:1px solid var(--ay-border); cursor:pointer; transition:padding-left .35s var(--ay-transition); border-radius:4px; }
.service-row:hover { padding-left:.6rem; }
.service-num { font-family:var(--ay-font-mono); font-size:.6rem; color:var(--ay-muted); letter-spacing:.1em; }
.service-name { font-family:var(--ay-font-display); font-size:clamp(1.5rem,2.5vw,2.2rem); letter-spacing:.02em; transition:color .3s; }
.service-row:hover .service-name { color:var(--ay-gold); }
.service-tags { display:flex; gap:5px; flex-wrap:wrap; justify-content:flex-end; }
@media(max-width:600px){.service-tags{display:none;}.service-row{grid-template-columns:50px 1fr;}}
.stag { font-family:var(--ay-font-mono); font-size:.52rem; letter-spacing:.08em; text-transform:uppercase; padding:4px 10px; border:1px solid var(--ay-border); color:var(--ay-muted); border-radius:100px; transition:all .3s; }
.service-row:hover .stag { border-color:rgba(251,201,38,.35); color:var(--ay-gold); }

/* ══════════════════════════════════════════════════════════════
   PROCESS
══════════════════════════════════════════════════════════════ */
.process-title { font-family:var(--ay-font-display); font-size:clamp(2.5rem,6vw,7rem); line-height:.9; max-width:700px; margin-bottom:3.5rem; }
.process-grid { display:grid; grid-template-columns:repeat(auto-fit,minmax(220px,1fr)); gap:2px; }
.process-card { background:var(--ay-mid); padding:2.2rem 1.8rem; position:relative; overflow:hidden; border-radius:3px; transition:background .4s, transform .4s var(--ay-transition); transform-style:preserve-3d; }
.process-card:hover { background:var(--ay-card); transform:translateY(-3px) rotateX(1.5deg); }
.process-deco-num { font-family:var(--ay-font-display); font-size:5rem; color:rgba(39,133,196,.06); position:absolute; top:.3rem; right:1rem; transition:color .4s; }
.process-card:hover .process-deco-num { color:rgba(39,133,196,.14); }
.process-card-title { font-family:var(--ay-font-display); font-size:1.4rem; letter-spacing:.02em; margin-bottom:.7rem; transition:color .3s; }
.process-card:hover .process-card-title { color:var(--ay-gold); }
.process-card-text { font-size:.82rem; line-height:1.7; color:var(--ay-muted); }

/* ══════════════════════════════════════════════════════════════
   TESTIMONIALS — with nav arrows
══════════════════════════════════════════════════════════════ */
.testimonials-wrap { max-width:820px; margin:0 auto; text-align:center; position:relative; }
.testimonial-quote-mark { font-family:var(--ay-font-display); font-size:7rem; line-height:.4; color:rgba(9,17,27,.15); margin-bottom:1.5rem; }
.testimonial-slider { position:relative; min-height:160px; }
.testimonial-slide { display:none; animation:testi-fade .5s ease; }
.testimonial-slide.active { display:block; }
@keyframes testi-fade { from{opacity:0;transform:translateY(10px)} to{opacity:1;transform:translateY(0)} }
.testimonial-text { font-family:var(--ay-font-display); font-size:clamp(1.5rem,3.5vw,2.8rem); line-height:1.15; letter-spacing:-.01em; color:var(--ay-black); margin-bottom:2rem; }
.testimonial-author { font-family:var(--ay-font-mono); font-size:.65rem; letter-spacing:.2em; text-transform:uppercase; color:rgba(9,17,27,.55); }
.testimonial-role { font-family:var(--ay-font-mono); font-size:.58rem; letter-spacing:.15em; text-transform:uppercase; color:rgba(9,17,27,.35); margin-top:.3rem; }
/* Dots */
.testimonial-dots { display:flex; justify-content:center; gap:.6rem; margin-top:2rem; }
.t-dot { width:6px; height:6px; border-radius:50%; background:rgba(9,17,27,.2); border:none; cursor:pointer; transition:all .3s; padding:0; }
.t-dot.active { background:var(--ay-black); transform:scale(1.5); }
/* Arrow buttons */
.testimonial-nav { display:flex; justify-content:center; gap:.8rem; margin-top:1.5rem; }
.testi-arrow {
  width:40px; height:40px; border-radius:50%;
  background:rgba(9,17,27,.08); border:1px solid rgba(9,17,27,.18);
  display:flex; align-items:center; justify-content:center;
  cursor:pointer; transition:all .3s; flex-shrink:0;
}
.testi-arrow:hover { background:var(--ay-black); border-color:var(--ay-black); }
.testi-arrow svg { width:14px; height:14px; fill:none; stroke:rgba(9,17,27,.7); stroke-width:2; transition:stroke .3s; }
.testi-arrow:hover svg { stroke:var(--ay-white); }
/* Auto-play speed indicator */
.testi-progress { width:80px; height:2px; background:rgba(9,17,27,.12); border-radius:2px; margin:1.2rem auto 0; overflow:hidden; }
.testi-progress-bar { height:100%; width:0; background:var(--ay-black); transition:width linear; }

/* ══════════════════════════════════════════════════════════════
   CONTACT SECTION (homepage + contact page)
══════════════════════════════════════════════════════════════ */
.contact-section { text-align:center; }
.contact-title { font-family:var(--ay-font-display); font-size:clamp(4rem,11vw,11rem); line-height:.88; letter-spacing:-.02em; margin-bottom:1.5rem; }
.contact-email { font-family:var(--ay-font-mono); font-size:.85rem; letter-spacing:.1em; color:var(--ay-soft); display:inline-block; border-bottom:1px solid rgba(240,246,252,.15); padding-bottom:4px; transition:all .3s; }
.contact-email:hover { color:var(--ay-gold); border-color:var(--ay-gold); }
/* Contact page two-col */
.contact-page-grid { display:grid; grid-template-columns:1fr 1fr; gap:5rem; align-items:start; }
@media(max-width:900px){.contact-page-grid{grid-template-columns:1fr;gap:3rem;}}
.contact-method { display:flex; flex-direction:column; gap:.3rem; padding:1.1rem 0; border-bottom:1px solid var(--ay-border); text-decoration:none; transition:padding-left .3s; }
.contact-method:hover { padding-left:.5rem; }
.contact-method-label { font-family:var(--ay-font-mono); font-size:.58rem; letter-spacing:.14em; text-transform:uppercase; color:var(--ay-muted); }
.contact-method-value { font-size:1rem; color:var(--ay-white); transition:color .3s; }
.contact-method:hover .contact-method-value { color:var(--ay-gold); }
/* Form */
.contact-form-wrap { max-width:620px; margin:3.5rem auto 0; text-align:left; }
.form-row { display:grid; grid-template-columns:1fr 1fr; gap:.9rem; margin-bottom:.9rem; }
@media(max-width:600px){.form-row{grid-template-columns:1fr;}}
.form-field { display:flex; flex-direction:column; gap:.35rem; margin-bottom:.9rem; }
.form-field label { font-family:var(--ay-font-mono); font-size:.58rem; letter-spacing:.14em; text-transform:uppercase; color:var(--ay-muted); }
.form-field input, .form-field textarea, .form-field select { background:var(--ay-mid); border:1px solid var(--ay-border); color:var(--ay-white); padding:.8rem 1rem; border-radius:var(--ay-radius); font-size:.9rem; transition:border-color .3s, box-shadow .3s; width:100%; }
.form-field input:focus, .form-field textarea:focus, .form-field select:focus { border-color:var(--ay-blue); outline:none; box-shadow:0 0 0 3px rgba(39,133,196,.12); }
.form-field textarea { resize:vertical; min-height:130px; }
.form-field select option { background:var(--ay-mid); }
.form-submit { width:100%; background:var(--ay-gold); color:var(--ay-black); border:none; padding:1rem; border-radius:100px; font-family:var(--ay-font-mono); font-size:.72rem; letter-spacing:.15em; text-transform:uppercase; font-weight:700; cursor:pointer; transition:background .3s, transform .2s, box-shadow .3s; }
.form-submit:hover { background:var(--ay-gold-dark); transform:translateY(-1px); box-shadow:0 8px 24px rgba(251,201,38,.28); }
.form-message { font-family:var(--ay-font-mono); font-size:.7rem; letter-spacing:.1em; margin-top:.8rem; }
.form-message.success { color:var(--ay-gold); }
.form-message.error { color:#ff7272; }

/* ══════════════════════════════════════════════════════════════
   FOOTER
══════════════════════════════════════════════════════════════ */
#colophon { padding:2rem clamp(1.25rem,5vw,3rem); border-top:1px solid var(--ay-border); display:flex; align-items:center; justify-content:space-between; gap:1.5rem; flex-wrap:wrap; background:var(--ay-dark); }
.footer-copy { font-family:var(--ay-font-mono); font-size:.58rem; letter-spacing:.12em; color:var(--ay-muted); }
.footer-social { display:flex; gap:1.5rem; }
.footer-social a { font-family:var(--ay-font-mono); font-size:.58rem; letter-spacing:.12em; text-transform:uppercase; color:var(--ay-muted); transition:color .3s; }
.footer-social a:hover { color:var(--ay-gold); }
@media(max-width:600px){#colophon{flex-direction:column;text-align:center;}}

/* ══════════════════════════════════════════════════════════════
   COOKIE BANNER
══════════════════════════════════════════════════════════════ */
#cookie-banner { position:fixed; bottom:1.25rem; left:1.25rem; right:1.25rem; max-width:480px; background:var(--ay-card); border:1px solid var(--ay-border); border-radius:var(--ay-radius); padding:1.1rem 1.4rem; z-index:9500; display:flex; align-items:center; gap:1.2rem; flex-wrap:wrap; box-shadow:var(--ay-shadow-md); }
#cookie-banner.hidden { display:none; }
#cookie-banner p { font-size:.75rem; color:var(--ay-soft); flex:1; }
#cookie-banner a { color:var(--ay-gold); }
.cookie-accept { background:var(--ay-gold); color:var(--ay-black); border:none; padding:.45rem 1.1rem; border-radius:100px; font-family:var(--ay-font-mono); font-size:.58rem; letter-spacing:.12em; text-transform:uppercase; font-weight:700; cursor:pointer; }

/* ══════════════════════════════════════════════════════════════
   ANIMATIONS & REVEAL
══════════════════════════════════════════════════════════════ */
@keyframes fade-up { from{opacity:0;transform:translateY(38px)} to{opacity:1;transform:translateY(0)} }
.reveal { opacity:0; transform:translateY(40px); transition:opacity .75s ease, transform .75s ease; }
.reveal.visible { opacity:1; transform:translateY(0); }
.reveal-d1{transition-delay:.1s} .reveal-d2{transition-delay:.2s} .reveal-d3{transition-delay:.3s} .reveal-d4{transition-delay:.4s}
.accent-3d { display:inline-block; transition:transform .35s var(--ay-transition), text-shadow .35s; }
.accent-3d:hover { transform:translateY(-3px) rotateX(8deg) scale(1.02); text-shadow:0 8px 20px rgba(251,201,38,.35); }

/* ══════════════════════════════════════════════════════════════
   PAGINATION
══════════════════════════════════════════════════════════════ */
.ay-pagination ul { display:flex; gap:.5rem; flex-wrap:wrap; }
.ay-pagination li a, .ay-pagination li span { font-family:var(--ay-font-mono); font-size:.62rem; letter-spacing:.1em; padding:.5rem .9rem; border:1px solid var(--ay-border); border-radius:100px; color:var(--ay-muted); transition:all .3s; display:block; }
.ay-pagination li a:hover, .ay-pagination li .current { background:var(--ay-gold); color:var(--ay-black); border-color:var(--ay-gold); }

/* ══════════════════════════════════════════════════════════════
   TYPOGRAPHY CONTENT
══════════════════════════════════════════════════════════════ */
.entry-content h1,.entry-content h2,.entry-content h3 { font-family:var(--ay-font-display); margin-bottom:1rem; }
.entry-content p { margin-bottom:1.2rem; color:var(--ay-soft); line-height:1.8; }
.entry-content a { color:var(--ay-gold); border-bottom:1px solid rgba(251,201,38,.3); }
.entry-content ul,.entry-content ol { margin:1rem 0 1rem 1.5rem; color:var(--ay-soft); }
.entry-content img { border-radius:var(--ay-radius); margin:1.5rem 0; }

/* ══════════════════════════════════════════════════════════════
   UTILITY
══════════════════════════════════════════════════════════════ */
.text-accent{color:var(--ay-gold)} .text-blue{color:var(--ay-blue)}
.mt-1{margin-top:1rem} .mt-2{margin-top:2rem} .mt-3{margin-top:3rem}
@keyframes pulse-dot{0%,100%{opacity:1;transform:scale(1)}50%{opacity:.6;transform:scale(1.3)}}
