:root{--bg1:#071216;--bg2:#102b36;--glass:rgba(255,255,255,.10);--line:rgba(255,255,255,.16);--text:#f5fbff;--muted:#c9e3ea;--aqua:#7af0d9;--blue:#8dbbff;--gold:#ffd36a;--danger:#ff7979}*{box-sizing:border-box}html{scroll-behavior:smooth}body{margin:0;font-family:Arial,Helvetica,sans-serif;background:linear-gradient(135deg,var(--bg1),var(--bg2) 50%,#13231f);color:var(--text);min-height:100vh;overflow-x:hidden}body:before{content:"";position:fixed;inset:0;background-image:linear-gradient(rgba(255,255,255,.035) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.035) 1px,transparent 1px);background-size:44px 44px;mask-image:linear-gradient(to bottom,rgba(0,0,0,.75),transparent);pointer-events:none}.bg-orb{position:fixed;border-radius:999px;filter:blur(35px);opacity:.34;pointer-events:none}.bg-orb.one{width:320px;height:320px;background:var(--aqua);left:-100px;top:90px}.bg-orb.two{width:360px;height:360px;background:var(--gold);right:-130px;bottom:50px}a{color:inherit}.menu-btn{position:fixed;top:16px;right:16px;z-index:50;width:56px;height:56px;border:1px solid var(--line);border-radius:20px;background:rgba(255,255,255,.12);color:white;font-size:28px;backdrop-filter:blur(18px);box-shadow:0 18px 40px rgba(0,0,0,.35);cursor:pointer}.drop-menu{display:none;position:fixed;top:82px;right:16px;z-index:49;width:min(320px,calc(100vw - 32px));padding:12px;border:1px solid var(--line);border-radius:24px;background:rgba(7,18,22,.95);backdrop-filter:blur(20px);box-shadow:0 20px 50px rgba(0,0,0,.4);max-height:75vh;overflow:auto}.drop-menu.open{display:block}.drop-menu a,.drop-menu button{display:block;width:100%;margin:5px 0;padding:14px 15px;border:0;border-radius:16px;background:rgba(255,255,255,.08);color:white;text-align:left;text-decoration:none;font-size:16px;cursor:pointer}.drop-menu a:hover,.drop-menu button:hover{background:rgba(122,240,217,.18)}main{width:min(1180px,92vw);margin:0 auto;padding:92px 0 70px;position:relative}.hero{display:grid;grid-template-columns:1.35fr .65fr;gap:24px;align-items:center;min-height:460px;padding:48px;border:1px solid var(--line);border-radius:38px;background:linear-gradient(135deg,rgba(255,255,255,.16),rgba(255,255,255,.05));box-shadow:0 26px 80px rgba(0,0,0,.32);position:relative;overflow:hidden}.hero:after{content:"";position:absolute;right:-80px;top:-80px;width:230px;height:230px;border-radius:999px;background:rgba(122,240,217,.16)}.hero.small{min-height:250px}.hero h1{font-size:clamp(40px,6vw,78px);line-height:.95;margin:0 0 18px;letter-spacing:-.05em}.hero p{font-size:19px;line-height:1.55;color:var(--muted)}.eyebrow{text-transform:uppercase;letter-spacing:.20em;color:var(--aqua);font-weight:800;font-size:13px!important}.hero-card,.panel{border:1px solid var(--line);border-radius:30px;background:var(--glass);box-shadow:0 20px 55px rgba(0,0,0,.24);backdrop-filter:blur(13px)}.hero-card{padding:30px;position:relative}.pulse-dot{width:14px;height:14px;border-radius:50%;background:var(--gold);box-shadow:0 0 0 8px rgba(255,211,106,.14);margin-bottom:18px}.panel{padding:30px;margin-top:26px}.panel h2{margin-top:0;font-size:32px;letter-spacing:-.03em}.grid.two{display:grid;grid-template-columns:1fr 1fr;gap:24px}.full{grid-column:1/-1}.section-title{display:flex;align-items:center;gap:14px;margin-bottom:18px}.section-title span{display:grid;place-items:center;min-width:42px;height:42px;border-radius:14px;background:linear-gradient(135deg,var(--aqua),var(--blue));color:#082129;font-weight:900}.section-title h2{margin:0}.admin-shortcuts{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;margin-top:24px}.admin-shortcuts a{padding:18px;border-radius:20px;text-align:center;text-decoration:none;font-weight:900;background:linear-gradient(135deg,rgba(122,240,217,.22),rgba(141,187,255,.16));border:1px solid var(--line)}.admin-shortcuts a:hover{transform:translateY(-2px);background:linear-gradient(135deg,rgba(122,240,217,.35),rgba(141,187,255,.25))}.form{display:grid;gap:10px}.form label,.text-editor label span{font-weight:800;color:#d7eef5}.form input,.form textarea,.form select,.text-editor input,.text-editor textarea{width:100%;padding:14px 15px;border:1px solid rgba(255,255,255,.18);border-radius:16px;background:rgba(255,255,255,.105);color:white;font-size:15px;outline:none}.form textarea,.text-editor textarea{min-height:105px;resize:vertical}.form input:focus,.form textarea:focus,.form select:focus,.text-editor input:focus,.text-editor textarea:focus{border-color:var(--aqua);box-shadow:0 0 0 4px rgba(122,240,217,.12)}.form option{color:#111}button,.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;border:0;border-radius:16px;padding:14px 19px;background:linear-gradient(135deg,var(--aqua),var(--blue));color:#092127;font-weight:900;text-decoration:none;cursor:pointer;box-shadow:0 12px 30px rgba(0,0,0,.18)}.btn.ghost{background:rgba(255,255,255,.12);color:#fff}.button-row{display:flex;gap:12px;flex-wrap:wrap;margin-top:22px}.danger{background:linear-gradient(135deg,#ffb199,var(--danger))!important;color:#360707!important}.error{padding:12px;border-radius:14px;background:rgba(255,99,99,.18);color:#ffd4d4}.modal{display:none;position:fixed;inset:0;z-index:80;background:rgba(0,0,0,.58);align-items:center;justify-content:center;padding:18px}.modal.open{display:flex}.modal-card{width:min(450px,94vw);padding:28px;border-radius:30px;background:#102731;border:1px solid var(--line);box-shadow:0 24px 65px rgba(0,0,0,.45);position:relative}.x{position:absolute;right:14px;top:14px;width:40px;height:40px;border-radius:50%;padding:0;background:rgba(255,255,255,.12);color:#fff}.calendar-panel{background:linear-gradient(135deg,rgba(13,43,54,.96),rgba(17,73,83,.76));position:relative}.calendar{display:grid;grid-template-columns:repeat(7,1fr);gap:10px;margin-top:20px}.day-name{text-align:center;color:var(--aqua);font-weight:900}.day{min-height:118px;border-radius:20px;padding:11px;background:rgba(255,255,255,.105);border:1px solid rgba(255,255,255,.13);overflow:hidden}.day strong{color:#fff}.day.empty{opacity:.23}.cal-event{display:flex;align-items:center;gap:7px;margin-top:7px;padding:8px;border-radius:13px;background:rgba(122,240,217,.16);font-size:12px;border:1px solid rgba(122,240,217,.14)}.cal-event img{width:24px;height:24px;object-fit:contain;border-radius:7px;background:white}.members-panel{text-align:center}.members-heading h2{margin-bottom:6px}.members-heading p{margin-top:0;color:var(--muted);font-size:18px}.member-logos{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,150px));gap:20px;justify-content:center;align-items:center;margin-top:24px}.member-logos a{display:block}.member-logos img{width:150px;height:95px;object-fit:contain;padding:13px;border-radius:22px;background:rgba(255,255,255,.94);box-shadow:0 12px 32px rgba(0,0,0,.22);transition:.18s}.member-logos img:hover{transform:translateY(-3px) scale(1.03)}.list{display:grid;gap:11px;margin-top:18px}.list-item{display:flex;align-items:center;justify-content:space-between;gap:10px;padding:13px;border-radius:18px;background:rgba(255,255,255,.075);flex-wrap:wrap;border:1px solid rgba(255,255,255,.08)}.mini-logo{width:50px;height:50px;object-fit:contain;border-radius:12px;background:white;padding:5px;margin-right:8px;vertical-align:middle}.inline{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.inline input{max-width:220px}.event-list{display:grid;gap:14px}.event-card{display:grid;grid-template-columns:66px 1fr auto;gap:14px;align-items:start;padding:17px;border-radius:22px;background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.11)}.event-logo{width:66px;height:66px;object-fit:contain;border-radius:15px;background:white;padding:7px}.tag{display:inline-block;padding:6px 11px;border-radius:999px;background:rgba(122,240,217,.18);color:#bff7ec;font-weight:900;font-size:12px}.text-group{border:1px solid rgba(255,255,255,.13);border-radius:20px;padding:14px;margin-bottom:14px;background:rgba(255,255,255,.06)}.text-group summary{cursor:pointer;font-weight:900;font-size:18px;color:var(--aqua)}.text-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:14px;margin-top:16px}.text-editor label{display:grid;gap:7px}@media(max-width:850px){main{width:94vw;padding-top:86px}.hero,.grid.two{grid-template-columns:1fr}.hero{padding:30px;min-height:auto}.admin-shortcuts{grid-template-columns:1fr 1fr}.text-grid{grid-template-columns:1fr}.calendar{gap:6px}.day{min-height:88px;padding:7px;border-radius:15px}.day-name{font-size:12px}.cal-event{font-size:10px;padding:5px}.event-card{grid-template-columns:50px 1fr}.event-card form{grid-column:1/-1}.event-logo{width:50px;height:50px}}

@media(min-width:900px){
  .member-logos{
    max-width:660px;
    margin-left:auto;
    margin-right:auto;
  }
}


.front-text-form{
    max-width:760px;
    margin:0 auto;
}
.admin-hero .admin-shortcuts a{
    min-height:92px;
    display:flex;
    align-items:center;
    justify-content:center;
    font-size:20px;
}


.org-welcome-logo{
    display:flex;
    align-items:center;
    justify-content:center;
    padding:24px;
    border-radius:28px;
    background:rgba(255,255,255,.12);
    border:1px solid var(--line);
}
.org-welcome-logo img{
    max-width:260px;
    max-height:180px;
    object-fit:contain;
    padding:18px;
    border-radius:24px;
    background:white;
}
.success-panel{
    background:rgba(122,240,217,.16);
    border-color:rgba(122,240,217,.32);
}
.feedback-list{display:grid;gap:14px}
.feedback-card{
    display:flex;
    justify-content:space-between;
    gap:16px;
    padding:18px;
    border-radius:20px;
    background:rgba(255,255,255,.08);
    border:1px solid rgba(255,255,255,.12);
}
.feedback-card p{margin:8px 0;color:var(--muted)}
.feedback-card small{color:rgba(255,255,255,.65)}
.modal-card.wide{width:min(760px,94vw)}
.simple-event-list{display:grid;gap:14px}
.simple-event-card{
    width:100%;
    display:flex;
    align-items:center;
    gap:14px;
    text-align:left;
    color:white;
    background:rgba(255,255,255,.08);
    border:1px solid rgba(255,255,255,.12);
    box-shadow:none;
}
.simple-event-card:hover{
    background:rgba(122,240,217,.16);
    transform:translateY(-1px);
}
.simple-event-card img{
    width:54px;
    height:54px;
    object-fit:contain;
    background:white;
    border-radius:14px;
    padding:7px;
}
.simple-event-card span{display:grid;gap:4px}
.simple-event-card small{color:var(--muted)}
.delete-modal-form{margin-top:14px}
.clickable-day{
    color:white;
    text-align:left;
    display:block;
    width:100%;
    box-shadow:none;
    cursor:pointer;
}
.clickable-day:hover{
    background:rgba(255,255,255,.16);
}
.cal-event{
    border-left:5px solid var(--aqua);
}
.day-modal-list{display:grid;gap:14px}
.day-modal-event{
    display:grid;
    grid-template-columns:64px 1fr;
    gap:14px;
    padding:16px;
    border-radius:20px;
    background:rgba(255,255,255,.08);
    border:1px solid rgba(255,255,255,.12);
    border-left:7px solid var(--aqua);
}
.day-modal-event img{
    width:64px;
    height:64px;
    object-fit:contain;
    background:white;
    border-radius:15px;
    padding:7px;
}
.day-modal-event p{margin:6px 0;color:var(--muted)}
.day-modal-event small{color:var(--aqua);font-weight:900}
@media(max-width:850px){
    .feedback-card{display:grid}
    .day-modal-event{grid-template-columns:48px 1fr}
    .day-modal-event img{width:48px;height:48px}
}

.profile-warning{
    margin:18px 0 0;
    padding:14px 16px;
    border-radius:18px;
    background:rgba(255,211,106,.16);
    border:1px solid rgba(255,211,106,.35);
    color:#ffe7a4;
    font-weight:900;
}
.list-item small{
    color:rgba(255,255,255,.65);
}


/* V8 */
#organisasjoner .mini-logo{
    width:88px;
    height:88px;
    border-radius:20px;
    padding:10px;
}
#organisasjoner .list-item{
    align-items:center;
    padding:18px;
}
.chat-panel{
    display:grid;
    gap:24px;
}
.chat-form{
    max-width:760px;
}
.chat-list{
    display:grid;
    gap:16px;
}
.chat-message{
    display:grid;
    grid-template-columns:60px 1fr;
    gap:14px;
    align-items:start;
}
.chat-avatar{
    width:60px;
    height:60px;
    border-radius:18px;
    background:rgba(255,255,255,.16);
    border:1px solid var(--line);
    display:grid;
    place-items:center;
    overflow:hidden;
    font-weight:900;
    font-size:24px;
}
.chat-avatar img{
    width:100%;
    height:100%;
    object-fit:contain;
    background:white;
    padding:7px;
}
.chat-bubble{
    padding:16px;
    border-radius:22px;
    background:rgba(255,255,255,.09);
    border:1px solid rgba(255,255,255,.12);
}
.chat-meta{
    display:flex;
    flex-wrap:wrap;
    gap:8px;
    align-items:baseline;
}
.chat-meta small{
    color:rgba(255,255,255,.62);
}
.chat-bubble p{
    margin:10px 0;
    color:var(--muted);
}
.mini-danger{
    padding:8px 12px;
    border-radius:12px;
    font-size:13px;
    box-shadow:none;
}
@media(max-width:700px){
    .chat-message{
        grid-template-columns:48px 1fr;
    }
    .chat-avatar{
        width:48px;
        height:48px;
        border-radius:14px;
    }
    #organisasjoner .mini-logo{
        width:72px;
        height:72px;
    }
}


