:root {
    --bg: #fff8f0;
    --paper: #fffdf9;
    --paper-2: #fff1e0;
    --ink: #24130f;
    --muted: #735c55;
    --brand: #b3261e;
    --brand-dark: #7e1712;
    --accent: #f5a623;
    --green: #477a4b;
    --line: rgba(91, 43, 30, .16);
    --shadow: 0 22px 70px rgba(80, 31, 18, .15);
    --radius: 24px;
    --max: 1180px;
}

* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
    margin: 0;
    font-family: system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
    color: var(--ink);
    background:
        radial-gradient(circle at top left, rgba(245, 166, 35, .20), transparent 35rem),
        radial-gradient(circle at 80% 10%, rgba(179, 38, 30, .12), transparent 28rem),
        var(--bg);
    line-height: 1.6;
}

a { color: var(--brand); text-decoration: none; }
a:hover { color: var(--brand-dark); }
img { max-width: 100%; display: block; }
code { background: rgba(179, 38, 30, .08); padding: .15rem .35rem; border-radius: .4rem; }

.skip-link {
    position: absolute;
    left: -999px;
    top: 1rem;
    padding: .7rem 1rem;
    background: var(--ink);
    color: white;
    z-index: 99;
}
.skip-link:focus { left: 1rem; }

.site-header {
    position: sticky;
    top: 0;
    z-index: 50;
    backdrop-filter: blur(18px);
    background: rgba(255, 248, 240, .88);
    border-bottom: 1px solid var(--line);
}
.topbar,
.main-nav,
.section,
.hero,
.page-hero,
.site-footer > * {
    width: min(var(--max), calc(100% - 2rem));
    margin-inline: auto;
}
.topbar {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: .9rem 0;
}
.brand {
    display: inline-flex;
    align-items: center;
    gap: .8rem;
    color: var(--ink);
}
.brand-mark { width: 52px; height: 52px; }
.brand strong { display: block; font-size: 1.08rem; letter-spacing: .02em; }
.brand small { display: block; color: var(--muted); font-size: .84rem; }

.nav-toggle {
    display: none;
    border: 0;
    background: var(--ink);
    color: white;
    border-radius: 999px;
    padding: .65rem .9rem;
    align-items: center;
    gap: .6rem;
    cursor: pointer;
}
.nav-toggle span {
    display: block;
    width: 16px;
    height: 2px;
    background: white;
    margin: 3px 0;
}
.nav-toggle em { font-style: normal; font-size: .9rem; }
.main-nav {
    display: flex;
    gap: .35rem;
    align-items: center;
    justify-content: center;
    padding: 0 0 .85rem;
    flex-wrap: wrap;
}
.main-nav a {
    color: var(--ink);
    padding: .65rem .85rem;
    border-radius: 999px;
    font-weight: 750;
    font-size: .94rem;
}
.main-nav a:hover,
.main-nav a.active {
    background: var(--brand);
    color: white;
}

.hero {
    display: grid;
    grid-template-columns: 1.08fr .92fr;
    gap: 2.5rem;
    align-items: center;
    padding: 4rem 0 3rem;
}
.hero h1,
.page-hero h1 {
    font-size: clamp(2.4rem, 6vw, 5rem);
    line-height: .98;
    margin: .2rem 0 1.2rem;
    letter-spacing: -.055em;
}
.lead,
.page-hero p {
    font-size: clamp(1.08rem, 2vw, 1.35rem);
    color: var(--muted);
    max-width: 64ch;
}
.eyebrow {
    text-transform: uppercase;
    letter-spacing: .13em;
    color: var(--brand);
    font-weight: 900;
    font-size: .78rem;
}
.hero-actions { display: flex; gap: .8rem; flex-wrap: wrap; margin-top: 1.5rem; }



.media-section {
    max-width: 1180px;
    margin-left: auto;
    margin-right: auto;
    padding-left: 1rem;
    padding-right: 1rem;
}

.video-hero {
    position: relative;
    width: 100%;
    min-height: 360px;
    overflow: hidden;
    border-radius: 22px;
    margin: 2rem 0;
    background: #2b1d12;
    box-shadow: 0 18px 45px rgba(80, 54, 30, 0.18);
}

