/*
  // Rady z https://fonts.google.com/
  // <uniquifier>: Use a unique and descriptive class name
  // <weight>: Use a value from 300 to 800

.open-sans-<uniquifier> {
  font-family: "Open Sans", sans-serif;
  font-optical-sizing: auto;
  font-weight: <weight>;
  font-style: normal;
  font-variation-settings:
    "wdth" 100;
}
*/

/* vynulování pro různě nastavené prohlížeče */
* {
    margin: 0;
    padding: 0;
    box-sizing: border-box; /* Zajišťuje, že padding a margin jsou počítány v celkové šířce a výšce */
}


body {
    font-family: "Open Sans", sans-serif;
    font-optical-sizing: auto;
    background-color: #f8f9fa;
    overflow-y: hidden; 
    /* height: 90vh; */
     /*padding-top: calc(3.5rem + 20px); /* Adjust the value to match the maximum height of your navbar */
}


.main-container {
    margin: auto; /* Centrování kontejneru */
    border: 1px solid black; /* Tenký černý rámeček */
    border-radius: 15px; /* Zakulacené okraje */
    padding-top: 20px; /* Padding uvnitř kontejneru */
    overflow-y: hidden;
}

.main-container, .container {
    max-width: 45rem;
}

.scroll-container {
    max-height: calc(90vh - 60px); /* Nastavení maximální výšky, aby se vešel do zbytku obrazovky */
    overflow-y: auto; /* Aktivace vertikálního scrollování */
    padding-right: 20px; /* Volitelný padding */
    /*padding-left: 10px; /* Volitelný padding */
    border: 0;
    /*border: 1px solid transparent; /* Přidání rámečku (pokud chcete) */
}

nav {
    background-color: #FFEDC9; /* Nastavení barvy pozadí */
    border-top: 1px solid black;
    border-left: 1px solid black;
    border-right: 1px solid black;
    border-bottom: 2px solid #E5C688;
    border-top-left-radius: 15px;
    border-top-right-radius: 15px;
    /* Maximální šířku není třeba zde nastavovat, je to již řízeno .main-container */
    padding: 0; /* Odstranění paddingu */

    overflow: hidden; /* Skrývá obsah přesahující hranice */

}


nav .navbar-brand, .logo-text {
    color: green; /* Barva textu */
    font-weight: 800; /* Tloušťka písma */
    font-size: 220%;
}

.fas, nav .navbar-brand, .logo-text {
    color: green;
}

nav .logo-img {
    width: 1.8em;
    height: 1.3em;
    position: relative;

}

nav .lang-switch {
    position: absolute; /* Umístění relativně k nejbližšímu pozicovanému rodiči */
    top: 10px; /* Posun od horního okraje */
    right: 10px; /* Posun od pravého okraje */
}

nav .lang-switch a {
    font-size: 34px; /* Zvětšení velikosti vlajky */
    text-decoration: none; /* Odebrání podtržení odkazu */
}

nav .lang-switch a:hover {
    transform: scale(1.2); /* Zvýraznění vlajky při přejetí myší */
    transition: transform 0.2s ease-in-out; /* Animace zvětšení */
}


h1 {
    /* horizontálně vycentrovat */
    text-align: center;
    font-size: calc(1.20rem + .8vw);
    padding-top: 1.2rem;
}

h2 {
    font-size: calc(1.10rem + .8vw);
    padding-top: 1.2rem;
}

h3 {
    font-size: calc(1rem + .5vw);
    padding-top: 1.0rem;
}

img.demo-img {
    width: 15rem;
    height: 15rem;
    /*margin-bottom: 20px; /* Přidání mezery pod obrázkem pro menší obrazovky */
}

img.qr-img {
    width: 10rem;
    height: 10rem;
    /*margin-bottom: 20px; /* Přidání mezery pod obrázkem pro menší obrazovky */
}

#problem-img {
    width: 10rem;
    height: 10rem;
}

#connectionIndicator {
    width: 20px;
    height: 20px;
    border-radius: 50%;
    margin-right: 10px;
}

.connected {
    background-color: green;
}

.disconnected {
    background-color: red;
}

/* Style for icons based on state */
.astriot-text-success {
    color: green;
}

.astriot-text-muted {
    /*color: #A3FBA3; /* Bootstrap's muted color */
    color: gray;
}



/* Style for message output */
#messageOutput {

    overflow-y: auto;
    border: 1px solid #ced4da; /* Match Bootstrap's default border color */
    padding: 10px;
    border-radius: 0.25rem;    /* Match Bootstrap's default border radius */
    background-color: #f9f9f9;
}

#cameraCanvas {
    width: 100%; /* Šířka bude maximální uvnitř rodiče */
    height: auto; /* Automatická výška založená na šířce */
    display: block; /* Pro odstranění mezery pod canvasem (běžná věc u inline-block elementů) */
}

/* Add rounded borders to canvas to match textarea */
#cameraCanvas {
    border: 6px solid #ced4da; /* Match Bootstrap's default border color */
    border-radius: 0.25rem;    /* Match Bootstrap's default border radius */
}

#cameraCanvas.canvas-border {
    border-color:green; /* Match Bootstrap's default border color */
}

/* Optional: Adjust switch size if needed */
.form-switch .form-check-input {
    width: 2em;
    height: 1em;
    padding-top: 20px;
}

/* CSS pro změnu barvy přepínače na zelenou při zapnutí */
.form-check-input:checked {
    background-color: green;
    /* border-color: green; */

}

.disabled-container {
    opacity: 0.5; /* Zeslabení barvy pro vizuální efekt */
    /* pointer-events: none; /* Zakáže klikání na všechny obsažené prvky */
}

/* Kontejner pro obsah při nepřístupné kameře */
.no-camera-access {
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    height: 100%;
  }
  
  /* Styl ikony přeškrtnuté kamery */
  .icon-container i {
    font-size: 10rem; /* Velikost ikony */
    color: #dc3545; /* Červená barva pro ikonu (Bootstrap 'danger' barva) */
  }
  
  /* Styl tlačítka pro obnovení stránky */
  .reload-button {
    font-size: 3rem; /* Velikost ikony uvnitř tlačítka */
    display: flex;
    align-items: center;
    justify-content: center;
    width: 90%;
  }
  

  /* Styl textu s chybovou zprávou */
  .error-message {
    margin-top: 1rem;
    color: #721c24; /* Tmavě červená barva pro text (Bootstrap 'danger' text) */
    font-size: 1.2rem;
    text-align: center;
  }

  .qrcode {
    margin: 1rem;
  }

  .page-container {
    margin-top: 3.8rem; 
    padding: 1rem;
  }

  button.gen-link-btn {
    margin: 1rem;
  }

  .grid-center-container {
    display: grid;
    place-items: center;
    height: 100%;
  }

.canvas-container {
    position: relative; /* Nastaví relativní pozici pro absolutní umístění loaderu */
}

#canvasLoader {
    color: green;
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    background-color: rgba(255, 255, 255, 0.8); /* Poloprůhledné pozadí */
    display: flex;
    justify-content: center;
    align-items: center;
    width: 100%;
    height: 100%;
    z-index: 10; /* Nadřazená vrstva vůči canvasu */
}
