﻿@import url("https://fonts.googleapis.com/css2?family=Roboto:wght@400;500;600;700&display=swap");

* {
    margin: 0;
    padding: 0;
    box-sizing: border-box;
    font-family: 'Roboto', sans-serif;
}

/* Center the logo inside the wrapper */
.logo-wrapper {
    display: flex;
    justify-content: center;
    align-items: center;
    margin: 0;
    padding: 0;
}

/* Style the logo */
.logo {
    max-width: 300px;
    height: auto;
}

/* Style for the bottom Exsitec logo */
.bottom-logo {
    width: 100px;
    height: 75px;
    object-fit: contain;
    display: block;
    margin: 0 auto;
}

nav {
    position: fixed;
    padding: 25px 60px;
    z-index: 1;
}

    nav a img {
        width: 167px;
    }
.login-label {
    text-align: center; /* Sentrert */
    font-size: 1.45rem; /* Mye større (28px) */
    font-weight: 400; /* Semi-bold for emphasis */
    color: #2c3e50; /* Mørkere farge */
    margin-top:3rem;
    margin-bottom: 1rem; /* Mer luftig */
    letter-spacing: 0.5px; /* Bedre lesbarhet */
    line-height: 1.3;
}

.form-help a {
    font-size: 2rem; /* Litt større (16px) */
    font-weight: 500; /* Medium vekt */
    color: #0066cc; /* Tydelig blå link-farge */
    padding: 8px 16px; /* Større klikkområde */
    border-radius: 6px; /* Rounded corners */
    display: inline-block; /* For padding */
}

    .form-help a:hover {
        color: #0052a3; /* Mørkere blå ved hover */
        background-color: #f0f7ff; /* Lys blå bakgrunn */
    }

.form-wrapper {
    position: absolute;
    left: 50%;
    top: 50%;
    border-radius: 4px;
    padding: 70px;
    width: 450px;
    transform: translate(-50%, -50%);
    background: #ffffff;
    box-shadow: 0 4px 10px rgba(0, 0, 0, 0.1);
}

    .form-wrapper h2 {
        color: #fff;
        font-size: 2rem;
    }

    .form-wrapper form {
        margin: 25px 0 65px;
    }

form .form-control {
    height: 50px;
    position: relative;
    margin-bottom: 16px;
}

.form-control input {
    height: 100%;
    width: 100%;
    background: #333;
    border: none;
    outline: none;
    border-radius: 4px;
    color: #fff;
    font-size: 1rem;
    padding: 0 20px;
}

    .form-control input:is(:focus, :valid) {
        background: #444;
        padding: 16px 20px 0;
    }

.form-control label {
    position: absolute;
    left: 20px;
    top: 50%;
    transform: translateY(-50%);
    font-size: 1rem;
    pointer-events: none;
    color: #8c8c8c;
    transition: all 0.1s ease;
}

.form-control input:is(:focus, :valid) ~ label {
    font-size: 0.75rem;
    transform: translateY(-130%);
}

form button {
    width: 100%;
    padding: 16px 0;
    font-size: 1rem;
    background: #181f4a !important;
    font-weight: 500;
    border-radius: 4px;
    border: none;
    outline: none;
    margin: 25px 0 10px;
    cursor: pointer;
    transition: 0.1s ease;
    color: white;
}

    form button:hover {
        background: #181f4a !important;
    }

.form-wrapper a {
    text-decoration: none;
}

    .form-wrapper a:hover {
        text-decoration: underline;
    }

.form-wrapper :where(label, p, small, a) {
    color: #3d3c3c;
}

form .form-help {
    display: flex;
    justify-content: center;
    align-items: center;
}

form .remember-me {
    display: flex;
    align-items: center;
}

    form .remember-me input {
        margin-right: 5px;
        accent-color: #3d3c3c;
    }

form .form-help :where(label, a) {
    font-size: 0.9rem;
}

/* Style for the help modal/popup */
.help-modal {
    display: none;
    position: fixed;
    z-index: 1000;
    left: 0;
    top: 0;
    width: 100%;
    height: 100%;
    background-color: rgba(0,0,0,0.5);
}

.help-modal-content {
    background-color: #fefefe;
    margin: 15% auto;
    padding: 20px;
    border-radius: 8px;
    width: 90%;
    max-width: 400px;
    text-align: center;
    box-shadow: 0 4px 6px rgba(0, 0, 0, 0.1);
}