.video-hero-bg {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.video-hero-overlay {
    position: absolute;
    inset: 0;
    background: linear-gradient(
        90deg,
        rgba(35, 24, 15, 0.72),
        rgba(35, 24, 15, 0.38),
        rgba(35, 24, 15, 0.18)
    );
}

.video-hero-content {
    position: relative;
    z-index: 2;
    max-width: 720px;
    padding: 4rem 2rem;
    color: #fffdf8;
}

.video-hero-content h1 {
    margin: 0 0 1rem;
    font-size: clamp(2rem, 5vw, 4rem);
    line-height: 1.05;
}

.video-hero-content p {
    max-width: 620px;
    font-size: 1.1rem;
    line-height: 1.65;
}

.video-hero-content .eyebrow {
    margin-bottom: 0.8rem;
    font-size: 0.85rem;
    text-transform: uppercase;
    letter-spacing: 0.12em;
    font-weight: 700;
    color: #f2d7a4;
}

@media (max-width: 800px) {
    .video-hero {
        min-height: 300px;
        border-radius: 18px;
    }

    .video-hero-content {
        padding: 3rem 1.25rem;
    }
}

.two-images {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 1.5rem;
    margin: 2rem 0;
}

.image-card {
    margin: 0;
    background: #fffdf8;
    border-radius: 20px;
    overflow: hidden;
    box-shadow: 0 10px 28px rgba(80, 54, 30, 0.12);
    border: 1px solid rgba(120, 80, 40, 0.12);
}

.image-card img {
    display: block;
    width: 100%;
    height: auto;
}

@media (max-width: 800px) {
    .two-images {
        grid-template-columns: 1fr;
    }

 
}


.info-trio {
    display: grid;
    grid-template-columns: repeat(3, 0.2fr);
    gap: 1.5rem;
    margin: 2rem 0;
 justify-content: center;
}

.info-box {
    background: #fffdf8;
    border-radius: 18px;
    padding: 1.5rem;
    box-shadow: 0 10px 28px rgba(80, 54, 30, 0.12);
    border: 1px solid rgba(120, 80, 40, 0.12);
}

.info-box h2 {
    margin: 0 0 0.75rem;
    font-size: 1.35rem;
    color: #3b2a1a;
}

.info-box p {
    margin: 0;
    line-height: 1.6;
    color: #5a4632;
}

/* Mobil */
@media (max-width: 800px) {
    .info-trio {
        grid-template-columns: 1fr;
    }
}
.button {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: .45rem;
    min-height: 46px;
    padding: .8rem 1.1rem;
    border-radius: 999px;
    border: 2px solid var(--brand);
    background: var(--brand);
    color: white;
    font-weight: 850;
    box-shadow: 0 12px 30px rgba(179, 38, 30, .23);
}
.button:hover { color: white; background: var(--brand-dark); border-color: var(--brand-dark); }
.button-ghost { background: transparent; color: var(--brand); box-shadow: none; }
.button-ghost:hover { background: var(--brand); color: white; }
.button-light { background: white; border-color: white; color: var(--brand); box-shadow: none; }
.button-light:hover { background: var(--paper-2); color: var(--brand-dark); }

.hero-card {
    background: linear-gradient(145deg, var(--paper), var(--paper-2));
    padding: 1rem;
    border: 1px solid var(--line);
    border-radius: calc(var(--radius) + 12px);
    box-shadow: var(--shadow);
    transform: rotate(1.5deg);
}
.hero-card img { border-radius: var(--radius); width: 100%; }
.stat-row {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: .6rem;
    margin-top: .8rem;
}
.stat-row span {
    background: white;
    border-radius: 18px;
    padding: .75rem;
    text-align: center;
    color: var(--muted);
    font-size: .84rem;
}
.stat-row strong { display: block; color: var(--brand); font-size: 1.3rem; }

.page-hero {
    padding: 4rem 0 2.5rem;
    min-height: 330px;
    display: flex;
    flex-direction: column;
    justify-content: center;
}
.small-hero { min-height: 250px; }
.category-hero,
.living-hero,
.business-hero,
.community-hero,
.gallery-hero,
.contact-hero,
.history-hero {
    background: linear-gradient(135deg, rgba(255,255,255,.72), rgba(255,241,224,.72)), url('../img/pattern.svg');
    border-bottom: 1px solid var(--line);
}
.big { font-size: 3.2rem; }

.section { padding: 3rem 0; }
.section-heading {
    display: flex;
    justify-content: space-between;
    align-items: end;
    gap: 1rem;
    margin-bottom: 1.2rem;
}
.section-heading h2,
.intro-copy h2,
.split-section h2,
.submit-box h2,
.readable h2 {
    font-size: clamp(1.8rem, 3vw, 3rem);
    line-height: 1.05;
    letter-spacing: -.04em;
    margin: 0 0 .8rem;
}
.intro-grid,
.two-column,
.split-section {
    display: grid;
    grid-template-columns: minmax(0, 1.2fr) minmax(280px, .8fr);
    gap: 1.5rem;
    align-items: start;
}
.highlight-box,
.info-panel,
.submit-box,
.notice {
    background: var(--paper);
    border: 1px solid var(--line);
    border-radius: var(--radius);
    padding: 1.4rem;
    box-shadow: var(--shadow);
}
.quick-links { display: grid; gap: .6rem; }
.quick-links a,
.link-list li,
.check-list li {
    background: var(--paper-2);
    padding: .75rem .9rem;
    border-radius: 14px;
    color: var(--ink);
    font-weight: 750;
}

.category-grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 1rem;
}
.category-grid.compact { grid-template-columns: repeat(6, minmax(0, 1fr)); }
.category-card,
.feature-card,
.association-card,
.business-card,
.directory-row,
.event-card,
.gallery-item {
    background: rgba(255, 253, 249, .92);
    border: 1px solid var(--line);
    border-radius: var(--radius);
    box-shadow: 0 12px 35px rgba(80, 31, 18, .09);
}
.category-card {
    position: relative;
    display: flex;
    flex-direction: column;
    gap: .6rem;
    min-height: 100%;
    padding: 1rem;
    color: var(--ink);
    overflow: hidden;
}
.category-card img { border-radius: 18px; aspect-ratio: 16 / 9; object-fit: cover; background: var(--paper-2); }
.category-card h2,
.category-card h3 { margin: 0; line-height: 1.1; }
.category-card p { margin: 0; color: var(--muted); }
.category-icon { font-size: 1.7rem; }
.card-link { margin-top: auto; font-weight: 850; }
.pill-list {
    list-style: none;
    display: flex;
    flex-wrap: wrap;
    gap: .35rem;
    margin: .2rem 0 0;
    padding: 0;
}
.pill-list li,
.tag {
    display: inline-flex;
    border-radius: 999px;
    padding: .28rem .55rem;
    background: rgba(179, 38, 30, .08);
    color: var(--brand-dark);
    font-size: .82rem;
    font-weight: 800;
}

.feature-grid,
.association-grid,
.gallery-grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 1rem;
}
.feature-card,
.association-card { padding: 1.35rem; }
.feature-card h2,
.feature-card h3,
.association-card h2,
.business-card h3 { margin-top: 0; line-height: 1.1; }
.feature-card p,
.association-card p,
.business-card p { color: var(--muted); }

.event-list { display: grid; gap: 1rem; }
.event-list.mini { padding: 0; }
.event-card {
    display: grid;
    grid-template-columns: 74px 1fr;
    gap: 1rem;
    padding: 1rem;
    align-items: center;
}
.event-card.large { grid-template-columns: 110px 1fr; padding: 1.25rem; }
.event-card time {
    display: grid;
    place-items: center;
    min-height: 74px;
    border-radius: 18px;
    background: var(--brand);
    color: white;
    font-weight: 900;
    text-align: center;
}
.event-card.large time strong { font-size: 2rem; line-height: 1; }
.event-card h2,
.event-card h3 { margin: .35rem 0 .2rem; }
.event-card p { margin: 0; color: var(--muted); }

.quote-band {
    background: var(--ink);
    color: white;
    border-radius: calc(var(--radius) + 10px);
    padding: 2rem;
    margin-block: 2rem;
}
.quote-band .eyebrow { color: var(--accent); }
.quote-slider {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 1rem;
}
blockquote {
    margin: 0;
    font-size: 1.08rem;
    background: rgba(255,255,255,.08);
    border: 1px solid rgba(255,255,255,.15);
    border-radius: 18px;
    padding: 1rem;
}

.tools-row { padding-bottom: 1rem; }
.search-box {
    display: grid;
    gap: .45rem;
    max-width: 620px;
    font-weight: 850;
}
input,
select,
textarea {
    width: 100%;
    border: 1px solid var(--line);
    border-radius: 16px;
    padding: .9rem 1rem;
    background: white;
    color: var(--ink);
    font: inherit;
}
input:focus,
select:focus,
textarea:focus { outline: 3px solid rgba(179, 38, 30, .18); border-color: var(--brand); }

