/*Global*/
body {
    overflow-x: hidden;
}

/* TABLET - 768px to 1024px */
@media (max-width: 1024px) {

    .navbar {
        padding: 0px 30px;
    }

    .nav-links {
        gap: 25px;
    }

    .hero {
        padding: 140px 30px 50px;
    }

    .hero-content h1 {
        font-size: 2rem;
        white-space: normal;
    }

    section {
        padding: 50px 30px;
    }

    .cards-grid {
        grid-template-columns: repeat(2, 1fr);
    }

    .services-grid {
        grid-template-columns: repeat(2, 1fr);
    }

    .values-grid {
        grid-template-columns: repeat(2, 1fr);
    }

    .addons-grid {
        grid-template-columns: repeat(2, 1fr);
    }

    .bundles-grid {
        grid-template-columns: repeat(2, 1fr);
    }

    .plans-grid {
        grid-template-columns: repeat(2, 1fr);
    }

    .ownership-grid {
        grid-template-columns: repeat(2, 1fr);
    }

    .footer-content {
        grid-template-columns: 1fr 1fr;
        gap: 30px;
    }

    .portfolio-grid {
        grid-template-columns: repeat(2, 1fr);
    }

    .contact-grid {
        grid-template-columns: 1fr;
        gap: 30px;
    }
}

/* MOBILE - below 768px */
@media (max-width: 768px) {

    /* NAVBAR */
    .navbar {
        padding: 0px 20px;
        height: 70px;
        position: relative;
    }

    .nav-logo {
        height: 55px;
        margin-top: -10px;
    }

    .nav-tagline {
        font-size: 0.5rem;
        letter-spacing: 1px;
        margin-top: -8px;
    }

    .nav-links {
        display: none;
        flex-direction: column;
        position: absolute;
        top: 70px;
        left: 0;
        width: 100%;
        background: rgba(10, 46, 46, 0.98);
        padding: 20px;
        gap: 20px;
        z-index: 999;
    }

    .nav-links.open {
        display: flex;
    }

    .hamburger {
        display: flex;
        flex-direction: column;
        gap: 5px;
        cursor: pointer;
        z-index: 1001;
    }

    .hamburger span {
        display: block;
        width: 25px;
        height: 2px;
        background: #ffffff;
        transition: all 0.3s ease;
    }

    /* HERO */
    .hero {
        padding: 100px 20px 50px;
        min-height: auto;
    }

    .hero-content h1 {
        font-size: 1.6rem;
        white-space: normal;
        line-height: 1.3;
    }

    .hero-sub {
        font-size: 0.7rem;
    }

    .hero-tagline {
        font-size: 0.85rem;
    }

    /* PAGE HEADER */
    .page-header {
        padding: 110px 20px 50px;
        text-align: center;
    }

    .page-header h1 {
        font-size: 2rem;
    }

    /* SECTIONS */
    section {
        padding: 40px 20px;
    }

    section h2 {
        font-size: 1.6rem;
    }

    /* CARDS */
    .cards-grid {
        grid-template-columns: 1fr;
    }

    .services-grid {
        grid-template-columns: 1fr;
    }

    .values-grid {
        grid-template-columns: 1fr;
    }

    .addons-grid {
        grid-template-columns: 1fr;
    }

    .bundles-grid {
        grid-template-columns: 1fr;
        max-width: 100%;
    }

    .plans-grid {
        grid-template-columns: 1fr !important;
        max-width: 100% !important;
    }

    .plan-card {
        width: 100%;
        box-sizing: border-box;
    }

    .ownership-grid {
        grid-template-columns: 1fr;
        max-width: 100%;
    }

    .portfolio-grid {
        grid-template-columns: 1fr;
    }

    /* CONTACT */
    .contact-grid {
        grid-template-columns: 1fr;
        gap: 30px;
    }

    .contact-form-wrapper {
        width: 100%;
        box-sizing: border-box;
        overflow: hidden;
    }

    .form-group input,
    .form-group select,
    .form-group textarea {
        width:100%;
        box-sizing: border-box;
    }

    /* FOOTER */
    .footer {
        padding: 40px 20px 20px;
    }

    .footer-content {
        grid-template-columns: 1fr;
        gap: 30px;
    }

    /* ENTRANCE PAGE MOBILE */
@media (max-width: 768px) {

    .entrance-page {
        padding: 20px;
    }

    .cities-img {
        width: 100%;
        max-width: 100%;
        top: 50%;
        mask-image: radial-gradient(ellipse at center, black 35%, transparent 65%);
        -webkit-mask-image: radial-gradient(ellipse at center, black 35%, transparent 65%);
    }

    .content {
        margin-top: -100px;
        margin-left: 0px;
        padding: 0 20px;
        text-align: center;
    }

    .logo {
        width: 280px;
    }

    .tagline {
        font-size: 0.85rem;
        letter-spacing: 1px;
        text-align: center;
        padding: 0 10px;
    }

    .get-started {
        font-size: 0.8rem;
        letter-spacing: 2px;
    }
}
}