  /* ──────────────────────────────────────────
     DESIGN TOKENS
  ────────────────────────────────────────── */
  :root {
    --primary:   #0A66C2;
    --primary-d: #0854a0;
    --accent:    #00D4FF;
    --accent-d:  #00aacc;
    --dark:      #0D0F14;
    --dark-2:    #141720;
    --dark-3:    #1C2130;
    --surface:   #1E2438;
    --border:    rgba(255,255,255,.08);
    --text:      #1A1A1A;
    --text-inv:  #E8ECF4;
    --text-muted:#8A93A8;
    --white:     #FFFFFF;
    --bg-alt:    #F5F7FA;
    --success:   #22C55E;
    --warning:   #F59E0B;
    --danger:    #EF4444;
    --radius:    12px;
    --radius-lg: 20px;
    --shadow:    0 8px 32px rgba(0,0,0,.28);
    --shadow-sm: 0 2px 12px rgba(0,0,0,.15);
  }

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

  html { scroll-behavior: smooth; }

  body {
    font-family: 'Inter', sans-serif;
    background: var(--dark);
    color: var(--text-inv);
    overflow-x: hidden;
    line-height: 1.6;
  }

  /* ──────────────────────────────────────────
     UTILITY
  ────────────────────────────────────────── */
  .hidden { display: none !important; }
  .container { max-width: 1180px; margin: 0 auto; padding: 0 24px; }
  h1,h2,h3,h4,h5 { font-family: 'Montserrat', sans-serif; }

  .btn {
    display: inline-flex; align-items: center; gap: 8px;
    padding: 12px 28px; border-radius: 8px;
    font-family: 'Inter', sans-serif; font-weight: 600; font-size: .9rem;
    cursor: pointer; border: none; transition: all .25s ease; text-decoration: none;
  }
  .btn-primary {
    background: var(--primary); color: #fff;
  }
  .btn-primary:hover { background: var(--primary-d); transform: translateY(-2px); box-shadow: 0 8px 24px rgba(10,102,194,.4); }

  .btn-accent {
    background: linear-gradient(135deg, var(--accent), var(--primary));
    color: #fff;
  }
  .btn-accent:hover { transform: translateY(-2px); box-shadow: 0 8px 32px rgba(0,212,255,.35); }

  .btn-outline {
    background: transparent; color: var(--text-inv);
    border: 1.5px solid var(--border);
  }
  .btn-outline:hover { border-color: var(--accent); color: var(--accent); }

  .btn-ghost {
    background: transparent; color: var(--text-muted); border: none; font-size: .85rem;
  }
  .btn-ghost:hover { color: var(--accent); }

  .badge {
    display: inline-flex; align-items: center; gap: 6px;
    padding: 4px 12px; border-radius: 20px; font-size: .75rem; font-weight: 600;
  }
  .badge-active  { background: rgba(34,197,94,.15);  color: var(--success); }
  .badge-pending { background: rgba(245,158,11,.15); color: var(--warning); }
  .badge-done    { background: rgba(10,102,194,.2);  color: var(--accent);  }
  .badge-new     { background: rgba(239,68,68,.15);  color: var(--danger);  }

  /* ──────────────────────────────────────────
     NAVBAR
  ────────────────────────────────────────── */
  #navbar {
    position: fixed; top: 0; left: 0; right: 0; z-index: 900;
    height: 68px;
    background: rgba(13,15,20,.85);
    backdrop-filter: blur(16px);
    border-bottom: 1px solid var(--border);
    display: flex; align-items: center;
    transition: transform .3s ease, background .22s ease, box-shadow .22s ease, border-color .22s ease;
    will-change: transform;
  }

  @media (max-width: 1024px) {
    .landing-page-shell {
      min-height: auto;
      padding: 112px 0 72px;
    }
  }

  @media (max-width: 768px) {
    .landing-preview-card,
    .landing-page-cta,
    .contact-view-shell .newsletter-card {
      padding: 24px;
    }

    .landing-page-head {
      margin-bottom: 28px;
    }

    .landing-page-shell {
      padding: 104px 0 64px;
    }
  }

  @media (max-width: 520px) {
    .landing-page-shell {
      padding: 94px 0 56px;
    }

    .landing-preview-grid {
      grid-template-columns: 1fr;
    }

    .landing-preview-title {
      font-size: 1.2rem;
    }
  }
  #navbar.mobile-navbar-scrolled {
    background: rgba(13,15,20,.94);
    box-shadow: 0 18px 36px rgba(0,0,0,.22);
    border-bottom-color: rgba(255,255,255,.06);
  }
  #navbar.mobile-navbar-hidden {
    transform: translateY(calc(-100% - 18px));
  }
  .nav-inner {
    width: 100%; max-width: 1180px; margin: 0 auto; padding: 0 24px;
    display: flex; align-items: center; justify-content: space-between;
  }
  .nav-logo {
    font-family: 'Montserrat', sans-serif; font-weight: 900; font-size: 1.5rem;
    background: linear-gradient(135deg, var(--accent), var(--primary));
    -webkit-background-clip: text; -webkit-text-fill-color: transparent;
    letter-spacing: -1px;
  }
  .nav-links {
    display: flex; align-items: center; gap: 6px;
    padding: 6px;
    border-radius: 18px;
    background: rgba(255,255,255,.03);
    border: 1px solid rgba(255,255,255,.05);
    box-shadow: inset 0 1px 0 rgba(255,255,255,.04);
  }
  .nav-link {
    color: var(--text-muted); text-decoration: none; font-size: .875rem;
    padding: 8px 14px; border-radius: 12px; transition: all .2s;
    background: transparent; border: none; font-family: inherit; cursor: pointer;
  }
  .nav-link:hover, .nav-link.active { color: var(--text-inv); background: rgba(255,255,255,.06); }
  .nav-link.highlight {
    color: var(--text-inv);
    background: linear-gradient(135deg, rgba(10,102,194,.28), rgba(0,212,255,.22));
    box-shadow: 0 10px 30px rgba(10,102,194,.16);
  }
  .nav-actions { display: flex; align-items: center; gap: 10px; }

  .mobile-nav-shell,
  .mobile-nav-backdrop {
    display: none;
  }

  .mobile-nav-shell {
    position: relative;
    width: 100%;
  }

  .mobile-nav-dock {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 8px;
    padding: 10px;
    border-radius: 32px;
    background: linear-gradient(180deg, rgba(247,250,255,.96), rgba(229,236,248,.9));
    border: 1px solid rgba(255,255,255,.88);
    box-shadow: 0 22px 45px rgba(3,9,24,.34), inset 0 1px 0 rgba(255,255,255,.9);
    backdrop-filter: blur(18px);
  }

  .mobile-nav-item {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 7px;
    min-height: 76px;
    padding: 10px 8px;
    border: none;
    border-radius: 24px;
    background: transparent;
    color: rgba(12,18,33,.72);
    cursor: pointer;
    transition: transform .22s ease, box-shadow .22s ease, background .22s ease, color .22s ease;
    text-align: center;
    font-family: inherit;
  }

  .mobile-nav-item:hover {
    transform: translateY(-2px);
  }

  .mobile-nav-item.is-active {
    background: linear-gradient(145deg, rgba(24,28,42,.98), rgba(8,12,26,.96));
    color: #fff;
    box-shadow: inset 0 1px 0 rgba(255,255,255,.08), 0 16px 28px rgba(7,10,20,.32);
  }

  .mobile-nav-item.is-accent {
    color: var(--primary);
  }

  .mobile-nav-item.is-active.is-accent {
    color: #fff;
    background: linear-gradient(145deg, rgba(10,102,194,.94), rgba(11,30,77,.98));
    box-shadow: inset 0 1px 0 rgba(255,255,255,.16), 0 18px 30px rgba(10,102,194,.32);
  }

  .mobile-nav-icon {
    width: 24px;
    height: 24px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
  }

  .mobile-nav-icon svg {
    width: 22px;
    height: 22px;
    stroke: currentColor;
    fill: none;
    stroke-width: 1.9;
    stroke-linecap: round;
    stroke-linejoin: round;
  }

  .mobile-nav-label {
    font-size: .76rem;
    font-weight: 700;
    line-height: 1.1;
    letter-spacing: -.01em;
  }

  .mobile-nav-backdrop {
    position: fixed;
    inset: 0;
    z-index: 905;
    background: rgba(6,8,15,.54);
    backdrop-filter: blur(12px);
    align-items: flex-start;
    justify-content: center;
    padding: 118px 16px 18px;
  }

  .mobile-nav-sheet {
    width: min(100%, 430px);
    background: linear-gradient(180deg, rgba(18,22,36,.98), rgba(10,14,26,.98));
    border: 1px solid rgba(255,255,255,.09);
    border-radius: 30px;
    padding: 22px;
    box-shadow: 0 26px 50px rgba(0,0,0,.42);
  }

  .mobile-nav-sheet-head {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 18px;
    margin-bottom: 18px;
  }

  .mobile-nav-sheet-kicker {
    margin-bottom: 8px;
    display: inline-flex;
  }

  .mobile-nav-sheet-title {
    font-size: 1.25rem;
    margin: 0 0 6px;
  }

  .mobile-nav-sheet-copy {
    color: var(--text-muted);
    font-size: .88rem;
    line-height: 1.5;
  }

  .mobile-nav-sheet-close {
    width: 42px;
    height: 42px;
    border: 1px solid rgba(255,255,255,.08);
    border-radius: 14px;
    background: rgba(255,255,255,.03);
    color: var(--text-inv);
    cursor: pointer;
    font-size: 1.4rem;
    line-height: 1;
  }

  .mobile-nav-sheet-grid {
    display: grid;
    gap: 12px;
  }

  .mobile-nav-sheet-action {
    width: 100%;
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 14px;
    padding: 16px 18px;
    border: 1px solid rgba(255,255,255,.08);
    border-radius: 20px;
    background: rgba(255,255,255,.04);
    color: var(--text-inv);
    cursor: pointer;
    text-align: left;
    transition: transform .22s ease, border-color .22s ease, background .22s ease;
    font-family: inherit;
  }

  .mobile-nav-sheet-action:hover {
    transform: translateY(-1px);
    border-color: rgba(0,212,255,.28);
    background: rgba(0,212,255,.07);
  }

  .mobile-nav-sheet-action strong {
    display: block;
    font-size: .96rem;
    margin-bottom: 2px;
  }

  .mobile-nav-sheet-action span {
    color: var(--text-muted);
    font-size: .82rem;
    line-height: 1.45;
  }

  .mobile-nav-sheet-action em {
    color: var(--accent);
    font-style: normal;
    font-size: 1rem;
    font-weight: 700;
  }

  .user-pill {
    display: flex; align-items: center; gap: 8px;
    background: var(--surface); border: 1px solid var(--border);
    border-radius: 40px; padding: 5px 14px 5px 8px;
    font-size: .8rem; cursor: pointer;
  }
  .user-avatar {
    width: 28px; height: 28px; border-radius: 50%;
    background: linear-gradient(135deg, var(--primary), var(--accent));
    display: flex; align-items: center; justify-content: center;
    font-size: .75rem; font-weight: 700;
  }

  /* ──────────────────────────────────────────
     HERO
  ────────────────────────────────────────── */
  #hero {
    min-height: 100vh;
    display: flex; flex-direction: column; justify-content: center;
    position: relative; overflow: hidden;
    padding-top: 68px;
  }
  .hero-bg {
    position: absolute; inset: 0; z-index: 0;
    background: radial-gradient(ellipse 80% 60% at 60% 40%, rgba(10,102,194,.18) 0%, transparent 70%),
                radial-gradient(ellipse 40% 40% at 80% 70%, rgba(0,212,255,.10) 0%, transparent 60%),
                var(--dark);
  }
  .grid-overlay {
    position: absolute; inset: 0; opacity: .04;
    background-image: linear-gradient(var(--accent) 1px, transparent 1px),
                      linear-gradient(90deg, var(--accent) 1px, transparent 1px);
    background-size: 60px 60px;
  }

  .hero-content { position: relative; z-index: 1; }

  .hero-eyebrow {
    display: inline-flex; align-items: center; gap: 8px;
    background: rgba(0,212,255,.08); border: 1px solid rgba(0,212,255,.2);
    border-radius: 40px; padding: 6px 16px; font-size: .8rem;
    color: var(--accent); font-weight: 600; margin-bottom: 24px;
    animation: fadeInUp .6s ease both;
  }
  .hero-eyebrow::before {
    content: ''; width: 6px; height: 6px; border-radius: 50%;
    background: var(--accent); animation: pulse 2s infinite;
  }

  @keyframes pulse { 0%,100%{opacity:1;transform:scale(1)} 50%{opacity:.4;transform:scale(1.3)} }

  .hero-title {
    font-size: clamp(2.4rem, 5vw, 4rem);
    font-weight: 900; line-height: 1.1;
    animation: fadeInUp .7s .1s ease both;
    margin-bottom: 20px;
  }
  .hero-title span {
    background: linear-gradient(135deg, var(--accent), var(--primary));
    -webkit-background-clip: text; -webkit-text-fill-color: transparent;
  }

  .hero-desc {
    font-size: 1.1rem; color: var(--text-muted); max-width: 540px;
    line-height: 1.75; margin-bottom: 36px;
    animation: fadeInUp .7s .2s ease both;
  }

  .hero-actions {
    display: flex; flex-wrap: wrap; gap: 14px;
    animation: fadeInUp .7s .3s ease both;
  }

  .hero-stats {
    display: flex; gap: 40px; margin-top: 60px;
    animation: fadeInUp .7s .4s ease both;
  }
  .stat-item { display: flex; flex-direction: column; gap: 4px; }
  .stat-num { font-family: 'Montserrat', sans-serif; font-size: 2rem; font-weight: 800; color: var(--white); }
  .stat-label { font-size: .8rem; color: var(--text-muted); }

  @keyframes fadeInUp {
    from { opacity: 0; transform: translateY(24px); }
    to   { opacity: 1; transform: translateY(0); }
  }

  /* ──────────────────────────────────────────
     SECTION COMMON
  ────────────────────────────────────────── */
  .section { padding: 96px 0; scroll-margin-top: 104px; }
  .section-alt { background: var(--dark-2); }

  .section-label {
    display: inline-block; font-size: .75rem; font-weight: 700;
    letter-spacing: 3px; text-transform: uppercase; color: var(--accent);
    margin-bottom: 12px;
  }
  .section-title {
    font-size: clamp(1.8rem, 3vw, 2.5rem); font-weight: 800; line-height: 1.2;
    margin-bottom: 16px;
  }
  .section-desc { color: var(--text-muted); max-width: 560px; line-height: 1.75; }

  .section-head { margin-bottom: 56px; }

  .landing-hub-head .section-desc {
    max-width: 760px;
  }

  .home-showcase-section {
    position: relative;
    min-height: clamp(640px, 78vh, 860px);
    overflow: hidden;
    background:
      radial-gradient(circle at 20% 18%, rgba(0,212,255,.12), transparent 30%),
      radial-gradient(circle at 80% 82%, rgba(10,102,194,.18), transparent 34%),
      linear-gradient(180deg, #0b1019 0%, #0d1320 100%);
  }

  .home-showcase-bg {
    position: absolute;
    inset: 0;
    z-index: 0;
    display: flex;
    align-items: stretch;
    justify-content: center;
    overflow: hidden;
  }

  .home-showcase-bg::before,
  .home-showcase-bg::after {
    content: '';
    position: absolute;
    inset: 0;
    pointer-events: none;
  }

  .home-showcase-bg::before {
    background:
      linear-gradient(90deg, rgba(8,11,18,.9) 0%, rgba(8,11,18,.4) 22%, rgba(8,11,18,.16) 50%, rgba(8,11,18,.4) 78%, rgba(8,11,18,.92) 100%),
      linear-gradient(180deg, rgba(8,11,18,.78) 0%, rgba(8,11,18,.18) 24%, rgba(8,11,18,.22) 76%, rgba(8,11,18,.84) 100%);
  }

  .home-showcase-bg::after {
    background-image:
      linear-gradient(rgba(0,212,255,.07) 1px, transparent 1px),
      linear-gradient(90deg, rgba(0,212,255,.07) 1px, transparent 1px);
    background-size: 86px 86px;
    opacity: .22;
    mix-blend-mode: screen;
  }

  .home-showcase-wall {
    width: min(1320px, calc(100% - 64px));
    height: 100%;
    padding: 24px 0;
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 18px;
    align-items: center;
  }

  .home-showcase-column {
    display: flex;
    flex-direction: column;
    gap: 18px;
    will-change: transform;
    animation-duration: var(--showcase-duration, 20s);
    animation-delay: var(--showcase-delay, 0s);
    animation-timing-function: ease-in-out;
    animation-iteration-count: infinite;
    animation-direction: alternate;
  }

  .home-showcase-column.is-moving-up {
    animation-name: homeShowcaseRise;
  }

  .home-showcase-column.is-moving-down {
    animation-name: homeShowcaseFall;
  }

  @keyframes homeShowcaseRise {
    from { transform: translateY(var(--showcase-drift, 64px)); }
    to { transform: translateY(calc(var(--showcase-drift, 64px) * -1)); }
  }

  @keyframes homeShowcaseFall {
    from { transform: translateY(calc(var(--showcase-drift, 64px) * -1)); }
    to { transform: translateY(var(--showcase-drift, 64px)); }
  }

  .home-showcase-card {
    border-radius: 28px;
    overflow: hidden;
    border: 1px solid rgba(255,255,255,.09);
    background: rgba(10,14,23,.78);
    box-shadow:
      0 22px 60px rgba(0,0,0,.28),
      0 0 0 1px rgba(255,255,255,.03) inset;
    backdrop-filter: blur(12px);
  }

  .home-showcase-browser {
    display: flex;
    align-items: center;
    gap: 12px;
    min-height: 38px;
    padding: 10px 14px;
    background: rgba(255,255,255,.05);
    border-bottom: 1px solid rgba(255,255,255,.05);
  }

  .home-showcase-dots {
    display: inline-flex;
    gap: 6px;
  }

  .home-showcase-dots span {
    width: 8px;
    height: 8px;
    border-radius: 999px;
    background: rgba(255,255,255,.28);
  }

  .home-showcase-dots span:first-child {
    background: rgba(255,95,87,.95);
  }

  .home-showcase-dots span:nth-child(2) {
    background: rgba(255,189,46,.92);
  }

  .home-showcase-dots span:nth-child(3) {
    background: rgba(39,201,63,.92);
  }

  .home-showcase-url {
    color: rgba(232,236,244,.66);
    font-size: .74rem;
    letter-spacing: .03em;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
  }

  .home-showcase-screen {
    min-height: 252px;
    padding: 18px;
    display: flex;
    flex-direction: column;
    background:
      radial-gradient(circle at top right, var(--showcase-glow, rgba(0,212,255,.2)), transparent 42%),
      linear-gradient(180deg, var(--showcase-tint, rgba(0,212,255,.08)) 0%, rgba(255,255,255,.02) 100%),
      linear-gradient(155deg, var(--showcase-start, rgba(14,26,58,.96)) 0%, var(--showcase-end, rgba(10,102,194,.88)) 100%);
  }

  .home-showcase-card-top,
  .home-showcase-actions {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 12px;
  }

  .home-showcase-card-top {
    justify-content: space-between;
    margin-bottom: 16px;
  }

  .home-showcase-kicker,
  .home-showcase-chip,
  .home-showcase-tags span {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border-radius: 999px;
    font-size: .72rem;
    font-weight: 700;
    letter-spacing: .04em;
  }

  .home-showcase-kicker {
    padding: 7px 12px;
    color: #f6fbff;
    background: rgba(255,255,255,.12);
    border: 1px solid rgba(255,255,255,.12);
  }

  .home-showcase-icon {
    width: 42px;
    height: 42px;
    border-radius: 16px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    background: rgba(255,255,255,.14);
    border: 1px solid rgba(255,255,255,.12);
    font-size: 1.15rem;
  }

  .home-showcase-card-title {
    font-size: 1.28rem;
    line-height: 1.18;
    margin-bottom: 10px;
  }

  .home-showcase-card-copy {
    color: rgba(232,236,244,.74);
    font-size: .92rem;
    line-height: 1.65;
    display: -webkit-box;
    -webkit-line-clamp: 3;
    -webkit-box-orient: vertical;
    overflow: hidden;
  }

  .home-showcase-wireframe {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 10px;
    margin: 18px 0 16px;
  }

  .home-showcase-wireframe span {
    min-height: 52px;
    border-radius: 16px;
    border: 1px solid rgba(255,255,255,.08);
    background: rgba(255,255,255,.08);
  }

  .home-showcase-wireframe span.is-wide {
    min-height: 78px;
    grid-row: span 2;
  }

  .home-showcase-wireframe span.is-primary {
    background: linear-gradient(135deg, rgba(255,255,255,.22), rgba(255,255,255,.08));
  }

  .home-showcase-wireframe span.is-soft {
    background: rgba(255,255,255,.05);
  }

  .home-showcase-chip-row {
    margin-top: auto;
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
  }

  .home-showcase-chip {
    padding: 8px 11px;
    color: rgba(255,255,255,.92);
    background: rgba(9,12,18,.22);
    border: 1px solid rgba(255,255,255,.1);
  }

  .home-showcase-overlay {
    position: relative;
    z-index: 1;
    min-height: inherit;
    display: flex;
    align-items: center;
    justify-content: center;
    padding-top: 76px;
    padding-bottom: 76px;
  }

  .home-showcase-focus {
    width: min(720px, 100%);
    padding: 34px 38px;
    text-align: center;
    border-radius: 32px;
    border: 1px solid rgba(255,255,255,.08);
    background:
      linear-gradient(180deg, rgba(10,14,22,.78), rgba(10,14,22,.88)),
      radial-gradient(circle at top, rgba(0,212,255,.1), transparent 48%);
    backdrop-filter: blur(16px);
    box-shadow: 0 28px 70px rgba(0,0,0,.34);
  }

  .home-showcase-focus .section-title,
  .home-showcase-focus .section-desc {
    margin-left: auto;
    margin-right: auto;
  }

  .home-showcase-desc {
    max-width: 620px;
  }

  .home-showcase-tags {
    margin-top: 20px;
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    gap: 10px;
  }

  .home-showcase-tags span {
    padding: 9px 14px;
    color: rgba(232,236,244,.88);
    background: rgba(255,255,255,.05);
    border: 1px solid rgba(255,255,255,.08);
  }

  .home-showcase-actions {
    margin-top: 26px;
    flex-wrap: wrap;
  }

  .home-showcase-legacy {
    display: none;
  }

  @media (max-width: 1180px) {
    .home-showcase-wall {
      width: calc(100% - 48px);
      grid-template-columns: repeat(3, minmax(0, 1fr));
    }
  }

  @media (max-width: 900px) {
    .home-showcase-section {
      min-height: 740px;
    }

    .home-showcase-wall {
      width: calc(100% - 32px);
      grid-template-columns: repeat(2, minmax(0, 1fr));
      gap: 14px;
    }

    .home-showcase-column {
      gap: 14px;
    }

    .home-showcase-focus {
      width: min(640px, 100%);
      padding: 30px 28px;
    }
  }

  @media (max-width: 640px) {
    .home-showcase-section {
      min-height: 660px;
    }

    .home-showcase-overlay {
      align-items: flex-end;
      padding-top: 108px;
      padding-bottom: 38px;
    }

    .home-showcase-wall {
      width: calc(100% - 20px);
      padding: 18px 0;
      gap: 10px;
    }

    .home-showcase-card {
      border-radius: 22px;
    }

    .home-showcase-screen {
      min-height: 208px;
      padding: 14px;
    }

    .home-showcase-card-title {
      font-size: 1rem;
    }

    .home-showcase-card-copy {
      font-size: .78rem;
      line-height: 1.5;
      -webkit-line-clamp: 2;
    }

    .home-showcase-wireframe {
      gap: 8px;
      margin: 14px 0 12px;
    }

    .home-showcase-wireframe span {
      min-height: 40px;
      border-radius: 12px;
    }

    .home-showcase-wireframe span.is-wide {
      min-height: 60px;
    }

    .home-showcase-chip-row {
      gap: 6px;
    }

    .home-showcase-chip {
      padding: 6px 9px;
      font-size: .64rem;
    }

    .home-showcase-focus {
      padding: 24px 18px 20px;
      border-radius: 26px;
    }

    .home-showcase-tags {
      gap: 8px;
    }

    .home-showcase-tags span {
      padding: 7px 11px;
      font-size: .66rem;
    }

    .home-showcase-actions {
      margin-top: 18px;
      gap: 10px;
    }

    .home-showcase-actions .btn {
      width: 100%;
      justify-content: center;
    }
  }

  .home-project-grid {
    margin-bottom: 28px;
  }

  .home-projects-cta {
    margin-top: 0;
  }

  .landing-preview-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
    gap: 24px;
  }

  .landing-preview-card {
    position: relative;
    padding: 32px;
    border-radius: 28px;
    border: 1px solid rgba(255,255,255,.08);
    background:
      radial-gradient(circle at top right, rgba(0,212,255,.12), transparent 34%),
      linear-gradient(160deg, rgba(17,23,38,.98), rgba(9,13,22,.98));
    box-shadow: var(--shadow-sm);
  }

  .landing-preview-top,
  .landing-breadcrumb {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
  }

  .landing-preview-kicker,
  .landing-preview-index {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: 6px 12px;
    border-radius: 999px;
    font-size: .72rem;
    font-weight: 700;
    letter-spacing: .4px;
    background: rgba(255,255,255,.06);
  }

  .landing-preview-kicker {
    color: var(--accent);
    background: rgba(0,212,255,.08);
  }

  .landing-preview-title {
    font-size: 1.35rem;
    line-height: 1.25;
    margin: 24px 0 14px;
  }

  .landing-preview-copy {
    color: var(--text-muted);
    line-height: 1.75;
  }

  .landing-preview-bullets {
    display: grid;
    gap: 10px;
    margin: 24px 0 28px;
    color: var(--text-muted);
    font-size: .92rem;
  }

  .landing-preview-bullets span {
    position: relative;
    padding-left: 18px;
  }

  .landing-preview-bullets span::before {
    content: '';
    position: absolute;
    top: .55rem;
    left: 0;
    width: 8px;
    height: 8px;
    border-radius: 999px;
    background: var(--accent);
    box-shadow: 0 0 0 6px rgba(0,212,255,.09);
  }

  .landing-page-shell {
    position: relative;
    min-height: 100vh;
    overflow: hidden;
    padding: 128px 0 96px;
    background: var(--dark);
  }

  .landing-page-body {
    position: relative;
    z-index: 1;
  }

  .landing-page-head {
    max-width: 760px;
    margin-bottom: 40px;
  }

  .landing-breadcrumb {
    justify-content: flex-start;
    margin-bottom: 18px;
    color: var(--text-muted);
    font-size: .9rem;
  }

  .landing-breadcrumb-link {
    appearance: none;
    background: transparent;
    border: 0;
    color: var(--text-inv);
    cursor: pointer;
    font-size: .9rem;
    padding: 0;
  }

  .landing-breadcrumb-link:hover {
    color: var(--accent);
  }

  .landing-page-cta {
    margin-top: 28px;
  }

  .contact-view-shell .newsletter-section {
    padding: 0;
    background: transparent;
  }

  /* ──────────────────────────────────────────
     SERVICES
  ────────────────────────────────────────── */
  .services-grid {
    display: grid; grid-template-columns: repeat(auto-fit, minmax(300px, 1fr));
    gap: 24px;
  }
  .service-card {
    background: var(--dark-3); border: 1px solid var(--border);
    border-radius: var(--radius-lg); padding: 36px 32px;
    transition: all .3s ease; position: relative; overflow: hidden;
  }
  .service-card::before {
    content: ''; position: absolute; top: 0; left: 0; right: 0; height: 3px;
    background: linear-gradient(90deg, var(--primary), var(--accent));
    opacity: 0; transition: opacity .3s;
  }
  .service-card:hover { border-color: rgba(0,212,255,.25); transform: translateY(-6px); box-shadow: var(--shadow); }
  .service-card:hover::before { opacity: 1; }

  .service-icon {
    width: 56px; height: 56px; border-radius: 14px;
    background: linear-gradient(135deg, rgba(10,102,194,.3), rgba(0,212,255,.1));
    display: flex; align-items: center; justify-content: center;
    font-size: 1.5rem; margin-bottom: 20px;
    border: 1px solid rgba(10,102,194,.3);
  }
  .service-title { font-size: 1.1rem; font-weight: 700; margin-bottom: 12px; }
  .service-desc { color: var(--text-muted); font-size: .9rem; line-height: 1.7; margin-bottom: 20px; }
  .service-tags { display: flex; flex-wrap: wrap; gap: 8px; }
  .service-tag {
    background: rgba(255,255,255,.05); border: 1px solid var(--border);
    border-radius: 4px; padding: 3px 10px; font-size: .75rem; color: var(--text-muted);
  }

  /* ──────────────────────────────────────────
     PORTFOLIO
  ────────────────────────────────────────── */
  .portfolio-grid {
    display: grid; grid-template-columns: repeat(3, 1fr); gap: 20px;
  }
  .portfolio-card {
    border-radius: var(--radius); overflow: hidden;
    position: relative; aspect-ratio: 4/3;
    cursor: pointer; group: true;
  }
  .portfolio-bg {
    width: 100%; height: 100%; transition: transform .4s ease;
    display: flex; align-items: center; justify-content: center; font-size: 3rem;
  }
  .portfolio-card:hover .portfolio-bg { transform: scale(1.05); }
  .portfolio-overlay {
    position: absolute; inset: 0;
    background: linear-gradient(to top, rgba(0,0,0,.85) 0%, transparent 60%);
    display: flex; flex-direction: column; justify-content: flex-end;
    padding: 20px; opacity: 0; transition: opacity .3s;
  }
  .portfolio-card:hover .portfolio-overlay { opacity: 1; }
  .portfolio-label { font-size: .7rem; color: var(--accent); font-weight: 700; text-transform: uppercase; letter-spacing: 2px; }
  .portfolio-name { font-family: 'Montserrat', sans-serif; font-size: 1rem; font-weight: 700; }

  .portfolio-card:nth-child(1) .portfolio-bg { background: linear-gradient(135deg, #0A66C2, #00D4FF); }
  .portfolio-card:nth-child(2) .portfolio-bg { background: linear-gradient(135deg, #1a1a2e, #16213e); }
  .portfolio-card:nth-child(3) .portfolio-bg { background: linear-gradient(135deg, #0D0F14, #0A66C2); }
  .portfolio-card:nth-child(4) .portfolio-bg { background: linear-gradient(135deg, #141720, #00D4FF); }
  .portfolio-card:nth-child(5) .portfolio-bg { background: linear-gradient(135deg, #0A66C2, #141720); }
  .portfolio-card:nth-child(6) .portfolio-bg { background: linear-gradient(135deg, #00D4FF, #0A66C2); }

  /* ──────────────────────────────────────────
     CLIENTS LOGOS
  ────────────────────────────────────────── */
.logos-row {
  overflow: hidden;
  width: 100%;
  margin-top: 40px;
}

.logos-track {
  display: flex;
  gap: 16px;
  width: max-content;
  animation: logosScroll 25s linear infinite;
}

@keyframes logosScroll {
  0% {
    transform: translateX(0);
  }
  100% {
    transform: translateX(-50%);
  }
}
  .logo-chip {
    background: var(--dark-3); border: 1px solid var(--border);
    border-radius: 10px; padding: 14px 28px;
    font-family: 'Montserrat', sans-serif; font-weight: 700; font-size: .85rem;
    color: var(--text-muted); transition: all .25s;
  }
  .logo-chip:hover { border-color: var(--accent); color: var(--text-inv); }

  /* ──────────────────────────────────────────
     CTA SECTION
  ────────────────────────────────────────── */
  .cta-box {
    background: linear-gradient(135deg, rgba(10,102,194,.25), rgba(0,212,255,.1));
    border: 1px solid rgba(0,212,255,.2);
    border-radius: 24px; padding: 64px 48px; text-align: center;
    position: relative; overflow: hidden;
  }
  .cta-box::before {
    content: ''; position: absolute;
    width: 300px; height: 300px; border-radius: 50%;
    background: radial-gradient(circle, rgba(0,212,255,.15), transparent 70%);
    top: -100px; right: -100px;
  }

  /* ──────────────────────────────────────────
     FOOTER
  ────────────────────────────────────────── */
  footer {
    background: var(--dark-2); border-top: 1px solid var(--border);
    padding: 48px 0 24px;
  }
  .footer-grid { display: grid; grid-template-columns: 2fr 1fr 1fr 1fr; gap: 40px; margin-bottom: 40px; }
  .footer-brand p { color: var(--text-muted); font-size: .875rem; line-height: 1.7; margin-top: 12px; max-width: 280px; }
  .footer-col h5 { font-size: .8rem; font-weight: 700; text-transform: uppercase; letter-spacing: 2px; color: var(--text-muted); margin-bottom: 16px; }
  .footer-link { display: block; color: var(--text-muted); text-decoration: none; font-size: .875rem; margin-bottom: 10px; transition: color .2s; }
  .footer-link:hover { color: var(--accent); }
  .footer-bottom { border-top: 1px solid var(--border); padding-top: 24px; display: flex; justify-content: space-between; align-items: center; }
  .footer-bottom p { font-size: .8rem; color: var(--text-muted); }

  /* ──────────────────────────────────────────
     WHATSAPP BUTTON
  ────────────────────────────────────────── */
  #wabtn {
      position: fixed; bottom: 28px; right: 28px; z-index: 800;
      width: 72px; height: 72px; border-radius: 22px;
      background: transparent;
      border: none; cursor: pointer;
      display: flex; align-items: center; justify-content: center;
      box-shadow: none;
      transition: transform .25s, box-shadow .25s;
      padding: 0;
      overflow: visible;
    }
  #wabtn > span {
    display: none;
  }
  #wabtn:hover { transform: translateY(-2px) scale(1.04); box-shadow: none; }
  .wa-icon-image {
      width: 100%;
      height: 100%;
      object-fit: cover;
      display: block;
      filter: drop-shadow(0 10px 20px rgba(69,98,246,.34));
    }
  #wabtn .wa-tooltip {
    position: absolute; right: 70px; background: var(--dark-3);
    border: 1px solid var(--border); color: var(--text-inv);
    padding: 6px 14px; border-radius: 8px; font-size: .8rem;
    white-space: nowrap; opacity: 0; pointer-events: none;
    transition: opacity .2s;
  }
  #wabtn:hover .wa-tooltip { opacity: 1; }

  /* ──────────────────────────────────────────
     MODAL
  ────────────────────────────────────────── */
  .modal-bg {
    position: fixed; inset: 0; z-index: 1000;
    background: rgba(0,0,0,.7); backdrop-filter: blur(8px);
    display: flex; align-items: center; justify-content: center;
    padding: 20px;
    overflow-x: hidden;
    overflow-y: auto;
    overscroll-behavior: contain;
  }
  .modal {
    background: var(--dark-2); border: 1px solid var(--border);
    border-radius: var(--radius-lg); padding: 40px; width: 100%; max-width: 440px;
    animation: modalIn .3s ease;
    max-height: calc(100vh - 40px);
    overflow-x: hidden;
    overflow-y: auto;
    -webkit-overflow-scrolling: touch;
  }
  @keyframes modalIn { from { opacity:0; transform: scale(.95) translateY(20px); } to { opacity:1; transform: scale(1) translateY(0); } }

  .modal-logo { font-family: 'Montserrat', sans-serif; font-weight: 900; font-size: 1.4rem;
    background: linear-gradient(135deg, var(--accent), var(--primary));
    -webkit-background-clip: text; -webkit-text-fill-color: transparent; margin-bottom: 6px; }
  .modal-sub { color: var(--text-muted); font-size: .875rem; margin-bottom: 28px; }
  .modal-tabs { display: flex; background: var(--dark-3); border-radius: 8px; padding: 4px; margin-bottom: 28px; }
  .modal-tab { flex: 1; padding: 8px; border: none; background: transparent; color: var(--text-muted);
    font-family: 'Inter', sans-serif; font-size: .875rem; border-radius: 6px; cursor: pointer; transition: all .2s; }
  .modal-tab.active { background: var(--primary); color: #fff; }

  .auth-modal {
    max-width: 500px;
    padding: 30px;
    border-radius: 28px;
    background:
      radial-gradient(circle at 16% 4%, rgba(0, 212, 255, .18), transparent 34%),
      radial-gradient(circle at 84% 0%, rgba(69, 98, 246, .22), transparent 38%),
      linear-gradient(145deg, rgba(22, 26, 39, .98), rgba(12, 15, 24, .98));
    box-shadow: 0 28px 90px rgba(0, 0, 0, .42), inset 0 1px 0 rgba(255, 255, 255, .04);
  }

  .auth-card-top {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    gap: 18px;
    margin-bottom: 22px;
  }

  .auth-card-top .modal-sub {
    margin-bottom: 0;
    line-height: 1.55;
  }

  .auth-close-btn {
    width: 36px;
    height: 36px;
    border-radius: 999px;
    border: 1px solid rgba(255, 255, 255, .08);
    background: rgba(255, 255, 255, .03);
    color: var(--text-muted);
    cursor: pointer;
    font-size: 1.35rem;
    line-height: 1;
    transition: color .2s, border-color .2s, background .2s, transform .2s;
  }

  .auth-close-btn:hover {
    color: var(--text-inv);
    border-color: rgba(0, 212, 255, .38);
    background: rgba(0, 212, 255, .08);
    transform: rotate(6deg);
  }

  .auth-modal .modal-tabs {
    margin-bottom: 20px;
    padding: 5px;
    border: 1px solid rgba(255, 255, 255, .06);
    background: rgba(255, 255, 255, .045);
    border-radius: 16px;
  }

  .auth-modal .modal-tab {
    padding: 11px 10px;
    border-radius: 12px;
    font-weight: 800;
  }

  .auth-modal .modal-tab.active {
    background: linear-gradient(135deg, rgba(0, 212, 255, .95), rgba(69, 98, 246, .95));
    box-shadow: 0 10px 28px rgba(0, 143, 255, .24);
  }

  .auth-form {
    display: flex;
    flex-direction: column;
    gap: 13px;
  }

  .auth-field {
    display: flex;
    flex-direction: column;
    gap: 8px;
  }

  .auth-input-shell {
    min-height: 52px;
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 0 13px;
    border-radius: 15px;
    border: 1px solid rgba(255, 255, 255, .1);
    background: rgba(255, 255, 255, .045);
    transition: border-color .2s, background .2s, box-shadow .2s;
  }

  .auth-input-shell:focus-within {
    border-color: rgba(0, 212, 255, .65);
    background: rgba(0, 212, 255, .06);
    box-shadow: 0 0 0 4px rgba(0, 212, 255, .08);
  }

  .auth-input-shell svg {
    width: 19px;
    height: 19px;
    flex: 0 0 19px;
    fill: var(--accent);
    opacity: .9;
  }

  .auth-input,
  .form-input.auth-soft-input {
    width: 100%;
    min-width: 0;
    border: 0;
    outline: 0;
    background: transparent;
    color: var(--text-inv);
    font-family: 'Inter', sans-serif;
    font-size: .92rem;
  }

  .form-input.auth-soft-input {
    border: 1px solid rgba(255, 255, 255, .1);
    background: rgba(255, 255, 255, .045);
    border-radius: 15px;
    min-height: 52px;
    padding: 0 14px;
  }

  .form-input.auth-soft-input:focus {
    border-color: rgba(0, 212, 255, .65);
    box-shadow: 0 0 0 4px rgba(0, 212, 255, .08);
  }

  .auth-input::placeholder,
  .form-input.auth-soft-input::placeholder {
    color: rgba(161, 169, 192, .74);
  }

  .auth-eye-btn {
    width: 34px;
    height: 34px;
    flex: 0 0 34px;
    display: grid;
    place-items: center;
    border: 0;
    border-radius: 999px;
    background: transparent;
    color: var(--text-muted);
    cursor: pointer;
    transition: background .2s, color .2s;
  }

  .auth-eye-btn:hover,
  .auth-eye-btn.is-visible {
    background: rgba(255, 255, 255, .07);
    color: var(--text-inv);
  }

  .auth-eye-btn svg {
    width: 18px;
    height: 18px;
    fill: currentColor;
  }

  .auth-options {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 14px;
    font-size: .82rem;
    color: var(--text-muted);
  }

  .auth-check {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    cursor: pointer;
  }

  .auth-check input {
    accent-color: var(--accent);
  }

  .auth-link-btn,
  .auth-switch-copy button {
    border: 0;
    background: transparent;
    color: var(--accent);
    font-weight: 800;
    cursor: pointer;
    padding: 0;
    font-family: 'Inter', sans-serif;
  }

  .auth-link-btn:hover,
  .auth-switch-copy button:hover {
    color: var(--primary);
  }

  .auth-submit-btn {
    width: 100%;
    min-height: 52px;
    border-radius: 15px;
    cursor: pointer;
    font-family: 'Inter', sans-serif;
    font-weight: 900;
    transition: transform .2s, box-shadow .2s, border-color .2s, background .2s;
  }

  .auth-submit-btn {
    border: 0;
    color: #fff;
    background: linear-gradient(135deg, var(--accent), var(--primary));
    box-shadow: 0 16px 34px rgba(0, 143, 255, .28);
  }

  .auth-submit-btn:hover {
    transform: translateY(-2px);
  }

  .auth-switch-copy {
    margin: 0;
    text-align: center;
    color: var(--text-muted);
    font-size: .86rem;
  }

  .auth-modal .modal-footer {
    margin-top: 18px;
    line-height: 1.5;
  }

  .form-group { margin-bottom: 18px; }
  .form-label { display: block; font-size: .8rem; font-weight: 600; color: var(--text-muted); margin-bottom: 7px; }
  .form-input {
    width: 100%; background: var(--dark-3); border: 1px solid var(--border);
    border-radius: 8px; padding: 11px 14px; color: var(--text-inv);
    font-family: 'Inter', sans-serif; font-size: .9rem;
    transition: border-color .2s;
  }
  .form-input:focus { outline: none; border-color: var(--primary); }
  .form-input::placeholder { color: var(--text-muted); }

  .modal-footer { margin-top: 20px; text-align: center; font-size: .8rem; color: var(--text-muted); }

  /* Role demo selector */
  .role-demo {
    background: rgba(0,212,255,.06); border: 1px solid rgba(0,212,255,.15);
    border-radius: 10px; padding: 14px 16px; margin-top: 16px;
    display: flex; align-items: center; justify-content: space-between;
  }
  .role-demo p { font-size: .8rem; color: var(--text-muted); }
  .role-btns { display: flex; gap: 8px; }
  .role-btn {
    padding: 5px 12px; border-radius: 6px; font-size: .75rem; font-weight: 600;
    cursor: pointer; border: 1px solid var(--border); background: transparent;
    color: var(--text-muted); transition: all .2s;
  }
  .role-btn:hover { border-color: var(--accent); color: var(--accent); }

  /* ──────────────────────────────────────────
     CLIENT PANEL
  ────────────────────────────────────────── */
  #client-panel {
    padding-top: 68px; min-height: 100vh;
    background: var(--dark);
  }
  .client-layout { display: flex; min-height: calc(100vh - 68px); }
  .client-sidebar {
    width: 240px; flex-shrink: 0;
    background: var(--dark-2); border-right: 1px solid var(--border);
    padding: 28px 16px;
  }
  .sidebar-section { margin-bottom: 8px; }
  .sidebar-label { font-size: .7rem; font-weight: 700; letter-spacing: 2px; text-transform: uppercase;
    color: var(--text-muted); padding: 0 12px; margin-bottom: 6px; margin-top: 20px; }
  .sidebar-link {
    display: flex; align-items: center; gap: 10px;
    padding: 10px 12px; border-radius: 8px; color: var(--text-muted);
    font-size: .875rem; text-decoration: none; cursor: pointer;
    transition: all .2s; border: none; background: transparent; width: 100%; text-align: left;
  }
  .sidebar-link:hover, .sidebar-link.active { background: rgba(255,255,255,.06); color: var(--text-inv); }
  .sidebar-link.active { color: var(--accent); }
  .sidebar-icon { font-size: 1rem; width: 20px; text-align: center; }

  .client-main { flex: 1; padding: 32px; overflow-y: auto; }

  .panel-header { margin-bottom: 32px; }
  .panel-title { font-size: 1.5rem; font-weight: 800; margin-bottom: 6px; }
  .panel-sub { color: var(--text-muted); font-size: .875rem; }

  .metrics-row { display: grid; grid-template-columns: repeat(3, 1fr); gap: 16px; margin-bottom: 28px; }
  .metric-card {
    background: var(--dark-2); border: 1px solid var(--border); border-radius: var(--radius);
    padding: 20px 24px;
  }
  .metric-label { font-size: .8rem; color: var(--text-muted); margin-bottom: 8px; }
  .metric-value { font-family: 'Montserrat', sans-serif; font-size: 1.8rem; font-weight: 800; }
  .metric-sub { font-size: .75rem; color: var(--text-muted); margin-top: 4px; }

  /* Progress */
  .progress-section { background: var(--dark-2); border: 1px solid var(--border); border-radius: var(--radius); padding: 24px; margin-bottom: 28px; }
  .progress-head { display: flex; align-items: center; justify-content: space-between; margin-bottom: 20px; }
  .milestone { margin-bottom: 18px; }
  .milestone-top { display: flex; justify-content: space-between; font-size: .875rem; margin-bottom: 6px; }
  .milestone-name { font-weight: 500; }
  .milestone-pct { color: var(--text-muted); }
  .progress-bar { height: 8px; background: rgba(255,255,255,.07); border-radius: 4px; overflow: hidden; }
  .progress-fill { height: 100%; border-radius: 4px; background: linear-gradient(90deg, var(--primary), var(--accent)); transition: width .5s ease; }
  .progress-fill.done { background: var(--success); }

  /* Messages */
  .messages-section { background: var(--dark-2); border: 1px solid var(--border); border-radius: var(--radius); padding: 24px; }
  .message-item { display: flex; gap: 12px; padding: 14px 0; border-bottom: 1px solid var(--border); }
  .message-item:last-child { border-bottom: none; }
  .msg-avatar { width: 36px; height: 36px; border-radius: 50%; flex-shrink: 0;
    background: linear-gradient(135deg, var(--primary), var(--accent));
    display: flex; align-items: center; justify-content: center; font-size: .75rem; font-weight: 700; }
  .msg-body p { font-size: .875rem; margin-bottom: 2px; }
  .msg-body span { font-size: .75rem; color: var(--text-muted); }
  .msg-unread { width: 8px; height: 8px; border-radius: 50%; background: var(--accent); margin-left: auto; align-self: center; flex-shrink: 0; }

  /* Wizard */
  .wizard-wrap { max-width: 640px; }
  .wizard-progress { display: flex; align-items: center; gap: 0; margin-bottom: 40px; }
  .wizard-step {
    display: flex; flex-direction: column; align-items: center; gap: 8px; flex: 1;
    position: relative;
  }
  .wizard-step:not(:last-child)::after {
    content: ''; position: absolute; top: 16px; left: 50%; width: 100%;
    height: 2px; background: var(--border);
  }
  .wizard-step.done::after, .wizard-step.active::after { background: var(--primary); }
  .ws-circle {
    width: 32px; height: 32px; border-radius: 50%; border: 2px solid var(--border);
    display: flex; align-items: center; justify-content: center; font-size: .8rem; font-weight: 700;
    background: var(--dark-3); position: relative; z-index: 1;
  }
  .wizard-step.active .ws-circle { border-color: var(--accent); color: var(--accent); }
  .wizard-step.done .ws-circle { border-color: var(--primary); background: var(--primary); color: #fff; }
  .ws-label { font-size: .7rem; color: var(--text-muted); text-align: center; max-width: 70px; }
  .wizard-step.active .ws-label { color: var(--accent); }

  .wizard-card { background: var(--dark-2); border: 1px solid var(--border); border-radius: var(--radius-lg); padding: 32px; }
  .wizard-title { font-size: 1.1rem; font-weight: 700; margin-bottom: 6px; }
  .wizard-sub { font-size: .875rem; color: var(--text-muted); margin-bottom: 24px; }
  .textarea-input {
    width: 100%; background: var(--dark-3); border: 1px solid var(--border);
    border-radius: 8px; padding: 12px 14px; color: var(--text-inv);
    font-family: 'Inter', sans-serif; font-size: .875rem; resize: vertical; min-height: 100px;
  }
  .textarea-input:focus { outline: none; border-color: var(--primary); }

  .radio-group { display: flex; flex-direction: column; gap: 10px; }
  .radio-opt {
    display: flex; align-items: center; gap: 12px;
    background: var(--dark-3); border: 1px solid var(--border);
    border-radius: 8px; padding: 14px 16px; cursor: pointer;
    transition: all .2s;
  }
  .radio-opt:hover, .radio-opt.selected { border-color: var(--primary); background: rgba(10,102,194,.1); }
  .radio-dot { width: 18px; height: 18px; border-radius: 50%; border: 2px solid var(--border); flex-shrink: 0; }
  .radio-opt.selected .radio-dot { border-color: var(--primary); background: var(--primary); }
  .radio-text { font-size: .875rem; }

  .wizard-actions { display: flex; justify-content: space-between; align-items: center; margin-top: 24px; }

  /* ──────────────────────────────────────────
     ADMIN DASHBOARD
  ────────────────────────────────────────── */
  #admin-panel {
    padding-top: 68px; min-height: 100vh;
    background: var(--dark);
  }
  .admin-layout { display: flex; min-height: calc(100vh - 68px); }
  .admin-sidebar {
    width: 256px; flex-shrink: 0;
    background: var(--dark-2); border-right: 1px solid var(--border);
    padding: 20px 12px;
  }
  .admin-main { flex: 1; padding: 32px; overflow-y: auto; }

  .admin-nav-group { margin-bottom: 4px; }
  .admin-section-label { font-size: .65rem; font-weight: 700; letter-spacing: 2px;
    text-transform: uppercase; color: var(--text-muted); padding: 12px 12px 6px; }

  /* Metrics */
  .admin-metrics { display: grid; grid-template-columns: repeat(4, 1fr); gap: 16px; margin-bottom: 28px; }
  .admin-metric {
    background: var(--dark-2); border: 1px solid var(--border); border-radius: var(--radius);
    padding: 20px; position: relative; overflow: hidden;
  }
  .admin-metric::after {
    content: ''; position: absolute; top: 0; right: 0;
    width: 60px; height: 100%; opacity: .06;
  }
  .admin-metric.m-blue::after { background: var(--primary); }
  .admin-metric.m-cyan::after { background: var(--accent); }
  .admin-metric.m-green::after { background: var(--success); }
  .admin-metric.m-yellow::after { background: var(--warning); }
  .am-label { font-size: .75rem; color: var(--text-muted); margin-bottom: 8px; display: flex; align-items: center; justify-content: space-between; }
  .am-icon { font-size: 1.1rem; }
  .am-value { font-family: 'Montserrat', sans-serif; font-size: 2rem; font-weight: 800; margin-bottom: 4px; }
  .am-delta { font-size: .75rem; }
  .am-delta.up { color: var(--success); }
  .am-delta.down { color: var(--danger); }

  /* CRM Kanban */
  .kanban-board { display: grid; grid-template-columns: repeat(4, 1fr); gap: 16px; }
  .kanban-col { background: var(--dark-3); border-radius: var(--radius); padding: 16px; }
  .kanban-col-header { display: flex; align-items: center; justify-content: space-between; margin-bottom: 14px; }
  .kanban-col-title { font-size: .8rem; font-weight: 700; }
  .kanban-count { background: rgba(255,255,255,.08); border-radius: 20px; padding: 2px 8px; font-size: .7rem; }

  .kanban-card {
    background: var(--dark-2); border: 1px solid var(--border);
    border-radius: 8px; padding: 14px; margin-bottom: 10px;
    cursor: grab; transition: all .2s;
  }
  .kanban-card:hover { border-color: rgba(0,212,255,.3); transform: translateY(-2px); box-shadow: var(--shadow-sm); }
  .kc-name { font-size: .875rem; font-weight: 600; margin-bottom: 6px; }
  .kc-service { font-size: .75rem; color: var(--text-muted); margin-bottom: 10px; }
  .kc-footer { display: flex; align-items: center; justify-content: space-between; }
  .kc-date { font-size: .7rem; color: var(--text-muted); }
  .kc-avatar { width: 22px; height: 22px; border-radius: 50%; background: linear-gradient(135deg, var(--primary), var(--accent)); font-size: .6rem; display: flex; align-items: center; justify-content: center; font-weight: 700; }
  .kanban-board-triple { grid-template-columns: repeat(3, minmax(0, 1fr)); }
  .task-kanban-card { min-width: 0; }
  .task-card-meta {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 10px;
    flex-wrap: wrap;
    margin-bottom: 12px;
  }
  .task-due {
    font-size: .72rem;
    color: var(--text-muted);
  }
  .task-due.danger {
    color: #ffb5b5;
  }
  .task-field {
    display: grid;
    gap: 6px;
    margin-bottom: 10px;
  }
  .task-inline-label {
    font-size: .7rem;
    letter-spacing: .8px;
    text-transform: uppercase;
    color: var(--text-muted);
    font-weight: 700;
  }
  .task-inline-select {
    min-height: 42px;
    padding-top: 9px;
    padding-bottom: 9px;
    font-size: .82rem;
  }
  .admin-task-metric-grid {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 12px;
    margin-top: 18px;
  }
  .admin-task-metric-grid.compact {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
  .admin-task-metric-card {
    min-width: 0;
    padding: 14px 16px;
    border-radius: 16px;
    border: 1px solid rgba(255,255,255,.06);
    background: rgba(255,255,255,.04);
  }
  .admin-task-metric-card span {
    display: block;
    font-size: .74rem;
    color: var(--text-muted);
    margin-bottom: 6px;
  }
  .admin-task-metric-card strong {
    display: block;
    font-size: 1rem;
  }
  .task-top-member,
  .team-performance-identity {
    display: flex;
    align-items: center;
    gap: 14px;
    min-width: 0;
  }
  .task-top-member {
    margin-top: 18px;
  }
  .task-top-member-avatar,
  .team-performance-avatar {
    width: 46px;
    height: 46px;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    color: #fff;
    font-weight: 800;
    box-shadow: var(--shadow-sm);
  }
  .task-top-member p,
  .team-performance-identity p {
    color: var(--text-muted);
    font-size: .82rem;
    margin-top: 4px;
  }
  .team-performance-list {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 16px;
  }
  .team-performance-card {
    min-width: 0;
    padding: 20px;
    border-radius: 20px;
    border: 1px solid rgba(255,255,255,.08);
    background: rgba(255,255,255,.025);
  }
  .team-performance-head {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 14px;
    margin-bottom: 16px;
  }
  .performance-bar {
    height: 8px;
    border-radius: 999px;
    background: rgba(255,255,255,.08);
    overflow: hidden;
    margin-top: 14px;
  }
  .performance-bar span {
    display: block;
    height: 100%;
    border-radius: inherit;
  }

  /* Chart placeholder */
  .chart-area {
    background: var(--dark-2); border: 1px solid var(--border); border-radius: var(--radius);
    padding: 24px; margin-bottom: 28px;
  }
  .chart-area canvas { display: block; }
  .chart-legend { display: flex; gap: 20px; margin-top: 12px; }
  .legend-item { display: flex; align-items: center; gap: 6px; font-size: .75rem; color: var(--text-muted); }
  .legend-dot { width: 8px; height: 8px; border-radius: 50%; }

  /* Tabs */
  .tabs { display: flex; border-bottom: 1px solid var(--border); margin-bottom: 24px; }
  .tab-btn {
    padding: 10px 20px; border: none; background: transparent;
    color: var(--text-muted); font-family: 'Inter', sans-serif; font-size: .875rem;
    cursor: pointer; border-bottom: 2px solid transparent; margin-bottom: -1px;
    transition: all .2s;
  }
  .tab-btn.active { color: var(--accent); border-bottom-color: var(--accent); }
  .tab-btn:hover { color: var(--text-inv); }

  /* Responsive basic */
  @media (max-width: 900px) {
    .portfolio-grid { grid-template-columns: repeat(2, 1fr); }
    .footer-grid { grid-template-columns: 1fr 1fr; }
    .admin-metrics { grid-template-columns: repeat(2, 1fr); }
    .kanban-board { grid-template-columns: repeat(2, 1fr); }
    .admin-task-metric-grid,
    .team-performance-list { grid-template-columns: repeat(2, minmax(0, 1fr)); }
    .admin-sidebar, .client-sidebar { width: 200px; }
  }
  @media (max-width: 640px) {
    .portfolio-grid { grid-template-columns: 1fr; }
    .hero-stats { gap: 24px; }
    .metrics-row { grid-template-columns: 1fr; }
    .admin-task-metric-grid,
    .admin-task-metric-grid.compact,
    .team-performance-list { grid-template-columns: 1fr; }
    .team-performance-head,
    .task-top-member { flex-direction: column; align-items: flex-start; }
    .admin-layout, .client-layout { flex-direction: column; }
    .admin-sidebar, .client-sidebar { width: 100%; padding: 12px; }
  }

  /* Active view helper */
  .view { display: none; }
  .view.active { display: block; }
  
  /* Notification dot */
  .notif-dot { width: 6px; height: 6px; border-radius: 50%; background: var(--accent); margin-left: auto; }

  /* Access denied */
  .access-denied {
    display: flex; flex-direction: column; align-items: center; justify-content: center;
    min-height: 60vh; text-align: center; gap: 16px;
  }
  .access-icon { font-size: 3rem; }

  .nav-logo-btn {
    border: none;
    background: transparent;
    cursor: pointer;
  }

  .portfolio-card-button {
    border: none;
    padding: 0;
    background: transparent;
    text-align: left;
  }

  .logo-chip-button {
    cursor: pointer;
  }

  .portfolio-summary {
    color: rgba(255,255,255,.76);
    font-size: .78rem;
    margin-top: 8px;
    line-height: 1.55;
  }

  .logos-caption {
    margin: 0 auto 32px;
    text-align: center;
  }

  .newsletter-section {
    position: relative;
    overflow: hidden;
  }

  .newsletter-section::before {
    content: '';
    position: absolute;
    inset: auto 10% -140px auto;
    width: 320px;
    height: 320px;
    border-radius: 50%;
    background: radial-gradient(circle, rgba(0,212,255,.12), transparent 68%);
    pointer-events: none;
  }

  .newsletter-card {
    position: relative;
    z-index: 1;
    display: grid;
    grid-template-columns: 1fr 1.15fr;
    gap: 32px;
    background: linear-gradient(145deg, rgba(10,102,194,.14), rgba(28,33,48,.95));
    border: 1px solid rgba(0,212,255,.12);
    border-radius: 28px;
    padding: 40px;
    box-shadow: var(--shadow);
  }

  .newsletter-copy {
    display: flex;
    flex-direction: column;
    gap: 18px;
  }

  .newsletter-form {
    background: rgba(13,15,20,.55);
    border: 1px solid rgba(255,255,255,.06);
    border-radius: 20px;
    padding: 28px;
  }

  .newsletter-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 16px;
  }

  .form-select {
    appearance: none;
    background-image:
      linear-gradient(45deg, transparent 50%, var(--text-muted) 50%),
      linear-gradient(135deg, var(--text-muted) 50%, transparent 50%);
    background-position:
      calc(100% - 22px) calc(50% - 3px),
      calc(100% - 16px) calc(50% - 3px);
    background-size: 6px 6px, 6px 6px;
    background-repeat: no-repeat;
  }

  .support-grid {
    display: grid;
    gap: 14px;
  }

  .support-chip {
    padding: 16px 18px;
    border-radius: 16px;
    background: rgba(255,255,255,.04);
    border: 1px solid rgba(255,255,255,.08);
  }

  .support-chip strong {
    display: block;
    margin-bottom: 6px;
  }

  .support-chip span {
    color: var(--text-muted);
    font-size: .85rem;
  }

  .cta-text {
    color: var(--text-muted);
    margin: 16px auto 32px;
    max-width: 520px;
  }

  .team-experts-section {
    position: relative;
    overflow: hidden;
  }

  .about-view-shell .landing-page-head {
    max-width: 860px;
  }

  .about-team-section {
    padding: 18px 0 0;
  }

  .about-team-section .container {
    padding: 0;
  }

  .team-experts-section::before {
    content: '';
    position: absolute;
    inset: 40px auto auto 8%;
    width: 320px;
    height: 320px;
    border-radius: 50%;
    background: radial-gradient(circle, rgba(0,212,255,.12), transparent 68%);
    pointer-events: none;
    filter: blur(10px);
  }

  .team-experts-section::after {
    content: '';
    position: absolute;
    right: 6%;
    bottom: 60px;
    width: 280px;
    height: 280px;
    border-radius: 50%;
    background: radial-gradient(circle, rgba(10,102,194,.12), transparent 70%);
    pointer-events: none;
    filter: blur(12px);
  }

  .team-experts-head {
    max-width: 760px;
    margin: 0 auto 42px;
    text-align: center;
    position: relative;
    z-index: 1;
  }

  .team-experts-grid {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 24px;
    position: relative;
    z-index: 1;
  }

  .expert-card {
    border-radius: 28px;
    overflow: hidden;
    border: 1px solid rgba(255,255,255,.08);
    background:
      linear-gradient(180deg, rgba(255,255,255,.03), rgba(255,255,255,.01)),
      linear-gradient(165deg, rgba(17,23,38,.98), rgba(8,11,18,.98));
    box-shadow: 0 18px 48px rgba(0,0,0,.28);
    min-height: 100%;
    position: relative;
  }

  .expert-card::before {
    content: '';
    position: absolute;
    inset: 0;
    background: linear-gradient(180deg, rgba(255,255,255,.03), transparent 30%);
    pointer-events: none;
  }

  .expert-visual {
    padding: 22px 22px 0;
    position: relative;
  }

  .expert-badge {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: 7px 12px;
    border-radius: 999px;
    font-size: .72rem;
    font-weight: 700;
    letter-spacing: 1.4px;
    text-transform: uppercase;
    color: var(--accent);
    background: rgba(0,212,255,.08);
    border: 1px solid rgba(0,212,255,.16);
  }

  .expert-portrait-shell {
    position: relative;
    margin-top: 18px;
    min-height: 320px;
    border-radius: 24px;
    overflow: hidden;
    background:
      linear-gradient(180deg, var(--expert-surface-start), var(--expert-surface-end)),
      linear-gradient(180deg, rgba(255,255,255,.04), rgba(255,255,255,.01));
    border: 1px solid rgba(255,255,255,.07);
  }

  .expert-portrait-shell.has-photo {
    background: linear-gradient(180deg, rgba(9,13,22,.2), rgba(9,13,22,.6));
  }

  .expert-portrait-shell::before {
    content: '';
    position: absolute;
    inset: 0;
    background-image:
      linear-gradient(rgba(255,255,255,.05) 1px, transparent 1px),
      linear-gradient(90deg, rgba(255,255,255,.05) 1px, transparent 1px);
    background-size: 26px 26px;
    opacity: .18;
    mask-image: linear-gradient(180deg, rgba(0,0,0,.9), rgba(0,0,0,.2));
  }

  .expert-portrait-shell::after {
    content: '';
    position: absolute;
    left: 50%;
    top: 34px;
    width: 200px;
    height: 200px;
    border-radius: 50%;
    transform: translateX(-50%);
    background: radial-gradient(circle, var(--expert-glow), transparent 72%);
    filter: blur(2px);
  }

  .expert-portrait {
    position: absolute;
    inset: 16px;
    border-radius: 22px;
    display: flex;
    align-items: flex-end;
    justify-content: center;
    padding-bottom: 34px;
    background: linear-gradient(180deg, rgba(6,9,18,.02), rgba(6,9,18,.36));
  }

  .expert-portrait.has-photo {
    inset: 0;
    padding-bottom: 0;
    background: transparent;
  }

  .expert-portrait::before {
    content: '';
    position: absolute;
    top: 40px;
    left: 50%;
    width: 108px;
    height: 108px;
    border-radius: 50%;
    transform: translateX(-50%);
    background: linear-gradient(180deg, rgba(255,255,255,.62), rgba(255,255,255,.16));
    box-shadow: 0 0 40px rgba(255,255,255,.08);
  }

  .expert-portrait::after {
    content: '';
    position: absolute;
    left: 50%;
    bottom: -10px;
    width: 220px;
    height: 240px;
    transform: translateX(-50%);
    border-radius: 130px 130px 30px 30px;
    background: linear-gradient(180deg, rgba(255,255,255,.28), rgba(255,255,255,.06));
    box-shadow: inset 0 1px 0 rgba(255,255,255,.08);
  }

  .expert-portrait.has-photo::before,
  .expert-portrait.has-photo::after {
    display: none;
  }

  .expert-photo {
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: center top;
    display: block;
  }

  .expert-photo-overlay {
    position: absolute;
    inset: 0;
    background: linear-gradient(180deg, rgba(8,11,18,.04) 24%, rgba(8,11,18,.18) 56%, rgba(8,11,18,.92) 100%);
  }

  .expert-portrait span {
    position: relative;
    z-index: 1;
    font-family: 'Montserrat', sans-serif;
    font-size: 3.9rem;
    font-weight: 900;
    letter-spacing: -4px;
    color: rgba(255,255,255,.96);
    text-shadow: 0 14px 30px rgba(0,0,0,.32);
  }

  .expert-body {
    padding: 24px;
    position: relative;
    z-index: 1;
  }

  .expert-name {
    font-size: 1.28rem;
    margin-bottom: 8px;
  }

  .expert-role {
    color: var(--accent);
    font-weight: 600;
    margin-bottom: 14px;
  }

  .expert-copy {
    color: var(--text-muted);
    line-height: 1.7;
    margin-bottom: 18px;
    min-height: 120px;
  }

  .expert-focus-list {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
  }

  .expert-focus-chip {
    display: inline-flex;
    align-items: center;
    padding: 9px 12px;
    border-radius: 999px;
    font-size: .8rem;
    color: rgba(255,255,255,.86);
    background: rgba(255,255,255,.04);
    border: 1px solid rgba(255,255,255,.08);
  }

  .team-experts-strip {
    margin-top: 28px;
    padding: 28px;
    border-radius: 24px;
    border: 1px solid rgba(255,255,255,.08);
    background: linear-gradient(135deg, rgba(10,102,194,.16), rgba(17,23,38,.92));
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 18px;
    position: relative;
    z-index: 1;
  }

  .team-experts-strip p {
    color: var(--text-muted);
    margin-top: 8px;
    max-width: 620px;
  }

  .wizard-page-shell {
    min-height: 100vh;
    padding: 96px 0;
    background: var(--dark);
  }

  .section-row,
  .split-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 16px;
    margin-bottom: 16px;
  }

  .split-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 20px;
  }

  .table-card {
    background: var(--dark-2);
    border: 1px solid var(--border);
    border-radius: var(--radius);
    padding: 24px;
  }

  .table-title {
    font-size: .95rem;
    font-weight: 700;
  }

  .table-wrap {
    overflow-x: auto;
  }

  .data-table {
    width: 100%;
    border-collapse: collapse;
  }

  .data-table th,
  .data-table td {
    padding: 12px 10px;
    text-align: left;
    border-bottom: 1px solid var(--border);
    font-size: .875rem;
  }

  .data-table th {
    font-size: .72rem;
    color: var(--text-muted);
    letter-spacing: 1px;
    text-transform: uppercase;
    font-weight: 700;
  }

  .data-table tr:last-child td {
    border-bottom: none;
  }

  .history-row {
    display: flex;
    justify-content: space-between;
    gap: 16px;
    padding: 16px 0;
    border-bottom: 1px solid var(--border);
  }

  .history-row:last-child {
    border-bottom: none;
  }

  .history-row p {
    font-size: .82rem;
    color: var(--text-muted);
    margin-top: 6px;
  }

  .summary-block {
    padding: 14px 0;
    border-bottom: 1px solid var(--border);
    font-size: .88rem;
  }

  .summary-block:last-child {
    border-bottom: none;
  }

  .list-stack {
    display: grid;
    gap: 12px;
  }

  .list-item {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 16px;
    padding: 14px 16px;
    border-radius: 14px;
    background: var(--dark-3);
    border: 1px solid rgba(255,255,255,.06);
  }

  .list-item p {
    color: var(--text-muted);
    font-size: .82rem;
    margin-top: 4px;
  }

  .action-row {
    display: flex;
    flex-wrap: wrap;
    gap: 12px;
    align-items: center;
  }

  .action-column {
    display: flex;
    flex-direction: column;
    gap: 12px;
    align-items: flex-start;
  }

  .modal-wide {
    max-width: 860px;
  }

  .modal-header-row {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 16px;
    margin-bottom: 16px;
  }

  .close-btn {
    background: transparent;
    color: var(--text-muted);
    border: 1px solid var(--border);
    border-radius: 999px;
    padding: 8px 14px;
    cursor: pointer;
    transition: all .2s ease;
  }

  .close-btn:hover {
    border-color: var(--accent);
    color: var(--accent);
  }

  .case-highlights {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
    margin: 20px 0 26px;
  }

  .case-tag {
    padding: 8px 14px;
    border-radius: 999px;
  }

  .schedule-modal .modal-sub,
  .case-modal .modal-sub {
    margin-bottom: 0;
  }

  .modal-submit {
    width: 100%;
    justify-content: center;
    margin-top: 6px;
  }

  .schedule-switch {
    display: flex;
    gap: 12px;
    margin-bottom: 16px;
  }

.schedule-shell {
  background: rgba(255,255,255,.03);
  border: 1px solid var(--border);
  border-radius: 20px;
  padding: 12px;
  width: 100%;
  min-height: 0;
  overflow: hidden;
}

.calendly-host {
  width: 100%;
  min-width: 0;
  height: min(76vh, 760px);
  min-height: 620px;
}

.calendly-host > *,
.calendly-host .calendly-inline-widget,
.calendly-host iframe {
  width: 100% !important;
  min-width: 0 !important;
  height: 100% !important;
}

.calendly-host iframe {
  display: block;
  border: 0;
  border-radius: 16px;
  background: #fff;
}

.schedule-modal {
  max-width: min(960px, calc(100vw - 40px));
}

  .empty-state,
  .empty-zone {
    border: 1px dashed rgba(255,255,255,.14);
    background: rgba(255,255,255,.03);
    border-radius: 16px;
    padding: 22px;
    text-align: center;
    color: var(--text-muted);
    font-size: .85rem;
  }

  .empty-zone {
    margin-top: 8px;
  }

  .mini-form {
    margin-bottom: 24px;
  }

  .drop-zone.drag-over {
    border: 1px dashed var(--accent);
    box-shadow: 0 0 0 1px rgba(0,212,255,.25) inset;
  }

  .kanban-card.dragging {
    opacity: .4;
    transform: scale(.98);
  }

  .inline-note {
    margin-top: 14px;
    font-size: .82rem;
    color: var(--text-muted);
  }

  .inline-note[data-state="success"] {
    color: var(--success);
  }

  .inline-note[data-state="error"] {
    color: var(--danger);
  }

  .inline-note[data-state="warning"] {
    color: var(--warning);
  }

  .metric-value-small {
    font-size: 1rem;
    line-height: 1.45;
  }

  .service-action {
    margin-top: 18px;
    padding-left: 0;
  }

  .toast-stack {
    position: fixed;
    top: 84px;
    right: 20px;
    z-index: 1200;
    display: grid;
    gap: 10px;
  }

  .toast {
    min-width: 240px;
    max-width: 320px;
    padding: 14px 16px;
    border-radius: 14px;
    color: #fff;
    box-shadow: var(--shadow-sm);
    border: 1px solid rgba(255,255,255,.08);
    animation: fadeInUp .2s ease both;
  }

  .toast-info {
    background: rgba(10,102,194,.95);
  }

  .toast-success {
    background: rgba(34,197,94,.95);
  }

  .toast-warning {
    background: rgba(245,158,11,.95);
  }

  .toast-error {
    background: rgba(239,68,68,.95);
  }

  .toast-out {
    opacity: 0;
    transform: translateY(-8px);
    transition: all .2s ease;
  }

  .footer-link-button {
    background: transparent;
    border: none;
    padding: 0;
    text-align: left;
    cursor: pointer;
  }

  @media (max-width: 900px) {
    .newsletter-card,
    .split-grid {
      grid-template-columns: 1fr;
    }

    .newsletter-grid {
      grid-template-columns: 1fr;
    }

  .schedule-shell {
    padding: 10px;
  }
}

  @media (max-width: 640px) {
    .newsletter-card {
      padding: 24px;
    }

    .newsletter-form {
      padding: 20px;
    }

    .toast-stack {
      left: 16px;
      right: 16px;
    }

    .toast {
      max-width: none;
      min-width: 0;
    }

    .history-row,
    .section-row,
    .split-header {
      flex-direction: column;
      align-items: flex-start;
    }

    .schedule-switch {
      flex-direction: column;
    }
  }

  .calculator-page-shell {
    position: relative;
    min-height: 100vh;
    padding: 108px 0 90px;
    background:
      radial-gradient(circle at top right, rgba(0,212,255,.12), transparent 30%),
      radial-gradient(circle at top left, rgba(78,110,255,.12), transparent 28%),
      linear-gradient(180deg, #090d16 0%, #101726 100%);
    overflow: hidden;
  }

  .calculator-page {
    position: relative;
    z-index: 1;
  }

  .calculator-head {
    max-width: 860px;
    margin-bottom: 34px;
  }

  .budget-head .section-title {
    max-width: 720px;
  }

  .budget-breadcrumb {
    display: inline-flex;
    align-items: center;
    gap: 10px;
    margin-bottom: 20px;
    color: rgba(229,238,255,.72);
    font-size: .82rem;
  }

  .budget-breadcrumb-link {
    padding: 0;
    border: none;
    background: transparent;
    color: rgba(229,238,255,.72);
    cursor: pointer;
    transition: color .2s ease;
  }

  .budget-breadcrumb-link:hover {
    color: var(--accent);
  }

  .budget-builder,
  .budget-summary-card {
    position: relative;
    border-radius: 30px;
    border: 1px solid rgba(255,255,255,.08);
    background: linear-gradient(180deg, rgba(17,23,38,.96), rgba(10,13,20,.98));
    box-shadow: var(--shadow);
    overflow: hidden;
  }

  .budget-builder {
    padding: 34px;
  }

  .budget-builder::before,
  .budget-summary-card::before {
    content: '';
    position: absolute;
    inset: 0 0 auto 0;
    height: 1px;
    background: linear-gradient(90deg, transparent, rgba(0,212,255,.45), transparent);
  }

  .budget-step + .budget-step {
    margin-top: 34px;
    padding-top: 34px;
    border-top: 1px solid rgba(255,255,255,.06);
  }

  .budget-summary-step {
    margin-top: 34px;
  }

  .budget-step-head {
    display: flex;
    align-items: flex-start;
    gap: 16px;
    margin-bottom: 18px;
  }

  .budget-step-head h3 {
    color: var(--text-inv);
    font-family: 'Montserrat', sans-serif;
    font-size: 1.35rem;
    margin-bottom: 6px;
  }

  .budget-step-head p {
    color: var(--text-muted);
    font-size: .92rem;
    line-height: 1.65;
  }

  .budget-step-index {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 42px;
    height: 42px;
    border-radius: 14px;
    border: 1px solid rgba(0,212,255,.28);
    background: rgba(0,212,255,.08);
    color: var(--accent);
    font-family: 'Montserrat', sans-serif;
    font-weight: 800;
    letter-spacing: .04em;
  }

  .budget-panel {
    border-radius: 24px;
    border: 1px solid rgba(255,255,255,.08);
    background: rgba(255,255,255,.03);
    padding: 24px;
  }

  .budget-client-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 18px;
  }

  .budget-client-span {
    grid-column: 1 / -1;
  }

  .budget-textarea {
    resize: vertical;
    min-height: 118px;
  }

  .budget-select-group {
    max-width: 300px;
    margin-bottom: 22px;
  }

  .budget-select {
    min-height: 48px;
  }

  .budget-project-card {
    padding: 28px;
    border-radius: 26px;
    border: 1px solid rgba(255,255,255,.08);
    background: linear-gradient(180deg, rgba(10,13,20,.96), rgba(13,18,32,.94));
  }

  .budget-project-top {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 24px;
  }

  .budget-project-chip {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    margin-bottom: 14px;
    padding: 8px 14px;
    border-radius: 999px;
    background: rgba(90,125,255,.18);
    color: #dbe5ff;
    font-size: .78rem;
    font-weight: 700;
    letter-spacing: .04em;
    text-transform: uppercase;
  }

  .budget-project-card h4 {
    color: var(--text-inv);
    font-family: 'Montserrat', sans-serif;
    font-size: 1.7rem;
    margin-bottom: 10px;
  }

  .budget-project-card p {
    color: var(--text-muted);
    line-height: 1.7;
  }

  .budget-price-box,
  .budget-timeline-box {
    min-width: 220px;
    padding: 18px 20px;
    border-radius: 20px;
    border: 1px solid rgba(255,255,255,.08);
    background: rgba(255,255,255,.04);
  }

  .budget-price-box span,
  .budget-timeline-box span {
    display: block;
    color: var(--text-muted);
    font-size: .78rem;
    margin-bottom: 8px;
    text-transform: uppercase;
    letter-spacing: .06em;
  }

  .budget-price-box strong,
  .budget-timeline-box strong {
    color: var(--text-inv);
    font-family: 'Montserrat', sans-serif;
    font-size: 1.45rem;
  }

  .budget-timeline-box {
    margin-top: 18px;
  }

  .budget-module-grid,
  .budget-feature-grid,
  .budget-delivery-grid,
  .budget-summary-meta,
  .budget-terms-grid {
    display: grid;
    gap: 14px;
  }

  .budget-module-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    margin-top: 22px;
  }

  .budget-module-card,
  .budget-option-card,
  .budget-delivery-card,
  .budget-meta-item {
    border-radius: 20px;
    border: 1px solid rgba(255,255,255,.08);
    background: rgba(255,255,255,.03);
    transition: transform .2s ease, border-color .2s ease, box-shadow .2s ease, background .2s ease;
  }

  .budget-module-card {
    padding: 18px;
  }

  .budget-module-card:hover,
  .budget-option-card:hover,
  .budget-delivery-card:hover {
    transform: translateY(-2px);
    border-color: rgba(0,212,255,.28);
    box-shadow: 0 18px 40px rgba(0,0,0,.22);
  }

  .budget-module-top,
  .budget-option-top,
  .budget-delivery-top,
  .budget-summary-total {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 16px;
  }

  .budget-module-top {
    margin-bottom: 12px;
  }

  .budget-module-top strong,
  .budget-option-top strong,
  .budget-delivery-top strong,
  .budget-meta-item strong {
    color: var(--text-inv);
  }

  .budget-module-top span,
  .budget-option-top em,
  .budget-delivery-top em {
    color: var(--accent);
    font-style: normal;
    font-weight: 700;
  }

  .budget-option-card,
  .budget-delivery-card {
    padding: 18px;
  }

  .budget-option-card.is-selected,
  .budget-delivery-card.is-selected {
    border-color: rgba(90,125,255,.62);
    background: linear-gradient(180deg, rgba(33,42,72,.95), rgba(20,28,48,.95));
    box-shadow: 0 18px 46px rgba(42,72,160,.18);
  }

  .budget-option-toggle,
  .budget-delivery-toggle {
    display: flex;
    align-items: flex-start;
    gap: 12px;
    cursor: pointer;
  }

  .budget-option-toggle input,
  .budget-delivery-toggle input {
    margin-top: 3px;
    accent-color: var(--accent);
    flex-shrink: 0;
  }

  .budget-option-body,
  .budget-delivery-body {
    display: grid;
    gap: 10px;
    width: 100%;
  }

  .budget-option-copy,
  .budget-delivery-copy {
    color: var(--text-muted);
    font-size: .88rem;
    line-height: 1.65;
  }

  .budget-option-link {
    margin-top: 14px;
    padding: 0;
    border: none;
    background: transparent;
    color: var(--accent);
    font-size: .82rem;
    font-weight: 600;
    cursor: pointer;
  }

  .budget-option-link:hover {
    color: #8bdfff;
  }

  .budget-feature-grid,
  .budget-delivery-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .budget-summary-card {
    padding: 30px;
  }

  .budget-summary-meta {
    grid-template-columns: repeat(4, minmax(0, 1fr));
    margin-bottom: 22px;
  }

  .budget-meta-item {
    padding: 18px;
  }

  .budget-meta-item span {
    display: block;
    margin-bottom: 8px;
    color: var(--text-muted);
    font-size: .78rem;
    text-transform: uppercase;
    letter-spacing: .06em;
  }

  .budget-summary-table {
    display: grid;
    margin-bottom: 22px;
    border-top: 1px solid rgba(255,255,255,.06);
    border-bottom: 1px solid rgba(255,255,255,.06);
  }

  .calc-breakdown-row {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 18px;
    padding: 16px 0;
    border-bottom: 1px solid rgba(255,255,255,.06);
    color: var(--text-muted);
    font-size: .9rem;
  }

  .calc-breakdown-row:last-child {
    border-bottom: none;
  }

  .calc-breakdown-row.is-base strong,
  .calc-breakdown-row strong {
    color: var(--text-inv);
    font-family: 'Montserrat', sans-serif;
  }

  .budget-summary-total {
    align-items: flex-end;
    padding: 22px 0 18px;
    border-bottom: 1px solid rgba(255,255,255,.06);
  }

  .budget-summary-total span {
    display: block;
    margin-bottom: 8px;
    color: var(--text-inv);
    font-family: 'Montserrat', sans-serif;
    font-size: 1rem;
    letter-spacing: .08em;
    text-transform: uppercase;
  }

  .budget-summary-total small {
    color: var(--text-muted);
    line-height: 1.5;
  }

  .budget-summary-total strong {
    color: #8ca0ff;
    font-family: 'Montserrat', sans-serif;
    font-size: clamp(2rem, 4vw, 3rem);
    letter-spacing: -1px;
  }

  .budget-summary-actions {
    margin-top: 22px;
  }

  .budget-summary-note {
    margin-top: 16px;
    color: var(--text-muted);
    font-size: .84rem;
    line-height: 1.65;
  }

  .budget-terms {
    margin-top: 24px;
    padding-top: 22px;
    border-top: 1px solid rgba(255,255,255,.06);
  }

  .budget-terms-title {
    margin-bottom: 16px;
    color: var(--text-inv);
    font-family: 'Montserrat', sans-serif;
    font-size: .98rem;
    letter-spacing: .08em;
    text-transform: uppercase;
  }

  .budget-terms-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .budget-term-item {
    padding: 16px 18px;
    border-radius: 18px;
    border: 1px solid rgba(255,255,255,.06);
    background: rgba(255,255,255,.025);
    color: var(--text-muted);
    font-size: .84rem;
    line-height: 1.6;
  }

  .budget-term-item strong {
    color: var(--text-inv);
  }

  .quote-detail-modal {
    position: relative;
    max-width: 560px;
    padding: 34px;
  }

  .quote-detail-close {
    position: absolute;
    top: 16px;
    right: 16px;
    width: 36px;
    height: 36px;
    border-radius: 10px;
    border: 1px solid rgba(255,255,255,.08);
    background: rgba(255,255,255,.04);
    color: var(--text-inv);
    cursor: pointer;
  }

  .quote-detail-kicker {
    display: inline-flex;
    margin-bottom: 12px;
    padding: 7px 12px;
    border-radius: 999px;
    background: rgba(0,212,255,.08);
    color: var(--accent);
    font-size: .78rem;
    font-weight: 700;
    letter-spacing: .05em;
    text-transform: uppercase;
  }

  .quote-detail-title {
    color: var(--text-inv);
    font-family: 'Montserrat', sans-serif;
    font-size: 1.6rem;
    margin-bottom: 10px;
  }

  .quote-detail-description {
    color: var(--text-muted);
    line-height: 1.75;
    margin-bottom: 16px;
  }

  .quote-detail-badge {
    display: inline-flex;
    margin-bottom: 18px;
    padding: 8px 14px;
    border-radius: 999px;
    background: rgba(90,125,255,.18);
    color: #dfe7ff;
    font-size: .82rem;
    font-weight: 700;
  }

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

  .quote-detail-item {
    padding: 14px 16px;
    border-radius: 16px;
    border: 1px solid rgba(255,255,255,.06);
    background: rgba(255,255,255,.03);
    color: var(--text-inv);
    line-height: 1.55;
  }

  @media (max-width: 980px) {
    .budget-client-grid,
    .budget-feature-grid,
    .budget-delivery-grid,
    .budget-summary-meta,
    .budget-terms-grid,
    .budget-module-grid {
      grid-template-columns: 1fr;
    }

    .budget-project-top,
    .budget-summary-total {
      flex-direction: column;
      align-items: flex-start;
    }

    .budget-price-box,
    .budget-timeline-box {
      min-width: 0;
      width: 100%;
    }
  }

  @media (max-width: 640px) {
    .calculator-page-shell {
      padding: 94px 0 72px;
    }

    .budget-builder,
    .budget-summary-card,
    .budget-panel,
    .budget-project-card,
    .quote-detail-modal {
      padding: 22px;
      border-radius: 22px;
    }

    .budget-step-head {
      flex-direction: column;
    }

    .budget-step-index {
      min-width: 36px;
      height: 36px;
      border-radius: 12px;
    }
  }

  #navbar::before {
    content: '';
    position: absolute;
    inset: auto 12% 0 12%;
    height: 1px;
    background: linear-gradient(90deg, transparent, rgba(0,212,255,.32), transparent);
    pointer-events: none;
  }

  .btn-whatsapp-inline {
    border-color: rgba(37,211,102,.35);
    color: #aaf5c4;
  }

  .btn-whatsapp-inline:hover {
    border-color: rgba(37,211,102,.8);
    color: #fff;
    box-shadow: 0 12px 30px rgba(37,211,102,.18);
  }

  .hero-signal-row {
    display: flex;
    flex-wrap: wrap;
    gap: 12px;
    margin-bottom: 22px;
  }

  .hero-signal {
    padding: 10px 14px;
    border-radius: 999px;
    border: 1px solid rgba(255,255,255,.08);
    background: rgba(255,255,255,.03);
    color: var(--text-muted);
    font-size: .8rem;
  }

  .service-callout,
  .portfolio-cta-strip,
  .footer-newsletter-shell {
    margin-top: 28px;
    padding: 28px;
    border-radius: 24px;
    border: 1px solid rgba(255,255,255,.08);
    background: linear-gradient(135deg, rgba(10,102,194,.14), rgba(17,23,38,.92));
    box-shadow: var(--shadow-sm);
  }

  .service-callout h3,
  .footer-newsletter-copy h3 {
    font-size: 1.35rem;
    margin-bottom: 10px;
  }

  .service-callout p,
  .footer-newsletter-copy p,
  .portfolio-cta-strip p {
    color: var(--text-muted);
  }

  .section-actions {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 14px;
    margin-bottom: 22px;
  }

  .action-row-center {
    justify-content: center;
  }

  .portfolio-controls {
    display: flex;
    gap: 10px;
  }

  .portfolio-control {
    width: 44px;
    height: 44px;
    border-radius: 50%;
    border: 1px solid rgba(255,255,255,.1);
    background: rgba(255,255,255,.04);
    color: var(--text-inv);
    cursor: pointer;
    font-size: 1rem;
    transition: all .2s ease;
  }

  .portfolio-control:hover {
    border-color: rgba(0,212,255,.45);
    color: var(--accent);
    transform: translateY(-2px);
  }

  #portfolio-view .section-actions,
  #portfolio-legacy-carousel,
  #portfolio-view .portfolio-progress {
    display: none;
  }

  .portfolio-memory-shell {
    position: relative;
    padding: 24px;
    border-radius: 30px;
    border: 1px solid rgba(255,255,255,.08);
    background:
      radial-gradient(circle at 16% 0%, rgba(0,212,255,.15), transparent 32%),
      linear-gradient(145deg, rgba(17,23,38,.9), rgba(8,12,22,.98));
    box-shadow: var(--shadow-sm);
    overflow: hidden;
  }

  .portfolio-memory-shell::before {
    content: '';
    position: absolute;
    inset: 0;
    pointer-events: none;
    background-image:
      linear-gradient(rgba(255,255,255,.04) 1px, transparent 1px),
      linear-gradient(90deg, rgba(255,255,255,.04) 1px, transparent 1px);
    background-size: 44px 44px;
    opacity: .16;
    mask-image: radial-gradient(circle at 50% 40%, #000, transparent 76%);
  }

  .portfolio-memory-intro {
    position: relative;
    z-index: 1;
    display: flex;
    align-items: end;
    justify-content: space-between;
    gap: 18px;
    margin-bottom: 20px;
  }

  .portfolio-memory-intro p {
    max-width: 560px;
    color: var(--text-muted);
    font-size: .92rem;
  }

  .portfolio-memory-grid {
    position: relative;
    z-index: 1;
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 16px;
  }

  .portfolio-memory-card {
    min-height: 210px;
    border: 0;
    padding: 0;
    background: transparent;
    color: inherit;
    cursor: pointer;
    perspective: 1100px;
  }

  .portfolio-memory-inner {
    position: relative;
    display: block;
    width: 100%;
    height: 100%;
    min-height: 210px;
    transform-style: preserve-3d;
    transition: transform .62s cubic-bezier(.2,.8,.2,1);
  }

  .portfolio-memory-card:hover .portfolio-memory-inner,
  .portfolio-memory-card:focus-visible .portfolio-memory-inner {
    transform: rotateY(180deg) translateY(-2px);
  }

  .portfolio-memory-card:focus-visible {
    outline: none;
  }

  .portfolio-memory-face {
    position: absolute;
    inset: 0;
    display: flex;
    flex-direction: column;
    border-radius: 22px;
    border: 1px solid rgba(255,255,255,.09);
    backface-visibility: hidden;
    overflow: hidden;
    box-shadow: 0 20px 50px rgba(0,0,0,.24);
  }

  .portfolio-memory-front {
    justify-content: space-between;
    padding: 16px;
    background:
      radial-gradient(circle at 82% 12%, rgba(0,212,255,.2), transparent 34%),
      linear-gradient(160deg, rgba(24,32,52,.98), rgba(10,15,26,.98));
  }

  .portfolio-memory-back {
    gap: 10px;
    justify-content: center;
    padding: 18px;
    transform: rotateY(180deg);
    background:
      radial-gradient(circle at top right, rgba(69,98,246,.26), transparent 36%),
      linear-gradient(160deg, rgba(8,14,28,.98), rgba(14,31,50,.98));
  }

  .portfolio-memory-top {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 10px;
    color: var(--text-muted);
    font-size: .72rem;
    font-weight: 800;
    letter-spacing: .08em;
    text-transform: uppercase;
  }

  .portfolio-memory-screen {
    position: relative;
    display: grid;
    place-items: center;
    min-height: 104px;
    margin: 12px 0;
    border-radius: 18px;
    border: 1px solid rgba(0,212,255,.16);
    background:
      linear-gradient(135deg, rgba(0,212,255,.12), transparent 38%),
      rgba(255,255,255,.035);
  }

  .portfolio-memory-window {
    position: absolute;
    inset: 15px;
    display: grid;
    gap: 7px;
    align-content: center;
    opacity: .65;
  }

  .portfolio-memory-bar {
    display: block;
    height: 9px;
    border-radius: 999px;
    background: rgba(255,255,255,.11);
  }

  .portfolio-memory-bar.is-wide {
    width: 78%;
    background: rgba(0,212,255,.22);
  }

  .portfolio-memory-bar.is-soft {
    width: 52%;
  }

  .portfolio-memory-icon {
    position: relative;
    z-index: 1;
    display: grid;
    place-items: center;
    width: 58px;
    height: 58px;
    border-radius: 18px;
    background: linear-gradient(135deg, rgba(10,102,194,.34), rgba(0,212,255,.16));
    border: 1px solid rgba(0,212,255,.22);
    font-size: 1.75rem;
  }

  .portfolio-memory-hint,
  .portfolio-memory-see {
    align-self: flex-start;
    display: inline-flex;
    align-items: center;
    gap: 8px;
    padding: 8px 12px;
    border-radius: 999px;
    color: var(--accent);
    background: rgba(0,212,255,.08);
    border: 1px solid rgba(0,212,255,.16);
    font-size: .72rem;
    font-weight: 800;
  }

  .portfolio-memory-back-kicker {
    color: var(--accent);
    font-size: .72rem;
    font-weight: 800;
    letter-spacing: .08em;
    text-transform: uppercase;
  }

  .portfolio-memory-back strong {
    display: block;
    font-size: 1.15rem;
    line-height: 1.15;
  }

  .portfolio-memory-copy {
    color: var(--text-muted);
    font-size: .83rem;
    line-height: 1.55;
  }

  .portfolio-memory-tags {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
  }

  .portfolio-memory-tags em {
    font-style: normal;
    padding: 6px 9px;
    border-radius: 999px;
    color: rgba(255,255,255,.76);
    background: rgba(255,255,255,.06);
    font-size: .68rem;
    font-weight: 700;
  }

  .portfolio-carousel-shell {
    overflow: hidden;
  }

  .portfolio-track {
    display: grid;
    grid-auto-flow: column;
    grid-auto-columns: minmax(300px, 1fr);
    gap: 24px;
    overflow-x: auto;
    padding-bottom: 10px;
    scroll-snap-type: x mandatory;
    scrollbar-width: none;
  }

  .portfolio-track::-webkit-scrollbar {
    display: none;
  }

  .portfolio-slide {
    position: relative;
    min-height: 390px;
    padding: 28px;
    border-radius: 26px;
    border: 1px solid rgba(255,255,255,.08);
    background:
      radial-gradient(circle at top right, rgba(0,212,255,.16), transparent 35%),
      linear-gradient(165deg, rgba(17,23,38,.98), rgba(9,13,22,.98));
    box-shadow: var(--shadow-sm);
    scroll-snap-align: start;
  }

  .portfolio-slide-top,
  .client-overview-top,
  .insight-head,
  .kc-top {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 14px;
  }

  .portfolio-slide-kicker,
  .portfolio-slide-index,
  .client-overview-badge,
  .insight-badge {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: 6px 12px;
    border-radius: 999px;
    font-size: .72rem;
    font-weight: 700;
    letter-spacing: .4px;
    background: rgba(255,255,255,.06);
    color: var(--text-inv);
  }

  .portfolio-slide-kicker {
    color: var(--accent);
    background: rgba(0,212,255,.08);
  }

  .portfolio-slide-visual {
    width: 62px;
    height: 62px;
    margin: 28px 0 18px;
    border-radius: 18px;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 1.9rem;
    background: linear-gradient(135deg, rgba(10,102,194,.28), rgba(0,212,255,.16));
    border: 1px solid rgba(0,212,255,.18);
  }

  .portfolio-slide-title {
    font-size: 1.4rem;
    margin-bottom: 12px;
  }

  .portfolio-slide-copy {
    color: var(--text-muted);
    margin-bottom: 18px;
    min-height: 54px;
  }

  .portfolio-slide-highlights {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
    margin-bottom: 20px;
  }

  .portfolio-highlight {
    display: inline-flex;
    align-items: center;
    padding: 8px 12px;
    border-radius: 999px;
    background: rgba(255,255,255,.04);
    border: 1px solid rgba(255,255,255,.07);
    font-size: .76rem;
    color: var(--text-muted);
  }

  .portfolio-slide-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
    margin-top: auto;
  }

  .portfolio-progress {
    display: flex;
    justify-content: center;
    gap: 10px;
    margin-top: 18px;
  }

  .portfolio-dot {
    width: 10px;
    height: 10px;
    border-radius: 999px;
    border: none;
    background: rgba(255,255,255,.18);
    cursor: pointer;
    transition: all .2s ease;
  }

  .portfolio-dot.active {
    width: 34px;
    background: linear-gradient(90deg, var(--accent), var(--primary));
  }

  .portfolio-cta-strip {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 18px;
  }

  .footer-newsletter-shell {
    display: grid;
    grid-template-columns: 1.1fr 1fr;
    gap: 26px;
    margin-bottom: 30px;
  }

  .footer-subscribe-form {
    padding: 22px;
    border-radius: 22px;
    background: rgba(9,13,22,.72);
    border: 1px solid rgba(255,255,255,.06);
  }

  .footer-subscribe-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 14px;
    margin-bottom: 14px;
  }

  .admin-insight-grid {
    margin-bottom: 24px;
  }

  .insight-panel {
    padding: 24px;
    border-radius: 22px;
    border: 1px solid rgba(255,255,255,.08);
    background: linear-gradient(165deg, rgba(18,24,39,.96), rgba(10,13,22,.98));
    box-shadow: var(--shadow-sm);
  }

  .insight-panel-primary {
    background: linear-gradient(135deg, rgba(10,102,194,.22), rgba(9,13,22,.98));
  }

  .insight-head h3 {
    font-size: 1.08rem;
    margin-bottom: 6px;
  }

  .insight-head p,
  .insight-inline-note {
    color: var(--text-muted);
    font-size: .84rem;
  }

  .insight-badge.neutral {
    background: rgba(255,255,255,.05);
    color: var(--text-muted);
  }

  .automation-chip-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 12px;
    margin-top: 18px;
  }

  .automation-chip {
    padding: 16px;
    border-radius: 18px;
    border: 1px solid rgba(255,255,255,.07);
    background: rgba(255,255,255,.04);
  }

  .automation-chip strong {
    display: block;
    font-family: 'Montserrat', sans-serif;
    font-size: 1.35rem;
    margin-bottom: 4px;
  }

  .automation-chip span,
  .client-overview-metrics span,
  .settings-block-title,
  .kc-email,
  .kc-message,
  .kc-next,
  .insight-list-row span {
    color: var(--text-muted);
  }

  .insight-list {
    display: grid;
    gap: 14px;
    margin-top: 18px;
  }

  .insight-list-row {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 14px;
    padding-bottom: 12px;
    border-bottom: 1px solid rgba(255,255,255,.06);
    font-size: .88rem;
  }

  .insight-list-row:last-child {
    border-bottom: none;
    padding-bottom: 0;
  }

  .automation-steps {
    display: grid;
    gap: 12px;
    margin-top: 18px;
  }

  .automation-step {
    padding: 14px 16px;
    border-radius: 16px;
    border: 1px solid rgba(255,255,255,.06);
    background: rgba(255,255,255,.03);
    color: var(--text-muted);
    font-size: .86rem;
  }

  .client-cards-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 16px;
    margin-bottom: 18px;
  }

  .client-overview-card {
    padding: 22px;
    border-radius: 20px;
    border: 1px solid rgba(255,255,255,.06);
    background: rgba(255,255,255,.03);
  }

  .client-overview-top h3 {
    font-size: 1rem;
    margin-bottom: 6px;
  }

  .client-overview-top p {
    color: var(--text-muted);
    font-size: .84rem;
  }

  .client-overview-metrics {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 14px;
    margin: 18px 0;
  }

  .client-overview-metrics strong {
    display: block;
    font-size: 1rem;
    margin-bottom: 4px;
  }

  .client-overview-actions,
  .kc-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
  }

  .data-table-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
  }

  .admin-client-modal {
    width: min(1120px, 100%);
    max-width: 1120px;
    overflow-x: hidden;
  }

  .admin-client-modal .modal-header-row {
    position: relative;
    top: auto;
    z-index: 1;
    padding-bottom: 18px;
    margin-bottom: 24px;
    background: var(--dark-2);
    border-bottom: 1px solid rgba(255,255,255,.06);
  }

  .admin-client-shell {
    display: grid;
    gap: 20px;
    min-width: 0;
  }

  .admin-client-hero {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 18px;
    padding: 22px 24px;
    border-radius: 24px;
    border: 1px solid rgba(255,255,255,.06);
    background: linear-gradient(135deg, rgba(10,102,194,.22), rgba(0,212,255,.08));
    min-width: 0;
  }

  .admin-client-kicker {
    font-size: .74rem;
    font-weight: 700;
    letter-spacing: 1.6px;
    text-transform: uppercase;
    color: var(--accent);
    margin-bottom: 10px;
  }

  .admin-client-hero h3 {
    font-size: 1.35rem;
    margin-bottom: 6px;
  }

  .admin-client-hero p {
    color: rgba(255,255,255,.72);
    font-size: .9rem;
    overflow-wrap: anywhere;
    word-break: break-word;
  }

  .admin-client-hero-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
    justify-content: flex-end;
    min-width: 0;
  }

  .admin-client-stat-grid {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 14px;
    min-width: 0;
  }

  .admin-client-stat-card {
    padding: 18px;
    border-radius: 20px;
    border: 1px solid rgba(255,255,255,.06);
    background: rgba(255,255,255,.03);
  }

  .admin-client-stat-card span {
    display: block;
    color: var(--text-muted);
    font-size: .78rem;
    margin-bottom: 8px;
  }

  .admin-client-stat-card strong {
    display: block;
    font-size: 1.08rem;
  }

  .admin-client-grid {
    align-items: start;
    min-width: 0;
  }

  .admin-client-panel-card {
    display: grid;
    gap: 16px;
    min-width: 0;
  }

  .admin-client-info-list {
    display: grid;
    gap: 12px;
    min-width: 0;
  }

  .admin-client-info-row {
    display: flex;
    justify-content: space-between;
    gap: 16px;
    padding-bottom: 12px;
    border-bottom: 1px solid rgba(255,255,255,.06);
    align-items: flex-start;
    min-width: 0;
  }

  .admin-client-info-row:last-child {
    padding-bottom: 0;
    border-bottom: none;
  }

  .admin-client-info-row span {
    color: var(--text-muted);
    font-size: .82rem;
    min-width: 0;
  }

  .admin-client-info-row strong {
    flex: 1 1 auto;
    min-width: 0;
    text-align: right;
    font-size: .86rem;
    overflow-wrap: anywhere;
    word-break: break-word;
  }

  .admin-client-state-card,
  .admin-client-quote-card {
    padding: 18px;
    border-radius: 18px;
    border: 1px solid rgba(255,255,255,.06);
    background: rgba(255,255,255,.03);
    min-width: 0;
  }

  .admin-client-state-card p,
  .admin-client-copy {
    color: var(--text-muted);
    font-size: .86rem;
    line-height: 1.65;
    overflow-wrap: anywhere;
    word-break: break-word;
  }

  .admin-client-highlight-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 12px;
    margin-top: 14px;
  }

  .admin-client-highlight {
    padding: 12px 14px;
    border-radius: 16px;
    background: rgba(255,255,255,.035);
    border: 1px solid rgba(255,255,255,.05);
    min-width: 0;
  }

  .admin-client-highlight span {
    display: block;
    color: var(--text-muted);
    font-size: .74rem;
    margin-bottom: 5px;
  }

  .admin-client-highlight strong {
    font-size: .92rem;
    overflow-wrap: anywhere;
    word-break: break-word;
  }

  .admin-client-form-block,
  .admin-client-milestones,
  .admin-client-secondary-projects {
    margin-top: 8px;
  }

  .admin-client-quote-top,
  .admin-client-project-head {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 16px;
    min-width: 0;
  }

  .admin-client-quote-top p,
  .admin-client-project-head p {
    margin-top: 6px;
    color: var(--text-muted);
    font-size: .84rem;
    line-height: 1.55;
    overflow-wrap: anywhere;
    word-break: break-word;
  }

  .admin-client-total {
    font-family: 'Montserrat', sans-serif;
    font-size: 1.45rem;
    font-weight: 800;
    color: var(--accent);
  }

  .admin-client-pill-row {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
    margin-top: 14px;
  }

  .admin-client-breakdown {
    display: grid;
    gap: 10px;
    margin-top: 18px;
  }

  .admin-client-breakdown-row {
    display: flex;
    justify-content: space-between;
    gap: 16px;
    font-size: .84rem;
    padding-bottom: 10px;
    border-bottom: 1px solid rgba(255,255,255,.06);
    min-width: 0;
  }

  .admin-client-breakdown-row:last-child {
    padding-bottom: 0;
    border-bottom: none;
  }

  .admin-client-breakdown-row span,
  .admin-client-breakdown-row strong {
    min-width: 0;
    overflow-wrap: anywhere;
    word-break: break-word;
  }

  .admin-client-progress-bar {
    margin: 16px 0 4px;
  }

  .admin-client-secondary-projects h4 {
    margin-bottom: 12px;
    font-size: .88rem;
  }

  .admin-client-timeline {
    display: grid;
    gap: 14px;
    min-width: 0;
  }

  .admin-client-timeline-item {
    display: grid;
    grid-template-columns: 10px minmax(0, 1fr);
    gap: 12px;
    align-items: start;
  }

  .admin-client-timeline-dot {
    width: 10px;
    height: 10px;
    border-radius: 999px;
    margin-top: 6px;
    background: linear-gradient(135deg, var(--primary), var(--accent));
    box-shadow: 0 0 0 4px rgba(10,102,194,.12);
  }

  .admin-client-timeline-item p {
    color: var(--text-muted);
    font-size: .84rem;
    line-height: 1.58;
    margin: 5px 0 6px;
  }

  .admin-client-timeline-item span {
    color: rgba(255,255,255,.48);
    font-size: .75rem;
  }

  .settings-block-title {
    margin: 8px 0 16px;
    text-transform: uppercase;
    font-size: .75rem;
    letter-spacing: 1.6px;
    font-weight: 700;
  }

  .kc-top {
    margin-bottom: 8px;
  }

  .kc-email {
    font-size: .78rem;
    margin-bottom: 8px;
  }

  .kc-message {
    font-size: .8rem;
    line-height: 1.55;
    margin-bottom: 10px;
  }

  .kc-next {
    padding: 12px 14px;
    border-radius: 14px;
    background: rgba(255,255,255,.04);
    font-size: .8rem;
    margin-bottom: 12px;
  }

  .lead-priority {
    padding: 5px 10px;
    border-radius: 999px;
    font-size: .7rem;
    font-weight: 700;
    white-space: nowrap;
  }

  .lead-priority-high {
    background: rgba(239,68,68,.18);
    color: #ffb5b5;
  }

  .lead-priority-medium {
    background: rgba(245,158,11,.18);
    color: #ffd58e;
  }

  .lead-priority-low {
    background: rgba(59,130,246,.14);
    color: #9fd1ff;
  }

  @media (max-width: 900px) {
    .section-actions,
    .portfolio-cta-strip,
    .footer-newsletter-shell,
    .team-experts-strip {
      grid-template-columns: 1fr;
      flex-direction: column;
      align-items: flex-start;
    }

    .team-experts-grid {
      grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .portfolio-track {
      grid-auto-columns: minmax(280px, 85%);
    }

    .portfolio-memory-grid {
      grid-template-columns: repeat(3, minmax(0, 1fr));
    }

    .portfolio-memory-intro {
      align-items: flex-start;
      flex-direction: column;
    }

    .client-cards-grid,
    .automation-chip-grid,
    .footer-subscribe-grid {
      grid-template-columns: 1fr;
    }
  }

  @media (max-width: 640px) {
    .hero-signal-row {
      gap: 10px;
    }

    .hero-signal,
    .portfolio-highlight {
      width: 100%;
    }

    .service-callout,
    .portfolio-cta-strip,
    .footer-newsletter-shell,
    .insight-panel,
    .client-overview-card,
    .team-experts-strip {
      padding: 20px;
      border-radius: 20px;
    }

    #servicios .services-grid,
    #equipo .team-experts-grid {
      grid-auto-columns: minmax(276px, 88%);
      gap: 16px;
    }

    .expert-portrait-shell {
      min-height: 280px;
    }

    .expert-copy {
      min-height: auto;
    }

    .portfolio-track {
      grid-auto-columns: 100%;
    }

    .portfolio-memory-shell {
      padding: 18px;
      border-radius: 24px;
    }

    .portfolio-memory-grid {
      grid-template-columns: repeat(2, minmax(0, 1fr));
      gap: 12px;
    }

    .portfolio-memory-card,
    .portfolio-memory-inner {
      min-height: 184px;
    }

    .portfolio-memory-front,
    .portfolio-memory-back {
      border-radius: 18px;
      padding: 14px;
    }

    .portfolio-memory-screen {
      min-height: 82px;
      margin: 8px 0;
    }

    .portfolio-memory-back strong {
      font-size: 1rem;
    }

    .portfolio-memory-copy,
    .portfolio-memory-tags {
      display: none;
    }

    .client-overview-metrics {
      grid-template-columns: 1fr;
    }

    .admin-client-modal {
      max-width: 100%;
    }

    .admin-client-hero,
    .admin-client-panel-card,
    .admin-client-state-card,
    .admin-client-quote-card,
    .admin-client-stat-card {
      padding: 18px;
      border-radius: 18px;
    }

    #public-view #hero {
      padding-top: 128px;
      padding-bottom: 82px;
    }

    #public-view #hero .hero-eyebrow {
      margin-bottom: 13px;
    }

    #public-view #hero .hero-title {
      line-height: 1.03;
      margin-bottom: 12px;
      letter-spacing: -.035em;
    }

    #public-view #hero .hero-desc {
      max-width: 100%;
      margin-bottom: 16px;
      line-height: 1.56;
    }

    #public-view #hero .hero-actions {
      gap: 10px;
    }

    .mobile-nav-shell {
      margin-top: 8px;
    }

    .mobile-nav-dock {
      padding: 5px;
      gap: 6px;
      border-radius: 18px;
    }

    .mobile-nav-item {
      min-height: 52px;
      padding: 7px 6px;
      border-radius: 14px;
    }

    .mobile-nav-label {
      font-size: .66rem;
    }

    .mobile-nav-sheet {
      border-radius: 24px;
      padding: 18px;
    }

    .mobile-nav-sheet-action {
      padding: 14px 16px;
      border-radius: 18px;
    }
  }

  @media (max-width: 1024px) {
    #navbar {
      height: auto;
      min-height: 0;
      padding: 0 0 10px;
      align-items: flex-start;
    }

    .nav-inner {
      justify-content: space-between;
      align-items: flex-start;
      flex-wrap: wrap;
      gap: 10px 14px;
      min-height: 0;
      padding: 12px 18px 0;
    }

    .nav-logo-btn {
      display: inline-flex;
      align-items: center;
      justify-content: flex-start;
      min-height: 40px;
    }

    .nav-links,
    .nav-actions {
      display: none !important;
    }

    .mobile-nav-shell {
      display: block;
      order: 10;
      width: 100%;
      margin-top: 8px;
    }

    .mobile-nav-backdrop {
      display: flex;
      padding: 118px 16px 16px;
    }

    .mobile-nav-dock {
      padding: 6px;
      gap: 6px;
      border-radius: 22px;
      background: rgba(255,255,255,.04);
      border: 1px solid rgba(255,255,255,.08);
      box-shadow: 0 14px 28px rgba(0,0,0,.18);
      backdrop-filter: blur(16px);
    }

    .mobile-nav-item {
      min-height: 58px;
      padding: 8px 6px;
      border-radius: 16px;
      color: var(--text-muted);
    }

    .mobile-nav-item.is-active {
      box-shadow: inset 0 1px 0 rgba(255,255,255,.06), 0 10px 18px rgba(7,10,20,.18);
    }

    .mobile-nav-icon svg {
      width: 18px;
      height: 18px;
      stroke-width: 2;
    }

    .mobile-nav-label {
      font-size: .68rem;
    }

    #hero,
    #client-panel,
    #admin-panel {
      padding-top: 126px;
    }

    .section {
      padding: 76px 0;
      scroll-margin-top: 134px;
    }

    .client-main,
    .admin-main {
      padding: 24px;
    }

    .admin-client-stat-grid {
      grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    body {
      padding-bottom: 0;
    }

    body.mobile-nav-sheet-open {
      overflow: hidden;
    }

    #wabtn {
      bottom: calc(22px + env(safe-area-inset-bottom));
    }
  }

  @media (max-width: 768px) {
    .container,
    .nav-inner {
      padding-left: 18px;
      padding-right: 18px;
    }

    #hero {
      min-height: auto;
      justify-content: flex-start;
      padding-top: 132px;
      padding-bottom: 64px;
    }

    #client-panel,
    #admin-panel {
      padding-top: 92px;
    }

    #public-view #hero {
      padding-top: 132px;
      padding-bottom: 92px;
    }

    #public-view #hero .hero-eyebrow {
      margin-bottom: 14px;
    }

    #public-view #hero .hero-title {
      font-size: clamp(2.35rem, 8.8vw, 4rem);
      line-height: 1.02;
      margin-bottom: 14px;
    }

    #public-view #hero .hero-desc {
      max-width: 100%;
      font-size: 1rem;
      line-height: 1.58;
      margin-bottom: 18px;
    }

    #public-view #hero .hero-signal-row,
    #public-view #hero .hero-stats {
      display: none;
    }

    #public-view #hero .hero-actions {
      gap: 10px;
      max-width: 100%;
    }

    #public-view #hero .hero-actions .btn:not(:first-child):not(.btn-whatsapp-inline) {
      display: none;
    }

    #servicios .section-head,
    #equipo .team-experts-head {
      margin-bottom: 22px;
    }

    #servicios .services-grid,
    #equipo .team-experts-grid {
      display: grid;
      grid-template-columns: none;
      grid-auto-flow: column;
      grid-auto-columns: minmax(280px, 82%);
      gap: 18px;
      overflow-x: auto;
      padding-bottom: 6px;
      scroll-snap-type: x mandatory;
      scrollbar-width: none;
    }

    #servicios .services-grid::-webkit-scrollbar,
    #equipo .team-experts-grid::-webkit-scrollbar {
      display: none;
    }

    #servicios .service-card,
    #equipo .expert-card {
      scroll-snap-align: start;
      min-height: 100%;
    }

    #servicios .service-card {
      padding: 28px 22px;
    }

    #equipo .expert-portrait-shell {
      min-height: 250px;
    }

    .hero-actions .btn,
    .action-row .btn,
    .action-column .btn,
    .schedule-switch .btn,
    .portfolio-slide-actions .btn,
    .client-overview-actions .btn,
    .kc-actions .btn,
    .wizard-actions .btn {
      width: 100%;
      justify-content: center;
    }

    .hero-stats {
      display: grid;
      grid-template-columns: repeat(2, minmax(0, 1fr));
      gap: 16px;
      margin-top: 38px;
      max-width: 460px;
    }

    .hero-stats .stat-item:last-child {
      grid-column: 1 / -1;
    }

    .footer-grid {
      grid-template-columns: 1fr;
      gap: 28px;
    }

    .footer-bottom {
      flex-direction: column;
      align-items: flex-start;
      gap: 10px;
    }

    .modal-bg {
      padding: 12px;
      align-items: flex-start;
      overflow-y: auto;
    }

    .modal {
      margin: auto 0;
      max-height: calc(100vh - 24px);
      overflow-y: auto;
      padding: 28px 22px;
    }

    .auth-modal {
      max-width: 100%;
      padding: 22px;
      border-radius: 22px;
    }

    .auth-card-top {
      gap: 12px;
    }

    .auth-options {
      align-items: flex-start;
      flex-direction: column;
      gap: 10px;
    }

    .auth-submit-btn,
    .auth-input-shell,
    .form-input.auth-soft-input {
      min-height: 50px;
    }

    .modal-wide {
      max-width: 100%;
    }

    .modal-tabs,
    .role-demo,
    .wizard-actions,
    .schedule-switch {
      flex-direction: column;
      align-items: stretch;
    }

    .role-btns {
      width: 100%;
    }

    .role-btn {
      flex: 1 1 auto;
      text-align: center;
    }

    .tabs {
      overflow-x: auto;
      white-space: nowrap;
      padding-bottom: 6px;
      scrollbar-width: none;
    }

    .tabs::-webkit-scrollbar {
      display: none;
    }

    .tab-btn {
      flex: 0 0 auto;
    }

    .schedule-shell {
      padding: 8px;
    }

    .calendly-host {
      min-width: 0;
      height: min(70vh, 640px);
      min-height: 540px;
    }

    .admin-metrics,
    .kanban-board {
      grid-template-columns: 1fr;
    }

    .admin-client-hero,
    .admin-client-quote-top,
    .admin-client-project-head,
    .admin-client-info-row {
      flex-direction: column;
      align-items: flex-start;
    }

    .admin-client-hero-actions {
      width: 100%;
      justify-content: flex-start;
    }

    .admin-client-highlight-grid,
    .admin-client-stat-grid {
      grid-template-columns: 1fr;
    }

    .data-table-actions {
      min-width: 110px;
    }
  }

  @media (max-width: 480px) {
    #hero {
      padding-top: 124px;
      padding-bottom: 52px;
    }

    #client-panel,
    #admin-panel {
      padding-top: 88px;
    }

    .section {
      padding: 72px 0;
    }

    .hero-title {
      font-size: clamp(2rem, 10vw, 2.75rem);
    }

    .hero-desc {
      font-size: .98rem;
      line-height: 1.72;
    }

    .hero-stats {
      grid-template-columns: 1fr;
      max-width: none;
    }

    .hero-stats .stat-item:last-child {
      grid-column: auto;
    }

    .data-table {
      min-width: 680px;
    }

    .table-wrap {
      -webkit-overflow-scrolling: touch;
    }

    .schedule-shell {
      padding: 6px;
    }

    .calendly-host {
      height: min(62vh, 560px);
      min-height: 460px;
    }

    #wabtn .wa-tooltip {
      display: none;
    }

    #wabtn {
        width: 56px;
        height: 56px;
        border-radius: 18px;
        right: 14px;
        bottom: calc(18px + env(safe-area-inset-bottom));
        box-shadow: 0 14px 30px rgba(6, 12, 28, .28);
      }

    #public-view #hero {
      padding-top: 124px;
      padding-bottom: 74px;
    }

    #public-view #hero .hero-eyebrow {
      padding: 6px 12px;
      font-size: .75rem;
      margin-bottom: 12px;
    }

    #public-view #hero .hero-title {
      font-size: clamp(2.15rem, 10.6vw, 2.85rem);
      line-height: 1;
      margin-bottom: 12px;
    }

    #servicios .services-grid,
    #equipo .team-experts-grid {
      grid-auto-columns: minmax(248px, 90%);
    }

    .portfolio-memory-grid {
      grid-template-columns: 1fr;
    }

    .portfolio-memory-card,
    .portfolio-memory-inner {
      min-height: 172px;
    }

    #public-view #hero .hero-desc {
      max-width: 100%;
      font-size: .95rem;
      line-height: 1.52;
      margin-bottom: 16px;
    }

    #public-view #hero .hero-signal-row {
      display: none;
    }

    #public-view #hero .hero-signal {
      padding: 8px 12px;
      font-size: .75rem;
    }

    #public-view #hero .hero-actions {
      gap: 8px;
    }

    #public-view #hero .hero-actions .btn {
      padding: 12px 16px;
      border-radius: 16px;
    }
  }