.business-list { display: grid; gap: .85rem; }
.business-card { padding: 1rem; }
.directory-list { display: grid; gap: .6rem; }
.directory-row {
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 1rem;
    padding: .9rem 1rem;
}
.directory-row h2 { margin: 0; font-size: 1rem; }
.directory-row span { color: var(--muted); font-weight: 750; }

.gallery-item { overflow: hidden; margin: 0; }
.gallery-item img { width: 100%; aspect-ratio: 4 / 3; object-fit: cover; }
.gallery-item figcaption { padding: .85rem 1rem; font-weight: 850; }

.contact-form {
    display: grid;
    gap: .9rem;
    background: var(--paper);
    border: 1px solid var(--line);
    border-radius: var(--radius);
    padding: 1.2rem;
}
.contact-form label { display: grid; gap: .35rem; font-weight: 850; }
.hp { position: absolute; left: -9999px; }
.notice.success { border-color: rgba(71, 122, 75, .35); }
.notice.error { border-color: rgba(179, 38, 30, .35); }
.muted { color: var(--muted); }
.readable { max-width: 820px; font-size: 1.1rem; }

.big-link {
    display: grid;
    place-items: center;
    min-height: 180px;
    background: var(--brand);
    color: white;
    border-radius: var(--radius);
    font-weight: 900;
    font-size: 1.2rem;
    padding: 1.4rem;
    text-align: center;
}
.big-link:hover { color: white; background: var(--brand-dark); }

.site-footer {
    margin-top: 2rem;
    background: #1f120f;
    color: white;
    padding: 2rem 0 1rem;
}
.footer-cta {
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 1rem;
    background: linear-gradient(135deg, var(--brand), var(--brand-dark));
    border-radius: calc(var(--radius) + 8px);
    padding: 1.5rem;
    margin-bottom: 2rem;
}
.footer-cta h2 { margin: 0 0 .3rem; }
.footer-cta p { margin: 0; color: rgba(255,255,255,.82); }
.footer-grid {
    display: grid;
    grid-template-columns: 1.2fr .8fr 1fr;
    gap: 1.5rem;
    color: rgba(255,255,255,.8);
}
.footer-grid h3 { color: white; margin-top: 0; }
.footer-grid ul { list-style: none; padding: 0; margin: 0; display: grid; gap: .4rem; }
.site-footer a { color: white; }
.footer-bottom {
    display: flex;
    justify-content: space-between;
    border-top: 1px solid rgba(255,255,255,.12);
    margin-top: 1.5rem;
    padding-top: 1rem;
    color: rgba(255,255,255,.72);
}

.hidden { display: none !important; }

@media (max-width: 980px) {
    .hero,
    .intro-grid,
    .two-column,
    .split-section,
    .footer-grid { grid-template-columns: 1fr; }
    .category-grid,
    .category-grid.compact,
    .feature-grid,
    .association-grid,
    .gallery-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
    .quote-slider { grid-template-columns: repeat(2, minmax(0, 1fr)); }
}

@media (max-width: 720px) {
    .nav-toggle { display: inline-flex; }
    .main-nav {
        display: none;
        align-items: stretch;
        padding: .7rem 0 1rem;
    }
    .main-nav.open { display: grid; }
    .main-nav a { border-radius: 16px; background: rgba(255,255,255,.8); }
    .hero { padding-top: 2rem; }
    .hero-card { transform: none; }
    .category-grid,
    .category-grid.compact,
    .feature-grid,
    .association-grid,
    .gallery-grid,
    .quote-slider { grid-template-columns: 1fr; }
    .section-heading,
    .footer-cta,
    .footer-bottom,
    .directory-row { align-items: start; flex-direction: column; display: flex; }
    .event-card,
    .event-card.large { grid-template-columns: 1fr; }
    .stat-row { grid-template-columns: 1fr; }
}


