    * {
      box-sizing: border-box;
    }

    html, body {
      min-height: 100%;
      height: 100%;
      background-size: cover;
      background-position: top center;
      font-family: 'Helvetica Neue', Helvetica, Arial, sans-serif;
      font-weight: 200;
    }

    html.modal-active, body.modal-active {
      overflow: hidden;
    }

    #modal-container {
      position: fixed;
      display: table;
      height: 100%;
      width: 100%;
      top: 0;
      left: 0;
      transform: scale(0);
      z-index: 1;
    }

    /* Effect 1: Unfolding */
    #modal-container.one {
      transform: scaleY(.01) scaleX(0);
      animation: unfoldIn 1s cubic-bezier(0.165, 0.840, 0.440, 1.000) forwards;
    }
    #modal-container.one .modal-background .modal {
      transform: scale(0);
      animation: zoomIn .5s .8s cubic-bezier(0.165, 0.840, 0.440, 1.000) forwards;
    }
    #modal-container.one.out {
      transform: scale(1);
      animation: unfoldOut 1s .3s cubic-bezier(0.165, 0.840, 0.440, 1.000) forwards;
    }
    #modal-container.one.out .modal-background .modal {
      animation: zoomOut .5s cubic-bezier(0.165, 0.840, 0.440, 1.000) forwards;
    }

    /* Effect 2: Revealing */
    #modal-container.two {
      transform: scale(1);
    }
    #modal-container.two .modal-background {
      background: rgba(0,0,0,.0);
      animation: fadeIn .5s cubic-bezier(0.165, 0.840, 0.440, 1.000) forwards;
    }
    #modal-container.two .modal-background .modal {
      opacity: 0;
      animation: scaleUp .5s cubic-bezier(0.165, 0.840, 0.440, 1.000) forwards;
    }
    #modal-container.two + .content {
      animation: scaleBack .5s cubic-bezier(0.165, 0.840, 0.440, 1.000) forwards;
    }
    #modal-container.two.out {
      animation: quickScaleDown 0s .5s linear forwards;
    }
    #modal-container.two.out .modal-background {
      animation: fadeOut .5s cubic-bezier(0.165, 0.840, 0.440, 1.000) forwards;
    }
    #modal-container.two.out .modal-background .modal {
      animation: scaleDown .5s cubic-bezier(0.165, 0.840, 0.440, 1.000) forwards;
    }
    #modal-container.two.out + .content {
      animation: scaleForward .5s cubic-bezier(0.165, 0.840, 0.440, 1.000) forwards;
    }

    /* Effect 3: Uncovering */
    #modal-container.three {
      z-index: 0;
      transform: scale(1);
    }
    #modal-container.three .modal-background {
      background: rgba(0,0,0,.6);
    }
    #modal-container.three .modal-background .modal {
      animation: moveUp .5s cubic-bezier(0.165, 0.840, 0.440, 1.000) forwards;
    }
    #modal-container.three + .content {
      z-index: 1;
      animation: slideUpLarge .5s cubic-bezier(0.165, 0.840, 0.440, 1.000) forwards;
    }
    #modal-container.three.out .modal-background .modal {
      animation: moveDown .5s cubic-bezier(0.165, 0.840, 0.440, 1.000) forwards;
    }
    #modal-container.three.out + .content {
      animation: slideDownLarge .5s cubic-bezier(0.165, 0.840, 0.440, 1.000) forwards;
    }

    /* Effect 4: Blow Up */
    #modal-container.four {
      z-index: 0;
      transform: scale(1);
    }
    #modal-container.four .modal-background {
      background: rgba(0,0,0,.7);
    }
    #modal-container.four .modal-background .modal {
      animation: blowUpModal .5s cubic-bezier(0.165, 0.840, 0.440, 1.000) forwards;
    }
    #modal-container.four + .content {
      z-index: 1;
      animation: blowUpContent .5s cubic-bezier(0.165, 0.840, 0.440, 1.000) forwards;
    }
    #modal-container.four.out .modal-background .modal {
      animation: blowUpModalTwo .5s cubic-bezier(0.165, 0.840, 0.440, 1.000) forwards;
    }
    #modal-container.four.out + .content {
      animation: blowUpContentTwo .5s cubic-bezier(0.165, 0.840, 0.440, 1.000) forwards;
    }

    /* Effect 5: Meep Meep */
    #modal-container.five {
      transform: scale(1);
    }
    #modal-container.five .modal-background {
      background: rgba(0,0,0,.0);
      animation: fadeIn .5s cubic-bezier(0.165, 0.840, 0.440, 1.000) forwards;
    }
    #modal-container.five .modal-background .modal {
      transform: translateX(-1500px);
      animation: roadRunnerIn .3s cubic-bezier(0.165, 0.840, 0.440, 1.000) forwards;
    }
    #modal-container.five.out {
      animation: quickScaleDown 0s .5s linear forwards;
    }
    #modal-container.five.out .modal-background {
      animation: fadeOut .5s cubic-bezier(0.165, 0.840, 0.440, 1.000) forwards;
    }
    #modal-container.five.out .modal-background .modal {
      animation: roadRunnerOut .5s cubic-bezier(0.165, 0.840, 0.440, 1.000) forwards;
    }

    /* Effect 6: Sketch */
    #modal-container.six {
      transform: scale(1);
    }
    #modal-container.six .modal-background {
      background: rgba(0,0,0,.0);
      animation: fadeIn .5s cubic-bezier(0.165, 0.840, 0.440, 1.000) forwards;
    }
    #modal-container.six .modal-background .modal {
      background-color: transparent;
      animation: modalFadeIn .5s .8s cubic-bezier(0.165, 0.840, 0.440, 1.000) forwards;
    }
    #modal-container.six .modal-background .modal .modal-image {
      /* Resim efekti için opacity ayarı */
      opacity: 0;
      animation: modalContentFadeIn .5s 1s cubic-bezier(0.165, 0.840, 0.440, 1.000) forwards;
    }
    #modal-container.six .modal-background .modal .modal-svg rect {
      animation: sketchIn .5s .3s cubic-bezier(0.165, 0.840, 0.440, 1.000) forwards;
    }
    #modal-container.six.out {
      animation: quickScaleDown 0s .5s linear forwards;
    }
    #modal-container.six.out .modal-background {
      animation: fadeOut .5s cubic-bezier(0.165, 0.840, 0.440, 1.000) forwards;
    }
    #modal-container.six.out .modal-background .modal {
      animation: modalFadeOut .5s cubic-bezier(0.165, 0.840, 0.440, 1.000) forwards;
    }
    #modal-container.six.out .modal-background .modal .modal-image {
      animation: modalContentFadeOut .5s cubic-bezier(0.165, 0.840, 0.440, 1.000) forwards;
    }
    #modal-container.six.out .modal-background .modal .modal-svg rect {
      animation: sketchOut .5s cubic-bezier(0.165, 0.840, 0.440, 1.000) forwards;
    }

    /* Effect 7: Bond */
    #modal-container.seven {
      transform: scale(1);
    }
    #modal-container.seven .modal-background {
      background: rgba(0,0,0,.0);
      animation: fadeIn .5s cubic-bezier(0.165, 0.840, 0.440, 1.000) forwards;
    }
    #modal-container.seven .modal-background .modal {
      height: 75px;
      width: 75px;
      border-radius: 75px;
      overflow: hidden;
      animation: bondJamesBond 1.5s cubic-bezier(0.165, 0.840, 0.440, 1.000) forwards;
    }
    #modal-container.seven .modal-background .modal .modal-image {
      opacity: 0;
      position: relative;
      animation: modalContentFadeIn .5s 1.4s linear forwards;
    }
    #modal-container.seven.out {
      animation: slowFade .5s 1.5s linear forwards;
    }
    #modal-container.seven.out .modal-background {
      background-color: rgba(0,0,0,.7);
      animation: fadeToRed 2s cubic-bezier(0.165, 0.840, 0.440, 1.000) forwards;
    }
    #modal-container.seven.out .modal-background .modal {
      border-radius: 3px;
      animation: killShot 1s cubic-bezier(0.165, 0.840, 0.440, 1.000) forwards;
    }
    #modal-container.seven.out .modal-background .modal .modal-image {
      animation: modalContentFadeOut .5s 0.5s cubic-bezier(0.165, 0.840, 0.440, 1.000) forwards;
    }

    /* General Modal Styles */
    #modal-container .modal-background {
      display: table-cell;
      background: rgba(0,0,0,.8);
      text-align: center;
      vertical-align: middle;
    }
    #modal-container .modal-background .modal {
      background: white;
      padding: 0; /* Resmi tamamen göstermek için padding'i sıfırlıyoruz */
      display: inline-block;
      width: 380px;         /* İdeal küçültülmüş genişlik */
      height: 380px;        /* Tam kare form faktörü */
      max-width: 90vw;      /* Mobil ekran taşma koruması */
      max-height: 90vw;
      border-radius: 12px;
      overflow: hidden; /* Resmin köşelerinin modal border-radius'ına uyması için */
      font-weight: 300;
      position: relative;
      box-shadow: 0 10px 30px rgba(0,0,0,0.5);
    }
    /* Modalın içindeki resim için stil */
    .modal-image {
      display: block;
        width: 100%;
        height: 100%;
        object-fit: cover;    /* Resmin kare alana tam oturmasını sağlar */
    }

    #modal-container .modal-background .modal .modal-svg {
      position: absolute;
      top: 0;
      left: 0;
      border-radius: 12px;
      pointer-events: none; /* SVG resmin üstüne binmesin */
    }
    #modal-container .modal-background .modal .modal-svg rect {
      stroke: #fff;
      stroke-width: 2px;
      stroke-dasharray: 778;
      stroke-dashoffset: 778;
    }

    /* Content Area Styles */
    .content {
      min-height: 100%;
      height: 100%;
      background: white;
      position: relative;
      z-index: 0;
    }
    .content h1 {
      padding: 75px 0 30px 0;
      text-align: center;
      font-size: 30px;
      line-height: 30px;
    }
    .content .buttons {
      max-width: 800px;
      margin: 0 auto;
      padding: 0;
      text-align: center;
    }
    .content .buttons .button {
      display: inline-block;
      text-align: center;
      padding: 10px 15px;
      margin: 10px;
      font-size: 18px;
      background-color: #efefef;
      border-radius: 3px;
      box-shadow: 0 1px 2px rgba(0,0,0,.3);
      cursor: pointer;
    }
    .content .buttons .button:hover {
      color: white;
      background: #009bd5;
    }

    /* Keyframes Animations */
    @keyframes unfoldIn {
      0% { transform: scaleY(.005) scaleX(0); }
      50% { transform: scaleY(.005) scaleX(1); }
      100% { transform: scaleY(1) scaleX(1); }
    }
    @keyframes unfoldOut {
      0% { transform: scaleY(1) scaleX(1); }
      50% { transform: scaleY(.005) scaleX(1); }
      100% { transform: scaleY(.005) scaleX(0); }
    }
    @keyframes zoomIn {
      0% { transform: scale(0); }
      100% { transform: scale(1); }
    }
    @keyframes zoomOut {
      0% { transform: scale(1); }
      100% { transform: scale(0); }
    }
    @keyframes fadeIn {
      0% { background: rgba(0,0,0,.0); }
      100% { background: rgba(0,0,0,.7); }
    }
    @keyframes fadeOut {
      0% { background: rgba(0,0,0,.7); }
      100% { background: rgba(0,0,0,.0); }
    }
    @keyframes scaleUp {
      0% { transform: scale(.8) translateY(1000px); opacity: 0; }
      100% { transform: scale(1) translateY(0px); opacity: 1; }
    }
    @keyframes scaleDown {
      0% { transform: scale(1) translateY(0px); opacity: 1; }
      100% { transform: scale(.8) translateY(1000px); opacity: 0; }
    }
    @keyframes scaleBack {
      0% { transform: scale(1); }
      100% { transform: scale(.85); }
    }
    @keyframes scaleForward {
      0% { transform: scale(.85); }
      100% { transform: scale(1); }
    }
    @keyframes quickScaleDown {
      0% { transform: scale(1); }
      99.9% { transform: scale(1); }
      100% { transform: scale(0); }
    }
    @keyframes slideUpLarge {
      0% { transform: translateY(0%); }
      100% { transform: translateY(-100%); }
    }
    @keyframes slideDownLarge {
      0% { transform: translateY(-100%); }
      100% { transform: translateY(0%); }
    }
    @keyframes moveUp {
      0% { transform: translateY(150px); }
      100% { transform: translateY(0); }
    }
    @keyframes moveDown {
      0% { transform: translateY(0px); }
      100% { transform: translateY(150px); }
    }
    @keyframes blowUpContent {
      0% { transform: scale(1); opacity: 1; }
      99.9% { transform: scale(2); opacity: 0; }
      100% { transform: scale(0); }
    }
    @keyframes blowUpContentTwo {
      0% { transform: scale(2); opacity: 0; }
      100% { transform: scale(1); opacity: 1; }
    }
    @keyframes blowUpModal {
      0% { transform: scale(0); }
      100% { transform: scale(1); }
    }
    @keyframes blowUpModalTwo {
      0% { transform: scale(1); opacity: 1; }
      100% { transform: scale(0); opacity: 0; }
    }
    @keyframes roadRunnerIn {
      0% { transform: translateX(-1500px) skewX(30deg) scaleX(1.3); }
      70% { transform: translateX(30px) skewX(0deg) scaleX(.9); }
      100% { transform: translateX(0px) skewX(0deg) scaleX(1); }
    }
    @keyframes roadRunnerOut {
      0% { transform: translateX(0px) skewX(0deg) scaleX(1); }
      30% { transform: translateX(-30px) skewX(-5deg) scaleX(.9); }
      100% { transform: translateX(1500px) skewX(30deg) scaleX(1.3); }
    }
    @keyframes sketchIn {
      0% { stroke-dashoffset: 778; }
      100% { stroke-dashoffset: 0; }
    }
    @keyframes sketchOut {
      0% { stroke-dashoffset: 0; }
      100% { stroke-dashoffset: 778; }
    }
    @keyframes modalFadeIn {
      0% { background-color: transparent; }
      100% { background-color: white; }
    }
    @keyframes modalFadeOut {
      0% { background-color: white; }
      100% { background-color: transparent; }
    }
    @keyframes modalContentFadeIn {
      0% { opacity: 0; top: -20px; }
      100% { opacity: 1; top: 0; }
    }
    @keyframes modalContentFadeOut {
      0% { opacity: 1; top: 0px; }
      100% { opacity: 0; top: -20px; }
    }
    @keyframes bondJamesBond {
      0% { transform: translateX(1000px); }
      80% { transform: translateX(0px); border-radius: 75px; height: 75px; width: 75px; }
      90% { border-radius: 3px; height: 182px; width: 247px; }
      100% { border-radius: 3px; height: 162px; width: 227px; }
    }
    @keyframes killShot {
      0% { transform: translateY(0) rotate(0deg); opacity: 1; }
      100% { transform: translateY(300px) rotate(45deg); opacity: 0; }
    }
    @keyframes fadeToRed {
      0% { background-color: rgba(0, 0, 0, 0.6); }
      100% { background-color: rgba(255, 0, 0, 0.8); }
    }
    @keyframes slowFade {
      0% { opacity: 1; }
      99.9% { opacity: 0; transform: scale(1); }
      100% { transform: scale(0); }
    }
