/* ==== Tilda embed reset ==== */
html, body { width: 100%; margin: 0; padding: 0; }
* { box-sizing: border-box; }
img { max-width: 100%; height: auto; }
body { overflow-x: hidden; }
/* If page is placed inside Tilda wrapper */
#allrecords, .t-records { overflow-x: hidden; }

@import url('https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700&display=swap');

* {
  margin: 0;
  padding: 0;
  box-sizing: border-box;
}

:root {
  --primary: #8B5CF6;
  --primary-hover: #7C3AED;
  --text-dark: #1F2933;
  --text-gray: #6B7280;
  --bg-light: #F8F9FA;
  --white: #ffffff;
  --border: #E5E7EB;
}

body {
  font-family: 'Inter', sans-serif;
  color: var(--text-dark);
  background: var(--bg-light);
  line-height: 1.6;
  -webkit-font-smoothing: antialiased;
}

.container {
  max-width: 1200px;
  margin: 0 auto;
  padding: 0 16px;
}

img {
  max-width: 100%;
  height: auto;
}

a {
  text-decoration: none;
  color: inherit;
}

/* HERO SECTION */
.hero {
  position: relative;
  min-height: 100vh;
  display: flex;
  align-items: center;
  justify-content: center;
  overflow: hidden;
  background: var(--text-dark);
}

.hero-bg {
  position: absolute;
  inset: 0;
  z-index: 0;
}

.hero-bg img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  opacity: 0.6;
}

.hero-overlay {
  position: absolute;
  inset: 0;
  background: rgba(31, 41, 51, 0.4);
}

.hero-gradient {
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  height: 128px;
  background: linear-gradient(to top, white, transparent);
  z-index: 10;
}

.hero-content {
  position: relative;
  z-index: 10;
  text-align: center;
  max-width: 900px;
  padding: 0 16px;
}

.hero h1 {
  font-size: 2.5rem;
  font-weight: 700;
  line-height: 1.2;
  margin-bottom: 24px;
  color: white;
  text-shadow: 0 2px 10px rgba(0,0,0,0.3);
}

.hero h1 .highlight {
  color: var(--primary);
}

.hero p {
  font-size: 1.125rem;
  color: rgba(255,255,255,0.9);
  margin-bottom: 40px;
  max-width: 640px;
  margin-left: auto;
  margin-right: auto;
  font-weight: 300;
  text-shadow: 0 1px 5px rgba(0,0,0,0.2);
}

.hero-buttons {
  display: flex;
  flex-direction: column;
  gap: 16px;
  max-width: 400px;
  margin: 0 auto;
}

.btn-primary {
  display: inline-block;
  padding: 20px 40px;
  background: var(--primary);
  color: white;
  border-radius: 12px;
  font-weight: 700;
  font-size: 1.125rem;
  transition: all 0.3s;
  border: none;
  cursor: pointer;
  box-shadow: 0 10px 30px rgba(139, 92, 246, 0.3);
}

.btn-primary:hover {
  background: var(--primary-hover);
  transform: translateY(-2px);
}

.btn-secondary {
  display: inline-block;
  padding: 20px 40px;
  background: rgba(255,255,255,0.1);
  backdrop-filter: blur(10px);
  color: white;
  border: 1px solid rgba(255,255,255,0.2);
  border-radius: 12px;
  font-weight: 700;
  font-size: 1.125rem;
  transition: all 0.3s;
  cursor: pointer;
}

.btn-secondary:hover {
  background: rgba(255,255,255,0.2);
}

/* SECTION HEADINGS */
.section-heading {
  text-align: center;
  margin-bottom: 64px;
}

.section-heading h2 {
  font-size: 2.5rem;
  font-weight: 700;
  margin-bottom: 16px;
  color: var(--text-dark);
}

.section-heading h2 .highlight {
  color: var(--primary);
}

