:root{
    --bg:#f4fbf7;
    --bg2:#edf7f2;
    --surface:#ffffff;
    --surface-2:#f8fcfa;
    --surface-3:#eef7f2;
    --text:#17352c;
    --muted:#638277;
    --line:#ddebe4;
    --green:#24b47e;
    --green-2:#e6fbf2;
    --blue:#ebf5ff;
    --gold:#fff7df;
    --danger:#d74242;
    --danger-bg:#fff0f0;
    --warn:#b98200;
    --warn-bg:#fff6d7;
    --shadow:0 20px 48px rgba(20,52,40,.08);
    --radius:24px;
}
*{box-sizing:border-box}
html,body{margin:0;min-height:100%;font-family:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Arial,sans-serif;background:linear-gradient(180deg,var(--bg) 0,var(--bg2) 100%);color:var(--text)}
a{color:inherit;text-decoration:none}
button,input,select,textarea{font:inherit}
pre{white-space:pre-wrap;word-break:break-word;margin:8px 0 0}
.shell{min-height:100vh;display:grid;grid-template-columns:280px 1fr}
.side{position:sticky;top:0;height:100vh;padding:22px;background:rgba(255,255,255,.88);backdrop-filter:blur(14px);border-right:1px solid var(--line);display:flex;flex-direction:column;gap:24px}
.brand{display:flex;align-items:center;gap:14px;padding:10px 8px}
.brand-mark{width:48px;height:48px;border-radius:17px;display:grid;place-items:center;background:linear-gradient(135deg,#28c68a,#baf5dc);color:#0d372b;font-weight:900;box-shadow:0 10px 28px rgba(36,180,126,.18)}
.brand strong{display:block;font-size:17px;letter-spacing:-.02em}.brand small{display:block;color:var(--muted);margin-top:3px}
.nav{display:grid;gap:8px}
.nav a,.logout{padding:13px 15px;border-radius:18px;color:#37584d;border:1px solid transparent;transition:.18s ease;display:flex;align-items:center;justify-content:space-between;gap:12px;font-weight:700}
.nav a:hover,.logout:hover{background:#f1f8f4}
.nav a.active{background:linear-gradient(135deg,#e6fbf2,#f6fffb);border-color:#cdeee0;color:#133c30;box-shadow:0 10px 22px rgba(36,180,126,.08)}
.nav-badge,.tab-badge{min-width:24px;height:24px;padding:0 7px;border-radius:999px;display:inline-flex;align-items:center;justify-content:center;font-size:12px;font-weight:900;background:#ecf7f2;color:#176247}
.nav-badge,.tab-badge.red{background:#ffe9e9;color:#b01e1e}
.logout{margin-top:auto;color:#9c3030;background:#fff7f7}
.main{padding:34px;max-width:1320px;width:100%;margin:0 auto}
.topbar{display:flex;align-items:flex-start;justify-content:space-between;gap:18px;margin-bottom:26px}.topbar.compact{align-items:center}
.eyebrow{margin:0 0 8px;color:var(--green);font-weight:800;letter-spacing:.12em;text-transform:uppercase;font-size:12px}.title{margin:0;font-size:34px;line-height:1.05;letter-spacing:-.05em}.sub{margin:9px 0 0;color:var(--muted);line-height:1.5}.subtle-line{margin:6px 0 0;color:var(--muted);font-size:14px;line-height:1.45}
.grid{display:grid;gap:18px}.grid-2{grid-template-columns:repeat(2,minmax(0,1fr))}.grid-3{grid-template-columns:repeat(3,minmax(0,1fr))}.grid-4{grid-template-columns:repeat(4,minmax(0,1fr))}
.card{background:var(--surface);color:var(--text);border-radius:var(--radius);padding:22px;box-shadow:var(--shadow);border:1px solid rgba(221,235,228,.9)}
.dark-card,.soft-panel{background:linear-gradient(180deg,#f8fcfa,#f3faf6);color:var(--text);border:1px solid var(--line);border-radius:22px;padding:18px}
.metric{display:flex;align-items:flex-end;justify-content:space-between;gap:12px}.metric strong{font-size:38px;letter-spacing:-.05em}.metric span{color:#5b756d;font-weight:800}.metric-card{position:relative;overflow:hidden}.metric-card:before{content:"";position:absolute;inset:auto -30px -30px auto;width:120px;height:120px;border-radius:50%;background:rgba(36,180,126,.06)}.accent-green{background:linear-gradient(180deg,#f5fffb,#ebfbf4)}.accent-blue{background:linear-gradient(180deg,#f9fcff,#eef6ff)}.accent-gold{background:linear-gradient(180deg,#fffdf6,#fff7e8)}
.actions{display:flex;flex-wrap:wrap;gap:10px;align-items:center}
.btn{border:0;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:12px 16px;border-radius:16px;background:#eef7f2;color:#113027;font-weight:800;min-height:44px;transition:.18s ease}
.btn.primary{background:linear-gradient(135deg,#2dc48a,#c8f6e1);color:#0b3428}.btn.dark{background:#11362d;color:#fff}.btn.soft-green{background:#e8faf2;color:#11684b}.btn.danger{background:#ffeaea;color:#a12222}.btn.small{padding:8px 11px;border-radius:13px;min-height:34px;font-size:13px}.btn:hover{filter:brightness(.99);transform:translateY(-1px)}
.table-wrap{overflow:auto;border-radius:22px;border:1px solid rgba(16,33,29,.08)}table{width:100%;border-collapse:collapse;background:#fff;color:var(--text)}th,td{text-align:left;padding:14px 15px;border-bottom:1px solid #edf3f0;vertical-align:top}th{font-size:12px;text-transform:uppercase;letter-spacing:.08em;color:#6b837b;background:#f4faf7}tr:last-child td{border-bottom:0}
.pill{display:inline-flex;align-items:center;gap:6px;padding:7px 10px;border-radius:999px;background:#eaf7f1;color:#176247;font-size:12px;font-weight:800}.pill.warn{background:var(--warn-bg);color:var(--warn)}.pill.red{background:var(--danger-bg);color:#952828}.pill.success{background:#eaf7f1;color:#176247}
.form{display:grid;gap:15px}.field{display:grid;gap:7px}.field label{font-size:13px;font-weight:850;color:#315149}.field input,.field select,.field textarea{width:100%;border:1px solid #dfe9e5;background:#fff;color:var(--text);border-radius:16px;padding:13px 14px;outline:none}.field textarea{min-height:120px;resize:vertical}.field input:focus,.field select:focus,.field textarea:focus{border-color:#69d3a8;box-shadow:0 0 0 4px rgba(105,211,168,.14)}
.notice{padding:14px 16px;border-radius:18px;background:#eaf7f1;color:#155a41;border:1px solid #ccecdf}.error{padding:14px 16px;border-radius:18px;background:#fff0f0;color:#9a2020;border:1px solid #ffd5d5}.empty{padding:34px;text-align:center;color:#6d817b;background:#f6fbf8;border:1px dashed #cbdcd5;border-radius:22px}
.login-page{min-height:100vh;display:grid;place-items:center;padding:22px}.login-card{width:min(440px,100%);background:rgba(255,255,255,.97);color:var(--text);border-radius:34px;padding:30px;box-shadow:var(--shadow)}.login-logo{width:62px;height:62px;border-radius:22px;display:grid;place-items:center;background:linear-gradient(135deg,#2dc48a,#dffbea);font-weight:950;margin-bottom:20px}
.split{display:grid;grid-template-columns:1fr 1fr;gap:16px}.field-row{display:grid;grid-template-columns:1.3fr .9fr 1.2fr auto;gap:10px;align-items:end;background:#f5fbf8;border:1px solid #e5f0ec;border-radius:20px;padding:12px;margin-bottom:10px}.field-row .field{gap:5px}
.muted{color:#71857e}.mini{font-size:12px;color:#72867f}.copy-link{font-size:13px;color:#145c43;background:#e9f8f1;border-radius:14px;padding:10px 12px;word-break:break-all}
.stat-public{min-height:100vh;padding:24px;display:grid;place-items:center}.public-card{width:min(760px,100%);background:#fff;color:var(--text);border-radius:32px;padding:28px;box-shadow:var(--shadow)}
.check-list{display:grid;gap:9px;max-height:360px;overflow:auto;border:1px solid #e6f0ec;border-radius:18px;padding:10px;background:#fff}.check-item{display:flex;gap:10px;align-items:center;padding:10px;border-radius:14px}.check-item:hover{background:#f4faf7}.check-item-head{position:sticky;top:0;background:#f8fcfa;z-index:2}
.badge-dot{width:10px;height:10px;border-radius:50%;background:var(--green);display:inline-block}.danger-zone{border:1px solid #ffd3d3;background:#fff7f7}.print-hint{display:none}
.role-badge{display:inline-flex;align-items:center;gap:7px;padding:8px 11px;border-radius:999px;background:#eef8f3;color:#156449;font-size:12px;font-weight:900;border:1px solid #cdeee0}
.tabs{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:16px}.tabs a{padding:11px 14px;border-radius:15px;background:#eef7f2;color:#18372e;font-weight:850;display:inline-flex;align-items:center;gap:8px}.tabs a.active{background:linear-gradient(135deg,#2dc48a,#dffbea);color:#0d3428}.pro-tabs{margin-bottom:18px}
.secret-note{font-size:12px;color:#6f857d;margin-top:8px}.admin-strip{display:flex;align-items:center;justify-content:space-between;gap:12px;border-radius:22px;padding:14px 16px;margin-bottom:18px}.admin-strip.light{background:linear-gradient(135deg,#effaf4,#fbfffd);border:1px solid #d6efe3;color:#205342}
.mail-shell{padding:18px}.mail-toolbar{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:16px}
.mail-layout{display:grid;grid-template-columns:minmax(320px,420px) minmax(0,1fr);gap:16px;min-height:520px}
.mail-list-pane{border:1px solid var(--line);border-radius:22px;background:#fbfefc;overflow:auto;padding:10px}
.mail-preview-pane{border:1px solid var(--line);border-radius:22px;background:#fbfefc;padding:10px;min-height:420px}
.mail-row{display:block;background:#fff;border:1px solid #e4efea;border-radius:18px;padding:14px;margin-bottom:10px;transition:.18s ease}
.mail-row:hover{border-color:#c9e8da;box-shadow:0 10px 24px rgba(36,180,126,.08)}
.mail-row.unread{border-color:#f2b3b3;background:linear-gradient(180deg,#fff,#fff8f8)}
.mail-row.selected{border-color:#80d9b6;box-shadow:0 0 0 3px rgba(36,180,126,.12)}
.mail-row-top{display:flex;justify-content:space-between;gap:12px;align-items:flex-start;margin-bottom:6px}.mail-from{font-weight:800;color:#28493f}.mail-date{font-size:12px;color:#7b9088}
.mail-subject{font-weight:900;color:#10211d}.mail-snippet{margin:8px 0 0;color:#445d55;line-height:1.45;font-size:14px}
.mail-preview-card{background:#fff;border:1px solid #e5efea;border-radius:18px;padding:16px;min-height:100%}
.mail-preview-head{display:flex;justify-content:space-between;gap:16px;align-items:flex-start;padding-bottom:14px;border-bottom:1px solid #edf3f0;margin-bottom:14px}.mail-preview-head h3{margin:0 0 10px;font-size:22px;letter-spacing:-.03em}
.preview-meta{font-size:13px;color:#5f7a70;margin-top:4px}
.mail-body{line-height:1.62;color:#18332b;background:#fbfffd;border-radius:16px;padding:16px;overflow:auto}
.mail-body p:first-child{margin-top:0}.mail-body p:last-child{margin-bottom:0}
.mail-compose-head{display:flex;justify-content:space-between;align-items:flex-start;gap:14px}.signature-preview pre{background:#fff;border:1px solid #e6efe9;border-radius:16px;padding:14px}.recipients-list{max-height:320px}.recipient-item{align-items:flex-start}
@media (max-width:1050px){.grid-4{grid-template-columns:repeat(2,minmax(0,1fr))}.mail-layout{grid-template-columns:1fr}}
@media (max-width:900px){.shell{grid-template-columns:1fr}.side{position:relative;height:auto}.main{padding:20px}.grid-2,.grid-3,.split{grid-template-columns:1fr}.topbar{display:grid}.field-row{grid-template-columns:1fr}.nav{grid-template-columns:repeat(2,minmax(0,1fr))}.logout{margin-top:0}.side{gap:14px}.title{font-size:29px}.mail-toolbar,.mail-preview-head,.mail-compose-head{display:grid}}
@media (max-width:620px){.grid-4{grid-template-columns:1fr}.nav{grid-template-columns:1fr}}
@media print{.side,.actions,.btn{display:none!important}.shell{display:block}.main{padding:0}.card{box-shadow:none;border:0}.print-hint{display:block}.table-wrap{overflow:visible}}

/* TR-adgang redesign */
.admin-tabs-wrap{padding:18px;background:linear-gradient(180deg,#ffffff,#fbfefc)}
.admin-tab-nav{display:flex;gap:10px;flex-wrap:wrap;margin-bottom:18px;padding:6px;background:#f1f8f4;border:1px solid var(--line);border-radius:18px}
.admin-tab-btn{appearance:none;border:0;background:transparent;color:#4d6b60;font-weight:900;padding:13px 18px;border-radius:14px;cursor:pointer;transition:.18s ease}
.admin-tab-btn.active{background:#fff;color:#16392f;box-shadow:0 8px 22px rgba(22,57,47,.08)}
.admin-tab-panel{display:none}.admin-tab-panel.active{display:block}
.admin-panel-head{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;margin-bottom:18px}
.admin-panel-head h2{margin:0;font-size:28px;letter-spacing:-.04em}.admin-panel-head p{margin:7px 0 0;color:var(--muted)}
.admin-form-stack{display:grid;gap:16px}
.admin-form-section{background:#ffffff;border:1px solid var(--line);border-radius:22px;padding:20px;box-shadow:0 10px 24px rgba(20,52,40,.04)}
.admin-form-section.accent{background:linear-gradient(180deg,#f8fcfa,#f4faf7)}
.admin-form-section-head{margin-bottom:14px}.admin-form-section-head h3{margin:0 0 6px;font-size:20px;letter-spacing:-.03em}.admin-form-section-head p{margin:0;color:var(--muted);font-size:14px}
.admin-form-footer{display:flex;align-items:center;justify-content:space-between;gap:14px;flex-wrap:wrap}
.admin-switch{background:#f6fbf8;border:1px solid var(--line);padding:12px 14px;border-radius:16px}
.tr-card-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:18px}
.tr-access-card{background:linear-gradient(180deg,#fff,#fcfffd);border:1px solid var(--line);border-radius:24px;padding:18px;box-shadow:0 16px 32px rgba(20,52,40,.06)}
.tr-access-top{display:flex;align-items:flex-start;justify-content:space-between;gap:14px;margin-bottom:16px}
.tr-access-top h3{margin:0 0 5px;font-size:24px;letter-spacing:-.04em}.tr-access-email{color:var(--muted);font-size:15px}
.tr-access-statuses{display:flex;gap:8px;flex-wrap:wrap;justify-content:flex-end}
.tr-access-meta-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:12px;margin-bottom:14px}
.tr-meta-box{background:#f7fbf8;border:1px solid #e5f0eb;border-radius:18px;padding:14px;min-height:98px;display:flex;flex-direction:column;gap:6px}
.tr-meta-box strong{font-size:15px;line-height:1.35}.tr-meta-box small{color:var(--muted);line-height:1.4}
.tr-meta-label{display:block;font-size:12px;font-weight:900;letter-spacing:.08em;text-transform:uppercase;color:#6e857b}
.tr-link-box{display:flex;align-items:center;justify-content:space-between;gap:14px;background:#eef8f3;border:1px solid #dcefe5;border-radius:18px;padding:14px;margin-bottom:14px}
.tr-link-box small{display:block;color:var(--muted);margin-top:4px}
.tr-actions-row{display:flex;gap:10px;flex-wrap:wrap;padding-top:4px}
@media (max-width:1100px){.tr-card-grid{grid-template-columns:1fr}.tr-access-meta-grid{grid-template-columns:1fr}}
@media (max-width:900px){.admin-panel-head,.tr-access-top,.tr-link-box,.admin-form-footer{display:grid}}


/* TR-adgang v7 - helt nyt design */
.tg-access-page{display:grid;gap:18px}
.tg-access-hero{
    display:flex;align-items:flex-start;justify-content:space-between;gap:20px;
    background:linear-gradient(135deg,#ffffff 0%,#f4fffa 55%,#effaf5 100%);
    border:1px solid #dceee6;border-radius:30px;padding:28px;box-shadow:0 24px 60px rgba(22,57,47,.07);
    position:relative;overflow:hidden;
}
.tg-access-hero:after{content:"";position:absolute;right:-80px;top:-80px;width:240px;height:240px;border-radius:50%;background:rgba(45,196,138,.12)}
.tg-access-hero h1{margin:0;font-size:42px;line-height:1;letter-spacing:-.06em;color:#14362c}
.tg-access-hero p{margin:10px 0 0;color:#5f7b70;max-width:720px;font-size:16px;line-height:1.55}
.tg-kicker{margin:0 0 10px;color:#23ad79;font-size:12px;font-weight:950;text-transform:uppercase;letter-spacing:.16em}
.tg-hero-badge{position:relative;z-index:1;border:1px solid #ccebdd;background:#fff;border-radius:999px;padding:10px 14px;font-weight:900;color:#185c45;white-space:nowrap}
.tg-message{margin:0}
.tg-access-stats{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:14px}
.tg-stat-card{background:#fff;border:1px solid #e0eee8;border-radius:22px;padding:17px 18px;box-shadow:0 12px 28px rgba(22,57,47,.05)}
.tg-stat-card span{display:block;color:#6b857b;font-size:12px;text-transform:uppercase;letter-spacing:.09em;font-weight:900}
.tg-stat-card strong{display:block;margin-top:7px;color:#14362c;font-size:34px;letter-spacing:-.05em}
.tg-access-board{background:#fff;border:1px solid #dceee6;border-radius:30px;padding:18px;box-shadow:0 24px 60px rgba(22,57,47,.08)}
.tg-faneblad{display:grid;grid-template-columns:1fr 1fr;gap:10px;padding:8px;background:#f2faf6;border:1px solid #e0eee8;border-radius:22px;margin-bottom:18px}
.tg-faneblad button{border:0;background:transparent;border-radius:17px;padding:16px 18px;text-align:left;font-weight:950;color:#527165;cursor:pointer;transition:.18s ease;font-size:16px}
.tg-faneblad button span{display:inline-flex;align-items:center;justify-content:center;width:28px;height:28px;border-radius:10px;background:#e1f4eb;color:#227a5d;margin-right:9px;font-size:12px}
.tg-faneblad button.active{background:#fff;color:#14362c;box-shadow:0 12px 30px rgba(22,57,47,.08)}
.tg-faneblad button.active span{background:#26ba83;color:#fff}
.tg-panel{display:none}.tg-panel.active{display:block}
.tg-section-head{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;margin:4px 4px 18px}
.tg-section-head h2{margin:0;color:#14362c;font-size:28px;letter-spacing:-.05em}
.tg-section-head p{margin:7px 0 0;color:#6a837a}
.tg-tr-list{display:grid;gap:14px}
.tg-tr-row{
    display:grid;grid-template-columns:minmax(210px,1fr) minmax(210px,1.1fr);gap:16px;
    background:linear-gradient(180deg,#ffffff,#fbfffd);border:1px solid #e2efe9;border-radius:24px;padding:18px;
}
.tg-tr-identity{display:flex;align-items:center;gap:14px;min-width:0}
.tg-avatar{width:56px;height:56px;border-radius:20px;display:grid;place-items:center;background:linear-gradient(135deg,#2bc68b,#d6f8e9);color:#0f3d30;font-weight:950;box-shadow:0 14px 28px rgba(45,196,138,.18);flex:0 0 auto}
.tg-tr-identity h3{margin:0 0 4px;color:#14362c;font-size:22px;letter-spacing:-.04em}
.tg-tr-identity a{color:#5f7b70;font-size:14px;word-break:break-word}
.tg-tr-statusline{display:flex;align-items:flex-start;justify-content:flex-end;gap:8px;flex-wrap:wrap}
.tg-chip{display:inline-flex;align-items:center;justify-content:center;border-radius:999px;padding:8px 10px;font-size:12px;font-weight:950;white-space:nowrap}
.tg-chip.ok{background:#e7f8f0;color:#176347}.tg-chip.wait{background:#fff3ce;color:#8a5e00}.tg-chip.closed{background:#ffe8e8;color:#a12626}
.tg-tr-details{grid-column:1/-1;display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:10px}
.tg-tr-details div{background:#f7fbf9;border:1px solid #e5f0eb;border-radius:18px;padding:13px;min-width:0}
.tg-tr-details span{display:block;color:#71887f;font-size:11px;font-weight:950;text-transform:uppercase;letter-spacing:.09em;margin-bottom:6px}
.tg-tr-details strong{display:block;color:#183a30;font-size:14px;line-height:1.35;overflow-wrap:anywhere}
.tg-tr-details small{display:block;color:#6b847b;margin-top:3px;line-height:1.35;overflow-wrap:anywhere}
.tg-tr-actions{grid-column:1/-1;display:flex;align-items:center;justify-content:flex-end;gap:9px;flex-wrap:wrap;border-top:1px solid #edf4f0;padding-top:14px}
.tg-tr-actions form{display:inline-flex;margin:0}
.tg-form-flow{display:grid;gap:14px}
.tg-form-card{display:grid;grid-template-columns:54px 1fr;gap:16px;background:#fff;border:1px solid #e2efe9;border-radius:24px;padding:20px}
.tg-form-card.highlight{background:linear-gradient(180deg,#fbfffd,#f3fbf7)}
.tg-form-number{width:44px;height:44px;border-radius:16px;display:grid;place-items:center;background:#e7f8f0;color:#176347;font-weight:950}
.tg-form-content h3{margin:0;color:#14362c;font-size:22px;letter-spacing:-.04em}
.tg-form-content p{margin:6px 0 15px;color:#6a837a}
.tg-form-submit{display:flex;align-items:center;justify-content:space-between;gap:14px;flex-wrap:wrap;background:#f7fbf9;border:1px solid #e2efe9;border-radius:24px;padding:16px 18px}
.tg-switch{display:inline-flex;align-items:center;gap:10px;font-weight:900;color:#183a30}
.tg-switch input{width:18px;height:18px}
@media (max-width:1100px){
    .tg-access-stats{grid-template-columns:repeat(2,minmax(0,1fr))}
    .tg-tr-row{grid-template-columns:1fr}
    .tg-tr-statusline{justify-content:flex-start}
    .tg-tr-details{grid-template-columns:1fr}
}
@media (max-width:760px){
    .tg-access-hero,.tg-section-head{display:grid}
    .tg-access-hero h1{font-size:34px}
    .tg-faneblad{grid-template-columns:1fr}
    .tg-access-stats{grid-template-columns:1fr}
    .tg-form-card{grid-template-columns:1fr}
    .tg-tr-actions{justify-content:flex-start}
}


/* TR-adgang v8 – premium underfaner og adgangskort */
.tg8-page{
    display:grid;
    gap:18px;
    color:#102f27;
}
.tg8-hero{
    position:relative;
    overflow:hidden;
    display:flex;
    align-items:stretch;
    justify-content:space-between;
    gap:20px;
    padding:30px;
    min-height:190px;
    border-radius:34px;
    border:1px solid rgba(185,221,204,.9);
    background:
        radial-gradient(circle at 18% 18%,rgba(67,212,152,.26),transparent 28%),
        linear-gradient(135deg,#ffffff 0%,#f2fff9 52%,#e8f8f1 100%);
    box-shadow:0 28px 80px rgba(21,72,54,.10);
}
.tg8-hero-glow{
    position:absolute;
    width:320px;
    height:320px;
    right:-120px;
    top:-120px;
    border-radius:999px;
    background:linear-gradient(135deg,rgba(44,195,136,.22),rgba(255,255,255,0));
}
.tg8-hero-content{position:relative;z-index:1;max-width:760px}
.tg8-kicker{
    display:inline-flex;
    padding:8px 12px;
    border-radius:999px;
    background:rgba(255,255,255,.78);
    border:1px solid rgba(192,230,212,.9);
    color:#17855f;
    text-transform:uppercase;
    font-weight:950;
    font-size:12px;
    letter-spacing:.13em;
}
.tg8-hero h1{
    margin:18px 0 0;
    font-size:52px;
    letter-spacing:-.075em;
    line-height:.92;
    color:#102f27;
}
.tg8-hero p{
    margin:14px 0 0;
    color:#597a6e;
    font-size:17px;
    line-height:1.55;
}
.tg8-hero-card{
    position:relative;
    z-index:1;
    min-width:170px;
    border-radius:28px;
    padding:22px;
    background:rgba(255,255,255,.74);
    backdrop-filter:blur(18px);
    border:1px solid rgba(255,255,255,.8);
    display:grid;
    place-content:center;
    text-align:center;
    box-shadow:0 20px 55px rgba(25,92,68,.12);
}
.tg8-hero-number{
    font-size:54px;
    line-height:.9;
    font-weight:1000;
    letter-spacing:-.08em;
    color:#127452;
}
.tg8-hero-card span{
    margin-top:10px;
    color:#55766b;
    font-size:13px;
    font-weight:950;
    text-transform:uppercase;
    letter-spacing:.1em;
}
.tg8-alert{margin:0}
.tg8-dashboard{
    display:grid;
    grid-template-columns:repeat(3,minmax(0,1fr));
    gap:14px;
}
.tg8-stat{
    position:relative;
    overflow:hidden;
    min-height:118px;
    padding:20px;
    border-radius:28px;
    background:#fff;
    border:1px solid #dcefe6;
    box-shadow:0 16px 40px rgba(17,65,49,.06);
}
.tg8-stat:after{
    content:"";
    position:absolute;
    right:-32px;
    bottom:-42px;
    width:130px;
    height:130px;
    border-radius:50%;
    background:#e8fbf3;
}
.tg8-stat small{
    position:relative;
    z-index:1;
    display:block;
    color:#6d867d;
    font-weight:950;
    text-transform:uppercase;
    letter-spacing:.1em;
    font-size:12px;
}
.tg8-stat strong{
    position:relative;
    z-index:1;
    display:block;
    margin-top:10px;
    color:#102f27;
    font-size:44px;
    line-height:1;
    letter-spacing:-.07em;
}
.tg8-shell{
    padding:18px;
    border-radius:36px;
    background:
        linear-gradient(#ffffff,#ffffff) padding-box,
        linear-gradient(135deg,rgba(45,196,138,.55),rgba(255,255,255,.2),rgba(17,83,63,.18)) border-box;
    border:1px solid transparent;
    box-shadow:0 30px 90px rgba(17,65,49,.10);
}
.tg8-tabs{
    display:grid;
    grid-template-columns:1fr 1fr;
    gap:12px;
    padding:8px;
    border-radius:26px;
    background:#f1faf6;
    border:1px solid #dcefe6;
    margin-bottom:18px;
}
.tg8-tabs button{
    appearance:none;
    border:0;
    cursor:pointer;
    display:flex;
    align-items:center;
    gap:13px;
    text-align:left;
    padding:18px;
    border-radius:22px;
    background:transparent;
    color:#536f64;
    transition:.18s ease;
}
.tg8-tabs button.active{
    color:#102f27;
    background:#fff;
    box-shadow:0 16px 34px rgba(17,65,49,.08);
}
.tg8-tab-icon{
    width:44px;
    height:44px;
    border-radius:17px;
    display:grid;
    place-items:center;
    color:#177d5a;
    background:#e5f8ef;
    font-weight:1000;
    flex:0 0 auto;
}
.tg8-tabs button.active .tg8-tab-icon{
    color:#fff;
    background:linear-gradient(135deg,#1fae79,#66ddb0);
}
.tg8-tabs strong{
    display:block;
    font-size:17px;
    letter-spacing:-.02em;
}
.tg8-tabs small{
    display:block;
    margin-top:3px;
    font-weight:800;
    color:#789086;
}
.tg8-panel{display:none}
.tg8-panel.active{display:block}
.tg8-panel-head{
    display:flex;
    align-items:flex-start;
    justify-content:space-between;
    gap:18px;
    padding:8px 6px 20px;
}
.tg8-panel-head h2{
    margin:0;
    color:#102f27;
    font-size:32px;
    line-height:1;
    letter-spacing:-.06em;
}
.tg8-panel-head p{
    margin:8px 0 0;
    color:#668276;
}
.tg8-primary,.tg8-secondary,.tg8-action{
    appearance:none;
    border:0;
    cursor:pointer;
    display:inline-flex;
    align-items:center;
    justify-content:center;
    gap:8px;
    text-decoration:none;
    min-height:42px;
    padding:11px 15px;
    border-radius:16px;
    font-weight:950;
    transition:.18s ease;
    white-space:nowrap;
}
.tg8-primary{
    background:linear-gradient(135deg,#20b87f,#b9f4d8);
    color:#0b3528;
    box-shadow:0 14px 26px rgba(32,184,127,.17);
}
.tg8-primary.big{min-height:50px;padding:13px 20px}
.tg8-secondary,.tg8-action{
    background:#eef8f3;
    color:#164f3d;
    border:1px solid #d8eee4;
}
.tg8-action.danger{
    background:#fff0f0;
    color:#a62222;
    border-color:#ffd5d5;
}
.tg8-primary:hover,.tg8-secondary:hover,.tg8-action:hover{transform:translateY(-1px);filter:brightness(.99)}
.tg8-empty{
    padding:40px;
    border-radius:28px;
    background:#f7fcfa;
    border:1px dashed #c8dfd4;
    text-align:center;
    color:#668276;
    font-weight:850;
}
.tg8-roster{
    display:grid;
    gap:16px;
}
.tg8-person{
    position:relative;
    overflow:hidden;
    display:grid;
    grid-template-columns:minmax(230px,.85fr) minmax(220px,.75fr);
    gap:16px;
    padding:20px;
    border-radius:30px;
    background:#fff;
    border:1px solid #deeee6;
    box-shadow:0 18px 45px rgba(17,65,49,.06);
}
.tg8-person:before{
    content:"";
    position:absolute;
    left:0;
    top:0;
    bottom:0;
    width:8px;
    background:linear-gradient(180deg,#20b87f,#aeeed2);
}
.tg8-color-2:before{background:linear-gradient(180deg,#28a7d8,#bfeaff)}
.tg8-color-3:before{background:linear-gradient(180deg,#d6a329,#fff0b8)}
.tg8-color-4:before{background:linear-gradient(180deg,#8877e8,#ddd8ff)}
.tg8-color-5:before{background:linear-gradient(180deg,#e57a7a,#ffd3d3)}
.tg8-person-main{
    display:flex;
    align-items:center;
    gap:15px;
    min-width:0;
}
.tg8-avatar{
    width:62px;
    height:62px;
    border-radius:22px;
    display:grid;
    place-items:center;
    flex:0 0 auto;
    color:#0d3a2e;
    background:linear-gradient(135deg,#35d49a,#e3fff0);
    font-weight:1000;
    letter-spacing:-.04em;
    font-size:20px;
    box-shadow:0 18px 34px rgba(45,196,138,.18);
}
.tg8-person-title{min-width:0}
.tg8-person-title h3{
    margin:0 0 6px;
    color:#102f27;
    font-size:25px;
    line-height:1;
    letter-spacing:-.055em;
}
.tg8-person-title a{
    color:#668276;
    word-break:break-word;
    font-weight:750;
}
.tg8-person-badges{
    display:flex;
    align-items:flex-start;
    justify-content:flex-end;
    gap:8px;
    flex-wrap:wrap;
}
.tg8-badge{
    display:inline-flex;
    align-items:center;
    justify-content:center;
    min-height:34px;
    padding:8px 11px;
    border-radius:999px;
    font-size:12px;
    font-weight:1000;
}
.tg8-badge.green{background:#e8f8f1;color:#176347}
.tg8-badge.yellow{background:#fff4d5;color:#8b6100}
.tg8-badge.red{background:#ffe9e9;color:#a62222}
.tg8-person-info{
    grid-column:1/-1;
    display:grid;
    grid-template-columns:repeat(3,minmax(0,1fr));
    gap:12px;
}
.tg8-person-info div{
    min-width:0;
    padding:15px;
    border-radius:20px;
    background:linear-gradient(180deg,#fbfffd,#f5fbf8);
    border:1px solid #e5f1eb;
}
.tg8-person-info small{
    display:block;
    margin-bottom:7px;
    color:#789086;
    font-size:11px;
    font-weight:1000;
    text-transform:uppercase;
    letter-spacing:.11em;
}
.tg8-person-info strong{
    display:block;
    color:#173c32;
    line-height:1.32;
    overflow-wrap:anywhere;
}
.tg8-person-info span{
    display:block;
    margin-top:4px;
    color:#668276;
    font-size:13px;
    line-height:1.35;
    overflow-wrap:anywhere;
}
.tg8-actionbar{
    grid-column:1/-1;
    display:flex;
    justify-content:flex-end;
    align-items:center;
    gap:9px;
    flex-wrap:wrap;
    padding-top:4px;
}
.tg8-actionbar form{display:inline-flex;margin:0}
.tg8-form{
    display:grid;
    gap:16px;
}
.tg8-form-grid{
    display:grid;
    grid-template-columns:1fr 1fr;
    gap:16px;
}
.tg8-form-block{
    position:relative;
    overflow:hidden;
    padding:22px;
    border-radius:30px;
    background:#fff;
    border:1px solid #deeee6;
    box-shadow:0 18px 45px rgba(17,65,49,.055);
}
.tg8-form-block.imap{
    grid-column:1/-1;
    background:linear-gradient(135deg,#ffffff 0%,#f5fff9 100%);
}
.tg8-form-block:after{
    content:"";
    position:absolute;
    right:-55px;
    top:-55px;
    width:140px;
    height:140px;
    border-radius:50%;
    background:rgba(45,196,138,.08);
}
.tg8-form-icon{
    position:relative;
    z-index:1;
    width:46px;
    height:46px;
    border-radius:18px;
    display:grid;
    place-items:center;
    color:#fff;
    background:linear-gradient(135deg,#1fae79,#66ddb0);
    font-weight:1000;
    box-shadow:0 12px 26px rgba(31,174,121,.18);
    margin-bottom:14px;
}
.tg8-form-top{position:relative;z-index:1;margin-bottom:16px}
.tg8-form-top h3{
    margin:0;
    color:#102f27;
    font-size:24px;
    letter-spacing:-.05em;
}
.tg8-form-top p{
    margin:6px 0 0;
    color:#668276;
}
.tg8-form-block .field,
.tg8-form-block .split{position:relative;z-index:1}
.tg8-savebar{
    position:sticky;
    bottom:16px;
    z-index:3;
    display:flex;
    align-items:center;
    justify-content:space-between;
    gap:14px;
    padding:16px;
    border-radius:26px;
    background:rgba(255,255,255,.88);
    border:1px solid rgba(210,235,224,.95);
    backdrop-filter:blur(16px);
    box-shadow:0 18px 50px rgba(17,65,49,.10);
}
.tg8-toggle{
    display:inline-flex;
    align-items:center;
    gap:11px;
    color:#173c32;
    font-weight:950;
}
.tg8-toggle input{
    position:absolute;
    opacity:0;
    pointer-events:none;
}
.tg8-toggle span{
    width:46px;
    height:26px;
    border-radius:999px;
    background:#d9e8e1;
    position:relative;
    transition:.18s ease;
}
.tg8-toggle span:after{
    content:"";
    position:absolute;
    width:20px;
    height:20px;
    border-radius:50%;
    top:3px;
    left:3px;
    background:#fff;
    box-shadow:0 4px 10px rgba(17,65,49,.16);
    transition:.18s ease;
}
.tg8-toggle input:checked + span{
    background:#26ba83;
}
.tg8-toggle input:checked + span:after{
    left:23px;
}
@media (max-width:1100px){
    .tg8-person{grid-template-columns:1fr}
    .tg8-person-badges{justify-content:flex-start}
    .tg8-person-info{grid-template-columns:1fr}
    .tg8-form-grid{grid-template-columns:1fr}
}
@media (max-width:900px){
    .tg8-hero,.tg8-panel-head,.tg8-savebar{display:grid}
    .tg8-dashboard{grid-template-columns:1fr}
    .tg8-tabs{grid-template-columns:1fr}
    .tg8-hero h1{font-size:42px}
    .tg8-hero-card{min-width:0}
}
@media (max-width:620px){
    .tg8-person-main{align-items:flex-start}
    .tg8-actionbar{justify-content:flex-start}
    .tg8-action,.tg8-primary,.tg8-secondary{width:100%}
}


/* Global mobil-lås + TR-adgang v10 */
html, body {
    max-width: 100%;
    overflow-x: hidden;
}
body {
    overscroll-behavior-x: none;
}
.shell,
.main,
.card,
.table-wrap,
.form,
.split,
.grid,
.grid-2,
.grid-3,
.grid-4 {
    min-width: 0;
}
img, video, iframe, table {
    max-width: 100%;
}
@media (max-width: 900px) {
    .main {
        width: 100%;
        max-width: 100vw;
        overflow-x: hidden;
    }
    .shell {
        width: 100%;
        max-width: 100vw;
        overflow-x: hidden;
    }
    .side {
        width: 100%;
        max-width: 100vw;
    }
}
