/* Kalajokinen Shop Bridge – peruslayout
   Kevyt, mutta Kalajokinen-henkinen. */

/* --------- PERUSKONTEKSTI --------- */

.kj-shop-bridge {
    margin: 2rem 0;
    font-family: system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
}

/* Otsikko korttilistalle */
.kj-shop-bridge .kj-shop-heading {
    font-size: 1.6rem;
    margin: 0 0 1rem;
    color: #024f91; /* Kalajokinen-sininen */
}

/* Virhe- ja tyhjätilaviestit */
.kj-shop-bridge .kj-shop-error,
.kj-shop-bridge .kj-shop-empty {
    padding: 1rem 1.25rem;
    border-left: 4px solid #9e6914; /* Rantahiekka */
    background: #fff7e0;
    color: #4c4c4c;
}

/* --------- GRID --------- */

.kj-shop-bridge .kj-shop-grid {
    display: grid;
    grid-auto-rows: 1fr;
    gap: 1rem;
}

.kj-shop-bridge.kj-shop-columns-1 .kj-shop-grid {
    grid-template-columns: 1fr;
}

.kj-shop-bridge.kj-shop-columns-2 .kj-shop-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
}

.kj-shop-bridge.kj-shop-columns-3 .kj-shop-grid {
    grid-template-columns: repeat(3, minmax(0, 1fr));
}

.kj-shop-bridge.kj-shop-columns-4 .kj-shop-grid {
    grid-template-columns: repeat(4, minmax(0, 1fr));
}

@media (max-width: 900px) {
    .kj-shop-bridge.kj-shop-columns-3 .kj-shop-grid,
    .kj-shop-bridge.kj-shop-columns-4 .kj-shop-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
}

@media (max-width: 600px) {
    .kj-shop-bridge .kj-shop-grid {
        grid-template-columns: 1fr !important;
    }
}

/* --------- KORTTI --------- */

.kj-shop-bridge .kj-shop-card {
    background: #ffffff;
    border-radius: 12px;
    border: 1px solid #e3e7ec;
    overflow: hidden;
    display: flex;
    flex-direction: column;
    box-shadow: 0 2px 4px rgba(0,0,0,0.03);
    color: #4c4c4c; /* perusväri tekstille kortin sisällä */
}

.kj-shop-bridge .kj-shop-thumb-link {
    display: block;
    overflow: hidden;
}

.kj-shop-bridge .kj-shop-thumb {
    display: block;
    width: 100%;
    height: 180px;
    object-fit: cover;
    transition: transform 0.25s ease-out;
}

.kj-shop-bridge .kj-shop-card:hover .kj-shop-thumb {
    transform: scale(1.03);
}

.kj-shop-bridge .kj-shop-card-body {
    padding: 0.9rem 1rem 1rem;
    display: flex;
    flex-direction: column;
    flex: 1 1 auto;
}

/* --------- OTSIKKO PER LAATIKKO --------- */

.kj-shop-bridge .kj-shop-card-title {
    font-size: 1.05rem;
    margin: 0 0 0.4rem;
    font-weight: 600;
}

/* Linkki otsikossa – pakotetaan siniseksi ja ilman piste-/alleviivauksia */
.kj-shop-bridge .kj-shop-card-title a {
    color: #024f91 !important;          /* Kalajokinen-sininen */
    text-decoration: none !important;
    border-bottom: none !important;
}

.kj-shop-bridge .kj-shop-card-title a:hover {
    text-decoration: underline !important;
    border-bottom: none !important;
}

/* --------- HINNAT --------- */

.kj-shop-bridge .kj-shop-price {
    margin-bottom: 0.35rem;
    color: #3c3c3b;                     /* Karikko */
    font-weight: 700;                   /* jos ei alea, tämä on päähinta */
}

/* Alehinnat: WooCommerce käyttää <del> ja <ins> */

/* Vanha hinta */
.kj-shop-bridge .kj-shop-price del,
.kj-shop-bridge .kj-shop-price del * {
    text-decoration: none !important;
    border-bottom: none !important;
    background: none !important;
    color: #999999 !important;          /* haalea vanha hinta */
    font-weight: 400 !important;
    margin-right: 0.35rem;
}

/* Uusi hinta */
.kj-shop-bridge .kj-shop-price ins,
.kj-shop-bridge .kj-shop-price ins * {
    text-decoration: none !important;
    border-bottom: none !important;
    background: none !important;
    color: #3c3c3b !important;          /* selkeä nykyinen hinta */
    font-weight: 700 !important;
}

/* Lyhyt kuvaus */
.kj-shop-bridge .kj-shop-desc {
    font-size: 0.9rem;
    line-height: 1.4;
    color: #4c4c4c;
    margin-bottom: 0.75rem;
}

/* --------- NAPIT --------- */

.kj-shop-bridge .kj-shop-actions {
    margin-top: auto;
    display: flex;
    flex-wrap: wrap;
    gap: 0.4rem;
}

.kj-shop-bridge .kj-shop-button {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: 0.45rem 0.9rem;
    border-radius: 999px;
    font-size: 0.9rem;
    text-decoration: none !important;
    border: 1px solid transparent;
    cursor: pointer;
    white-space: nowrap;
}

/* Osta-nappi – perus */
.kj-shop-bridge .kj-shop-button-primary {
    background: #024f91;                /* Kalajokinen-sininen */
    border-color: #024f91;
    color: #ffffff !important;          /* valkoinen teksti */
    font-weight: 600;
}

/* Osta-nappi – hover */
.kj-shop-bridge .kj-shop-button-primary:hover {
    background: #fcc049;                /* Hiekkasärkät-keltainen */
    border-color: #fcc049;
    color: #3c3c3b !important;          /* tumma teksti keltaisella */
}

/* Lisätiedot-nappi */
.kj-shop-bridge .kj-shop-button-secondary {
    background: #ffffff;
    border-color: #c4ccd6;
    color: #4c4c4c;
}

.kj-shop-bridge .kj-shop-button-secondary:hover {
    background: #f5f7fa;
    border-color: #9ea9b8;
    color: #3c3c3b;
}
