/*
Theme Name: Kalajokinen Commerce
Theme URI: https://kalajokinen.fi
Author: Kaupunkilehti Kalajokinen / Markus Haapasaari
Author URI: https://kalajokinen.fi
Description: Kevyt Kalajokinen-kassateema kauppa.kalajokinen.fi -aliverkolle. WooCommerce-keskeinen teema, joka käyttää Montserrat-otsikoita ja Sora-leipätekstiä sekä Kalajokisen brändivärejä.
Version: 1.0
Text Domain: kalajokinen-commerce
*/

/* -------------------------------------------------------
   1) FONTIT (LOKAALIT WOFF2 – toimivat myös Apple-laitteissa)
   ------------------------------------------------------- */

/* Montserrat – otsikot */
@font-face {
    font-family: 'Montserrat';
    src: url('assets/fonts/montserrat/montserrat-v31-latin-regular.woff2') format('woff2');
    font-weight: 400;
    font-style: normal;
    font-display: swap;
}
@font-face {
    font-family: 'Montserrat';
    src: url('assets/fonts/montserrat/montserrat-v31-latin-500.woff2') format('woff2');
    font-weight: 500;
    font-style: normal;
    font-display: swap;
}
@font-face {
    font-family: 'Montserrat';
    src: url('assets/fonts/montserrat/montserrat-v31-latin-500italic.woff2') format('woff2');
    font-weight: 500;
    font-style: italic;
    font-display: swap;
}
@font-face {
    font-family: 'Montserrat';
    src: url('assets/fonts/montserrat/montserrat-v31-latin-600.woff2') format('woff2');
    font-weight: 600;
    font-style: normal;
    font-display: swap;
}
@font-face {
    font-family: 'Montserrat';
    src: url('assets/fonts/montserrat/montserrat-v31-latin-600italic.woff2') format('woff2');
    font-weight: 600;
    font-style: italic;
    font-display: swap;
}
@font-face {
    font-family: 'Montserrat';
    src: url('assets/fonts/montserrat/montserrat-v31-latin-700.woff2') format('woff2');
    font-weight: 700;
    font-style: normal;
    font-display: swap;
}
@font-face {
    font-family: 'Montserrat';
    src: url('assets/fonts/montserrat/montserrat-v31-latin-700italic.woff2') format('woff2');
    font-weight: 700;
    font-style: italic;
    font-display: swap;
}
@font-face {
    font-family: 'Montserrat';
    src: url('assets/fonts/montserrat/montserrat-v31-latin-800.woff2') format('woff2');
    font-weight: 800;
    font-style: normal;
    font-display: swap;
}
@font-face {
    font-family: 'Montserrat';
    src: url('assets/fonts/montserrat/montserrat-v31-latin-800italic.woff2') format('woff2');
    font-weight: 800;
    font-style: italic;
    font-display: swap;
}
@font-face {
    font-family: 'Montserrat';
    src: url('assets/fonts/montserrat/montserrat-v31-latin-900.woff2') format('woff2');
    font-weight: 900;
    font-style: normal;
    font-display: swap;
}
@font-face {
    font-family: 'Montserrat';
    src: url('assets/fonts/montserrat/montserrat-v31-latin-900italic.woff2') format('woff2');
    font-weight: 900;
    font-style: italic;
    font-display: swap;
}

/* Sora – leipäteksti (500 perus, mutta mukana myös muut painot jos haluat käyttää) */
@font-face {
    font-family: 'Sora';
    src: url('assets/fonts/sora/sora-v17-latin-regular.woff2') format('woff2');
    font-weight: 400;
    font-style: normal;
    font-display: swap;
}
@font-face {
    font-family: 'Sora';
    src: url('assets/fonts/sora/sora-v17-latin-500.woff2') format('woff2');
    font-weight: 500;
    font-style: normal;
    font-display: swap;
}
@font-face {
    font-family: 'Sora';
    src: url('assets/fonts/sora/sora-v17-latin-600.woff2') format('woff2');
    font-weight: 600;
    font-style: normal;
    font-display: swap;
}
@font-face {
    font-family: 'Sora';
    src: url('assets/fonts/sora/sora-v17-latin-700.woff2') format('woff2');
    font-weight: 700;
    font-style: normal;
    font-display: swap;
}
@font-face {
    font-family: 'Sora';
    src: url('assets/fonts/sora/sora-v17-latin-800.woff2') format('woff2');
    font-weight: 800;
    font-style: normal;
    font-display: swap;
}

/* -------------------------------------------------------
   2) VÄRIT JA PERUSASETUKSET
   ------------------------------------------------------- */

:root {
    --kj-blue: #024f91;         /* Kalajokinen-sininen */
    --kj-yellow: #fcc049;       /* Hiekkasärkät-keltainen */
    --kj-karikko: #3c3c3b;      /* Karikko */
    --kj-night: #4c4c4c;        /* Yötaivas */
    --kj-white: #ffffff;        /* Talvi */

    --kj-radius-lg: 16px;
    --kj-radius-md: 10px;

    --kj-shadow-soft: 0 2px 6px rgba(0,0,0,0.06);
}

html {
    box-sizing: border-box;
    font-size: 16px;
}

*, *::before, *::after {
    box-sizing: inherit;
}

body {
    margin: 0;
    padding: 0;
    font-family: 'Sora', system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
    font-weight: 500;
    line-height: 1.55;
    color: var(--kj-night);
    background-color: #f5f7fb;
}

/* -------------------------------------------------------
   3) PERUSLAYOUT
   ------------------------------------------------------- */

