/*
 * ╔══════════════════════════════════════════════════════════╗
 * ║   CUTTERZ BARBER — Mobile-First Responsive Layer         ║
 * ║   Cobre todas as páginas: pública + admin                ║
 * ║   Breakpoints: 480px · 600px · 768px · 900px            ║
 * ╚══════════════════════════════════════════════════════════╝
 */

/* ════════════════════════════════
   BASE MOBILE IMPROVEMENTS
════════════════════════════════ */

/* Touch feedback — pressed state visual */
@media (hover: none) {
    a:active, button:active, [role="button"]:active {
        opacity: 0.75;
        transition: opacity 0.08s ease;
    }
}

/* Smooth momentum scrolling em iOS */
html {
    -webkit-overflow-scrolling: touch;
}

/* Prevent text overflow global */
* {
    word-break: break-word;
}

/* ════════════════════════════════
   HEADER & NAV — MOBILE
════════════════════════════════ */
@media (max-width: 900px) {
    /* Hamburger visível */
    .nav-toggle {
        display: flex;
    }

    /* Menu mobile — drawer lateral */
    nav ul {
        position: fixed;
        top: 0; right: 0; bottom: 0;
        width: min(300px, 85vw);
        flex-direction: column;
        align-items: flex-start;
        background: var(--coal);
        border-left: var(--line);
        padding-top: calc(68px + env(safe-area-inset-top, 0px));
        padding-left: var(--sp-4);
        padding-right: calc(var(--sp-4) + env(safe-area-inset-right, 0px));
        padding-bottom: calc(var(--sp-6) + env(safe-area-inset-bottom, 0px));
        transform: translateX(110%);
        transition: transform 0.38s cubic-bezier(0.34, 1.56, 0.64, 1);
        z-index: 999;
        overflow-y: auto;
        height: 100dvh;
        max-height: 100dvh;
        gap: 4px;
        box-shadow: none;
    }

    nav ul.open {
        transform: translateX(0);
        box-shadow: -32px 0 80px rgba(0,0,0,0.75);
    }

    nav ul li {
        width: 100%;
    }

    nav ul li a {
        width: 100%;
        display: flex;
        align-items: center;
        gap: var(--sp-3);
        padding: 13px var(--sp-4);
        font-size: 0.95rem;
        font-weight: 500;
        color: var(--white-75);
        border-radius: var(--r);
        min-height: 48px;
        transition: var(--t-2);
    }

    nav ul li a:active {
        background: var(--violet-ghost);
        color: var(--violet-pale);
    }

    nav ul li a i {
        width: 20px;
        text-align: center;
        font-size: 0.9rem;
        opacity: 0.7;
        flex-shrink: 0;
    }

    /* Botões especiais no menu mobile */
    .btn-admin {
        background: linear-gradient(135deg, var(--violet), var(--violet-soft)) !important;
        color: var(--white) !important;
        padding: 12px var(--sp-4) !important;
        border-radius: var(--r-sm) !important;
        justify-content: center !important;
        margin-top: 4px;
    }

    .btn-logout-client {
        color: #fca5a5 !important;
        background: var(--danger-dim) !important;
        padding: 12px var(--sp-4) !important;
        border-radius: var(--r-sm) !important;
        margin-top: 4px;
    }

    .user-welcome {
        display: flex !important;
        align-items: center;
        gap: var(--sp-2);
        padding: 10px var(--sp-4);
        color: var(--violet-pale) !important;
        font-weight: 600;
        font-size: 0.9rem;
        min-height: 44px;
    }

    /* Separador visual no menu */
    nav ul li:nth-last-child(3) {
        margin-top: var(--sp-4);
        padding-top: var(--sp-4);
        border-top: var(--line);
    }
}

@media (max-width: 480px) {
    nav {
        padding: var(--sp-3) 0;
    }

    .logo {
        font-size: 1.45rem;
    }
}