.phone-input-shell {
  display: flex;
  align-items: center;
  gap: 0;
  border: 1px solid rgba(255,255,255,.08);
  border-radius: 16px;
  background: rgba(18,20,28,.9);
  overflow: hidden;
  transition: border-color .2s ease, box-shadow .2s ease, transform .2s ease;
}

.auth-phone-shell {
  min-height: 52px;
}

.phone-input-shell:focus-within {
  border-color: rgba(0,212,255,.32);
  box-shadow: 0 0 0 4px rgba(0,212,255,.08);
  transform: translateY(-1px);
}

.phone-input-prefix {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 72px;
  align-self: stretch;
  padding: 0 16px;
  border-right: 1px solid rgba(255,255,255,.08);
  background: linear-gradient(180deg, rgba(10,102,194,.2), rgba(10,102,194,.08));
  color: var(--text-inv);
  font-weight: 700;
  letter-spacing: .04em;
}

.phone-input-control.form-input {
  border: none;
  border-radius: 0;
  background: transparent;
  box-shadow: none;
  padding-left: 16px;
}

.phone-input-control.form-input:focus {
  box-shadow: none;
}

.budget-project-card {
  position: relative;
  overflow: hidden;
  box-shadow: 0 28px 56px rgba(0,0,0,.28);
}

