/** place in public/css/inhaler-card.css
/* ============================================================
   inhaler-card.css  —  drop after materialize.min.css
   Fully namespaced: zero bleed into the rest of your app.
   All per-card colour is driven by two CSS custom properties
   injected inline by the Blade component:
     --ic-accent   full hex   e.g. #0096c7
     --ic-tint     8% hex     e.g. #0096c714
   ============================================================ */

/* Shell */
.inhaler-card {
    width: 264px;
    border-radius: 18px !important;
    overflow: hidden;
    box-shadow: 0 2px 6px rgba(0,0,0,.07), 0 8px 24px rgba(0,0,0,.09) !important;
    background: #fff;
    transition: transform .30s cubic-bezier(.34,1.56,.64,1), box-shadow .30s ease;
    flex-shrink: 0;
    margin-right: 20px;   /* carousel gap */
    cursor: default;
}
.inhaler-card:hover {
    transform: translateY(-8px);
    box-shadow: 0 6px 16px rgba(0,0,0,.09), 0 22px 52px rgba(0,0,0,.15) !important;
}

/* Image zone */
.inhaler-card__image-zone {
    height: 190px !important;
    background-color: var(--ic-tint, #e3f2fd) !important;
    background-image: radial-gradient(
        ellipse 85% 65% at 50% 35%,
        rgba(255,255,255,.55) 0%, transparent 80%
    ) !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    position: relative;
    overflow: hidden;
}
/* decorative circles — accent colour, very low opacity */
.inhaler-card__image-zone::before {
    content: '';
    position: absolute;
    width: 160px; height: 160px;
    border-radius: 50%;
    background: var(--ic-accent, #0096c7);
    opacity: .07;
    bottom: -40px; right: -24px;
    pointer-events: none;
}
.inhaler-card__image-zone::after {
    content: '';
    position: absolute;
    width: 80px; height: 80px;
    border-radius: 50%;
    background: var(--ic-accent, #0096c7);
    opacity: .05;
    top: -20px; left: -12px;
    pointer-events: none;
}

.inhaler-card__img {
    height: 148px;
    width: auto;
    max-width: 76%;
    object-fit: contain;
    filter: drop-shadow(0 10px 20px rgba(0,0,0,.22));
    transition: transform .34s cubic-bezier(.34,1.56,.64,1);
    display: block;
    position: relative;
    z-index: 1;
}
.inhaler-card:hover .inhaler-card__img {
    transform: scale(1.08) translateY(-6px);
}

/* Type badge */
.inhaler-card__badge {
    position: absolute;
    top: 5px; right: 5px;
    background: var(--ic-accent, #0096c7);
    color: #fff;
    font-size: .4rem;
    font-weight: 400;
    letter-spacing: .14em;
    text-transform: uppercase;
    padding: 4px 11px;
    border-radius: 999px;
    z-index: 2;
    box-shadow: 0 2px 10px rgba(0,0,0,.22);
}

/* Content */
.inhaler-card__content { padding: 16px 18px 6px !important; }
.inhaler-card__brand {
    font-size: .6rem;
    font-weight: 700;
    letter-spacing: .16em;
    text-transform: uppercase;
    color: var(--ic-accent, #0096c7);
    margin: 0 0 4px;
    line-height: 1;
}
.inhaler-card__name {
    font-size: 1rem !important;
    font-weight: 700 !important;
    color: #0f172a !important;
    line-height: 1.28 !important;
    margin: 0 !important;
}

/* Actions */
.inhaler-card__actions {
    padding: 10px 14px 16px !important;
    display: flex !important;
    gap: 10px;
    border-top: 1px solid rgba(0,0,0,.06) !important;
}
.inhaler-card__btn {
    flex: 1;
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    gap: 6px;
    font-size: .7rem !important;
    font-weight: 700 !important;
    letter-spacing: .06em;
    text-transform: uppercase;
    border-radius: 9px !important;
    height: 38px !important;
    line-height: 1 !important;
    padding: 0 10px !important;
    transition: filter .18s ease, transform .2s cubic-bezier(.34,1.56,.64,1),
                box-shadow .18s ease !important;
    box-shadow: none !important;
    text-decoration: none;
    white-space: nowrap;
}
.inhaler-card__btn:hover { transform: translateY(-2px); }
.inhaler-card__btn svg { width: 14px; height: 14px; fill: currentColor; flex-shrink: 0; }

/* Video — solid */
.inhaler-card__btn--video {
    background-color: var(--ic-accent, #0096c7) !important;
    color: #fff !important;
}
.inhaler-card__btn--video:hover {
    filter: brightness(.86);
    box-shadow: 0 5px 16px rgba(0,0,0,.2) !important;
}

/* PDF — ghost */
.inhaler-card__btn--pdf {
    background-color: transparent !important;
    color: var(--ic-accent, #0096c7) !important;
    border: 1.5px solid var(--ic-accent, #0096c7) !important;
}
.inhaler-card__btn--pdf:hover {
    background-color: var(--ic-tint, rgba(0,150,199,.08)) !important;
}