/* ════════════════════════════════
   HERO — MOBILE
════════════════════════════════ */
@media (max-width: 768px) {
    .hero {
        min-height: 90dvh;
        align-items: flex-end;
        padding-bottom: var(--sp-9);
    }

    .hero .container {
        text-align: left;
        padding-top: var(--sp-8);
        padding-bottom: var(--sp-7);
    }

    .hero-eyebrow {
        font-size: 0.62rem;
        letter-spacing: 0.22em;
    }

    .hero h1 {
        font-size: clamp(2.4rem, 12vw, 4.5rem);
        margin-bottom: var(--sp-5);
    }

    .hero > .container > p,
    .hero p {
        font-size: 0.95rem;
        max-width: 100%;
    }

    .hero-buttons {
        flex-direction: column;
        gap: var(--sp-3);
        align-items: flex-start;
    }

    .hero-buttons .btn-primary,
    .hero-buttons .btn-secondary,
    .hero-buttons a {
        width: 100%;
        justify-content: center;
        min-height: 52px;
        font-size: 0.95rem;
    }
}

@media (max-width: 480px) {
    .hero {
        min-height: 85dvh;
    }

    .hero h1 {
        font-size: clamp(2rem, 13vw, 3.5rem);
        line-height: 1.0;
    }

    .hero-scroll-hint {
        display: none;
    }
}

/* ════════════════════════════════
   SEÇÕES GERAIS — MOBILE
════════════════════════════════ */
@media (max-width: 768px) {
    section {
        padding: var(--sp-8) 0;
    }

    .section-title {
        margin-bottom: var(--sp-6);
    }

    .section-title h2 {
        font-size: clamp(1.8rem, 7vw, 3rem);
    }
}

@media (max-width: 480px) {
    section {
        padding: var(--sp-7) 0;
    }
}

/* ════════════════════════════════
   BARBEIROS GRID — MOBILE
════════════════════════════════ */
@media (max-width: 768px) {
    .barbeiros-grid {
        grid-template-columns: 1fr;
        gap: var(--sp-5);
        max-width: 420px;
        margin: 0 auto;
    }
}

@media (max-width: 480px) {
    .barbeiros-grid {
        max-width: 100%;
    }

    .barbeiro-card {
        border-radius: var(--r-lg);
    }

    .barbeiro-info {
        padding: var(--sp-4);
    }
}

/* ════════════════════════════════
   SERVIÇOS — MOBILE
════════════════════════════════ */
@media (max-width: 640px) {
    .servicos-grid {
        grid-template-columns: 1fr 1fr;
        gap: var(--sp-3);
    }

    .servico-card {
        padding: var(--sp-4) var(--sp-3);
    }

    .servico-icon {
        font-size: 1.6rem;
        margin-bottom: var(--sp-3);
    }

    .servico-card h3 {
        font-size: 0.88rem;
    }

    .servico-card > p {
        font-size: 0.78rem;
    }
}

@media (max-width: 360px) {
    .servicos-grid {
        grid-template-columns: 1fr;
    }
}

/* ════════════════════════════════
   ABOUT SECTION — MOBILE
════════════════════════════════ */
@media (max-width: 900px) {
    .about-content {
        grid-template-columns: 1fr;
        gap: var(--sp-6);
    }

    .about-image {
        order: -1;
        max-height: 320px;
        border-radius: var(--r-lg);
    }
}

@media (max-width: 480px) {
    .about-image {
        max-height: 260px;
    }

    .about-text h2 {
        font-size: clamp(1.7rem, 8vw, 2.5rem);
    }

    .about-features {
        grid-template-columns: 1fr 1fr;
    }

    .feature-item {
        padding: var(--sp-4) var(--sp-3);
    }

    .feature-item h4 {
        font-size: 0.82rem;
    }

    .feature-item p {
        font-size: 0.75rem;
    }
}

@media (max-width: 360px) {
    .about-features {
        grid-template-columns: 1fr;
    }
}

/* ════════════════════════════════
   BOOKING / AGENDAMENTO — MOBILE
════════════════════════════════ */
@media (max-width: 900px) {
    .booking-grid {
        grid-template-columns: 1fr;
    }

    .booking-info {
        order: -1;
    }

    .booking-info-item {
        padding: var(--sp-3) var(--sp-4);
    }
}

@media (max-width: 480px) {
    .booking-form {
        padding: var(--sp-5);
        border-radius: var(--r-lg);
    }

    .booking-form h3 {
        font-size: 1.1rem;
    }

    .form-row {
        grid-template-columns: 1fr;
    }

    .form-group input,
    .form-group select,
    .form-group textarea {
        padding: 13px var(--sp-4);
        font-size: 16px; /* Previne zoom iOS */
    }

    .btn-submit {
        min-height: 52px;
        font-size: 0.95rem;
    }

    .booking-info h3 {
        font-size: 1.2rem;
    }
}