.section-heading p {
  font-size: 1.125rem;
  color: var(--text-gray);
  max-width: 600px;
  margin: 0 auto;
}

/* PAIN POINTS SECTION */
.pain-points {
  padding: 96px 0;
  background: white;
}

.pain-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 32px;
  max-width: 1100px;
  margin: 0 auto;
}

.pain-card {
  padding: 32px;
  border-radius: 24px;
  background: var(--bg-light);
  border: 1px solid #F3F4F6;
  transition: all 0.3s;
}

.pain-card:hover {
  background: white;
  border-color: rgba(139, 92, 246, 0.3);
  box-shadow: 0 20px 50px rgba(0,0,0,0.08);
}

.pain-icon {
  width: 56px;
  height: 56px;
  border-radius: 16px;
  background: rgba(139, 92, 246, 0.1);
  display: flex;
  align-items: center;
  justify-content: center;
  margin-bottom: 24px;
  color: var(--primary);
  font-size: 24px;
}

.pain-card h3 {
  font-size: 1.25rem;
  font-weight: 700;
  margin-bottom: 12px;
  color: var(--text-dark);
}

.pain-card p {
  color: var(--text-gray);
  line-height: 1.6;
}

.pain-cta {
  text-align: center;
  margin-top: 64px;
  max-width: 640px;
  margin-left: auto;
  margin-right: auto;
}

.pain-cta p {
  font-size: 1.25rem;
  color: var(--text-dark);
  margin-bottom: 32px;
  font-weight: 500;
}

/* EXPERTISE SECTION */
.expertise {
  padding: 96px 0;
  background: var(--text-dark);
  color: white;
  position: relative;
  overflow: hidden;
}

.expertise-gradient {
  position: absolute;
  top: 0;
  right: 0;
  width: 50%;
  height: 100%;
  background: linear-gradient(to left, rgba(139, 92, 246, 0.05), transparent);
  pointer-events: none;
}

.expertise-content {
  position: relative;
  z-index: 10;
  max-width: 900px;
  margin: 0 auto;
  text-align: center;
}

.expertise h2 {
  font-size: 2.5rem;
  font-weight: 700;
  margin-bottom: 48px;
}

.expertise-photo {
  position: relative;
  max-width: 400px;
  margin: 0 auto 48px;
}

.expertise-photo img {
  width: 100%;
  aspect-ratio: 4/5;
  object-fit: cover;
  border-radius: 24px;
  box-shadow: 0 25px 50px rgba(0,0,0,0.3);
  border: 1px solid rgba(255,255,255,0.1);
  position: relative;
  z-index: 10;
}

.expertise-photo-border {
  position: absolute;
  bottom: -24px;
  right: -24px;
  width: 100%;
  height: 100%;
  border: 2px solid rgba(139, 92, 246, 0.3);
  border-radius: 24px;
  z-index: 0;
}

.expertise-photo-blur {
  position: absolute;
  top: -24px;
  left: -24px;
  width: 128px;
  height: 128px;
  background: rgba(139, 92, 246, 0.2);
  border-radius: 50%;
  filter: blur(40px);
}

.expertise-text {
  text-align: left;
  max-width: 700px;
  margin: 0 auto;
}

.expertise-text p {
  font-size: 1.125rem;
  color: #D1D5DB;
  line-height: 1.8;
  margin-bottom: 24px;
}

/* COURSES SECTION */
.courses {
  padding: 96px 0;
  background: white;
}

.courses-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 32px;
  max-width: 1400px;
  margin: 0 auto;
}

.course-card {
  background: white;
  border-radius: 32px;
  overflow: hidden;
  box-shadow: 0 20px 50px rgba(0,0,0,0.08);
  border: 1px solid #F3F4F6;
  display: flex;
  flex-direction: column;
  transition: all 0.3s;
}

.course-card:hover {
  border-color: rgba(139, 92, 246, 0.3);
}

