/**
 * Rich Attribute Suite — origin-modal structural CSS.
 *
 * Scope: only the rules the dialog needs to *function*. Mobil går til
 * blocking fullskjerm, desktop går til non-blocking over gallery-området.
 * Alt visuelt (farger, typografi, spacing, kort-layout) eier temaet.
 *
 * Ingen breakpoints: layouten bruker intrinsic grid (`auto-fit` +
 * `minmax(min(100%, N), 1fr)`) slik at seksjonene splittes når de har
 * plass og stacker når de ikke har det. Mobil- vs desktop-oppførsel
 * på selve dialogen drives av `:modal`-pseudo-klassen (satt av
 * `showModal()`), ikke av viewport-media.
 *
 * `[hidden]` må vinne over grid/flex-display — `!important` til slutt.
 */

/* ── Base ─────────────────────────────────────────────────────── */

.wc-ras-origin-modal {
    padding: 0;
    border: none;
    color: inherit;
    max-width: none;
    max-height: none;
    overflow: visible;
}

.wc-ras-origin-modal[open] {
    display: flex;
    flex-direction: column;
    background: var(--bg-color-selected, #fff);
}

/* Modal (showModal): full viewport, blocking, backdrop */
.wc-ras-origin-modal[open]:modal {
    position: fixed;
    inset: 0;
    width: 100vw;
    height: 100dvh;
    margin: 0;
    z-index: 1000;
}

.wc-ras-origin-modal:modal::backdrop {
    background: rgba(0, 0, 0, 0.55);
}

/* Non-modal (show): fyller parent-containeren (gallery på desktop) */
.wc-ras-origin-modal[open]:not(:modal) {
    width: 100%;
    height: 100%;
}

/* ── Chrome (nav + close) ─────────────────────────────────────── */

.wc-ras-origin-modal__chrome {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 0.5rem;
    padding: 0.5rem;
    flex: 0 0 auto;
}

.wc-ras-origin-modal__chrome button {
    cursor: pointer;
    background: transparent;
    border: 0;
    padding: 0.5rem 0.75rem;
    line-height: 1;
    font: inherit;
    color: inherit;
}

.wc-ras-origin-modal__chrome button[disabled] {
    opacity: 0.4;
    cursor: default;
}

/* ── Card + seksjoner ─────────────────────────────────────────── */
/*
 * Struktur:
 *   hero       → alltid full bredde (banner-bilde + tittel + pills)
 *   body       → flex-wrap-grid over de 4 seksjonene. flex-basis 14em
 *                + flex-grow gjør at siste seksjon i en rad fyller
 *                det som er igjen — ingen orphan-kolonner når 3 tracks
 *                fitter men vi bare har 4 items.
 *   permalink  → alltid full bredde nederst.
 *
 * Innenfor hver seksjon gjør `auto-fit + minmax(min(100%, Nem), 1fr)`
 * at sub-elementer (post-harvest ferm|tørk, flavour radar|noter)
 * splittes når seksjonen har plass, stabler seg ellers.
 *
 * `text-align: start` overstyrer temaets sentrerte p-regler som
 * ellers lekker inn.
 */

.wc-ras-origin-modal__card {
    flex: 1 1 auto;
    overflow: auto;
    min-height: 0;
    display: flex;
    flex-direction: column;
    gap: 1.5rem;
    padding: 1rem;
    text-align: start;
}

.wc-ras-origin-modal__hero {
    display: grid;
    gap: 0.75rem;
}

.wc-ras-origin-modal__image {
    display: block;
    width: 100%;
    height: auto;
    aspect-ratio: 5 / 2;
    max-height: 18em;
    object-fit: cover;
}

.wc-ras-origin-modal__hero-text {
    display: grid;
    gap: 0.5rem;
    align-content: start;
}

.wc-ras-origin-modal__pills {
    display: flex;
    flex-wrap: wrap;
    gap: 0.5rem 0.75rem;
    align-items: center;
}

.wc-ras-origin-modal__body {
    display: flex;
    flex-wrap: wrap;
    gap: 1.25rem;
}

.wc-ras-origin-modal__body > .wc-ras-origin-modal__section {
    flex: 1 1 14em;
    min-width: 0;
}

.wc-ras-origin-modal__section {
    display: grid;
    grid-template-columns: minmax(0, 1fr);
    gap: 0.5rem;
    align-content: start;
}

.wc-ras-origin-modal__section > * {
    margin: 0;
}

.wc-ras-origin-modal__section.postharvest {
    grid-template-columns: repeat(auto-fit, minmax(min(100%, 10em), 1fr));
    gap: 1rem;
}

.wc-ras-origin-modal__section.flavour {
    grid-template-columns: repeat(auto-fit, minmax(min(100%, 10em), 1fr));
    gap: 1rem;
    align-items: center;
}

.wc-ras-origin-modal__permalink {
    margin: 0;
}

/* ── Seksjons-interne komponenter ─────────────────────────────── */

.wc-ras-origin-modal .postharvest-item {
    display: flex;
    align-items: flex-start;
    gap: 0.75rem;
}

.wc-ras-origin-modal .postharvest-item .icon {
    flex: 0 0 auto;
    width: 1.25em;
    height: 1.25em;
}

.wc-ras-origin-modal .postharvest-item .icon svg {
    width: 100%;
    height: 100%;
}

.wc-ras-origin-modal .postharvest-item .body {
    flex: 1 1 auto;
    display: flex;
    flex-direction: column;
}

.wc-ras-origin-modal .pill {
    display: inline-flex;
    align-items: center;
    gap: 0.4rem;
    line-height: 1.2;
}

.wc-ras-origin-modal .pill img,
.wc-ras-origin-modal .pill svg,
.flag-img {
    height: 1em;
}

.wc-ras-origin-modal .certifications ul {
    display: flex;
    flex-wrap: wrap;
    gap: 1rem;
    align-items: center;
    list-style: none;
    margin: 0;
    padding: 0;
}

.wc-ras-origin-modal .certifications li {
    display: inline-flex;
    align-items: center;
    gap: 0.5rem;
}

.wc-ras-origin-modal .certifications img {
    width: 1.5em;
    height: 1.5em;
}

.wc-ras-origin-modal .radar {
    display: block;
}

/* ── Skala: små overskrifter + em-baserte SVG-er ──────────────── */

.wc-ras-origin-modal__title {
    font-size: 1.25em;
    margin: 0;
    line-height: 1.2;
}

.wc-ras-origin-modal__section h3,
.wc-ras-origin-modal .notes h3 {
    font-size: 1em;
    margin: 0 0 0.25em;
    line-height: 1.2;
}

.wc-ras-origin-modal svg.wc-ras-icon {
    width: 1em;
    height: 1em;
}

.wc-ras-origin-modal .wc-ras-radar {
    display: block;
    width: 100%;
    max-width: 12em;
    height: auto;
}

/* ── [hidden] wins over our display rules ─────────────────────── */

.wc-ras-origin-modal [hidden] {
    display: none !important;
}
