/* ==========================
   OLMOS DENTAL — Guardas Nocturnas (CSS INVERTIDO)
   Fondo blanco • Texto negro • Acentos dorados
========================== */

/* Variables (si ya tienes un :root global, puedes mezclarlo) */
:root{
    --olmos-bg: #ffffff;
    --olmos-surface: rgba(0,0,0,.03);
    --olmos-surface-2: rgba(0,0,0,.05);
    --olmos-border: rgba(0,0,0,.10);
  
    --olmos-text: rgba(0,0,0,.88);
    --olmos-muted: rgba(0,0,0,.68);
    --olmos-muted-2: rgba(0,0,0,.55);
  
    --olmos-gold: #d4af37;
    --olmos-gold-strong: #b89016;
    --olmos-gold-soft: rgba(212,175,55,.20);
    --olmos-gold-soft-2: rgba(212,175,55,.10);
  
    --olmos-radius: 18px;
    --olmos-radius-lg: 22px;
  
    --olmos-shadow: 0 16px 40px rgba(0,0,0,.10);
    --olmos-shadow-soft: 0 10px 24px rgba(0,0,0,.08);
    --olmos-ring: 0 0 0 3px rgba(212,175,55,.22);
  }
  
  /* Sección */
  .olmos-section{
    background:
      radial-gradient(1200px 600px at 15% 0%, rgba(212,175,55,.18), transparent 55%),
      radial-gradient(900px 500px at 95% 15%, rgba(212,175,55,.10), transparent 55%),
      var(--olmos-bg);
    color: var(--olmos-text);
    padding: clamp(56px, 5vw, 88px) 0;
    position: relative;
    overflow: hidden;
  }
  
  /* Contenedor */
  .olmos-container{
    width: min(1120px, calc(100% - 40px));
    margin: 0 auto;
  }
  
  /* Header */
  .olmos-header{
    text-align: left;
    max-width: 780px;
    margin-bottom: 26px;
  }
  .olmos-eyebrow{
    letter-spacing: .22em;
    text-transform: uppercase;
    color: var(--olmos-muted-2);
    font-size: .78rem;
    margin: 0 0 10px;
  }
  .olmos-title{
    font-size: clamp(1.9rem, 3.2vw, 2.6rem);
    line-height: 1.1;
    margin: 0 0 10px;
    font-weight: 900;
  }
  .olmos-subtitle{
    margin: 0;
    color: var(--olmos-muted);
    line-height: 1.65;
    font-size: 1rem;
  }
  
  /* Grids */
  .olmos-grid{
    display: grid;
    gap: 18px;
  }
  .olmos-grid-2{
    grid-template-columns: 1.05fr .95fr;
    align-items: start;
  }
  .olmos-grid-3{
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }
  
  /* Cards */
  .olmos-card{
    background: linear-gradient(180deg, rgba(0,0,0,.03), rgba(0,0,0,.015));
    border: 1px solid var(--olmos-border);
    border-radius: var(--olmos-radius-lg);
    box-shadow: var(--olmos-shadow-soft);
    padding: 18px;
    position: relative;
    overflow: hidden;
  }
  .olmos-card::before{
    content: "";
    position: absolute;
    inset: -1px;
    background: radial-gradient(600px 280px at 20% 0%, var(--olmos-gold-soft), transparent 55%);
    opacity: .55;
    pointer-events: none;
  }
  .olmos-card > *{
    position: relative;
    z-index: 1;
  }
  .olmos-card-wide{
    margin-top: 18px;
  }
  .olmos-card-title{
    margin: 0 0 10px;
    font-weight: 900;
    letter-spacing: .01em;
    font-size: 1.15rem;
  }
  .olmos-card-text{
    margin: 0 0 14px;
    color: var(--olmos-muted);
    line-height: 1.65;
  }
  
  /* Video */
  .olmos-video{
    border-radius: 16px;
    overflow: hidden;
    border: 1px solid rgba(212,175,55,.28);
    background: rgba(0,0,0,.03);
    box-shadow: 0 14px 34px rgba(0,0,0,.10);
  }
  .olmos-iframe{
    width: 100%;
    aspect-ratio: 16/9;
    display: block;
  }
  .olmos-video-tag{
    width: 100%;
    height: auto;
    display: block;
  }
  
  /* Nota */
  .olmos-note{
    margin-top: 14px;
    padding: 12px 14px;
    border-radius: 14px;
    border: 1px solid rgba(212,175,55,.35);
    background: linear-gradient(180deg, rgba(212,175,55,.12), rgba(0,0,0,.01));
    color: var(--olmos-muted);
    line-height: 1.55;
  }
  .olmos-note strong{ color: rgba(0,0,0,.88); }
  
  /* Lista de beneficios */
  .olmos-list{
    list-style: none;
    padding: 0;
    margin: 0;
    display: grid;
    gap: 10px;
  }
  .olmos-list li{
    padding-left: 22px;
    position: relative;
    color: var(--olmos-muted);
    line-height: 1.55;
  }
  .olmos-list li::before{
    content: "";
    width: 10px; height: 10px;
    border-radius: 50%;
    position: absolute;
    left: 0; top: .38em;
    background: radial-gradient(circle at 30% 30%, #fff, var(--olmos-gold));
    box-shadow: 0 0 0 4px rgba(212,175,55,.22);
  }
  .olmos-list strong{ color: rgba(0,0,0,.88); }
  
  /* Badges */
  .olmos-badges{
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
    margin-top: 14px;
  }
  .olmos-badge{
    font-size: .82rem;
    color: rgba(0,0,0,.78);
    padding: 8px 10px;
    border-radius: 999px;
    border: 1px solid rgba(212,175,55,.40);
    background: rgba(212,175,55,.12);
  }
  
  /* Mini cards */
  .olmos-mini{
    border-radius: var(--olmos-radius);
    border: 1px solid rgba(0,0,0,.10);
    background: rgba(0,0,0,.02);
    padding: 14px;
  }
  .olmos-mini-title{
    margin: 0 0 6px;
    font-size: 1rem;
    font-weight: 900;
  }
  .olmos-mini-text{
    margin: 0;
    color: var(--olmos-muted);
    line-height: 1.6;
  }
  
  /* Tipos de guardas */
  .olmos-type{
    border-radius: var(--olmos-radius-lg);
    border: 1px solid rgba(0,0,0,.10);
    background: linear-gradient(180deg, rgba(0,0,0,.02), rgba(0,0,0,.01));
    padding: 14px;
    box-shadow: var(--olmos-shadow-soft);
    transition: transform .2s ease, border-color .2s ease, box-shadow .2s ease;
  }
  .olmos-type:hover{
    transform: translateY(-2px);
    border-color: rgba(212,175,55,.55);
    box-shadow: var(--olmos-shadow);
  }
  
  .olmos-type-image{
    width: 100%;
    border-radius: 16px;
    overflow: hidden;
    border: 1px solid rgba(212,175,55,.35);
    background: rgba(0,0,0,.02);
    box-shadow: 0 12px 28px rgba(0,0,0,.10);
    margin-bottom: 12px;
  }
  .olmos-type-image img{
    width: 100%;
    height: 180px;
    object-fit: cover;
    display: block;
    transform: scale(1.01);
    transition: transform .25s ease;
  }
  .olmos-type:hover .olmos-type-image img{
    transform: scale(1.05);
  }
  
  .olmos-type-title{
    margin: 0 0 8px;
    font-weight: 950;
    font-size: 1.08rem;
    color: rgba(0,0,0,.90);
  }
  .olmos-type-text{
    margin: 0 0 12px;
    color: var(--olmos-muted);
    line-height: 1.65;
  }
  
  .olmos-bullets{
    margin: 0;
    padding-left: 18px;
    color: var(--olmos-muted);
    line-height: 1.55;
  }
  .olmos-bullets li{
    margin: 6px 0;
  }
  .olmos-bullets li::marker{
    color: var(--olmos-gold-strong);
  }
  
  /* CTA */
  .olmos-cta{
    margin-top: 18px;
    border-radius: var(--olmos-radius-lg);
    border: 1px solid rgba(212,175,55,.45);
    background: linear-gradient(90deg, rgba(212,175,55,.18), rgba(0,0,0,.01));
    box-shadow: var(--olmos-shadow);
    padding: 18px;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 14px;
  }
  .olmos-cta-title{
    margin: 0 0 6px;
    font-size: 1.2rem;
    font-weight: 950;
    color: rgba(0,0,0,.92);
  }
  .olmos-cta-text{
    margin: 0;
    color: var(--olmos-muted);
    line-height: 1.6;
  }
  .olmos-cta-actions{
    display: flex;
    gap: 10px;
    flex-wrap: wrap;
    justify-content: flex-end;
  }
  
  /* Botones */
  .olmos-btn{
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 10px;
    text-decoration: none;
    border-radius: 999px;
    padding: 12px 16px;
    font-weight: 950;
    letter-spacing: .02em;
    border: 1px solid transparent;
    transition: transform .15s ease, box-shadow .2s ease, background .2s ease, border-color .2s ease;
    user-select: none;
  }
  .olmos-btn:active{ transform: translateY(1px); }
  
  .olmos-btn-primary{
    color: #111;
    background: linear-gradient(180deg, #f7e19b, var(--olmos-gold));
    border-color: rgba(184,144,22,.35);
    box-shadow: 0 10px 24px rgba(212,175,55,.25);
  }
  .olmos-btn-primary:hover{
    box-shadow: 0 16px 34px rgba(212,175,55,.30);
  }
  
  .olmos-btn-ghost{
    color: rgba(0,0,0,.85);
    background: rgba(0,0,0,.02);
    border-color: rgba(0,0,0,.14);
  }
  .olmos-btn-ghost:hover{
    border-color: rgba(212,175,55,.55);
    box-shadow: 0 10px 24px rgba(0,0,0,.10);
  }
  
  /* Focus */
  .olmos-btn:focus-visible,
  .olmos-type:focus-within,
  .olmos-card:focus-within{
    outline: none;
    box-shadow: var(--olmos-ring), var(--olmos-shadow-soft);
  }
  
  /* Responsive */
  @media (max-width: 980px){
    .olmos-grid-2{ grid-template-columns: 1fr; }
    .olmos-grid-3{ grid-template-columns: 1fr; }
    .olmos-cta{
      flex-direction: column;
      align-items: flex-start;
    }
    .olmos-cta-actions{
      width: 100%;
      justify-content: flex-start;
    }
    .olmos-type-image img{ height: 210px; }
  }
  
  @media (max-width: 520px){
    .olmos-container{ width: min(1120px, calc(100% - 28px)); }
    .olmos-card{ padding: 16px; }
    .olmos-btn{ width: 100%; }
  }
  