/*
 Theme Name:   Page Builder Framework Child
 Theme URI:    https://www.lynmediagroup.com/
 Description:  Child theme for Page Builder Framework — Lyn Media Group global stylesheet covering all marketing pages (Home, About, Local SEO, SEO Backlinks, Guest Post, Facebook Ads, etc.)
 Author:       Lyn Media Group
 Author URI:   https://www.lynmediagroup.com/
 Template:     page-builder-framework
 Version:      2.1.0
 License:      GNU General Public License v2 or later
 License URI:  http://www.gnu.org/licenses/gpl-2.0.html
 Text Domain:  page-builder-framework-child
*/

/* ============================================================
   LYN MEDIA GROUP — GLOBAL DESIGN SYSTEM
   Wrap every page content in: <div class="lyn-page"> ... </div>
   ============================================================ */

@import url('https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700;800;900&display=swap');

/* ============================================================
   1. CSS VARIABLES
   ============================================================ */
:root {
  --primary: #800F81;
  --primary-dark: #5F0A60;
  --primary-light: #A123A2;
  --primary-lighter: #C44BC5;
  --dark: #0D0D2B;
  --dark-alt: #1A1A4E;
  --blue: #4361EE;
  --gray: #5A6271;
  --gray-soft: #6B7280;
  --gray-light: #F3F4F6;
  --white: #FFFFFF;
  --green: #10B981;
  --purple: #8B5CF6;
  --amber: #F59E0B;
  --pink: #EC4899;
  --orange: #F97316;
  --border: #E5E7EB;
  --border-soft: #EEF1F5;
  --shadow: 0 4px 24px rgba(13, 13, 43, .06);
  --shadow-lg: 0 16px 48px rgba(13, 13, 43, .12);
  --shadow-xl: 0 24px 64px rgba(13, 13, 43, .18);
  --radius: 12px;
  --radius-lg: 20px;
  --radius-xl: 28px;
  --tr: all .35s cubic-bezier(.4, 0, .2, 1);
  --font: 'Inter', sans-serif;

  /* Typography scale — single source of truth for ALL pages */
  --fs-xs:    .75rem;     /* 12px — micro labels, badges */
  --fs-sm:    .875rem;    /* 14px — small text, captions, tags */
  --fs-base:  1rem;       /* 16px — body paragraph */
  --fs-md:    1.125rem;   /* 18px — lead paragraph (.body-lg) */
  --fs-lg:    1.25rem;    /* 20px — small heading (h4) */
  --fs-xl:    1.5rem;     /* 24px — section sub-heading (h3) */
  --fs-2xl:   1.875rem;   /* 30px — card/component title */
  --fs-3xl:   2.25rem;    /* 36px — secondary section heading */
  --fs-4xl:   3rem;       /* 48px — primary section heading (h2 max) */
  --fs-5xl:   4rem;       /* 64px — hero h1 max */

  /* Line heights */
  --lh-tight: 1.15;       /* big headings */
  --lh-snug:  1.35;       /* small headings, sub-titles */
  --lh-base:  1.7;        /* body */
  --lh-loose: 1.8;        /* lead paragraphs */

  /* Font weights (use these instead of hard-coded numbers) */
  --fw-medium:    500;
  --fw-semibold:  600;
  --fw-bold:      700;
  --fw-extrabold: 800;
  --fw-black:     900;
}

/* ============================================================
   2. BASE / RESET
   ============================================================ */
.lyn-page *, .lyn-page *::before, .lyn-page *::after { box-sizing: border-box; margin: 0; padding: 0; }
.lyn-page { font-family: var(--font); color: var(--dark); background: var(--white); line-height: var(--lh-base); overflow-x: hidden; -webkit-font-smoothing: antialiased; text-rendering: optimizeLegibility; font-size: 16px; }
.lyn-page img { max-width: 100%; height: auto; display: block; }
.lyn-page a { text-decoration: none; color: inherit; }
.lyn-page ul { list-style: none; }
.lyn-page button { font-family: inherit; }
html { scroll-behavior: smooth; }

/* ============================================================
   2b. TYPOGRAPHY BASELINE — element defaults so EVERY page is consistent
       even if a class is forgotten. Component-specific class rules
       (.heading-lg, .card h3, .price-card h3, etc.) still win on
       specificity, so existing layouts are unaffected.
   ============================================================ */
.lyn-page h1 { font-size: clamp(2.5rem, 5.2vw, var(--fs-5xl)); font-weight: var(--fw-black); line-height: 1.08; letter-spacing: -.03em; color: var(--dark); }
.lyn-page h2 { font-size: clamp(2rem, 4.5vw, var(--fs-4xl)); font-weight: var(--fw-extrabold); line-height: var(--lh-tight); letter-spacing: -.02em; color: var(--dark); }
.lyn-page h3 { font-size: var(--fs-xl); font-weight: var(--fw-extrabold); line-height: var(--lh-snug); letter-spacing: -.01em; color: var(--dark); }
.lyn-page h4 { font-size: var(--fs-lg); font-weight: var(--fw-bold); line-height: var(--lh-snug); color: var(--dark); }
.lyn-page h5 { font-size: var(--fs-md); font-weight: var(--fw-bold); line-height: var(--lh-snug); color: var(--dark); }
.lyn-page h6 { font-size: var(--fs-base); font-weight: var(--fw-bold); line-height: var(--lh-snug); color: var(--dark); }
.lyn-page p { font-size: var(--fs-base); line-height: var(--lh-base); color: var(--gray); }
.lyn-page strong, .lyn-page b { font-weight: var(--fw-bold); }
.lyn-page small { font-size: var(--fs-sm); }
.lyn-page em, .lyn-page i { font-style: italic; }

/* ============================================================
   2c. FULL-WIDTH BREAKOUT — strip parent container constraints
       so .lyn-page hero/sections span the FULL viewport width.
       SAFE VERSION: no negative margins (which can push content
       off-screen in some page templates). Instead, target every
       known WordPress / Page Builder Framework wrapper and force
       it to 100% width with zero padding.
   ============================================================ */

/* Strip max-width + padding from common WordPress wrappers
   ONLY when the page contains a .lyn-page block. */
body:has(.lyn-page) .wpbf-container,
body:has(.lyn-page) .wpbf-main-container,
body:has(.lyn-page) .wpbf-page-content-container,
body:has(.lyn-page) .wpbf-inner-content,
body:has(.lyn-page) #content,
body:has(.lyn-page) .site-content,
body:has(.lyn-page) .entry-content,
body:has(.lyn-page) article.post,
body:has(.lyn-page) article.page,
body:has(.lyn-page) main#main {
  max-width: 100% !important;
  width: 100% !important;
  padding: 0 !important;
  margin: 0 !important;
}

/* Also strip space directly around the .lyn-page wrapper itself */
body:has(.lyn-page) .lyn-page {
  margin-top: 0 !important;
  padding-top: 0 !important;
}

/* Close the white strip between WordPress header (header.php) and hero.
   .lyn-site-header is the class used by header.php — so these rules
   apply ONLY in WordPress context (not in standalone HTML preview). */

/* Hide the redundant inline .site-navbar from page widgets when the
   real WordPress header (.lyn-site-header) is already present. */
body:has(.lyn-site-header) .site-navbar,
body:has(.lyn-site-header) .nav-mobile,
body:has(.lyn-site-header) .skip-link { display: none !important; }

/* Without the inline fixed navbar, the hero doesn't need the old 150px
   top offset — header.php is sticky and handles its own flow. Drop the
   hero to a natural 40px top padding so the purple hero sits flush
   beneath the header with no white gap. */
body:has(.lyn-site-header) .lyn-page .hero { padding-top: 40px !important; }
@media (max-width: 900px) {
  body:has(.lyn-site-header) .lyn-page .hero { padding-top: 30px !important; }
}

/* .lyn-page is simply 100% of its (now-unconstrained) parent.
   Inside, the .container class still caps content at 1200px for
   readability — only section backgrounds go edge-to-edge. */
.lyn-page {
  width: 100%;
  max-width: 100%;
}

/* ============================================================
   3. UTILITIES
   ============================================================ */
.lyn-page .container { width: 100%; max-width: 1200px; margin: 0 auto; padding: 0 24px; }
.lyn-page .section { padding: 96px 0; }
.lyn-page .tag { display: inline-block; font-size: 14px; font-weight: 700; letter-spacing: 1.8px; text-transform: uppercase; color: var(--primary); margin-bottom: 16px; }
.lyn-page .heading-lg { font-size: clamp(2rem, 4.5vw, 3rem); font-weight: 800; line-height: 1.15; color: var(--dark); letter-spacing: -.02em; }
.lyn-page .body-lg { font-size: 1.125rem; color: var(--gray); line-height: 1.8; }
.lyn-page .text-center { text-align: center; }

/* ============================================================
   4. BUTTONS
   ============================================================ */