.close-modal {
    color: #aaa;
    float: right;
    font-size: 28px;
    font-weight: bold;
    cursor: pointer;
    line-height: 1;
}

    .close-modal:hover,
    .close-modal:focus {
        color: black;
    }

.form-wrapper p a {
    color: #fff;
}

.form-wrapper small {
    display: block;
    margin-top: 15px;
    color: #3d3c3c;
}

    .form-wrapper small a {
        color: #0071eb;
    }

@media (max-width: 740px) {
    nav, .form-wrapper {
        padding: 20px;
    }

        nav a img {
            width: 140px;
        }

    .form-wrapper {
        width: 100%;
        top: 43%;
    }

        .form-wrapper form {
            margin: 25px 0 40px;
        }
}

/* Fullscreen videobakgrunn – ingen fallback-bilde */
html, body {
    width: 100%;
    height: 100%;
    margin: 0 !important;
    padding: 0 !important;
    overflow: hidden; /* ingen scrollbars */
    background: #000 !important; /* ren farge – null bilde */
    background-image: none !important;
}

/* nøytraliser margin fra site.css for å unngå vertikal scroll */
body {
    margin-bottom: 0 !important;
}

    /* slå av ev. body-pseudo som legger bakgrunn */
    body::before, body::after {
        content: none !important;
        background: transparent !important;
        background-image: none !important;
    }

/* slå av ev. gammel klasse */
.background-image {
    background: transparent !important;
    background-image: none !important;
}

/* Selve videoen */
.bg-video {
    position: fixed;
    inset: 0; /* top/right/bottom/left: 0 */
    width: 100%;
    height: 100%;
    object-fit: cover; /* dekker hele skjermen */
    object-position: center center;
    z-index: -1; /* under innhold */
    display: block;
    pointer-events: none;
}

/* Alt innhold skal ligge over videoen */
.form-wrapper, nav, .help-modal {
    position: relative;
    z-index: 1;
}

/* Hvis bruker har reduced motion -> ingen video (kun svart bakgrunn) */
@media (prefers-reduced-motion: reduce) {
    .bg-video {
        display: none;
    }
}

/* Fyll hele viewporten og fjern bakgrunner */
html, body {
    margin: 0;
    height: 100%;
    overflow: hidden;
    background: #000;
}

/* Zoom og flytt videoen slik at høyre panel og bunnstripe forsvinner */
.bg-video {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: 35% center; /* flytt fokus mot venstre (20–45% er typisk bra) */
    transform: scale(1.15); /* zoom litt inn (1.08–1.25 etter behov) */
    z-index: -1;
    pointer-events: none;
}

/* ——— Fullscreen bakgrunn uten bakgrunnsbilde ——— */
html, body {
    margin: 0 !important;
    padding: 0 !important;
    height: 100%;
    overflow: hidden !important;
    background: #000 !important; /* ren farge hvis video ikke spiller */
    background-image: none !important; /* slå av ev. bakgrunnsbilder */
}

/* innholdet over videoen */
.form-wrapper, nav, .help-modal {
    position: relative;
    z-index: 1;
}

/* nøytraliser margin-bottom fra site.css uten å endre site.css */
body {
    margin-bottom: 0 !important;
}

    /* slå av evt. pseudo-/klasse-bakgrunner */
    body::before, body::after,
    .background-image {
        background: transparent !important;
        background-image: none !important;
    }


/* --- Login-knapper (match bildet) --- */

:root {
    /* Farger fra designet ditt */
    --btn-bg: #181f4a; /* primær knappbakgrunn */
    --btn-bg-hover: #1e2756; /* litt lysere/dypere ved hover */
    --btn-text: #e6ecf0;
    /* Kantrender og glans */
    --btn-border: rgba(226, 232, 240, 0.18);
    --btn-border-hover: rgba(226, 232, 240, 0.30);
    --btn-sheen-top: rgba(255, 255, 255, 0.16); /* “glass”-lag øverst */
    --btn-sheen-btm: rgba(255, 255, 255, 0.06); /* svakere mot bunn */
    /* Geometri/effekter */
    --btn-radius: 18px;
    --btn-pad-y: 18px;
    --btn-pad-x: 28px;
}