/* V9 chat fix */
.chat-panel{
    max-width:900px;
    margin-left:auto;
    margin-right:auto;
}
.chat-box{
    display:grid;
    grid-template-rows: minmax(260px, 56vh) auto;
    gap:14px;
}
.chat-list{
    overflow-y:auto;
    padding:14px;
    border-radius:24px;
    background:rgba(0,0,0,.18);
    border:1px solid rgba(255,255,255,.12);
    max-height:56vh;
    scroll-behavior:smooth;
}
.chat-input-row{
    display:grid;
    grid-template-columns:1fr auto;
    gap:12px;
    align-items:end;
    padding:12px;
    border-radius:22px;
    background:rgba(255,255,255,.08);
    border:1px solid rgba(255,255,255,.12);
}
.chat-input-row textarea{
    width:100%;
    min-height:56px;
    max-height:140px;
    resize:vertical;
    padding:14px 15px;
    border:1px solid rgba(255,255,255,.18);
    border-radius:16px;
    background:rgba(255,255,255,.105);
    color:white;
    font-size:15px;
    outline:none;
}
.chat-input-row textarea:focus{
    border-color:var(--aqua);
    box-shadow:0 0 0 4px rgba(122,240,217,.12);
}
.chat-input-row button{
    height:56px;
    white-space:nowrap;
}
@media(max-width:700px){
    .chat-box{
        grid-template-rows:minmax(260px, 58vh) auto;
    }
    .chat-input-row{
        grid-template-columns:1fr;
    }
    .chat-input-row button{
        width:100%;
    }
}


