/* =========================================================================
   NordicLifeRP — fælles stylesheet (skovgrøn tema)
   ========================================================================= */
:root{
  --bg:#0a0f0c; --bg-2:#0d140f; --surface:#111b15; --surface-2:#16241b;
  --border:rgba(255,255,255,.08); --border-strong:rgba(255,255,255,.14);
  --text:#e9f0ea; --muted:#9db0a5; --muted-2:#6e847a;
  --green:#1f7a45; --green-600:#1c6d3e; --green-700:#155230; --green-glow:#2fae66; --mint:#5fd39a;
  --green-soft:rgba(47,174,102,.14);
  --red:#e0564f; --red-soft:rgba(224,86,79,.12);
  --amber:#e2a53f; --amber-soft:rgba(226,165,63,.13);
  --radius:16px; --radius-sm:11px; --shadow:0 24px 60px -20px rgba(0,0,0,.7); --max:1180px;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{font-family:'Inter',system-ui,-apple-system,Segoe UI,Roboto,sans-serif;background:var(--bg);
  color:var(--text);line-height:1.65;overflow-x:hidden;-webkit-font-smoothing:antialiased;min-height:100vh}
h1,h2,h3,.display{font-family:'Space Grotesk','Inter',sans-serif;letter-spacing:-.02em;line-height:1.1}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
.wrap{width:100%;max-width:var(--max);margin:0 auto;padding:0 24px}
.section-pad{padding:96px 0}
.muted{color:var(--muted)}
.eyebrow{display:inline-flex;align-items:center;gap:8px;font-size:.78rem;font-weight:600;
  letter-spacing:.14em;text-transform:uppercase;color:var(--mint)}
.eyebrow::before{content:"";width:22px;height:1px;background:var(--green-glow);opacity:.7}

/* Aurora bg */
.aura{position:fixed;inset:0;z-index:-2;overflow:hidden;pointer-events:none}
.aura::before,.aura::after{content:"";position:absolute;border-radius:50%;filter:blur(90px);opacity:.5}
.aura::before{width:620px;height:620px;background:radial-gradient(circle,#1f7a45,transparent 65%);top:-160px;left:-120px}
.aura::after{width:560px;height:560px;background:radial-gradient(circle,#0f5e37,transparent 65%);top:340px;right:-160px;opacity:.4}
.grid-bg{position:fixed;inset:0;z-index:-1;pointer-events:none;
  background-image:linear-gradient(var(--border) 1px,transparent 1px),linear-gradient(90deg,var(--border) 1px,transparent 1px);
  background-size:64px 64px;mask-image:radial-gradient(ellipse 80% 60% at 50% 0%,#000 20%,transparent 75%);opacity:.35}

/* Buttons */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:9px;font-weight:600;font-size:.95rem;
  padding:12px 20px;border-radius:12px;cursor:pointer;border:1px solid transparent;font-family:inherit;
  transition:transform .15s,box-shadow .2s,background .2s,border-color .2s,opacity .2s;white-space:nowrap}
.btn:active{transform:translateY(1px)}
.btn:disabled{opacity:.55;cursor:not-allowed}
.btn-primary{background:linear-gradient(180deg,var(--green),var(--green-700));color:#eafff2;
  box-shadow:0 10px 26px -10px rgba(31,122,69,.9),inset 0 1px 0 rgba(255,255,255,.15)}
.btn-primary:hover:not(:disabled){box-shadow:0 14px 34px -8px rgba(47,174,102,.75);transform:translateY(-2px)}
.btn-ghost{background:rgba(255,255,255,.04);border-color:var(--border-strong);color:var(--text)}
.btn-ghost:hover:not(:disabled){background:rgba(255,255,255,.08);border-color:var(--green-glow)}
.btn-discord{background:#5865F2;color:#fff}
.btn-discord:hover:not(:disabled){background:#4a56d6;transform:translateY(-2px)}
.btn-danger{background:var(--red-soft);border-color:rgba(224,86,79,.4);color:#f0a29d}
.btn-danger:hover:not(:disabled){background:rgba(224,86,79,.22)}
.btn-approve{background:var(--green-soft);border-color:rgba(47,174,102,.4);color:var(--mint)}
.btn-approve:hover:not(:disabled){background:rgba(47,174,102,.24)}
.btn-lg{padding:15px 26px;font-size:1rem}
.btn-sm{padding:8px 13px;font-size:.85rem;border-radius:9px}
.btn-block{width:100%}

/* Nav */
header.nav{position:sticky;top:0;z-index:50;backdrop-filter:blur(14px);
  background:rgba(10,15,12,.72);border-bottom:1px solid var(--border)}
.nav-inner{display:flex;align-items:center;justify-content:space-between;height:70px;gap:16px}
.brand{display:flex;align-items:center;gap:12px;font-family:'Space Grotesk';font-weight:700;font-size:1.12rem}
.brand .mark{width:34px;height:34px;border-radius:9px;display:grid;place-items:center;
  background:linear-gradient(160deg,var(--green-glow),var(--green-700));
  box-shadow:0 6px 18px -6px rgba(47,174,102,.8);color:#04120a;font-weight:700}
.brand-logo{width:36px;height:36px;border-radius:9px;object-fit:cover;
  box-shadow:0 6px 18px -6px rgba(47,174,102,.8);border:1px solid var(--border)}
.brand b{color:var(--mint)}
.nav-links a.link.active-link{color:var(--text)}
.nav-links a.link.active-link::after{width:100%}

/* Visnings-opdeling (forside) */
.view{display:none;animation:viewIn .35s ease}
.view.active{display:block}
@keyframes viewIn{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:none}}
.nav-links{display:flex;align-items:center;gap:28px}
.nav-links a.link{font-size:.93rem;font-weight:500;color:var(--muted);transition:color .2s;position:relative}
.nav-links a.link:hover{color:var(--text)}
.nav-links a.link::after{content:"";position:absolute;left:0;bottom:-6px;width:0;height:2px;background:var(--green-glow);transition:width .25s}
.nav-links a.link:hover::after{width:100%}
.nav-cta{display:flex;align-items:center;gap:10px}
.burger{display:none;background:none;border:1px solid var(--border-strong);border-radius:10px;width:44px;height:44px;cursor:pointer;color:var(--text);font-size:1.1rem}

/* User chip */
.user-menu{position:relative}
.user-chip{display:flex;align-items:center;gap:9px;padding:7px 12px;border-radius:11px;background:var(--surface);
  border:1px solid var(--border);cursor:pointer;font-weight:600;font-size:.9rem;color:var(--text)}
.user-chip:hover{border-color:var(--green-glow)}
.avatar{width:26px;height:26px;border-radius:7px;display:grid;place-items:center;font-size:.8rem;font-weight:700;
  background:linear-gradient(160deg,var(--green-glow),var(--green-700));color:#04120a}
.dropdown{position:absolute;right:0;top:calc(100% + 8px);min-width:190px;background:var(--surface);
  border:1px solid var(--border-strong);border-radius:13px;padding:7px;box-shadow:var(--shadow);
  opacity:0;visibility:hidden;transform:translateY(-6px);transition:.18s;z-index:60}
.dropdown.open{opacity:1;visibility:visible;transform:none}
.dropdown a,.dropdown button{display:flex;align-items:center;gap:9px;width:100%;text-align:left;padding:10px 12px;
  border-radius:9px;background:none;border:none;color:var(--text);font-family:inherit;font-size:.9rem;cursor:pointer}
.dropdown a:hover,.dropdown button:hover{background:var(--green-soft);color:var(--mint)}
.dropdown .sep{height:1px;background:var(--border);margin:5px 0}

/* Cards / sections */
.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:28px}
.sec-head{max-width:640px;margin-bottom:44px}
.sec-head.center{margin-left:auto;margin-right:auto;text-align:center}
.sec-head h2{font-size:clamp(1.9rem,4vw,2.7rem);font-weight:700;margin:14px 0 12px}
.sec-head p{color:var(--muted);font-size:1.05rem}

/* Forms */
.field{margin-bottom:18px}
.field label{display:block;font-size:.88rem;font-weight:600;margin-bottom:8px}
.field label .req{color:var(--mint)}
.field input,.field textarea,.field select{width:100%;padding:12px 15px;background:var(--bg-2);
  border:1px solid var(--border-strong);border-radius:11px;color:var(--text);font-family:inherit;font-size:.95rem;
  transition:border-color .2s,box-shadow .2s;resize:vertical}
.field input:focus,.field textarea:focus,.field select:focus{outline:none;border-color:var(--green-glow);box-shadow:0 0 0 3px var(--green-soft)}
.field textarea{min-height:110px}
.field .hint{font-size:.8rem;color:var(--muted-2);margin-top:6px}
.two-col{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.form-msg{margin-top:6px;padding:12px 15px;border-radius:11px;font-size:.9rem;display:none}
.form-msg.show{display:block}
.form-msg.ok{background:var(--green-soft);border:1px solid rgba(47,174,102,.4);color:var(--mint)}
.form-msg.err{background:var(--red-soft);border:1px solid rgba(224,86,79,.4);color:#f0a29d}

/* Badges */
.badge{display:inline-flex;align-items:center;gap:6px;padding:4px 11px;border-radius:999px;font-size:.78rem;font-weight:600}
.badge.pending{background:var(--amber-soft);color:var(--amber);border:1px solid rgba(226,165,63,.35)}
.badge.approved{background:var(--green-soft);color:var(--mint);border:1px solid rgba(47,174,102,.35)}
.badge.rejected{background:var(--red-soft);color:#f0a29d;border:1px solid rgba(224,86,79,.35)}
.badge.role-admin{background:rgba(146,109,222,.15);color:#b79df0;border:1px solid rgba(146,109,222,.35)}
.badge.role-staff{background:var(--green-soft);color:var(--mint);border:1px solid rgba(47,174,102,.35)}
.badge.role-user{background:rgba(255,255,255,.06);color:var(--muted);border:1px solid var(--border)}
.badge.banned{background:var(--red-soft);color:#f0a29d;border:1px solid rgba(224,86,79,.35)}

/* Table */
.table-wrap{overflow-x:auto;border:1px solid var(--border);border-radius:var(--radius);background:var(--surface)}
table{width:100%;border-collapse:collapse;min-width:640px}
th,td{text-align:left;padding:14px 16px;font-size:.92rem;border-bottom:1px solid var(--border);vertical-align:middle}
th{font-size:.78rem;text-transform:uppercase;letter-spacing:.08em;color:var(--muted-2);font-weight:600;background:var(--bg-2)}
tr:last-child td{border-bottom:none}
td .row-actions{display:flex;gap:7px;flex-wrap:wrap}

/* Tabs */
.tabs{display:flex;gap:8px;margin-bottom:26px;flex-wrap:wrap}
.tab{padding:10px 18px;border-radius:11px;background:var(--surface);border:1px solid var(--border);
  color:var(--muted);font-weight:600;font-size:.92rem;cursor:pointer;font-family:inherit;transition:.2s}
.tab:hover{color:var(--text)}
.tab.active{background:var(--green-soft);border-color:var(--green-glow);color:var(--mint)}
.tab .count{margin-left:7px;font-size:.78rem;opacity:.8}

/* Modal */
.modal-overlay{position:fixed;inset:0;background:rgba(4,8,6,.72);backdrop-filter:blur(6px);z-index:100;
  display:flex;align-items:center;justify-content:center;padding:20px;opacity:0;visibility:hidden;transition:.2s}
.modal-overlay.open{opacity:1;visibility:visible}
.modal{background:var(--surface);border:1px solid var(--border-strong);border-radius:20px;padding:34px;
  width:100%;max-width:430px;box-shadow:var(--shadow);transform:translateY(14px) scale(.98);transition:.24s}
.modal-overlay.open .modal{transform:none}
.modal h3{font-size:1.5rem;margin-bottom:6px}
.modal .sub{color:var(--muted);font-size:.94rem;margin-bottom:24px}
.modal-close{position:absolute;top:16px;right:16px}
.modal-tabs{display:flex;gap:6px;background:var(--bg-2);padding:5px;border-radius:12px;margin-bottom:22px}
.modal-tabs button{flex:1;padding:9px;border-radius:9px;background:none;border:none;color:var(--muted);
  font-family:inherit;font-weight:600;font-size:.9rem;cursor:pointer;transition:.2s}
.modal-tabs button.active{background:var(--green-soft);color:var(--mint)}
.modal .switch{text-align:center;margin-top:16px;font-size:.9rem;color:var(--muted)}
.modal .switch a{color:var(--mint);cursor:pointer;font-weight:600}

/* Toast */
.toast-wrap{position:fixed;bottom:24px;right:24px;z-index:200;display:flex;flex-direction:column;gap:10px}
.toast{background:var(--surface-2);border:1px solid var(--border-strong);border-left:3px solid var(--green-glow);
  border-radius:12px;padding:14px 18px;font-size:.92rem;box-shadow:var(--shadow);min-width:240px;max-width:360px;
  animation:slideIn .3s ease}
.toast.err{border-left-color:var(--red)}
@keyframes slideIn{from{opacity:0;transform:translateX(30px)}to{opacity:1;transform:none}}

/* Discord-knap */
.btn-discord-lg{background:#5865F2;color:#fff}
.btn-discord-lg:hover:not(:disabled){background:#4a56d6;transform:translateY(-2px)}
.or-sep{display:flex;align-items:center;gap:12px;margin:18px 0;color:var(--muted-2);font-size:.82rem}
.or-sep::before,.or-sep::after{content:"";flex:1;height:1px;background:var(--border)}

/* Svar-banner (godkendt/afvist) */
.decision{border-radius:var(--radius);padding:22px 24px;margin-bottom:20px;border:1px solid var(--border)}
.decision.approved{background:var(--green-soft);border-color:rgba(47,174,102,.4)}
.decision.rejected{background:var(--red-soft);border-color:rgba(224,86,79,.4)}
.decision .d-head{display:flex;justify-content:space-between;align-items:center;gap:12px;margin-bottom:12px;flex-wrap:wrap}
.decision .d-note{color:var(--text);line-height:1.6;white-space:pre-wrap}
.decision .d-wl{margin-top:14px;padding:11px 14px;border-radius:10px;background:rgba(47,174,102,.16);border:1px solid rgba(47,174,102,.4);color:var(--mint);font-weight:600;font-size:.92rem}
.decision .d-cool{margin-top:12px;color:var(--muted);font-size:.9rem}

/* Discord-koblings-kort */
.link-discord{display:flex;align-items:center;gap:16px;padding:18px 20px;border-radius:var(--radius);
  background:rgba(88,101,242,.1);border:1px solid rgba(88,101,242,.35);margin-bottom:20px;flex-wrap:wrap}
.link-discord .txt{flex:1;min-width:200px}
.link-discord .txt b{display:block;margin-bottom:2px}
.link-discord .txt span{color:var(--muted);font-size:.9rem}

/* Empty state */
.empty{text-align:center;padding:60px 20px;color:var(--muted)}
.empty .ic{font-size:2.4rem;margin-bottom:10px;opacity:.7}

/* Page header (dashboard/admin) */
.page-head{padding:48px 0 8px}
.page-head h1{font-size:clamp(1.8rem,4vw,2.5rem);margin-bottom:8px}
.page-head p{color:var(--muted)}

/* App list (dashboard) */
.app-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:22px 24px;margin-bottom:14px}
.app-card .top{display:flex;justify-content:space-between;align-items:center;gap:14px;margin-bottom:12px;flex-wrap:wrap}
.app-card .meta{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:12px;margin-top:12px}
.app-card .meta div span{display:block;font-size:.76rem;color:var(--muted-2);text-transform:uppercase;letter-spacing:.06em}
.app-card .meta div b{font-weight:600}
.app-card .note{margin-top:14px;padding:12px 15px;border-radius:11px;background:var(--bg-2);border:1px solid var(--border);font-size:.9rem;color:var(--muted)}

/* Utility */
.reveal{opacity:0;transform:translateY(24px);transition:opacity .6s,transform .6s}
.reveal.in{opacity:1;transform:none}
.hidden{display:none!important}
.center{text-align:center}
.mt-2{margin-top:20px}.mt-3{margin-top:30px}

@media(max-width:900px){.two-col{grid-template-columns:1fr}}
@media(max-width:720px){
  .section-pad{padding:72px 0}
  .nav-links{position:fixed;inset:70px 0 auto 0;flex-direction:column;background:rgba(10,15,12,.98);
    backdrop-filter:blur(14px);padding:22px;gap:16px;border-bottom:1px solid var(--border);
    transform:translateY(-120%);transition:transform .3s;z-index:40}
  .nav-links.open{transform:none}
  .burger{display:grid;place-items:center}
  .nav-cta .hide-mobile{display:none}
}