/* ════════════════════════════════
   GALERIA — MOBILE
════════════════════════════════ */
@media (max-width: 640px) {
    .galeria-grid {
        grid-template-columns: repeat(2, 1fr);
        gap: 10px;
    }

    .galeria-filters {
        flex-wrap: wrap;
        gap: var(--sp-2);
        justify-content: center;
    }

    .galeria-filters button {
        font-size: 0.78rem;
        padding: 8px 14px;
    }
}

@media (max-width: 380px) {
    .galeria-grid {
        grid-template-columns: 1fr;
    }
}

/* ════════════════════════════════
   FOOTER — MOBILE
════════════════════════════════ */
@media (max-width: 768px) {
    .footer-content {
        grid-template-columns: 1fr 1fr;
        gap: var(--sp-6);
    }

    .footer-brand {
        grid-column: 1 / -1;
    }
}

@media (max-width: 480px) {
    .footer-content {
        grid-template-columns: 1fr;
        gap: var(--sp-5);
    }

    .footer-bottom {
        flex-direction: column;
        text-align: center;
        gap: var(--sp-3);
    }
}

/* ════════════════════════════════
   LOGIN PAGE — MOBILE
════════════════════════════════ */
@media (max-width: 900px) {
    .login-wrapper,
    .signup-wrapper {
        grid-template-columns: 1fr;
        gap: var(--sp-6);
        max-width: 480px;
        margin: 0 auto;
    }

    .login-content,
    .signup-content {
        display: none; /* Esconde conteúdo lateral em mobile */
    }
}

@media (max-width: 480px) {
    .login-page,
    .signup-page {
        padding: var(--sp-5) var(--sp-4);
        min-height: 100dvh;
        align-items: flex-start;
        padding-top: var(--sp-7);
    }

    .login-box,
    .signup-box {
        padding: var(--sp-5);
        border-radius: var(--r-lg);
    }

    .login-box h2,
    .signup-box h2 {
        font-size: 1.6rem;
    }

    .form-group input {
        padding: 13px var(--sp-4);
        font-size: 16px;
    }

    .btn-submit {
        padding: 15px;
        font-size: 1rem;
        min-height: 52px;
    }

    .form-row {
        grid-template-columns: 1fr;
    }
}

/* ════════════════════════════════
   PERFIL PAGE — MOBILE
════════════════════════════════ */
@media (max-width: 768px) {
    .profile-container {
        padding: var(--sp-5) 0 var(--sp-8);
    }

    .profile-header {
        padding: var(--sp-5);
        border-radius: var(--r-lg);
    }

    .profile-grid {
        grid-template-columns: 1fr;
        gap: var(--sp-4);
    }

    .profile-header h1 {
        font-size: 1.4rem;
    }
}

@media (max-width: 480px) {
    .profile-header {
        padding: var(--sp-4);
    }

    .profile-field input,
    .profile-field select {
        padding: 13px var(--sp-4);
        font-size: 16px;
    }

    .profile-actions {
        flex-direction: column;
        gap: var(--sp-3);
    }

    .profile-actions button,
    .profile-actions .btn-save,
    .profile-actions .btn-cancel {
        width: 100%;
        justify-content: center;
        min-height: 48px;
    }

    .appointment-card {
        border-radius: var(--r-lg);
        padding: var(--sp-4);
    }

    .appointment-details {
        grid-template-columns: 1fr 1fr;
    }

    .appointment-actions {
        flex-direction: column;
        gap: var(--sp-2);
    }

    .appointment-actions > *,
    .btn-reschedule,
    .btn-cancel-appointment {
        width: 100%;
        justify-content: center;
    }
}

@media (max-width: 360px) {
    .appointment-details {
        grid-template-columns: 1fr;
    }
}

/* ════════════════════════════════
   ESQUECI SENHA — MOBILE
════════════════════════════════ */
@media (max-width: 480px) {
    .forgot-wrapper,
    .reset-wrapper {
        padding: var(--sp-5);
        border-radius: var(--r-lg);
    }

    .forgot-wrapper h2,
    .reset-wrapper h2 {
        font-size: 1.5rem;
    }
}