/* --- Databas/admin-utbyggnad --- */
.notice { padding: 1rem 1.2rem; border-radius: 1rem; margin: 1rem 0; border: 1px solid rgba(0,0,0,.08); background: #fff7ed; }
.notice.success { background: #ecfdf5; }
.notice.error { background: #fef2f2; }
.meta-list { display: flex; flex-wrap: wrap; gap: .55rem 1rem; margin: .8rem 0; color: var(--muted); }
.listing-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(260px, 1fr)); gap: 1rem; }
.listing-card, .prose-card { background: var(--surface); border: 1px solid rgba(0,0,0,.07); border-radius: 1.4rem; padding: 1.2rem; box-shadow: var(--shadow); }
.listing-card h3 { margin-top: .3rem; }
.event-card.wide { align-items: flex-start; }
.event-card.wide time { min-width: 8.5rem; }
.event-card.wide time strong { display: block; font-size: 1.3rem; }
.event-card.wide time span { display: block; font-size: .85rem; opacity: .75; }
.admin-link { opacity: .8; }
.admin-body { background: #f8f4ef; }
.admin-top { max-width: 1180px; margin: 0 auto; padding: 1rem; display: flex; align-items: center; justify-content: space-between; gap: 1rem; }
.admin-nav { display: flex; gap: .5rem; flex-wrap: wrap; }
.admin-nav a { padding: .6rem .8rem; border-radius: 999px; background: rgba(255,255,255,.75); text-decoration: none; color: var(--text); }
.admin-main { max-width: 1180px; margin: 0 auto; padding: 1rem 1rem 3rem; }
.admin-hero { background: linear-gradient(135deg, rgba(179,38,30,.12), rgba(245,158,11,.13)); border-radius: 1.6rem; padding: 1.6rem; margin-bottom: 1rem; }
.admin-hero h1 { margin: .2rem 0; }
.admin-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(190px, 1fr)); gap: 1rem; margin: 1rem 0; }
.admin-card { background: var(--surface); border: 1px solid rgba(0,0,0,.08); border-radius: 1.3rem; padding: 1.2rem; box-shadow: var(--shadow); }
a.admin-card { text-decoration: none; color: var(--text); }
a.admin-card strong { display: block; font-size: 2.2rem; color: var(--accent); }
.admin-layout { display: grid; grid-template-columns: minmax(300px, 440px) 1fr; gap: 1rem; align-items: start; }
.admin-form { display: grid; gap: .85rem; }
.admin-form label { display: grid; gap: .35rem; font-weight: 700; }
.admin-form label small { font-weight: 400; color: var(--muted); }
.admin-form input, .admin-form textarea, .admin-form select, .contact-form input, .contact-form textarea { width: 100%; border: 1px solid rgba(0,0,0,.16); border-radius: .9rem; padding: .8rem .9rem; font: inherit; background: #fff; }
.admin-form .check { display: flex; grid-template-columns: auto 1fr; align-items: center; gap: .55rem; }
.admin-form .check input { width: auto; }
.form-grid.two { display: grid; grid-template-columns: 1fr 1fr; gap: .8rem; }
.table-card { overflow-x: auto; }
table { width: 100%; border-collapse: collapse; font-size: .93rem; }
th, td { padding: .75rem; text-align: left; border-bottom: 1px solid rgba(0,0,0,.08); vertical-align: top; }
th { color: var(--muted); font-size: .8rem; text-transform: uppercase; letter-spacing: .05em; }
.login-card { max-width: 480px; margin: 3rem auto; }
.contact-layout { display: grid; grid-template-columns: minmax(280px, 1fr) 320px; gap: 1rem; align-items: start; }
.contact-form { background: var(--surface); border-radius: 1.4rem; padding: 1.2rem; box-shadow: var(--shadow); display: grid; gap: .9rem; }
.contact-form label { display: grid; gap: .35rem; font-weight: 700; }
@media (max-width: 850px) { .admin-layout, .contact-layout { grid-template-columns: 1fr; } .form-grid.two { grid-template-columns: 1fr; } .admin-top { align-items: flex-start; flex-direction: column; } }

/* --- v2 CMS-fixar: bilder, kalenderkort, formulär och adminlayout --- */
:root { --surface: var(--paper); --text: var(--ink); }

.image-hero {
    position: relative;
    overflow: hidden;
    border-bottom: 1px solid var(--line);
}
.image-hero::before {
    content: "";
    position: absolute;
    inset: 0;
    background-image: linear-gradient(90deg, rgba(255,248,240,.94), rgba(255,248,240,.75)), var(--hero-image);
    background-size: cover;
    background-position: center;
    z-index: -1;
}

.image-card { overflow: hidden; }
.image-card > img,
.feature-card > img,
.listing-card > img {
    width: 100%;
    aspect-ratio: 16 / 9;
    object-fit: cover;
    border-radius: 18px;
    margin-bottom: .85rem;
    background: var(--paper-2);
}

.event-card { align-items: start; }
.event-card.wide,
.event-with-image {
    grid-template-columns: 92px minmax(0, 180px) minmax(0, 1fr);
    align-items: start;
}
.event-card:not(.event-with-image):not(.wide) {
    grid-template-columns: 82px minmax(0, 1fr);
}
.event-card.wide:not(.event-with-image) {
    grid-template-columns: 92px minmax(0, 1fr);
}
.date-badge,
.event-card time.date-badge {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    width: 82px;
    min-width: 82px;
    min-height: 82px;
    padding: .55rem;
    border-radius: 20px;
    background: var(--brand);
    color: #fff;
    text-align: center;
    line-height: 1.05;
    overflow: hidden;
}
.date-badge strong { font-size: 1.65rem; line-height: 1; display: block; }
.date-badge span { font-size: .82rem; text-transform: uppercase; letter-spacing: .08em; display: block; }
.date-badge small { font-size: .72rem; opacity: .88; margin-top: .12rem; }
.event-image,
.event-thumb {
    width: 100%;
    aspect-ratio: 16 / 10;
    object-fit: cover;
    border-radius: 18px;
    background: var(--paper-2);
}
.event-thumb { margin: 0 0 .65rem; }
.event-body { min-width: 0; }
.event-body h3 { overflow-wrap: anywhere; }
.event-card p { overflow-wrap: anywhere; }

.admin-layout,
.form-grid,
.admin-card,
.table-card,
.admin-form,
.image-picker,
.permission-box { min-width: 0; }
.admin-layout { grid-template-columns: minmax(0, 460px) minmax(0, 1fr); }
.admin-form input,
.admin-form textarea,
.admin-form select,
.contact-form input,
.contact-form textarea {
    max-width: 100%;
    min-width: 0;
}
.admin-form textarea { resize: vertical; }
.admin-form .check { display: flex; align-items: center; gap: .55rem; }
.admin-form .check input { flex: 0 0 auto; }
.image-picker {
    display: grid;
    gap: .75rem;
    padding: .85rem;
    background: rgba(179,38,30,.05);
    border: 1px dashed rgba(179,38,30,.25);
    border-radius: 1rem;
}
.image-preview img,
.admin-thumb {
    width: 96px;
    height: 64px;
    object-fit: cover;
    border-radius: .8rem;
    background: var(--paper-2);
}
.permission-box {
    border: 1px solid var(--line);
    border-radius: 1rem;
    padding: .85rem;
    display: grid;
    gap: .4rem;
}
.permission-box legend { font-weight: 850; padding: 0 .35rem; }
.media-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(150px, 1fr));
    gap: .85rem;
}
.media-tile {
    margin: 0;
    border: 1px solid var(--line);
    border-radius: 1rem;
    padding: .6rem;
    background: white;
    overflow: hidden;
}
.media-tile img {
    width: 100%;
    aspect-ratio: 4 / 3;
    object-fit: cover;
    border-radius: .75rem;
}
.media-tile figcaption {
    margin-top: .5rem;
    font-size: .8rem;
    overflow-wrap: anywhere;
}

@media (max-width: 980px) {
    .event-card.wide,
    .event-with-image { grid-template-columns: 82px minmax(0, 1fr); }
    .event-card.wide .event-image,
    .event-with-image .event-image { grid-column: 2; }
    .event-card.wide .event-body,
    .event-with-image .event-body { grid-column: 2; }
}
@media (max-width: 720px) {
    .event-card.wide,
    .event-with-image,
    .event-card:not(.event-with-image):not(.wide) { grid-template-columns: 1fr; }
    .date-badge,
    .event-card time.date-badge { width: 100%; min-width: 0; min-height: auto; flex-direction: row; gap: .4rem; justify-content: flex-start; }
    .event-card.wide .event-image,
    .event-with-image .event-image,
    .event-card.wide .event-body,
    .event-with-image .event-body { grid-column: auto; }
}

.install-log {
    margin: 1rem 0 0;
    padding: 1rem 1.25rem 1rem 2.25rem;
    background: rgba(255,255,255,.7);
    border: 1px solid rgba(80,50,30,.12);
    border-radius: 18px;
}
.install-log li {
    margin: .25rem 0;
}