.kj-site-wrapper {
    min-height: 100vh;
    display: flex;
    flex-direction: column;
}

.kj-site-header {
    background: var(--kj-white);
    border-bottom: 1px solid rgba(2,79,145,0.08);
    box-shadow: 0 1px 3px rgba(0,0,0,0.03);
    position: sticky;
    top: 0;
    z-index: 99;
}

.kj-header-inner {
    max-width: 1040px;
    margin: 0 auto;
    padding: 0.7rem 1rem;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
}

.kj-branding {
    display: flex;
    align-items: center;
    gap: 0.6rem;
}

.kj-logo-mark {
    width: 36px;
    height: 36px;
    border-radius: 50%;
    background: radial-gradient(circle at 30% 30%, var(--kj-yellow), var(--kj-blue));
}

.kj-site-title {
    font-family: 'Montserrat', system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
    font-weight: 700;
    font-size: 1.1rem;
    margin: 0;
    color: var(--kj-blue);
}

.kj-site-subtitle {
    margin: 0;
    font-size: 0.78rem;
    color: var(--kj-night);
    opacity: 0.75;
}

.kj-header-right {
    text-align: right;
    font-size: 0.78rem;
    color: var(--kj-night);
}

.kj-security-pill {
    display: inline-flex;
    align-items: center;
    gap: 0.35rem;
    padding: 0.25rem 0.7rem;
    border-radius: 999px;
    background: rgba(2,79,145,0.06);
    color: var(--kj-blue);
    font-weight: 600;
}

.kj-main {
    flex: 1 1 auto;
    max-width: 1040px;
    margin: 1.5rem auto 2rem;
    padding: 0 1rem 2rem;
}

.kj-site-footer {
    background: var(--kj-karikko);
    color: var(--kj-white);
    padding: 1.4rem 1rem;
    font-size: 0.82rem;
}

.kj-footer-inner {
    max-width: 1040px;
    margin: 0 auto;
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
    gap: 0.6rem;
    align-items: center;
}

/* -------------------------------------------------------
   4) TYPOGRAFIA
   ------------------------------------------------------- */

h1, h2, h3, h4, h5, h6 {
    font-family: 'Montserrat', system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
    font-weight: 700;
    color: var(--kj-blue);
    margin-top: 0;
}

a {
    color: var(--kj-blue);
    text-decoration: none;
}

a:hover {
    text-decoration: underline;
}

p {
    margin: 0 0 0.75rem;
}

/* -------------------------------------------------------
   5) PÄÄSISÄLTÖALUE
   ------------------------------------------------------- */

.kj-content-card {
    background: var(--kj-white);
    border-radius: var(--kj-radius-lg);
    box-shadow: var(--kj-shadow-soft);
    padding: 1.25rem 1.3rem;
}

/* -------------------------------------------------------
   6) WOO – PERUSKOSMEETTISTA SIIVOUSTA
   ------------------------------------------------------- */

.woocommerce .woocommerce-breadcrumb {
    display: none;
}

.woocommerce-cart, .woocommerce-checkout, .woocommerce-account {
    background: transparent;
}

.woocommerce .col2-set,
.woocommerce-page .col2-set {
    display: flex;
    flex-wrap: wrap;
    gap: 1rem;
}

.woocommerce .col2-set .col-1,
.woocommerce .col2-set .col-2 {
    flex: 1 1 320px;
}

.woocommerce form .form-row label {
    font-size: 0.85rem;
    font-weight: 600;
    color: var(--kj-night);
}

.woocommerce form .form-row input.input-text,
.woocommerce form .form-row textarea {
    border-radius: var(--kj-radius-md);
    border: 1px solid #d6dde7;
    padding: 0.5rem 0.6rem;
    font-family: 'Sora', system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
    font-weight: 500;
}

.woocommerce form .form-row input.input-text:focus,
.woocommerce form .form-row textarea:focus {
    border-color: var(--kj-blue);
    box-shadow: 0 0 0 1px rgba(2,79,145,0.15);
    outline: none;
}

.woocommerce a.button,
.woocommerce button.button,
.woocommerce input.button,
.woocommerce #respond input#submit {
    border-radius: 999px;
    background-color: var(--kj-blue);
    border-color: var(--kj-blue);
    color: var(--kj-white);
    font-family: 'Montserrat', system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
    font-weight: 700;
    padding: 0.6rem 1.2rem;
}

.woocommerce a.button:hover,
.woocommerce button.button:hover,
.woocommerce input.button:hover,
.woocommerce #respond input#submit:hover {
    background-color: #013c6c;
    border-color: #013c6c;
    color: var(--kj-white);
}

/* -------------------------------------------------------
   7) "PALAA KALAJOKINEN.FI -PALVELUUN" -NAPPULA
   ------------------------------------------------------- */

.kjc-return-main-site-wrap {
    margin-top: 2rem;
    text-align: center;
}

.kjc-return-main-site-button {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: 0.75rem 1.7rem;
    border-radius: 999px;
    background: var(--kj-blue);
    color: var(--kj-white);
    text-decoration: none;
    font-family: 'Montserrat', system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
    font-weight: 700;
    font-size: 0.95rem;
    border: 1px solid var(--kj-blue);
    cursor: pointer;
    gap: 0.35rem;
}

.kjc-return-main-site-button:hover {
    background: #013c6c;
    border-color: #013c6c;
    color: var(--kj-white);
}

.kjc-return-main-site-button span.kjc-arrow {
    font-size: 1rem;
}