/* ════════════════════════════════
   ADMIN HEADER — MOBILE
════════════════════════════════ */
@media (max-width: 768px) {
    .admin-header .container {
        gap: var(--sp-3);
        flex-wrap: nowrap;
        padding: 0 var(--sp-4);
    }

    .admin-title {
        font-size: 1rem;
    }

    .btn-logout {
        padding: 8px var(--sp-3);
        font-size: 0.78rem;
    }
}

@media (max-width: 480px) {
    .admin-header {
        padding: var(--sp-2) 0;
    }

    .admin-title {
        font-size: 0.9rem;
    }

    /* Esconde texto do logout, mantém ícone */
    .btn-logout span {
        display: none;
    }
}

/* ════════════════════════════════
   ADMIN INDEX — DASHBOARD MOBILE
════════════════════════════════ */
@media (max-width: 900px) {
    .dash-header {
        flex-direction: column;
        gap: var(--sp-4);
        align-items: flex-start;
    }

    .dash-header-left h1 {
        font-size: clamp(1.4rem, 5vw, 2rem);
    }

    .stats-grid {
        grid-template-columns: 1fr 1fr;
        gap: var(--sp-3);
    }
}

@media (max-width: 600px) {
    .admin-main {
        padding: var(--sp-5) 0 var(--sp-8);
    }

    .dash-header {
        margin-bottom: var(--sp-5);
    }

    .dash-header-left h1 {
        font-size: 1.4rem;
    }

    .quick-actions {
        width: 100%;
    }

    .quick-actions a {
        flex: 1;
        justify-content: center;
        font-size: 0.78rem;
        padding: 9px var(--sp-3);
    }

    /* Abas admin — scroll horizontal */
    .admin-nav {
        margin-bottom: var(--sp-5);
        gap: 0;
        padding-bottom: 2px;
    }

    .admin-nav button {
        font-size: 0.8rem;
        padding: var(--sp-3) var(--sp-4);
        gap: var(--sp-2);
        flex-shrink: 0;
    }

    .tab-badge {
        font-size: 0.6rem;
        min-width: 16px;
        height: 16px;
    }

    /* Stats grid */
    .stats-grid {
        grid-template-columns: 1fr 1fr;
        gap: var(--sp-3);
        margin-bottom: var(--sp-5);
    }

    .stat-card {
        padding: var(--sp-4);
    }

    .stat-number {
        font-size: 1.8rem;
    }

    .stat-card .stat-label {
        font-size: 0.62rem;
    }

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

    /* Seção inner header */
    .section-inner-header {
        flex-direction: column;
        align-items: flex-start;
        gap: var(--sp-3);
        margin-bottom: var(--sp-4);
    }
}

@media (max-width: 420px) {
    .stats-grid {
        grid-template-columns: 1fr;
    }

    .quick-actions {
        flex-direction: column;
    }

    .quick-actions a {
        width: 100%;
    }
}

/* ════════════════════════════════
   ADMIN TABLE — MOBILE SCROLL
════════════════════════════════ */
@media (max-width: 768px) {
    .table-wrap {
        border-radius: var(--r);
        margin: 0 -4px; /* Permite tabela chegar na borda */
    }

    .admin-table {
        font-size: 0.82rem;
        min-width: 600px;
    }

    .admin-table th {
        padding: var(--sp-3) var(--sp-4);
        font-size: 0.62rem;
    }

    .admin-table td {
        padding: var(--sp-3) var(--sp-4);
    }

    .action-buttons {
        gap: 6px;
        flex-wrap: nowrap;
    }

    .btn-action {
        padding: 6px 10px;
        font-size: 0.72rem;
    }
}

/* ════════════════════════════════
   ADMIN — GALERIA MOBILE
════════════════════════════════ */
@media (max-width: 600px) {
    .galeria-grid {
        grid-template-columns: repeat(2, 1fr);
        gap: var(--sp-3);
    }

    .galeria-upload-card,
    .galeria-fotos-card {
        padding: var(--sp-4);
    }
}

@media (max-width: 360px) {
    .galeria-grid {
        grid-template-columns: 1fr;
    }
}

