  * {
      margin: 0;
      padding: 0;
      box-sizing: border-box;
    }

    body {
      font-family: 'Inter', sans-serif;
      background: #faf3e8;  
      color: #2e241b;
      padding-bottom: 20px;
    } 

    /* HEADER – estilo de la imagen */
    .cafe-banner {
      background: #4f3a2b;  /* marrón oscuro */
      color: #f7e9da;
      padding: 1.2rem 1rem;
      text-align: center;
      border-bottom: 5px solid #b48b5a;
      box-shadow: 0 4px 10px rgba(0,0,0,0.15);
    }
    .cafe-banner h1 {
      font-weight: 800;
      letter-spacing: 1px;
      font-size: 2.2rem;
      margin-bottom: 0.2rem;
      color: #fbe5c3;
      text-shadow: 2px 2px 0 #3a2c1e;
    }
    .cafe-banner p {
      font-size: 1rem;
      opacity: 0.95;
      font-weight: 400;
    }
    .btn-elegir {
      background: #d9ae6c;
      border: none;
      color: #2e241b;
      font-weight: 600;
      padding: 0.5rem 1.5rem;
      border-radius: 40px;
      margin: 0.3rem;
      box-shadow: 0 3px 0 #7b5a3b;
      transition: all 0.1s ease;
    }
    .btn-elegir:hover {
      background: #e8c28e;
      transform: translateY(-2px);
      box-shadow: 0 5px 0 #7b5a3b;
    }
    .btn-outline-crema {
      background: transparent;
      border: 2px solid #d9ae6c;
      color: #fbe5c3;
      font-weight: 600;
      padding: 0.5rem 1.5rem;
      border-radius: 40px;
      margin: 0.3rem;
    }
    .btn-outline-crema:hover {
      background: #d9ae6c;
      color: #2e241b;
    }

    /* MOSTRADOR con la señora */
    .counter-section {
      background: #c9ab86;  /* madera clara */
      background-image: repeating-linear-gradient(45deg, #b48b5a22, #b48b5a22 10px, #cfa77622 10px, #cfa77622 20px);
      border-radius: 40px 40px 20px 20px;
      margin: 20px 16px 16px 16px;
      padding: 20px 18px;
      box-shadow: 0 10px 20px rgba(0,0,0,0.2), inset 0 1px 5px #eedcc9;
      border: 2px solid #7c5f41;
      position: relative;
    }
    /* efecto mostrador (barra de madera) */
    .counter-section::after {
      content: '';
      position: absolute;
      bottom: -6px;
      left: 10%;
      width: 80%;
      height: 12px;
      background: #5f4230;
      border-radius: 20px;
      filter: blur(2px);
      opacity: 0.5;
    }

    .barista-row {
      display: flex;
      align-items: center;
      gap: 20px;
      flex-wrap: wrap;
    }
    .barista-figure {
      text-align: center;
      min-width: 120px;
    }
    .barista-emoji {
      font-size: 100px;
      line-height: 1;
      background: #f2dbc0;
      width: 130px;
      height: 130px;
      border-radius: 50%;
      display: flex;
      align-items: center;
      justify-content: center;
      border: 5px solid #976b42;
      box-shadow: 0 6px 0 #4f3a2b;
      background: radial-gradient(circle at 30% 30%, #ffefd1, #e7cba5);
    }
    .barista-caption {
      font-weight: 600;
      margin-top: 10px;
      color: #2e1f12;
      background: #faead6;
      display: inline-block;
      padding: 4px 12px;
      border-radius: 40px;
      font-size: 0.9rem;
    }
    .speech-bubble {
      background: #fef9ed;
      padding: 18px 22px;
      border-radius: 30px 30px 30px 10px;
      box-shadow: 4px 4px 0 #7b5a3b;
      max-width: 450px;
      border: 1px solid #be9f7b;
    }
    .speech-bubble p {
      margin: 0;
      font-size: 1.3rem;
      font-weight: 600;
      color: #3b2d1e;
    }
    .speech-bubble small {
      color: #7d613f;
      font-weight: 500;
    }

    /* MINI TARJETAS de productos (los más elegidos) */
    .product-strip {
      display: flex;
      gap: 15px;
      overflow-x: auto;
      padding: 15px 5px 5px 5px;
      margin-top: 15px;
      scrollbar-width: thin;
      scrollbar-color: #b48b5a #eedcc9;
    }
    .mini-card {
      background: white;
      min-width: 170px;
      border-radius: 20px;
      padding: 12px 12px 8px 12px;
      box-shadow: 0 4px 8px rgba(0,0,0,0.1);
      border-left: 6px solid #976b42;
    }
    .mini-card h4 {
      font-size: 1rem;
      font-weight: 800;
      margin-bottom: 4px;
    }
    .mini-card .price {
      font-size: 1.2rem;
      font-weight: 700;
      color: #aa5e2b;
    }
    .mini-card .stock {
      font-size: 0.75rem;
      background: #f1dac2;
      display: inline-block;
      padding: 2px 8px;
      border-radius: 20px;
      color: #3a2a18;
    }
    .badge-limit {
      background: #cfaa7a;
      color: #1f2e1b;
      font-size: 0.7rem;
    }

    /* SECCIÓN OPINIONES (estilo Google) */
    .reviews-panel {
      background: #eadaca;
      margin: 20px 16px;
      padding: 18px;
      border-radius: 30px;
      border: 1px solid #b89b7a;
      box-shadow: inset 0 1px 5px #fff8ee, 0 5px 0 #896b4b;
    }
    .stars {
      color: #e6b422;
      font-size: 1.2rem;
      letter-spacing: 3px;
    }
    .review-item {
      font-size: 0.95rem;
      margin-bottom: 12px;
      padding-bottom: 8px;
      border-bottom: 1px dashed #b48b5a;
    }

    /* CHAT (abajo del mostrador) */
    .chat-wrapper {
      background: #fcf8f2;
      border-radius: 35px 35px 0 0;
      margin: 20px 16px 0 16px;
      padding: 20px 18px 25px 18px;
      box-shadow: 0 -8px 15px rgba(0,0,0,0.05);
      border: 1px solid #d8bc9c;
      border-bottom: none;
    }
    .chat-box {
      background: #f3ede4;
      border-radius: 24px;
      padding: 20px 15px 10px 15px;
      height: 620px;
      overflow-y: auto;
      display: flex;
      flex-direction: column;
      gap: 14px;
      border: 1px solid #cbb095;
    }
    .msg {
      display: flex;
    }
    .msg.bot {
      justify-content: flex-start;
    }
    .msg.user {
      justify-content: flex-end;
    }
    .bubble {
      max-width: 82%;
      padding: 14px 20px;
      border-radius: 22px;
      font-size: 1.05rem;
      line-height: 1.6;
      background: #e1cfb9;
      color: #2e241b;
      border-bottom-left-radius: 5px;
    }
    .user .bubble {
      background: #a77b55;
      color: white;
      border-bottom-right-radius: 5px;
    }
    .input-area {
      display: flex;
      gap: 10px;
      margin-top: 18px;
    }
    .input-area input {
      flex: 1;
      background: #fcf6ee;
      border: 2px solid #b48b5a;
      border-radius: 50px;
      padding: 12px 20px;
      outline: none;
      font-size: 1rem;
    }
    .input-area button {
      background: #6f4e37;
      border: none;
      border-radius: 60px;
      width: 55px;
      height: 55px;
      color: white;
      font-size: 1.3rem;
      box-shadow: 0 4px 0 #4f3a2b;
      transition: 0.05s linear;
    }
    .input-area button:active {
      transform: translateY(4px);
      box-shadow: none;
    }

    /* PIE DE PÁGINA con contactos y medios de pago (exacto de la imagen) */
    .footer-contact {
      background: #dccbb6;
      margin: 0 16px 20px 16px;
      padding: 20px 15px;
      border-radius: 30px;
      font-size: 0.9rem;
      border: 1px solid #aa875f;
      text-align: center;
      color: #2c1f12;
    }
    .footer-contact i {
      color: #4f3a2b;
      width: 24px;
    }
    .payment-icons {
      display: flex;
      flex-wrap: wrap;
      justify-content: center;
      gap: 18px;
      font-weight: 600;
      margin: 15px 0 5px 0;
    }
    .payment-icons a {
      text-decoration: none;
      background: #eee1cf;
      padding: 6px 16px;
      border-radius: 40px;
      color: #2e241b;
      border: 1px solid #a77b55;
      font-size: 0.9rem;
    }
    .whatsapp-link {
      color: #1f6b3b;
      font-weight: 600;
    }
    /* botón reset */
    .chat-control {
      display: flex;
      justify-content: center;
      margin-top: 10px;
    }
    .reset-chat {
      background: none;
      border: 1px solid #b48b5a;
      border-radius: 40px;
      padding: 8px 22px;
      font-size: 0.9rem;
      color: #5f4230;
    }