/* V10 admin chat fix */
.admin-chat-box{
    grid-template-rows:minmax(260px, 62vh);
}
.admin-chat-message{
    grid-template-columns:60px 1fr;
}
.delete-chat-form{
    margin-top:10px;
}
.delete-chat-form .mini-danger{
    padding:7px 11px;
    font-size:12px;
}
.chat-list{
    min-height:320px;
}
.chat-message{
    width:100%;
}
.chat-bubble{
    max-width:100%;
    overflow-wrap:anywhere;
}


/* V11 tettere chat + admin kan skrive */
.chat-box{
    grid-template-rows:minmax(260px, 62vh) auto !important;
    gap:8px !important;
}
.admin-chat-box{
    grid-template-rows:minmax(260px, 62vh) auto !important;
}
.chat-list{
    padding:8px !important;
    max-height:62vh !important;
    min-height:320px;
}
.chat-list{
    gap:6px !important;
}
.chat-message{
    grid-template-columns:38px 1fr !important;
    gap:8px !important;
    margin:0 !important;
}
.chat-avatar{
    width:38px !important;
    height:38px !important;
    border-radius:12px !important;
    font-size:17px !important;
}
.chat-avatar img{
    padding:4px !important;
}
.chat-bubble{
    padding:9px 11px !important;
    border-radius:15px !important;
}
.chat-meta{
    gap:5px !important;
    line-height:1.15 !important;
}
.chat-meta strong{
    font-size:15px !important;
}
.chat-meta small{
    font-size:12px !important;
}
.chat-bubble p{
    margin:5px 0 !important;
    line-height:1.25 !important;
    font-size:15px !important;
}
.delete-chat-form{
    margin-top:5px !important;
}
.delete-chat-form .mini-danger{
    padding:5px 8px !important;
    font-size:11px !important;
}
.chat-input-row{
    padding:8px !important;
    gap:8px !important;
    border-radius:18px !important;
}
.chat-input-row textarea{
    min-height:44px !important;
    max-height:95px !important;
    padding:10px 12px !important;
    border-radius:14px !important;
}
.chat-input-row button{
    height:44px !important;
    padding:10px 15px !important;
}
@media(max-width:700px){
    .chat-message{
        grid-template-columns:34px 1fr !important;
        gap:7px !important;
    }
    .chat-avatar{
        width:34px !important;
        height:34px !important;
    }
}


/* V12 - fjern stort mellomrom mellom chatmeldinger */
.chat-list{
    display:block !important;
    align-content:start !important;
}

.chat-message{
    display:grid !important;
    margin:0 0 7px 0 !important;
}

.chat-message:last-child{
    margin-bottom:0 !important;
}

.chat-bubble{
    min-height:0 !important;
}

.chat-box{
    align-items:stretch !important;
}

.chat-panel .chat-list > *{
    margin-top:0 !important;
}


/* V15 - kalenderdato oppe høyre + mobil som datoliste */
.day{
    position:relative;
    padding-top:34px !important;
}

.day > strong{
    position:absolute;
    top:9px;
    right:11px;
    min-width:28px;
    height:28px;
    display:grid;
    place-items:center;
    border-radius:10px;
    background:rgba(255,255,255,.12);
    color:#fff;
    font-size:14px;
}

@media(max-width:700px){
    .calendar{
        display:grid !important;
        grid-template-columns:1fr !important;
        gap:8px !important;
    }

    .day-name{
        display:none !important;
    }

    .day.empty{
        display:none !important;
    }

    .day{
        min-height:64px !important;
        padding:13px 13px 13px 72px !important;
        border-radius:18px !important;
    }

    .day > strong{
        left:13px !important;
        right:auto !important;
        top:50% !important;
        transform:translateY(-50%);
        width:42px;
        height:42px;
        border-radius:14px;
        background:linear-gradient(135deg,var(--aqua),var(--blue));
        color:#082129;
        font-size:17px;
        font-weight:900;
    }

    .cal-event{
        margin-top:4px !important;
        font-size:13px !important;
        padding:8px !important;
    }

    .cal-event:first-of-type{
        margin-top:0 !important;
    }
}


