/*Variablen*/

:root {
  --dynamic-red-100: #F5384A;
  --midnight-blue-100: #26294C;
  --eggshell-100: #EBE8E0;
  --border-color: #F3F1EB;

  --container-w: 1400px;
  --gutter: clamp(16px, 4vw, 40px);
}

/*Größen */

.text-size-medium {
  font-size: 18px;
  line-height: 150%;
  color: var(--dynamic-red-100);
}
.text-size-regular{
  font-size: 16px;
  line-height: 150%;
  color: var(--dynamic-red-100);
}
.text-size-small{
  font-size: 14px;
  line-height: 150%;
  color: var(--dynamic-red-100);
  text-decoration: none;
}

.bold{
  font-weight: 700;
}
.semi-bold{
  font-weight: 600;
}

.text-width{
  max-width: 445px;
}


.heading2-desktop {
  margin: 0;
  font-weight: 800;
  font-size: 48px;
  line-height: 120%;
  color: var(--dynamic-red-100);
  width: 608px;
}

/*Reset & Grundstil*/
*, *::before, *::after { box-sizing: border-box; }
html, body { height: 100%; }


.container {
  display: block;
  margin: 0 auto;
  width: 100%;
  max-width: 1440px;
}

body {
  font-family: "Plus Jakarta Sans", system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
  background: var(--eggshell-100);
  line-height: 120%;
}

body.login-bg {
  display: grid;
  grid-template-rows: auto 1fr auto;
}

/*Header */

header{
  width:100%;
  margin-top: 32px !important;
  display:flex !important;
  justify-content:space-between;
}

.ghost-btn {
  border: 1.5px solid var(--dynamic-red-100);
  color: var(--dynamic-red-100);
  padding: 16px 24px;
  border-radius: 16px;
  font-weight: 600;
  text-decoration: none;
  transition: all 150ms ease-out;
}