.upload-client-status {
    display: block;
    margin-top: .45rem;
    font-size: .88rem;
    line-height: 1.35;
    color: var(--muted, #64748b);
}
.upload-client-status[data-type="ok"] {
    color: #166534;
}
.upload-client-status[data-type="warn"] {
    color: #92400e;
}

/* --- v9: hela kalenderbilder + klickbar större bild + enkel bildradering --- */
.event-image-link,
.event-thumb-link {
    display: block;
    width: 100%;
    border-radius: 18px;
    background: #fff;
    border: 1px solid var(--line);
    overflow: hidden;
    text-decoration: none;
}
.event-image-link:hover,
.event-thumb-link:hover {
    box-shadow: 0 10px 30px rgba(50, 30, 20, .13);
    transform: translateY(-1px);
}
.event-image-link:focus-visible,
.event-thumb-link:focus-visible,
.media-tile a:focus-visible {
    outline: 3px solid rgba(179, 38, 30, .28);
    outline-offset: 3px;
}
.event-image,
.event-thumb {
    object-fit: contain;
    background: #fff;
}
.event-image-link .event-image,
.event-thumb-link .event-thumb {
    display: block;
    border: 0;
    border-radius: 0;
}
.event-thumb-link { margin: 0 0 .65rem; }
.event-thumb-link .event-thumb { margin: 0; }

.image-lightbox {
    position: fixed;
    inset: 0;
    display: none;
    align-items: center;
    justify-content: center;
    padding: 1.25rem;
    z-index: 9999;
}
.image-lightbox.open { display: flex; }
.image-lightbox-backdrop {
    position: absolute;
    inset: 0;
    background: rgba(20, 12, 9, .82);
    backdrop-filter: blur(3px);
}
.image-lightbox-panel {
    position: relative;
    width: min(1180px, 96vw);
    max-height: 92vh;
    display: grid;
    gap: .75rem;
    justify-items: center;
    padding: 1rem;
    border-radius: 24px;
    background: rgba(255,255,255,.96);
    box-shadow: 0 30px 90px rgba(0,0,0,.35);
}
.image-lightbox-panel img {
    max-width: 100%;
    max-height: 78vh;
    object-fit: contain;
    border-radius: 18px;
    background: #fff;
}
.image-lightbox-close {
    position: absolute;
    top: .55rem;
    right: .55rem;
    width: 42px;
    height: 42px;
    border: 0;
    border-radius: 999px;
    background: var(--brand);
    color: #fff;
    font-size: 1.8rem;
    line-height: 1;
    cursor: pointer;
}
.image-lightbox-caption {
    margin: 0;
    color: var(--muted);
    font-weight: 750;
    overflow-wrap: anywhere;
}
body.lightbox-open { overflow: hidden; }

.media-library-card { grid-column: 1 / -1; }
.media-tile a {
    display: block;
    border-radius: .75rem;
    background: #fff;
    border: 1px solid var(--line);
    overflow: hidden;
}
.media-tile img {
    object-fit: contain;
    background: #fff;
}
.media-tile figcaption {
    display: grid;
    gap: .45rem;
}
.media-tile figcaption small {
    color: var(--muted);
}
.media-delete-form { margin: .15rem 0 0; }
.button-danger {
    min-height: 38px;
    padding: .55rem .8rem;
    border-color: #991b1b;
    background: #991b1b;
    box-shadow: none;
    font-size: .86rem;
}
.button-danger:hover {
    background: #7f1d1d;
    border-color: #7f1d1d;
}

@media (min-width: 981px) {
    .event-card.wide .event-image-link,
    .event-with-image .event-image-link { grid-column: 2; }
}
@media (max-width: 980px) {
    .event-card.wide .event-image-link,
    .event-with-image .event-image-link { grid-column: 2; }
}
@media (max-width: 720px) {
    .event-card.wide .event-image-link,
    .event-with-image .event-image-link { grid-column: auto; }
    .image-lightbox { padding: .5rem; }
    .image-lightbox-panel { width: 98vw; padding: .65rem; }
    .image-lightbox-panel img { max-height: 80vh; }
}

/* --- v10: proportionella kalenderbilder ---
   Bilder ska inte pressas in i en fast 16:10-ruta.
   Stående bilder får bli höga, liggande bilder får breda ut sig på bredden. */
.event-card.wide,
.event-with-image {
    grid-template-columns: 92px minmax(240px, 420px) minmax(0, 1fr);
}
.event-image-link,
.event-thumb-link {
    overflow: visible;
    background: #fff;
}
.event-image,
.event-thumb,
.event-image-link .event-image,
.event-thumb-link .event-thumb {
    display: block;
    width: 100%;
    max-width: 100%;
    height: auto;
    max-height: none;
    aspect-ratio: auto;
    object-fit: contain;
    border-radius: 18px;
    background: #fff;
}
.event-image-link .event-image,
.event-thumb-link .event-thumb {
    border-radius: 18px;
}
.event-thumb-link {
    margin: 0 0 .65rem;
}

/* På startsidan ligger bilden inne i textdelen. Där får den använda hela kortets bredd. */
.event-list.mini .event-thumb-link,
.event-list.mini .event-thumb {
    width: 100%;
}

@media (max-width: 980px) {
    .event-card.wide,
    .event-with-image {
        grid-template-columns: 82px minmax(0, 1fr);
    }
}
@media (max-width: 720px) {
    .event-card.wide,
    .event-with-image {
        grid-template-columns: 1fr;
    }
}

/* --- v12: kalender med sök, månadsbläddring och visa fler --- */
.calendar-section { display: grid; gap: 1.15rem; }
.calendar-heading { align-items: flex-start; }
.section-intro { margin: .35rem 0 0; max-width: 68ch; color: var(--muted); }
.calendar-search {
    display: grid;
    gap: .55rem;
    padding: 1rem;
    border: 1px solid var(--line);
    border-radius: 22px;
    background: rgba(255,255,255,.72);
}
.calendar-search label { font-weight: 850; }
.calendar-search-row {
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto auto;
    gap: .65rem;
    align-items: center;
}
.calendar-search-row input[type="search"] {
    width: 100%;
    min-width: 0;
    min-height: 46px;
    padding: .75rem .9rem;
    border: 1px solid var(--line);
    border-radius: 999px;
    background: #fff;
    color: var(--ink);
    font: inherit;
}
.calendar-toolbar {
    display: flex;
    flex-wrap: wrap;
    gap: .65rem;
    align-items: center;
}
.calendar-count {
    margin: 0;
    color: var(--muted);
    font-weight: 750;
}
.load-more-row {
    display: flex;
    justify-content: center;
    padding-top: .5rem;
}

@media (max-width: 760px) {
    .calendar-search-row { grid-template-columns: 1fr; }
    .calendar-search-row .button,
    .calendar-toolbar .button,
    .load-more-row .button { width: 100%; justify-content: center; }
}

/* --- v13: ladda fler kalenderinlägg utan sidomladdning --- */
.load-more-row {
    display: grid;
    justify-items: center;
    gap: .45rem;
}
.load-more-status {
    min-height: 1.25rem;
    margin: 0;
    color: var(--muted);
    font-weight: 700;
    text-align: center;
}
#calendarLoadMore[disabled] {
    opacity: .72;
    cursor: progress;
}

