*, *::before, *::after {
  box-sizing: border-box;
  margin: 0;
  padding: 0;
}

:root {
  --acid: #AADD00;
  --acid-dim: #F4FFAA;
  --black: #0A0A0A;
  --gray: #6B6B6B;
  --lightgray: #E8E8E4;
  --bg: #F8F8F4;
  --white: #fff;
  --border: #E0E0D8;
}

html {
  scroll-behavior: smooth;
  overflow-x: hidden;
}

body {
  background: var(--bg);
  color: var(--black);
  font-family: "Onest", sans-serif;
  line-height: 1.6;
}

/* прогресс скролла */
#scroll-prog {
  position: fixed;
  top: 60px;
  left: 0;
  z-index: 300;
  height: 2px;
  width: 0;
  background: var(--acid);
  pointer-events: none;
}

/* кнопка наверх */
#back-top {
  position: fixed;
  bottom: 24px;
  right: 24px;
  z-index: 400;
  width: 44px;
  height: 44px;
  border-radius: 10px;
  background: var(--black);
  color: var(--white);
  border: none;
  cursor: pointer;
  font-size: 1.1rem;
  display: flex;
  align-items: center;
  justify-content: center;
  opacity: 0;
  pointer-events: none;
  transition: opacity 0.3s, background 0.18s;
  box-shadow: 0 4px 16px rgba(0,0,0,0.2);
}

#back-top.show {
  opacity: 1;
  pointer-events: all;
}

#back-top:hover {
  background: var(--acid);
  color: var(--black);
}

/* навигация */
nav {
  position: sticky;
  top: 0;
  z-index: 200;
  height: 60px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 0 2.5rem;
  background: rgba(248,248,244,0.93);
  backdrop-filter: blur(16px);
  border-bottom: 1px solid var(--border);
  animation: fadeDown 0.5s ease both;
}

@keyframes fadeDown {
  from { opacity: 0; transform: translateY(-12px); }
  to   { opacity: 1; transform: translateY(0); }
}

.nav-logo {
  font-family: "Unbounded", sans-serif;
  font-weight: 900;
  font-size: 0.95rem;
  letter-spacing: -0.04em;
  color: var(--black);
  text-decoration: none;
  display: flex;
  align-items: center;
  gap: 0.5rem;
}

.nav-dot {
  width: 8px;
  height: 8px;
  background: var(--acid);
  border-radius: 50%;
  animation: blink 2s infinite;
}

@keyframes blink {
  0%, 100% { opacity: 1; }
  50%       { opacity: 0.3; }
}

.nav-logo-img {
  height: 28px;
  width: auto;
}

.nav-links {
  display: flex;
  gap: 0.2rem;
  list-style: none;
}

.nav-links a {
  font-size: 0.78rem;
  font-weight: 500;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  color: var(--gray);
  text-decoration: none;
  padding: 0.4rem 0.75rem;
  border-radius: 6px;
  transition: color 0.18s, background 0.18s;
}

.nav-links a:hover,
.nav-links a.active {
  color: var(--black);
  background: var(--lightgray);
}

.nav-btn {
  font-family: "Unbounded", sans-serif;
  font-size: 0.7rem;
  font-weight: 700;
  letter-spacing: 0.04em;
  background: var(--black);
  color: var(--bg);
  text-decoration: none;
  padding: 0.5rem 1.1rem;
  border-radius: 6px;
  transition: opacity 0.18s;
}

.nav-btn:hover { opacity: 0.75; }

.burger {
  display: none;
  flex-direction: column;
  gap: 5px;
  cursor: pointer;
  padding: 8px;
  min-width: 44px;
  min-height: 44px;
  align-items: center;
  justify-content: center;
}

.burger span {
  display: block;
  width: 22px;
  height: 1.5px;
  background: var(--black);
  border-radius: 2px;
  transition: all 0.22s;
}

.burger.open span:nth-child(1) { transform: translateY(6.5px) rotate(45deg); }
.burger.open span:nth-child(2) { opacity: 0; }
.burger.open span:nth-child(3) { transform: translateY(-6.5px) rotate(-45deg); }

.mob-menu {
  display: none;
  position: fixed;
  top: 60px;
  left: 0;
  right: 0;
  bottom: 0;
  background: var(--white);
  z-index: 190;
  flex-direction: column;
  padding: 1.5rem;
  gap: 0.5rem;
  border-top: 1px solid var(--border);
  overflow-y: auto;
}

.mob-menu.open { display: flex; }

.mob-menu a {
  font-size: 1rem;
  font-weight: 500;
  color: var(--black);
  text-decoration: none;
  padding: 0.85rem 1rem;
  border: 1px solid var(--border);
  border-radius: 8px;
  text-align: center;
  transition: background 0.15s;
}

.mob-menu a:hover { background: var(--bg); }

.mob-menu a.cta {
  background: var(--black);
  color: var(--white);
  border-color: var(--black);
  font-family: "Unbounded", sans-serif;
  font-size: 0.82rem;
}

/* герой */
.hero {
  min-height: calc(100vh - 60px);
  display: grid;
  grid-template-columns: 1fr 400px;
  border-bottom: 1px solid var(--border);
  overflow: hidden;
}

.hero-left {
  padding: 5rem 2.5rem;
  display: flex;
  flex-direction: column;
  justify-content: center;
  border-right: 1px solid var(--border);
}

.hero-eyebrow {
  display: inline-flex;
  align-items: center;
  gap: 0.6rem;
  font-size: 0.72rem;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  font-weight: 600;
  color: var(--gray);
  margin-bottom: 1.8rem;
}

.tag-pill {
  background: var(--acid);
  color: var(--black);
  font-size: 0.65rem;
  font-weight: 700;
  letter-spacing: 0.1em;
  padding: 0.2rem 0.65rem;
  border-radius: 30px;
}

@keyframes slideUp {
  to { transform: translateY(0); }
}

.hero-name {
  font-family: "Unbounded", sans-serif;
  font-size: clamp(3rem, 7.5vw, 6.5rem);
  font-weight: 900;
  line-height: 1.05;
  margin-bottom: 0.5em;
}

.hero-name-row {
  display: block;
  overflow: hidden;
  padding-bottom: 0.06em;
}

.hero-name-row span {
  display: block;
}

.hero-name-row:nth-child(2) span { color: var(--acid); }

.hero-chips {
  display: flex;
  flex-wrap: wrap;
  gap: 0.5rem;
  margin-bottom: 2rem;
}

.chip {
  font-size: 0.82rem;
  font-weight: 500;
  border: 1.5px solid var(--black);
  color: var(--black);
  padding: 0.35rem 1rem;
  border-radius: 30px;
  transition: background 0.18s, color 0.18s;
}

.chip:hover { background: var(--black); color: var(--white); }

.chip.filled {
  background: var(--black);
  color: var(--white);
}

.chip.filled:hover {
  background: var(--acid);
  border-color: var(--acid);
  color: var(--black);
}

.hero-desc {
  font-size: 1.05rem;
  color: var(--gray);
  line-height: 1.85;
  max-width: 520px;
  margin-bottom: 2.5rem;
  font-weight: 300;
  
}

.hero-desc strong { color: var(--black); font-weight: 600; }

.hero-btns {
  display: flex;
  gap: 0.8rem;
  flex-wrap: wrap;
  
}

.btn-dark {
  display: inline-flex;
  align-items: center;
  gap: 0.4rem;
  background: var(--black);
  color: var(--white);
  font-family: "Unbounded", sans-serif;
  font-size: 0.72rem;
  font-weight: 700;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  text-decoration: none;
  padding: 0.9rem 1.8rem;
  border-radius: 8px;
  transition: opacity 0.18s;
}

.btn-dark:hover { opacity: 0.8; }

.btn-outline {
  display: inline-flex;
  align-items: center;
  gap: 0.4rem;
  border: 1.5px solid var(--border);
  color: var(--black);
  font-family: "Unbounded", sans-serif;
  font-size: 0.72rem;
  font-weight: 700;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  text-decoration: none;
  padding: 0.9rem 1.8rem;
  border-radius: 8px;
  transition: border-color 0.18s, background 0.18s;
}

.btn-outline:hover {
  border-color: var(--black);
  background: var(--lightgray);
}

/* правая часть героя */
.hero-right {
  display: flex;
  flex-direction: column;
  background: var(--white);
}

.hero-canvas-wrap {
  flex: 1;
  min-height: 340px;
  overflow: hidden;
  position: relative;
}

.hero-canvas-wrap canvas {
  display: block;
  width: 100%;
  height: 100%;
  position: absolute;
  top: 0;
  left: 0;
}

.hero-stats {
  display: grid;
  grid-template-columns: 1fr 1fr;
  border-top: 1px solid var(--border);
}

.hero-stat {
  padding: 1.4rem;
  border-right: 1px solid var(--border);
}

.hero-stat:last-child { border-right: none; }

.hero-stat-n {
  font-family: "Unbounded", sans-serif;
  font-size: 1.8rem;
  font-weight: 900;
  letter-spacing: -0.04em;
  line-height: 1;
}

.hero-stat-n em { color: var(--acid); font-style: normal; }

.hero-stat-l {
  font-size: 0.76rem;
  color: var(--gray);
  margin-top: 0.3rem;
  line-height: 1.4;
}

.hero-loc {
  border-top: 1px solid var(--border);
  padding: 0.85rem 1.4rem;
  display: flex;
  align-items: center;
  gap: 0.5rem;
  font-size: 0.76rem;
  color: var(--gray);
}

.dot-live {
  width: 7px;
  height: 7px;
  background: #22C55E;
  border-radius: 50%;
  flex-shrink: 0;
  animation: blink 2s infinite;
}

/* бегущая строка */
.marquee-wrap {
  background: var(--black);
  overflow: hidden;
  padding: 0.85rem 0;
}

.marquee-track {
  display: flex;
  white-space: nowrap;
  animation: marquee 26s linear infinite;
}

.marquee-wrap:hover .marquee-track { animation-play-state: paused; }

@keyframes marquee {
  from { transform: translateX(0); }
  to   { transform: translateX(-50%); }
}

.marquee-item {
  display: inline-flex;
  align-items: center;
  gap: 1.5rem;
  font-family: "Unbounded", sans-serif;
  font-size: 0.72rem;
  font-weight: 700;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--white);
  padding: 0 2rem;
}

.msep { color: var(--acid); }

/* общие стили секций */
.sec {
  padding: 5.5rem 2.5rem;
}

.max-w {
  max-width: 1200px;
  margin: 0 auto;
}