.ghost-btn:hover{
  color: #fff;
border-radius:  16px;
border:  1.5px solid var #F5384A;
background: var(--Dynamic-Red, #F5384A);
box-shadow: 0 12px 20px 0  rgba(245, 56, 74, 0.25);
  text-shadow: 0 0 40px var(--White, #FFF), 0 0 40px var(--White, #FFF);
}


/*Main */
main{
  margin: auto 0;
}

.login-main {
  width: 100%;
  padding: 88px 0px 0px 0px;
  display: grid;
  grid-template-columns: 1.1fr 1fr;
  gap: clamp(40px, 8vw, 96px);
  place-content: center; 
}

.login-info { padding-top: 8px, 2vw, 16px; }

.login-info .text-regular-semi-bold {
  display: inline-block;
  margin-bottom: 16px;
  opacity: .85;
}


/* =========================
   Formular
   ========================= */
.login-form {
  display: grid;
  gap: 18px;
  max-width: 400px;
}

.room-request{
  color: var(--dynamic-red-100) !important;
  cursor: pointer;
}

.input-field {
  height: 64px;
  border: 1.5px solid var(--dynamic-red-100);
  border-radius: 16px;
  background-color: var(--eggshell-100);
  padding-left: 12px;
  font-family: Plus Jakarta Sans, system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
}

.input-field::placeholder {
  color: var(--dynamic-red-100);
  padding: 8px 0px;
}

.text-width{
  width: 450px !important;
  margin-bottom: 48px;
}

.btn-red {
  font-size: 18px;
  margin-top: 32px;
  padding: 32px 48px;
  border: 0;
  border-radius: 24px;
  background: var(--dynamic-red-100);
  color: #fff;
  cursor: pointer;
  width: fit-content !important;
  transition: all 150ms ease-out;
}

.btn-red:hover {
  text-shadow: 0 0 40px var(--White, #FFF), 0 0 40px var(--White, #FFF);
  box-shadow: 0 12px 20px 0 rgba(245, 56, 74, 0.25);
}

/* =========================
   Footer 
   ========================= */

.login-footer {
  margin: 0 auto;
  padding: 32px 0px;
  display: flex !important;
  justify-content:space-between;
  gap: 16px;
  border-top: 1.5px solid var(--border-color);

  margin-top: 64px;
  margin-bottom: 32px ;
}

.footer-nav {
  display: flex;
  gap: 22px;
  text-decoration: none;
}



@media (max-width: 1440px){
  .container {
    padding-left: 24px;
    padding-right: 24px;
  }
}

@media (max-width: 1200px){
  .main,
  .login-main,
  main.main,
  main.login-main{
    display: grid;               
    grid-template-columns: 1fr !important;
    row-gap: clamp(24px, 6vw, 48px);
    place-content: center;         
    justify-items: start;
    min-height: 100svh;
  }

  .login-info{ order: 1; }
  .login-form-section{ order: 2; }

  
  .heading2-desktop{ font-size: clamp(34px, 7.5vw, 46px); }

    .heading2-desktop,
  .text-width{
    width: auto !important;
  }

  @media (max-width: 560px){
  header .ghost-btn{
    white-space: nowrap;
    padding: 10px 14px;
    border-radius: 12px;
    font-size: 0;
    line-height: normal !important;
  }
  header .ghost-btn::after{
    content: "Zur Website";
    font-size: 15px;
    line-height: 1;
    color: var(--dynamic-red-100);
  }
  header .ghost-btn:hover::after{
    color: #fff;
  }
}
}




h1 {
    color: var(--dynamic-red-100);
    font-size: 48px;
    font-weight: 800;
    line-height: 120%;
    margin-block-start: 0;
    margin-block-end: 0;
}

.width-h1{
  max-width: 608px !important;
}

a.btn-logout {
    border-radius: 16px;
    border: 1.5px solid var(--dynamic-red-100);
    background: var(--dynamic-red-100);

    color: var(--eggshell-100);
    font-size: 16px;
    font-weight: 600;
    line-height: 150%;
    text-decoration: none;
    padding:16px 24px;
    cursor: pointer;
    display: flex;
    gap: 12px;
    align-items: center;
}
.btn-delet {
    border-radius: 16px;
    background: var(--eggshell-100);
    border: 1.5px solid var(--eggshell-100);
    color: var(--dynamic-red-100);
    font-size: 16px;
    font-weight: 600;
    line-height: 150%;
    text-decoration: none;
    padding:16px 24px;
    font-family: "Plus Jakarta Sans";
    display: flex;
    gap: 12px;
    align-items: center;
    cursor: pointer;
}
.left-block{
  max-width: 800px;
  color: var(--dynamic-red-100);
  font-size: 18px;
  font-weight: 500;
  line-height: 150%;
  margin-right: 200px;
}

table th {
    text-align: left;
    color: var(--dynamic-red-100);
    font-size: 18px;
    font-weight: 500;
    line-height: 150%;
    padding-bottom: 24px;
}
table td {
    border-top: 1px solid var(--border-color);
    padding:24px 0;
    color: var(--midnight-blue-100);
    font-size: 18px;
    font-weight: 700;
    line-height: 150%;
}
.grid-wrapper {
    display: flex;
}
.grid-wrapper .left-block, .grid-wrapper .right-block {
    flex:1;
}
.display-flex-buttonbar {
    display: flex;
    justify-content: flex-end;
}
.margin-top-big {
    margin-top: 64px;
}

.margin-top-medium {
    margin-top: 32px;
}
.padding-top-medium{
    padding-top: 32px;
}

.space-contact{
    padding-right: 40px;
}


p{
  margin-block-start: 0;
}

.br-750{display:none;}

@media (max-width: 1440px){

  .container{
    padding-left: 24px !important;
    padding-right: 24px !important;
  }
}


@media (max-width: 1200px){

  .left-block{ margin-right: 0; }

  header.container.grid-wrapper{
    display:flex;
    align-items:center;
    justify-content:space-between;
    gap:12px;
    flex-wrap:nowrap;
  }
  header.container.grid-wrapper .left-block,
  header.container.grid-wrapper .right-block{
    flex:0 0 auto;
  }
  header.container.grid-wrapper .display-flex-buttonbar{
    display:flex;
    align-items:center;
    gap:12px;
    flex-wrap:nowrap;
  }


  div.container .grid-wrapper{
    flex-direction:column;
    align-items:flex-start;
    gap:24px;
  }

  .left-block h1{ width:auto; }
  .text-size-medium .text-width{ max-width:680px; }
}


@media (max-width: 1100px){


  table thead, table thead *, table th{ display:none !important; }
  table > tbody > tr:first-child,
  table > tr:first-child{ display:none !important; }

 
  table tr{
    display:grid;
    grid-template-columns: 1.2fr 1.6fr 1fr; 
    column-gap:16px;
    row-gap:10px;
    align-items:center;
    border-top:1px solid var(--border-color);
    padding:16px 0;
  }
  table tr td{ border-top:none; padding:0; }

  table tr td:nth-child(1){ grid-column:1; grid-row:1; } 
  table tr td:nth-child(2){ grid-column:2; grid-row:1; } 
  table tr td:nth-child(3){ grid-column:3; grid-row:1; }

 
  table tr td.space-contact{
    grid-column:1 / span 2;    
    grid-row:2;
    white-space:normal;
    word-break:break-word;
    overflow-wrap:anywhere;
  }
  table tr td:last-child{
    grid-column:3;
    grid-row:2;
    justify-self:start;        
  }
  table tr td:last-child .btn-logout{ width:auto; }


  table tr:first-of-type{ border-top:none; }
}



@media (max-width: 750px){
.grid-wrapper{
    display:grid !important;
    grid-template-columns:1fr;
    row-gap:12px;
    align-items:start;
  }

  .left-block{
    grid-column:1;
    grid-row:1;
    align-self:start;
  }

  /* headline mobil: kleiner, darf trennen, keine fixe breite */
  .left-block h1,
  h1{
    width:auto !important;
    max-width:100%;
    font-size:clamp(32px,9vw,40px);
    line-height:1.12;
    hyphens:auto;
    overflow-wrap:anywhere;
    word-break:break-word;
  }

    header.container{
    padding-inline: 24px !important;
    box-sizing: border-box;
    margin-inline: auto;
  }

  .text-style-medium{ max-width:100%; }

  /* buttons unter dem logo, 70/30 als ratio, schrumpfen proportional */
    .display-flex-buttonbar{
    grid-column:1;
    grid-row:2;
    display:grid;
    grid-template-columns:7fr 3fr;   /* 70 / 30 */

  }
  .display-flex-buttonbar form{
    grid-column:1;
    width:100%;
    display:flex;
  }
  .display-flex-buttonbar .btn-delet,
  .display-flex-buttonbar .btn-logout{
    width:100%;
    justify-content:center;
    white-space:nowrap;
    font-size:clamp(14px,3.8vw,16px);
    padding:clamp(10px,3vw,14px) clamp(12px,4vw,16px);
    border-radius:clamp(12px,3.2vw,16px);
    margin-left:0;
  }
  .display-flex-buttonbar .btn-logout{ grid-column:2; }
  .br-750{display:block;}
}



@media (max-width: 750px){

  table thead, table thead *, table th{ display:none !important; }
  table > tbody > tr:first-child,
  table > tr:first-child{ display:none !important; }


  table{
    width:100%;
    border-collapse: collapse;
  }
  table tr{
    display:block;
    padding:16px 0;
    border-top:1px solid var(--border-color);
  }
  table tr:first-of-type{ border-top:none; }


  table td{
    display:block;
    border:0;
    padding:6px 0;
  }


  table td.space-contact{
    white-space:normal;
    word-break:break-word;
    overflow-wrap:anywhere;
  }


  table td:last-child{
    padding-top:10px;
  }
  table td:last-child .btn-logout{
    width:100%;
    justify-content:center;
  }
}