.budget-project-card::before {
  content: '';
  position: absolute;
  inset: 0;
  background:
    radial-gradient(circle at top right, rgba(0,212,255,.12), transparent 34%),
    linear-gradient(140deg, rgba(255,255,255,.04), transparent 40%);
  pointer-events: none;
}

.budget-project-top,
.budget-timeline-box,
.budget-module-grid {
  position: relative;
  z-index: 1;
}

.budget-module-grid {
  align-items: stretch;
}

.budget-module-card {
  position: relative;
  overflow: hidden;
  padding: 20px;
  background:
    linear-gradient(180deg, rgba(255,255,255,.06), rgba(255,255,255,.025)),
    rgba(10,14,24,.8);
  box-shadow: inset 0 1px 0 rgba(255,255,255,.05);
}

.budget-module-card::before {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(160deg, rgba(255,255,255,.05), transparent 44%);
  pointer-events: none;
}

.budget-module-card.tone-cyan {
  border-color: rgba(0,212,255,.18);
}

.budget-module-card.tone-violet {
  border-color: rgba(130,110,255,.18);
}

.budget-module-card.tone-emerald {
  border-color: rgba(16,185,129,.18);
}

.budget-module-card.tone-warm {
  border-color: rgba(245,158,11,.18);
}

.budget-module-eyebrow {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  margin-bottom: 14px;
}