/* --- v14: återkommande kalenderinlägg och periodinlägg --- */
.tag-soft {
    background: rgba(71, 122, 75, .12);
    color: var(--green);
    margin-left: .3rem;
}
.calendar-note,
.field-help {
    color: var(--muted);
    font-size: .92rem;
    margin: .25rem 0 .55rem;
}
.small-notice {
    box-shadow: none;
    margin: 0;
    padding: .85rem 1rem;
}
.small-notice p { margin: .25rem 0 0; }
.recurrence-box {
    background: rgba(255,255,255,.56);
}
.weekday-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(125px, 1fr));
    gap: .35rem .65rem;
    margin: .35rem 0 .65rem;
}
.weekday-grid .check {
    background: rgba(255,255,255,.74);
    border: 1px solid var(--line);
    border-radius: .8rem;
    padding: .55rem .65rem;
}

/* --- v15: smartare administration av kalenderinlägg --- */
.events-admin-layout {
    grid-template-columns: minmax(0, 430px) minmax(0, 1fr);
}
.admin-event-panel {
    display: grid;
    gap: 1rem;
}
.admin-event-panel-head {
    display: flex;
    gap: 1rem;
    justify-content: space-between;
    align-items: flex-start;
}
.admin-event-panel-head h2 { margin-bottom: .25rem; }
.admin-event-panel-head p { margin: 0; color: var(--muted); }
.secondary-button {
    background: rgba(0,0,0,.06);
    color: var(--text);
}
.admin-event-search {
    display: grid;
    grid-template-columns: minmax(0, 1.2fr) minmax(180px, .55fr) auto;
    gap: .75rem;
    align-items: end;
    padding: .85rem;
    border: 1px solid var(--line);
    border-radius: 1.1rem;
    background: rgba(255,255,255,.66);
}
.admin-event-search label {
    display: grid;
    gap: .35rem;
    font-weight: 850;
}
.admin-event-search input,
.admin-event-search select {
    width: 100%;
    min-width: 0;
    border: 1px solid rgba(0,0,0,.16);
    border-radius: .9rem;
    padding: .75rem .85rem;
    font: inherit;
    background: #fff;
}
.admin-event-search-actions {
    display: flex;
    gap: .5rem;
    flex-wrap: wrap;
}
.admin-event-stats {
    display: flex;
    justify-content: space-between;
    gap: .75rem;
    flex-wrap: wrap;
    color: var(--muted);
    font-weight: 800;
    padding: 0 .15rem;
}
.admin-event-list {
    display: grid;
    gap: .8rem;
}
.admin-event-card {
    display: grid;
    grid-template-columns: 78px minmax(0, 96px) minmax(0, 1fr) auto;
    gap: .85rem;
    align-items: stretch;
    padding: .9rem;
    border: 1px solid var(--line);
    border-radius: 1.15rem;
    background: rgba(255,255,255,.84);
    box-shadow: 0 10px 30px rgba(20, 20, 20, .05);
}
.admin-event-card.active {
    border-color: rgba(71, 122, 75, .42);
    background: rgba(71, 122, 75, .06);
}
.admin-event-card.is-hidden {
    opacity: .82;
}
.admin-event-date {
    display: grid;
    align-content: center;
    justify-items: center;
    text-align: center;
    min-height: 82px;
    border-radius: 1rem;
    background: var(--accent);
    color: #fff;
    padding: .5rem;
}
.admin-event-date strong {
    display: block;
    font-size: 1.65rem;
    line-height: 1;
}
.admin-event-date span {
    display: block;
    font-size: .8rem;
    text-transform: uppercase;
    letter-spacing: .08em;
}
.admin-event-date small {
    opacity: .86;
}
.admin-event-image {
    display: flex;
    align-items: center;
    justify-content: center;
    min-width: 0;
    border-radius: 1rem;
    overflow: hidden;
    background: rgba(0,0,0,.05);
}
.admin-event-image img {
    width: 100%;
    height: auto;
    max-height: 96px;
    object-fit: contain;
    display: block;
}
.admin-event-content {
    min-width: 0;
}
.admin-event-tags {
    display: flex;
    gap: .35rem;
    flex-wrap: wrap;
    align-items: center;
}
.admin-event-content h3 {
    margin: .35rem 0 .2rem;
    overflow-wrap: anywhere;
}
.admin-event-next,
.admin-event-rule,
.admin-event-excerpt {
    margin: .2rem 0;
    color: var(--muted);
    overflow-wrap: anywhere;
}
.admin-event-next { color: var(--text); }
.admin-event-rule { font-size: .92rem; }
.admin-event-excerpt { font-size: .93rem; }
.admin-event-actions {
    display: grid;
    align-content: center;
    gap: .45rem;
    min-width: 96px;
}
.small-button {
    min-height: auto;
    padding: .55rem .75rem;
    border-radius: .8rem;
    font-size: .92rem;
    justify-content: center;
}
.danger-button {
    background: #7f1d1d;
    color: #fff;
    border: 0;
    cursor: pointer;
}
.tag-status { background: rgba(0,0,0,.06); color: var(--text); }
.tag-active { background: rgba(71, 122, 75, .16); color: var(--green); }
.tag-upcoming { background: rgba(179,38,30,.10); color: var(--accent); }
.tag-past { background: rgba(0,0,0,.08); color: var(--muted); }
.tag-warning { background: rgba(245,158,11,.18); color: #7c4a03; }
.empty-admin-events {
    padding: 1rem;
    border: 1px dashed var(--line);
    border-radius: 1rem;
    background: rgba(255,255,255,.6);
}

@media (max-width: 1020px) {
    .events-admin-layout { grid-template-columns: 1fr; }
}
@media (max-width: 820px) {
    .admin-event-search { grid-template-columns: 1fr; }
    .admin-event-panel-head { display: grid; }
    .admin-event-card { grid-template-columns: 78px minmax(0, 1fr); }
    .admin-event-image { grid-column: 2; justify-content: flex-start; }
    .admin-event-image img { max-width: 170px; }
    .admin-event-content { grid-column: 1 / -1; }
    .admin-event-actions { grid-column: 1 / -1; display: flex; flex-wrap: wrap; }
}
@media (max-width: 520px) {
    .admin-event-card { grid-template-columns: 1fr; }
    .admin-event-date { justify-items: start; text-align: left; min-height: auto; }
    .admin-event-image,
    .admin-event-content,
    .admin-event-actions { grid-column: auto; }
    .admin-event-actions .button,
    .admin-event-actions form { width: 100%; }
    .admin-event-actions form button { width: 100%; }
}


/* v16: tightare knappar i kalenderadmin */
.admin-event-actions {
    min-width: 72px;
    justify-items: end;
}
.admin-event-actions .button,
.admin-event-actions form,
.admin-event-actions form button {
    width: auto;
    max-width: max-content;
}
.admin-event-actions .small-button {
    padding: .32rem .55rem;
    border-radius: .55rem;
    font-size: .82rem;
    line-height: 1.1;
    min-height: 0;
}
.admin-event-organizer {
    margin: .2rem 0;
    color: var(--muted);
    font-size: .92rem;
}
.event-contact-grid label { min-width: 0; }
.event-more {
    margin-top: .7rem;
    border-top: 1px solid var(--line);
    padding-top: .55rem;
}
.event-more summary {
    cursor: pointer;
    font-weight: 800;
    color: var(--accent);
}
.event-description {
    margin-top: .7rem;
    white-space: normal;
}
.event-meta-list {
    display: grid;
    grid-template-columns: minmax(90px, max-content) minmax(0, 1fr);
    gap: .35rem .75rem;
    margin: .75rem 0 0;
    padding: .75rem;
    border-radius: .9rem;
    background: rgba(255,255,255,.72);
    border: 1px solid var(--line);
}
.event-meta-list dt {
    font-weight: 800;
    color: var(--muted);
}
.event-meta-list dd {
    margin: 0;
    min-width: 0;
    overflow-wrap: anywhere;
}
.event-meta-list a {
    font-weight: 800;
}
@media (max-width: 520px) {
    .admin-event-actions,
    .admin-event-actions form {
        width: auto;
        display: flex;
        flex-wrap: wrap;
        gap: .45rem;
        justify-content: flex-start;
    }
    .admin-event-actions .button,
    .admin-event-actions form button {
        width: auto;
        max-width: max-content;
    }
    .event-meta-list {
        grid-template-columns: 1fr;
    }
}


/* v17: eventkontakt och kompaktare adminåtgärder */
.admin-event-actions {
    min-width: 64px;
}
.admin-event-actions .small-button {
    white-space: nowrap;
}
.event-contact-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
}
@media (max-width: 720px) {
    .event-contact-grid {
        grid-template-columns: 1fr;
    }
}