/* ════════════════════════════════
   ADMIN — MODAIS MOBILE
════════════════════════════════ */
@media (max-width: 580px) {
    /* Modal de vendas — body em coluna */
    .vendas-body {
        flex-direction: column;
        overflow-y: auto;
    }

    .vendas-produtos {
        border-right: none;
        border-bottom: var(--line);
        max-height: 45vh;
        overflow-y: auto;
    }

    .vendas-carrinho {
        width: 100%;
        border-right: none;
        border-left: none;
        max-height: none;
        min-height: 200px;
    }

    .vendas-modal {
        border-radius: var(--r-lg);
        max-height: 95dvh;
    }

    .vendas-header {
        padding: 14px 18px;
    }

    .vendas-header h3 {
        font-size: 0.9rem;
    }
}

@media (max-width: 420px) {
    .vendas-footer {
        flex-direction: column;
        gap: var(--sp-2);
    }

    .btn-finalizar-venda,
    .btn-limpar-venda {
        width: 100%;
        justify-content: center;
    }

    /* Modal calendário */
    .cal-modal {
        border-radius: var(--r-lg);
    }

    .cal-nav {
        padding: 12px 16px 8px;
    }

    .cal-grid {
        padding: 0 14px 12px;
    }

    .cal-day {
        font-size: 0.7rem;
    }

    /* Modal encaixe */
    .enc-modal {
        border-radius: var(--r-lg);
        max-height: 96dvh;
    }

    .enc-footer {
        flex-direction: column;
    }

    .btn-encaixar {
        justify-content: center;
    }

    .enc-form-row {
        flex-direction: column;
    }

    .nc-body {
        padding: var(--sp-4);
    }
}

/* Cal trigger — posição safe area */
@media (max-width: 480px) {
    .cal-trigger {
        bottom: calc(20px + env(safe-area-inset-bottom, 0px));
        right: 20px;
        width: 48px;
        height: 48px;
        font-size: 1.1rem;
    }
}

/* ════════════════════════════════
   ADMIN — AGENDAR PAGE MOBILE
════════════════════════════════ */
@media (max-width: 768px) {
    /* Calendário de agendamento admin */
    .booking-calendar-wrapper {
        border-radius: var(--r-lg);
    }
}

@media (max-width: 600px) {
    .booking-calendar-wrapper {
        overflow-x: auto;
        -webkit-overflow-scrolling: touch;
    }

    .calendar-header {
        padding: var(--sp-3) var(--sp-4);
        flex-wrap: wrap;
        gap: var(--sp-2);
    }

    .calendar-header h2 {
        font-size: 1rem;
    }
}