.sec-label {
  font-size: 0.7rem;
  letter-spacing: 0.15em;
  text-transform: uppercase;
  font-weight: 700;
  color: var(--gray);
  margin-bottom: 0.6rem;
  display: flex;
  align-items: center;
  gap: 0.5rem;
}

.sec-label::before {
  content: "";
  width: 14px;
  height: 1.5px;
  background: var(--acid);
  flex-shrink: 0;
}

.sec-title {
  font-family: "Unbounded", sans-serif;
  font-size: clamp(1.8rem, 3.5vw, 3rem);
  font-weight: 900;
  line-height: 1.05;
  letter-spacing: -0.04em;
}

/* reveal анимация */
.reveal {
  opacity: 0;
  transform: translateY(28px);
  transition: opacity 0.8s cubic-bezier(0.22,1,0.36,1),
              transform 0.8s cubic-bezier(0.22,1,0.36,1);
}

.reveal.visible { opacity:1; transform:none; }

/* о себе */
.about {
  background: var(--white);
  border-bottom: 1px solid var(--border);
}

.about-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 4rem;
  margin-top: 3rem;
}

.about-texts {
  display: flex;
  flex-direction: column;
  gap: 1.1rem;
}

.about-p {
  font-size: 1rem;
  color: var(--gray);
  line-height: 1.9;
  font-weight: 300;
}

.about-p strong { color: var(--black); font-weight: 600; }

.about-quote {
  padding: 1.3rem 1.6rem;
  border-left: 4px solid var(--acid);
  background: var(--acid-dim);
  border-radius: 0 8px 8px 0;
  font-size: 1rem;
  font-style: italic;
  font-weight: 500;
  color: var(--black);
  line-height: 1.7;
}

.values {
  border: 1px solid var(--border);
  border-radius: 16px;
  overflow: hidden;
}

.val-row {
  display: flex;
  align-items: flex-start;
  gap: 1rem;
  padding: 1.3rem 1.4rem;
  border-bottom: 1px solid var(--border);
  transition: background 0.18s;
}

.val-row:last-child { border-bottom: none; }
.val-row:hover { background: var(--bg); }

.val-icon {
  width: 30px;
  height: 30px;
  flex-shrink: 0;
  background: var(--acid);
  border-radius: 6px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-family: "Unbounded", sans-serif;
  font-size: 0.62rem;
  font-weight: 900;
  color: var(--black);
}

.val-t { font-size: 0.88rem; font-weight: 600; margin-bottom: 0.15rem; }
.val-d { font-size: 0.8rem; color: var(--gray); line-height: 1.5; }

/* что делаю */
.whatido {
  background: var(--bg);
  border-bottom: 1px solid var(--border);
}

.do-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 1.2rem;
  margin-top: 3rem;
}

.do-card {
  background: var(--white);
  border: 1px solid var(--border);
  border-radius: 16px;
  padding: 1.8rem;
  transition: box-shadow 0.22s, transform 0.22s;
}

.do-card:hover {
  box-shadow: 0 16px 44px rgba(0,0,0,0.08);
  transform: translateY(-4px);
}

.do-num {
  font-family: "Unbounded", sans-serif;
  font-size: 1.9rem;
  font-weight: 900;
  color: var(--acid);
  letter-spacing: -0.06em;
  line-height: 1;
  margin-bottom: 0.9rem;
}

.do-t { font-size: 0.95rem; font-weight: 700; margin-bottom: 0.5rem; }
.do-d { font-size: 0.86rem; color: var(--gray); line-height: 1.7; }

/* проекты */
.projects {
  background: var(--black);
  border-bottom: 1px solid #222;
}

.projects .sec-label { color: #666; }
.projects .sec-label::before { background: var(--acid); }
.projects .sec-title { color: var(--white); }

.proj-sub {
  font-size: 0.95rem;
  color: #777;
  line-height: 1.8;
  margin-top: 0.6rem;
  max-width: 540px;
  font-weight: 300;
}

.proj-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 1.2rem;
  margin-top: 3rem;
}

.proj-card {
  border-radius: 16px;
  overflow: hidden;
  display: block;
  text-decoration: none;
  color: inherit;
  transition: transform 0.22s;
}

.proj-card:hover { transform: translateY(-4px); }

.proj-card.span2 {
  grid-column: span 2;
  display: grid;
  grid-template-columns: 1fr 1fr;
}

.proj-body {
  padding: 2.2rem;
  background: #161616;
  border: 1px solid #282828;
  border-radius: 16px;
  height: 100%;
  display: flex;
  flex-direction: column;
  transition: border-color 0.22s;
}

.proj-card:hover .proj-body { border-color: #3A3A3A; }
.proj-card.span2 .proj-body { border-radius: 0; border: none; }

.proj-card.span2 .proj-accent {
  background: var(--acid);
  padding: 2.2rem;
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
}

.proj-badge {
  display: inline-block;
  font-size: 0.62rem;
  font-weight: 700;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  background: var(--acid);
  color: var(--black);
  padding: 0.22rem 0.65rem;
  border-radius: 3px;
  margin-bottom: 1.3rem;
}

.proj-badge.dim {
  background: transparent;
  color: #666;
  border: 1px solid #2E2E2E;
}

.proj-name {
  font-family: "Unbounded", sans-serif;
  font-size: 1.5rem;
  font-weight: 900;
  letter-spacing: -0.04em;
  color: var(--white);
  line-height: 1.15;
  margin-bottom: 0.9rem;
}

.proj-desc {
  font-size: 0.88rem;
  color: #777;
  line-height: 1.75;
  flex: 1;
  margin-bottom: 1.3rem;
}

.proj-tags {
  display: flex;
  flex-wrap: wrap;
  gap: 0.35rem;
  margin-bottom: 1.3rem;
}

.proj-tag {
  font-size: 0.7rem;
  color: #555;
  border: 1px solid #282828;
  padding: 0.18rem 0.55rem;
  border-radius: 3px;
}

.proj-link {
  display: inline-flex;
  align-items: center;
  gap: 0.35rem;
  font-family: "Unbounded", sans-serif;
  font-size: 0.68rem;
  font-weight: 700;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--acid);
}

.proj-accent .proj-name { color: var(--black); font-size: 2rem; }

.big-num {
  font-family: "Unbounded", sans-serif;
  font-size: 3.2rem;
  font-weight: 900;
  letter-spacing: -0.06em;
  color: var(--black);
  line-height: 1;
}

.big-lbl {
  font-size: 0.82rem;
  font-weight: 600;
  color: rgba(0,0,0,0.55);
  line-height: 1.4;
  margin-top: 0.3rem;
}

/* freshcheck */
.freshcheck {
  background: var(--acid-dim);
  border-bottom: 1px solid #D0E070;
}

.freshcheck .sec-label { color: #5A7800; }
.freshcheck .sec-label::before { background: #5A7800; }

.fc-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 4rem;
  margin-top: 3rem;
}

.fc-mission {
  font-family: "Unbounded", sans-serif;
  font-size: 1.15rem;
  font-weight: 700;
  line-height: 1.65;
  letter-spacing: -0.02em;
  margin-bottom: 1.3rem;
}

.fc-p {
  font-size: 0.93rem;
  color: #555;
  line-height: 1.85;
  margin-bottom: 0.9rem;
  font-weight: 300;
}

.fc-p strong { color: var(--black); font-weight: 600; }

.fc-nums {
  display: grid;
  grid-template-columns: 1fr 1fr 1fr;
  gap: 0.8rem;
  margin: 1.8rem 0;
}

.fc-num-box {
  background: var(--white);
  border-radius: 10px;
  padding: 1rem;
  text-align: center;
}

.fc-num-val {
  font-family: "Unbounded", sans-serif;
  font-size: 1.5rem;
  font-weight: 900;
  letter-spacing: -0.04em;
}

.fc-num-lbl { font-size: 0.7rem; color: var(--gray); margin-top: 0.2rem; }

.fc-steps {
  border: 1.5px solid rgba(0,0,0,0.14);
  border-radius: 16px;
  overflow: hidden;
  background: var(--white);
}

.fc-step {
  display: flex;
  gap: 0.9rem;
  align-items: flex-start;
  padding: 1.1rem 1.3rem;
  border-bottom: 1px solid var(--lightgray);
  transition: background 0.18s;
}

.fc-step:hover { background: var(--bg); }
.fc-step:last-child { border-bottom: none; }

.fc-step-n {
  width: 26px;
  height: 26px;
  flex-shrink: 0;
  background: var(--black);
  color: var(--white);
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-family: "Unbounded", sans-serif;
  font-size: 0.62rem;
  font-weight: 900;
}

.fc-step-t { font-size: 0.86rem; font-weight: 600; margin-bottom: 0.18rem; }
.fc-step-d { font-size: 0.78rem; color: var(--gray); line-height: 1.5; }

/* скиллы */
.skills {
  background: var(--white);
  border-bottom: 1px solid var(--border);
}

.skills-layout {
  display: grid;
  grid-template-columns: 1fr 2fr;
  gap: 4rem;
  margin-top: 3rem;
}

.skills-note {
  font-size: 0.93rem;
  color: var(--gray);
  line-height: 1.85;
  font-weight: 300;
}

.skills-note strong { color: var(--black); font-weight: 600; }

.skill-groups {
  display: flex;
  flex-direction: column;
  gap: 1.8rem;
}

.sg-name {
  font-size: 0.68rem;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  font-weight: 700;
  color: var(--gray);
  margin-bottom: 0.7rem;
  padding-bottom: 0.4rem;
  border-bottom: 1px solid var(--lightgray);
}

.sg-pills { display: flex; flex-wrap: wrap; gap: 0.45rem; }

.pill {
  font-size: 0.83rem;
  border: 1px solid var(--border);
  color: var(--black);
  padding: 0.32rem 0.85rem;
  border-radius: 30px;
  background: var(--bg);
  transition: all 0.18s;
  cursor: default;
}

.pill:hover {
  background: var(--black);
  color: var(--white);
  border-color: var(--black);
}

.pill.hi {
  background: var(--acid);
  border-color: var(--acid);
  color: var(--black);
  font-weight: 600;
}

.pill.hi:hover {
  background: var(--black);
  color: var(--white);
  border-color: var(--black);
}

/* skill bars */
.stack-bars {
  margin-top: 2rem;
  display: flex;
  flex-direction: column;
  gap: 0.85rem;
}

.sbar-row {
  display: flex;
  align-items: center;
  gap: 0.7rem;
}

.sbar-label {
  font-size: 0.8rem;
  color: var(--gray);
  min-width: 110px;
  flex-shrink: 0;
}

.sbar-track {
  flex: 1;
  height: 4px;
  background: var(--lightgray);
  border-radius: 2px;
  overflow: hidden;
  max-width: 220px;
}

.sbar-fill {
  height: 100%;
  background: var(--acid);
  border-radius: 2px;
  width: 0;
  transition: width 1.2s ease;
}

.sbar-pct {
  font-size: 0.75rem;
  color: var(--gray);
  min-width: 32px;
  text-align: right;
}

/* опыт */
.experience {
  background: var(--bg);
  border-bottom: 1px solid var(--border);
}

.exp-layout {
  display: grid;
  grid-template-columns: 1fr 2fr;
  gap: 4rem;
  margin-top: 3rem;
}

.exp-note {
  font-size: 0.93rem;
  color: var(--gray);
  line-height: 1.85;
  font-weight: 300;
}

.exp-items {
  display: flex;
  flex-direction: column;
  gap: 1.3rem;
}

.exp-card {
  background: var(--white);
  border: 1px solid var(--border);
  border-radius: 16px;
  padding: 1.8rem;
  position: relative;
  overflow: hidden;
  transition: box-shadow 0.22s, border-color 0.22s;
}

.exp-card:hover {
  box-shadow: 0 10px 36px rgba(0,0,0,0.08);
  border-color: #ccc;
}

.exp-card::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: 4px;
  height: 100%;
  background: var(--acid);
}