/* V16 - måned/år + blaing + mindre mobilkalender */
.calendar-top{
    display:flex;
    align-items:center;
    justify-content:center;
    gap:16px;
    margin:18px 0 18px;
}

.calendar-top h3{
    margin:0;
    min-width:220px;
    text-align:center;
    font-size:28px;
    letter-spacing:-.03em;
}

.calendar-nav-btn{
    width:46px;
    height:46px;
    padding:0;
    border-radius:16px;
    font-size:32px;
    line-height:1;
}

@media(max-width:700px){
    .calendar-top{
        gap:10px;
        margin:12px 0;
    }

    .calendar-top h3{
        min-width:150px;
        font-size:21px;
    }

    .calendar-nav-btn{
        width:38px;
        height:38px;
        border-radius:13px;
        font-size:26px;
    }

    .day{
        min-height:46px !important;
        padding:8px 8px 8px 52px !important;
        border-radius:14px !important;
    }

    .day > strong{
        left:8px !important;
        width:32px !important;
        height:32px !important;
        border-radius:11px !important;
        font-size:14px !important;
    }

    .cal-event{
        margin-top:3px !important;
        font-size:11px !important;
        padding:5px 6px !important;
        border-radius:10px !important;
    }

    .cal-event img{
        width:18px !important;
        height:18px !important;
        border-radius:5px !important;
    }

    .calendar{
        gap:5px !important;
    }
}


