/* ============================================================
   ВІНСОФТ — style.css v2  |  Vibrant Design System
   Bold · Playful · Colorful · Dynamic
   ============================================================ */

/* ── 1. TOKENS ──────────────────────────────────────────────── */
:root {
  --primary:        #7C61D4;
  --primary-dark:   #5b43b0;
  --primary-light:  #a48de0;
  --primary-bg:     #ede9fa;
  --primary-bg2:    #f5f2fd;

  --secondary:      #EAAE87;
  --secondary-dark: #d4834a;
  --secondary-bg:   #fdf3eb;

  --success:  #16A34A;
  --warning:  #D97706;
  --danger:   #DC2626;

  --surface:  #FFFFFF;
  --neutral:  #FAF9FF;
  --text:     #2F281D;
  --text-2:   #5c5247;
  --text-3:   #a09890;
  --border:   #e8e2f8;

  --font-sans:    'Noto Sans', system-ui, sans-serif;
  --font-display: 'Syne', system-ui, sans-serif;
  --font-mono:    'Fira Code', monospace;

  --sp-2:2px; --sp-4:4px; --sp-8:8px; --sp-12:12px;
  --sp-16:16px; --sp-24:24px; --sp-32:32px; --sp-48:48px;

  --r-sm: 8px;
  --r:    16px;
  --r-lg: 24px;
  --r-xl: 40px;

  --shadow-sm: 0 2px 8px rgba(124,97,212,0.10);
  --shadow:    0 6px 24px rgba(124,97,212,0.16), 0 2px 6px rgba(0,0,0,0.05);
  --shadow-lg: 0 16px 48px rgba(124,97,212,0.22), 0 4px 12px rgba(0,0,0,0.08);
  --shadow-clr:0 8px 32px rgba(124,97,212,0.40);

  --ease: cubic-bezier(0.4,0,0.2,1);
  --t:    0.22s;
  --h:    72px;

  --g-brand:   linear-gradient(135deg, #7C61D4 0%, #EAAE87 100%);
  --g-purple:  linear-gradient(135deg, #5b43b0 0%, #7C61D4 100%);
  --g-warm:    linear-gradient(135deg, #EAAE87 0%, #d4834a 100%);
  --g-dark:    linear-gradient(145deg, #120e24 0%, #1e1540 45%, #2d1e08 100%);
  --g-section: linear-gradient(160deg, #f5f2fd 0%, #fdf3eb 100%);
}

/* ── 2. RESET ───────────────────────────────────────────────── */
*, *::before, *::after { box-sizing:border-box; margin:0; padding:0; }
html { scroll-behavior:smooth; font-size:16px; -webkit-text-size-adjust:100%; }
@media (prefers-reduced-motion:reduce) {
  *,*::before,*::after { animation-duration:.01ms!important; transition-duration:.01ms!important; }
  html { scroll-behavior:auto; }
}
body {
  font-family: var(--font-sans);
  font-size: 1rem;
  line-height: 1.65;
  color: var(--text);
  background: var(--surface);
  overflow-x: hidden;
}
a { color:var(--primary); text-decoration:none; transition:color var(--t) var(--ease); }
a:hover { color:var(--primary-dark); }
a:focus-visible { outline:3px solid var(--primary); outline-offset:3px; border-radius:4px; }
img,svg { display:block; max-width:100%; }
ul,ol { list-style:none; }
button { cursor:pointer; font-family:inherit; border:none; background:none; }
input,select,textarea { font-family:inherit; }

/* ── 3. LAYOUT ──────────────────────────────────────────────── */
.container { width:min(1200px, 100% - 40px); margin-inline:auto; }
.section { padding-block: 100px; }

/* ── 4. TYPOGRAPHY HELPERS ──────────────────────────────────── */
.chip {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-family: var(--font-mono);
  font-size: 0.75rem;
  font-weight: 500;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  padding: 6px 14px;
  border-radius: 99px;
  background: var(--primary-bg);
  color: var(--primary);
  border: 1.5px solid rgba(124,97,212,0.2);
  margin-bottom: var(--sp-16);
}
.chip::before {
  content: '';
  width: 7px; height: 7px;
  border-radius: 50%;
  background: var(--primary);
  flex-shrink: 0;
}

.section-head { text-align:center; max-width:660px; margin-inline:auto; margin-bottom:60px; }

.section-title {
  font-family: var(--font-display);
  font-size: clamp(1.875rem, 4.5vw, 2.75rem);
  font-weight: 800;
  line-height: 1.1;
  color: var(--text);
  margin-bottom: var(--sp-16);
}
.section-title span { color: var(--primary); }
.section-title mark {
  background: var(--g-brand);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
  font-style: normal;
}

.section-desc { font-size: 1.0625rem; color: var(--text-2); line-height:1.75; }

/* ── 5. BUTTONS ─────────────────────────────────────────────── */
.btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  font-weight: 700;
  font-size: 0.9375rem;
  border-radius: var(--r);
  padding: 13px 26px;
  min-height: 48px;
  border: 2px solid transparent;
  cursor: pointer;
  transition: transform var(--t) var(--ease), box-shadow var(--t) var(--ease),
              background var(--t) var(--ease), border-color var(--t) var(--ease),
              color var(--t) var(--ease);
  white-space: nowrap;
  position: relative;
  overflow: hidden;
  text-decoration: none;
}
.btn:focus-visible { outline:3px solid var(--primary); outline-offset:3px; }
.btn:active { transform: translateY(1px) scale(0.98) !important; }

.btn--primary {
  background: var(--g-purple);
  color: #fff;
  box-shadow: 0 4px 16px rgba(92,67,176,0.4);
}
.btn--primary:hover { transform:translateY(-2px); box-shadow:0 8px 28px rgba(92,67,176,0.5); color:#fff; }

.btn--secondary {
  background: var(--g-warm);
  color: #fff;
  box-shadow: 0 4px 16px rgba(212,131,74,0.35);
}
.btn--secondary:hover { transform:translateY(-2px); box-shadow:0 8px 28px rgba(212,131,74,0.5); color:#fff; }

.btn--outline {
  border-color: var(--primary);
  color: var(--primary);
  background: transparent;
}
.btn--outline:hover { background:var(--primary-bg); border-color:var(--primary-dark); }

.btn--ghost {
  color: rgba(255,255,255,0.92);
  border-color: rgba(255,255,255,0.35);
  background: rgba(255,255,255,0.08);
  backdrop-filter: blur(12px);
}
.btn--ghost:hover { background:rgba(255,255,255,0.18); border-color:rgba(255,255,255,0.7); color:#fff; }

.btn--sm  { padding:9px 18px; font-size:0.875rem; min-height:38px; border-radius:10px; }
.btn--lg  { padding:16px 36px; font-size:1.0625rem; border-radius:var(--r-lg); }
.btn--xl  { padding:18px 44px; font-size:1.125rem; border-radius:var(--r-lg); }
.btn--full{ width:100%; }

/* ── 6. HEADER ──────────────────────────────────────────────── */
.header {
  position: sticky;
  top: 0; z-index: 200;
  height: var(--h);
  background: rgba(255,255,255,0.92);
  backdrop-filter: blur(20px) saturate(180%);
  border-bottom: 1.5px solid var(--border);
  transition: box-shadow var(--t) var(--ease), background var(--t) var(--ease);
}
.header.scrolled { box-shadow: 0 2px 24px rgba(124,97,212,0.15); background:rgba(255,255,255,0.97); }
.header__inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  height: 100%;
  gap: var(--sp-16);
}

/* ── LOGO ───────────────────────────────────────────────────── */
.logo { display:flex; align-items:center; gap:12px; text-decoration:none; flex-shrink:0; }
.logo__mark { position:relative; flex-shrink:0; }

/* Hexagon draws in */
.logo-hex {
  stroke-dasharray: 120;
  stroke-dashoffset: 120;
  animation: logo-draw 0.9s cubic-bezier(0.4,0,0.2,1) 0s forwards;
}
/* Horizontal cross arm */
.logo-cross--h {
  stroke-dasharray: 22;
  stroke-dashoffset: 22;
  animation: logo-draw 0.38s cubic-bezier(0.4,0,0.2,1) 0.75s forwards;
}
/* Vertical cross arm */
.logo-cross--v {
  stroke-dasharray: 22;
  stroke-dashoffset: 22;
  animation: logo-draw 0.38s cubic-bezier(0.4,0,0.2,1) 0.85s forwards;
}
/* Nodes pop in */
.logo-node {
  opacity: 0;
  transform-origin: center;
  transform-box: fill-box;
  animation: logo-node-in 0.32s cubic-bezier(0.34,1.56,0.64,1) forwards;
}
.logo-node--t { animation-delay: 0.95s; }
.logo-node--r { animation-delay: 1.05s; }
.logo-node--b { animation-delay: 1.10s; }
.logo-node--l { animation-delay: 1.00s; }
.logo-node--c { animation-delay: 1.18s; }

/* Hover: glow the whole mark */
.logo__mark { transition: filter 0.35s ease; }
.logo:hover .logo__mark {
  filter: drop-shadow(0 0 5px rgba(124,97,212,0.6))
          drop-shadow(0 0 12px rgba(167,139,250,0.3));
}

@keyframes logo-draw    { to { stroke-dashoffset: 0; } }
@keyframes logo-node-in { from{opacity:0;transform:scale(0)} to{opacity:1;transform:scale(1)} }

.logo__text     { display:flex; flex-direction:column; line-height:1.2; }
.logo__name     { font-family:var(--font-display); font-size:1.125rem; font-weight:800; color:var(--text); letter-spacing:0.03em; }
.logo__tagline  { font-family:var(--font-mono); font-size:0.65rem; color:var(--primary); letter-spacing:0.1em; }

/* Nav */
.nav__list { display:flex; align-items:center; gap:2px; }
.nav__link {
  font-size: 0.9375rem;
  font-weight: 600;
  color: var(--text-2);
  padding: 8px 14px;
  border-radius: 10px;
  transition: color var(--t) var(--ease), background var(--t) var(--ease);
}
.nav__link:hover { color:var(--primary); background:var(--primary-bg); }
.nav__link.active { color:var(--primary); background:var(--primary-bg); }

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

.lang-toggle {
  display: flex; align-items:center; gap:4px;
  font-family: var(--font-mono); font-size:0.8125rem; font-weight:700;
  color: var(--text-2); padding:7px 12px;
  border-radius:10px; border:2px solid var(--border); background:var(--surface);
  transition: border-color var(--t) var(--ease), color var(--t) var(--ease), background var(--t) var(--ease);
}
.lang-toggle:hover { border-color:var(--primary); color:var(--primary); background:var(--primary-bg); }
.lang-toggle__active { color:var(--primary); }
.lang-toggle__sep { opacity:0.35; }

.burger {
  display:none; flex-direction:column; justify-content:center; align-items:center;
  gap:5px; width:44px; height:44px; border-radius:12px;
  transition:background var(--t) var(--ease);
}
.burger:hover { background:var(--primary-bg); }
.burger span { display:block; width:22px; height:2.5px; background:var(--text); border-radius:2px; transition:transform var(--t) var(--ease),opacity var(--t) var(--ease); }
.burger.open span:nth-child(1) { transform:translateY(7.5px) rotate(45deg); }
.burger.open span:nth-child(2) { opacity:0; transform:scaleX(0); }
.burger.open span:nth-child(3) { transform:translateY(-7.5px) rotate(-45deg); }

.mobile-menu {
  display:none; position:absolute; top:var(--h); left:0; right:0;
  background:var(--surface); border-bottom:2px solid var(--border);
  box-shadow:var(--shadow-lg); padding:16px 16px 24px; z-index:199;
}
.mobile-menu.open { display:block; animation:fade-down 0.2s var(--ease); }
@keyframes fade-down { from{opacity:0;transform:translateY(-8px)} to{opacity:1;transform:none} }
.mobile-menu__list { display:flex; flex-direction:column; gap:4px; }
.mobile-menu__link {
  display:block; padding:13px 18px; font-size:1rem; font-weight:600;
  color:var(--text); border-radius:12px;
  transition:background var(--t) var(--ease),color var(--t) var(--ease);
}
.mobile-menu__link:hover { background:var(--primary-bg); color:var(--primary); }

/* ── 7. HERO ────────────────────────────────────────────────── */
.hero {
  position: relative;
  min-height: calc(100vh - var(--h));
  display: flex;
  align-items: center;
  overflow: hidden;
  background: #090614;
  color: #fff;
}
.hero__bg {
  position: absolute;
  inset: 0;
  pointer-events: none;
  overflow: hidden;
}

/* Slow-drifting color orbs — CSS only, no JS, no flash, epilepsy-safe */
.hero__orb {
  position: absolute;
  border-radius: 50%;
  will-change: transform;
}

/* TOP-LEFT: deep violet */
.hero__orb--1 {
  width: 1400px; height: 1400px;
  top: -50%; left: -35%;
  background: radial-gradient(circle at 38% 38%,
    rgba(95,50,215,1)    0%,
    rgba(75,38,170,0.7)  25%,
    rgba(50,22,120,0.25) 52%,
    transparent          68%);
  filter: blur(50px);
}

/* BOTTOM-RIGHT: amber/orange */
.hero__orb--2 {
  width: 1300px; height: 1300px;
  bottom: -45%; right: -32%;
  background: radial-gradient(circle at 62% 62%,
    rgba(215,88,15,1)    0%,
    rgba(175,72,25,0.65) 26%,
    rgba(130,55,18,0.22) 52%,
    transparent          68%);
  filter: blur(48px);
}

/* TOP-RIGHT: deep indigo */
.hero__orb--3 {
  width: 1000px; height: 1000px;
  top: -30%; right: -22%;
  background: radial-gradient(circle at 58% 32%,
    rgba(25,12,135,0.85) 0%,
    rgba(45,28,155,0.48) 28%,
    transparent          62%);
  filter: blur(60px);
}

/* BOTTOM-LEFT: violet */
.hero__orb--4 {
  width: 950px; height: 950px;
  bottom: -25%; left: -20%;
  background: radial-gradient(circle at 36% 64%,
    rgba(145,42,195,0.75) 0%,
    rgba(115,35,160,0.40) 30%,
    transparent           62%);
  filter: blur(62px);
}

/* CENTER: soft violet bridge */
.hero__orb--5 {
  width: 900px; height: 900px;
  top: 50%; left: 50%;
  transform: translate(-50%, -50%);
  background: radial-gradient(circle at center,
    rgba(85,50,175,0.28) 0%,
    transparent          65%);
  filter: blur(90px);
}

/* Subtle film-grain noise overlay for cinematic depth */
.hero__noise {
  position: absolute;
  inset: 0;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='200' height='200'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.75' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='200' height='200' filter='url(%23n)' opacity='1'/%3E%3C/svg%3E");
  opacity: 0.035;
  pointer-events: none;
}

.hero::after {
  content: ''; position: absolute; bottom: -2px; left: 0; right: 0;
  height: 80px; background: var(--surface);
  clip-path: polygon(0 100%, 100% 0, 100% 100%);
  z-index: 2;
}

.hero__content { position:relative; z-index:3; padding-block:90px 120px; max-width:780px; }

.hero__badge {
  display: inline-flex; align-items:center; gap:8px;
  font-family:var(--font-mono); font-size:0.8125rem; font-weight:500;
  color:var(--secondary); background:rgba(234,174,135,.12);
  border:1.5px solid rgba(234,174,135,.35); padding:7px 16px;
  border-radius:99px; margin-bottom:24px;
  opacity: 0; /* GSAP animates this in */
}
.hero__badge-dot { width:8px;height:8px;background:var(--secondary);border-radius:50%;animation:dot-glow 2s ease-in-out infinite; }

.hero__title {
  font-family: var(--font-display);
  font-size: clamp(2.25rem, 5.5vw, 3.75rem);
  font-weight: 800;
  line-height: 1.1;
  color: #fff;
  margin-bottom: 24px;
  opacity: 0;
}
.hero__title em {
  font-style: normal;
  background: linear-gradient(90deg,#EAAE87 0%,#c98cff 55%,#7C61D4 100%);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
}

.hero__desc {
  font-size: 1.1875rem;
  color: rgba(255,255,255,.72);
  max-width: 580px;
  margin-bottom: 40px;
  line-height: 1.8;
  opacity: 0;
}

.hero__actions {
  display:flex; flex-wrap:wrap; gap:14px;
  margin-bottom:64px;
  opacity: 0;
}

.hero__stats {
  display:flex; flex-wrap:wrap; gap:0;
  opacity: 0;
  background:rgba(255,255,255,.05);
  border:1.5px solid rgba(255,255,255,.1);
  border-radius:var(--r-lg);
  backdrop-filter:blur(12px);
  overflow:hidden; width:fit-content;
}
.stat { display:flex; flex-direction:column; align-items:center; padding:20px 36px; border-right:1.5px solid rgba(255,255,255,.1); }
.stat:last-child { border-right:none; }
.stat__num  { font-family:var(--font-display); font-size:2.25rem; color:#fff; line-height:1; }
.stat__unit { font-size:1.5rem; color:var(--secondary); font-family:var(--font-display); }
.stat__label{ font-family:var(--font-mono); font-size:.72rem; color:rgba(255,255,255,.5); letter-spacing:.05em; margin-top:5px; text-align:center; }

.hero__scroll { position:absolute; bottom:96px; left:50%; transform:translateX(-50%); z-index:3; display:flex; flex-direction:column; align-items:center; gap:8px; }
.hero__scroll-line { width:1.5px; height:48px; background:linear-gradient(to bottom,rgba(255,255,255,.5),transparent); animation:scroll-line 2s ease-in-out infinite; }
@keyframes scroll-line { 0%,100%{height:48px;opacity:1} 50%{height:24px;opacity:.4} }

/* ── 8. SERVICES ────────────────────────────────────────────── */
.services { background:var(--surface); }
.services__grid { display:grid; grid-template-columns:repeat(3,1fr); gap:24px; }

.svc {
  position:relative; background:var(--surface); border-radius:var(--r-lg);
  padding:36px 32px; border:2px solid var(--border);
  transition:border-color var(--t) var(--ease),box-shadow var(--t) var(--ease),transform var(--t) var(--ease);
  cursor:default; overflow:hidden; outline:none;
}
.svc::before {
  content:''; position:absolute; inset:0;
  background:linear-gradient(135deg,var(--primary-bg) 0%,rgba(234,174,135,.06) 100%);
  opacity:0; transition:opacity var(--t) var(--ease);
}
.svc:hover, .svc:focus-visible { border-color:var(--primary); box-shadow:var(--shadow-lg); transform:translateY(-6px); }
.svc:hover::before, .svc:focus-visible::before { opacity:1; }

.svc__num { position:absolute; top:16px; right:22px; font-family:var(--font-display); font-size:4rem; color:var(--primary); opacity:.06; line-height:1; transition:opacity var(--t) var(--ease); }
.svc:hover .svc__num { opacity:.14; }

.svc__icon { width:56px;height:56px;border-radius:16px;display:flex;align-items:center;justify-content:center;margin-bottom:24px;position:relative;z-index:1;transition:transform var(--t) var(--ease); }
.svc:hover .svc__icon { transform:scale(1.08) rotate(-4deg); }
.svc__icon svg { width:28px;height:28px; }

.svc:nth-child(1) .svc__icon { background:linear-gradient(135deg,#ede9fa,#d6ccf7); color:var(--primary-dark); }
.svc:nth-child(2) .svc__icon { background:linear-gradient(135deg,#fdf3eb,#fad9bf); color:#c06820; }
.svc:nth-child(3) .svc__icon { background:linear-gradient(135deg,#ecfdf5,#bbf7d0); color:#166534; }
.svc:nth-child(4) .svc__icon { background:linear-gradient(135deg,#fef9c3,#fde68a); color:#92400e; }
.svc:nth-child(5) .svc__icon { background:linear-gradient(135deg,#fee2e2,#fecaca); color:#991b1b; }
.svc:nth-child(6) .svc__icon { background:linear-gradient(135deg,#e0f2fe,#bae6fd); color:#075985; }

.svc__title { font-family:var(--font-display); font-size:1.0625rem; font-weight:800; margin-bottom:12px; position:relative;z-index:1; }
.svc__desc  { font-size:.9375rem; color:var(--text-2); line-height:1.7; margin-bottom:16px; position:relative;z-index:1; }
.svc__tags  { display:flex; flex-wrap:wrap; gap:6px; position:relative;z-index:1; }
.svc__tag   { font-family:var(--font-mono); font-size:.7rem; padding:3px 10px; border-radius:99px; background:var(--primary-bg2); color:var(--primary); border:1px solid rgba(124,97,212,.15); }

/* ── 9. ABOUT ───────────────────────────────────────────────── */
.about {
  background: linear-gradient(145deg,#120e24 0%,#1e1540 60%,#2d1e08 100%);
  color:#fff; position:relative; overflow:hidden;
}
.about::before { content:''; position:absolute; inset:0; background-image:radial-gradient(circle,rgba(124,97,212,.15) 1px,transparent 1px); background-size:40px 40px; }
.about::after  { content:''; position:absolute; top:-2px; left:0; right:0; height:80px; background:var(--surface); clip-path:polygon(0 0,100% 0,0 100%); }

.about__inner { display:grid; grid-template-columns:1fr 1fr; gap:64px; align-items:center; position:relative; z-index:1; padding-top:40px; }

.about__visual { display:flex; flex-direction:column; align-items:flex-start; gap:32px; }
.about__card { background:rgba(255,255,255,.06); border:1.5px solid rgba(255,255,255,.12); border-radius:var(--r-xl); padding:40px; backdrop-filter:blur(20px); width:100%; max-width:380px; }
.about__logo-big { display:flex; align-items:center; justify-content:center; width:100px; height:100px; border-radius:28px; background:rgba(124,97,212,.15); border:2px solid rgba(124,97,212,.3); margin-bottom:24px; }
.about__year { font-family:var(--font-display); font-size:3.5rem; color:var(--secondary); line-height:1; margin-bottom:6px; }
.about__year-label { font-family:var(--font-mono); font-size:.75rem; color:rgba(255,255,255,.45); letter-spacing:.1em; }
.about__pills { display:flex; flex-wrap:wrap; gap:8px; }
.tech-pill { font-family:var(--font-mono); font-size:.8rem; padding:6px 14px; border-radius:99px; background:rgba(124,97,212,.2); color:rgba(255,255,255,.85); border:1px solid rgba(124,97,212,.3); transition:background var(--t) var(--ease),color var(--t) var(--ease); }
.tech-pill:hover { background:var(--primary); color:#fff; }

.about__text .chip { background:rgba(124,97,212,.2); color:rgba(255,255,255,.8); border-color:rgba(124,97,212,.3); }
.about__text .chip::before { background:var(--secondary); }
.about__text .section-title { color:#fff; }
.about__text .section-title span { color:var(--secondary); }
.about__para { color:rgba(255,255,255,.68); line-height:1.8; margin-bottom:18px; font-size:1rem; }
.about__values { display:flex; flex-direction:column; gap:16px; margin-top:8px; }
.val { display:flex; align-items:flex-start; gap:16px; background:rgba(255,255,255,.05); border:1px solid rgba(255,255,255,.08); border-radius:14px; padding:18px 20px; transition:background var(--t) var(--ease),border-color var(--t) var(--ease); }
.val:hover { background:rgba(124,97,212,.12); border-color:rgba(124,97,212,.3); }
.val__icon { width:40px;height:40px;border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:1.2rem;flex-shrink:0;background:rgba(124,97,212,.2); }
.val strong { display:block; font-size:.9375rem; font-weight:700; color:#fff; margin-bottom:3px; }
.val span   { font-size:.875rem; color:rgba(255,255,255,.55); }

/* ── 10. PORTFOLIO ──────────────────────────────────────────── */
.portfolio { background:var(--neutral); }
.portfolio__grid { display:grid; grid-template-columns:repeat(2,1fr); gap:24px; }

.pcard { border-radius:var(--r-xl); overflow:hidden; background:var(--surface); border:2px solid var(--border); transition:box-shadow var(--t) var(--ease),transform var(--t) var(--ease),border-color var(--t) var(--ease); cursor:default; outline:none; }
.pcard:hover,.pcard:focus-visible { box-shadow:var(--shadow-lg); transform:translateY(-6px); border-color:var(--primary); }
.pcard__thumb { height:200px; position:relative; display:flex; align-items:flex-start; justify-content:space-between; padding:20px 24px; overflow:hidden; }
.pcard__thumb::after { content:''; position:absolute; inset:0; background:rgba(0,0,0,.15); }
.pcard__tag { font-family:var(--font-mono); font-size:.75rem; font-weight:600; color:#fff; background:rgba(0,0,0,.35); backdrop-filter:blur(8px); border:1px solid rgba(255,255,255,.2); padding:5px 12px; border-radius:99px; position:relative;z-index:1; }
.pcard__thumb-icon { font-size:3.5rem; position:absolute; bottom:16px; right:24px; z-index:1; opacity:.7; transition:opacity var(--t) var(--ease),transform var(--t) var(--ease); }
.pcard:hover .pcard__thumb-icon { opacity:1; transform:scale(1.1) rotate(-5deg); }
.pcard__body { padding:28px; }
.pcard__title { font-size:1.0625rem; font-weight:800; margin-bottom:10px; }
.pcard__desc  { font-size:.9rem; color:var(--text-2); margin-bottom:18px; line-height:1.65; }
.pcard__stack { display:flex; flex-wrap:wrap; gap:6px; }
.pcard__stack span { font-family:var(--font-mono); font-size:.72rem; padding:4px 11px; background:var(--primary-bg); color:var(--primary); border-radius:99px; border:1px solid rgba(124,97,212,.2); }

/* ── 11. PRICING ────────────────────────────────────────────── */
.pricing { background:var(--surface); }
.pricing__grid { display:grid; grid-template-columns:repeat(3,1fr); gap:24px; align-items:start; }

.prc { border-radius:var(--r-xl); padding:40px 36px; border:2px solid var(--border); background:var(--surface); position:relative; transition:box-shadow var(--t) var(--ease),transform var(--t) var(--ease); cursor:default; outline:none; }
.prc:hover,.prc:focus-visible { box-shadow:var(--shadow); transform:translateY(-3px); }

.prc--featured { background:var(--g-purple); border-color:transparent; color:#fff; box-shadow:var(--shadow-clr); transform:scale(1.03); }
.prc--featured:hover { transform:scale(1.03) translateY(-3px); box-shadow:0 20px 56px rgba(92,67,176,.55); }

.prc__badge { position:absolute; top:-15px; left:50%; transform:translateX(-50%); background:var(--g-warm); color:#fff; font-size:.75rem; font-weight:800; padding:5px 18px; border-radius:99px; white-space:nowrap; box-shadow:0 4px 12px rgba(212,131,74,.4); }
.prc__name { font-family:var(--font-display); font-size:1.25rem; font-weight:800; margin-bottom:20px; }
.prc--featured .prc__name { color:#fff; }
.prc__price-wrap { display:flex; align-items:baseline; gap:6px; margin-bottom:6px; }
.prc__amt { font-size:2rem; font-weight:900; color:var(--text); }
.prc--featured .prc__amt { color:#fff; }
.prc__cur { font-size:1rem; font-weight:700; color:var(--text-2); }
.prc--featured .prc__cur { color:rgba(255,255,255,.75); }
.prc__period { font-size:.8125rem; color:var(--text-3); margin-bottom:28px; }
.prc--featured .prc__period { color:rgba(255,255,255,.55); }
.prc__divider { height:1.5px; background:var(--border); margin-bottom:24px; }
.prc--featured .prc__divider { background:rgba(255,255,255,.2); }
.prc__features { display:flex; flex-direction:column; gap:13px; margin-bottom:32px; }
.prc__feat { font-size:.9375rem; color:var(--text-2); padding-left:24px; position:relative; }
.prc__feat::before { content:'✓'; position:absolute; left:0; color:var(--success); font-weight:800; }
.prc__feat.off { color:var(--text-3); }
.prc__feat.off::before { content:'–'; color:var(--text-3); font-weight:400; }
.prc--featured .prc__feat { color:rgba(255,255,255,.85); }
.prc--featured .prc__feat::before { color:#86efac; }
.prc--featured .prc__feat.off { color:rgba(255,255,255,.35); }
.prc--featured .prc__feat.off::before { color:rgba(255,255,255,.3); }

/* ── 12. PROCESS ────────────────────────────────────────────── */
.process { background:var(--g-section); }
.process__steps { display:grid; grid-template-columns:repeat(5,1fr); gap:0; position:relative; }
.process__steps::before { content:''; position:absolute; top:35px; left:10%; right:10%; height:2px; background:linear-gradient(90deg,var(--primary) 0%,var(--secondary) 100%); z-index:0; }

.proc-step { display:flex; flex-direction:column; align-items:center; text-align:center; padding:0 12px; position:relative; z-index:1; }
.proc-step__num { width:72px;height:72px;border-radius:50%;background:var(--surface);border:3px solid var(--primary);display:flex;align-items:center;justify-content:center;font-family:var(--font-display);font-size:1.375rem;color:var(--primary);margin-bottom:24px;box-shadow:0 0 0 6px var(--primary-bg);transition:background var(--t) var(--ease),color var(--t) var(--ease),transform var(--t) var(--ease); }
.proc-step:hover .proc-step__num { background:var(--primary); color:#fff; transform:scale(1.1); }
.proc-step__title { font-size:.9375rem; font-weight:800; margin-bottom:10px; }
.proc-step__desc  { font-size:.8125rem; color:var(--text-2); line-height:1.7; }

/* ── 13. CONTACT ────────────────────────────────────────────── */
.contact { background:var(--surface); }
.contact__inner { display:grid; grid-template-columns:1fr 1.15fr; gap:64px; align-items:start; }
.contact__info .section-title { text-align:left; }
.contact__intro { color:var(--text-2); margin-bottom:36px; font-size:1.0625rem; line-height:1.75; }
.contact__list { display:flex; flex-direction:column; gap:20px; }
.contact__item { display:flex; align-items:flex-start; gap:16px; }
.contact__icon { width:48px;height:48px;min-width:48px;background:var(--primary-bg);border:1.5px solid rgba(124,97,212,.2);border-radius:14px;display:flex;align-items:center;justify-content:center;color:var(--primary); }
.contact__link { font-size:1rem;font-weight:700;color:var(--text);display:inline-block;margin-top:4px; }
.contact__link:hover { color:var(--primary); }
.contact__sub { font-size:.8125rem; color:var(--text-3); }
.contact__address { font-size:.9375rem; color:var(--text-2); line-height:1.7; margin-top:4px; }
.contact__hours p { font-size:.9375rem; color:var(--text-2); }
.contact__hours p:first-child { margin-top:4px; }

.cform { background:var(--surface); border:2px solid var(--border); border-radius:var(--r-xl); padding:40px; box-shadow:var(--shadow-lg); display:flex; flex-direction:column; gap:18px; }
.fg { display:flex; flex-direction:column; gap:6px; }
.fg label { font-size:.875rem; font-weight:700; color:var(--text); }
.fg input,.fg select,.fg textarea { width:100%; padding:12px 16px; border:2px solid var(--border); border-radius:12px; font-size:.9375rem; color:var(--text); background:var(--surface); min-height:48px; transition:border-color var(--t) var(--ease),box-shadow var(--t) var(--ease); }
.fg input:focus,.fg select:focus,.fg textarea:focus { outline:none; border-color:var(--primary); box-shadow:0 0 0 4px rgba(124,97,212,.1); }
.fg input.error,.fg select.error,.fg textarea.error { border-color:var(--danger); }
.fg textarea { resize:vertical; min-height:120px; }

.cb-label { display:flex; align-items:center; gap:10px; font-size:.875rem; color:var(--text-2); cursor:pointer; flex-wrap:wrap; }
.cb-label input[type="checkbox"] { position:absolute; opacity:0; width:0; height:0; }
.cb-box { display:inline-flex;align-items:center;justify-content:center;width:22px;height:22px;min-width:22px;border:2px solid var(--border);border-radius:7px;background:var(--surface);transition:border-color var(--t) var(--ease),background var(--t) var(--ease); }
.cb-label input:checked ~ .cb-box { background:var(--primary); border-color:var(--primary); }
.cb-label input:checked ~ .cb-box::after { content:'';display:block;width:12px;height:7px;border-left:2.5px solid #fff;border-bottom:2.5px solid #fff;transform:rotate(-45deg) translateY(-1px); }
.cb-label input:focus-visible ~ .cb-box { outline:3px solid var(--primary); outline-offset:2px; }
.cb-link { color:var(--primary); font-weight:700; }
.cb-link:hover { text-decoration:underline; }
.form-err { font-size:.8rem; color:var(--danger); min-height:1em; }
.form-ok { display:none;text-align:center;font-weight:700;font-size:.9375rem;color:var(--success);background:rgba(22,163,74,.08);border:1.5px solid rgba(22,163,74,.25);border-radius:12px;padding:14px; }
.form-ok.show { display:block; }

/* ── 14. FOOTER ─────────────────────────────────────────────── */
.footer { background:linear-gradient(160deg,#0d0a1c 0%,#1a1138 60%,#1c1005 100%); color:rgba(255,255,255,.65); padding-top:72px; }
.footer__inner { display:grid; grid-template-columns:2.2fr 1fr 1fr 1.4fr; gap:32px; padding-bottom:56px; }
.footer__brand .logo__name { color:#fff; }
.footer__brand .logo__tagline { color:var(--secondary); }
.footer__desc { font-size:.875rem; color:rgba(255,255,255,.45); margin-top:16px; line-height:1.75; }
.fn-title { font-family:var(--font-display); font-size:0.8125rem; font-weight:800; color:rgba(255,255,255,.9); margin-bottom:18px; letter-spacing:.04em; }
.fnav ul { display:flex; flex-direction:column; gap:10px; }
.fnav a  { font-size:.875rem; color:rgba(255,255,255,.5); transition:color var(--t) var(--ease); }
.fnav a:hover { color:var(--secondary); }
.footer__hours { font-size:.8125rem; color:rgba(255,255,255,.4); line-height:2; margin-top:4px; }
.footer__hours strong { color:rgba(255,255,255,.75); }
.footer__bot { border-top:1px solid rgba(255,255,255,.07); padding-block:18px; }
.footer__bot-inner { display:flex; justify-content:space-between; align-items:center; flex-wrap:wrap; gap:8px; font-size:.8125rem; color:rgba(255,255,255,.3); }

/* ── 15. BACK TO TOP ────────────────────────────────────────── */
.back-to-top { position:fixed; bottom:28px; right:28px; z-index:90; width:48px; height:48px; border-radius:50%; background:var(--g-purple); color:#fff; display:flex; align-items:center; justify-content:center; box-shadow:0 4px 16px rgba(92,67,176,.45); opacity:0; pointer-events:none; transform:translateY(12px) scale(.9); transition:opacity var(--t) var(--ease),transform var(--t) var(--ease); }
.back-to-top.visible { opacity:1; pointer-events:auto; transform:none; }
.back-to-top:hover { background:var(--primary-dark); }

/* ── 16. ANIMATIONS ─────────────────────────────────────────── */
@keyframes fade-up { from{opacity:0;transform:translateY(30px)} to{opacity:1;transform:translateY(0)} }
.reveal { opacity:0; transform:translateY(32px); transition:opacity .6s var(--ease),transform .6s var(--ease); }
.reveal.visible { opacity:1; transform:none; }
.rd1{transition-delay:.08s} .rd2{transition-delay:.16s} .rd3{transition-delay:.24s}
.rd4{transition-delay:.32s} .rd5{transition-delay:.40s}

/* ── 17. PRIVACY PAGE ───────────────────────────────────────── */
.privacy-page { max-width:800px; margin-inline:auto; padding-block:80px 100px; }
.privacy-page h1 { font-family:var(--font-display); font-size:clamp(1.75rem,4vw,2.5rem); margin-bottom:8px; }
.privacy-date { font-family:var(--font-mono); font-size:.8125rem; color:var(--text-3); margin-bottom:40px; }
.privacy-page h2 { font-size:1.0625rem; font-weight:800; margin-top:36px; margin-bottom:12px; color:var(--text); }
.privacy-page p,.privacy-page li { font-size:.9375rem; color:var(--text-2); line-height:1.8; margin-bottom:10px; }
.privacy-page ul { list-style:disc; padding-left:24px; }
.privacy-page a { color:var(--primary); font-weight:600; }

/* ── 18. RESPONSIVE ─────────────────────────────────────────── */
@media (max-width:1100px) {
  .services__grid { grid-template-columns:repeat(2,1fr); }
  .process__steps { grid-template-columns:repeat(3,1fr); gap:32px; }
  .process__steps::before { display:none; }
  .footer__inner { grid-template-columns:1fr 1fr; }
}
@media (max-width:900px) {
  .about__inner   { grid-template-columns:1fr; }
  .contact__inner { grid-template-columns:1fr; }
  .portfolio__grid{ grid-template-columns:1fr; }
  .pricing__grid  { grid-template-columns:1fr; }
  .prc--featured  { transform:none; }
  .prc--featured:hover { transform:translateY(-3px); }
}
@media (max-width:768px) {
  .section { padding-block:72px; }
  .nav { display:none; }
  .burger { display:flex; }
  .header__actions .btn--sm { display:none; }
  .services__grid { grid-template-columns:1fr; }
  .hero__title { font-size:2.2rem; }
  .hero__stats { width:100%; flex-direction:column; }
  .stat { flex-direction:row; justify-content:space-between; border-right:none; border-bottom:1.5px solid rgba(255,255,255,.1); padding:16px 24px; }
  .stat:last-child { border-bottom:none; }
  .process__steps { grid-template-columns:1fr 1fr; }
  .footer__inner { grid-template-columns:1fr; }
  .footer__bot-inner { flex-direction:column; text-align:center; }
}
@media (max-width:480px) {
  .hero__title { font-size:1.9rem; }
  .hero__actions { flex-direction:column; }
  .hero__actions .btn { width:100%; text-align:center; }
  .process__steps { grid-template-columns:1fr; }
  .cform { padding:24px; }
  .prc { padding:28px 24px; }
}