.budget-module-icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 42px;
  height: 42px;
  border-radius: 14px;
  background: rgba(0,212,255,.12);
  border: 1px solid rgba(0,212,255,.18);
  font-size: 1.05rem;
}

.budget-module-index {
  color: var(--text-muted);
  font-size: .73rem;
  letter-spacing: .12em;
  text-transform: uppercase;
}

.budget-module-list {
  margin: 14px 0 0;
  padding: 0;
  list-style: none;
  display: grid;
  gap: 10px;
}

.budget-module-list li {
  position: relative;
  padding-left: 18px;
  color: rgba(231,235,245,.84);
  font-size: .92rem;
  line-height: 1.55;
}

.budget-module-list li::before {
  content: '';
  position: absolute;
  left: 0;
  top: .48rem;
  width: 8px;
  height: 8px;
  border-radius: 999px;
  background: linear-gradient(180deg, #00d4ff, #0a66c2);
  box-shadow: 0 0 0 4px rgba(0,212,255,.1);
}

.budget-option-link {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  margin-top: 16px;
  padding: 10px 14px;
  border-radius: 999px;
  background: rgba(0,212,255,.08);
  border: 1px solid rgba(0,212,255,.14);
  color: var(--text-inv);
  transition: transform .2s ease, background .2s ease, border-color .2s ease, color .2s ease;
}

.budget-option-link::after {
  content: '↗';
  font-size: .82rem;
}

.budget-option-link:hover {
  color: #ffffff;
  background: rgba(0,212,255,.14);
  border-color: rgba(0,212,255,.24);
  transform: translateX(2px);
}

.case-modal {
  max-width: min(1120px, calc(100vw - 32px));
}

.case-modal-layout {
  display: grid;
  grid-template-columns: minmax(0, .8fr) minmax(360px, 1.2fr);
  gap: 22px;
  margin-top: 18px;
}

.case-modal-copy {
  display: grid;
  gap: 14px;
  align-content: start;
}

.case-metrics-strip {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 12px;
}

.case-metric-card {
  padding: 16px;
  border-radius: 18px;
  border: 1px solid rgba(255,255,255,.08);
  background: linear-gradient(180deg, rgba(255,255,255,.035), rgba(255,255,255,.02));
}

.case-metric-label {
  display: block;
  color: var(--text-muted);
  font-size: .74rem;
  letter-spacing: .12em;
  text-transform: uppercase;
  margin-bottom: 8px;
}

.case-metric-value {
  color: var(--text-inv);
  font-size: 1rem;
  line-height: 1.45;
}

.case-mockup-stage {
  position: relative;
  min-height: 430px;
  border-radius: 26px;
  border: 1px solid rgba(255,255,255,.08);
  background:
    radial-gradient(circle at top, rgba(0,212,255,.12), transparent 32%),
    linear-gradient(180deg, rgba(8,10,18,.96), rgba(12,17,29,.96));
  overflow: hidden;
  padding: 18px;
}

.case-mockup-stage::before,
.case-mockup-stage::after {
  content: '';
  position: absolute;
  inset: 0;
  pointer-events: none;
}

.case-mockup-stage::before {
  background-image:
    linear-gradient(rgba(255,255,255,.04) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,.04) 1px, transparent 1px);
  background-size: 34px 34px;
  mask-image: linear-gradient(180deg, rgba(0,0,0,.9), rgba(0,0,0,.35));
}