.course-card.featured {
  border-color: rgba(139, 92, 246, 0.2);
  box-shadow: 0 20px 50px rgba(139, 92, 246, 0.1), 0 0 0 4px rgba(139, 92, 246, 0.05);
}

.course-image {
  position: relative;
  aspect-ratio: 16/9;
  overflow: hidden;
}

.course-image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform 0.5s;
}

.course-card:hover .course-image img {
  transform: scale(1.05);
}

.course-badge {
  position: absolute;
  top: 16px;
  right: 16px;
  background: var(--primary);
  color: white;
  padding: 4px 16px;
  border-radius: 50px;
  font-size: 0.875rem;
  font-weight: 700;
  box-shadow: 0 5px 15px rgba(0,0,0,0.2);
}

.course-content {
  padding: 32px;
  flex: 1;
  display: flex;
  flex-direction: column;
}

.course-tags {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-bottom: 24px;
}

.course-tag {
  padding: 4px 12px;
  border-radius: 50px;
  font-size: 0.75rem;
  font-weight: 500;
}

.course-tag.gray {
  background: #F3F4F6;
  color: var(--text-gray);
}

.course-tag.purple {
  background: rgba(139, 92, 246, 0.1);
  color: var(--primary);
}

.course-card h3 {
  font-size: 1.5rem;
  font-weight: 700;
  margin-bottom: 16px;
  color: var(--text-dark);
}

.course-subtitle {
  font-weight: 700;
  color: var(--text-dark);
  font-size: 0.875rem;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  text-align: center;
  background: var(--bg-light);
  padding: 8px;
  border-radius: 8px;
  margin-bottom: 16px;
}

.course-subtitle.purple {
  background: rgba(139, 92, 246, 0.05);
}

.course-features {
  flex: 1;
  margin-bottom: 32px;
}

.course-feature {
  display: flex;
  align-items: flex-start;
  gap: 12px;
  color: var(--text-gray);
  font-size: 0.875rem;
  margin-bottom: 16px;
}

.course-feature .check {
  width: 16px;
  height: 16px;
  color: var(--primary);
  flex-shrink: 0;
  margin-top: 2px;
}

.course-footer {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding-top: 24px;
  border-top: 1px solid #F3F4F6;
  margin-top: auto;
}

.course-price .old-price {
  font-size: 0.875rem;
  color: #9CA3AF;
  text-decoration: line-through;
}

.course-price .new-price {
  font-size: 1.5rem;
  font-weight: 700;
  color: var(--text-dark);
}

.btn-course {
  padding: 12px 24px;
  background: var(--primary);
  color: white;
  border-radius: 12px;
  font-weight: 700;
  transition: all 0.3s;
  border: none;
  cursor: pointer;
  box-shadow: 0 5px 20px rgba(139, 92, 246, 0.3);
}

.btn-course:hover {
  background: var(--primary-hover);
}

/* PORTFOLIO SECTION */
.portfolio {
  padding: 96px 0;
  background: white;
  overflow: hidden;
}

.portfolio-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 16px;
  max-width: 1100px;
  margin: 0 auto;
}

.portfolio-item {
  border-radius: 16px;
  overflow: hidden;
  box-shadow: 0 10px 30px rgba(0,0,0,0.1);
  aspect-ratio: 4/5;
}

.portfolio-item img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform 0.5s;
}

.portfolio-item:hover img {
  transform: scale(1.05);
}

/* REVIEWS SECTION */
.reviews {
  padding: 96px 0;
  background: var(--bg-light);
}

.reviews-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 48px;
  max-width: 1200px;
  margin: 0 auto;
}

.review-card {
  display: flex;
  flex-direction: column;
  align-items: center;
}

.review-title {
  text-align: center;
  margin-bottom: 32px;
}

.review-title h3 {
  font-size: 1.25rem;
  font-weight: 700;
  font-style: italic;
  color: var(--primary);
  margin-bottom: 16px;
}