/* === V17 REDESIGN: Orkland Distriktsforum heritage theme === */
:root{
  --bg:#eef1e5;
  --bg-soft:#f7f3e9;
  --surface:#fbf8f1;
  --surface-alt:#f3ede0;
  --line:#d7ccb5;
  --text:#203126;
  --muted:#5d6c61;
  --forest:#274432;
  --forest-deep:#1a2f22;
  --moss:#6e8d63;
  --sage:#97ab88;
  --clay:#916246;
  --gold:#d1aa69;
  --shadow:0 18px 60px rgba(39,68,50,.12);
}
html{scroll-behavior:smooth}
body{
  background:
    radial-gradient(circle at top left, rgba(209,170,105,.10), transparent 22%),
    radial-gradient(circle at bottom right, rgba(110,141,99,.10), transparent 20%),
    linear-gradient(180deg, #f4f1e8 0%, #eef1e5 100%);
  color:var(--text) !important;
}
body::before{
  content:"";
  position:fixed; inset:0;
  background-image:linear-gradient(rgba(255,255,255,.18), rgba(255,255,255,.18)), url('assets/hero-orkland.jpg');
  background-size:cover;
  background-position:center top;
  opacity:.10;
  pointer-events:none;
  z-index:-3;
}
.bg-orb{display:none !important}
main{width:min(1240px, calc(100% - 32px)) !important; margin:140px auto 72px !important;}
.floating-brand{
  position:fixed; left:22px; top:18px; z-index:50;
}
.floating-brand-inner{
  display:flex; align-items:center; gap:14px;
  padding:10px 16px 10px 10px; text-decoration:none;
  background:rgba(251,248,241,.88); backdrop-filter:blur(14px);
  border:1px solid rgba(39,68,50,.10);
  border-radius:999px; box-shadow:var(--shadow); color:var(--text);
}
.floating-brand img{width:56px;height:56px;border-radius:50%;object-fit:cover;box-shadow:0 6px 18px rgba(39,68,50,.18)}
.floating-brand strong{display:block;font-size:15px;line-height:1.1;color:var(--forest-deep)}
.floating-brand span{display:block;font-size:12px;color:var(--muted);margin-top:4px}
.menu-btn{
  top:24px !important; right:22px !important; z-index:60 !important;
  width:58px; height:58px; border-radius:18px !important;
  background:linear-gradient(145deg,var(--forest),var(--forest-deep)) !important;
  color:#fff !important; box-shadow:0 18px 40px rgba(26,47,34,.28) !important;
  border:1px solid rgba(255,255,255,.12) !important;
}
.drop-menu{
  top:92px !important; right:22px !important; left:auto !important;
  background:rgba(251,248,241,.96) !important; backdrop-filter:blur(14px);
  border:1px solid rgba(39,68,50,.10) !important;
  border-radius:26px !important; box-shadow:var(--shadow) !important; padding:14px !important;
  min-width:250px !important;
}
.drop-menu a,.drop-menu button{color:var(--forest-deep) !important; border-radius:14px !important; font-weight:700 !important}
.drop-menu a:hover,.drop-menu button:hover{background:rgba(39,68,50,.08) !important}
.hero.public-hero{
  position:relative; overflow:hidden;
  min-height:580px; padding:54px !important;
  border-radius:42px !important;
  background:linear-gradient(120deg, rgba(15,29,21,.68), rgba(15,29,21,.32)), url('assets/hero-orkland.jpg') center/cover no-repeat !important;
  color:#fff !important;
  box-shadow:0 30px 80px rgba(26,47,34,.22);
  border:1px solid rgba(255,255,255,.10);
  align-items:end !important;
}
.hero.public-hero::after{
  content:""; position:absolute; inset:0;
  background:linear-gradient(180deg, transparent 0%, rgba(15,29,21,.18) 30%, rgba(15,29,21,.52) 100%);
  pointer-events:none;
}
.hero.public-hero > *{position:relative; z-index:1}
.hero-copy{max-width:680px}
.hero-motto{
  display:inline-flex; align-items:center; gap:8px; margin-bottom:14px;
  padding:10px 16px; border-radius:999px;
  background:rgba(251,248,241,.16); border:1px solid rgba(255,255,255,.20);
  font-weight:700; letter-spacing:.02em; color:#f8efe0;
}
.hero.public-hero .eyebrow{color:#f2d6a6 !important; letter-spacing:.18em !important}
.hero.public-hero h1{font-size:clamp(2.7rem, 6vw, 5rem) !important; line-height:.95 !important; max-width:10ch; margin:0 0 16px !important; color:#fff !important; text-shadow:0 8px 25px rgba(0,0,0,.25)}
.hero-lead,.hero.public-hero p{color:rgba(255,255,255,.88) !important; max-width:58ch; font-size:1.08rem !important}
.hero.public-hero .button-row{margin-top:28px !important}
.btn, button, .calendar-nav-btn{
  background:linear-gradient(145deg, var(--gold), #e7c793) !important;
  color:var(--forest-deep) !important;
  border:none !important; box-shadow:0 14px 26px rgba(145,98,70,.16);
}
.btn.ghost, .button-row .ghost, .drop-menu form button.ghost{
  background:rgba(251,248,241,.12) !important; color:#fff !important; border:1px solid rgba(255,255,255,.22) !important;
  box-shadow:none !important;
}
.hero-mini-points{display:flex;flex-wrap:wrap;gap:10px;margin-top:26px}
.hero-mini-points span{
  padding:10px 14px; border-radius:999px; background:rgba(255,255,255,.12);
  border:1px solid rgba(255,255,255,.14); font-size:.92rem; color:#fff;
}
.hero-side-card{display:grid; gap:16px; justify-self:end; width:min(340px,100%)}
.hero-emblem-wrap{
  padding:12px; border-radius:32px; background:rgba(251,248,241,.14); border:1px solid rgba(255,255,255,.16);
  backdrop-filter: blur(8px);
}
.hero-emblem{display:block; width:100%; border-radius:28px; background:#f7f1e4; box-shadow:0 18px 45px rgba(0,0,0,.18)}
.heritage-card,.hero-card{
  background:rgba(251,248,241,.90) !important; color:var(--text) !important; border:1px solid rgba(39,68,50,.10) !important;
  border-radius:28px !important; box-shadow:0 18px 40px rgba(0,0,0,.14) !important;
}
.heritage-card h3,.hero-card h3{color:var(--forest-deep) !important}
.heritage-card p,.hero-card p{color:var(--muted) !important}
.pulse-dot{background:var(--moss) !important; box-shadow:0 0 0 8px rgba(110,141,99,.18) !important}
.overview-strip{
  display:grid; grid-template-columns:repeat(3,1fr); gap:18px; margin-top:24px;
}
.overview-strip article{
  background:rgba(251,248,241,.92); border:1px solid var(--line); border-radius:28px; padding:24px; box-shadow:var(--shadow)
}
.overview-strip small{display:inline-block; margin-bottom:8px; font-weight:800; color:var(--clay); letter-spacing:.12em}
.overview-strip h3{margin:0 0 10px; color:var(--forest-deep); font-size:1.2rem}
.overview-strip p{margin:0; color:var(--muted); line-height:1.55}
.panel, .chat-panel, .admin-section, .contact-panel, .calendar-panel, .members-panel{
  background:rgba(251,248,241,.92) !important; border:1px solid var(--line) !important; box-shadow:var(--shadow) !important; border-radius:34px !important;
  color:var(--text) !important;
}
.panel h2, .panel h1, .panel h3, .section-title h2, .hero.small h1{color:var(--forest-deep) !important}
.panel p, .panel small, .panel label, .panel span, .hero.small p, .chat-bubble p, .simple-event-card small{color:var(--muted) !important}
.section-title span{background:var(--surface-alt) !important; color:var(--clay) !important; border:1px solid var(--line)}
.hero.small, .welcome-hero{
  background:linear-gradient(135deg, rgba(251,248,241,.96), rgba(241,235,223,.96)) !important;
  border:1px solid var(--line) !important; box-shadow:var(--shadow) !important; color:var(--text) !important;
}
.hero.small .eyebrow, .welcome-hero .eyebrow{color:var(--clay) !important}
.calendar-top{background:var(--surface-alt); border:1px solid var(--line); padding:12px; border-radius:22px}
.calendar-top h3{color:var(--forest-deep) !important}
.calendar{
  gap:10px !important;
}
.day-name{
  background:transparent !important; color:var(--clay) !important; font-weight:800 !important;
}
.day{
  background:#fffdfa !important; border:1px solid var(--line) !important; box-shadow:none !important;
}
.day > strong{
  background:var(--surface-alt) !important; color:var(--forest-deep) !important; font-weight:800 !important;
}
.day.has-events{background:#fffaf1 !important}
.cal-event{
  color:var(--forest-deep) !important; font-weight:700 !important;
  border-radius:12px !important; border-left-width:5px !important;
}
.cal-event span{color:var(--forest-deep) !important}
.cal-event img{background:#fff; border-radius:8px; padding:3px}
.member-logos img{background:#fff !important; border:1px solid var(--line); box-shadow:0 12px 30px rgba(39,68,50,.08) !important}
.contact-panel{background:linear-gradient(135deg, #f8f3e7, #f2ead8) !important}
input, textarea, select{
  background:#fffdfa !important; color:var(--text) !important; border:1px solid var(--line) !important;
}
input::placeholder, textarea::placeholder{color:#899489 !important}
.list-item, .feedback-card, .chat-bubble, .chat-input-row, .simple-event-card, .day-modal-event{
  background:#fffdfa !important; border:1px solid var(--line) !important; color:var(--text) !important;
}
.chat-list{background:#f5efe2 !important; border:1px solid var(--line) !important}
.chat-meta strong, .simple-event-card strong, .day-modal-event strong{color:var(--forest-deep) !important}
.chat-avatar{background:#e8e2d4 !important; border:1px solid var(--line) !important}
.chat-input-row textarea{background:#fff !important}
.org-welcome-logo{background:#fff7eb !important; border:1px solid var(--line) !important}
.profile-warning{background:#fff5da !important; color:#7d5c1f !important; border:1px solid #ecd08d !important}
.modal{background:rgba(19,32,24,.45) !important}
.modal-card{
  background:#fbf8f1 !important; color:var(--text) !important; border:1px solid var(--line) !important; border-radius:32px !important;
}
.modal-card h2, .modal-card h3{color:var(--forest-deep) !important}
.x{background:#f0e8d7 !important; color:var(--forest-deep) !important}
@media(max-width:980px){
  .floating-brand{left:14px;top:14px}
  .floating-brand-inner{padding:8px 12px 8px 8px}
  .floating-brand img{width:46px;height:46px}
  .floating-brand strong{font-size:13px}
  .floating-brand span{font-size:11px}
  main{margin-top:118px !important}
  .hero.public-hero{padding:32px !important; min-height:auto; display:grid !important; grid-template-columns:1fr !important}
  .hero-side-card{justify-self:stretch; width:100%}
  .overview-strip{grid-template-columns:1fr}
}
@media(max-width:700px){
  main{width:min(100% - 18px, 100%) !important; margin:106px auto 36px !important}
  .floating-brand-inner{gap:10px; max-width:calc(100vw - 92px)}
  .floating-brand img{width:40px;height:40px}
  .floating-brand strong{font-size:12px}
  .floating-brand span{font-size:10px}
  .menu-btn{top:16px !important; right:14px !important; width:52px; height:52px}
  .drop-menu{top:78px !important; right:12px !important; left:12px !important; min-width:auto !important}
  .hero.public-hero{border-radius:28px !important; padding:24px !important}
  .hero.public-hero h1{font-size:2.45rem !important; max-width:100%}
  .hero-motto{font-size:.92rem; padding:8px 12px}
  .hero-mini-points span{font-size:.82rem; padding:8px 11px}
  .overview-strip article{padding:18px; border-radius:22px}
  .panel, .chat-panel, .admin-section, .contact-panel, .calendar-panel, .members-panel, .hero.small{border-radius:24px !important}
}


/* === V18 polish: better contrast, less weird scroll, livelier background === */
html, body{
  max-width:100%;
  overflow-x:hidden !important;
  overscroll-behavior-y:none;
}
body{
  min-height:100dvh;
}
body::after{
  content:"";
  position:fixed;
  inset:0;
  pointer-events:none;
  z-index:-2;
  background:
    radial-gradient(circle at 8% 16%, rgba(108,171,255,.20), transparent 16%),
    radial-gradient(circle at 88% 14%, rgba(255,171,114,.18), transparent 17%),
    radial-gradient(circle at 18% 86%, rgba(118,210,161,.18), transparent 18%),
    radial-gradient(circle at 83% 78%, rgba(215,131,255,.14), transparent 16%),
    radial-gradient(circle at 50% 50%, rgba(255,255,255,.09), transparent 26%);
  filter:blur(12px);
}
main{
  padding-bottom:42px !important;
}
main > *:last-child{
  margin-bottom:0 !important;
}
.hero.public-hero h1{
  font-size:clamp(2.5rem, 5.5vw, 4.8rem) !important;
  max-width:12ch !important;
}
.hero.public-hero .hero-card,
.hero.public-hero .heritage-card{
  background:rgba(250,247,240,.92) !important;
}
.hero.public-hero .heritage-card p,
.hero.public-hero .hero-card p{
  color:#607165 !important;
}
.form label,
.text-editor label span,
.modal-card label,
.panel .form label,
.hero.small .form label,
.welcome-hero .form label{
  color:var(--forest-deep) !important;
}
.form input,
.form textarea,
.form select,
.text-editor input,
.text-editor textarea,
.modal-card input,
.modal-card textarea,
.modal-card select{
  background:#fffdfa !important;
  color:var(--forest-deep) !important;
  border:1px solid #d8ccb7 !important;
}
.form input::placeholder,
.form textarea::placeholder,
.modal-card input::placeholder,
.modal-card textarea::placeholder,
.text-editor input::placeholder,
.text-editor textarea::placeholder{
  color:#8a958d !important;
}
.form input:focus,
.form textarea:focus,
.form select:focus,
.modal-card input:focus,
.modal-card textarea:focus,
.modal-card select:focus,
.text-editor input:focus,
.text-editor textarea:focus{
  border-color:#7d9b71 !important;
  box-shadow:0 0 0 4px rgba(110,141,99,.12) !important;
}
.modal-card,
.modal-card p,
.modal-card h2,
.modal-card h3{
  color:var(--forest-deep) !important;
}
.error{
  background:#ffe4df !important;
  color:#7d2e2e !important;
  border:1px solid #efb3aa;
}
.panel .btn.ghost,
.hero.small .btn.ghost,
.welcome-hero .btn.ghost,
.modal-card .btn.ghost,
.button-row .btn.ghost:not(.public-hero .btn.ghost){
  background:#efe6d6 !important;
  color:var(--forest-deep) !important;
  border:1px solid #d8ccb7 !important;
}
.public-hero .button-row .btn.ghost{
  background:rgba(255,255,255,.10) !important;
  color:#fff !important;
  border:1px solid rgba(255,255,255,.28) !important;
}
.panel .btn,
.hero.small .btn,
.welcome-hero .btn,
.modal-card button,
.modal-card .btn,
.admin-shortcuts a,
.calendar-nav-btn{
  color:var(--forest-deep) !important;
}
.drop-menu a,
.drop-menu button{
  color:var(--forest-deep) !important;
}
.day-modal-event p,
.day-modal-event small,
.feedback-card p,
.feedback-card small,
.simple-event-card small,
.list-item small,
.members-heading p,
.contact-panel p{
  color:var(--muted) !important;
}
@media(max-width:700px){
  .hero.public-hero h1{
    font-size:2.1rem !important;
    max-width:100% !important;
  }
  .hero.public-hero p,
  .hero-lead{
    font-size:1rem !important;
  }
  .button-row{
    gap:10px !important;
  }
  .button-row .btn,
  .button-row button{
    min-height:50px;
  }
}


/* V19 - fikser scrolling med touchpad / to fingre */
html,
body{
    overflow-x:hidden !important;
    overflow-y:auto !important;
    overscroll-behavior-y:auto !important;
    touch-action:pan-y !important;
    -webkit-overflow-scrolling:touch !important;
}

body{
    position:relative !important;
}

main{
    touch-action:auto !important;
}

.modal.open{
    touch-action:auto !important;
}

.chat-list{
    touch-action:pan-y !important;
    -webkit-overflow-scrolling:touch !important;
}


/* V20 - fjernet ekstra hero-elementer */
.hero-mini-points,
.overview-strip{
    display:none !important;
}

.public-hero .button-row .btn{
    background:linear-gradient(145deg, var(--gold), #e7c793) !important;
    color:var(--forest-deep) !important;
    border:none !important;
}


/* V21 - skjul venstre topp-logo på mobil */
@media (max-width: 700px){
  .floating-brand{
    display:none !important;
  }

  main{
    margin-top:86px !important;
  }
}


/* V22 - mobilbilde + underlogoer */
.mobile-hero-picture{
    display:none;
}

@media(max-width:700px){
    .hero.public-hero{
        background:
            linear-gradient(180deg, rgba(20,35,25,.28), rgba(20,35,25,.82)),
            url('assets/hero-orkland.jpg') center top / cover no-repeat !important;
        padding:14px !important;
    }

    .mobile-hero-picture{
        display:block;
        margin-bottom:18px;
        border-radius:22px;
        overflow:hidden;
        border:1px solid rgba(255,255,255,.22);
        box-shadow:0 18px 38px rgba(0,0,0,.20);
        background:#f7f1e4;
    }

    .mobile-hero-picture img{
        display:block;
        width:100%;
        aspect-ratio:16/9;
        object-fit:cover;
        object-position:center;
    }

    .hero-copy{
        padding:8px 4px 4px;
    }

    .hero-side-card{
        margin-top:10px;
    }

    .hero-emblem-wrap{
        display:none;
    }
}


/* V23 - viser underlogoene på forsiden */
.underlogo-panel{
    text-align:center;
}

.underlogo-panel code{
    background:rgba(39,68,50,.08);
    padding:3px 7px;
    border-radius:8px;
    color:var(--forest-deep);
}

.underlogo-grid{
    display:grid;
    grid-template-columns:repeat(2, minmax(0, 1fr));
    gap:18px;
    margin-top:24px;
}

.underlogo-card{
    padding:18px;
    border-radius:24px;
    background:#fffdfa;
    border:1px solid var(--line);
    box-shadow:0 12px 28px rgba(39,68,50,.08);
    display:grid;
    gap:10px;
    align-items:center;
}

.underlogo-card img{
    display:block;
    max-width:100%;
    max-height:220px;
    object-fit:contain;
    margin:auto;
}

.underlogo-card span{
    font-weight:800;
    color:var(--forest-deep) !important;
}

@media(max-width:700px){
    .underlogo-grid{
        grid-template-columns:1fr;
    }

    .underlogo-card{
        padding:12px;
        border-radius:18px;
    }

    .underlogo-card img{
        max-height:160px;
    }
}


/* V24 - felles logoområde + bedre mobil */
.shared-brand-panel{
  margin-top:26px;
}
.shared-brand-header{
  margin-bottom:22px;
}
.shared-brand-title{
  display:flex;
  align-items:center;
  gap:18px;
}
.shared-brand-title h2{
  margin:0 0 6px;
}
.shared-brand-title p{
  margin:0;
}
.shared-round-logo{
  width:88px;
  height:88px;
  object-fit:cover;
  border-radius:50%;
  background:#fff;
  padding:6px;
  border:1px solid var(--line);
  box-shadow:0 10px 24px rgba(39,68,50,.12);
}
.brand-showcase-grid{
  display:grid;
  grid-template-columns:repeat(5,minmax(0,1fr));
  gap:16px;
}
.brand-card{
  background:#fffdfa;
  border:1px solid var(--line);
  border-radius:24px;
  padding:16px;
  display:grid;
  gap:12px;
  align-items:center;
  text-align:center;
  box-shadow:0 10px 28px rgba(39,68,50,.08);
}
.brand-card img{
  max-width:100%;
  max-height:120px;
  margin:auto;
  object-fit:contain;
}
.brand-card strong{
  color:var(--forest-deep);
}
.brand-card.brand-main img{
  max-height:150px;
}
/* restore emblem on mobile in hero */
@media(max-width:700px){
  .hero.public-hero{
    background:
      linear-gradient(180deg, rgba(20,35,25,.20), rgba(20,35,25,.72)),
      url('assets/hero-orkland.jpg') center center / cover no-repeat !important;
    min-height:auto !important;
  }
  .mobile-hero-picture{
    margin-bottom:14px !important;
  }
  .mobile-hero-picture img{
    aspect-ratio: 16/10;
    object-position:center center;
  }
  .hero-side-card{
    gap:12px !important;
  }
  .hero-emblem-wrap{
    display:block !important;
    max-width:150px;
    margin:4px auto 0;
    padding:8px !important;
    border-radius:22px !important;
    background:rgba(250,247,240,.72) !important;
  }
  .hero-emblem{
    border-radius:20px !important;
  }
  .heritage-card, .hero-card{
    padding:20px !important;
  }
  .shared-brand-title{
    align-items:flex-start;
    gap:12px;
  }
  .shared-round-logo{
    width:64px;
    height:64px;
  }
  .brand-showcase-grid{
    grid-template-columns:repeat(2,minmax(0,1fr));
    gap:12px;
  }
  .brand-card{
    padding:12px;
    border-radius:18px;
  }
  .brand-card img{
    max-height:78px;
  }
  .brand-card.brand-main{
    grid-column:1/-1;
  }
  .brand-card.brand-main img{
    max-height:110px;
  }
}
@media(max-width:980px){
  .brand-showcase-grid{
    grid-template-columns:repeat(3,minmax(0,1fr));
  }
  .brand-card.brand-main{
    grid-column:span 3;
  }
}


/* V25 - eksklusivt logoområde integrert i siden */
.brand-ribbon{
    margin:0 0 24px;
    padding:18px;
    display:grid;
    grid-template-columns:1.1fr 1.2fr;
    gap:18px;
    align-items:center;
    border-radius:30px;
    background:
        linear-gradient(135deg, rgba(251,248,241,.96), rgba(243,237,224,.96)),
        linear-gradient(135deg, rgba(209,170,105,.10), rgba(110,141,99,.10));
    border:1px solid var(--line);
    box-shadow:0 18px 44px rgba(39,68,50,.10);
    overflow:hidden;
    position:relative;
}

.brand-ribbon::before{
    content:"";
    position:absolute;
    inset:auto -40px -50px auto;
    width:180px;
    height:180px;
    border-radius:50%;
    background:radial-gradient(circle, rgba(209,170,105,.22), transparent 70%);
    pointer-events:none;
}

.brand-ribbon-left{
    display:flex;
    align-items:center;
    gap:18px;
    min-width:0;
}

.brand-ribbon-badge{
    flex:0 0 auto;
    width:92px;
    height:92px;
    display:grid;
    place-items:center;
    border-radius:50%;
    background:#fffdfa;
    border:1px solid var(--line);
    box-shadow:0 12px 30px rgba(39,68,50,.10);
    padding:7px;
}

.brand-ribbon-badge img{
    width:100%;
    height:100%;
    object-fit:cover;
    border-radius:50%;
}

.brand-ribbon-text h2{
    margin:0 0 4px;
    color:var(--forest-deep);
    font-size:1.45rem;
}

.brand-ribbon-text p{
    margin:0;
    color:var(--muted);
}

.brand-ribbon-right{
    display:grid;
    grid-template-columns:repeat(4, minmax(0, 1fr));
    gap:12px;
    align-items:stretch;
}

.brand-ribbon-logo{
    min-height:92px;
    display:grid;
    place-items:center;
    padding:12px;
    border-radius:22px;
    background:rgba(255,253,250,.88);
    border:1px solid var(--line);
    box-shadow:0 10px 24px rgba(39,68,50,.06);
    transition:.18s;
}

.brand-ribbon-logo:hover{
    transform:translateY(-2px);
    box-shadow:0 14px 28px rgba(39,68,50,.10);
}

.brand-ribbon-logo img{
    max-width:100%;
    max-height:60px;
    object-fit:contain;
}

@media(max-width:980px){
    .brand-ribbon{
        grid-template-columns:1fr;
    }

    .brand-ribbon-right{
        grid-template-columns:repeat(4, minmax(0, 1fr));
    }
}

@media(max-width:700px){
    .brand-ribbon{
        padding:14px;
        gap:14px;
        border-radius:24px;
        margin:0 0 18px;
    }

    .brand-ribbon-left{
        gap:12px;
        align-items:center;
    }

    .brand-ribbon-badge{
        width:72px;
        height:72px;
    }

    .brand-ribbon-text h2{
        font-size:1.08rem;
    }

    .brand-ribbon-text p{
        font-size:.92rem;
    }

    .brand-ribbon-right{
        grid-template-columns:repeat(2, minmax(0, 1fr));
        gap:10px;
    }

    .brand-ribbon-logo{
        min-height:74px;
        padding:10px;
        border-radius:18px;
    }

    .brand-ribbon-logo img{
        max-height:44px;
    }
}


/* V26 - fjerner alle ekstra logoområder */
.brand-ribbon,
.shared-brand-panel,
.underlogo-panel,
.brand-showcase-grid,
.underlogo-grid{
    display:none !important;
}


/* V27 - én stor underlogo på Min side */
.minside-underlogo-panel{
    padding:28px !important;
    display:flex;
    align-items:center;
    justify-content:center;
    background:
        linear-gradient(135deg, rgba(251,248,241,.96), rgba(243,237,224,.96)) !important;
    overflow:hidden;
}

.minside-underlogo-panel img{
    display:block;
    width:min(820px, 100%);
    max-height:220px;
    object-fit:contain;
}

@media(max-width:700px){
    .minside-underlogo-panel{
        padding:18px !important;
        border-radius:24px !important;
    }

    .minside-underlogo-panel img{
        max-height:135px;
        width:100%;
    }
}


/* V28 - fjerner øverste mobilbilde */
.mobile-hero-picture{
    display:none !important;
}


/* V29 - logo øverst på Min side */
.minside-top-logo{
    margin:0 0 18px;
    padding:22px 26px;
    display:flex;
    align-items:center;
    justify-content:center;
    border-radius:28px;
    background:linear-gradient(135deg, rgba(251,248,241,.96), rgba(243,237,224,.96));
    border:1px solid var(--line);
    box-shadow:0 14px 36px rgba(39,68,50,.10);
}

.minside-top-logo img{
    display:block;
    width:min(820px, 100%);
    max-height:190px;
    object-fit:contain;
}

.minside-underlogo-panel{
    display:none !important;
}

@media(max-width:700px){
    .minside-top-logo{
        padding:14px;
        border-radius:22px;
        margin-bottom:14px;
    }

    .minside-top-logo img{
        max-height:105px;
    }
}


/* V30 - mer kompakt mobilkalender */
@media(max-width:700px){
    .calendar-panel{
        padding:18px !important;
    }

    .calendar-top{
        padding:8px !important;
        gap:8px !important;
        border-radius:16px !important;
        margin:10px 0 12px !important;
    }

    .calendar-top h3{
        font-size:18px !important;
        min-width:130px !important;
    }

    .calendar-nav-btn{
        width:34px !important;
        height:34px !important;
        border-radius:11px !important;
        font-size:22px !important;
    }

    .calendar{
        display:grid !important;
        grid-template-columns:repeat(7, minmax(0, 1fr)) !important;
        gap:4px !important;
        margin-top:10px !important;
    }

    .day-name{
        display:block !important;
        font-size:10px !important;
        padding:0 0 3px !important;
        text-align:center !important;
        color:var(--clay) !important;
    }

    .day.empty{
        display:block !important;
        min-height:42px !important;
        opacity:.22 !important;
    }

    .day{
        min-height:46px !important;
        padding:20px 4px 4px !important;
        border-radius:10px !important;
        text-align:left !important;
        overflow:hidden !important;
    }

    .day > strong{
        top:4px !important;
        right:4px !important;
        left:auto !important;
        transform:none !important;
        width:20px !important;
        height:20px !important;
        min-width:20px !important;
        border-radius:7px !important;
        font-size:11px !important;
    }

    .cal-event{
        margin-top:2px !important;
        padding:2px 3px !important;
        border-radius:7px !important;
        font-size:8px !important;
        line-height:1.1 !important;
        gap:2px !important;
        white-space:nowrap !important;
        overflow:hidden !important;
        text-overflow:ellipsis !important;
        border-left-width:3px !important;
    }

    .cal-event img{
        display:none !important;
    }

    .cal-event span{
        overflow:hidden !important;
        text-overflow:ellipsis !important;
        white-space:nowrap !important;
    }
}


/* V31 - mobilkalender med farget dato uten navn + opprettet av */
.created-by-line{
    margin:0 0 14px;
    color:var(--muted) !important;
    font-weight:800;
}

@media(max-width:700px){
    .day.has-events{
        background:linear-gradient(135deg, color-mix(in srgb, var(--event-color) 48%, #fffdfa), #fffdfa) !important;
        border-color:var(--event-color) !important;
        box-shadow:inset 0 0 0 2px color-mix(in srgb, var(--event-color) 45%, transparent) !important;
    }

    .day.has-events > strong{
        background:var(--event-color) !important;
        color:#102118 !important;
    }

    .day.has-events .cal-event{
        display:none !important;
    }

    .day.clickable-day{
        cursor:pointer !important;
    }
}

/* V33 - markering av dagens dato i kalender */
.day.today,
.clickable-day.today{
    border:2px solid var(--gold) !important;
    box-shadow:0 0 0 4px rgba(209,170,105,.22), 0 14px 34px rgba(39,68,50,.18) !important;
    background:linear-gradient(135deg,rgba(209,170,105,.25),rgba(255,255,255,.10)) !important;
}

.day.today > strong,
.clickable-day.today > strong{
    background:linear-gradient(135deg,var(--gold),#ffe2a3) !important;
    color:#1a2f22 !important;
    font-weight:900 !important;
}

.today-label{
    position:absolute;
    top:9px;
    left:11px;
    padding:5px 9px;
    border-radius:999px;
    background:rgba(209,170,105,.22);
    border:1px solid rgba(209,170,105,.45);
    color:var(--text);
    font-size:12px;
    font-weight:900;
}

@media(max-width:700px){
    .today-label{
        position:static;
        display:inline-flex;
        margin:0 0 4px 0;
        font-size:11px;
        padding:4px 8px;
    }
}


/* V34 - bedre menynavigasjon og tydeligere dagens dato */
.day.today,
.clickable-day.today{
    border:3px solid #111 !important;
    box-shadow:0 0 0 2px rgba(255,255,255,.55), 0 14px 32px rgba(0,0,0,.18) !important;
}

.day.today > strong,
.clickable-day.today > strong{
    background:#111 !important;
    color:#fff !important;
}

.today-label{
    display:none !important;
}

@media(max-width:700px){
    .day.today,
    .clickable-day.today{
        border:4px solid #111 !important;
        box-shadow:0 0 0 2px rgba(255,255,255,.7) !important;
    }
}