/* Base-knapp */
.btn-neo {
    position: relative;
    display: inline-flex;
    align-items: center;
    gap: .9rem;
    padding: var(--btn-pad-y) var(--btn-pad-x);
    border-radius: var(--btn-radius);
    border: 1.5px solid var(--btn-border);
    color: var(--btn-text);
    font-weight: 700;
    font-size: clamp(18px, 2.2vw, 28px);
    line-height: 1;
    /* NB: lagdelt bakgrunn – først glans, så selve fargen */
    background: linear-gradient(180deg, var(--btn-sheen-top), var(--btn-sheen-btm)), var(--btn-bg);
    /* Drop-shadow + subtile innerskygger for “innramming” */
    box-shadow: 0 22px 45px rgba(15, 21, 53, 0.30), /* stor myk skygge på hvit bg */
    0 8px 18px rgba(15, 21, 53, 0.18), inset 0 1px 0 rgba(255, 255, 255, 0.15), /* lys topp-highlight */
    inset 0 0 0 1px rgba(255, 255, 255, 0.06); /* indre ring */
    text-decoration: none;
    cursor: pointer;
    transition: background-color .15s ease, box-shadow .15s ease, border-color .15s ease, transform .05s ease;
}

    /* Ikon i venstre kant (match screenshot) */
    .btn-neo .btn-icon {
        display: inline-grid;
        place-items: center;
        width: 38px;
        height: 38px;
        border-radius: 10px; /* bare for enklere plassering – ikke synlig */
    }

    /* Hover/active-stater */
    .btn-neo:hover {
        background: linear-gradient(180deg, rgba(255,255,255,.18), rgba(255,255,255,.08)), var(--btn-bg-hover);
        border-color: var(--btn-border-hover);
        box-shadow: 0 26px 52px rgba(15, 21, 53, 0.32), 0 10px 20px rgba(15, 21, 53, 0.20), inset 0 1px 0 rgba(255, 255, 255, 0.18), inset 0 0 0 1px rgba(255, 255, 255, 0.08);
    }

    .btn-neo:active {
        transform: translateY(1px);
        box-shadow: 0 14px 24px rgba(15, 21, 53, 0.28), 0 6px 12px rgba(15, 21, 53, 0.20), inset 0 1px 0 rgba(255, 255, 255, 0.12), inset 0 0 0 1px rgba(255, 255, 255, 0.06);
    }

.login-providers{
  display: grid;
  grid-template-columns: 1fr;
  gap: 28px;
}

/* To knapper ved bred skjerm – side om side */
@media (min-width: 992px){
  .login-providers{
    grid-template-columns: 1fr 1fr;
    gap: 40px;
  }
}

.provider-btn{
  display: flex;
  align-items: center;
  gap: 18px;
  width: 100%;
  padding: 22px 28px;
  min-height: 84px;

  background: var(--btn-bg);
  border: 2px solid var(--btn-border);
  border-radius: 18px;

  color: var(--btn-text);
  font-weight: 700;
  font-size: clamp(18px, 1.2vw, 26px);
  letter-spacing: .2px;

  cursor: pointer;
  text-decoration: none;
  transition: background-color .15s ease, border-color .15s ease, transform .12s ease, box-shadow .15s ease;
  box-shadow: 0 8px 22px rgba(0,0,0,.25), inset 0 0 0 1px rgba(255,255,255,.04);
}

.provider-btn:hover{
  background: var(--btn-bg-hover);
  border-color: var(--btn-border-hover);
  transform: translateY(-1px);
  box-shadow: 0 12px 28px rgba(0,0,0,.32), inset 0 0 0 1px rgba(255,255,255,.06);
}

.provider-btn:active{
  transform: translateY(0);
  box-shadow: 0 6px 18px rgba(0,0,0,.28);
}

.provider-btn:focus-visible{
  outline: none;
  box-shadow: 0 0 0 3px rgba(37,140,251,.5), 0 12px 28px rgba(0,0,0,.32);
}

/* Ikonene større og med luft */
.provider-logo{
  width: 44px;
  height: 44px;
  object-fit: contain;
  flex: 0 0 auto;
}

/* Teksten får litt mer rom (ikke helt venstrestilt) */
.provider-btn span{
  line-height: 1;
}

/* Fjern/overstyr gamle brand-borderfarger */
.visma-btn, .microsoft-btn{
  border-color: var(--btn-border) !important;
  background: var(--btn-bg) !important;
  color: var(--btn-text) !important;
}