.review-title-line {
  width: 64px;
  height: 4px;
  background: var(--primary);
  border-radius: 50px;
  opacity: 0.3;
  margin: 0 auto;
}

.review-image {
  border-radius: 40px;
  overflow: hidden;
  box-shadow: 0 25px 50px rgba(0,0,0,0.15);
  border: 1px solid #F3F4F6;
  aspect-ratio: 9/16;
  width: 100%;
  background: white;
  transition: all 0.5s;
}

.review-image:hover {
  transform: scale(1.02);
  box-shadow: 0 25px 50px rgba(139, 92, 246, 0.2);
}

.review-image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

/* FAQ SECTION */
.faq {
  padding: 96px 0;
  background: white;
}

.faq-list {
  max-width: 768px;
  margin: 0 auto;
}

.faq-item {
  border-bottom: 1px solid #E5E7EB;
}

.faq-question {
  width: 100%;
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 24px 0;
  background: none;
  border: none;
  cursor: pointer;
  text-align: left;
  font-size: 1.125rem;
  font-weight: 500;
  color: var(--text-dark);
  transition: color 0.3s;
}

.faq-question:hover {
  color: var(--primary);
}

.faq-question .arrow {
  width: 24px;
  height: 24px;
  transition: transform 0.3s;
}

.faq-item.open .faq-question .arrow {
  transform: rotate(180deg);
}

.faq-answer {
  padding-bottom: 24px;
  color: var(--text-gray);
  font-size: 1rem;
  line-height: 1.7;
  display: none;
}

.faq-item.open .faq-answer {
  display: block;
}

/* CONTACT SECTION */
.contact {
  padding: 96px 0;
  background: #111827;
  color: white;
  position: relative;
  overflow: hidden;
}

.contact-bg {
  position: absolute;
  inset: 0;
  background-image: url('https://images.unsplash.com/photo-1604654894610-df63bc536371?auto=format&fit=crop&q=80');
  background-size: cover;
  background-position: center;
  opacity: 0.1;
}

.contact-content {
  position: relative;
  z-index: 10;
  display: grid;
  grid-template-columns: 1fr;
  gap: 48px;
  max-width: 1100px;
  margin: 0 auto;
}

.contact-info h2 {
  font-size: 2.5rem;
  font-weight: 700;
  margin-bottom: 24px;
}

.contact-info h2 .highlight {
  color: var(--primary);
}

.contact-info > p {
  font-size: 1.25rem;
  color: #D1D5DB;
  margin-bottom: 32px;
}

.contact-features {
  display: flex;
  flex-direction: column;
  gap: 24px;
}

.contact-feature {
  display: flex;
  align-items: center;
  gap: 16px;
}

.contact-feature-icon {
  width: 48px;
  height: 48px;
  border-radius: 50%;
  background: rgba(139, 92, 246, 0.2);
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--primary);
}

.contact-feature h4 {
  font-weight: 700;
  font-size: 1.125rem;
  margin-bottom: 4px;
}

.contact-feature p {
  color: #9CA3AF;
  font-size: 0.875rem;
}

/* FORM */
.contact-form {
  background: rgba(255,255,255,0.05);
  backdrop-filter: blur(10px);
  border: 1px solid rgba(255,255,255,0.1);
  border-radius: 24px;
  padding: 32px;
}

.form-group {
  margin-bottom: 20px;
}

.form-group label {
  display: block;
  font-weight: 500;
  margin-bottom: 8px;
  color: white;
}

.form-group input,
.form-group select {
  width: 100%;
  padding: 16px;
  border-radius: 12px;
  border: 1px solid rgba(255,255,255,0.2);
  background: rgba(255,255,255,0.1);
  color: white;
  font-size: 1rem;
  transition: all 0.3s;
}

.form-group input::placeholder {
  color: rgba(255,255,255,0.5);
}