.exp-head {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 1rem;
  margin-bottom: 0.6rem;
  flex-wrap: wrap;
}

.exp-title { font-size: 0.97rem; font-weight: 700; }

.exp-period {
  font-size: 0.68rem;
  font-weight: 700;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  background: var(--black);
  color: var(--white);
  padding: 0.2rem 0.65rem;
  border-radius: 4px;
  white-space: nowrap;
}

.exp-org {
  font-size: 0.86rem;
  color: var(--gray);
  margin-bottom: 0.7rem;
}

.exp-org a {
  color: var(--black);
  font-weight: 500;
  text-decoration: underline;
  text-decoration-color: var(--acid);
  text-underline-offset: 3px;
}

.exp-desc { font-size: 0.86rem; color: var(--gray); line-height: 1.75; }

.exp-ul {
  margin-top: 0.7rem;
  display: flex;
  flex-direction: column;
  gap: 0.35rem;
}

.exp-li {
  font-size: 0.82rem;
  color: var(--gray);
  padding-left: 1rem;
  position: relative;
  line-height: 1.55;
}

.exp-li::before {
  content: "—";
  position: absolute;
  left: 0;
  color: var(--acid);
  font-weight: 700;
}

.exp-li strong { color: var(--black); font-weight: 600; }

/* принципы */
.philosophy {
  background: var(--black);
  border-bottom: 1px solid #1E1E1E;
}