/* v19: admin-eventkort utan bild får full bredd för texten.
   Kort med bild visar fortfarande bilden i egen kolumn. */
.admin-event-card.admin-event-with-image {
    grid-template-columns: 78px minmax(88px, 112px) minmax(0, 1fr) auto;
}
.admin-event-card.admin-event-no-image {
    grid-template-columns: 78px minmax(0, 1fr) auto;
}
.admin-event-card.admin-event-no-image .admin-event-content {
    grid-column: auto;
    width: 100%;
}
.admin-event-card.admin-event-no-image .admin-event-actions {
    grid-column: auto;
}
.admin-event-card.admin-event-with-image .admin-event-image {
    width: 100%;
    min-height: 82px;
}
.admin-event-card.admin-event-with-image .admin-event-image img {
    width: 100%;
    height: auto;
    max-height: 110px;
    object-fit: contain;
}
@media (max-width: 820px) {
    .admin-event-card.admin-event-with-image {
        grid-template-columns: 78px minmax(0, 1fr);
    }
    .admin-event-card.admin-event-no-image {
        grid-template-columns: 78px minmax(0, 1fr);
    }
    .admin-event-card.admin-event-with-image .admin-event-image {
        grid-column: 2;
        justify-content: flex-start;
        max-width: 180px;
    }
    .admin-event-card.admin-event-with-image .admin-event-content,
    .admin-event-card.admin-event-no-image .admin-event-content {
        grid-column: 1 / -1;
    }
    .admin-event-card.admin-event-with-image .admin-event-actions,
    .admin-event-card.admin-event-no-image .admin-event-actions {
        grid-column: 1 / -1;
    }
}
@media (max-width: 520px) {
    .admin-event-card.admin-event-with-image,
    .admin-event-card.admin-event-no-image {
        grid-template-columns: 1fr;
    }
    .admin-event-card.admin-event-with-image .admin-event-image,
    .admin-event-card.admin-event-with-image .admin-event-content,
    .admin-event-card.admin-event-with-image .admin-event-actions,
    .admin-event-card.admin-event-no-image .admin-event-content,
    .admin-event-card.admin-event-no-image .admin-event-actions {
        grid-column: auto;
    }
}

/* --- v22: startsidans kalenderdel på rad --- */
.home-current {
    display: grid;
    gap: 1.15rem;
}
.home-current-heading {
    align-items: center;
    margin-bottom: 0;
}
.home-current-heading p:not(.eyebrow) {
    max-width: 720px;
    margin: 0;
    color: var(--muted);
}
.home-event-grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 1rem;
    align-items: stretch;
}
.home-event-grid .home-event-card {
    grid-template-columns: 1fr;
    align-content: start;
    height: 100%;
}
.home-event-grid .date-badge {
    width: 100%;
    min-width: 0;
    min-height: auto;
    flex-direction: row;
    justify-content: flex-start;
    gap: .45rem;
    padding: .7rem .85rem;
}
.home-event-grid .date-badge strong {
    font-size: 1.35rem;
}
.home-event-grid .event-thumb-link {
    display: block;
    margin: 0 0 .75rem;
}
.home-event-grid .event-thumb {
    display: block;
    width: 100%;
    height: auto;
    aspect-ratio: auto;
    object-fit: contain;
}
.home-event-grid .empty-note {
    grid-column: 1 / -1;
}
@media (max-width: 980px) {
    .home-event-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
}
@media (max-width: 720px) {
    .home-current-heading {
        align-items: flex-start;
    }
    .home-event-grid {
        grid-template-columns: 1fr;
    }
}