.case-mockup-stage::after {
  background: radial-gradient(circle at 50% 20%, rgba(0,212,255,.12), transparent 40%);
}

.case-mockup-card {
  position: absolute;
  border-radius: 24px;
  border: 1px solid rgba(255,255,255,.08);
  background: linear-gradient(180deg, rgba(17,22,38,.92), rgba(11,15,24,.96));
  box-shadow: 0 22px 44px rgba(0,0,0,.35);
  overflow: hidden;
  backdrop-filter: blur(10px);
  animation-delay: var(--mockup-delay, 0s);
  animation-duration: 6.2s;
  animation-iteration-count: infinite;
  animation-timing-function: ease-in-out;
}

.case-mockup-card.skin-browser {
  left: 20px;
  top: 26px;
  width: min(54%, 360px);
}

.case-mockup-card.skin-phone {
  right: 26px;
  top: 54px;
  width: min(34%, 220px);
}

.case-mockup-card.skin-panel {
  right: 42px;
  bottom: 26px;
  width: min(56%, 360px);
}

.case-mockup-card.is-up {
  animation-name: caseMockupFloatUp;
}

.case-mockup-card.is-down {
  animation-name: caseMockupFloatDown;
}

.case-mockup-card.is-side {
  animation-name: caseMockupDriftSide;
}

