   :root {
      --bg: #070907;
      --card: #111711;
      --soft: rgba(255,255,255,.045);
      --line: rgba(255,255,255,.105);
      --green: #1fff61;
      --lime: #a8ff3f;
      --text: #f4fff5;
      --muted: #aab7ac;
      --dark-text: #071008;
      --radius: 24px;
      --shadow: 0 28px 90px rgba(0,0,0,.48);
      --container: 1180px;
    }

    * { margin: 0; padding: 0; box-sizing: border-box; }
    html { scroll-behavior: smooth; }
    body {
      font-family: Inter, ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
      color: var(--text);
      background: var(--bg);
    }

    body::before {
      content: "";
      position: fixed;
      inset: 0;
      pointer-events: none;
      z-index: -1;
      background-image:
        linear-gradient(rgba(255,255,255,.028) 1px, transparent 1px),
        linear-gradient(90deg, rgba(255,255,255,.028) 1px, transparent 1px);
      background-size: 72px 72px;
      mask-image: radial-gradient(circle at center, black 0%, transparent 74%);
    }

    a { color: inherit; text-decoration: none; }
    .container { width: min(var(--container), calc(100% - 36px)); margin: 0 auto; }

    .nav-wrap {
      position: sticky;
      top: 0;
      z-index: 20;
      background: rgba(7,9,7,.78);
      border-bottom: 1px solid rgba(255,255,255,.065);
      backdrop-filter: blur(18px);
    }

    .navbar {
      min-height: 84px;
      display: flex;
      align-items: center;
      justify-content: space-between;
      gap: 24px;
    }

    .brand {
      display: inline-flex;
      align-items: center;
      gap: 11px;
      font-size: 23px;
      font-weight: 900;
      letter-spacing: -.045em;
      white-space: nowrap;
    }

    .brand-mark {
      width: 38px;
      height: 38px;
      display: grid;
      place-items: center;
      border-radius: 13px;
      color: var(--dark-text);
      background: linear-gradient(135deg, var(--green), var(--lime));
      box-shadow: 0 0 30px rgba(31,255,97,.36);
    }

    .nav-links { display: flex; align-items: center; gap: 28px; color: var(--muted); font-size: 14px; }
    .nav-links a:hover { color: var(--green); }

    .btn {
      display: inline-flex;
      align-items: center;
      justify-content: center;
      gap: 10px;
      min-height: 48px;
      padding: 0 23px;
      border-radius: 999px;
      color: var(--dark-text);
      font-size: 14px;
      font-weight: 900;
      border: 1px solid rgba(31,255,97,.48);
      background: linear-gradient(135deg, var(--green), var(--lime));
      box-shadow: 0 0 36px rgba(31,255,97,.25);
      transition: transform .22s ease, box-shadow .22s ease, border-color .22s ease;
      cursor: pointer;
    }

    .btn:hover { transform: translateY(-2px); box-shadow: 0 0 54px rgba(31,255,97,.4); }
    .btn.secondary {
      color: var(--text);
      background: rgba(255,255,255,.04);
      border-color: rgba(255,255,255,.13);
      box-shadow: none;
    }

    .btn.secondary:hover { border-color: rgba(31,255,97,.55); box-shadow: 0 0 30px rgba(31,255,97,.12); }

    .hero { padding: 74px 0 55px; }
    .hero-grid { display: grid; grid-template-columns: 1.04fr .96fr; gap: 40px; align-items: center; }

    .eyebrow {
      width: fit-content;
      display: inline-flex;
      align-items: center;
      gap: 9px;
      margin-bottom: 22px;
      padding: 8px 13px;
      border-radius: 999px;
      color: var(--green);
      background: rgba(31,255,97,.062);
      border: 1px solid rgba(31,255,97,.22);
      font-size: 20px;
      font-weight: 800;
    }

    .section-head .eyebrow { margin-left: auto; margin-right: auto; }
    .pulse-dot { width: 8px; height: 8px; border-radius: 999px; background: var(--green); box-shadow: 0 0 0 7px rgba(31,255,97,.13); }

    h1 { max-width: 850px; font-size: clamp(46px, 7vw, 86px); line-height: .92; letter-spacing: -.078em; }
    .highlight { color: var(--green); text-shadow: 0 0 35px rgba(31,255,97,.22); }
    .hero-copy { max-width: 650px; margin: 26px 0 32px; color: var(--muted); font-size: 18px; line-height: 1.75; }
    .hero-actions { display: flex; flex-wrap: wrap; gap: 14px; align-items: center; }

    .proof-row { display: flex; flex-wrap: wrap; gap: 18px; align-items: center; margin-top: 30px; color: var(--muted); font-size: 13px; }
    .avatar-stack { display: flex; }
    .avatar {
      width: 38px;
      height: 38px;
      margin-left: -10px;
      border-radius: 50%;
      border: 2px solid #070907;
      display: grid;
      place-items: center;
      color: var(--dark-text);
      background: linear-gradient(135deg,#edffe8,var(--green));
      font-size: 11px;
      font-weight: 900;
    }
    .avatar:first-child { margin-left: 0; }

    .hero-panel {
      position: relative;
      min-height: 690px;
    }

    .green-shape {
      position: absolute;
      inset: 55px 0 auto 38px;
      height: 395px;
      border-radius: 38px;
      overflow: hidden;
      background:
        radial-gradient(circle at 23% 26%, #eaff42 0 6%, transparent 18%),
        linear-gradient(118deg, #d6ff37 0%, #32f35b 32%, #138c34 61%, #0a3319 100%);
      box-shadow: inset 0 0 92px rgba(255,255,255,.18), 0 42px 105px rgba(31,255,97,.16);
    }

    .green-shape::before,
    .green-shape::after {
      content: "";
      position: absolute;
      width: 140%;
      height: 230px;
      left: -24%;
      border: 2px solid rgba(255,255,255,.24);
      border-radius: 50%;
      transform: rotate(-13deg);
    }

    .green-shape::before { top: 82px; }
    .green-shape::after { top: 140px; opacity: .55; }

    /* NEW HERO PHONE MOCKUP + ROTATING APP INTERFACE */
    .phone-mockup {
      position: absolute;
      right: 32px;
      top: 0;
      width: min(360px, 86vw);
      padding: 14px;
      border-radius: 48px;
      background:
        linear-gradient(145deg, rgba(255,255,255,.18), rgba(255,255,255,.035)),
        #101610;
      border: 1px solid rgba(255,255,255,.2);
      box-shadow: var(--shadow), 0 0 70px rgba(31,255,97,.16);
      backdrop-filter: blur(18px);
    }

    .phone-mockup::before {
      content: "";
      position: absolute;
      inset: 10px;
      border-radius: 40px;
      border: 1px solid rgba(255,255,255,.08);
      pointer-events: none;
    }

    .phone-speaker {
      position: absolute;
      top: 25px;
      left: 50%;
      z-index: 8;
      width: 82px;
      height: 8px;
      border-radius: 999px;
      transform: translateX(-50%);
      background: rgba(255,255,255,.18);
      box-shadow: inset 0 0 8px rgba(0,0,0,.55);
    }

    .phone-screen {
      position: relative;
      min-height: 690px;
      border-radius: 38px;
      overflow: hidden;
      background: #071007;
      border: 1px solid rgba(31,255,97,.22);
    }

    .app-slider {
      position: absolute;
      inset: 0;
      background:
        radial-gradient(circle at 20% 10%, rgba(31,255,97,.17), transparent 28%),
        linear-gradient(180deg, #0d160d, #071007);
    }

    .app-slide {
      position: absolute;
      inset: 0;
      display: flex;
      flex-direction: column;
      gap: 14px;
      padding: 56px 18px 48px;
      opacity: 0;
      transform: translateX(28px) scale(.985);
      transition: opacity .42s ease, transform .42s ease;
      pointer-events: none;
    }

    .app-slide.active {
      opacity: 1;
      transform: translateX(0) scale(1);
      pointer-events: auto;
    }

    .phone-status {
      display: flex;
      align-items: center;
      justify-content: space-between;
      color: rgba(244,255,245,.74);
      font-size: 12px;
      font-weight: 800;
      margin-bottom: 4px;
    }

    .slide-chip {
      width: fit-content;
      padding: 7px 10px;
      border-radius: 999px;
      color: var(--green);
      background: rgba(31,255,97,.13);
      border: 1px solid rgba(31,255,97,.2);
      font-size: 11px;
      font-weight: 900;
    }

    .slide-title {
      font-size: 28px;
      line-height: 1.02;
      letter-spacing: -.055em;
    }

    .slide-copy {
      color: var(--muted);
      line-height: 1.55;
      font-size: 13px;
    }

    .phone-card {
      padding: 15px;
      border-radius: 18px;
      background: rgba(255,255,255,.046);
      border: 1px solid rgba(255,255,255,.09);
      box-shadow: 0 18px 40px rgba(0,0,0,.16);
    }

    .phone-card.light {
      color: var(--dark-text);
      background: linear-gradient(135deg, rgba(31,255,97,.95), rgba(168,255,63,.88));
      border-color: rgba(255,255,255,.28);
    }

    .phone-row {
      display: flex;
      align-items: center;
      justify-content: space-between;
      gap: 10px;
    }

    .phone-card-title {
      font-size: 14px;
      font-weight: 900;
    }

    .phone-card-subtitle {
      color: rgba(244,255,245,.64);
      font-size: 12px;
      line-height: 1.45;
      margin-top: 5px;
    }

    .phone-card.light .phone-card-subtitle { color: rgba(7,16,8,.7); }

    .phone-tag {
      color: var(--green);
      font-size: 12px;
      font-weight: 900;
      white-space: nowrap;
    }

    .phone-card.light .phone-tag { color: var(--dark-text); }

    .mini-chart {
      height: 145px;
      display: flex;
      align-items: flex-end;
      gap: 9px;
      padding: 14px;
      border-radius: 18px;
      background:
        linear-gradient(180deg, rgba(31,255,97,.15), rgba(31,255,97,.01)),
        repeating-linear-gradient(to top, transparent 0 34px, rgba(255,255,255,.052) 35px 36px);
      border: 1px solid rgba(255,255,255,.08);
    }

    .mini-chart span {
      flex: 1;
      height: var(--h);
      border-radius: 999px 999px 7px 7px;
      background: linear-gradient(180deg, var(--lime), var(--green));
      box-shadow: 0 0 20px rgba(31,255,97,.2);
    }

    .booking-card {
      display: grid;
      grid-template-columns: 52px 1fr;
      gap: 12px;
      align-items: center;
    }

    .date-box {
      min-height: 52px;
      display: grid;
      place-items: center;
      border-radius: 16px;
      color: var(--dark-text);
      background: linear-gradient(135deg, var(--green), var(--lime));
      font-size: 18px;
      font-weight: 900;
    }

    .product-grid {
      display: grid;
      grid-template-columns: 1fr 1fr;
      gap: 11px;
    }

    .product-tile {
      min-height: 118px;
      padding: 12px;
      border-radius: 17px;
      background: rgba(255,255,255,.046);
      border: 1px solid rgba(255,255,255,.09);
    }

    .product-img {
      height: 58px;
      border-radius: 13px;
      margin-bottom: 10px;
      background:
        radial-gradient(circle at 30% 25%, rgba(255,255,255,.34), transparent 20%),
        linear-gradient(135deg, rgba(31,255,97,.85), rgba(168,255,63,.35));
    }

    .product-tile strong { display: block; font-size: 13px; margin-bottom: 4px; }
    .product-tile span { color: var(--green); font-size: 12px; font-weight: 900; }

    .portal-list { display: grid; gap: 10px; }

    .portal-item {
      display: flex;
      align-items: center;
      justify-content: space-between;
      gap: 12px;
      padding: 12px;
      border-radius: 16px;
      background: rgba(255,255,255,.044);
      border: 1px solid rgba(255,255,255,.08);
    }

    .portal-icon {
      width: 36px;
      height: 36px;
      display: grid;
      place-items: center;
      border-radius: 12px;
      color: var(--dark-text);
      background: linear-gradient(135deg, var(--green), var(--lime));
      font-weight: 900;
      flex: 0 0 auto;
    }

    .portal-item strong { display: block; font-size: 13px; }
    .portal-item small { color: var(--muted); font-size: 11px; }

    .slide-dots {
      position: absolute;
      left: 50%;
      bottom: 18px;
      display: flex;
      gap: 7px;
      transform: translateX(-50%);
      z-index: 4;
    }

    .slide-dots span {
      width: 7px;
      height: 7px;
      border-radius: 999px;
      background: rgba(255,255,255,.25);
      transition: width .25s ease, background .25s ease;
    }

    .slide-dots span.active { width: 22px; background: var(--green); }

    .floating-card {
      position: absolute;
      left: 0;
      bottom: 48px;
      max-width: 326px;
      padding: 22px;
      border-radius: var(--radius);
      background: rgba(15,20,15,.84);
      border: 1px solid rgba(31,255,97,.25);
      box-shadow: var(--shadow);
      backdrop-filter: blur(16px);
    }

    .floating-card strong { display: block; margin-bottom: 8px; color: var(--green); font-size: 38px; line-height: 1; }
    .floating-card p { color: var(--muted); line-height: 1.55; font-size: 14px; }

    .logo-strip { padding: 32px 0 32px; }
    .logos { display: grid; grid-template-columns: repeat(5, 1fr); gap: 14px; color: rgba(255,255,255,.62); font-size: 15px; font-weight: 900; }
    .logo-item { min-height: 62px; display: flex; align-items: center; justify-content: center; gap: 9px; border-radius: 16px; background: rgba(255,255,255,.026); border: 1px solid rgba(255,255,255,.08); }

    .section { padding: 35px 0; }
    .section-head { max-width: 760px; margin: 0 auto 42px; text-align: center; }
    .section-head h2, .content-block h2 { font-size: clamp(34px,5vw,58px); line-height: 1; letter-spacing: -.065em; margin-bottom: 18px; }
    .section-head p, .content-block p { color: var(--muted); line-height: 1.75; font-size: 17px; }

    .services-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 18px; }
    .service-card {
      position: relative;
      min-height: 270px;
      padding: 28px;
      border-radius: var(--radius);
      overflow: hidden;
      background: linear-gradient(180deg, rgba(255,255,255,.047), rgba(255,255,255,.018)), var(--card);
      border: 1px solid rgba(255,255,255,.09);
      transition: transform .22s ease, border-color .22s ease, background .22s ease;
    }

    .service-card:hover {
      transform: translateY(-5px);
      border-color: rgba(31,255,97,.36);
      background:
        radial-gradient(circle at 78% 15%, rgba(31,255,97,.15), transparent 34%),
        linear-gradient(180deg, rgba(255,255,255,.055), rgba(255,255,255,.02)),
        var(--card);
    }

    .icon {
      width: 58px;
      height: 58px;
      display: grid;
      place-items: center;
      margin-bottom: 24px;
      border-radius: 18px;
      color: var(--green);
      background: rgba(31,255,97,.12);
      border: 1px solid rgba(31,255,97,.22);
      font-size: 25px;
    }

    .service-card h3 { font-size: 22px; letter-spacing: -.04em; margin-bottom: 12px; }
    .service-card p { color: var(--muted); line-height: 1.7; font-size: 15px; }
    .read-link { position: absolute; left: 28px; bottom: 24px; color: var(--green); font-size: 13px; font-weight: 900; }

    .split { display: grid; grid-template-columns: .92fr 1.08fr; gap: 36px; align-items: center; }
    .visual-card {
      min-height: 500px;
      padding: 24px;
      border-radius: 32px;
      overflow: hidden;
      background:
        radial-gradient(circle at 70% 18%, rgba(31,255,97,.2), transparent 30%),
        linear-gradient(180deg, rgba(255,255,255,.055), rgba(255,255,255,.02));
      border: 1px solid rgba(255,255,255,.11);
      box-shadow: var(--shadow);
    }

    .build-board { min-height: 452px; padding: 20px; border-radius: 24px; background: #0b0f0b; border: 1px solid rgba(31,255,97,.18); }
    .board-top { display: flex; justify-content: space-between; align-items: center; margin-bottom: 22px; }
    .board-title { font-size: 20px; font-weight: 900; letter-spacing: -.04em; }
    .board-pill { width: 130px; height: 34px; border-radius: 999px; background: rgba(255,255,255,.06); border: 1px solid rgba(255,255,255,.08); }
    .kanban { display: grid; grid-template-columns: repeat(3, 1fr); gap: 12px; }
    .kanban-col { min-height: 300px; padding: 12px; border-radius: 18px; background: rgba(255,255,255,.032); border: 1px solid rgba(255,255,255,.075); }
    .kanban-col h4 { margin-bottom: 12px; color: var(--green); font-size: 12px; text-transform: uppercase; letter-spacing: .08em; }
    .ticket { min-height: 72px; margin-bottom: 10px; padding: 12px; border-radius: 14px; background: rgba(255,255,255,.052); border: 1px solid rgba(255,255,255,.08); color: var(--muted); font-size: 13px; line-height: 1.45; }

    .mini-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 14px; margin: 28px 0; }
    .mini-card { padding: 20px; border-radius: 18px; background: rgba(255,255,255,.035); border: 1px solid rgba(255,255,255,.09); }
    .mini-card h4 { color: var(--green); margin-bottom: 8px; font-size: 15px; }
    .mini-card p { margin: 0; font-size: 14px; line-height: 1.6; }

    .audience-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 18px; }
    .audience-card { padding: 34px; border-radius: 28px; background: linear-gradient(180deg, rgba(255,255,255,.047), rgba(255,255,255,.018)); border: 1px solid rgba(255,255,255,.09); }
    .audience-card h3 { font-size: 28px; letter-spacing: -.05em; margin-bottom: 14px; }
    .audience-card p { color: var(--muted); line-height: 1.75; margin-bottom: 20px; }

    .check-list { display: grid; gap: 10px; color: var(--muted); }
    .check-list li { list-style: none; display: flex; gap: 10px; align-items: flex-start; }
    .check-list li::before { content: "✓"; color: var(--green); font-weight: 900; }

    .steps { display: grid; grid-template-columns: repeat(3, 1fr); gap: 18px; }
    .step-card { padding: 30px; border-radius: var(--radius); border: 1px solid rgba(255,255,255,.09); background: rgba(255,255,255,.03); }
    .step-no { margin-bottom: 20px; color: var(--green); font-size: 46px; font-weight: 900; letter-spacing: -.08em; }
    .step-card h3 { margin-bottom: 12px; font-size: 22px; letter-spacing: -.04em; }
    .step-card p { color: var(--muted); line-height: 1.7; }

    .stats-band {
      margin-top: 48px;
      padding: 18px;
      border-radius: 28px;
      overflow: hidden;
      background: linear-gradient(115deg, rgba(31,255,97,.9), rgba(168,255,63,.86));
      box-shadow: 0 30px 90px rgba(31,255,97,.14);
    }

    .stats-inner { display: grid; grid-template-columns: repeat(4,1fr); gap: 12px; }
    .stat { padding: 28px 16px; text-align: center; border-radius: 20px; color: var(--dark-text); background: rgba(5,15,7,.25); border: 1px solid rgba(255,255,255,.24); }
    .stat strong { display: block; margin-bottom: 4px; font-size: 38px; letter-spacing: -.05em; }
    .stat span { font-size: 13px; font-weight: 900; opacity: .82; }

    .cta-panel {
      position: relative;
      overflow: hidden;
      padding: 70px 32px;
      text-align: center;
      border-radius: 34px;
      color: var(--dark-text);
      background: linear-gradient(110deg, rgba(168,255,63,.95), rgba(31,255,97,.86));
      box-shadow: 0 35px 100px rgba(31,255,97,.17);
    }

    .cta-panel::before,
    .cta-panel::after {
      content: "";
      position: absolute;
      width: 105%;
      height: 280px;
      left: -10%;
      border: 3px solid rgba(255,255,255,.35);
      border-radius: 50%;
      transform: rotate(-14deg);
      pointer-events: none;
    }

    .cta-panel::before { top: -30px; }
    .cta-panel::after { top: 80px; opacity: .45; }

    .cta-content {
      position: relative;
      z-index: 1;
      max-width: 720px;
      margin: 0 auto;
      padding: 38px;
      border-radius: 28px;
      background: rgba(5,15,7,.25);
      border: 1px solid rgba(255,255,255,.28);
      backdrop-filter: blur(16px);
    }

    .cta-content h2 { margin-bottom: 16px; font-size: clamp(34px,5vw,58px); line-height: 1; letter-spacing: -.065em; }
    .cta-content p { max-width: 580px; margin: 0 auto 24px; color: rgba(7,16,8,.76); line-height: 1.75; font-weight: 700; }
    .cta-content .btn { color: var(--green); background: #071008; border-color: rgba(7,16,8,.35); box-shadow: none; }

    .footer { padding: 44px 0; color: var(--muted); border-top: 1px solid rgba(255,255,255,.07); }
    .footer-row { display: flex; justify-content: space-between; gap: 20px; align-items: center; }
    .footer-links { display: flex; gap: 20px; font-size: 14px; }
    .footer-links a:hover { color: var(--green); }

    @media (max-width: 980px) {
      .nav-links { display: none; }
      .hero-grid, .split { grid-template-columns: 1fr; }
      .hero-panel { min-height: 760px; }
      .phone-mockup { left: 50%; right: auto; transform: translateX(-50%); }
      .green-shape { left: 0; right: 0; }
      .floating-card { left: 50%; bottom: 0; width: min(326px, 92%); transform: translateX(-50%); }
      .services-grid, .steps, .stats-inner { grid-template-columns: 1fr 1fr; }
      .logos { grid-template-columns: repeat(3,1fr); }
    }

    @media (max-width: 700px) {
      .hero { padding-top: 44px; }
      .navbar { min-height: 72px; }
      .brand { font-size: 20px; }
      .hero-copy, .section-head p, .content-block p { font-size: 16px; }
      .services-grid, .steps, .stats-inner, .mini-grid, .logos, .audience-grid, .kanban { grid-template-columns: 1fr; }
      .hero-panel { min-height: 735px; }
      .phone-mockup { width: min(360px, 100%); }
      .phone-screen { min-height: 640px; }
      .app-slide { padding-top: 52px; }
      .green-shape { height: 300px; }
      .footer-row { flex-direction: column; align-items: flex-start; }
    }
  
    /* IMAGE-BASED SMARTPHONE SLIDER */
    .image-phone-mockup {
      width: min(365px, 86vw);
    }

    .image-phone-screen {
      min-height: 690px;
      background: #050805;
    }

    .image-slider {
      position: absolute;
      inset: 0;
      overflow: hidden;
      background: #050805;
    }

    .image-slide {
      position: absolute;
      inset: 0;
      margin: 0;
      opacity: 0;
      transform: scale(1.035);
      transition: opacity .5s ease, transform .5s ease;
      pointer-events: none;
    }

    .image-slide.active {
      opacity: 1;
      transform: scale(1);
      pointer-events: auto;
    }

    .image-slide img {
      width: 100%;
      height: 100%;
      display: block;
      object-fit: cover;
    }

    .image-slide-overlay {
      position: absolute;
      left: 18px;
      right: 18px;
      bottom: 58px;
      z-index: 4;
      padding: 16px;
      border-radius: 20px;
      background: rgba(5, 8, 5, .62);
      border: 1px solid rgba(255,255,255,.14);
      backdrop-filter: blur(16px);
      box-shadow: 0 18px 45px rgba(0,0,0,.28);
    }

    .image-slide-overlay span {
      display: block;
      color: var(--green);
      font-size: 12px;
      font-weight: 900;
      margin-bottom: 5px;
    }

    .image-slide-overlay strong {
      display: block;
      color: var(--text);
      font-size: 18px;
      line-height: 1.15;
      letter-spacing: -.035em;
    }

    .image-dots {
      bottom: 28px;
    }
/* ==========================================================
   Phone mockup using the uploaded PNG untouched
   Actual PNG size: 573 x 1158
   The image is copied as assets/phone-mockup.png with no edits.
   Screenshots sit behind the transparent inside area.
   ========================================================== */

.phone-device {
  position: absolute;
  right: 22px;
  top: -8px;
  width: min(370px, 86vw);
  aspect-ratio: 573 / 1158;
  filter: drop-shadow(0 34px 90px rgba(0,0,0,.52)) drop-shadow(0 0 55px rgba(31,255,97,.13));
}

.phone-device-frame {
  position: absolute;
  inset: 0;
  z-index: 10;
  width: 100%;
  height: 100%;
  object-fit: contain;
  pointer-events: none;
  user-select: none;
}

/* Screen area measured to sit behind the transparent opening of your PNG. */
.phone-device-screen {
  position: absolute;
  z-index: 1;
  left: 5.75%;
  right: 4.9%;
  top: 2.42%;
  bottom: 2.5%;
  overflow: hidden;
  border-radius: 9% / 4.25%;
  background: #050805;
}

.phone-screenshot-slider {
  position: absolute;
  inset: 0;
  overflow: hidden;
  background: #050805;
}

.phone-screenshot-slide {
  position: absolute;
  inset: 0;
  margin: 0;
  opacity: 0;
  transform: scale(1.025);
  transition: opacity .45s ease, transform .45s ease;
  pointer-events: none;
}

.phone-screenshot-slide.active {
  opacity: 1;
  transform: scale(1);
  pointer-events: auto;
}

.phone-screenshot-slide img {
  width: 100%;
  height: 100%;
  display: block;
  object-fit: fill;
}

.phone-screenshot-caption {
  position: absolute;
  left: 18px;
  right: 18px;
  bottom: 58px;
  z-index: 4;
  padding: 15px;
  border-radius: 20px;
  background: rgba(5, 8, 5, .62);
  border: 1px solid rgba(255,255,255,.14);
  backdrop-filter: blur(16px);
  box-shadow: 0 18px 45px rgba(0,0,0,.28);
}

.phone-screenshot-caption span {
  display: block;
  color: var(--green);
  font-size: 12px;
  font-weight: 900;
  margin-bottom: 5px;
}

.phone-screenshot-caption strong {
  display: block;
  color: var(--text);
  font-size: 18px;
  line-height: 1.15;
  letter-spacing: -.035em;
}

.phone-screenshot-dots {
  position: absolute;
  left: 50%;
  bottom: 29px;
  z-index: 5;
  display: flex;
  gap: 7px;
  transform: translateX(-50%);
}

.phone-screenshot-dots span {
  width: 7px;
  height: 7px;
  border-radius: 999px;
  background: rgba(255,255,255,.25);
  transition: width .25s ease, background .25s ease;
}

.phone-screenshot-dots span.active {
  width: 22px;
  background: var(--green);
}

@media (max-width: 980px) {
  .phone-device {
    left: 50%;
    right: auto;
    transform: translateX(-50%);
  }
}

@media (max-width: 700px) {
  .phone-device {
    width: min(370px, 100%);
  }
}