.form-group input:focus,
.form-group select:focus {
  outline: none;
  border-color: var(--primary);
  box-shadow: 0 0 0 3px rgba(139, 92, 246, 0.2);
}

.form-group select option {
  background: #1F2937;
  color: white;
}

.btn-submit {
  width: 100%;
  padding: 16px;
  background: var(--primary);
  color: white;
  border: none;
  border-radius: 12px;
  font-size: 1.125rem;
  font-weight: 700;
  cursor: pointer;
  transition: all 0.3s;
  box-shadow: 0 10px 30px rgba(139, 92, 246, 0.3);
}

.btn-submit:hover {
  background: var(--primary-hover);
  transform: translateY(-2px);
}

/* FOOTER */
.footer {
  background: #121b31;
  color: white;
  padding: 48px 0;
  border-top: 1px solid rgba(255,255,255,0.1);
}

.footer-content {
  display: flex;
  flex-direction: column;
  gap: 48px;
  max-width: 1100px;
  margin: 0 auto;
  text-align: center;
}

.footer-info h3 {
  font-size: 1.5rem;
  font-weight: 700;
  margin-bottom: 8px;
}

.footer-info > p {
  color: #9CA3AF;
  margin-bottom: 16px;
}

.footer-address {
  font-size: 0.875rem;
  color: #6B7280;
}

.footer-address p {
  margin-bottom: 4px;
}

.footer-links {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 16px;
}

.footer-social {
  display: flex;
  gap: 24px;
}

.footer-social a {
  color: white;
  transition: color 0.3s;
}

.footer-social a:hover {
  color: var(--primary);
}

.footer-handle {
  font-size: 0.875rem;
  font-weight: 700;
  color: var(--primary);
}

.footer-bottom {
  padding-top: 32px;
  margin-top: 32px;
  border-top: 1px solid rgba(255,255,255,0.1);
  text-align: center;
  color: #6B7280;
  font-size: 0.875rem;
}

/* RESPONSIVE */
@media (min-width: 640px) {
  .hero h1 {
    font-size: 3.5rem;
  }
  
  .hero p {
    font-size: 1.25rem;
  }
  
  .hero-buttons {
    flex-direction: row;
    justify-content: center;
  }
  
  .section-heading h2 {
    font-size: 3rem;
  }
}

@media (min-width: 768px) {
  .pain-grid {
    grid-template-columns: repeat(2, 1fr);
  }
  
  .portfolio-grid {
    grid-template-columns: repeat(3, 1fr);
  }
  
  .reviews-grid {
    grid-template-columns: repeat(2, 1fr);
  }
  
  .contact-content {
    grid-template-columns: 1fr 1fr;
    align-items: center;
  }
  
  .footer-content {
    flex-direction: row;
    justify-content: space-between;
    text-align: left;
  }
  
  .footer-links {
    align-items: flex-end;
  }
}

@media (min-width: 1024px) {
  .hero h1 {
    font-size: 4.5rem;
  }
  
  .pain-grid {
    grid-template-columns: repeat(3, 1fr);
  }
  
  .courses-grid {
    grid-template-columns: repeat(3, 1fr);
  }
  
  .portfolio-grid {
    grid-template-columns: repeat(4, 1fr);
  }
  
  .reviews-grid {
    grid-template-columns: repeat(3, 1fr);
  }
}



/* ==== Reviews text additions ==== */
.review-label{
  text-align:center;
  color: rgba(124,92,255,.95);
  font-weight: 700;
  font-size: 14px;
  margin: 0 0 10px;
}
.reviews-footer{
  text-align:center;
  margin-top: 22px;
  font-size: 14px;
  line-height: 1.35;
  color: rgba(233,236,255,.72);
}
.reviews-footer strong{color: rgba(233,236,255,.92)}

/* Make reviews show 3 on desktop */
.review-slide{min-width:100%}
@media (min-width: 980px){
  .review-slide{min-width:33.3333%}
}

