    * {
      box-sizing: border-box;
    }

    body {
      margin: 0;
      font-family: sans-serif;
      background-color: #aaa;
      display: flex;
      justify-content: center;
    }

    .container {
      display: flex;
      flex-direction: column;
      width: 100%;
      max-width: 1200px;
      min-height: 100vh;
      background-color: #fff;
      box-shadow: 0px 5px 10px rgba(100,100,100,0.7);

    }

    main {
      flex: 1;
      background-color: #ddd;
      text-align: center;
      padding: 2rem;
    }

    footer {
      text-align: center;
      padding: 1rem;
      background-color: #ccc;
      min-height: 10vh;
    }

    h1 {
      margin: 2rem 0 1rem;
      color: #333;
    }

    p {
      font-size: 1rem;
      line-height: 1.4;
      color: #333;
      margin: 1rem 0;
    }

    p.secondary {
      color: #888;
      font-style: italic;
    }
    
    p.legal {
      display: block;
      width: 70%;
      margin: 0 auto;  
      font-size: 0.8rem;
      padding-top: 1em;
      color: #888;
      font-style: normal;
      border-top: dotted 1px #666;
      text-align: center;  
    }

   @media (max-width: 580px) {
     h1 {
        font-size: 2.8rem; 
      }

      p {
        font-size: 1.3rem;
      }

      p.legal {
        font-size: 1rem;
      }
    }
 