/* ===================== SAMYLITA - COSMIC LUXURY ===================== */
:root{
  --bg:#05060e;
  --bg-soft:#0a0d1d;
  --panel:rgba(16,20,38,.62);
  --panel-solid:#0e1226;
  --ink:#f6f3ea;
  --muted:#bcc1d6;
  --muted-2:#8f96b3;
  --gold:#e3c373;
  --gold-2:#f4e3ab;
  --gold-deep:#b8923f;
  --line:rgba(227,195,115,.22);
  --line-soft:rgba(255,255,255,.08);
  --radius:18px;
  --maxw:1120px;
  --shadow:0 24px 60px rgba(0,0,0,.45);
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  background:var(--bg);
  color:var(--ink);
  font-family:"Be Vietnam Pro",system-ui,Segoe UI,Roboto,sans-serif;
  font-weight:300;
  line-height:1.68;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}

/* ---------- Nền vũ trụ ---------- */
#cosmos{
  position:fixed; inset:0;
  width:100%; height:100%;
  z-index:0; pointer-events:none;
  display:block;
}
.cosmos-veil{
  position:fixed; inset:0; z-index:1; pointer-events:none;
  background:
    radial-gradient(120% 80% at 50% -10%, rgba(227,195,115,.08), transparent 60%),
    linear-gradient(180deg, rgba(5,6,14,.35) 0%, rgba(5,6,14,.62) 45%, rgba(5,6,14,.82) 100%);
}
body > *:not(#cosmos):not(.cosmos-veil){position:relative; z-index:2}

/* ---------- Layout ---------- */
.wrap{width:100%; max-width:var(--maxw); margin:0 auto; padding:0 22px}
.section{padding:74px 0}
.section-title{
  font-family:"Cormorant Garamond",Georgia,serif;
  font-weight:700;
  font-size:36px; line-height:1.18;
  margin:0 0 14px;
  letter-spacing:.2px;
}
.section-intro{color:var(--muted); max-width:680px; margin:0 0 30px}
.kicker{
  font-size:15px; letter-spacing:3px; text-transform:uppercase;
  color:var(--gold); margin:0 0 10px; font-weight:600;
}

/* ---------- Nút ---------- */
.btn-solid,.btn-ghost{
  display:inline-flex; align-items:center; justify-content:center;
  gap:.4em; text-decoration:none; cursor:pointer;
  font-weight:600; font-size:18px; letter-spacing:.3px;
  padding:13px 24px; border-radius:999px; border:1px solid transparent;
  transition:transform .15s ease, box-shadow .25s ease, background .25s ease;
  text-align:center;
}
.btn-solid{
  color:#1a1405;
  background:linear-gradient(135deg,var(--gold-2),var(--gold) 55%,var(--gold-deep));
  box-shadow:0 10px 26px rgba(227,195,115,.28);
}
.btn-solid:hover{transform:translateY(-2px); box-shadow:0 16px 34px rgba(227,195,115,.4)}
.btn-ghost{
  color:var(--gold-2);
  background:rgba(227,195,115,.06);
  border-color:var(--line);
  backdrop-filter:blur(4px);
}
.btn-ghost:hover{background:rgba(227,195,115,.13); transform:translateY(-2px)}
.btn-lg{padding:16px 30px; font-size:19px}
.btn-sm{padding:9px 16px; font-size:16px}
.btn-block{width:100%; margin-top:6px; padding:15px 24px; font-size:19px}

/* ---------- Header ---------- */
.site-header{
  position:sticky; top:0; z-index:30;
  background:rgba(5,6,14,.55);
  backdrop-filter:blur(10px);
  border-bottom:1px solid var(--line-soft);
}
.header-inner{display:flex; align-items:center; justify-content:space-between; height:64px}
.brand{display:flex; align-items:center; gap:11px; text-decoration:none; color:var(--ink)}
.brand-mark{
  width:34px; height:34px; border-radius:50%; flex:0 0 auto; position:relative;
  background:radial-gradient(circle at 50% 50%, var(--gold-2), var(--gold-deep));
  box-shadow:0 0 16px rgba(227,195,115,.5);
}
.brand-mark::after{
  content:""; position:absolute; inset:-7px; border-radius:50%;
  border:1px solid var(--line);
}
.brand-text{display:flex; flex-direction:column; line-height:1.1}
.brand-name{font-family:"Cormorant Garamond",serif; font-weight:700; font-size:27.5px; letter-spacing:1px}
.brand-tag{font-size:12.5px; color:var(--muted-2); letter-spacing:1px}
.header-actions{display:flex; align-items:center; gap:10px}
.btn-call{display:none}

/* ---------- Hero ---------- */
.hero{position:relative; padding:64px 0 78px; text-align:center}
.hero-inner{max-width:780px; margin:0 auto}
.eyebrow{
  display:inline-block; font-size:14.5px; letter-spacing:2.5px; text-transform:uppercase;
  color:var(--gold); border:1px solid var(--line); border-radius:999px;
  padding:7px 16px; margin:0 0 22px; background:rgba(227,195,115,.05);
}
.hero h1{
  font-family:"Cormorant Garamond",Georgia,serif;
  font-weight:700; font-size:45.5px; line-height:1.14;
  margin:0 0 20px; letter-spacing:.3px;
  text-shadow:0 2px 30px rgba(0,0,0,.5);
}
.hero .lead{font-size:20.5px; color:var(--muted); max-width:640px; margin:0 auto 30px}
.hero-cta{display:flex; flex-direction:column; gap:12px; align-items:center; margin-bottom:34px}
.hero-cta a{width:100%; max-width:330px}

.trust-row{
  list-style:none; margin:0; padding:0;
  display:grid; grid-template-columns:repeat(2,1fr); gap:12px;
  max-width:560px; margin:0 auto;
}
.trust-row li{
  background:var(--panel); border:1px solid var(--line-soft);
  border-radius:14px; padding:14px 12px; backdrop-filter:blur(6px);
  display:flex; flex-direction:column; gap:3px;
}
.trust-row strong{color:var(--gold-2); font-family:"Cormorant Garamond",serif; font-size:23px; font-weight:600}
.trust-row span{font-size:15px; color:var(--muted-2); line-height:1.4}

.scroll-hint{display:flex; justify-content:center; margin-top:42px}
.scroll-hint span{
  width:22px; height:34px; border:1px solid var(--line); border-radius:14px; position:relative;
}
.scroll-hint span::after{
  content:""; position:absolute; left:50%; top:7px; width:3px; height:7px; border-radius:2px;
  background:var(--gold); transform:translateX(-50%); animation:scrollDot 1.8s ease-in-out infinite;
}
@keyframes scrollDot{0%{opacity:0; transform:translate(-50%,0)}40%{opacity:1}80%{opacity:0; transform:translate(-50%,10px)}100%{opacity:0}}

/* ---------- Vấn đề ---------- */
.pain-grid{display:grid; grid-template-columns:1fr; gap:16px; margin-top:8px}
.pain-card{
  background:var(--panel); border:1px solid var(--line-soft); border-radius:var(--radius);
  padding:24px 22px; backdrop-filter:blur(6px); position:relative;
}
.pain-dot{
  display:inline-block; width:30px; height:30px; border-radius:50%; margin-bottom:12px;
  background:radial-gradient(circle at 40% 35%, #ff9d7a, #b8453a);
  box-shadow:0 0 18px rgba(184,69,58,.5);
}
.pain-card h3{font-family:"Cormorant Garamond",serif; font-weight:600; font-size:25px; margin:0 0 8px}
.pain-card p{margin:0; color:var(--muted); font-size:18px}
.problem-philo{
  margin:30px auto 0; max-width:680px; text-align:center;
  font-family:"Cormorant Garamond",serif; font-style:italic; font-size:27.5px; line-height:1.4;
  color:var(--gold-2);
}

/* ---------- Người dẫn đường ---------- */
.guide-inner{display:grid; grid-template-columns:1fr; gap:30px}
.guide-copy p{color:var(--muted); font-size:19px; margin:0 0 22px}
.authority{list-style:none; margin:0; padding:0; display:grid; gap:14px}
.authority li{
  background:var(--panel); border:1px solid var(--line-soft); border-left:2px solid var(--gold);
  border-radius:14px; padding:16px 18px; backdrop-filter:blur(6px);
  display:flex; flex-direction:column; gap:5px;
}
.authority strong{color:var(--ink); font-size:18.5px; font-weight:600}
.authority span{color:var(--muted-2); font-size:17px}
.map-btn{margin-top:4px}

/* ---------- Kế hoạch ---------- */
.step-list{list-style:none; margin:8px 0 0; padding:0; display:grid; gap:18px}
.step-list li{
  background:var(--panel); border:1px solid var(--line-soft); border-radius:var(--radius);
  padding:24px 22px 22px; backdrop-filter:blur(6px); position:relative;
}
.step-num{
  display:inline-flex; align-items:center; justify-content:center;
  width:42px; height:42px; border-radius:50%; margin-bottom:12px;
  font-family:"Cormorant Garamond",serif; font-weight:700; font-size:25px; color:#1a1405;
  background:linear-gradient(135deg,var(--gold-2),var(--gold-deep));
  box-shadow:0 0 18px rgba(227,195,115,.35);
}
.step-list h3{font-family:"Cormorant Garamond",serif; font-weight:600; font-size:25px; margin:0 0 6px}
.step-list p{margin:0; color:var(--muted); font-size:18px}

/* ---------- Phiếu tư vấn ---------- */
.form-section{padding:70px 0}
.form-card{
  background:linear-gradient(180deg,rgba(20,24,46,.85),rgba(10,13,29,.92));
  border:1px solid var(--line); border-radius:24px; padding:30px 24px;
  display:grid; grid-template-columns:1fr; gap:26px;
  box-shadow:var(--shadow); backdrop-filter:blur(8px);
}
.form-copy h2{font-family:"Cormorant Garamond",serif; font-weight:700; font-size:32.5px; margin:0 0 10px}
.form-copy > p{color:var(--muted); margin:0 0 14px}
.form-perks{list-style:none; margin:0 0 16px; padding:0; display:grid; gap:11px}
.form-perks li{position:relative; padding-left:30px; color:var(--ink); font-size:18px}
.form-perks li::before{
  content:""; position:absolute; left:0; top:7px; width:16px; height:16px; border-radius:50%;
  background:radial-gradient(circle at 40% 35%,var(--gold-2),var(--gold-deep));
  box-shadow:0 0 10px rgba(227,195,115,.5);
}
.form-reassure{color:var(--muted-2); font-size:16px; margin:0}

.lead-form{display:grid; gap:14px}
.lead-form label{display:flex; flex-direction:column; gap:6px; font-size:16px; color:var(--muted)}
.lead-form label em{color:var(--muted-2); font-style:normal}
.lead-form input,.lead-form select{
  width:100%; padding:13px 14px; border-radius:12px;
  background:rgba(5,6,14,.55); color:var(--ink);
  border:1px solid var(--line-soft); font:inherit; font-size:18px; font-weight:400;
  transition:border-color .2s ease, box-shadow .2s ease;
}
.lead-form input::placeholder{color:#6c7390}
.lead-form input:focus,.lead-form select:focus{
  outline:none; border-color:var(--gold);
  box-shadow:0 0 0 3px rgba(227,195,115,.18);
}
.lead-form .invalid{border-color:#e0796b; box-shadow:0 0 0 3px rgba(224,121,107,.18)}
.lead-form select{appearance:none; background-image:
  url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%23e3c373' stroke-width='1.6' fill='none'/%3E%3C/svg%3E");
  background-repeat:no-repeat; background-position:right 14px center; padding-right:36px}
.form-msg{margin:4px 0 0; font-size:17px; min-height:1px}
.form-msg.ok{color:var(--gold-2)}
.form-msg.err{color:#f0a99c}
.form-msg a{color:var(--gold-2); font-weight:600}

/* ---------- Hai ngã rẽ ---------- */
.stakes-grid{display:grid; grid-template-columns:1fr; gap:16px; margin-top:8px}
.stakes-card{border-radius:var(--radius); padding:24px 22px; border:1px solid var(--line-soft); backdrop-filter:blur(6px)}
.stakes-card h3{font-family:"Cormorant Garamond",serif; font-weight:600; font-size:25px; margin:0 0 14px}
.stakes-card ul{margin:0; padding:0; list-style:none; display:grid; gap:9px}
.stakes-card li{position:relative; padding-left:26px; font-size:18px; color:var(--muted)}
.stakes-card li::before{position:absolute; left:0; top:0; font-size:18px}
.stakes-card.fail{background:rgba(40,18,18,.5)}
.stakes-card.fail li::before{content:"\2715"; color:#e0796b}
.stakes-card.win{background:rgba(18,30,24,.5); border-color:var(--line)}
.stakes-card.win li::before{content:"\2713"; color:var(--gold-2)}

/* ---------- Bằng chứng ---------- */
.proof-inner{
  text-align:center; max-width:680px; margin:0 auto;
  background:var(--panel); border:1px solid var(--line); border-radius:24px;
  padding:40px 26px; backdrop-filter:blur(8px); box-shadow:var(--shadow);
}
.proof-stars{color:var(--gold); font-size:36px; letter-spacing:6px; margin-bottom:8px}
.proof-big{font-family:"Cormorant Garamond",serif; font-weight:700; font-size:33.5px; margin:0 0 12px}
.proof-sub{color:var(--muted); margin:0 0 24px}

/* ---------- FAQ ---------- */
.faq-list{display:grid; gap:12px; max-width:760px; margin:8px auto 0}
.faq-list details{
  background:var(--panel); border:1px solid var(--line-soft); border-radius:14px;
  padding:4px 18px; backdrop-filter:blur(6px);
}
.faq-list summary{
  cursor:pointer; list-style:none; padding:15px 0; font-weight:500; font-size:18.5px;
  display:flex; justify-content:space-between; align-items:center; gap:14px; color:var(--ink);
}
.faq-list summary::-webkit-details-marker{display:none}
.faq-list summary::after{content:"+"; color:var(--gold); font-size:26.5px; line-height:1; transition:transform .2s ease}
.faq-list details[open] summary::after{transform:rotate(45deg)}
.faq-list details p{margin:0 0 16px; color:var(--muted); font-size:18px}

/* ---------- CTA cuối ---------- */
.final-card{
  text-align:center; max-width:760px; margin:0 auto;
  background:linear-gradient(180deg,rgba(20,24,46,.86),rgba(10,13,29,.94));
  border:1px solid var(--line); border-radius:24px; padding:40px 24px;
  box-shadow:var(--shadow); backdrop-filter:blur(8px);
}
.final-card h2{font-family:"Cormorant Garamond",serif; font-weight:700; font-size:33.5px; margin:0 0 12px}
.final-card > p{color:var(--muted); margin:0 auto 26px; max-width:520px}
.lead-form-compact{text-align:left; max-width:440px; margin:0 auto}

/* ---------- Footer ---------- */
.site-footer{border-top:1px solid var(--line-soft); background:rgba(5,6,14,.6); margin-top:10px}
.footer-inner{display:grid; grid-template-columns:1fr; gap:24px; padding:42px 0 26px}
.footer-brand{font-size:29px; display:block; margin-bottom:8px}
.footer-col p{margin:5px 0; color:var(--muted); font-size:17px}
.footer-col h4{margin:0 0 8px; font-size:15.5px; letter-spacing:1.5px; text-transform:uppercase; color:var(--gold)}
.footer-col a{color:var(--muted); text-decoration:none}
.footer-col a:hover{color:var(--gold-2)}
.footer-bottom{padding:16px 0 30px; border-top:1px solid var(--line-soft)}
.footer-bottom p{margin:0; color:var(--muted-2); font-size:15px}

/* ---------- Zalo nổi ---------- */
.zalo-float{
  position:fixed; right:16px; bottom:18px; z-index:40;
  background:linear-gradient(135deg,var(--gold-2),var(--gold-deep)); color:#1a1405;
  text-decoration:none; font-weight:700; font-size:17px;
  padding:12px 18px; border-radius:999px; box-shadow:0 10px 28px rgba(227,195,115,.4);
  display:flex; align-items:center; gap:7px;
}
.zalo-float::before{content:""; width:9px; height:9px; border-radius:50%; background:#1a7a3c; box-shadow:0 0 0 0 rgba(26,122,60,.6); animation:pulseDot 2s infinite}
@keyframes pulseDot{0%{box-shadow:0 0 0 0 rgba(26,122,60,.6)}70%{box-shadow:0 0 0 8px rgba(26,122,60,0)}100%{box-shadow:0 0 0 0 rgba(26,122,60,0)}}

/* ---------- Reveal khi cuộn (chỉ ẩn khi có JS) ---------- */
.reveal{transition:opacity .7s ease, transform .7s ease}
.js .reveal{opacity:0; transform:translateY(22px)}
.reveal.in{opacity:1; transform:none}

/* ===================== TABLET / DESKTOP ===================== */
@media(min-width:680px){
  .btn-call{display:inline-flex}
  .hero-cta{flex-direction:row; justify-content:center}
  .hero-cta a{width:auto}
  .trust-row{grid-template-columns:repeat(4,1fr)}
  .pain-grid{grid-template-columns:repeat(3,1fr)}
  .stakes-grid{grid-template-columns:1fr 1fr}
  .form-card{grid-template-columns:1.05fr 1fr; padding:40px 38px; align-items:start}
  .footer-inner{grid-template-columns:1.4fr 1fr 1fr}
  .section-title{font-size:41px}
  .hero h1{font-size:60px}
}
@media(min-width:1000px){
  .section{padding:90px 0}
  .hero{padding:80px 0 90px}
  .hero h1{font-size:72px}
  .guide-inner{grid-template-columns:1fr 1.05fr; gap:48px; align-items:center}
  .step-list{grid-template-columns:repeat(3,1fr)}
  .section-title{font-size:45.5px}
}

/* ===================== GIẢM CHUYỂN ĐỘNG ===================== */
@media(prefers-reduced-motion:reduce){
  html{scroll-behavior:auto}
  .reveal,.js .reveal{opacity:1; transform:none; transition:none}
  .scroll-hint span::after,.zalo-float::before{animation:none}
}

/* ===================== ẢNH THẬT ===================== */
.guide-person{display:flex; align-items:center; gap:16px; margin-bottom:20px}
.guide-portrait{
  width:92px; height:92px; border-radius:50%; object-fit:cover; flex:0 0 auto;
  border:2px solid var(--gold);
  box-shadow:0 0 0 5px rgba(227,195,115,.08), 0 12px 26px rgba(0,0,0,.45);
}
.guide-person .kicker{margin:0 0 2px}
.guide-person-name{font-family:"Cormorant Garamond",serif; font-weight:700; font-size:29px; margin:0; color:var(--ink); line-height:1.1}
.guide-person-role{margin:2px 0 0; color:var(--muted-2); font-size:15.5px}

.proof-wrap{display:grid; grid-template-columns:1fr; gap:26px; align-items:center}
.proof-photo{margin:0}
.proof-photo img{
  width:100%; max-width:340px; height:auto; display:block; margin:0 auto;
  border-radius:18px; border:1px solid var(--line); box-shadow:var(--shadow);
}
.proof-photo figcaption{margin-top:10px; text-align:center; color:var(--muted-2); font-size:15px}
.proof-wrap .proof-inner{text-align:center; background:none; border:none; box-shadow:none; padding:0; backdrop-filter:none}

@media(min-width:880px){
  .proof-wrap{grid-template-columns:.82fr 1fr; gap:40px}
  .proof-photo img{max-width:330px}
  .proof-wrap .proof-inner{text-align:left}
  .proof-wrap .proof-inner .btn-solid{margin-top:4px}
  .guide-portrait{width:104px; height:104px}
}

/* ---------- Gallery ảnh thật ---------- */
.gallery-grid{display:grid; grid-template-columns:repeat(2,1fr); gap:12px; margin-top:8px}
.gallery-grid figure{
  margin:0; border-radius:16px; overflow:hidden;
  border:1px solid var(--line); box-shadow:0 12px 30px rgba(0,0,0,.4);
}
.gallery-grid img{
  width:100%; aspect-ratio:3/4; object-fit:cover; display:block;
  transition:transform .5s ease;
}
.gallery-grid figure:hover img{transform:scale(1.05)}
@media(min-width:760px){
  .gallery-grid{grid-template-columns:repeat(3,1fr); gap:16px}
}

/* ---------- Trích tổng hợp đánh giá ---------- */
.proof-quote{
  margin:18px 0 22px; padding-left:16px; border-left:2px solid var(--gold);
  font-family:"Cormorant Garamond",serif; font-style:italic; font-size:23px; line-height:1.45;
  color:var(--gold-2);
}
.proof-quote span{
  display:block; margin-top:8px; font-family:"Be Vietnam Pro",sans-serif;
  font-style:normal; font-size:15px; color:var(--muted-2); letter-spacing:.3px;
}


/* ---------- Chống rớt chữ / orphan (cân dòng tự động) ---------- */
h1, h2, h3,
.section-title, .problem-philo, .proof-big,
.guide-person-name, .form-copy h2, .final-card h2 { text-wrap: balance; }
p, .lead, .section-intro,
.pain-card p, .step-list p, .authority span,
.form-perks li, .faq-list p, .stakes-card li { text-wrap: pretty; }


/* ---------- Đánh giá khách (Google) ---------- */
.reviews-grid{display:grid; grid-template-columns:1fr; gap:14px; margin-top:8px}
.review-card{
  background:var(--panel); border:1px solid var(--line-soft); border-radius:16px;
  padding:20px 20px 22px; backdrop-filter:blur(6px);
  display:flex; flex-direction:column; gap:11px;
}
.review-head{display:flex; align-items:center; gap:11px}
.review-ava{
  width:42px; height:42px; border-radius:50%; flex:0 0 auto;
  display:flex; align-items:center; justify-content:center;
  color:#fff; font-weight:600; font-size:19px;
}
.review-name{margin:0; font-weight:600; font-size:18px; color:var(--ink); line-height:1.2}
.review-meta{margin:0; font-size:13px; color:var(--muted-2)}
.review-stars{color:#fbbc04; font-size:18px; letter-spacing:2px; line-height:1}
.review-text{margin:0; color:var(--muted); font-size:18px; line-height:1.55}
.reviews-cta{display:block; width:max-content; max-width:100%; margin:28px auto 0}
@media(min-width:680px){ .reviews-grid{grid-template-columns:1fr 1fr} }
@media(min-width:1000px){ .reviews-grid{grid-template-columns:repeat(3,1fr)} }


/* ---------- Ảnh nổi bật trong gallery (ngang, full khung) ---------- */
.gallery-feature{grid-column:1 / -1}
.gallery-feature img{aspect-ratio:3 / 2}


/* ---------- Gallery: banner + carousel (slide) ---------- */
.gallery-feature{margin:0 0 18px; border-radius:18px; overflow:hidden; border:1px solid var(--line); box-shadow:var(--shadow)}
.gallery-feature img{width:100%; aspect-ratio:3 / 2; object-fit:cover; display:block}

.gallery-carousel{position:relative}
.carousel-track{
  display:flex; gap:14px; overflow-x:auto; scroll-snap-type:x mandatory;
  scroll-behavior:smooth; -webkit-overflow-scrolling:touch; padding:2px; scrollbar-width:none;
}
.carousel-track::-webkit-scrollbar{display:none}
.carousel-track figure{
  margin:0; flex:0 0 80%; scroll-snap-align:center;
  border-radius:16px; overflow:hidden; border:1px solid var(--line);
  box-shadow:0 12px 30px rgba(0,0,0,.4);
}
.carousel-track img{width:100%; aspect-ratio:3 / 4; object-fit:cover; display:block}
.carousel-btn{
  position:absolute; top:50%; transform:translateY(-50%);
  width:46px; height:46px; border-radius:50%; border:1px solid var(--line);
  background:rgba(10,13,29,.72); color:var(--gold-2); font-size:26px; line-height:1;
  cursor:pointer; display:none; align-items:center; justify-content:center;
  backdrop-filter:blur(6px); z-index:3;
}
.carousel-btn:hover{background:rgba(227,195,115,.16)}
.carousel-prev{left:8px}
.carousel-next{right:8px}
.carousel-dots{display:flex; gap:8px; justify-content:center; margin-top:18px; flex-wrap:wrap}
.carousel-dots button{
  width:9px; height:9px; border-radius:50%; border:none; padding:0; cursor:pointer;
  background:rgba(227,195,115,.3); transition:width .25s ease, background .25s ease;
}
.carousel-dots button.active{background:var(--gold); width:24px; border-radius:5px}
@media(min-width:680px){
  .carousel-track figure{flex-basis:46%}
  .carousel-btn{display:flex}
}
@media(min-width:1000px){
  .carousel-track figure{flex-basis:31%}
}