/* Small nav positioning on mobile */
@media (max-width: 520px){
  .reviews-nav.prev{left:-4px}
  .reviews-nav.next{right:-4px}
}


/* ==== Contact features (left) ==== */
.contact-features{margin-top:26px;display:grid;gap:14px}
.contact-feature{display:flex;gap:14px;align-items:flex-start}
.contact-feature-icon{
  width:40px;height:40px;border-radius:999px;
  background:rgba(124,92,255,.16);
  border:1px solid rgba(124,92,255,.28);
  display:flex;align-items:center;justify-content:center;
  flex:0 0 auto;
  color: rgba(124,92,255,.95);
}
.contact-feature h4{margin:0 0 2px;font-size:16px;color:rgba(255,255,255,.92)}
.contact-feature p{margin:0;font-size:13px;color:rgba(255,255,255,.68);line-height:1.35}


/* ==== Contact: strict left text / right form (desktop) ==== */
.contact-content{
  display:flex !important;
  align-items:center !important;
  justify-content:space-between;
  gap: 70px;
}
.contact-info{flex:1 1 640px; max-width:700px}
.contact-form{flex:0 0 520px; max-width:520px; margin-left:auto}
@media (max-width: 980px){
  .contact-content{display:block !important}
  .contact-form{max-width:560px; margin:22px auto 0}
}


/* ==== Carousel (FINAL) ==== */
.carousel{
  display:grid;
  grid-template-columns: 56px 1fr 56px;
  gap: 18px;
  align-items:center;
  margin-top: 26px;
}
@media (max-width: 640px){
  .carousel{grid-template-columns: 48px 1fr 48px; gap: 12px;}
}

.carousel-viewport{
  overflow-x:auto !important;
  overflow-y:hidden !important;
  scroll-snap-type:x mandatory;
  scroll-behavior:smooth;
  -webkit-overflow-scrolling: touch;
  scrollbar-width:none;
  position:relative;
  z-index:1;
}
.carousel-viewport::-webkit-scrollbar{display:none}

.carousel-track{
  display:flex;
  gap: 24px;              /* расстояние между фото */
  padding: 6px 2px;       /* чтобы тени не обрезались */
}

.carousel-slide{
  scroll-snap-align:start;
  flex: 0 0 100%;
}

/* Portfolio: 1/2/4 */
.portfolio-carousel .portfolio-slide{border-radius:18px; overflow:hidden; aspect-ratio: 3 / 4}
.portfolio-carousel .portfolio-slide img{display:block;width:100%;height:100%;object-fit:cover;border-radius:18px}
@media (min-width: 700px){
  .portfolio-carousel .portfolio-slide{flex-basis: calc((100% - 24px) / 2);}
}
@media (min-width: 980px){
  .portfolio-carousel .portfolio-slide{flex-basis: calc((100% - 24px*3) / 4);}
}

/* Reviews: 1 / 3 */
.reviews-carousel .review-slide{flex-basis: 100%;}
@media (min-width: 980px){
  .reviews-carousel .review-slide{flex-basis: calc((100% - 24px*2) / 3);}
}
.reviews-carousel .review-card img{width:100%;height:100%;object-fit:cover;border-radius:18px;display:block}

.review-label{
  text-align:center;
  color:#7c5cff;
  font-weight:700;
  font-size:14px;
  margin: 0 0 10px;
}