.case-mockup-card.tone-cyan .case-mockup-glow {
  color: #00d4ff;
}

.case-mockup-card.tone-violet .case-mockup-glow {
  color: #8b7dff;
}

.case-mockup-card.tone-emerald .case-mockup-glow {
  color: #22c55e;
}

.case-mockup-card.tone-warm .case-mockup-glow {
  color: #f59e0b;
}

.case-mockup-top {
  display: flex;
  gap: 8px;
  padding: 14px 16px 0;
}

.case-mockup-dot {
  width: 8px;
  height: 8px;
  border-radius: 999px;
  background: rgba(255,255,255,.26);
}

.case-mockup-body {
  position: relative;
  z-index: 1;
  padding: 14px 16px 18px;
  display: grid;
  gap: 10px;
}

.case-mockup-kicker {
  color: rgba(255,255,255,.55);
  font-size: .72rem;
  letter-spacing: .14em;
  text-transform: uppercase;
}

.case-mockup-title {
  color: var(--text-inv);
  font-size: 1.08rem;
  line-height: 1.3;
}

.case-mockup-copy {
  color: rgba(231,235,245,.76);
  line-height: 1.6;
  font-size: .92rem;
}

.case-mockup-tags {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}

.case-mockup-tag {
  display: inline-flex;
  align-items: center;
  padding: 8px 12px;
  border-radius: 999px;
  background: rgba(255,255,255,.06);
  border: 1px solid rgba(255,255,255,.08);
  color: rgba(255,255,255,.8);
  font-size: .78rem;
}