/* --- v23: bildväljare med sök, sidindelning och radering --- */
.media-picker-label {
    display: grid;
    gap: .2rem;
}
.media-picker-label span {
    color: var(--muted);
    font-weight: 500;
}
.media-picker-current {
    display: grid;
    grid-template-columns: 86px minmax(0, 1fr);
    gap: .75rem;
    align-items: center;
    padding: .65rem;
    border: 1px solid var(--line);
    border-radius: .9rem;
    background: rgba(255,255,255,.72);
}
.media-picker-current img,
.media-picker-empty {
    width: 86px;
    height: 64px;
    border-radius: .75rem;
    background: #fff;
    border: 1px solid var(--line);
}
.media-picker-current img {
    object-fit: contain;
}
.media-picker-empty {
    display: grid;
    place-items: center;
    color: var(--muted);
    font-size: .82rem;
    text-align: center;
    padding: .35rem;
}
.media-picker-current small {
    display: block;
    color: var(--muted);
    font-weight: 700;
}
.media-picker-current strong {
    display: block;
    overflow-wrap: anywhere;
}
.media-picker-actions {
    display: flex;
    gap: .55rem;
    flex-wrap: wrap;
}
.media-picker-actions .button {
    width: auto;
}
.media-picker-modal[hidden] { display: none; }
.media-picker-modal {
    position: fixed;
    inset: 0;
    z-index: 1000;
    display: grid;
    place-items: center;
    padding: 1rem;
}
.media-picker-backdrop {
    position: absolute;
    inset: 0;
    background: rgba(18, 16, 14, .56);
}
.media-picker-dialog {
    position: relative;
    width: min(1120px, 96vw);
    max-height: 92vh;
    overflow: auto;
    background: var(--surface);
    border-radius: 1.4rem;
    border: 1px solid rgba(255,255,255,.55);
    box-shadow: 0 30px 90px rgba(0,0,0,.28);
    padding: 1rem;
    display: grid;
    gap: 1rem;
}
.media-picker-dialog-head {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    gap: 1rem;
}
.media-picker-dialog-head h2 {
    margin: .15rem 0;
}
.media-picker-dialog-head p:not(.eyebrow) {
    margin: 0;
    color: var(--muted);
}
.media-picker-search {
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto auto;
    gap: .65rem;
    align-items: end;
    padding: .85rem;
    border: 1px solid var(--line);
    border-radius: 1rem;
    background: rgba(255,255,255,.7);
}
.media-picker-search label {
    display: grid;
    gap: .35rem;
    font-weight: 850;
}
.media-picker-search input {
    width: 100%;
    min-width: 0;
    border: 1px solid rgba(0,0,0,.16);
    border-radius: .9rem;
    padding: .75rem .85rem;
    font: inherit;
    background: #fff;
}
.media-picker-counts {
    display: flex;
    justify-content: space-between;
    gap: .75rem;
    flex-wrap: wrap;
    color: var(--muted);
    font-weight: 800;
}
.media-picker-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(180px, 1fr));
    gap: .8rem;
}
.media-picker-tile {
    display: grid;
    gap: .55rem;
    padding: .65rem;
    border: 1px solid var(--line);
    border-radius: 1rem;
    background: #fff;
    min-width: 0;
}
.media-picker-image-button {
    display: block;
    width: 100%;
    padding: 0;
    border: 1px solid var(--line);
    border-radius: .85rem;
    background: #fff;
    cursor: pointer;
    overflow: hidden;
}
.media-picker-image-button img {
    display: block;
    width: 100%;
    aspect-ratio: 4 / 3;
    object-fit: contain;
    background: #fff;
}
.media-picker-tile-text {
    display: grid;
    gap: .2rem;
    min-width: 0;
}
.media-picker-tile-text strong {
    font-size: .9rem;
    overflow-wrap: anywhere;
}
.media-picker-tile-text small {
    color: var(--muted);
    font-size: .78rem;
    overflow-wrap: anywhere;
}
.media-picker-tile-actions {
    display: flex;
    gap: .45rem;
    flex-wrap: wrap;
}
.media-picker-empty-result {
    grid-column: 1 / -1;
    padding: 1rem;
    border: 1px dashed var(--line);
    border-radius: 1rem;
    background: rgba(255,255,255,.7);
}
body.media-picker-open { overflow: hidden; }

@media (max-width: 720px) {
    .media-picker-dialog-head,
    .media-picker-search {
        grid-template-columns: 1fr;
        display: grid;
    }
    .media-picker-search .button,
    .media-picker-dialog-head .button {
        width: 100%;
        justify-content: center;
    }
    .media-picker-current {
        grid-template-columns: 1fr;
    }
    .media-picker-current img,
    .media-picker-empty {
        width: 100%;
        height: auto;
        min-height: 74px;
    }
}


/* --- v25: tydligare datumfält i eventformuläret --- */
.events-admin-layout {
    grid-template-columns: minmax(0, 500px) minmax(0, 1fr);
}
.event-date-range {
    display: grid;
    grid-template-columns: 1fr;
    gap: .75rem;
}
.event-date-range label {
    min-width: 0;
}
.event-date-range input[type="datetime-local"] {
    width: 100%;
    min-width: 0;
}
@media (max-width: 1020px) {
    .events-admin-layout {
        grid-template-columns: 1fr;
    }
}

/* Egna sidor och menyadmin */
.admin-card-heading {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
    margin-bottom: 1rem;
}

.admin-card-heading h2 {
    margin: 0;
}

.admin-form-actions {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: .75rem;
    margin-top: .75rem;
}

.nowrap {
    white-space: nowrap;
}

.small-action {
    display: inline-flex;
    align-items: center;
    min-height: 2rem;
    padding: .35rem .65rem;
    border-radius: 999px;
    background: rgba(179, 38, 30, .08);
    color: #7b1b16;
    font-weight: 700;
    text-decoration: none;
    margin-right: .35rem;
}

.inline-delete {
    display: inline;
    margin: 0;
}

.link-button {
    appearance: none;
    border: 0;
    background: none;
    padding: 0;
    font: inherit;
    color: inherit;
    cursor: pointer;
}

.danger-link {
    display: inline-flex;
    align-items: center;
    min-height: 2rem;
    padding: .35rem .65rem;
    border-radius: 999px;
    background: rgba(150, 30, 30, .08);
    color: #8a1f1a;
    font-weight: 700;
}

.menu-admin-layout .admin-form select,
.menu-admin-layout .admin-form input {
    min-width: 0;
}

.page-content-card img {
    max-width: 100%;
    height: auto;
    border-radius: 16px;
}

.page-content-card a {
    font-weight: 700;
}

@media (max-width: 760px) {
    .admin-card-heading {
        align-items: flex-start;
        flex-direction: column;
    }

    .nowrap {
        white-space: normal;
    }
}