.philosophy .sec-label { color: #555; }
.philosophy .sec-label::before { background: var(--acid); }
.philosophy .sec-title { color: var(--white); }

.phil-grid {
  display: grid;
  grid-template-columns: 1fr 1fr 1fr;
  gap: 1.2rem;
}

.phil-card {
  border: 1px solid #222;
  border-radius: 16px;
  background: #111;
  padding: 1.8rem;
  transition: border-color 0.22s, transform 0.22s;
}

.phil-card:hover {
  border-color: #444;
  transform: translateY(-4px);
}

.phil-q {
  font-size: 1rem;
  font-style: italic;
  color: var(--white);
  line-height: 1.7;
  margin-bottom: 1.3rem;
  font-weight: 300;
}

.phil-q em { font-style: normal; color: var(--acid); font-weight: 600; }
.phil-src { font-size: 0.75rem; color: #444; letter-spacing: 0.05em; }

/* uses */
.uses-sec {
  background: var(--bg);
  border-bottom: 1px solid var(--border);
}

.uses-layout {
  display: grid;
  grid-template-columns: 1fr 2fr;
  gap: 4rem;
  margin-top: 3rem;
  align-items: start;
}

.uses-intro {
  font-size: 0.93rem;
  color: var(--gray);
  line-height: 1.85;
  font-weight: 300;
}

.uses-intro strong { color: var(--black); font-weight: 600; }

.uses-groups { display: flex; flex-direction: column; gap: 2rem; }

.uses-group-label {
  font-size: 0.68rem;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  font-weight: 700;
  color: var(--gray);
  margin-bottom: 0.8rem;
  padding-bottom: 0.4rem;
  border-bottom: 1px solid var(--lightgray);
}

.uses-chips { display: flex; flex-wrap: wrap; gap: 0.5rem; }

.uses-chip {
  display: flex;
  flex-direction: column;
  gap: 0.15rem;
  background: var(--white);
  border: 1px solid var(--border);
  border-radius: 10px;
  padding: 0.6rem 0.95rem;
  transition: border-color 0.18s, transform 0.18s;
  cursor: default;
}

.uses-chip:hover {
  border-color: #aaa;
  transform: translateY(-2px);
}

.uses-chip.hi {
  border-color: rgba(170,221,0,0.4);
  background: rgba(170,221,0,0.04);
}

.uses-chip-name { font-size: 0.86rem; font-weight: 700; color: var(--black); line-height: 1; }
.uses-chip-sub { font-size: 0.7rem; color: var(--gray); }

/* нравится / не нравится */
.likes-sec {
  background: var(--black);
  border-bottom: 1px solid #222;
}

.likes-sec .sec-label { color: #555; }
.likes-sec .sec-label::before { background: var(--acid); }
.likes-sec .sec-title { color: var(--white); }
.likes-sec .sec-title em { color: var(--acid); font-style: normal; }

.likes-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 1.2rem;
  margin-top: 3rem;
}

.like-col-head {
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  font-family: "Unbounded", sans-serif;
  font-size: 0.65rem;
  font-weight: 900;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  padding: 0.4rem 0.9rem;
  border-radius: 30px;
  margin-bottom: 1rem;
}

.like-col-head--yes { background: var(--acid); color: var(--black); }
.like-col-head--no  { background: #3a0000; color: #ff6666; border: 1px solid #5a0000; }

.like-col { display: flex; flex-direction: column; gap: 0.8rem; }

.like-card {
  background: #111;
  border: 1px solid #1e1e1e;
  border-radius: 16px;
  padding: 1.4rem 1.5rem;
  position: relative;
  overflow: hidden;
  transition: border-color 0.22s;
}

.like-card--yes { border-left: 3px solid var(--acid); }
.like-card--no  { border-left: 3px solid #5a0000; }

.like-card-num {
  position: absolute;
  bottom: 0.6rem;
  right: 1.2rem;
  font-family: "Unbounded", sans-serif;
  font-size: 3rem;
  font-weight: 900;
  letter-spacing: -0.06em;
  opacity: 0.05;
  line-height: 1;
  color: var(--white);
  pointer-events: none;
  user-select: none;
}

.like-card-title {
  font-family: "Unbounded", sans-serif;
  font-size: 0.95rem;
  font-weight: 900;
  letter-spacing: -0.03em;
  color: var(--white);
  line-height: 1.2;
  margin-bottom: 0.5rem;
}

.like-card--yes .like-card-title em { color: var(--acid); font-style: normal; }
.like-card--no  .like-card-title em { color: #ff6666; font-style: normal; }
.like-card-desc { font-size: 0.81rem; color: #666; line-height: 1.65; font-weight: 300; }

/* faq */
.faq {
  background: var(--black);
  border-bottom: 1px solid #222;
}

.faq .sec-label { color: #555; }
.faq .sec-label::before { background: var(--acid); }
.faq .sec-title { color: var(--white); }

.faq-layout {
  display: grid;
  grid-template-columns: 1fr 2fr;
  gap: 4rem;
  margin-top: 3rem;
  align-items: start;
}

.faq-note { font-size: 0.93rem; color: #555; line-height: 1.85; font-weight: 300; }
.faq-note strong { color: var(--white); }

.faq-list { display: flex; flex-direction: column; }

.faq-item { border-bottom: 1px solid #1e1e1e; }
.faq-item:first-child { border-top: 1px solid #1e1e1e; }

.faq-q {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
  padding: 1.1rem 0;
  cursor: pointer;
  user-select: none;
  width: 100%;
  background: none;
  border: none;
  font: inherit;
  text-align: left;
}


.faq-q-text {
  font-size: 0.93rem;
  font-weight: 600;
  color: var(--white);
  transition: color 0.18s;
  flex: 1;
}

.faq-item.is-open .faq-q-text { color: var(--acid); }

.faq-icon {
  width: 26px;
  height: 26px;
  flex-shrink: 0;
  border: 1.5px solid #333;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1rem;
  color: #555;
  transition: border-color 0.2s, color 0.2s, transform 0.3s, background 0.2s;
}

.faq-item.is-open .faq-icon {
  background: var(--acid);
  border-color: var(--acid);
  color: var(--black);
  transform: rotate(45deg);
}

.faq-a {
  overflow: hidden;
  height: 0;
  opacity: 0;
  padding: 0;
  font-size: 0.87rem;
  color: #666;
  line-height: 1.85;
  font-weight: 300;
  transition: height 0.5s cubic-bezier(0.22,1,0.36,1),
              opacity 0.4s ease,
              padding 0.5s cubic-bezier(0.22,1,0.36,1);
}

.faq-item.is-open .faq-a {
  opacity: 1;
  padding-bottom: 1.1rem;
}

.faq-a strong { color: var(--white); font-weight: 600; }
.faq-a a { color: var(--acid); text-decoration: underline; text-underline-offset: 3px; }

/* контакты */
.contact {
  background: var(--white);
  border-bottom: 1px solid var(--border);
}

.contact-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 4rem;
  margin-top: 3rem;
}

.contact-lead {
  font-family: "Unbounded", sans-serif;
  font-size: clamp(1.6rem, 3vw, 2.6rem);
  font-weight: 900;
  letter-spacing: -0.04em;
  line-height: 1.1;
  margin-bottom: 1.3rem;
}

.contact-lead mark {
  background: var(--acid);
  padding: 0 0.2em;
  border-radius: 3px;
  font-style: normal;
}

.contact-sub {
  font-size: 0.93rem;
  color: var(--gray);
  line-height: 1.85;
  font-weight: 300;
  margin-bottom: 1.8rem;
}

.avail {
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  font-size: 0.78rem;
  font-weight: 600;
  color: #16a34a;
  background: #f0fdf4;
  border: 1px solid #86efac;
  padding: 0.45rem 0.9rem;
  border-radius: 30px;
}

.contact-links { display: flex; flex-direction: column; gap: 0.9rem; }

.contact-link {
  display: flex;
  align-items: center;
  gap: 1.1rem;
  text-decoration: none;
  color: var(--black);
  padding: 1.2rem 1.4rem;
  border: 1px solid var(--border);
  border-radius: 10px;
  background: var(--bg);
  transition: border-color 0.2s, background 0.2s, box-shadow 0.2s;
}

.contact-link:hover {
  border-color: var(--black);
  background: var(--white);
  box-shadow: 0 6px 22px rgba(0,0,0,0.08);
}

.contact-link-icon {
  width: 38px;
  height: 38px;
  flex-shrink: 0;
  background: var(--black);
  border: 1.5px solid rgba(10,10,10,0.08);
  border-radius: 8px;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: background 0.25s, border-color 0.25s;
}

.contact-link-icon i {
  font-size: 1.15rem;
  color: var(--acid);
  transition: color 0.25s;
}

.contact-link:hover .contact-link-icon {
  background: var(--acid);
  border-color: var(--acid);
}

.contact-link:hover .contact-link-icon i { color: var(--black); }

.contact-link-icon svg {
  width: 17px;
  height: 17px;
  fill: none;
  stroke: var(--acid);
  stroke-width: 1.8;
  transition: stroke 0.25s;
}

.contact-link:hover .contact-link-icon svg { stroke: var(--black); }

.clink-meta { flex: 1; }
.clink-type { font-size: 0.68rem; color: var(--gray); font-weight: 600; letter-spacing: 0.1em; text-transform: uppercase; }
.clink-val  { font-size: 0.92rem; font-weight: 600; margin-top: 0.12rem; }
.clink-arrow { font-size: 1rem; color: var(--gray); transition: transform 0.2s; }
.contact-link:hover .clink-arrow { transform: translateX(5px); }

.fc-contact {
  margin-top: 0.9rem;
  padding: 1.2rem 1.4rem;
  background: var(--acid-dim);
  border: 1px solid #C8E060;
  border-radius: 10px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
  text-decoration: none;
  color: var(--black);
  transition: background 0.18s;
}

.fc-contact:hover { background: #E8FF88; }

.fc-contact-lbl {
  font-size: 0.67rem;
  font-weight: 700;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: #5A7800;
  margin-bottom: 0.25rem;
}

.fc-contact-t { font-size: 0.92rem; font-weight: 700; }

/* страница VK */
.vkpage-teaser { background: var(--black); border-bottom: 1px solid #222; }
.vkpage-teaser .sec-label { color: #555; }
.vkpage-teaser .sec-label::before { background: var(--acid); }
.vkpage-teaser .sec-title { color: var(--white); }

.vkpage-inner {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 2rem;
  margin-top: 3rem;
  align-items: center;
}

.vkpage-desc {
  font-size: 0.95rem;
  color: #777;
  line-height: 1.85;
  font-weight: 300;
  margin-top: 1rem;
  margin-bottom: 2rem;
}

.vkpage-card {
  background: #161616;
  border: 1px solid #242424;
  border-radius: 16px;
  overflow: hidden;
  text-decoration: none;
  display: block;
  color: inherit;
  transition: border-color 0.2s;
}

.vkpage-card:hover { border-color: #3A3A3A; }

.vkpage-cover {
  height: 90px;
  background: #0A0A0A;
  overflow: hidden;
  position: relative;
}

.vkpage-cover img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  filter: brightness(0.6);
  display: block;
}

.vkpage-cover-grad {
  position: absolute;
  inset: 0;
  background: linear-gradient(to bottom, transparent 40%, rgba(10,10,10,0.8) 100%);
}

.vkpage-profile { padding: 0 1.2rem 1.2rem; }

.vkpage-ava-wrap {
  margin-top: -22px;
  margin-bottom: 0.6rem;
  position: relative;
  display: inline-block;
}

.vkpage-ava {
  width: 44px;
  height: 44px;
  border-radius: 50%;
  border: 3px solid #161616;
  object-fit: cover;
  display: block;
  background: #0A0A0A;
}

.vkpage-ava-dot {
  width: 10px;
  height: 10px;
  background: var(--acid);
  border-radius: 50%;
  border: 2px solid #161616;
  position: absolute;
  bottom: 1px;
  right: 1px;
}

.vkpage-name {
  font-family: "Unbounded", sans-serif;
  font-size: 0.9rem;
  font-weight: 900;
  letter-spacing: -0.03em;
  color: var(--white);
  margin-bottom: 0.15rem;
}

.vkpage-handle { font-size: 0.72rem; color: #555; }

.vkpage-rows {
  margin-top: 0.8rem;
  border-top: 1px solid #242424;
  padding-top: 0.8rem;
  display: flex;
  flex-direction: column;
}

.vkpage-row {
  display: flex;
  gap: 0.6rem;
  padding: 0.35rem 0;
  border-bottom: 1px solid rgba(255,255,255,0.04);
  align-items: baseline;
}

.vkpage-row:last-child { border-bottom: none; }
.vkpage-rkey { font-size: 0.72rem; color: #555; min-width: 80px; flex-shrink: 0; }
.vkpage-rval { font-size: 0.78rem; color: #ccc; }

.vkpage-btn {
  display: inline-flex;
  align-items: center;
  gap: 0.4rem;
  background: var(--acid);
  color: var(--black);
  font-family: "Unbounded", sans-serif;
  font-size: 0.68rem;
  font-weight: 700;
  letter-spacing: 0.05em;
  text-transform: uppercase;
  text-decoration: none;
  padding: 0.75rem 1.6rem;
  border-radius: 7px;
  transition: opacity 0.18s;
}

.vkpage-btn:hover { opacity: 0.85; }

/* футер */
footer {
  background: var(--black);
  padding: 3rem 2.5rem 2rem;
}

.footer-logo-img { height: 32px; width: auto; display: block; }

.footer-grid {
  max-width: 1200px;
  margin: 0 auto;
  display: grid;
  grid-template-columns: 1fr 1fr 1fr;
  gap: 3rem;
  padding-bottom: 2.5rem;
  border-bottom: 1px solid #1E1E1E;
  margin-bottom: 1.5rem;
}

.footer-logo { text-decoration: none; display: inline-block; margin-bottom: 0.7rem; }
.footer-tag  { font-size: 0.8rem; color: #555; line-height: 1.6; max-width: 200px; }

.footer-col-title {
  font-size: 0.66rem;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  font-weight: 700;
  color: #555;
  margin-bottom: 0.9rem;
}

.footer-links { display: flex; flex-direction: column; gap: 0.45rem; }

.footer-links a {
  font-size: 0.83rem;
  color: #777;
  text-decoration: none;
  transition: color 0.15s;
}

.footer-links a:hover { color: var(--acid); }

.footer-bottom {
  max-width: 1200px;
  margin: 0 auto;
  display: flex;
  justify-content: space-between;
  font-size: 0.76rem;
  color: #3A3A3A;
  flex-wrap: wrap;
  gap: 0.5rem;
}

/* адаптив */
@media (max-width: 1024px) {
  .do-grid   { grid-template-columns: 1fr 1fr; }
  .phil-grid { grid-template-columns: 1fr 1fr; }
  .footer-grid { grid-template-columns: 1fr 1fr; }
}

@media (max-width: 768px) {
  nav { padding: 0 1.2rem; position: fixed; top: 0; left: 0; right: 0; }
  body { padding-top: 60px; }

  .nav-links, .nav-btn { display: none; }
  .burger { display: flex; }

  .sec { padding: 3rem 1.2rem; }

  .hero { grid-template-columns: 1fr; min-height: auto; }
  .hero-left { padding: 2.5rem 1.2rem; border-right: none; border-bottom: 1px solid var(--border); }
  .hero-canvas-wrap { min-height: 260px; }

  .about-grid, .fc-grid, .skills-layout, .exp-layout,
  .contact-grid, .uses-layout, .faq-layout { grid-template-columns: 1fr; gap: 2.5rem; }

  .do-grid, .phil-grid, .likes-grid { grid-template-columns: 1fr; }

  .proj-grid { grid-template-columns: 1fr; }
  .proj-card.span2 { grid-column: span 1; display: block; }
  .proj-card.span2 .proj-accent { display: none; }
  .proj-card .proj-body { border-radius: 16px !important; }

  .footer-grid { grid-template-columns: 1fr; gap: 2rem; }
  .footer-bottom { flex-direction: column; }
  .vkpage-inner { grid-template-columns: 1fr; }
  .fc-nums { grid-template-columns: 1fr 1fr; }
  .sbar-track { max-width: none; }
}

@media (max-width: 480px) {
  .hero-name  { font-size: clamp(2.4rem, 10vw, 3.2rem); }
  .hero-desc  { font-size: 0.95rem; }
  .hero-btns  { flex-direction: column; }
  .btn-dark, .btn-outline { text-align: center; justify-content: center; width: 100%; }
  .chip { font-size: 0.76rem; padding: 0.3rem 0.8rem; }
  .sec-title { font-size: clamp(1.5rem, 7vw, 2rem); }
  .hero-stats { grid-template-columns: 1fr 1fr; }
  .contact-link { padding: 1rem; gap: 0.8rem; }
  .clink-val { font-size: 0.84rem; }
  .exp-card { padding: 1.3rem; }
}

::selection { background: rgba(170,221,0,0.25); }


/* =====================================================================
   POLISH — stacking sections, smooth transitions, micro-interactions
   ===================================================================== */

/* --- Skip-link -------------------------------------------------- */
.skip-link {
  position: absolute;
  left: -9999px;
  top: 0;
  z-index: 10000;
  padding: 12px 20px;
  background: var(--black);
  color: var(--white);
  text-decoration: none;
  font-family: "Unbounded", sans-serif;
  font-size: 0.78rem;
  font-weight: 700;
  letter-spacing: 0.05em;
  text-transform: uppercase;
  border-radius: 0 0 10px 0;
}
.skip-link:focus { left: 0; outline: 2px solid var(--acid); outline-offset: 2px; }

/* --- Focus-visible ---------------------------------------------- */
:focus-visible {
  outline: 2px solid var(--acid);
  outline-offset: 3px;
  border-radius: 6px;
}
.nav-logo:focus:not(:focus-visible) { outline: none; }

/* --- Reduced motion --------------------------------------------- */
@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after {
    animation-duration: 0.01ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: 0.01ms !important;
    scroll-behavior: auto !important;
  }
  .nav-dot, .dot-live { animation: none !important; }
  .sec { position: relative !important; }
}



/* ================================================================
   REVEAL — плавные появления при скролле
   ================================================================ */

/* Базовый reveal: мягче и длиннее, кубический безье */


.reveal.visible { opacity:1; transform:none; }

/* Каскадная задержка для элементов в сетках */
.do-grid .reveal:nth-child(2) { transition-delay: 0.06s; }
.do-grid .reveal:nth-child(3) { transition-delay: 0.12s; }
.do-grid .reveal:nth-child(4) { transition-delay: 0.18s; }
.do-grid .reveal:nth-child(5) { transition-delay: 0.24s; }
.do-grid .reveal:nth-child(6) { transition-delay: 0.30s; }

.phil-grid .reveal:nth-child(2) { transition-delay: 0.08s; }
.phil-grid .reveal:nth-child(3) { transition-delay: 0.16s; }

/* values-ряды появляются каскадом через JS */
.val-row {
  /* opacity controlled by GSAP */
  transform: none;
  transition:
    opacity 0.6s cubic-bezier(0.22, 1, 0.36, 1),
    transform 0.6s cubic-bezier(0.22, 1, 0.36, 1),
    background 0.25s ease,
    padding-left 0.25s ease;
}

.val-row.visible {
  opacity: 1;
  transform: translateX(0);
}

/* FC-steps каскад */
.fc-step {
  /* opacity controlled by GSAP */
  transform: none;
  transition:
    opacity 0.55s cubic-bezier(0.22, 1, 0.36, 1),
    transform 0.55s cubic-bezier(0.22, 1, 0.36, 1),
    background 0.22s ease;
}

.fc-step.visible {
  opacity: 1;
  transform: translateY(0);
}

/* exp-card каскад */
.exp-card {
  /* opacity controlled by GSAP */
  transform: none;
  transition:
    opacity 0.7s cubic-bezier(0.22, 1, 0.36, 1),
    transform 0.7s cubic-bezier(0.22, 1, 0.36, 1),
    box-shadow 0.3s ease,
    border-color 0.3s ease;
}
.exp-card.visible { opacity: 1; transform: translateY(0); }

/* like-card каскад */
.like-card {
  /* opacity controlled by GSAP */
  transform: none;
  transition:
    opacity 0.6s cubic-bezier(0.22, 1, 0.36, 1),
    transform 0.6s cubic-bezier(0.22, 1, 0.36, 1),
    border-color 0.25s ease;
}
.like-card.visible { opacity: 1; transform: translateY(0) scale(1); }

/* ================================================================
   MICRO-INTERACTIONS — ховеры, акценты
   ================================================================ */

/* Общий easing для всех карточек */
.do-card {
  transition:
    box-shadow 0.4s cubic-bezier(0.22, 1, 0.36, 1),
    transform 0.4s cubic-bezier(0.22, 1, 0.36, 1);
}
.do-card:hover {
  box-shadow: 0 20px 50px rgba(0,0,0,0.09);
  transform: translateY(-6px);
}

/* Стрелка в углу услуг */
.do-card { position: relative; overflow: hidden; }
.do-card::after {
  content: "→";
  position: absolute;
  top: 1.5rem; right: 1.6rem;
  font-family: "Unbounded", sans-serif;
  font-size: 1.1rem; font-weight: 700;
  color: var(--acid);
  opacity: 0;
  transform: translate(-10px, 6px);
  transition: all 0.45s cubic-bezier(0.22, 1, 0.36, 1);
  pointer-events: none;
}
.do-card:hover::after { opacity: 1; transform: translate(0, 0); }

/* Цифра-номер в do-card плавно */
.do-num { transition: transform 0.45s cubic-bezier(0.22, 1, 0.36, 1), color 0.3s ease; }
.do-card:hover .do-num { transform: translateY(-4px); }

/* Values — зелёная полоска слева */
.val-row { position: relative; }
.val-row::after {
  content: "";
  position: absolute; left: 0; top: 0; bottom: 0;
  width: 0;
  background: var(--acid);
  transition: width 0.35s cubic-bezier(0.22, 1, 0.36, 1);
}
.val-row:hover::after { width: 3px; }
.val-row:hover { padding-left: calc(1.4rem + 5px); }

/* val-icon: скруглённее и масштаб */
.val-icon { transition: transform 0.4s cubic-bezier(0.22, 1, 0.36, 1), border-radius 0.4s; }
.val-row:hover .val-icon { transform: rotate(-6deg) scale(1.08); border-radius: 10px; }

/* FC-steps: номер подсвечивается */
.fc-step-n {
  transition: background 0.3s cubic-bezier(0.22, 1, 0.36, 1),
              color 0.3s ease,
              transform 0.3s cubic-bezier(0.22, 1, 0.36, 1);
}
.fc-step:hover .fc-step-n {
  background: var(--acid);
  color: var(--black);
  transform: scale(1.1);
}

/* Вертикальная линия между fc-step номерами */
.fc-step { position: relative; }
.fc-step:not(:last-child) .fc-step-n::after {
  content: "";
  position: absolute;
  left: 50%; top: 100%;
  width: 1.5px;
  height: calc(100% + 0.6rem);
  background: linear-gradient(to bottom, rgba(0,0,0,0.15), rgba(0,0,0,0.03));
  transform: translateX(-50%);
  pointer-events: none;
  z-index: -1;
}

/* Proj-card: зелёный отблеск в углу */
.proj-card:not([aria-hidden]) .proj-body {
  position: relative; overflow: hidden;
}
.proj-card:not([aria-hidden]) .proj-body::after {
  content: "";
  position: absolute; top: 0; right: 0;
  width: 180px; height: 180px;
  background: radial-gradient(circle at top right, rgba(170,221,0,0.1), transparent 70%);
  opacity: 0;
  transition: opacity 0.5s cubic-bezier(0.22, 1, 0.36, 1);
  pointer-events: none;
  border-radius: inherit;
}
.proj-card:not([aria-hidden]):hover .proj-body::after { opacity: 1; }
.proj-body > * { position: relative; z-index: 1; }

/* Proj-card: ховер мягче */
.proj-card {
  transition: transform 0.5s cubic-bezier(0.22, 1, 0.36, 1);
}
.proj-card:hover { transform: translateY(-5px); }

/* Тёмный бордер при ховере с зелёным */
.proj-card:not([aria-hidden]):hover .proj-body {
  border-color: rgba(170,221,0,0.2) !important;
}

/* Proj-link: буквы разъезжаются */
.proj-link {
  transition: letter-spacing 0.4s cubic-bezier(0.22, 1, 0.36, 1),
              gap 0.4s cubic-bezier(0.22, 1, 0.36, 1);
}
.proj-card:hover .proj-link { letter-spacing: 0.1em; }

/* Пустая карточка: пульсирующая точка */
.proj-card--empty .proj-body {
  border: 1.5px dashed #2E2E2E !important;
  opacity: 0.65;
  background: transparent !important;
  transition: border-color 0.4s ease, opacity 0.4s ease;
}
.proj-card--empty:hover .proj-body { border-color: var(--acid) !important; opacity: 1; }
.proj-card--empty .proj-link { position: relative; padding-left: 14px; }
.proj-card--empty .proj-link::before {
  content: "";
  position: absolute; left: 0; top: 50%;
  width: 6px; height: 6px;
  background: var(--acid);
  border-radius: 50%;
  transform: translateY(-50%);
  animation: dotPulse 2.5s ease-in-out infinite;
}
@keyframes dotPulse {
  0%, 100% { opacity: 1; transform: translateY(-50%) scale(1); }
  50%      { opacity: 0.3; transform: translateY(-50%) scale(0.5); }
}

/* Phil-card: декоративная кавычка */
.phil-card {
  position: relative; overflow: hidden;
  transition: border-color 0.35s ease,
              transform 0.45s cubic-bezier(0.22, 1, 0.36, 1),
              box-shadow 0.45s cubic-bezier(0.22, 1, 0.36, 1);
}
.phil-card::before {
  content: "\201C";
  position: absolute; top: -20px; left: 16px;
  font-family: "Unbounded", sans-serif;
  font-size: 8rem; font-weight: 900;
  color: var(--acid);
  opacity: 0.05;
  line-height: 1;
  pointer-events: none; user-select: none;
  transition: opacity 0.5s ease, transform 0.5s cubic-bezier(0.22, 1, 0.36, 1);
}
.phil-card:hover { box-shadow: 0 16px 48px rgba(170,221,0,0.06); transform: translateY(-5px); }
.phil-card:hover::before { opacity: 0.1; transform: translateY(-3px); }

/* Exp-card: акцент-бар расширяется */
.exp-card::before { transition: width 0.4s cubic-bezier(0.22, 1, 0.36, 1); }
.exp-card:hover::before { width: 6px; }

/* FAQ: кислотная полоска слева при открытии */
.faq-item {
  border-left: 2px solid transparent;
  padding-left: 0;
  transition: border-left-color 0.35s ease,
              padding-left 0.35s cubic-bezier(0.22, 1, 0.36, 1);
}
.faq-item.is-open {
  border-left-color: var(--acid);
  padding-left: 1rem;
}

/* FAQ: hover на текст мягче */
.faq-q-text { transition: color 0.3s ease; }
.faq-item:hover:not(.is-open) .faq-q-text { color: #ccc; }

/* FAQ icon: мягче вращение */
.faq-icon {
  transition: border-color 0.35s ease,
              color 0.35s ease,
              transform 0.4s cubic-bezier(0.22, 1, 0.36, 1),
              background 0.35s ease;
}

/* Skill-bars: мягкий градиент */
.sbar-fill {
  transition: width 1.4s cubic-bezier(0.22, 1, 0.36, 1);
  background: linear-gradient(90deg, var(--acid) 0%, #c8eb30 100%);
}

/* Hero-stat ховер */
.hero-stat {
  transition: background 0.35s cubic-bezier(0.22, 1, 0.36, 1);
  cursor: default;
}
.hero-stat:hover { background: rgba(170,221,0,0.05); }

/* Chips: мягче */
.chip {
  transition: background 0.3s ease, color 0.3s ease,
              border-color 0.3s ease,
              transform 0.35s cubic-bezier(0.22, 1, 0.36, 1);
}
.chip:hover { transform: translateY(-2px); }

/* Uses-chip ховер */
.uses-chip {
  transition: border-color 0.3s ease, transform 0.35s cubic-bezier(0.22, 1, 0.36, 1),
              box-shadow 0.35s ease;
}
.uses-chip.hi:hover {
  box-shadow: 0 8px 28px rgba(170,221,0,0.1);
  border-color: rgba(170,221,0,0.5);
}

/* Like-card: приподнимается и подсвечивается */
.like-card {
  transition: border-color 0.3s ease,
              transform 0.4s cubic-bezier(0.22, 1, 0.36, 1);
}
.like-card:hover { transform: translateY(-3px); }
.like-card--yes:hover { border-color: rgba(170,221,0,0.3); }
.like-card--no:hover  { border-color: #6a0000; }

/* Фоновый номер в like-card: чуть проявляется при hover */
.like-card-num {
  transition: opacity 0.4s ease, transform 0.5s cubic-bezier(0.22, 1, 0.36, 1);
}
.like-card:hover .like-card-num { opacity: 0.08; transform: translate(-2px, -5px); }

/* Sec-label: линия мягко дышит */
.sec-label::before {
  transition: width 0.6s ease;
}

/* Contact-link-icon: лёгкий поворот */
.contact-link-icon {
  transition: background 0.3s ease,
              transform 0.4s cubic-bezier(0.22, 1, 0.36, 1);
}
.contact-link:hover .contact-link-icon { transform: rotate(-6deg) scale(1.05); }

/* CTA arrow: мягче */
.clink-arrow { transition: transform 0.35s cubic-bezier(0.22, 1, 0.36, 1); }
.contact-link:hover .clink-arrow { transform: translateX(6px); }



/* Nav: мягче вход */
nav { animation: fadeDown 0.6s cubic-bezier(0.22, 1, 0.36, 1) both; }

/* Selection */
::selection { background: rgba(170,221,0,0.3); color: var(--black); }

/* Details marker */
details > summary { list-style: none; }
details > summary::-webkit-details-marker { display: none; }

/* ================================================================
   PRINT
   ================================================================ */
@media print {
  nav, #back-top, #scroll-prog, .mob-menu, .burger,
  #heroCanvas, .hero-canvas-wrap,
  .hero-btns, .nav-btn, .vkpage-btn, .btn-dark, .btn-outline,
  .proj-accent, .marquee-wrap { display: none !important; }
  body { background: #fff !important; color: #000 !important; font-size: 11pt; padding: 0 !important; }
  .sec { position: relative !important; padding: 1rem 0 !important; background: #fff !important; border: none !important; box-shadow: none !important; }
  .sec-title, .sec-label, h2, h3 { color: #000 !important; }
  a { color: #000 !important; text-decoration: underline; }
  a[href^="http"]::after { content: " (" attr(href) ")"; font-size: 9pt; color: #555; }
  section, .exp-card, .do-card, .phil-card, .like-card {
    page-break-inside: avoid; break-inside: avoid;
    background: #fff !important; border-color: #ccc !important; color: #000 !important;
  }
  .projects, .philosophy, .faq, .likes-sec, .vkpage-teaser { background: #fff !important; }
  .proj-name, .phil-q, .faq-q-text, .like-card-title, .contact-lead { color: #000 !important; }
}

/* ================================================================
   ANIMATION SYSTEM — added layer
   ================================================================ */

/* ── CHAR SPLITS ────────────────────────────────────────────── */
.char { display:inline-block; will-change:transform,opacity; }
.word { display:inline-block; overflow:hidden; }

/* ── CLIP REVEAL ────────────────────────────────────────────── */
.line-wrap { overflow:hidden; display:block; }

/* ── MAGNETIC ───────────────────────────────────────────────── */
.btn-dark, .btn-outline, .btn-acid, .vkpage-btn, .nav-btn {
  transform-style: preserve-3d;
  will-change: transform;
}

/* ── PRELOADER EXIT ─────────────────────────────────────────── */
#preloader.out {
  animation: preOut 0.9s cubic-bezier(0.76,0,0.24,1) both;
}
@keyframes preOut {
  to { transform: translateY(-100%); }
}

/* ── SCROLLBAR ──────────────────────────────────────────────── */
::-webkit-scrollbar { width:4px; }
::-webkit-scrollbar-track { background:#0A0A0A; }
::-webkit-scrollbar-thumb { background:var(--acid); border-radius:2px; }

/* ── GSAP HIDDEN ────────────────────────────────────────────── */
.gsap-hidden { opacity:0 !important; }

/* ── SECTION ENTRY LINES ────────────────────────────────────── */
.sec-title-line {
  height:2px; background:var(--acid); border-radius:2px;
  transform-origin:left; display:block;
  margin-top:8px; max-width:56px;
}

/* ── HERO CANVAS PARALLAX WRAPPER ───────────────────────────── */
.hero-canvas-wrap { overflow:hidden; }


/* ── TILT CARDS ─────────────────────────────────────────────── */
.tilt { transform-style:preserve-3d; perspective:1000px; }
.tilt-inner { transition:transform 0.1s ease; transform-style:preserve-3d; }

/* ── SCROLLING MARQUEE (always visible) ─────────────────────── */
.marquee-wrap { position:relative; z-index:1; }

/* ── CONTACT GLOW ───────────────────────────────────────────── */
.contact { position:relative; overflow:hidden; }
.contact::before {
  content:''; position:absolute;
  width:600px; height:600px; border-radius:50%;
  background:radial-gradient(circle, rgba(170,221,0,.06) 0%, transparent 70%);
  top:-200px; right:-200px; pointer-events:none;
  animation:contactPulse 5s ease-in-out infinite;
}
@keyframes contactPulse {
  0%,100%{transform:scale(1);opacity:.7} 50%{transform:scale(1.2);opacity:1}
}

/* ── MOBILE OPTIMIZATIONS ───────────────────────────────────── */
@media (max-width:768px) {
  .contact::before { display:none; }
}


/* ── HERO STAT FLOAT (replaces anime.js) ───────────────────── */
@keyframes floatUp {
  0%, 100% { transform: translateY(0); }
  50%       { transform: translateY(-7px); }
}
@keyframes floatDown {
  0%, 100% { transform: translateY(0); }
  50%       { transform: translateY(7px); }
}
/* hero-stat float is handled by GSAP in initHeroEntrance onComplete */

/* ── PROJ EMPTY CARD BORDER PULSE (replaces anime.js) ──────── */
@keyframes borderPulse {
  0%, 100% { border-color: #2E2E2E; }
  50%       { border-color: rgba(170,221,0,0.45); }
}
.proj-card--empty .proj-body {
  animation: borderPulse 2.6s ease-in-out infinite;
}

@media (prefers-reduced-motion: reduce) {
  .hero-stat { animation: none !important; }
  .proj-card--empty .proj-body { animation: none !important; }
}

@media (prefers-reduced-motion:reduce) {
  #preloader { display:none !important; }
  * { animation-duration:0.01ms !important; transition-duration:0.01ms !important; }
}

/* ── NAV SCROLLED STATE ─────────────────────────────────────── */
nav.scrolled {
  background:rgba(248,248,244,0.97);
  box-shadow:0 1px 0 var(--border), 0 4px 32px rgba(0,0,0,.06);
}

/* ── PROJ CARD CURSOR STATE ─────────────────────────────────── */


/* ── STAGGER UTILITY ────────────────────────────────────────── */
[data-delay="1"] { transition-delay:.05s !important; }
[data-delay="2"] { transition-delay:.10s !important; }
[data-delay="3"] { transition-delay:.15s !important; }
[data-delay="4"] { transition-delay:.20s !important; }
[data-delay="5"] { transition-delay:.25s !important; }

/* ── STAGGER DELAYS ─────────────────────────────────────────── */
.reveal[data-d="1"] { transition-delay: 0.09s; }
.reveal[data-d="2"] { transition-delay: 0.18s; }
.reveal[data-d="3"] { transition-delay: 0.27s; }
.reveal[data-d="4"] { transition-delay: 0.36s; }
.reveal[data-d="5"] { transition-delay: 0.45s; }
.reveal[data-d="6"] { transition-delay: 0.42s; }

/* ── CARD INITIAL STATES (for stagger via JS) ───────────────── */
.do-card, .proj-card, .phil-card, .like-card, .faq-item,
.val-row, .fc-step, .exp-card, .uses-chip, .pill,
.fc-num-box, .contact-link, .fc-contact,
.about-p, .fc-p, .fc-mission, .exp-li, .hero-stat, .hero-loc,
.footer-grid > div {
  opacity: 0;
  transform: translateY(20px);
  /* Only transition opacity+transform for entry animation */
  transition: opacity 0.65s cubic-bezier(0.22,1,0.36,1),
              transform 0.65s cubic-bezier(0.22,1,0.36,1);
}

/* Once animated in — restore clean hover-only transitions */
.do-card.anim-in       { transition: opacity 0.65s cubic-bezier(0.22,1,0.36,1), transform 0.65s cubic-bezier(0.22,1,0.36,1), box-shadow 0.28s ease; }
.proj-card.anim-in     { transition: opacity 0.65s cubic-bezier(0.22,1,0.36,1), transform 0.65s cubic-bezier(0.22,1,0.36,1); }
.phil-card.anim-in     { transition: opacity 0.65s cubic-bezier(0.22,1,0.36,1), transform 0.65s cubic-bezier(0.22,1,0.36,1), border-color 0.22s; }
.like-card.anim-in     { transition: opacity 0.65s cubic-bezier(0.22,1,0.36,1), transform 0.65s cubic-bezier(0.22,1,0.36,1), border-color 0.22s; }
.faq-item.anim-in      { transition: opacity 0.65s cubic-bezier(0.22,1,0.36,1), transform 0.65s cubic-bezier(0.22,1,0.36,1); }
.val-row.anim-in       { transition: opacity 0.65s cubic-bezier(0.22,1,0.36,1), transform 0.65s cubic-bezier(0.22,1,0.36,1), background 0.18s ease; }
.fc-step.anim-in       { transition: opacity 0.65s cubic-bezier(0.22,1,0.36,1), transform 0.65s cubic-bezier(0.22,1,0.36,1), background 0.18s ease; }
.exp-card.anim-in      { transition: opacity 0.65s cubic-bezier(0.22,1,0.36,1), transform 0.65s cubic-bezier(0.22,1,0.36,1), box-shadow 0.22s, border-color 0.22s; }
.uses-chip.anim-in     { transition: opacity 0.65s cubic-bezier(0.22,1,0.36,1), transform 0.65s cubic-bezier(0.22,1,0.36,1), border-color 0.18s; }
.pill.anim-in          { transition: opacity 0.65s cubic-bezier(0.22,1,0.36,1), transform 0.65s cubic-bezier(0.22,1,0.36,1), background 0.18s, color 0.18s, border-color 0.18s; }
.contact-link.anim-in  { transition: opacity 0.65s cubic-bezier(0.22,1,0.36,1), transform 0.65s cubic-bezier(0.22,1,0.36,1), border-color 0.2s, background 0.2s, box-shadow 0.2s; }
.fc-contact.anim-in    { transition: opacity 0.65s cubic-bezier(0.22,1,0.36,1), transform 0.65s cubic-bezier(0.22,1,0.36,1), background 0.18s; }

/* Direction overrides — all use translateY for consistency */
.val-row { transform: translateY(16px); }
.fc-step { transform: translateY(16px); }
.exp-li  { transform: translateY(12px); }

.anim-in {
  opacity: 1 !important;
  transform: none !important;
}
/* ================================================================
/* ================================================================
   PLATFORM SELECTOR
   ================================================================ */

.cfg-platform-block {
  padding: 1.25rem 1.5rem 1.1rem;
  border-bottom: 1px solid var(--border);
  background: var(--bg);
}

.cfg-platform-lbl {
  font-size: 0.65rem; font-weight: 700; letter-spacing: 0.14em;
  text-transform: uppercase; color: var(--gray); margin-bottom: 0.85rem;
}

.cfg-platform-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 0.55rem;
}

@media (max-width: 640px) {
  .cfg-platform-grid { grid-template-columns: 1fr; }
}

.cfg-plat-pill {
  display: flex; flex-direction: column; align-items: flex-start;
  gap: 0.25rem; padding: 0.85rem 1rem;
  border: 1.5px solid var(--border); border-radius: 10px;
  background: var(--white); cursor: pointer; text-align: left;
  transition: border-color 0.18s, background 0.18s, box-shadow 0.18s;
}

.cfg-plat-pill:hover {
  border-color: #bbb;
  box-shadow: 0 2px 8px rgba(0,0,0,0.06);
}

.cfg-plat-pill.on {
  border-color: var(--black);
  background: var(--black);
  box-shadow: 0 3px 12px rgba(0,0,0,0.18);
}

.cpp-badge {
  font-size: 0.58rem; font-weight: 700; letter-spacing: 0.09em;
  text-transform: uppercase; color: var(--gray);
  padding: 0.15rem 0.45rem; border-radius: 4px;
  background: var(--lightgray); border: 1px solid var(--border);
  transition: color 0.15s, background 0.15s, border-color 0.15s;
}

.cfg-plat-pill.on .cpp-badge {
  background: rgba(170,221,0,0.18); border-color: rgba(170,221,0,0.4); color: #5c7a00;
}

.cpp-name {
  font-size: 0.9rem; font-weight: 700; color: var(--black);
  line-height: 1; transition: color 0.15s;
}

.cfg-plat-pill.on .cpp-name { color: var(--white); }

.cpp-desc {
  font-size: 0.72rem; color: var(--gray); line-height: 1.45;
  transition: color 0.15s;
}

.cfg-plat-pill.on .cpp-desc { color: rgba(255,255,255,0.55); }

.cpp-from {
  font-family: "Unbounded", sans-serif; font-size: 0.68rem;
  font-weight: 700; color: var(--black); margin-top: 0.2rem;
  transition: color 0.15s;
}

.cfg-plat-pill.on .cpp-from { color: var(--acid); }

.cfg-reset-btn {
  width: 100%; padding: 0.65rem; background: transparent;
  border: 1.5px dashed var(--border); border-radius: 8px;
  color: var(--gray); font-size: 0.79rem; font-family: "Onest", sans-serif;
  cursor: pointer; transition: border-color 0.2s, color 0.2s;
}

.cfg-reset-btn:hover { border-color: rgba(200,80,80,0.4); color: #cc4444; }

/* ================================================================
   PRICING CONFIGURATOR — two-column (options | receipt)
   ================================================================ */

.srv-intro-text {
  font-size: 0.95rem; color: var(--gray); max-width: 600px;
  line-height: 1.75; margin: 1.5rem 0 2.5rem;
}

/* ── Layout ── */
.price-cfg {
  display: grid;
  grid-template-columns: 1fr 320px;
  gap: 1.8rem;
  align-items: start;
}

.cfg-left {
  background: var(--white);
  border: 1px solid var(--border);
  border-radius: 16px;
  overflow: hidden;
}

/* ── Module ── */
.cfg-mod { border-bottom: 1px solid var(--border); }
.cfg-mod:last-child { border-bottom: none; }

.cfg-mod-hd {
  width: 100%; text-align: left; background: none; border: none;
  cursor: pointer; display: flex; align-items: center; gap: 0.85rem;
  padding: 1.1rem 1.5rem; transition: background 0.18s;
}

.cfg-mod-hd:hover { background: var(--bg); }

.cfg-cb {
  width: 20px; height: 20px; flex-shrink: 0;
  border: 2px solid var(--border); border-radius: 5px;
  display: flex; align-items: center; justify-content: center;
  transition: background 0.18s, border-color 0.18s; background: var(--bg);
}

.cfg-cb svg { opacity: 0; transition: opacity 0.15s; color: var(--black); }
.cfg-cb[data-on="true"] { background: var(--acid); border-color: var(--acid); }
.cfg-cb[data-on="true"] svg { opacity: 1; }

.cfg-mod-name {
  font-size: 0.86rem; font-weight: 600; color: var(--black); flex: 1;
}

.cfg-mod-sum {
  font-size: 0.8rem; font-weight: 700; color: var(--black);
  white-space: nowrap; font-family: "Unbounded", sans-serif;
  letter-spacing: -0.02em;
}

.cfg-mod-sum--off { font-family: "Onest", sans-serif; color: var(--gray); font-weight: 400; letter-spacing: 0; }

/* ── Module body ── */
.cfg-mod-bd {
  padding: 0 1.5rem;
  overflow: hidden;
  transition: height 0.35s cubic-bezier(0.22,1,0.36,1), opacity 0.3s ease;
  opacity: 1;
}

.cfg-mod-bd[hidden] { display: none; }

/* Ensure HTML hidden attribute always works regardless of other CSS */
[hidden] { display: none !important; }

/* ── Group ── */
.cfg-grp { padding: 1.2rem 0; border-top: 1px solid var(--border); }
.cfg-grp:first-child { border-top: none; padding-top: 1rem; }

.cfg-glbl {
  font-size: 0.65rem; font-weight: 700; letter-spacing: 0.14em;
  text-transform: uppercase; color: var(--gray); margin-bottom: 0.7rem;
}

/* ── Pills (radio) ── */
.cfg-pills { display: flex; flex-wrap: wrap; gap: 0.45rem; }

.cfg-pill {
  display: flex; flex-direction: column; gap: 0.1rem;
  padding: 0.5rem 0.85rem; border: 1.5px solid var(--border);
  border-radius: 8px; background: var(--bg); cursor: pointer;
  font-size: 0.82rem; font-weight: 500; color: var(--black);
  text-align: left; transition: border-color 0.15s, background 0.15s, box-shadow 0.15s;
}

.cfg-pill small { font-size: 0.67rem; color: var(--gray); font-weight: 400; }
.cfg-pill:hover { border-color: #aaa; background: var(--white); }

.cfg-pill.on {
  border-color: var(--black); background: var(--black); color: var(--white);
  box-shadow: 0 2px 8px rgba(0,0,0,0.15);
}

.cfg-pill.on small { color: rgba(255,255,255,0.5); }

/* ── Checkbox list ── */
.cfg-chks { display: flex; flex-direction: column; gap: 0; }

.cfg-chk {
  display: flex; align-items: center; justify-content: space-between;
  padding: 0.6rem 0.75rem; border-radius: 7px; border: none;
  background: transparent; cursor: pointer; width: 100%; text-align: left;
  font-size: 0.82rem; font-weight: 500; color: var(--black);
  transition: background 0.15s; gap: 0.5rem;
}

.cfg-chk::before {
  content: ''; width: 14px; height: 14px; flex-shrink: 0;
  border: 1.5px solid var(--border); border-radius: 3px;
  transition: background 0.15s, border-color 0.15s;
}

.cfg-chk:hover { background: var(--bg); }

.cfg-chk.on::before { background: var(--acid); border-color: var(--acid); }

.cfg-chk-p {
  font-size: 0.72rem; color: var(--gray); font-weight: 400;
  white-space: nowrap; margin-left: auto;
}

.cfg-chk.on .cfg-chk-p { color: var(--black); font-weight: 600; }

/* ── Always included ── */
.cfg-always {
  display: flex; flex-wrap: wrap; gap: 0.3rem 0.8rem;
  padding: 0.85rem 0 1.1rem; font-size: 0.75rem; color: var(--gray);
  border-top: 1px dashed var(--border); margin-top: 0.5rem;
}

.cfg-always-lbl { font-weight: 700; color: var(--black); width: 100%; font-size: 0.67rem; letter-spacing: 0.1em; text-transform: uppercase; margin-bottom: 0.2rem; }

/* ── Urgency ── */
.cfg-urg-wrap {
  padding: 1.2rem 1.5rem 1.5rem;
  background: var(--bg);
  border-top: 1px solid var(--border);
}

.cfg-urg-wrap .cfg-glbl { margin-bottom: 0.7rem; }
.cfg-pills--urg .cfg-pill { flex: 1; align-items: center; }

.cfg-discount-note {
  margin-top: 0.9rem; font-size: 0.74rem; color: var(--gray);
}

/* ── Receipt (right column) ── */
.cfg-right { position: sticky; top: 76px; }

.cfg-receipt {
  background: var(--black); border-radius: 16px; overflow: hidden;
  color: var(--white);
}

.cfg-rcpt-hd {
  padding: 1.1rem 1.4rem 0.9rem;
  border-bottom: 1px solid rgba(255,255,255,0.07);
}

.cfg-rcpt-title {
  font-family: "Unbounded", sans-serif; font-size: 0.72rem;
  font-weight: 700; letter-spacing: 0.1em; text-transform: uppercase;
  color: rgba(255,255,255,0.4);
}

.cfg-rcpt-body {
  padding: 0.6rem 1.4rem; min-height: 80px;
  max-height: 320px; overflow-y: auto;
}

.cfg-rcpt-empty {
  font-size: 0.8rem; color: rgba(255,255,255,0.2);
  font-style: italic; padding: 1rem 0;
}

/* Receipt sections */
.rcpt-sec { margin-bottom: 1rem; }
.rcpt-sec:last-child { margin-bottom: 0; }

.rcpt-sec-nm {
  font-size: 0.62rem; font-weight: 700; letter-spacing: 0.12em;
  text-transform: uppercase; color: var(--acid); margin-bottom: 0.35rem;
}

.rcpt-row {
  display: flex; justify-content: space-between; align-items: baseline;
  gap: 0.5rem; padding: 0.18rem 0; font-size: 0.79rem;
}

.rcpt-row-name { color: rgba(255,255,255,0.65); flex: 1; }
.rcpt-row-price { color: rgba(255,255,255,0.85); white-space: nowrap; font-weight: 600; font-size: 0.75rem; }

.rcpt-row--add .rcpt-row-name { color: rgba(255,255,255,0.4); padding-left: 0.8rem; font-size: 0.74rem; }
.rcpt-row--add .rcpt-row-name::before { content: '+ '; }

.rcpt-row--sub {
  border-top: 1px solid rgba(255,255,255,0.07);
  margin-top: 0.25rem; padding-top: 0.35rem;
}

.rcpt-row--sub .rcpt-row-name { color: rgba(255,255,255,0.25); font-size: 0.68rem; }
.rcpt-row--sub .rcpt-row-price { color: rgba(255,255,255,0.7); font-weight: 700; }

.rcpt-urg-row {
  display: flex; justify-content: space-between; font-size: 0.75rem;
  padding: 0.6rem 0; border-top: 1px dashed rgba(255,255,255,0.1);
  margin-top: 0.5rem; color: rgba(255,255,255,0.5);
}

.rcpt-urg-row span:last-child { color: #ff9f43; font-weight: 600; }

/* ── Receipt footer ── */
.cfg-rcpt-footer {
  padding: 0.85rem 1.4rem 0.9rem;
  border-top: 1px solid rgba(255,255,255,0.1);
  background: rgba(255,255,255,0.03);
}

.cfg-rcpt-total {
  display: flex; justify-content: space-between; align-items: baseline; gap: 0.5rem;
}

.cfg-rcpt-total > span:first-child {
  font-size: 0.68rem; font-weight: 600; letter-spacing: 0.1em;
  text-transform: uppercase; color: rgba(255,255,255,0.3);
}

.cfg-rcpt-total-val {
  font-family: "Unbounded", sans-serif; font-size: 1.5rem;
  font-weight: 900; letter-spacing: -0.05em; color: var(--acid);
  transition: all 0.25s cubic-bezier(0.22,1,0.36,1);
}

.cfg-discount-badge {
  display: inline-flex; align-items: center; gap: 0.4rem; margin-top: 0.4rem;
  background: rgba(170,221,0,0.12); border: 1px solid rgba(170,221,0,0.25);
  color: var(--acid); font-size: 0.67rem; font-weight: 700;
  letter-spacing: 0.06em; padding: 0.2rem 0.55rem; border-radius: 20px;
}

/* ── Actions ── */
.cfg-rcpt-actions {
  padding: 0.85rem 1.4rem; display: flex; flex-direction: column; gap: 0.5rem;
  border-top: 1px solid rgba(255,255,255,0.07);
}

.cfg-copy-btn {
  display: inline-flex; align-items: center; justify-content: center; gap: 0.5rem;
  padding: 0.6rem 0.9rem; background: rgba(255,255,255,0.07);
  border: 1px solid rgba(255,255,255,0.1); border-radius: 7px;
  color: rgba(255,255,255,0.65); font-family: "Onest", sans-serif;
  font-size: 0.77rem; font-weight: 500; cursor: pointer; width: 100%;
  transition: background 0.18s, border-color 0.18s, color 0.18s;
}

.cfg-copy-btn:hover { background: rgba(255,255,255,0.12); border-color: rgba(255,255,255,0.2); color: var(--white); }
.cfg-copy-btn.copied { background: rgba(170,221,0,0.14); border-color: rgba(170,221,0,0.35); color: var(--acid); }

.cfg-cta-btn {
  display: flex; align-items: center; justify-content: center;
  padding: 0.65rem; background: var(--acid); border-radius: 7px;
  color: var(--black); font-family: "Unbounded", sans-serif;
  font-size: 0.65rem; font-weight: 700; letter-spacing: 0.05em;
  text-decoration: none; transition: opacity 0.18s; width: 100%;
}

.cfg-cta-btn:hover { opacity: 0.88; }

.cfg-copy-hint {
  padding: 0 1.4rem 0.85rem; font-size: 0.68rem;
  color: rgba(255,255,255,0.22); line-height: 1.55;
}

/* ── Paste ── */
.cfg-paste-wrap {
  padding: 0.85rem 1.4rem 1.1rem;
  border-top: 1px solid rgba(255,255,255,0.07);
}

.cfg-paste-lbl {
  font-size: 0.62rem; font-weight: 700; letter-spacing: 0.1em;
  text-transform: uppercase; color: rgba(255,255,255,0.25); margin-bottom: 0.5rem;
}

.cfg-paste-row { display: flex; gap: 0.4rem; }

.cfg-paste-inp {
  flex: 1; background: rgba(255,255,255,0.06); border: 1px solid rgba(255,255,255,0.1);
  border-radius: 6px; padding: 0.5rem 0.7rem; color: rgba(255,255,255,0.8);
  font-size: 0.75rem; font-family: "Onest", sans-serif; outline: none;
  transition: border-color 0.18s;
}

.cfg-paste-inp::placeholder { color: rgba(255,255,255,0.2); }
.cfg-paste-inp:focus { border-color: rgba(255,255,255,0.3); }

.cfg-paste-btn {
  padding: 0.5rem 0.75rem; background: rgba(255,255,255,0.1);
  border: 1px solid rgba(255,255,255,0.12); border-radius: 6px;
  color: rgba(255,255,255,0.6); cursor: pointer; font-size: 1rem;
  transition: background 0.18s, color 0.18s;
}

.cfg-paste-btn:hover { background: var(--acid); color: var(--black); border-color: var(--acid); }

/* ── Responsive ── */
@media (max-width: 960px) {
  .price-cfg { grid-template-columns: 1fr; }
  .cfg-right { position: static; }
  .cfg-receipt { border-radius: 12px; }
  .cfg-rcpt-actions { flex-direction: row; }
  .cfg-copy-btn, .cfg-cta-btn { flex: 1; }
}

@media (max-width: 560px) {
  .cfg-mod-hd { padding: 1rem 1.1rem; }
  .cfg-mod-bd { padding: 0 1.1rem; }
  .cfg-urg-wrap { padding: 1rem 1.1rem 1.3rem; }
  .cfg-rcpt-hd, .cfg-rcpt-body, .cfg-rcpt-footer,
  .cfg-rcpt-actions, .cfg-copy-hint, .cfg-paste-wrap { padding-left: 1.1rem; padding-right: 1.1rem; }
  .cfg-rcpt-total-val { font-size: 1.25rem; }
  .cfg-rcpt-actions { flex-direction: column; }
}

/* ── Service notes (payment + disclaimer) ── */
.srv-notes {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 1rem;
  margin-top: 1.5rem;
}

.srv-note-item {
  display: flex;
  align-items: flex-start;
  gap: 0.9rem;
  padding: 1.1rem 1.3rem;
  background: var(--white);
  border: 1px solid var(--border);
  border-radius: 12px;
}

.srv-note-icon {
  font-size: 1rem;
  color: var(--acid);
  flex-shrink: 0;
  margin-top: 0.1rem;
  line-height: 1;
}

.srv-note-title {
  font-size: 0.8rem;
  font-weight: 700;
  color: var(--black);
  margin-bottom: 0.3rem;
}

.srv-note-text {
  font-size: 0.77rem;
  color: var(--gray);
  line-height: 1.65;
}

@media (max-width: 600px) {
  .srv-notes { grid-template-columns: 1fr; }
}

/* ── Mini CTA strip ── */
.mini-cta {
  background: var(--black);
  padding: 1.4rem 0;
}

.mini-cta-inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1.5rem;
  flex-wrap: wrap;
}

.mini-cta-text {
  font-size: 1rem;
  color: rgba(255,255,255,0.85);
  font-weight: 500;
}

.mini-cta-btn {
  display: inline-flex;
  align-items: center;
  padding: 0.65rem 1.4rem;
  background: var(--acid);
  color: var(--black);
  font-family: "Unbounded", sans-serif;
  font-size: 0.65rem;
  font-weight: 700;
  letter-spacing: 0.05em;
  text-decoration: none;
  border-radius: 8px;
  transition: opacity 0.18s;
  white-space: nowrap;
}

.mini-cta-btn:hover { opacity: 0.85; }

@media (max-width: 600px) {
  .mini-cta { padding: 1rem 1.2rem; }
  .mini-cta-text { font-size: 0.85rem; }
  .mini-cta-btn { width: 100%; justify-content: center; }
}
/* ── CONFIGURATOR RESET BUTTON ─────────────────────────────── */
.cfg-reset-btn {
  width: 100%;
  background: none;
  border: 1px solid var(--border);
  border-radius: 8px;
  padding: 0.55rem 1rem;
  font-size: 0.76rem;
  color: var(--gray);
  cursor: pointer;
  transition: border-color 0.18s, color 0.18s;
  margin-top: 0.75rem;
}
.cfg-reset-btn:hover { border-color: var(--black); color: var(--black); }
/* ================================================================
   PRICING v5 ADDITIONS
   ================================================================ */

/* Edit platform note */
.cfg-edit-note {
  font-size: 0.72rem; color: var(--gray); font-style: italic;
  margin: 0 0 0.6rem; padding: 0.35rem 0.6rem;
  background: var(--bg); border-radius: 5px;
  border-left: 2px solid var(--lightgray);
  line-height: 1.4;
}

/* Tilda built-in note badge in integration buttons */
.int-tilda-note {
  font-size: 0.58rem; font-weight: 700; letter-spacing: 0.05em;
  text-transform: uppercase; color: #5c7a00;
  background: rgba(170,221,0,0.13); border: 1px solid rgba(170,221,0,0.28);
  padding: 0.1rem 0.4rem; border-radius: 3px;
  white-space: nowrap; flex-shrink: 0; align-self: center;
}

/* Example scenarios */
.srv-examples {
  margin: 2.5rem 0 2rem;
}

.srv-ex-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(200px, 1fr));
  gap: 0.65rem;
}

.srv-ex-card {
  display: flex; flex-direction: column; align-items: flex-start;
  gap: 0.45rem; padding: 1rem 1.1rem;
  background: var(--white); border: 1.5px solid var(--border);
  border-radius: 12px; cursor: pointer; text-align: left;
  font-family: "Onest", sans-serif;
  transition: border-color 0.18s, box-shadow 0.18s, transform 0.15s;
}

.srv-ex-card:hover {
  border-color: var(--black);
  transform: translateY(-2px);
  box-shadow: 0 4px 14px rgba(0,0,0,0.09);
}

.srv-ex-card:active { transform: translateY(0); }

.sec-ttl { font-size: 0.88rem; font-weight: 700; color: var(--black); }

.sec-tags { display: flex; flex-wrap: wrap; gap: 0.3rem; }

.sec-tags span {
  font-size: 0.62rem; padding: 0.15rem 0.45rem;
  background: var(--bg); border: 1px solid var(--border);
  border-radius: 4px; color: var(--gray);
}

.sec-price {
  font-family: "Unbounded", sans-serif; font-size: 0.78rem;
  font-weight: 700; color: var(--black); margin-top: 0.1rem;
}

@media (max-width: 480px) {
  .srv-ex-grid { grid-template-columns: 1fr 1fr; }
}