.case-mockup-tag.is-solid {
  background: linear-gradient(135deg, rgba(0,212,255,.18), rgba(10,102,194,.22));
  border-color: rgba(0,212,255,.22);
  color: #ffffff;
}

.case-mockup-glow {
  position: absolute;
  right: 14px;
  bottom: 10px;
  font-size: 3.2rem;
  opacity: .16;
  filter: blur(.2px);
}

@keyframes caseMockupFloatUp {
  0%, 100% { transform: translate3d(0, 0, 0); }
  50% { transform: translate3d(0, -14px, 0); }
}

@keyframes caseMockupFloatDown {
  0%, 100% { transform: translate3d(0, 0, 0); }
  50% { transform: translate3d(0, 16px, 0); }
}

@keyframes caseMockupDriftSide {
  0%, 100% { transform: translate3d(0, 0, 0); }
  50% { transform: translate3d(14px, -8px, 0); }
}

@media (max-width: 980px) {
  .case-modal-layout {
    grid-template-columns: 1fr;
  }

  .case-mockup-stage {
    min-height: 0;
    display: grid;
    gap: 14px;
  }

  .case-mockup-card {
    position: relative;
    inset: auto;
    width: 100% !important;
    animation-duration: 5.6s;
  }
}

@media (max-width: 640px) {
  .phone-input-prefix {
    min-width: 64px;
    padding: 0 14px;
  }

  .case-metrics-strip {
    grid-template-columns: 1fr;
  }

  .case-modal {
    max-width: calc(100vw - 18px);
  }
}