.reviews{background:#fff;color:#111}
.reviews .section-heading p{color:rgba(0,0,0,.55)}
.reviews-footer{
  text-align:center;
  margin-top: 22px;
  font-size: 14px;
  line-height: 1.35;
  color: rgba(0,0,0,.55);
}
.reviews-footer strong{color: rgba(0,0,0,.78);}

/* Arrows: premium, never overlap photos */
.carousel-arrow{
  position: relative;
  width:46px;height:46px;border-radius:999px;
  border:1px solid rgba(124,92,255,.35);
  background:#fff;
  box-shadow:0 10px 30px rgba(0,0,0,.12);
  cursor:pointer;
  display:flex;
  align-items:center;
  justify-content:center;
  color: rgba(124,92,255,.95);
  z-index:10;
  pointer-events:auto;
}
.carousel-arrow:hover{box-shadow:0 12px 34px rgba(0,0,0,.16)}
.carousel-arrow:active{transform:translateY(1px)}
.arrow-ic{width:18px;height:18px;display:block}

/* ==== Contact: hard fix for Tilda ==== */
.contact-content{
  display:flex !important;
  flex-wrap:nowrap !important;
  align-items:flex-start !important;
  justify-content:space-between !important;
  gap: 70px !important;
}
.contact-info{flex:1 1 640px; max-width:720px !important}
.contact-form{flex:0 0 520px !important; max-width:520px !important; margin-left:auto !important}
@media (max-width: 980px){
  .contact-content{display:block !important}
  .contact-form{max-width:560px !important; margin:22px auto 0 !important}
}

/* ===== FIX: Portfolio slides should NOT stretch to full screen on mobile ===== */
/* (Overrides the generic .carousel-slide { flex:0 0 100%; } only for portfolio) */
.portfolio-carousel .carousel-slide{
  flex: 0 0 320px;
  max-width: 320px;
}

@media (max-width: 1024px){
  .portfolio-carousel .carousel-slide{
    flex-basis: 300px;
    max-width: 300px;
  }
}

@media (max-width: 520px){
  .portfolio-carousel .carousel-slide{
    flex: 0 0 78vw;     /* ~1 карточка, но не на весь экран */
    max-width: 340px;   /* ограничение, чтобы не распухало */
  }
}

/* Optional: чуть меньше gap на мобилке */
@media (max-width: 520px){
  .portfolio-carousel .carousel-track{ gap: 14px; }
}

/* ===== Footer (final layout like mock) ===== */
.site-footer{
  background: linear-gradient(180deg, rgba(17,24,39,.92) 0%, rgba(15,23,42,1) 100%);
  color: rgba(255,255,255,.92);
  padding: 34px 0 22px;
}

.site-footer__top{
  display: grid;
  grid-template-columns: 1.35fr 1fr 1fr;
  gap: 36px;
  align-items: start;
}

.site-footer__title{
  font-weight: 800;
  letter-spacing: .06em;
  text-transform: uppercase;
  font-size: 18px;
  margin-bottom: 10px;
}

.site-footer__subtitle{
  font-weight: 700;
  font-size: 18px;
  margin-bottom: 14px;
}

.site-footer__text{
  color: rgba(255,255,255,.72);
  margin-bottom: 16px;
}

.site-footer__muted{
  color: rgba(255,255,255,.55);
  font-size: 14px;
  line-height: 1.45;
  margin-bottom: 14px;
}

.site-footer__link{
  color: rgba(255,255,255,.65);
  text-decoration: none;
  font-weight: 600;
  font-size: 14px;
}

.site-footer__link:hover{ color: rgba(255,255,255,.92); }

.site-footer__row{
  display: flex;
  align-items: center;
  gap: 14px;
  flex-wrap: wrap;
}

.sf-ic{
  width: 40px;
  height: 40px;
  border-radius: 999px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border: 1px solid rgba(139,92,246,.35);
  color: rgba(255,255,255,.92);
  background: rgba(139,92,246,.12);
  text-decoration: none;
}

.sf-ic svg{ width: 20px; height: 20px; }

.site-footer__phone{
  color: rgba(255,255,255,.92);
  text-decoration: none;
  font-weight: 700;
  font-size: 16px;
  letter-spacing: .02em;
}

.site-footer__handle{
  font-weight: 700;
  color: rgba(255,255,255,.9);
}

.site-footer__divider{
  margin-top: 26px;
  height: 1px;
  background: rgba(255,255,255,.08);
}

.site-footer__bottom{
  text-align: center;
  margin-top: 16px;
  color: rgba(255,255,255,.55);
  font-size: 13px;
}

/* Responsive */
@media (max-width: 980px){
  .site-footer__top{
    grid-template-columns: 1fr;
    gap: 22px;
  }
}



/* ===== Privacy popup (checkbox, no JS) ===== */
.privacy-toggle{position:absolute;left:-9999px;top:auto;width:1px;height:1px;overflow:hidden;}
.privacy-popup{
  position:fixed; inset:0;
  z-index:999999;
  display:flex;
  align-items:center;
  justify-content:center;
  padding:16px;
  opacity:0;
  visibility:hidden;
  pointer-events:none;
  transition:opacity .2s ease, visibility .2s ease;
}
.privacy-popup__overlay{
  position:absolute; inset:0;
  background:rgba(0,0,0,.65);
  cursor:pointer;
}
.privacy-popup__panel{
  position:relative;
  width:min(920px, 100%);
  max-height:92vh;
  background:#0f172a;
  border:1px solid rgba(255,255,255,.12);
  border-radius:18px;
  box-shadow:0 30px 80px rgba(0,0,0,.45);
  overflow:hidden;
}
.privacy-popup__head{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:16px;
  padding:16px 18px;
  background:rgba(255,255,255,.04);
  border-bottom:1px solid rgba(255,255,255,.08);
}
.privacy-popup__title{
  font-weight:800;
  color:rgba(255,255,255,.95);
  font-size:18px;
}
.privacy-popup__close{
  width:34px;height:34px;border-radius:10px;
  display:flex;align-items:center;justify-content:center;
  cursor:pointer;
  background:rgba(124,92,255,.18);
  border:1px solid rgba(124,92,255,.35);
  color:#fff;
  font-size:18px;
  user-select:none;
}
.privacy-popup__body{
  padding:16px 18px;
  max-height:calc(92vh - 64px);
  overflow:auto;
}
.privacy-text{
  margin:0;
  white-space:pre-wrap;
  font-family: 'Inter', system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
  font-size:13px;
  line-height:1.45;
  color:rgba(255,255,255,.86);
}

/* show popup */
.privacy-toggle:checked + .privacy-popup{
  opacity:1;
  visibility:visible;
  pointer-events:auto;
}

/* ===== MAX icon (in your style) ===== */
.sf-ic--max{
  background: linear-gradient(135deg, #2d8cff 0%, #7c5cff 55%, #ff4fd8 100%) !important;
  color:#fff !important;
  border-color: rgba(255,255,255,.0) !important;
}
.sf-ic--max svg{width:22px;height:22px;display:block}

/* ===== Portfolio footer align fix ===== */
.portfolio-footer{
  text-align:center;
  margin-top:32px;
  padding: 0 16px;
  color: rgba(0,0,0,.55);
  font-size:14px;
  line-height:1.35;
}
.portfolio-footer strong{color: rgba(0,0,0,.78);}


/* ===== Сделать иконки в футере как на примере (без кружков) ===== */
.site-footer .site-footer__row{
  display:flex;
  align-items:center;
  gap:14px;
  flex-wrap:nowrap;
}

.site-footer .sf-ic{
  width:auto !important;
  height:auto !important;
  border:none !important;
  background:transparent !important;
  border-radius:0 !important;
  padding:0 !important;
  box-shadow:none !important;
  display:inline-flex !important;
  align-items:center;
  justify-content:center;
  color: rgba(255,255,255,.92);
  transition: opacity .2s ease;
}

.site-footer .sf-ic:hover{
  opacity:.75;
  transform:none !important;
}

.site-footer .sf-ic svg{
  width:24px;
  height:24px;
  display:block;
}

.site-footer__phone,
.site-footer__handle{
  white-space:nowrap;
}