/* =========================================================
   Switchly Apex — Mobile Responsive Patch
   Aggiungere questo <link> DOPO css/style.css in ogni pagina
   ========================================================= */

/* ── Reset base ── */
*, *::before, *::after { box-sizing: border-box; }
img, canvas { max-width: 100%; }

/* ── Navbar: hamburger mobile ── */
.mobile-menu-btn {
    display: none;
    background: none;
    border: none;
    cursor: pointer;
    padding: 8px;
    color: var(--text, #111);
    border-radius: 8px;
    transition: background .2s;
}
.mobile-menu-btn:hover { background: rgba(0,0,0,.06); }
.mobile-menu-btn i { width: 22px; height: 22px; }

/* ── Nav slide-in on mobile ── */
@media (max-width: 768px) {
    .mobile-menu-btn { display: flex; align-items: center; }

    .nav-links {
        position: fixed;
        top: 0; right: 0;
        width: min(320px, 88vw);
        height: 100dvh;
        background: rgba(255,255,255,.97);
        backdrop-filter: blur(24px);
        border-left: 1px solid rgba(0,0,0,.08);
        flex-direction: column;
        align-items: flex-start;
        justify-content: flex-start;
        padding: 100px 32px 40px;
        gap: 8px;
        transform: translateX(110%);
        transition: transform .35s cubic-bezier(.4,0,.2,1);
        z-index: 100;
        box-shadow: -20px 0 60px rgba(0,0,0,.12);
    }

    .nav-links.open { transform: translateX(0); }

    .nav-links a {
        width: 100%;
        padding: 14px 0;
        font-size: 18px;
        font-weight: 600;
        border-bottom: 1px solid rgba(0,0,0,.07);
        display: block;
    }

    .nav-links a:last-child { border-bottom: none; }

    /* Demo button in menu */
    .nav-links .btn.btn-primary {
        margin-top: 16px;
        width: 100%;
        text-align: center;
        border-radius: 12px;
    }

    /* Overlay */
    .nav-overlay {
        position: fixed;
        inset: 0;
        background: rgba(0,0,0,.35);
        z-index: 99;
        opacity: 0;
        pointer-events: none;
        transition: opacity .3s;
    }
    .nav-overlay.open { opacity: 1; pointer-events: all; }
}

/* ── Page header ── */
@media (max-width: 768px) {
    header[style*="padding: 180px"] {
        padding: 120px 0 50px !important;
    }

    header h1 {
        font-size: clamp(36px, 11vw, 60px) !important;
        letter-spacing: -1.5px !important;
        line-height: 1.05 !important;
    }

    header p {
        font-size: 16px !important;
    }
}

/* ── About: manifesto ── */
@media (max-width: 768px) {
    .manifesto-text {
        font-size: 18px !important;
        letter-spacing: -0.2px !important;
    }

    .manifesto-text p.muted {
        font-size: 16px !important;
    }

    section[style*="padding: 80px 0 140px"] {
        padding: 40px 0 80px !important;
    }
}

/* ── Architecture ── */
@media (max-width: 768px) {
    .arch-node {
        max-width: 100% !important;
        padding: 24px !important;
    }

    .arch-node h3 { font-size: 22px !important; }

    .agents-row {
        flex-direction: column !important;
        align-items: center !important;
        gap: 0 !important;
    }

    .agents-row .arch-node {
        width: 100% !important;
        max-width: 360px !important;
    }

    /* spacer between stacked agents */
    .agents-row .arch-link.mobile-link {
        display: block !important;
        height: 40px !important;
        background: rgba(15,23,42,.1) !important;
        width: 2px !important;
        margin: 0 auto !important;
    }

    .split-links { display: none !important; }

    section[style*="padding: 60px 0 140px"] {
        padding: 40px 0 80px !important;
    }
}

/* ── Mission grid ── */
@media (max-width: 768px) {
    .mission-grid {
        grid-template-columns: 1fr !important;
        gap: 16px !important;
    }

    .mission-card {
        padding: 28px 24px !important;
    }

    section[style*="padding: 40px 0 140px"] {
        padding: 20px 0 70px !important;
    }
}

/* ── Use cases ── */
@media (max-width: 768px) {
    .case-block,
    .case-block.reverse {
        grid-template-columns: 1fr !important;
        gap: 28px !important;
        margin-bottom: 70px !important;
    }

    /* Text always first on mobile */
    .case-block.reverse .case-visual { order: 2; }
    .case-block.reverse .case-text  { order: 1; }

    .case-text h2 {
        font-size: 28px !important;
        letter-spacing: -0.5px !important;
    }

    .case-text p { font-size: 16px !important; }

    .case-visual { padding: 28px 20px !important; }

    /* Terminal font sizing */
    .term-line { font-size: 12px !important; line-height: 1.7 !important; }

    /* Arch mini diagram: stack vertically */
    .arch-diagram-mini {
        flex-direction: column !important;
        gap: 12px !important;
        align-items: center !important;
    }

    .tunnel-line {
        width: 2px !important;
        height: 40px !important;
        margin: 0 0 0 0 !important;
        background: linear-gradient(to bottom, rgba(15,23,42,.1), var(--monarch, #8b5cf6), rgba(15,23,42,.1)) !important;
    }

    .tunnel-label {
        top: auto !important;
        left: auto !important;
        transform: none !important;
        position: relative !important;
        font-size: 9px !important;
        white-space: nowrap !important;
        text-align: center !important;
    }

    section[style*="padding: 60px 0"] {
        padding: 30px 0 !important;
    }
}

/* ── Footer ── */
@media (max-width: 768px) {
    .footer-container {
        flex-direction: column !important;
        gap: 8px !important;
        text-align: center !important;
    }
}

/* ── Generic container safety ── */
@media (max-width: 480px) {
    .container {
        width: calc(100% - 32px) !important;
    }
}