.lyn-page .btn { display: inline-flex; align-items: center; gap: 10px; padding: 16px 34px; border-radius: 10px; font-size: 16px; font-weight: 600; cursor: pointer; transition: var(--tr); border: none; white-space: nowrap; font-family: var(--font); text-decoration: none; }
.lyn-page .btn-primary { background: var(--primary); color: #fff; box-shadow: 0 6px 20px rgba(128, 15, 129, .35); }
.lyn-page .btn-primary:hover { background: var(--primary-dark); transform: translateY(-2px); box-shadow: 0 10px 28px rgba(128, 15, 129, .45); color: #fff; }
.lyn-page .btn-outline { background: transparent; color: #fff; border: 2px solid rgba(255, 255, 255, .6); }
.lyn-page .btn-outline:hover { background: #fff; color: var(--primary); border-color: #fff; }
.lyn-page .btn-dark-outline { background: transparent; color: var(--dark); border: 2px solid var(--border); }
.lyn-page .btn-dark-outline:hover { border-color: var(--primary); color: var(--primary); }
.lyn-page .btn-white { background: #fff; color: var(--primary); font-weight: 700; }
.lyn-page .btn-white:hover { transform: translateY(-2px); box-shadow: var(--shadow-lg); color: var(--primary); }

/* ============================================================
   5. HERO
   ============================================================ */
.lyn-page .hero { display: flex; align-items: center; background: linear-gradient(135deg, #0D0D2B 0%, #1A1A4E 50%, #0D0D2B 100%); position: relative; overflow: hidden; padding: 80px 0 90px; }
.lyn-page .hero::before { content: ''; position: absolute; top: -50%; right: -20%; width: 700px; height: 700px; background: radial-gradient(circle, rgba(128, 15, 129, .18) 0%, transparent 70%); pointer-events: none; }
.lyn-page .hero::after { content: ''; position: absolute; bottom: -30%; left: -10%; width: 500px; height: 500px; background: radial-gradient(circle, rgba(67, 97, 238, .14) 0%, transparent 70%); pointer-events: none; }
.lyn-page .hero-grid { display: grid; grid-template-columns: 1.05fr 1fr; gap: 64px; align-items: center; position: relative; z-index: 1; }
.lyn-page .breadcrumb { display: flex; align-items: center; gap: 8px; font-size: 14px; color: rgba(255, 255, 255, .65); margin-bottom: 24px; font-weight: 500; }
.lyn-page .breadcrumb a { color: rgba(255, 255, 255, .65); transition: color .2s; }
.lyn-page .breadcrumb a:hover { color: var(--primary-light); }
.lyn-page .breadcrumb svg { opacity: .5; }
.lyn-page .hero-tag { display: inline-flex; align-items: center; gap: 8px; background: rgba(128, 15, 129, .18); border: 1px solid rgba(128, 15, 129, .35); border-radius: 100px; padding: 8px 18px; font-size: 14px; font-weight: 600; color: #C44BC5; margin-bottom: 24px; letter-spacing: .5px; }
.lyn-page .hero-dot { width: 7px; height: 7px; background: var(--primary-light); border-radius: 50%; animation: lyn-pulse 2s infinite; }
@keyframes lyn-pulse { 0%, 100% { opacity: 1; transform: scale(1); } 50% { opacity: .5; transform: scale(1.3); } }
.lyn-page .hero h1 { font-size: clamp(2.5rem, 5.2vw, 4rem); font-weight: 900; line-height: 1.08; color: #fff !important; letter-spacing: -.03em; margin-bottom: 24px; }
.lyn-page .hero h1 .g-text { background: linear-gradient(135deg, #C44BC5 0%, #800F81 100%); -webkit-background-clip: text; -webkit-text-fill-color: transparent; background-clip: text; color: #C44BC5; }
.lyn-page .hero p, .lyn-page .hero p.lead { font-size: 1.1875rem; color: rgba(255, 255, 255, .78) !important; line-height: 1.75; margin-bottom: 40px; max-width: 560px; font-weight: 400; }
.lyn-page .hero-actions { display: flex; align-items: center; gap: 16px; flex-wrap: wrap; }
.lyn-page .hero-badges { display: flex; align-items: center; gap: 24px; margin-top: 48px; padding-top: 36px; border-top: 1px solid rgba(255, 255, 255, .12); flex-wrap: wrap; }
.lyn-page .hero-badge { display: flex; align-items: center; gap: 12px; }
.lyn-page .hb-icon { width: 44px; height: 44px; background: rgba(255, 255, 255, .08); border-radius: 11px; display: flex; align-items: center; justify-content: center; flex-shrink: 0; border: 1px solid rgba(255, 255, 255, .06); }
.lyn-page .hb-text strong { display: block; font-size: 1.0625rem; font-weight: 800; color: #fff !important; letter-spacing: -.01em; }
.lyn-page .hb-text span { font-size: .8125rem; color: rgba(255, 255, 255, .55); font-weight: 500; }

/* ============================================================
   6. HERO VISUAL — HOMEPAGE (services icon-grid + perf bar)
   ============================================================ */
.lyn-page .hero-visual { position: relative; }
.lyn-page .hero-card { background: rgba(255, 255, 255, .06); backdrop-filter: blur(20px); border: 1px solid rgba(255, 255, 255, .12); border-radius: var(--radius-lg); padding: 32px; position: relative; }
.lyn-page .icon-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 16px; margin-bottom: 24px; }
.lyn-page .ig-item { background: rgba(255, 255, 255, .07); border: 1px solid rgba(255, 255, 255, .1); border-radius: 12px; padding: 20px 16px; text-align: center; transition: var(--tr); }
.lyn-page .ig-item:hover { background: rgba(128, 15, 129, .15); border-color: rgba(128, 15, 129, .3); transform: translateY(-3px); }
.lyn-page .ig-item span { display: block; font-size: 11px; font-weight: 600; color: rgba(255, 255, 255, .7); text-transform: uppercase; letter-spacing: .5px; margin-top: 8px; }
.lyn-page .perf-bar { background: rgba(255, 255, 255, .06); border-radius: 10px; padding: 16px; border: 1px solid rgba(255, 255, 255, .1); }
.lyn-page .perf-bar-top { display: flex; align-items: center; justify-content: space-between; margin-bottom: 12px; }
.lyn-page .perf-bar-top span:first-child { font-size: 12px; font-weight: 600; color: rgba(255, 255, 255, .7); text-transform: uppercase; letter-spacing: .8px; }
.lyn-page .perf-bar-top span:last-child { font-size: 12px; color: #10B981; font-weight: 600; }
.lyn-page .bar-track { height: 6px; background: rgba(255, 255, 255, .1); border-radius: 100px; overflow: hidden; margin-bottom: 8px; }
.lyn-page .bar-fill { height: 100%; border-radius: 100px; }
.lyn-page .bar-1 { width: 75%; background: linear-gradient(90deg, #800F81, #A123A2); }
.lyn-page .bar-2 { width: 58%; background: linear-gradient(90deg, #4361EE, #60A5FA); }
.lyn-page .bar-3 { width: 88%; background: linear-gradient(90deg, #10B981, #34D399); }

/* ============================================================
   7. HERO VISUAL — LOCAL SEO MAPS / GBP MOCKUP
   ============================================================ */
.lyn-page .gbp-card { background: #fff; border-radius: var(--radius-lg); padding: 0; position: relative; box-shadow: 0 30px 80px rgba(0, 0, 0, .4), 0 0 0 1px rgba(255, 255, 255, .05); overflow: hidden; }
.lyn-page .gbp-head { display: flex; align-items: center; justify-content: space-between; padding: 18px 22px; background: linear-gradient(180deg, #fff 0%, #FAFBFF 100%); border-bottom: 1px solid var(--border-soft); }
.lyn-page .gbp-search { display: flex; align-items: center; gap: 10px; background: #F3F4F6; border-radius: 24px; padding: 8px 14px; flex: 1; margin-left: 14px; font-size: .8125rem; color: var(--gray); font-weight: 500; }
.lyn-page .gbp-google { display: flex; align-items: center; gap: 6px; }
.lyn-page .gbp-g { font-size: 1.125rem; font-weight: 600; letter-spacing: -1px; }
.lyn-page .gbp-g .b { color: #4285F4; }
.lyn-page .gbp-g .o { color: #EA4335; }
.lyn-page .gbp-g .y { color: #FBBC05; }
.lyn-page .gbp-g .g { color: #34A853; }
.lyn-page .gbp-tabs { display: flex; gap: 0; padding: 0 22px; background: #fff; border-bottom: 1px solid var(--border-soft); }
.lyn-page .gbp-tab { padding: 12px 14px; font-size: .8125rem; font-weight: 500; color: var(--gray); border-bottom: 2px solid transparent; cursor: default; }
.lyn-page .gbp-tab.active { color: #1A73E8; border-bottom-color: #1A73E8; font-weight: 600; }
.lyn-page .map-mock { position: relative; height: 200px; background: linear-gradient(135deg, #E8F0F7 0%, #D0E1F0 50%, #E8F0F7 100%); overflow: hidden; }
.lyn-page .map-grid { position: absolute; inset: 0; background-image: linear-gradient(rgba(255, 255, 255, .5) 1px, transparent 1px), linear-gradient(90deg, rgba(255, 255, 255, .5) 1px, transparent 1px); background-size: 32px 32px; opacity: .6; }
.lyn-page .map-road { position: absolute; background: #fff; box-shadow: 0 0 0 1px rgba(0, 0, 0, .04); }
.lyn-page .r1 { top: 30%; left: 0; right: 0; height: 10px; }
.lyn-page .r2 { top: 0; bottom: 0; left: 42%; width: 10px; }
.lyn-page .r3 { top: 65%; left: 0; right: 0; height: 8px; transform: rotate(-3deg); }
.lyn-page .r4 { top: 15%; left: 65%; width: 8px; height: 60%; transform: rotate(15deg); }
.lyn-page .map-pin { position: absolute; width: 34px; height: 34px; background: linear-gradient(135deg, #800F81, #5F0A60); border-radius: 50% 50% 50% 0; transform: rotate(-45deg); display: flex; align-items: center; justify-content: center; box-shadow: 0 6px 16px rgba(128, 15, 129, .5); animation: lyn-bounce 2s ease-in-out infinite; z-index: 2; }
.lyn-page .map-pin::after { content: ''; width: 13px; height: 13px; background: #fff; border-radius: 50%; }
.lyn-page .pin-1 { top: 20%; left: 32%; animation-delay: 0s; }
.lyn-page .pin-2 { top: 48%; left: 58%; width: 28px; height: 28px; background: linear-gradient(135deg, #4361EE, #2563EB); box-shadow: 0 6px 16px rgba(67, 97, 238, .5); animation-delay: .4s; }
.lyn-page .pin-2::after { width: 10px; height: 10px; }
.lyn-page .pin-3 { top: 68%; left: 25%; width: 28px; height: 28px; background: linear-gradient(135deg, #10B981, #059669); box-shadow: 0 6px 16px rgba(16, 185, 129, .5); animation-delay: .8s; }
.lyn-page .pin-3::after { width: 10px; height: 10px; }
@keyframes lyn-bounce { 0%, 100% { transform: rotate(-45deg) translateY(0); } 50% { transform: rotate(-45deg) translateY(-8px); } }
.lyn-page .map-pin-pulse { position: absolute; width: 64px; height: 64px; background: radial-gradient(circle, rgba(128, 15, 129, .4) 0%, transparent 70%); border-radius: 50%; top: 14%; left: 28%; animation: lyn-pulse-ring 2s ease-out infinite; pointer-events: none; }
@keyframes lyn-pulse-ring { 0% { transform: scale(.5); opacity: 1; } 100% { transform: scale(1.6); opacity: 0; } }
.lyn-page .pack-list { padding: 16px 22px 22px; background: #fff; }
.lyn-page .pack-head { display: flex; align-items: center; justify-content: space-between; margin-bottom: 12px; }
.lyn-page .pack-head strong { font-size: .9375rem; font-weight: 700; color: var(--dark); }
.lyn-page .pack-head .live { display: inline-flex; align-items: center; gap: 6px; font-size: .7rem; color: var(--green); font-weight: 700; text-transform: uppercase; letter-spacing: .8px; }
.lyn-page .pack-head .live::before { content: ''; width: 7px; height: 7px; background: var(--green); border-radius: 50%; box-shadow: 0 0 0 3px rgba(16, 185, 129, .18); animation: lyn-pulse 2s infinite; }
.lyn-page .pack-item { display: flex; align-items: center; gap: 12px; padding: 12px; border-radius: 12px; transition: var(--tr); margin-bottom: 8px; }
.lyn-page .pack-item.you { background: linear-gradient(135deg, rgba(128, 15, 129, .08), rgba(128, 15, 129, .02)); border: 1px solid rgba(128, 15, 129, .18); box-shadow: 0 4px 12px rgba(128, 15, 129, .06); }
.lyn-page .pack-item:not(.you) { opacity: .55; }
.lyn-page .pack-item:last-child { margin-bottom: 0; }
.lyn-page .pack-rank { width: 30px; height: 30px; background: var(--primary); color: #fff; border-radius: 8px; display: flex; align-items: center; justify-content: center; font-size: .875rem; font-weight: 800; flex-shrink: 0; }
.lyn-page .pack-item:not(.you) .pack-rank { background: #E5E7EB; color: #9CA3AF; }
.lyn-page .pack-info { flex: 1; min-width: 0; }
.lyn-page .pack-name { font-size: .875rem; font-weight: 700; color: var(--dark); margin-bottom: 2px; display: flex; align-items: center; gap: 6px; }
.lyn-page .pack-you-tag { background: var(--primary); color: #fff; font-size: .6rem; font-weight: 700; padding: 2px 6px; border-radius: 4px; letter-spacing: .5px; text-transform: uppercase; }
.lyn-page .pack-meta { display: flex; align-items: center; gap: 6px; font-size: .75rem; color: var(--gray); }
.lyn-page .stars { color: #F59E0B; font-size: .75rem; letter-spacing: 1px; }
.lyn-page .pack-arrow { color: var(--gray); opacity: .4; }

/* ============================================================
   8. HERO VISUAL — BACKLINK PROFILE DASHBOARD
   ============================================================ */
.lyn-page .bl-card { background: #fff; border-radius: var(--radius-lg); padding: 0; position: relative; box-shadow: 0 30px 80px rgba(0, 0, 0, .4), 0 0 0 1px rgba(255, 255, 255, .05); overflow: hidden; }
.lyn-page .bl-head { display: flex; align-items: center; justify-content: space-between; padding: 18px 22px; background: linear-gradient(180deg, #fff 0%, #FAFBFF 100%); border-bottom: 1px solid var(--border-soft); }
.lyn-page .bl-head-l { display: flex; align-items: center; gap: 10px; }
.lyn-page .bl-head-l strong { font-size: .9375rem; font-weight: 800; color: var(--dark); }
.lyn-page .bl-head-l span { font-size: .75rem; color: var(--gray); }
.lyn-page .live-pill { display: inline-flex; align-items: center; gap: 6px; font-size: .7rem; color: var(--green); font-weight: 700; text-transform: uppercase; letter-spacing: .8px; background: rgba(16, 185, 129, .12); padding: 5px 10px; border-radius: 100px; }
.lyn-page .live-pill::before { content: ''; width: 7px; height: 7px; background: var(--green); border-radius: 50%; box-shadow: 0 0 0 3px rgba(16, 185, 129, .18); animation: lyn-pulse 2s infinite; }
.lyn-page .score-row { display: grid; grid-template-columns: 1fr 1fr; gap: 14px; padding: 20px 22px; background: linear-gradient(180deg, #FAFBFF 0%, #fff 100%); }
.lyn-page .score-tile { background: #fff; border: 1px solid var(--border-soft); border-radius: 14px; padding: 16px; position: relative; overflow: hidden; }
.lyn-page .score-tile::before { content: ''; position: absolute; top: -30px; right: -30px; width: 90px; height: 90px; border-radius: 50%; }
.lyn-page .score-tile.da::before { background: radial-gradient(circle, rgba(128, 15, 129, .15), transparent 70%); }
.lyn-page .score-tile.dr::before { background: radial-gradient(circle, rgba(67, 97, 238, .15), transparent 70%); }
.lyn-page .score-label { font-size: .7rem; font-weight: 700; color: var(--gray); text-transform: uppercase; letter-spacing: 1px; margin-bottom: 6px; }
.lyn-page .score-row-num { display: flex; align-items: baseline; gap: 6px; }
.lyn-page .score-num { font-size: 2rem; font-weight: 900; color: var(--dark); line-height: 1; letter-spacing: -.04em; }
.lyn-page .score-tile.da .score-num { color: var(--primary); }
.lyn-page .score-tile.dr .score-num { color: var(--blue); }
.lyn-page .score-trend { font-size: .75rem; font-weight: 700; color: var(--green); display: inline-flex; align-items: center; gap: 2px; }
.lyn-page .score-bar { height: 5px; background: var(--gray-light); border-radius: 100px; overflow: hidden; margin-top: 12px; position: relative; z-index: 1; }
.lyn-page .score-bar-fill { height: 100%; border-radius: 100px; animation: lyn-fillBar 2.5s cubic-bezier(.2, .8, .2, 1) forwards; width: 0; }
.lyn-page .score-tile.da .score-bar-fill { background: linear-gradient(90deg, #C44BC5, #800F81); --w: 67%; }
.lyn-page .score-tile.dr .score-bar-fill { background: linear-gradient(90deg, #60A5FA, #4361EE); --w: 72%; animation-delay: .2s; }
@keyframes lyn-fillBar { from { width: 0; } to { width: var(--w, 60%); } }
.lyn-page .feed-section { padding: 14px 22px 20px; background: #fff; }
.lyn-page .feed-head { display: flex; align-items: center; justify-content: space-between; margin-bottom: 12px; }
.lyn-page .feed-head strong { font-size: .875rem; font-weight: 800; color: var(--dark); }
.lyn-page .feed-head a { font-size: .7rem; color: var(--primary); font-weight: 700; text-transform: uppercase; letter-spacing: .5px; }
.lyn-page .feed-list { display: flex; flex-direction: column; gap: 8px; }
.lyn-page .feed-row { display: flex; align-items: center; gap: 12px; padding: 10px 12px; background: #FAFBFF; border-radius: 10px; border: 1px solid var(--border-soft); transition: var(--tr); }
.lyn-page .feed-row:hover { background: #fff; box-shadow: 0 4px 12px rgba(13, 13, 43, .05); }
.lyn-page .feed-icon { width: 32px; height: 32px; border-radius: 8px; display: flex; align-items: center; justify-content: center; flex-shrink: 0; font-size: .875rem; font-weight: 900; color: #fff; }
.lyn-page .fi-1 { background: linear-gradient(135deg, #C44BC5, #800F81); }
.lyn-page .fi-2 { background: linear-gradient(135deg, #A78BFA, #8B5CF6); }
.lyn-page .fi-3 { background: linear-gradient(135deg, #34D399, #10B981); }
.lyn-page .fi-4 { background: linear-gradient(135deg, #60A5FA, #4361EE); }
.lyn-page .feed-info { flex: 1; min-width: 0; }
.lyn-page .feed-domain { font-size: .8125rem; font-weight: 700; color: var(--dark); margin-bottom: 1px; }
.lyn-page .feed-meta { font-size: .7rem; color: var(--gray); display: flex; align-items: center; gap: 6px; }
.lyn-page .da-pill { font-size: .65rem; font-weight: 800; color: var(--primary); background: rgba(128, 15, 129, .1); padding: 2px 7px; border-radius: 4px; letter-spacing: .3px; }
.lyn-page .feed-check { width: 22px; height: 22px; border-radius: 50%; background: var(--green); display: flex; align-items: center; justify-content: center; flex-shrink: 0; }

/* ============================================================
   9. FLOATING BADGES (used by every hero visual)
   ============================================================ */
.lyn-page .float-badge { position: absolute; background: #fff; border-radius: 14px; padding: 12px 18px; box-shadow: 0 12px 32px rgba(0, 0, 0, .18); display: flex; align-items: center; gap: 10px; z-index: 3; }
.lyn-page .fb1 { top: -22px; right: -18px; animation: lyn-float 4s ease-in-out infinite; }
.lyn-page .fb2 { bottom: -22px; left: -18px; animation: lyn-float 4s ease-in-out 2s infinite; }
@keyframes lyn-float { 0%, 100% { transform: translateY(0); } 50% { transform: translateY(-8px); } }
.lyn-page .fb-icon { width: 38px; height: 38px; border-radius: 10px; display: flex; align-items: center; justify-content: center; flex-shrink: 0; }
.lyn-page .fb-green { background: linear-gradient(135deg, #ECFDF5, #D1FAE5); }
.lyn-page .fb-blue { background: linear-gradient(135deg, #EFF6FF, #DBEAFE); }
.lyn-page .fb-text strong { display: block; font-size: .875rem; font-weight: 800; color: var(--dark); line-height: 1.2; }
.lyn-page .fb-text span { font-size: .7rem; color: var(--gray); }

/* ============================================================
   10. INDUSTRIES STRIP
   ============================================================ */
.lyn-page .industries-strip { padding: 64px 0; background: linear-gradient(180deg, #fff 0%, #F8F9FF 100%); border-bottom: 1px solid var(--border); }
.lyn-page .industries-label { text-align: center; font-size: .875rem; font-weight: 700; color: var(--gray-soft); text-transform: uppercase; letter-spacing: 2px; margin-bottom: 36px; display: block; }
.lyn-page .industries-grid { display: grid; grid-template-columns: repeat(6, 1fr); gap: 18px; }
.lyn-page .ind-card { background: #fff; border: 1px solid var(--border); border-radius: 16px; padding: 22px 14px; text-align: center; transition: var(--tr); cursor: default; position: relative; overflow: hidden; }
.lyn-page .ind-card::before { content: ''; position: absolute; top: 0; left: 0; right: 0; height: 3px; background: linear-gradient(90deg, var(--primary), var(--primary-light)); transform: scaleX(0); transition: transform .35s; transform-origin: center; }
.lyn-page .ind-card:hover { border-color: transparent; transform: translateY(-6px); box-shadow: 0 16px 32px rgba(13, 13, 43, .08); }
.lyn-page .ind-card:hover::before { transform: scaleX(1); }
.lyn-page .ind-icon { width: 52px; height: 52px; border-radius: 13px; display: flex; align-items: center; justify-content: center; margin: 0 auto 14px; transition: var(--tr); }
.lyn-page .ind-card:hover .ind-icon { transform: scale(1.08) rotate(-4deg); }
.lyn-page .ind-1 { background: linear-gradient(135deg, rgba(128, 15, 129, .12), rgba(161, 35, 162, .05)); }
.lyn-page .ind-2 { background: linear-gradient(135deg, rgba(67, 97, 238, .12), rgba(96, 165, 250, .05)); }
.lyn-page .ind-3 { background: linear-gradient(135deg, rgba(16, 185, 129, .12), rgba(52, 211, 153, .05)); }
.lyn-page .ind-4 { background: linear-gradient(135deg, rgba(139, 92, 246, .12), rgba(167, 139, 250, .05)); }
.lyn-page .ind-5 { background: linear-gradient(135deg, rgba(245, 158, 11, .12), rgba(251, 191, 36, .05)); }
.lyn-page .ind-6 { background: linear-gradient(135deg, rgba(236, 72, 153, .12), rgba(244, 114, 182, .05)); }
.lyn-page .ind-card span { font-size: .9375rem; font-weight: 700; color: var(--dark); display: block; }

/* ============================================================
   11. SECTION HEADER
   ============================================================ */
.lyn-page .section-header { max-width: 720px; margin: 0 auto 64px; }

/* ============================================================
   12. APPROACH CARDS — 3-COLUMN (Homepage)
   ============================================================ */
.lyn-page .cards-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 24px; }
.lyn-page .card { background: #fff; border: 1px solid var(--border); border-radius: var(--radius-lg); padding: 36px 28px; transition: var(--tr); position: relative; overflow: hidden; }
.lyn-page .card::before { content: ''; position: absolute; bottom: 0; left: 0; right: 0; height: 4px; background: linear-gradient(90deg, var(--primary), var(--primary-light)); transform: scaleX(0); transition: transform .3s; transform-origin: left; }
.lyn-page .card:hover { box-shadow: var(--shadow-lg); transform: translateY(-6px); border-color: transparent; }
.lyn-page .card:hover::before { transform: scaleX(1); }
.lyn-page .card-icon { width: 60px; height: 60px; border-radius: 14px; display: flex; align-items: center; justify-content: center; margin-bottom: 20px; }
.lyn-page .icon-orange { background: rgba(249, 115, 22, .1); }
.lyn-page .card h3 { font-size: 1.125rem; font-weight: 800; color: var(--dark); margin-bottom: 12px; }
.lyn-page .card p { font-size: .9375rem; color: var(--gray); line-height: 1.7; }

/* ============================================================
   13. OFFER CARDS (4-col, used on Local SEO / Backlinks pages)
   ============================================================ */
.lyn-page .offer-section { background: #fff; }
.lyn-page .offer-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 22px; }
.lyn-page .offer-card { background: #fff; border: 1px solid var(--border); border-radius: var(--radius-lg); padding: 36px 28px; transition: var(--tr); position: relative; overflow: hidden; }
.lyn-page .offer-card::before { content: ''; position: absolute; bottom: 0; left: 0; right: 0; height: 3px; background: linear-gradient(90deg, var(--primary), var(--primary-light)); transform: scaleX(0); transition: transform .3s; transform-origin: left; }
.lyn-page .offer-card:hover { box-shadow: var(--shadow-lg); transform: translateY(-8px); border-color: transparent; }
.lyn-page .offer-card:hover::before { transform: scaleX(1); }
.lyn-page .offer-icon { width: 60px; height: 60px; border-radius: 15px; display: flex; align-items: center; justify-content: center; margin-bottom: 20px; }
.lyn-page .icon-red { background: rgba(128, 15, 129, .1); }
.lyn-page .icon-blue { background: rgba(67, 97, 238, .1); }
.lyn-page .icon-purple { background: rgba(139, 92, 246, .1); }
.lyn-page .icon-green { background: rgba(16, 185, 129, .1); }
.lyn-page .icon-amber { background: rgba(245, 158, 11, .1); }
.lyn-page .icon-pink { background: rgba(236, 72, 153, .1); }
.lyn-page .offer-card h3 { font-size: 1.1875rem; font-weight: 800; color: var(--dark); margin-bottom: 12px; letter-spacing: -.01em; }
.lyn-page .offer-card p { font-size: .9375rem; color: var(--gray); line-height: 1.7; }

/* ============================================================
   14. ABOUT SECTION (Homepage Who-We-Are)
   ============================================================ */
.lyn-page .about-section { background: #F8F9FF; }
.lyn-page .about-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 80px; align-items: center; }
.lyn-page .about-vis-main { background: linear-gradient(135deg, var(--dark) 0%, #1A1A4E 100%); border-radius: var(--radius-lg); padding: 48px 40px; position: relative; overflow: hidden; }
.lyn-page .about-vis-main::before { content: ''; position: absolute; top: -50px; right: -50px; width: 200px; height: 200px; background: radial-gradient(circle, rgba(128, 15, 129, .2), transparent 70%); }
.lyn-page .stat-pair { display: grid; grid-template-columns: 1fr 1fr; gap: 24px; position: relative; z-index: 1; }
.lyn-page .stat-item { text-align: center; padding: 24px 16px; background: rgba(255, 255, 255, .06); border: 1px solid rgba(255, 255, 255, .1); border-radius: 12px; }
.lyn-page .stat-num { font-size: 2.25rem; font-weight: 900; color: #fff !important; letter-spacing: -.03em; line-height: 1; margin-bottom: 6px; }
.lyn-page .stat-num .hl { color: var(--primary-light) !important; }
.lyn-page .stat-lbl { font-size: .8125rem; color: rgba(255, 255, 255, .55); font-weight: 500; text-transform: uppercase; letter-spacing: .8px; }
.lyn-page .about-features { display: flex; flex-direction: column; gap: 16px; margin-bottom: 36px; }
.lyn-page .about-features .feat-item { gap: 14px; }
.lyn-page .about-features .feat-item > p { font-size: .9375rem; color: var(--gray); margin: 0; line-height: 1.6; }

/* ============================================================
   14b. ABOUT PAGE — Hero Profile Card + History Section
   ============================================================ */

/* Hero small badges row (under hero buttons on About page) */
.lyn-page .hbadge-row { display: flex; gap: 9px; flex-wrap: wrap; margin-top: 24px; }
.lyn-page .hbadge { display: inline-flex; align-items: center; gap: 7px; background: rgba(255,255,255,.07); border: 1px solid rgba(255,255,255,.1); border-radius: 100px; padding: 7px 14px; font-size: .8125rem; font-weight: 600; color: rgba(255,255,255,.78); }

/* Company Profile Card (About hero right side) */
.lyn-page .co-profile-card { background: rgba(255,255,255,.065); backdrop-filter: blur(28px); -webkit-backdrop-filter: blur(28px); border: 1px solid rgba(255,255,255,.12); border-radius: var(--radius-lg); padding: 26px; }
.lyn-page .co-card-hd { display: flex; align-items: center; gap: 12px; margin-bottom: 20px; padding-bottom: 18px; border-bottom: 1px solid rgba(255,255,255,.08); }
.lyn-page .co-card-logo { width: 46px; height: 46px; background: var(--primary); border-radius: 12px; display: flex; align-items: center; justify-content: center; flex-shrink: 0; }
.lyn-page .co-card-hd > div:not(.co-verified) strong { display: block; font-size: 1rem; font-weight: 800; color: #fff !important; }
.lyn-page .co-card-hd > div:not(.co-verified) span { font-size: .75rem; color: rgba(255,255,255,.42); }
.lyn-page .co-verified { margin-left: auto; display: inline-flex; align-items: center; gap: 5px; white-space: nowrap; font-size: .75rem; font-weight: 700; color: #10B981; background: rgba(16,185,129,.12); border: 1px solid rgba(16,185,129,.28); border-radius: 100px; padding: 5px 11px; }

.lyn-page .co-team { margin-bottom: 18px; }
.lyn-page .co-team-lbl { font-size: .8125rem; font-weight: 700; color: rgba(255,255,255,.42); text-transform: uppercase; letter-spacing: 1px; margin-bottom: 12px; }
.lyn-page .co-avatars { display: flex; align-items: center; }
.lyn-page .co-avatar { width: 40px; height: 40px; border-radius: 50%; border: 2.5px solid rgba(255,255,255,.15); display: flex; align-items: center; justify-content: center; margin-right: -10px; overflow: hidden; flex-shrink: 0; }
.lyn-page .co-avatar-more { width: 40px; height: 40px; border-radius: 50%; border: 2.5px solid rgba(255,255,255,.15); background: rgba(128,15,129,.25); display: flex; align-items: center; justify-content: center; font-size: .75rem; font-weight: 800; color: var(--primary-lighter); flex-shrink: 0; }
.lyn-page .co-team-note { font-size: .8125rem; color: rgba(255,255,255,.55) !important; margin-top: 10px; }

.lyn-page .co-info { display: flex; flex-direction: column; gap: 8px; margin-bottom: 18px; }
.lyn-page .co-info-row { display: flex; align-items: center; gap: 10px; background: rgba(255,255,255,.045); border-radius: 9px; padding: 9px 13px; border: 1px solid rgba(255,255,255,.06); }
.lyn-page .co-info-row-ico { width: 28px; height: 28px; border-radius: 7px; display: flex; align-items: center; justify-content: center; flex-shrink: 0; }
.lyn-page .co-info-row span { font-size: .875rem; color: rgba(255,255,255,.72) !important; font-weight: 500; }

.lyn-page .co-awards { display: flex; flex-direction: column; gap: 7px; }
.lyn-page .co-award-row { display: flex; align-items: center; gap: 9px; padding: 9px 13px; background: rgba(255,255,255,.04); border-radius: 9px; border: 1px solid rgba(255,255,255,.06); }
.lyn-page .co-award-ico { width: 26px; height: 26px; border-radius: 6px; display: flex; align-items: center; justify-content: center; flex-shrink: 0; }
.lyn-page .co-award-row span { font-size: .8125rem; color: rgba(255,255,255,.65) !important; font-weight: 500; }

/* About Who-We-Are visual enhancements (logo header + trust banner) */
.lyn-page .who-vis-hd { display: flex; align-items: center; gap: 13px; margin-bottom: 24px; position: relative; z-index: 1; }
.lyn-page .who-vis-logo { width: 48px; height: 48px; background: var(--primary); border-radius: 13px; display: flex; align-items: center; justify-content: center; flex-shrink: 0; }
.lyn-page .who-vis-hd > div strong { display: block; font-size: 1rem; font-weight: 800; color: #fff !important; }
.lyn-page .who-vis-hd > div span { font-size: .8125rem; color: rgba(255,255,255,.42); }
.lyn-page .who-trust { background: rgba(128,15,129,.1); border: 1px solid rgba(128,15,129,.22); border-radius: 13px; padding: 15px 17px; display: flex; align-items: center; gap: 12px; position: relative; z-index: 1; margin-top: 20px; }
.lyn-page .who-trust-ico { width: 40px; height: 40px; background: var(--primary); border-radius: 11px; display: flex; align-items: center; justify-content: center; flex-shrink: 0; }
.lyn-page .who-trust > div strong { display: block; color: #fff !important; font-size: .9375rem; }
.lyn-page .who-trust > div span { color: rgba(255,255,255,.5); font-size: .875rem; }

/* About Who-feat (bigger feature items) */
.lyn-page .who-feats { display: flex; flex-direction: column; gap: 22px; margin-bottom: 32px; }
.lyn-page .who-feat-item { display: flex; align-items: flex-start; gap: 16px; }
.lyn-page .who-feat-ico { width: 48px; height: 48px; border-radius: 13px; display: flex; align-items: center; justify-content: center; flex-shrink: 0; margin-top: 2px; transition: transform .3s ease; }
.lyn-page .who-feat-item:hover .who-feat-ico { transform: translateY(-3px) scale(1.06); }
.lyn-page .who-feat-item > div strong { display: block; font-size: 1.0625rem; font-weight: 700; color: var(--dark); margin-bottom: 4px; }
.lyn-page .who-feat-item > div p { font-size: 1rem; color: var(--gray); line-height: 1.72; }

/* History points (left column, About History section) */
.lyn-page .hist-section { background: #fff; }
.lyn-page .hist-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 80px; align-items: center; }
.lyn-page .hist-points { display: flex; flex-direction: column; gap: 22px; margin-top: 32px; }
.lyn-page .hist-point { display: flex; align-items: flex-start; gap: 16px; }
.lyn-page .hist-pt-dot { width: 48px; height: 48px; border-radius: 50%; flex-shrink: 0; display: flex; align-items: center; justify-content: center; margin-top: 2px; border: 3px solid #fff; box-shadow: 0 0 0 2px var(--border); transition: transform .3s ease, box-shadow .3s ease; }
.lyn-page .hist-point:hover .hist-pt-dot { transform: scale(1.08); box-shadow: 0 0 0 2px var(--primary); }
.lyn-page .hist-pt-body strong { display: block; font-size: 1.0625rem; font-weight: 700; color: var(--dark); margin-bottom: 6px; }
.lyn-page .hist-pt-body p { font-size: 1rem; color: var(--gray); line-height: 1.72; }

/* History expertise visual (right column) */
.lyn-page .hist-vis { background: linear-gradient(148deg, #0D0D2B, #1A1A4E); border-radius: var(--radius-lg); padding: 38px; position: relative; overflow: hidden; }
.lyn-page .hist-vis::before { content: ''; position: absolute; top: -50px; left: -50px; width: 200px; height: 200px; background: radial-gradient(circle, rgba(67,97,238,.2), transparent 70%); }
.lyn-page .hist-vis::after { content: ''; position: absolute; bottom: -50px; right: -30px; width: 160px; height: 160px; background: radial-gradient(circle, rgba(128,15,129,.15), transparent 70%); }
.lyn-page .hist-vis-ttl { font-size: .8125rem; font-weight: 700; color: rgba(255,255,255,.4); text-transform: uppercase; letter-spacing: 1.4px; margin-bottom: 22px; position: relative; z-index: 1; }
.lyn-page .hist-exp-list { display: flex; flex-direction: column; gap: 12px; position: relative; z-index: 1; }
.lyn-page .hist-exp-item { background: rgba(255,255,255,.06); border: 1px solid rgba(255,255,255,.09); border-radius: 12px; padding: 16px 18px; display: flex; align-items: center; gap: 13px; transition: background .25s ease; }
.lyn-page .hist-exp-item:hover { background: rgba(255,255,255,.1); }
.lyn-page .hist-exp-ico { width: 40px; height: 40px; border-radius: 10px; display: flex; align-items: center; justify-content: center; flex-shrink: 0; }
.lyn-page .hist-exp-t strong { display: block; font-size: .9375rem; font-weight: 700; color: #fff !important; margin-bottom: 2px; }
.lyn-page .hist-exp-t span { font-size: .8125rem; color: rgba(255,255,255,.42); }
.lyn-page .hist-exp-bar { margin-left: auto; display: flex; flex-direction: column; align-items: flex-end; gap: 4px; }
.lyn-page .hist-exp-pct { font-size: .875rem; font-weight: 800; color: var(--primary-lighter); }
.lyn-page .hist-exp-btr { width: 72px; height: 5px; background: rgba(255,255,255,.12); border-radius: 100px; overflow: hidden; }
.lyn-page .hist-exp-btf { height: 100%; border-radius: 100px; background: linear-gradient(90deg, #800F81, #C44BC5); }

/* ============================================================
   15. WHY SECTION (Local SEO / Backlinks)
   ============================================================ */
.lyn-page .why-section { background: #F8F9FF; }
.lyn-page .why-grid { display: grid; grid-template-columns: 1fr 1.05fr; gap: 80px; align-items: center; }
.lyn-page .why-vis { background: linear-gradient(135deg, var(--dark) 0%, #1A1A4E 100%); border-radius: var(--radius-lg); padding: 40px; position: relative; overflow: hidden; }
.lyn-page .why-vis::before { content: ''; position: absolute; top: -50px; right: -50px; width: 240px; height: 240px; background: radial-gradient(circle, rgba(128, 15, 129, .22), transparent 70%); }
.lyn-page .why-vis::after { content: ''; position: absolute; bottom: -80px; left: -40px; width: 200px; height: 200px; background: radial-gradient(circle, rgba(67, 97, 238, .2), transparent 70%); }
.lyn-page .why-stats { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; position: relative; z-index: 1; margin-bottom: 24px; }
.lyn-page .why-stat { padding: 26px 20px; background: rgba(255, 255, 255, .06); border: 1px solid rgba(255, 255, 255, .1); border-radius: 14px; text-align: center; backdrop-filter: blur(8px); }
.lyn-page .why-stat-num { font-size: 2.5rem; font-weight: 900; color: #fff !important; letter-spacing: -.03em; line-height: 1; margin-bottom: 8px; }
.lyn-page .why-stat-num .hl { color: #C44BC5 !important; }
.lyn-page .why-stat-lbl { font-size: .8125rem; color: rgba(255, 255, 255, .7); font-weight: 500; text-transform: uppercase; letter-spacing: .6px; line-height: 1.4; }
.lyn-page .search-mock { background: rgba(255, 255, 255, .06); border: 1px solid rgba(255, 255, 255, .1); border-radius: 14px; padding: 20px; position: relative; z-index: 1; }
.lyn-page .search-bar { display: flex; align-items: center; gap: 10px; background: rgba(255, 255, 255, .1); border-radius: 24px; padding: 12px 18px; margin-bottom: 16px; }
.lyn-page .search-bar span { color: #fff; font-size: .9375rem; flex: 1; font-weight: 500; }
.lyn-page .result-list { display: flex; flex-direction: column; gap: 8px; }
.lyn-page .result-row { display: flex; align-items: center; gap: 12px; padding: 10px 12px; background: rgba(255, 255, 255, .05); border-radius: 10px; border-left: 3px solid var(--primary); }
.lyn-page .result-rank { width: 24px; height: 24px; background: var(--primary); color: #fff; border-radius: 7px; display: flex; align-items: center; justify-content: center; font-size: .75rem; font-weight: 800; flex-shrink: 0; }
.lyn-page .result-row span.rt { font-size: .875rem; color: rgba(255, 255, 255, .92); font-weight: 600; flex: 1; }
.lyn-page .result-row.alt { border-left-color: rgba(255, 255, 255, .18); opacity: .55; }
.lyn-page .result-row.alt .result-rank { background: rgba(255, 255, 255, .15); color: rgba(255, 255, 255, .5); }
.lyn-page .rank-chart { background: rgba(255, 255, 255, .06); border: 1px solid rgba(255, 255, 255, .1); border-radius: 14px; padding: 22px; position: relative; z-index: 1; }
.lyn-page .rank-chart-head { display: flex; align-items: center; justify-content: space-between; margin-bottom: 16px; }
.lyn-page .rank-chart-head strong { font-size: .875rem; font-weight: 700; color: #fff; }
.lyn-page .rank-chart-head .delta { font-size: .75rem; color: #10B981; font-weight: 700; display: inline-flex; align-items: center; gap: 4px; }
.lyn-page .rank-rows { display: flex; flex-direction: column; gap: 10px; }
.lyn-page .rank-row { display: flex; align-items: center; gap: 10px; font-size: .75rem; }
.lyn-page .rank-row-label { color: rgba(255, 255, 255, .6); width: 48px; font-weight: 600; flex-shrink: 0; }
.lyn-page .rank-bar-track { flex: 1; height: 7px; background: rgba(255, 255, 255, .08); border-radius: 100px; overflow: hidden; position: relative; }
.lyn-page .rank-bar-fill { height: 100%; border-radius: 100px; transition: width 1s ease; }
.lyn-page .rb-1 { width: 18%; background: linear-gradient(90deg, #EF4444, #F87171); }
.lyn-page .rb-2 { width: 38%; background: linear-gradient(90deg, #F59E0B, #FBBF24); }
.lyn-page .rb-3 { width: 62%; background: linear-gradient(90deg, #3B82F6, #60A5FA); }
.lyn-page .rb-4 { width: 88%; background: linear-gradient(90deg, #10B981, #34D399); }
.lyn-page .rank-pos { color: #fff; font-weight: 800; width: 36px; text-align: right; flex-shrink: 0; font-size: .8125rem; }
.lyn-page .rank-pos .star { color: #F59E0B; margin-left: 2px; }

/* Shared Feat Item (used by why-features and about-features) */
.lyn-page .why-features { display: flex; flex-direction: column; gap: 22px; margin-bottom: 36px; }
.lyn-page .feat-item { display: flex; align-items: flex-start; gap: 16px; }
.lyn-page .feat-check { width: 28px; height: 28px; background: rgba(128, 15, 129, .12); border-radius: 8px; display: flex; align-items: center; justify-content: center; flex-shrink: 0; margin-top: 2px; }
.lyn-page .about-features .feat-check { width: 22px; height: 22px; border-radius: 6px; }
.lyn-page .feat-text strong { display: block; font-size: 1.0625rem; font-weight: 800; color: var(--dark); margin-bottom: 6px; letter-spacing: -.01em; }
.lyn-page .feat-text p { font-size: .9375rem; color: var(--gray); line-height: 1.7; margin: 0; }

/* ============================================================
   16. STATS BAR (orange gradient)
   ============================================================ */
.lyn-page .stats-bar { background: linear-gradient(135deg, var(--primary) 0%, #5F0A60 100%); padding: 72px 0; position: relative; overflow: hidden; }
.lyn-page .stats-bar::before { content: ''; position: absolute; inset: 0; background: url("data:image/svg+xml,%3Csvg width='60' height='60' xmlns='http://www.w3.org/2000/svg'%3E%3Cg fill='%23fff' fill-opacity='.04'%3E%3Cpath d='M36 34v-4h-2v4h-4v2h4v4h2v-4h4v-2h-4zm0-30V0h-2v4h-4v2h4v4h2V6h4V4h-4zM6 34v-4H4v4H0v2h4v4h2v-4h4v-2H6zM6 4V0H4v4H0v2h4v4h2V6h4V4H6z'/%3E%3C/g%3E%3C/svg%3E"); }
.lyn-page .stats-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 32px; position: relative; z-index: 1; }
.lyn-page .stat-block { text-align: center; padding: 8px; }
.lyn-page .sbn { font-size: 3rem; font-weight: 900; color: #fff !important; line-height: 1; margin-bottom: 10px; letter-spacing: -.03em; }
.lyn-page .sbl { font-size: .9375rem; color: rgba(255, 255, 255, .85); font-weight: 600; text-transform: uppercase; letter-spacing: 1.2px; }

/* ============================================================
   17. PRICING (3-tier with featured)
   ============================================================ */
.lyn-page .pricing-section { background: #fff; }
.lyn-page .pricing-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 26px; align-items: stretch; }
.lyn-page .price-card { background: #fff; border: 1px solid var(--border); border-radius: var(--radius-lg); padding: 42px 34px; transition: var(--tr); position: relative; display: flex; flex-direction: column; }
.lyn-page .price-card:hover { box-shadow: var(--shadow-lg); transform: translateY(-6px); }
.lyn-page .price-card.featured { background: linear-gradient(135deg, var(--dark) 0%, #1A1A4E 100%); color: #fff; border: none; transform: scale(1.04); box-shadow: 0 24px 64px rgba(13, 13, 43, .32); }
.lyn-page .price-card.featured:hover { transform: scale(1.04) translateY(-6px); }
.lyn-page .price-badge { position: absolute; top: -14px; left: 50%; transform: translateX(-50%); background: var(--primary); color: #fff !important; font-size: .75rem; font-weight: 800; letter-spacing: 1.2px; text-transform: uppercase; padding: 8px 18px; border-radius: 100px; box-shadow: 0 6px 16px rgba(128, 15, 129, .45); }
.lyn-page .price-icon { width: 68px; height: 68px; border-radius: 17px; display: flex; align-items: center; justify-content: center; margin-bottom: 22px; }
.lyn-page .price-card.featured .price-icon { background: rgba(128, 15, 129, .22); }
.lyn-page .price-card h3 { font-size: 1.5rem; font-weight: 800; margin-bottom: 8px; letter-spacing: -.02em; color: var(--dark); }
.lyn-page .price-card.featured h3 { color: #fff !important; }
.lyn-page .price-card .price-sub { font-size: .9375rem; color: var(--gray); margin-bottom: 26px; line-height: 1.5; }
.lyn-page .price-card.featured .price-sub { color: rgba(255, 255, 255, .7) !important; }
.lyn-page .price-tag { display: flex; align-items: baseline; gap: 4px; margin-bottom: 30px; padding-bottom: 26px; border-bottom: 1px dashed var(--border); }
.lyn-page .price-card.featured .price-tag { border-color: rgba(255, 255, 255, .15); }
.lyn-page .price-tag .cur { font-size: 1.375rem; font-weight: 700; color: var(--gray); }
.lyn-page .price-card.featured .price-tag .cur { color: rgba(255, 255, 255, .6) !important; }
.lyn-page .price-tag .amt { font-size: 3.25rem; font-weight: 900; color: var(--dark); line-height: 1; letter-spacing: -.04em; }
.lyn-page .price-card.featured .price-tag .amt { color: #fff !important; }
.lyn-page .price-tag .per { font-size: .9375rem; color: var(--gray); margin-left: 8px; }
.lyn-page .price-card.featured .price-tag .per { color: rgba(255, 255, 255, .55) !important; }
.lyn-page .price-features { display: flex; flex-direction: column; gap: 15px; margin-bottom: 34px; flex: 1; }
.lyn-page .pf { display: flex; align-items: flex-start; gap: 12px; font-size: 1rem; color: var(--dark); line-height: 1.5; }
.lyn-page .price-card.featured .pf { color: rgba(255, 255, 255, .9) !important; }
.lyn-page .pf-check { width: 22px; height: 22px; background: rgba(16, 185, 129, .14); border-radius: 50%; display: flex; align-items: center; justify-content: center; flex-shrink: 0; margin-top: 2px; }
.lyn-page .price-card.featured .pf-check { background: rgba(16, 185, 129, .25); }
.lyn-page .pf-mute { opacity: .4; }
.lyn-page .pf-mute .pf-check { background: var(--gray-light); }
.lyn-page .price-card.featured .pf-mute .pf-check { background: rgba(255, 255, 255, .08); }
.lyn-page .price-cta { padding: 15px 32px; border-radius: 10px; font-size: 15px; font-weight: 700; cursor: pointer; transition: var(--tr); text-align: center; display: block; border: 2px solid var(--border); background: #fff; color: var(--dark); text-decoration: none; }
.lyn-page .price-cta:hover { border-color: var(--primary); color: var(--primary); transform: translateY(-2px); }
.lyn-page .price-card.featured .price-cta { background: var(--primary); color: #fff; border-color: var(--primary); box-shadow: 0 6px 18px rgba(128, 15, 129, .4); }
.lyn-page .price-card.featured .price-cta:hover { background: var(--primary-dark); transform: translateY(-2px); color: #fff; }
.lyn-page .pricing-note { text-align: center; margin-top: 40px; font-size: 1rem; color: var(--gray); }
.lyn-page .pricing-note a { color: var(--primary); font-weight: 700; text-decoration: underline; text-underline-offset: 3px; }

/* ============================================================
   18. JOURNEY (5-step horizontal timeline)
   ============================================================ */
.lyn-page .journey-section { background: #F8F9FF; }
.lyn-page .journey-section .heading-lg { font-weight: 900; letter-spacing: -.025em; }
.lyn-page .journey-grid { display: grid; grid-template-columns: repeat(5, 1fr); gap: 22px; position: relative; }
.lyn-page .journey-grid::before { content: ''; position: absolute; top: 44px; left: 10%; right: 10%; height: 2px; background: linear-gradient(90deg, var(--primary), var(--purple), var(--green), var(--blue), var(--amber)); z-index: 0; border-radius: 2px; }
.lyn-page .journey-step { text-align: center; position: relative; z-index: 1; display: flex; flex-direction: column; align-items: center; }
.lyn-page .step-icon-wrap { width: 88px; height: 88px; border-radius: 50%; display: flex; align-items: center; justify-content: center; margin: 0 auto 22px; border: 4px solid #fff; box-shadow: 0 0 0 3px var(--border-soft); transition: var(--tr); position: relative; }
.lyn-page .step-1 { background: linear-gradient(135deg, #C44BC5, #800F81); }
.lyn-page .step-2 { background: linear-gradient(135deg, #A78BFA, #8B5CF6); }
.lyn-page .step-3 { background: linear-gradient(135deg, #34D399, #10B981); }
.lyn-page .step-4 { background: linear-gradient(135deg, #60A5FA, #4361EE); }
.lyn-page .step-5 { background: linear-gradient(135deg, #FBBF24, #F59E0B); }
.lyn-page .journey-step:hover .step-icon-wrap { transform: translateY(-4px) scale(1.05); box-shadow: 0 12px 32px rgba(0, 0, 0, .18); }
.lyn-page .step-num { position: absolute; top: -6px; right: -6px; width: 26px; height: 26px; background: var(--dark); color: #fff; border-radius: 50%; font-size: 11px; font-weight: 800; display: flex; align-items: center; justify-content: center; border: 2px solid #fff; }
.lyn-page .journey-step h3 { font-size: 1.25rem !important; font-weight: 700 !important; color: var(--dark); margin-bottom: 10px; min-height: 1.4em; display: flex; align-items: center; justify-content: center; letter-spacing: 0; }
.lyn-page .journey-step p { font-size: .9375rem; color: var(--gray); line-height: 1.65; min-height: 5em; max-width: 200px; }

/* ============================================================
   19. SERVICES SECTION (Homepage 3-col cards)
   ============================================================ */
.lyn-page .services-section { background: #F8F9FF; }
.lyn-page .services-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 24px; }
.lyn-page .service-card { background: #fff; border-radius: var(--radius-lg); padding: 32px; transition: var(--tr); border: 1px solid var(--border); }
.lyn-page .service-card:hover { transform: translateY(-6px); box-shadow: var(--shadow-lg); border-color: transparent; }
.lyn-page .svc-icon { width: 56px; height: 56px; border-radius: 14px; display: flex; align-items: center; justify-content: center; margin-bottom: 20px; }
.lyn-page .service-card h3 { font-size: 1.125rem; font-weight: 800; color: var(--dark); margin-bottom: 10px; }
.lyn-page .service-card p { font-size: .9375rem; color: var(--gray); line-height: 1.7; margin-bottom: 20px; }
.lyn-page .svc-link { display: inline-flex; align-items: center; gap: 6px; font-size: .875rem; font-weight: 700; color: var(--primary); transition: gap .2s; }
.lyn-page .svc-link:hover { gap: 10px; }

/* ============================================================
   20. INCLUDED (numbered cards 3-col)
   ============================================================ */
.lyn-page .included-section { background: linear-gradient(180deg, #fff 0%, #F8F9FF 100%); }
.lyn-page .included-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 26px; }
.lyn-page .inc-card { background: #fff; border-radius: var(--radius-xl); padding: 38px 32px; transition: var(--tr); border: 1px solid var(--border-soft); position: relative; overflow: hidden; box-shadow: 0 2px 8px rgba(13, 13, 43, .03); }
.lyn-page .inc-card::before { content: ''; position: absolute; top: 0; left: 0; right: 0; height: 5px; background: linear-gradient(90deg, var(--primary), var(--primary-light)); transform: scaleX(0); transition: transform .4s ease; transform-origin: left; border-radius: 5px 5px 0 0; }
.lyn-page .inc-card::after { content: ''; position: absolute; top: -30px; right: -30px; width: 140px; height: 140px; border-radius: 50%; background: radial-gradient(circle, rgba(128, 15, 129, .05), transparent 70%); opacity: 0; transition: opacity .4s; }
.lyn-page .inc-card:hover { transform: translateY(-8px); box-shadow: var(--shadow-xl); border-color: transparent; }
.lyn-page .inc-card:hover::before { transform: scaleX(1); }
.lyn-page .inc-card:hover::after { opacity: 1; }
.lyn-page .inc-num { position: absolute; top: 24px; right: 28px; font-size: 2.75rem; font-weight: 900; color: var(--gray-light); line-height: 1; letter-spacing: -.05em; transition: var(--tr); font-family: var(--font); }
.lyn-page .inc-card:hover .inc-num { color: var(--primary); opacity: .18; }
.lyn-page .inc-icon-grad { width: 64px; height: 64px; border-radius: 18px; display: flex; align-items: center; justify-content: center; margin-bottom: 24px; box-shadow: 0 10px 24px rgba(0, 0, 0, .12); position: relative; z-index: 1; }
.lyn-page .grad-red { background: linear-gradient(135deg, #C44BC5, #800F81); }
.lyn-page .grad-blue { background: linear-gradient(135deg, #60A5FA, #4361EE); }
.lyn-page .grad-purple { background: linear-gradient(135deg, #A78BFA, #8B5CF6); }
.lyn-page .grad-green { background: linear-gradient(135deg, #34D399, #10B981); }
.lyn-page .grad-amber { background: linear-gradient(135deg, #FBBF24, #F59E0B); }
.lyn-page .grad-pink { background: linear-gradient(135deg, #F472B6, #EC4899); }
.lyn-page .inc-card h3 { font-size: 1.25rem; font-weight: 800; color: var(--dark); margin-bottom: 12px; letter-spacing: -.01em; position: relative; z-index: 1; }
.lyn-page .inc-card > p { font-size: 1rem; color: var(--gray); line-height: 1.7; margin-bottom: 22px; position: relative; z-index: 1; }
.lyn-page .inc-list { display: flex; flex-direction: column; gap: 10px; padding-top: 20px; border-top: 1px dashed var(--border); position: relative; z-index: 1; }
.lyn-page .inc-list li { display: flex; align-items: center; gap: 10px; font-size: .9375rem; color: var(--dark); font-weight: 500; }
.lyn-page .inc-list svg { flex-shrink: 0; color: var(--green); }

/* ============================================================
   21. FAQ
   ============================================================ */
.lyn-page .faq-section { background: #F8F9FF; }
/* Default FAQ grid: 1fr 1.45fr (Local SEO / Backlinks pages) */
.lyn-page .faq-grid { display: grid; grid-template-columns: 1fr 1.45fr; gap: 64px; align-items: start; }
/* Equal grid variant (Homepage) */
.lyn-page .faq-grid.equal { grid-template-columns: 1fr 1fr; }
.lyn-page .faq-list { display: flex; flex-direction: column; gap: 14px; }
.lyn-page .faq-item { border: 1px solid var(--border); border-radius: 14px; overflow: hidden; transition: var(--tr); background: #fff; }
.lyn-page .faq-item.active { border-color: var(--primary); box-shadow: 0 6px 20px rgba(128, 15, 129, .1); }
.lyn-page .faq-q { display: flex; align-items: center; justify-content: space-between; gap: 16px; padding: 22px 26px; cursor: pointer; background: #fff; transition: background .2s; width: 100%; border: none; text-align: left; font-family: inherit; }
.lyn-page .faq-item.active .faq-q { background: rgba(128, 15, 129, .04); }
.lyn-page .faq-q span { font-size: 1.0625rem; font-weight: 700; color: var(--dark); flex: 1; letter-spacing: -.005em; }
.lyn-page .faq-toggle { width: 32px; height: 32px; background: var(--gray-light); border-radius: 50%; display: flex; align-items: center; justify-content: center; flex-shrink: 0; transition: var(--tr); }
.lyn-page .faq-item.active .faq-toggle { background: var(--primary); transform: rotate(45deg); }
.lyn-page .faq-item.active .faq-toggle svg { stroke: #fff; }
.lyn-page .faq-ans { max-height: 0; overflow: hidden; transition: max-height .4s ease; }
.lyn-page .faq-item.active .faq-ans { max-height: 320px; }
.lyn-page .faq-ans p { padding: 0 26px 24px; font-size: 1rem; color: var(--gray); line-height: 1.75; }
.lyn-page .faq-side, .lyn-page .faq-visual { position: sticky; top: 30px; }
.lyn-page .faq-card { background: linear-gradient(135deg, #0D0D2B, #1A1A4E); border-radius: var(--radius-lg); padding: 42px; color: #fff; position: relative; overflow: hidden; }
.lyn-page .faq-card::before { content: ''; position: absolute; top: -60px; right: -60px; width: 220px; height: 220px; background: radial-gradient(circle, rgba(128, 15, 129, .25), transparent 70%); }
.lyn-page .faq-card::after { content: ''; position: absolute; bottom: -80px; left: -50px; width: 200px; height: 200px; background: radial-gradient(circle, rgba(67, 97, 238, .2), transparent 70%); }
.lyn-page .faq-card-body { position: relative; z-index: 1; }
.lyn-page .faq-card h3 { font-size: 1.625rem; font-weight: 800; margin-bottom: 14px; letter-spacing: -.01em; color: #fff !important; line-height: 1.2; }
.lyn-page .faq-card .fc-desc, .lyn-page .faq-card > p { color: rgba(255, 255, 255, .78) !important; font-size: 1rem; line-height: 1.7; margin-bottom: 28px; }
.lyn-page .support-items { display: flex; flex-direction: column; gap: 14px; margin-bottom: 28px; }
.lyn-page .sup-item { display: flex; align-items: center; gap: 14px; padding: 16px 18px; background: rgba(255, 255, 255, .07); border-radius: 12px; border: 1px solid rgba(255, 255, 255, .1); }
.lyn-page .sup-item span { font-size: .9375rem; color: #fff !important; font-weight: 500; }

/* ============================================================
   22. CTA BANNER
   ============================================================ */
.lyn-page .cta-banner { background: linear-gradient(135deg, var(--primary) 0%, #5F0A60 100%); padding: 88px 0; position: relative; overflow: hidden; }
.lyn-page .cta-banner::before { content: ''; position: absolute; top: -100px; right: -100px; width: 400px; height: 400px; background: rgba(255, 255, 255, .07); border-radius: 50%; }
.lyn-page .cta-banner::after { content: ''; position: absolute; bottom: -150px; left: -50px; width: 350px; height: 350px; background: rgba(0, 0, 0, .1); border-radius: 50%; }
.lyn-page .cta-inner { display: flex; align-items: center; justify-content: space-between; gap: 40px; position: relative; z-index: 1; }
.lyn-page .cta-content h2 { font-size: clamp(2rem, 4vw, 2.75rem); font-weight: 800; color: #fff !important; margin-bottom: 14px; letter-spacing: -.02em; line-height: 1.15; }
.lyn-page .cta-content p { color: rgba(255, 255, 255, .9) !important; font-size: 1.125rem; max-width: 560px; line-height: 1.6; }
.lyn-page .cta-actions { display: flex; align-items: center; gap: 14px; flex-shrink: 0; flex-wrap: wrap; }

/* ============================================================
   23. CONTACT
   ============================================================ */
.lyn-page .contact-section { background: #F8F9FF; padding: 96px 0; }
.lyn-page .contact-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 64px; align-items: start; }
.lyn-page .contact-grid h3 { font-size: 1.5rem; font-weight: 800; color: var(--dark); margin-bottom: 28px; letter-spacing: -.01em; }
.lyn-page .cd-item { display: flex; align-items: flex-start; gap: 16px; margin-bottom: 22px; }
.lyn-page .cd-icon { width: 48px; height: 48px; background: rgba(128, 15, 129, .1); border-radius: 12px; display: flex; align-items: center; justify-content: center; flex-shrink: 0; }
.lyn-page .cd-text strong { display: block; font-size: .8125rem; font-weight: 700; color: var(--gray-soft); text-transform: uppercase; letter-spacing: 1px; margin-bottom: 4px; }
.lyn-page .cd-text span { font-size: 1rem; color: var(--dark); font-weight: 600; }
.lyn-page .form-placeholder { background: #fff; border: 2px dashed var(--border); border-radius: var(--radius-lg); padding: 56px 36px; text-align: center; }
.lyn-page .form-placeholder h4 { font-size: 1.25rem; font-weight: 800; color: var(--dark); margin: 18px 0 10px; }
.lyn-page .form-placeholder p { font-size: .9375rem; color: var(--gray); line-height: 1.7; }
.lyn-page .cal-placeholder { margin-top: 26px; background: #fff; border: 1px solid var(--border); border-radius: var(--radius-lg); padding: 34px; text-align: center; }
.lyn-page .cal-placeholder h4 { font-size: 1.125rem; font-weight: 800; color: var(--dark); margin: 16px 0 8px; }
.lyn-page .cal-placeholder p { font-size: .9375rem; color: var(--gray); line-height: 1.6; }
.lyn-page .cal-placeholder em { font-size: .8125rem; color: var(--gray); font-style: italic; display: block; margin-top: 14px; }

/* ============================================================
   24. ANIMATIONS (scroll-in + counter)
   ============================================================ */
.lyn-page .fade-up,
.lyn-page .fade-left,
.lyn-page .fade-right,
.lyn-page .fade-in,
.lyn-page .scale-in { opacity: 0; transition: opacity .7s ease, transform .8s cubic-bezier(.2, .8, .2, 1); }
.lyn-page .fade-up { transform: translateY(40px); }
.lyn-page .fade-left { transform: translateX(-40px); }
.lyn-page .fade-right { transform: translateX(40px); }
.lyn-page .scale-in { transform: scale(.94); }
.lyn-page .fade-up.visible,
.lyn-page .fade-left.visible,
.lyn-page .fade-right.visible,
.lyn-page .fade-in.visible,
.lyn-page .scale-in.visible { opacity: 1; transform: none; }
.lyn-page .fade-up:nth-child(2),
.lyn-page .fade-left:nth-child(2),
.lyn-page .fade-right:nth-child(2),
.lyn-page .fade-in:nth-child(2),
.lyn-page .scale-in:nth-child(2) { transition-delay: .08s; }
.lyn-page .fade-up:nth-child(3),
.lyn-page .fade-left:nth-child(3),
.lyn-page .fade-right:nth-child(3),
.lyn-page .fade-in:nth-child(3),
.lyn-page .scale-in:nth-child(3) { transition-delay: .16s; }
.lyn-page .fade-up:nth-child(4),
.lyn-page .fade-left:nth-child(4),
.lyn-page .fade-right:nth-child(4),
.lyn-page .fade-in:nth-child(4),
.lyn-page .scale-in:nth-child(4) { transition-delay: .24s; }
.lyn-page .fade-up:nth-child(5),
.lyn-page .fade-left:nth-child(5),
.lyn-page .fade-right:nth-child(5),
.lyn-page .fade-in:nth-child(5),
.lyn-page .scale-in:nth-child(5) { transition-delay: .32s; }
.lyn-page .fade-up:nth-child(6),
.lyn-page .fade-left:nth-child(6),
.lyn-page .fade-right:nth-child(6),
.lyn-page .fade-in:nth-child(6),
.lyn-page .scale-in:nth-child(6) { transition-delay: .4s; }
.lyn-page [data-delay="100"] { transition-delay: .1s !important; }
.lyn-page [data-delay="200"] { transition-delay: .2s !important; }
.lyn-page [data-delay="300"] { transition-delay: .3s !important; }
.lyn-page [data-delay="400"] { transition-delay: .4s !important; }
.lyn-page [data-delay="500"] { transition-delay: .5s !important; }

/* ============================================================
   25. RESPONSIVE
   ============================================================ */
@media (max-width: 1024px) {
  .lyn-page .hero-grid { grid-template-columns: 1fr; gap: 60px; }
  .lyn-page .hero-visual { display: none; }
  .lyn-page .why-grid { grid-template-columns: 1fr; gap: 48px; }
  .lyn-page .about-grid { grid-template-columns: 1fr; gap: 48px; }
  .lyn-page .hist-grid { grid-template-columns: 1fr; gap: 48px; }
  .lyn-page .offer-grid { grid-template-columns: repeat(2, 1fr); }
  .lyn-page .industries-grid { grid-template-columns: repeat(3, 1fr); }
  .lyn-page .pricing-grid { grid-template-columns: 1fr; gap: 32px; max-width: 480px; margin: 0 auto; }
  .lyn-page .price-card.featured { transform: none; }
  .lyn-page .price-card.featured:hover { transform: translateY(-6px); }
  .lyn-page .journey-grid { grid-template-columns: repeat(3, 1fr); gap: 36px 22px; }
  .lyn-page .journey-grid::before { display: none; }
  .lyn-page .journey-step p { min-height: auto; }
  .lyn-page .included-grid { grid-template-columns: repeat(2, 1fr); }
  .lyn-page .faq-grid { grid-template-columns: 1fr; gap: 40px; }
  .lyn-page .faq-side, .lyn-page .faq-visual { position: static; order: -1; }
}
@media (max-width: 768px) {
  .lyn-page .section { padding: 72px 0; }
  .lyn-page .hero { padding: 60px 0 70px; }
  .lyn-page .hero h1 { font-size: clamp(2rem, 7vw, 2.75rem); }
  .lyn-page .hero-badges { flex-wrap: wrap; gap: 16px; }
  .lyn-page .cards-grid { grid-template-columns: 1fr; gap: 16px; }
  .lyn-page .services-grid { grid-template-columns: 1fr; }
  .lyn-page .offer-grid { grid-template-columns: 1fr; gap: 18px; }
  .lyn-page .industries-grid { grid-template-columns: repeat(2, 1fr); }
  .lyn-page .stats-grid { grid-template-columns: repeat(2, 1fr); gap: 32px; }
  .lyn-page .included-grid { grid-template-columns: 1fr; }
  .lyn-page .journey-grid { grid-template-columns: 1fr 1fr; }
  .lyn-page .cta-inner { flex-direction: column; text-align: center; }
  .lyn-page .cta-actions { flex-direction: column; width: 100%; }
  .lyn-page .cta-actions .btn { justify-content: center; width: 100%; }
  .lyn-page .contact-grid { grid-template-columns: 1fr; gap: 40px; }
  .lyn-page .why-stats { grid-template-columns: 1fr 1fr; }
}
@media (max-width: 480px) {
  .lyn-page .stats-grid { grid-template-columns: 1fr 1fr; }
  .lyn-page .journey-grid { grid-template-columns: 1fr; gap: 32px; }
  .lyn-page .industries-grid { grid-template-columns: 1fr 1fr; }
  .lyn-page .hero-actions { flex-direction: column; width: 100%; }
  .lyn-page .hero-actions .btn { justify-content: center; width: 100%; }
  .lyn-page .price-card { padding: 36px 26px; }
  .lyn-page .price-tag .amt { font-size: 2.75rem; }
  .lyn-page .float-badge { padding: 10px 14px; }
  .lyn-page .fb1 { right: -10px; }
  .lyn-page .fb2 { left: -10px; }
}

/* ============================================================
   26. FACEBOOK ADS PAGE — Meta-specific accents + utilities
   ============================================================ */
/* Meta / Facebook brand-blue gradient (used on dashboard header icon) */
.lyn-page .fb-meta { background: linear-gradient(135deg, #1877F2, #0866FF) !important; }

/* Facebook-blue feed-icon variant (matches fi-1 / fi-2 / fi-3 / fi-4 pattern) */
.lyn-page .feed-icon.fi-fb { background: linear-gradient(135deg, #1877F2, #0866FF); }

/* Success-green pill variant for "ACTIVE" campaign rows */
.lyn-page .da-pill.pill-success { color: var(--green); background: rgba(16, 185, 129, .12); }

/* Current-page item inside the breadcrumb (white emphasis) */
.lyn-page .breadcrumb .current { color: rgba(255, 255, 255, .85); }

/* Force a span to display block (e.g. sub-line under dashboard title) */
.lyn-page .bl-head-l span.block { display: block; }

/* Default spacing between heading and body inside section-headers */
.lyn-page .section-header .body-lg { margin-top: 16px; }

/* Lead-paragraph spacing inside the why-grid right column */
.lyn-page .why-grid .body-lg { margin: 18px 0 36px; }

/* Block-level (full-width, centered) button modifier */
.lyn-page .btn-block { width: 100%; justify-content: center; }

/* Center-aligned standalone SVG (placeholder cards) */
.lyn-page .svg-center { margin: 0 auto; }

/* ============================================================
   27. ADVANCED ANIMATIONS (v3 — universal, applied site-wide)
   Pulled from contact page so every .lyn-page gets these effects.
   The accompanying lyn-global.js auto-injects required DOM nodes.
   ============================================================ */

/* --- Scroll progress bar (fixed at viewport top, JS-injected) --- */
.lyn-scroll-progress { position: fixed; top: 0; left: 0; height: 3px; width: 0; background: linear-gradient(90deg, var(--primary), var(--primary-light), var(--blue)); z-index: 9999; transition: width .1s ease-out; box-shadow: 0 0 14px rgba(128, 15, 129, .55); border-radius: 0 3px 3px 0; pointer-events: none; }

/* --- Hero animated grid overlay (JS-injected into .hero) --- */
.lyn-page .lyn-hero-grid-bg { position: absolute; inset: 0; background-image: linear-gradient(rgba(255, 255, 255, .028) 1px, transparent 1px), linear-gradient(90deg, rgba(255, 255, 255, .028) 1px, transparent 1px); background-size: 54px 54px; animation: lyn-gridDrift 40s linear infinite; pointer-events: none; z-index: 0; -webkit-mask-image: radial-gradient(ellipse 70% 55% at 50% 50%, #000 25%, transparent 80%); mask-image: radial-gradient(ellipse 70% 55% at 50% 50%, #000 25%, transparent 80%); }
@keyframes lyn-gridDrift { from { background-position: 0 0; } to { background-position: 54px 54px; } }

/* --- Hero floating particles (8 colored orbs, JS-injected) --- */
.lyn-page .lyn-hero-particles { position: absolute; inset: 0; pointer-events: none; z-index: 0; overflow: hidden; }
.lyn-page .lyn-particle { position: absolute; border-radius: 50%; filter: blur(.5px); }
.lyn-page .lyn-p1 { width: 6px; height: 6px; top: 22%; left: 12%; background: radial-gradient(circle, rgba(255, 138, 92, .9), transparent 70%); animation: lyn-particleFloat 18s linear infinite; }
.lyn-page .lyn-p2 { width: 4px; height: 4px; top: 62%; left: 22%; background: radial-gradient(circle, rgba(96, 165, 250, .8), transparent 70%); animation: lyn-particleFloat 22s linear infinite 3s; }
.lyn-page .lyn-p3 { width: 8px; height: 8px; top: 38%; left: 82%; background: radial-gradient(circle, rgba(196, 75, 197, .85), transparent 70%); animation: lyn-particleFloat 20s linear infinite 6s; }
.lyn-page .lyn-p4 { width: 5px; height: 5px; top: 78%; left: 72%; background: radial-gradient(circle, rgba(52, 211, 153, .8), transparent 70%); animation: lyn-particleFloat 16s linear infinite 9s; }
.lyn-page .lyn-p5 { width: 3px; height: 3px; top: 18%; left: 52%; background: radial-gradient(circle, rgba(255, 255, 255, .9), transparent 70%); animation: lyn-particleFloat 24s linear infinite 2s; }
.lyn-page .lyn-p6 { width: 7px; height: 7px; top: 72%; left: 42%; background: radial-gradient(circle, rgba(139, 92, 246, .7), transparent 70%); animation: lyn-particleFloat 19s linear infinite 12s; }
.lyn-page .lyn-p7 { width: 4px; height: 4px; top: 48%; left: 30%; background: radial-gradient(circle, rgba(252, 211, 77, .8), transparent 70%); animation: lyn-particleFloat 21s linear infinite 15s; }
.lyn-page .lyn-p8 { width: 6px; height: 6px; top: 32%; left: 65%; background: radial-gradient(circle, rgba(161, 35, 162, .8), transparent 70%); animation: lyn-particleFloat 17s linear infinite 5s; }
@keyframes lyn-particleFloat {
  0% { transform: translate(0, 20px) scale(.6); opacity: 0; }
  10% { opacity: .9; }
  50% { transform: translate(30px, -80px) scale(1.3); opacity: .7; }
  90% { opacity: .5; }
  100% { transform: translate(-20px, -160px) scale(.7); opacity: 0; }
}

/* --- Hero tag shimmer sweep --- */
.lyn-page .hero-tag { position: relative; overflow: hidden; }
.lyn-page .hero-tag::after { content: ''; position: absolute; top: 0; left: -100%; width: 60%; height: 100%; background: linear-gradient(90deg, transparent, rgba(196, 75, 197, .35), transparent); animation: lyn-tagShimmer 3.5s ease-in-out infinite; pointer-events: none; }
@keyframes lyn-tagShimmer { 0% { left: -100%; } 60%, 100% { left: 150%; } }

/* --- Breadcrumb arrow gentle bounce --- */
.lyn-page .breadcrumb svg { animation: lyn-bcBounce 2.5s ease-in-out infinite; }
@keyframes lyn-bcBounce { 0%, 100% { transform: translateX(0); } 50% { transform: translateX(4px); } }

/* --- Scroll indicator (mouse + dot, JS-injected at first .hero bottom) --- */
.lyn-page .lyn-scroll-ind { position: absolute; bottom: 28px; left: 50%; transform: translateX(-50%); z-index: 2; display: flex; flex-direction: column; align-items: center; gap: 10px; color: rgba(255, 255, 255, .55); font-size: .68rem; letter-spacing: 2.2px; text-transform: uppercase; font-weight: 700; pointer-events: none; animation: lyn-scrollIndIn 1.5s 1s both; }
@keyframes lyn-scrollIndIn { from { opacity: 0; transform: translate(-50%, 20px); } to { opacity: 1; transform: translate(-50%, 0); } }
.lyn-page .lyn-scroll-ind-mouse { width: 24px; height: 38px; border: 2px solid rgba(255, 255, 255, .4); border-radius: 14px; position: relative; }
.lyn-page .lyn-scroll-ind-mouse::before { content: ''; position: absolute; top: 6px; left: 50%; transform: translateX(-50%); width: 3px; height: 7px; background: #fff; border-radius: 2px; animation: lyn-scrollMouse 2s ease-in-out infinite; }
@keyframes lyn-scrollMouse { 0% { transform: translate(-50%, 0); opacity: 1; } 70% { transform: translate(-50%, 14px); opacity: 0; } 100% { transform: translate(-50%, 0); opacity: 0; } }

/* --- Universal ripple effect (JS attaches to clicks) --- */
.lyn-ripple-eff { position: absolute; border-radius: 50%; transform: scale(0); animation: lyn-rippleAnim .7s ease-out; background: rgba(128, 15, 129, .28); pointer-events: none; z-index: 2; }
@keyframes lyn-rippleAnim { to { transform: scale(4); opacity: 0; } }

/* --- 3D tilt wrapper (JS reads [data-tilt]) --- */
.lyn-page .tilt-wrap { perspective: 1200px; }
.lyn-page .tilt-inner { transition: transform .25s cubic-bezier(.4, 0, .2, 1); transform-style: preserve-3d; will-change: transform; }

/* --- Card icon bounce on hover (applies to all card-style icons) --- */
.lyn-page .service-card .svc-icon svg,
.lyn-page .offer-card .offer-icon svg,
.lyn-page .card .card-icon svg,
.lyn-page .wu-card .wu-icon svg,
.lyn-page .ind-card .ind-icon svg { transition: transform .45s cubic-bezier(.34, 1.56, .64, 1); }
.lyn-page .service-card:hover .svc-icon svg,
.lyn-page .offer-card:hover .offer-icon svg,
.lyn-page .card:hover .card-icon svg,
.lyn-page .wu-card:hover .wu-icon svg,
.lyn-page .ind-card:hover .ind-icon svg { animation: lyn-iconBounce .55s ease; }
@keyframes lyn-iconBounce { 0% { transform: translateY(0); } 40% { transform: translateY(-7px); } 60% { transform: translateY(-4px); } 100% { transform: translateY(0); } }

/* --- Stats pulse dot (above each stat number) --- */
.lyn-page .stat-block { position: relative; }
.lyn-page .stat-block::before { content: ''; position: absolute; top: -6px; left: 50%; transform: translateX(-50%); width: 4px; height: 4px; background: #fff; border-radius: 50%; box-shadow: 0 0 10px #fff; opacity: .75; animation: lyn-statDot 3s ease-in-out infinite; }
@keyframes lyn-statDot { 0%, 100% { transform: translateX(-50%) scale(1); opacity: .6; } 50% { transform: translateX(-50%) scale(1.8); opacity: 1; } }
.lyn-page .stat-block:hover .sbn { text-shadow: 0 0 36px rgba(255, 255, 255, .55); transition: text-shadow .3s; }

/* --- Social icon spin on hover (footer + social cards) --- */
.lyn-page .soc-link svg,
.lyn-page .social-card .sc-ico svg,
.lyn-page .social-links a svg { transition: transform .5s cubic-bezier(.34, 1.56, .64, 1); }
.lyn-page .soc-link:hover svg,
.lyn-page .social-card:hover .sc-ico svg,
.lyn-page .social-links a:hover svg { animation: lyn-iconSpin 1s ease; }
@keyframes lyn-iconSpin { to { transform: rotate(360deg); } }

/* --- FAQ answer fade + slide (layered on top of max-height) --- */
.lyn-page .faq-ans p { opacity: 0; transform: translateY(-8px); transition: opacity .35s .08s ease, transform .35s .08s ease; }
.lyn-page .faq-item.active .faq-ans p { opacity: 1; transform: none; }

/* --- CTA banner — animated wave (JS-injected SVG) --- */
.lyn-page .lyn-cta-wave { position: absolute; bottom: -1px; left: 0; right: 0; height: 80px; z-index: 0; pointer-events: none; opacity: .45; }
.lyn-page .lyn-cta-wave svg { width: 200%; height: 100%; display: block; animation: lyn-waveMove 14s linear infinite; }
@keyframes lyn-waveMove { 0% { transform: translate3d(0, 0, 0); } 100% { transform: translate3d(-50%, 0, 0); } }
.lyn-page .cta-banner > .container { position: relative; z-index: 1; }

/* --- CTA white-button ring pulse --- */
.lyn-page .cta-actions .btn-white { position: relative; }
.lyn-page .cta-actions .btn-white::before { content: ''; position: absolute; inset: -4px; border-radius: inherit; border: 2px solid rgba(255, 255, 255, .5); animation: lyn-ringPulse 2.2s ease-out infinite; pointer-events: none; }
@keyframes lyn-ringPulse { 0% { transform: scale(1); opacity: 1; } 100% { transform: scale(1.7); opacity: 0; } }

/* --- Float badge hover scale --- */
.lyn-page .float-badge { transition: transform .3s ease, box-shadow .3s ease; }
.lyn-page .float-badge:hover { transform: scale(1.08) !important; box-shadow: 0 18px 48px rgba(0, 0, 0, .28); z-index: 10; }

/* --- Quick-card / icon glow on hover (color-aware via shadow) --- */
.lyn-page .ig-item:hover { box-shadow: 0 0 28px rgba(128, 15, 129, .25); }

/* ============================================================
   28. REDUCED MOTION
   ============================================================ */
@media (prefers-reduced-motion: reduce) {
  .lyn-page *,
  .lyn-page *::before,
  .lyn-page *::after { animation-duration: .01ms !important; transition-duration: .01ms !important; }
  .lyn-page .fade-up,
  .lyn-page .fade-left,
  .lyn-page .fade-right,
  .lyn-page .fade-in,
  .lyn-page .scale-in { opacity: 1 !important; transform: none !important; }
  .lyn-scroll-progress,
  .lyn-page .lyn-particle,
  .lyn-page .lyn-hero-grid-bg,
  .lyn-page .lyn-scroll-ind { display: none !important; }
}