/* ════════════════════════════════
   ADMIN — ESTOQUE MOBILE
════════════════════════════════ */
@media (max-width: 768px) {
    .estoque-header {
        flex-direction: column;
        gap: var(--sp-4);
        align-items: flex-start;
    }

    .estoque-actions {
        width: 100%;
        justify-content: flex-start;
    }

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

@media (max-width: 480px) {
    .estoque-card {
        padding: var(--sp-4);
    }

    .estoque-actions button {
        width: 100%;
        justify-content: center;
    }

    .modal-estoque-body {
        padding: var(--sp-4);
    }
}

/* ════════════════════════════════
   ADMIN — BLOQUEAR HORÁRIOS MOBILE
════════════════════════════════ */
@media (max-width: 768px) {
    .bloqueio-grid {
        grid-template-columns: 1fr;
    }

    .bloqueio-form-card {
        padding: var(--sp-4);
    }
}

/* ════════════════════════════════
   ADMIN — CHECKOUT MOBILE
════════════════════════════════ */
@media (max-width: 768px) {
    .checkout-wrapper {
        flex-direction: column;
    }

    .checkout-sidebar {
        width: 100%;
        border-left: none;
        border-top: var(--line);
    }
}

@media (max-width: 480px) {
    .checkout-form {
        padding: var(--sp-4);
    }

    .payment-methods {
        flex-direction: column;
        gap: var(--sp-2);
    }

    .payment-method-btn {
        width: 100%;
        justify-content: center;
    }
}

/* ════════════════════════════════
   BOOKING CALENDAR (CLIENTE) MOBILE
════════════════════════════════ */
@media (max-width: 768px) {
    .booking-calendar {
        border-radius: var(--r-lg);
    }

    .bc-header {
        padding: var(--sp-3) var(--sp-4);
    }

    .bc-days {
        grid-template-columns: repeat(7, 1fr);
    }

    .bc-day {
        min-height: 42px;
        font-size: 0.78rem;
    }
}

@media (max-width: 480px) {
    .bc-header {
        flex-wrap: wrap;
        gap: var(--sp-2);
    }

    .bc-title {
        font-size: 0.88rem;
    }

    .bc-day {
        min-height: 38px;
        font-size: 0.72rem;
    }

    .bc-weekday {
        font-size: 0.58rem;
    }

    .time-slots-grid {
        grid-template-columns: repeat(3, 1fr);
        gap: var(--sp-2);
    }

    .time-slot {
        padding: 10px var(--sp-2);
        font-size: 0.82rem;
        min-height: 44px;
    }
}

@media (max-width: 360px) {
    .time-slots-grid {
        grid-template-columns: repeat(2, 1fr);
    }
}

/* ════════════════════════════════
   NOTIFICAÇÕES — MOBILE
════════════════════════════════ */
@media (max-width: 480px) {
    .notification-panel {
        width: calc(100vw - 32px) !important;
        right: -8px !important;
        max-height: 80dvh;
    }

    .notification-item {
        padding: var(--sp-3) var(--sp-4);
        font-size: 0.82rem;
    }
}

/* ════════════════════════════════
   UTILITIES MOBILE
════════════════════════════════ */
@media (max-width: 480px) {
    /* Stack horizontais em vertical */
    .flex-mobile-col {
        flex-direction: column !important;
    }

    /* Full width em mobile */
    .full-mobile {
        width: 100% !important;
    }
}

/* ════════════════════════════════
   STATUS BADGES — MOBILE
════════════════════════════════ */
@media (max-width: 480px) {
    .status-badge {
        font-size: 0.62rem;
        padding: 3px 8px;
    }

    .badge-method {
        font-size: 0.62rem;
    }
}

/* ════════════════════════════════
   INFO CARD — MOBILE
════════════════════════════════ */
@media (max-width: 480px) {
    .info-card {
        padding: var(--sp-7) var(--sp-4);
        border-radius: var(--r-lg);
    }

    .info-card i {
        font-size: 2rem;
    }

    .info-card h3 {
        font-size: 1rem;
    }

    .info-card p {
        font-size: 0.82rem;
    }
}

/* ════════════════════════════════
   GALERIA MODAL — MOBILE
════════════════════════════════ */
@media (max-width: 480px) {
    .galeria-modal,
    .servicos-modal {
        padding: 20px 12px;
    }

    .galeria-modal-close,
    .servicos-modal-close {
        top: 12px;
        right: 12px;
        width: 40px;
        height: 40px;
    }

    .lightbox-inner img {
        max-height: 50vh;
        border-radius: var(--r);
    }
}

/* ════════════════════════════════
   SAFE AREA — IPHONE NOTCH
════════════════════════════════ */
@supports (padding: max(0px)) {
    .cal-trigger {
        bottom: max(20px, calc(env(safe-area-inset-bottom, 0px) + 12px));
        right: max(20px, env(safe-area-inset-right, 0px));
    }
}

/* ════════════════════════════════
   TOUCH IMPROVEMENTS
════════════════════════════════ */

/* Tap highlight removal em elementos interativos */
a, button, input, select, textarea, [role="button"] {
    -webkit-tap-highlight-color: rgba(109, 40, 217, 0.15);
}

/* Garante que selects, inputs não sofrem zoom no iOS */
@media (max-width: 768px) {
    input[type="text"],
    input[type="email"],
    input[type="password"],
    input[type="tel"],
    input[type="number"],
    input[type="date"],
    input[type="time"],
    select,
    textarea {
        font-size: 16px !important;
        -webkit-text-size-adjust: 100%;
    }
}

/* ════════════════════════════════
   PRINT — mantido
════════════════════════════════ */
@media print {
    .cal-trigger,
    .nav-toggle,
    .nav-overlay,
    .btn-logout,
    .quick-actions {
        display: none !important;
    }
}
