/* =========================
       THEME TOKENS (DEFAULT: DARK)
       ========================= */
    :root{
      --bg: #0B0F17;
      --bg2:#060912;
      --bg3:#090C14;

      --panel: rgba(255,255,255,.06);
      --panel2: rgba(255,255,255,.08);
      --border: rgba(255,255,255,.12);

      --text: rgba(255,255,255,.92);
      --muted: rgba(255,255,255,.66);
      --muted2: rgba(255,255,255,.48);

      --accent: #4F46E5;
      --accent2:#22D3EE;
      --ok:#34D399;

      --shadow: 0 20px 50px rgba(0,0,0,.45);

      --radius: 18px;
      --radius2: 26px;

      --max: 1120px;
      --pad: clamp(16px, 3.6vw, 28px);

      --h1: clamp(34px, 5.4vw, 56px);
      --h2: clamp(22px, 3.6vw, 34px);
      --p: clamp(16px, 2.2vw, 18px);

      --mono: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace;
      --sans: ui-sans-serif, system-ui, -apple-system, Segoe UI, Roboto, Helvetica, Arial, "Apple Color Emoji","Segoe UI Emoji";
      
      --carouselH: 560px;
    }

    /* =========================
       THEME TOKENS (LIGHT)
       ========================= */
    [data-theme="light"]{
      --bg: #F6F7FB;
      --bg2:#FFFFFF;
      --bg3:#EEF1F7;

      --panel: rgba(15,23,42,.05);
      --panel2: rgba(15,23,42,.08);
      --border: rgba(15,23,42,.12);

      --text: rgba(15,23,42,.92);
      --muted: rgba(15,23,42,.64);
      --muted2: rgba(15,23,42,.50);

      --accent: #4F46E5;
      --accent2:#0891B2;

      --shadow: 0 18px 40px rgba(15,23,42,.14);
    }

    /* =========================
       BASE
       ========================= */
    *{box-sizing:border-box}
    html,body{height:100%}
    body{
      margin:0;
      font-family: var(--sans);
      color:var(--text);
      background:
        radial-gradient(1000px 600px at 18% 10%, rgba(79,70,229,.22), transparent 55%),
        radial-gradient(900px 600px at 85% 30%, rgba(34,211,238,.16), transparent 55%),
        radial-gradient(800px 600px at 45% 92%, rgba(167,139,250,.14), transparent 55%),
        linear-gradient(180deg, var(--bg2) 0%, var(--bg) 45%, var(--bg3) 100%);
      overflow-x:hidden;
    }
    a{color:inherit}
    .wrap{max-width:var(--max); margin:0 auto; padding:0 var(--pad)}
    .topbar{
      position:fixed; top:0; left:0; right:0; z-index:100;
      backdrop-filter:saturate(1.2) blur(10px);
      background: linear-gradient(180deg,
        color-mix(in srgb, var(--bg2) 75%, transparent),
        color-mix(in srgb, var(--bg2) 40%, transparent)
      );
      border-bottom:1px solid color-mix(in srgb, var(--border) 50%, transparent);
    }

    header.hero{padding: 100px 0 30px}
    @media (max-width: 600px) {
        header.hero { padding: 80px 0 20px; }
    }
    .nav{
      display:flex; align-items:center; justify-content:space-between;
      padding:14px 0;
      gap:14px;
    }
    .brand{display:flex; align-items:center; gap:10px; font-weight:800; letter-spacing:.2px}
    .logo{
      width:34px; height:34px; border-radius:12px;
      background:
        radial-gradient(16px 16px at 30% 30%, rgba(255,255,255,.18), transparent 60%),
        linear-gradient(135deg, var(--accent), #7C3AED);
      box-shadow: 0 10px 30px rgba(79,70,229,.25);
      border:1px solid var(--border);
    }
    .menu{display:flex; align-items:center; gap:18px; color:var(--muted); font-size:14px}
    .menu a{opacity:.9; text-decoration:none}
    .menu a:hover{opacity:1; color:var(--text)}
    .actions{display:flex; align-items:center; gap:10px; flex-wrap:wrap}

    .btn{
      display:inline-flex; align-items:center; justify-content:center;
      gap:10px; padding:11px 14px;
      border-radius:14px; border:1px solid var(--border);
      background: var(--panel);
      text-decoration:none; font-weight:800; font-size:14px;
      box-shadow: 0 10px 25px rgba(0,0,0,.08);
      color: var(--text);
    }
    .btn:hover{filter:brightness(1.03)}
    .btn.primary{
      border:none;
      background: linear-gradient(135deg, var(--accent), #7C3AED);
      color: rgba(255,255,255,.95);
      box-shadow: 0 18px 40px rgba(79,70,229,.22);
    }

    .pill{
      display:inline-flex; align-items:center; gap:8px;
      padding:7px 10px; border-radius:999px;
      border:1px solid var(--border);
      background: var(--panel);
      color:var(--muted);
      font-size:13px;
      font-weight:700;
      white-space:nowrap;
    }
    .dot{width:8px; height:8px; border-radius:99px; background: var(--ok); box-shadow: 0 0 0 6px rgba(52,211,153,.12)}

    /* =========================
       THEME TOGGLE (same style as your 2nd example)
       ========================= */
    .toggle{
      display:flex; align-items:center; gap:10px;
      padding:10px 12px;
      border-radius:16px;
      border:1px solid var(--border);
      background: var(--panel);
      user-select:none;
      box-shadow: 0 10px 25px rgba(0,0,0,.08);
    }
    .toggle label{font-size:12px; color:var(--muted); font-weight:900}
    .switch{
      position:relative; width:52px; height:30px;
      border-radius:999px;
      border:1px solid var(--border);
      background: color-mix(in srgb, var(--panel2) 55%, transparent);
      cursor:pointer;
      flex:0 0 52px;
      outline:none;
    }
    .switch:focus-visible{
      box-shadow: 0 0 0 4px color-mix(in srgb, var(--accent) 35%, transparent);
    }
    .knob{
      position:absolute; top:3px; left:3px;
      width:24px; height:24px; border-radius:999px;
      background: linear-gradient(135deg, rgba(255,255,255,.85), rgba(255,255,255,.45));
      border:1px solid var(--border);
      transition: transform .18s ease;
    }
    [data-theme="light"] .knob{
      background: linear-gradient(135deg, rgba(15,23,42,.85), rgba(15,23,42,.45));
      transform: translateX(22px);
    }

    /* =========================
       HERO + CONTENT (from first HTML)
       ========================= */
    header.hero{padding: 46px 0 30px}
    .heroGrid{
      display:grid;
      grid-template-columns: 1.15fr .85fr;
      gap: 22px;
      align-items:stretch;
    }
    .hero h1{font-size:var(--h1); line-height:1.02; margin:14px 0 10px}
    .hero p{font-size:var(--p); line-height:1.55; color:var(--muted); margin:0 0 18px}
    .hero .ctas{display:flex; gap:10px; flex-wrap:wrap; margin: 14px 0 16px}
    .trust{display:flex; flex-wrap:wrap; gap:10px; margin-top:10px; color:var(--muted2); font-size:13px}
    .trust span{display:inline-flex; align-items:center; gap:8px}
    .check{
      width:18px; height:18px; border-radius:8px;
      background: rgba(52,211,153,.15); border:1px solid rgba(52,211,153,.35);
      display:inline-flex; align-items:center; justify-content:center;
      color: var(--ok); font-weight:900; font-size:12px;
    }
    .card{
      border-radius: var(--radius2);
      border: 1px solid var(--border);
      background: linear-gradient(180deg, var(--panel2), color-mix(in srgb, var(--panel) 70%, transparent));
      box-shadow: var(--shadow);
    }
    .heroCard{
      padding: 14px;
      overflow:hidden;
      position:relative;
    }
    .glow{
      position:absolute; inset:-120px -120px auto auto;
      width:320px; height:320px;
      background: radial-gradient(circle at 30% 30%, rgba(34,211,238,.22), transparent 55%),
                  radial-gradient(circle at 70% 60%, rgba(79,70,229,.30), transparent 55%);
      filter: blur(12px);
      opacity:.85;
      pointer-events:none;
    }
    .mock{display:grid; gap:12px}
    .mockTop{
      display:flex; align-items:center; justify-content:space-between;
      gap:10px;
      padding: 12px 12px;
      border-radius: 18px;
      border:1px solid var(--border);
      background: color-mix(in srgb, var(--panel) 80%, transparent);
    }
    .mockTitle{display:flex; flex-direction:column}
    .mockTitle strong{font-size:13px}
    .mockTitle span{font-size:12px; color:var(--muted2)}
    .seg{display:flex; gap:6px}
    .seg button{
      appearance:none; border:1px solid var(--border);
      background: var(--panel);
      color: var(--muted);
      font-size:12px; padding:8px 10px; border-radius:999px;
      font-weight:800;
    }
    .seg button.active{
      background: color-mix(in srgb, var(--accent) 18%, transparent);
      border-color: color-mix(in srgb, var(--accent) 50%, var(--border));
      color: var(--text);
    }
    .grid2{display:grid; grid-template-columns: 1fr 1fr; gap:12px}
    .panel{
      border-radius: 18px;
      border:1px solid var(--border);
      background: color-mix(in srgb, var(--panel) 80%, transparent);
      padding: 12px;
    }
    .kpis{display:grid; grid-template-columns: 1fr 1fr 1fr; gap:10px}
    .kpi{
      border-radius: 16px;
      border:1px solid color-mix(in srgb, var(--border) 85%, transparent);
      background: var(--panel);
      padding: 10px;
    }
    .kpi .n{font-size:18px; font-weight:900}
    .kpi .l{font-size:12px; color:var(--muted2); margin-top:4px}
    .chips{display:flex; gap:8px; flex-wrap:wrap; margin-top:10px}
    .chip{
      font-size:12px;
      padding:7px 10px;
      border-radius:999px;
      border:1px solid var(--border);
      background: var(--panel);
      color: var(--muted);
      font-weight:800;
    }
    .chip.hl{
      background: color-mix(in srgb, var(--accent2) 14%, transparent);
      border-color: color-mix(in srgb, var(--accent2) 35%, var(--border));
      color: color-mix(in srgb, var(--text) 92%, transparent);
    }
    .list{display:flex; flex-direction:column; gap:10px}
    .row{
      display:flex; align-items:center; justify-content:space-between; gap:10px;
      padding: 10px 10px;
      border-radius: 16px;
      border:1px solid color-mix(in srgb, var(--border) 85%, transparent);
      background: var(--panel);
    }
    .row .left{display:flex; align-items:center; gap:10px}
    .ico{
      width:36px; height:36px; border-radius:14px;
      background: linear-gradient(135deg,
        color-mix(in srgb, var(--accent) 28%, transparent),
        color-mix(in srgb, #A78BFA 18%, transparent)
      );
      border:1px solid var(--border);
      display:flex; align-items:center; justify-content:center;
      font-weight:900;
    }
    .row b{font-size:13px}
    .row small{display:block; color:var(--muted2); font-size:12px; margin-top:2px}
    .row .tag{
      font-family: var(--mono);
      font-size:11px; color: color-mix(in srgb, var(--text) 75%, transparent);
      padding: 6px 8px;
      border-radius: 12px;
      border:1px solid var(--border);
      background: color-mix(in srgb, var(--panel) 80%, transparent);
      white-space:nowrap;
    }

    section{padding: 26px 0}
    .sectionTitle{
      display:flex; align-items:flex-end; justify-content:space-between; gap:16px;
      margin-bottom: 14px;
    }
    .sectionTitle h2{margin:0; font-size:var(--h2); line-height:1.1}
    .sectionTitle p{margin:0; color:var(--muted); max-width:60ch; font-size:14px; line-height:1.55}
    .cards{
      display:grid; gap:12px;
      grid-template-columns: repeat(3, 1fr);
    }
    .feat{
      padding: 16px;
      border-radius: var(--radius);
      border:1px solid var(--border);
      background: linear-gradient(180deg, var(--panel2), color-mix(in srgb, var(--panel) 70%, transparent));
    }
    .feat h3{margin: 10px 0 6px; font-size:16px}
    .feat p{margin:0; color:var(--muted); font-size:14px; line-height:1.55}
    .badge{
      display:inline-flex; align-items:center; gap:8px;
      color: color-mix(in srgb, var(--text) 92%, transparent);
      background: color-mix(in srgb, var(--accent) 16%, transparent);
      border:1px solid color-mix(in srgb, var(--accent) 45%, var(--border));
      padding: 7px 10px; border-radius:999px; font-size:12px;
      font-weight:900;
    }
    .steps{display:grid; grid-template-columns: 1fr 1fr 1fr; gap:12px}
    .step{
      padding: 16px;
      border-radius: var(--radius);
      border:1px solid var(--border);
      background: color-mix(in srgb, var(--panel) 85%, transparent);
    }
    .step .n{
      width:34px; height:34px; border-radius:14px;
      display:flex; align-items:center; justify-content:center;
      background: color-mix(in srgb, var(--accent2) 14%, transparent);
      border:1px solid color-mix(in srgb, var(--accent2) 35%, var(--border));
      font-weight:900;
    }
    .step h3{margin: 10px 0 6px; font-size:16px}
    .step p{margin:0; color:var(--muted); font-size:14px; line-height:1.55}
    .miniUI{
      margin-top:12px;
      border-radius: 16px;
      border:1px solid var(--border);
      background: var(--panel);
      padding: 10px;
      display:grid; gap:8px;
    }
    .miniLine{
      height:10px; border-radius:999px;
      background: linear-gradient(90deg, color-mix(in srgb, var(--text) 18%, transparent), color-mix(in srgb, var(--text) 6%, transparent));
    }
    .miniLine.s{width:68%}
    .miniLine.m{width:82%}
    .miniLine.l{width:92%}
    .looks{display:grid; grid-template-columns: 1.1fr .9fr; gap:12px}
    .lookCard{
      padding: 16px;
      border-radius: var(--radius2);
      border:1px solid var(--border);
      background: linear-gradient(180deg, var(--panel2), color-mix(in srgb, var(--panel) 70%, transparent));
    }
    .lookGrid{
      display:grid; grid-template-columns: repeat(3, 1fr); gap:10px;
      margin-top: 12px;
    }
    .look{
      border-radius: 16px;
      border:1px solid color-mix(in srgb, var(--border) 85%, transparent);
      background: color-mix(in srgb, var(--panel) 85%, transparent);
      padding: 12px;
      display:grid; gap:10px;
    }
    .thumb{
      height: 110px;
      border-radius: 14px;
      border:1px solid color-mix(in srgb, var(--border) 85%, transparent);
      background:
        radial-gradient(40px 40px at 30% 30%, color-mix(in srgb, var(--text) 12%, transparent), transparent 60%),
        linear-gradient(135deg, color-mix(in srgb, var(--accent) 22%, transparent), color-mix(in srgb, var(--accent2) 10%, transparent));
    }
    .look b{font-size:13px}
    .look .meta{display:flex; gap:8px; flex-wrap:wrap}
    .miniTag{
      font-size:11px;
      padding: 6px 8px;
      border-radius: 999px;
      border:1px solid var(--border);
      background: var(--panel);
      color: var(--muted);
      font-weight:800;
    }
    .lookActions{display:flex; gap:8px; flex-wrap:wrap}
    .miniBtn{
      font-size:12px; font-weight:900;
      padding: 8px 10px;
      border-radius: 12px;
      border:1px solid var(--border);
      background: var(--panel);
      text-decoration:none;
      color: color-mix(in srgb, var(--text) 92%, transparent);
    }
    .miniBtn.primary{
      border:none;
      background: color-mix(in srgb, var(--accent) 18%, transparent);
    }

    .b2b{display:grid; grid-template-columns: 1fr 1fr; gap:12px; align-items:stretch}
    .b2b .box{padding: 18px}
    .ul{margin:12px 0 0; padding:0; list-style:none; display:grid; gap:10px}
    .ul li{
      display:flex; gap:10px; align-items:flex-start; color: var(--muted);
      font-size:14px; line-height:1.55;
    }
    .ul .bullet{
      width:20px; height:20px; border-radius:10px;
      background: color-mix(in srgb, var(--accent) 16%, transparent);
      border:1px solid color-mix(in srgb, var(--accent) 40%, var(--border));
      flex:0 0 20px; margin-top:2px;
    }

    footer{padding: 30px 0 42px; color: var(--muted2)}
    .foot{
      display:flex; flex-wrap:wrap; align-items:center; justify-content:space-between; gap:14px;
      border-top: 1px solid color-mix(in srgb, var(--border) 55%, transparent);
      padding-top: 16px;
    }
    .foot a{color: var(--muted2); text-decoration:none; font-weight:800; font-size:13px}
    .foot a:hover{color: var(--text)}

    /* Responsive */
    @media (max-width: 920px){
      .heroGrid{grid-template-columns:1fr;}
      .cards{grid-template-columns:1fr}
      .steps{grid-template-columns:1fr}
      .looks{grid-template-columns:1fr}
      .lookGrid{grid-template-columns:1fr}
      .b2b{grid-template-columns:1fr}
      .menu{display:none}
      .toggle label{display:none}
    }

    @media (max-width: 600px) {
      :root {
        --carouselH: 420px;
        --h1: 32px;
        --pad: 16px;
      }
      .hero h1 { margin-top: 10px; }
      .heroCard { padding: 10px; }
      .mockTop { padding: 8px 10px; }
      .seg button { padding: 6px 8px; font-size: 11px; }
      .recTitle { font-size: 14px; }
      .recImgWrap { height: 55%; }
      .recBody { height: 45%; padding: 10px; }
      .recActions { gap: 4px; }
      .miniBtn { padding: 6px 8px; font-size: 11px; }
      
      .kpi .n { font-size: 16px; }
      .kpi .l { font-size: 11px; }
      
      .lookGrid { gap: 16px; }
      .sectionTitle { flex-direction: column; align-items: flex-start; gap: 8px; }
    }
  
    /* =========================
       CAROUSEL (elegant crossfade + subtle motion)
       ========================= */
    .carouselStage{
      position:relative;
      border-radius: 18px;
      outline:none;
    }
    .carouselSlides{
      position:relative;
      min-height: var(--carouselH);
    }
    .carouselSlide{
      position:absolute; inset:0;
      opacity:0;
      transform: translateY(8px) scale(0.985);
      transition: opacity .55s ease, transform .75s cubic-bezier(.2,.8,.2,1), filter .75s ease;
      pointer-events:none;
      filter: blur(0.5px);
    }
    .carouselSlide.is-active{
      opacity:1;
      transform: translateY(0) scale(1);
      pointer-events:auto;
      filter: blur(0);
    }
    .carouselMedia{width:100%; height:100%}
    .carouselMedia svg{
      display:block;
      width:100%;
      height:auto;
      border-radius: 18px;
      border: 1px solid var(--border);
      background: color-mix(in srgb, var(--panel) 85%, transparent);
    }
    /* Slide 2 is the original HTML mock; keep its original layout spacing */
    .carouselSlide[data-slide="1"] .carouselMedia{
      display:grid;
      gap:12px;
    }

    .carouselDots{
      position:absolute;
      left:50%;
      transform: translateX(-50%);
      bottom: 12px;
      display:flex;
      gap:8px;
      padding: 10px 12px;
      border-radius: 999px;
      border: 1px solid var(--border);
      background: color-mix(in srgb, var(--panel) 90%, transparent);
      backdrop-filter: blur(8px);
    }
    .dotBtn{
      width:10px; height:10px;
      border-radius:999px;
      border:1px solid var(--border);
      background: color-mix(in srgb, var(--text) 22%, transparent);
      padding:0;
      cursor:pointer;
      opacity:.9;
    }
    .dotBtn.is-active{
      width:22px;
      background: color-mix(in srgb, var(--accent2) 35%, transparent);
      border-color: color-mix(in srgb, var(--accent2) 55%, var(--border));
    }
    @media (prefers-reduced-motion: reduce){
      .carouselSlide{transition:none}
    }



    .carouselCanvas{
      height: var(--carouselH);
      min-height: var(--carouselH); /* la referencia (mínimo) */
      display:block;
    }
    .carouselMedia{width:100%; height:100%}
    .carouselImg{
      width:100%;
      height:100%;
      object-fit: cover;
      border-radius: 18px;
      border: 1px solid var(--border);
      display:block;
      background: color-mix(in srgb, var(--panel) 85%, transparent);
    }
    .recCard{
      height:100%;
      border-radius: 18px;
      border: 1px solid var(--border);
      background: linear-gradient(180deg, var(--panel2), color-mix(in srgb, var(--panel) 70%, transparent));
      overflow:hidden;
      display:flex;
      flex-direction:column;
    }
    .recImgWrap{position:relative; height:62%}
    .recImgOverlay{
      position:absolute; left:12px; right:12px; bottom:12px;
      display:flex; gap:8px; flex-wrap:wrap;
    }
    .recBody{padding:12px; height:38%; display:flex; flex-direction:column; justify-content:space-between}
    .recHead{display:flex; align-items:flex-start; justify-content:space-between; gap:10px}
    .recTitle{margin-top:10px; font-weight:900; font-size:16px}
    .recSub{margin-top:6px; color:var(--muted); font-size:13px; line-height:1.45}
    .recActions{display:flex; gap:8px; flex-wrap:wrap; margin-top:12px}
    .wardrobeCard{
      height:100%;
      position:relative;
      border-radius: 18px;
      overflow:hidden;
    }
    .wardrobeOverlay{
      position:absolute;
      left:12px; right:12px; bottom:12px;
    }
    .how-image{
        margin-top:16px;
        border-radius:16px;
        overflow:hidden;
        border:1px solid var(--border);
        background:var(--panel);

        width:140px;              /* 👈 más estrecho */
        height:170px;             /* 👈 proporción vertical */
        margin-left:auto;
        margin-right:auto;

        display:flex;
        align-items:center;
        justify-content:center;
        padding:8px;
    }

    .how-image img{
        max-width:100%;
        max-height:100%;
        object-fit:contain;
    }

.look-image {
    width: 100%;
    aspect-ratio: 4 / 5;
    border-radius: 18px;
    overflow: hidden;
    background: #f5f5f7;
    display: flex;
    align-items: center;
    justify-content: center;
}

.look-image img {
    width: 100%;
    height: 100%;
    object-fit: contain;
}

.look-card:hover .look-image img{
    transform:scale(1.04);
}