/* =========================
   CLINICASUITE – MOBILE (FIX21)
   Design EXCLUSIVO para mobile:
   Appbar + Drawer + Bottom Nav + Action Sheet
========================= */

:root{
  --m-appbar-h: 58px;
  --m-bottomnav-h: 70px;
  --m-radius: 18px;
  --safe-top: env(safe-area-inset-top, 0px);
  --safe-bottom: env(safe-area-inset-bottom, 0px);
}

@media (max-width: 768px){

  /* Reserve espaço para appbar e bottom nav */
  body{
    padding-top: calc(var(--m-appbar-h) + var(--safe-top) + var(--m-chipbar-h, 0px));
    padding-bottom: calc(var(--m-bottomnav-h) + var(--safe-bottom) + 48px);
    -webkit-tap-highlight-color: transparent;
  }

  body.m-lock{
    overflow: hidden;
    touch-action: none;
  }

  /* Desktop sidebar nunca no mobile */
  .sidebar{ display:none !important; }

  /* Conteúdo ocupa tudo */
  .layout{ display:block; min-height: 100vh; }
  .content{ width:100%; margin:0; height:auto !important; min-height:0 !important; overflow:visible !important; }

  /* Container mais “app” */
  .container-fluid.page{
    padding-left: 14px !important;
    padding-right: 14px !important;
    padding-top: 10px !important;
     padding-bottom: calc(var(--m-bottomnav-h) + var(--safe-bottom) + 56px) !important;
  }

  /* Títulos mais compactos (o título principal fica na appbar) */
  .page-title{
    padding: 6px 0 10px 0 !important;
    margin-bottom: 10px !important;
    border-bottom: 1px solid rgba(15,23,42,.08);
  }
  .page-title h1{ font-size: 18px !important; margin:0 !important; }
  .page-title .text-muted{ font-size: 12px !important; }

  /* Appbar */
  .m-appbar{
    position: fixed;
    top: 0; left: 0; right: 0;
    height: calc(var(--m-appbar-h) + var(--safe-top));
    display:flex;
    align-items:center;
    justify-content:space-between;
    gap: 10px;
    padding: calc(10px + var(--safe-top)) 12px 10px 12px;
    background: rgba(255,255,255,.86);
    backdrop-filter: blur(14px);
    -webkit-backdrop-filter: blur(14px);
    border-bottom: 1px solid rgba(15,23,42,.08);
    z-index: 1200;
  }

  .m-iconbtn{
    width: 44px; height: 44px;
    display:grid; place-items:center;
    border-radius: 999px;
    border: 1px solid rgba(15,23,42,.14);
    background: #fff;
    box-shadow: 0 10px 24px rgba(15,23,42,.08);
  }
  .m-iconbtn i{ font-size: 18px; }
  /* Appbar icon colors */
  .m-backbtn, .m-backbtn i{ color: var(--primary) !important; }
  .m-menubtn, .m-menubtn i{ color: var(--primary) !important; }



  /* Back button control (mobile): só em telas de detalhe/edição */
  .m-backbtn{ display:none; }
  .m-backbtn.is-visible{ display:grid; }
  .m-menubtn.is-hidden{ display:none; }
  .m-appbar__title{
    flex: 1;
    min-width: 0;
    display:flex;
    flex-direction:column;
    line-height: 1.05;
  }
  .m-appbar__kicker{
    font-size: 12px;
    color: rgba(15,23,42,.55);
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
  }
  .m-appbar__page{
    font-size: 15px;
    font-weight: 800;
    color: #0f172a;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
  }

  .m-fab-mini{
    width: 46px; height: 46px;
    border: none;
    border-radius: 16px;
    background: linear-gradient(135deg, rgba(255,79,160,1), rgba(255,119,183,1));
    box-shadow: 0 16px 32px rgba(255,79,160,.28);
    color: #fff;
    display:grid; place-items:center;
  }
  .m-fab-mini i{ font-size: 18px; }

  /* Chips (filtros rápidos) */
  .m-chipbar-wrap{
    position: sticky;
    top: calc(var(--m-appbar-h) + var(--safe-top));
    z-index: 1100;
    margin: 8px 0 6px 0;
    padding: 0 2px;
  }

  /* Chipbar fix: em iOS sticky falha se algum pai tem overflow/transform.
     Então usamos modo fixed quando o JS detectar a chipbar. */
  .m-chipbar-wrap.is-fixed{
    position: fixed !important;
    left: 12px;
    right: 12px;
    top: calc(var(--m-appbar-h) + var(--safe-top) + 8px);
    margin: 0 !important;
    padding: 0 !important;
    z-index: 1190;
  }
  .m-chipbar{
    display:flex;
    gap: 8px;
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
    padding: 6px 6px;
    border-radius: 16px;
    background: rgba(255,255,255,.78);
    backdrop-filter: blur(12px);
    -webkit-backdrop-filter: blur(12px);
    border: 1px solid rgba(15,23,42,.08);
    box-shadow: 0 10px 26px rgba(15,23,42,.06);
  }
  .m-chipbar::-webkit-scrollbar{ display:none; }
  .m-chip{
    display:inline-flex;
    align-items:center;
    gap: 8px;
    height: 38px;
    padding: 0 12px;
    border-radius: 999px;
    border: 1px solid rgba(15,23,42,.12);
    background: #fff;
    color: rgba(15,23,42,.78);
    font-weight: 700;
    font-size: 13px;
    white-space: nowrap;
    text-decoration: none;
  }
  .m-chip i{ font-size: 15px; }
  .m-chip.is-active{
    border-color: rgba(255,79,160,.35);
    background: rgba(255,79,160,.10);
    color: rgba(255,79,160,1);
  }

  /* FAB contextual (ação rápida) */
  .m-fab{
    position: fixed;
    right: 14px;
    bottom: calc(var(--m-bottomnav-h) + var(--safe-bottom) + 14px);
    z-index: 1250;
    height: 56px;
    padding: 0 16px;
    border-radius: 20px;
    border: 0;
    background: linear-gradient(135deg, rgba(255,79,160,1), rgba(255,119,183,1));
    color: #fff;
    display:inline-flex;
    align-items:center;
    gap: 10px;
    text-decoration: none;
    box-shadow: 0 18px 44px rgba(255,79,160,.30);
  }
  .m-fab i{ font-size: 18px; }
  .m-fab span{ font-weight: 900; letter-spacing: -.02em; }
  .m-fab:active{ transform: translateY(1px); }

  /* Toasts no mobile: centraliza e evita sobrepor appbar */
  .toast-stack{
    left: 50%;
    right: auto;
    transform: translateX(-50%);
    top: calc(var(--m-appbar-h) + var(--safe-top) + 10px);
    max-width: min(520px, calc(100vw - 20px));
  }

  /* Empty states (mobile) */
  .m-empty{
    margin: 14px 0;
    padding: 18px 16px;
    border-radius: 20px;
    border: 1px solid rgba(15,23,42,.08);
    background: #fff;
    box-shadow: 0 16px 36px rgba(2,6,23,.06);
    text-align: center;
  }
  .m-empty__icon{
    width: 52px; height: 52px;
    margin: 0 auto 10px auto;
    border-radius: 18px;
    background: rgba(255,79,160,.10);
    color: rgba(255,79,160,1);
    display:grid; place-items:center;
  }
  .m-empty__icon i{ font-size: 22px; }
  .m-empty__title{ font-weight: 900; font-size: 16px; }
  .m-empty__text{ color: rgba(15,23,42,.62); font-size: 13px; margin-top: 4px; }
  .m-empty__cta{
    margin-top: 12px;
    display:inline-flex;
    align-items:center;
    justify-content:center;
    gap: 8px;
    height: 44px;
    padding: 0 14px;
    border-radius: 14px;
    background: rgba(255,79,160,1);
    color:#fff;
    text-decoration:none;
    font-weight: 800;
    box-shadow: 0 12px 26px rgba(255,79,160,.22);
  }
  .m-empty__cta i{ font-size: 16px; }

  /* Drawer */
  .m-drawer{
    position: fixed;
    inset: 0;
    z-index: 1400;
    pointer-events: none;
  }
  .m-drawer__backdrop{
    position:absolute;
    inset:0;
    border:none;
    background: rgba(15,23,42,.48);
    opacity:0;
    transition: opacity .18s ease;
  }
  .m-drawer__panel{
    position:absolute;
    top: 0; bottom: 0; left: 0;
    width: min(86vw, 340px);
    background: #fff;
    transform: translateX(-102%);
    transition: transform .22s ease;
    border-top-right-radius: 22px;
    border-bottom-right-radius: 22px;
    box-shadow: 24px 0 48px rgba(15,23,42,.18);
    display:flex;
    flex-direction:column;
    overflow:hidden;
  }
  .m-drawer.is-open{ pointer-events:auto; }
  .m-drawer.is-open .m-drawer__backdrop{ opacity:1; }
  .m-drawer.is-open .m-drawer__panel{ transform: translateX(0); }

  .m-drawer__brand{
    display:flex;
    align-items:center;
    gap: 10px;
    padding: 14px 14px 12px 14px;
    border-bottom: 1px solid rgba(15,23,42,.08);
  }
  .m-drawer__logo{
    width: 44px; height: 44px;
    border-radius: 16px;
    border: 1px solid rgba(15,23,42,.10);
    background: rgba(255,79,160,.08);
    display:grid; place-items:center;
    overflow:hidden;
  }
  .m-drawer__logo img{
    width: 28px; height: 28px;
    object-fit: contain;
    display:block;
  }
  .m-drawer__brandtext{ flex:1; min-width:0; }
  .m-drawer__name{
    font-weight: 900;
    font-size: 14px;
    white-space: nowrap;
    overflow:hidden;
    text-overflow: ellipsis;
  }
  .m-drawer__sub{
    font-size: 12px;
    color: rgba(15,23,42,.55);
    white-space: nowrap;
    overflow:hidden;
    text-overflow: ellipsis;
  }
  .m-drawer__close{
    width: 40px; height: 40px;
    border-radius: 14px;
    box-shadow:none;
  }

  .m-drawer__links{
    padding: 10px;
    overflow:auto;
  }
  .m-drawer__links a{
    display:flex;
    align-items:center;
    gap: 12px;
    padding: 12px 12px;
    border-radius: 16px;
    color: rgba(15,23,42,.86);
    text-decoration:none;
    border: 1px solid rgba(15,23,42,.06);
    background: rgba(255,255,255,.8);
    margin-bottom: 10px;
  }
  .m-drawer__links a i{ font-size: 18px; width: 20px; text-align:center; }
  .m-drawer__links a.active{
    background: rgba(255,79,160,.10);
    border-color: rgba(255,79,160,.28);
    color: #0f172a;
  }

  .m-drawer__footer{
    margin-top:auto;
    padding: 12px;
    border-top: 1px solid rgba(15,23,42,.08);
    display:flex;
    gap: 10px;
    align-items:center;
    justify-content:space-between;
  }
  .m-drawer__user{
    display:flex;
    align-items:center;
    gap: 10px;
    min-width: 0;
  }
  .m-avatar{
    width: 38px; height: 38px;
    border-radius: 14px;
    display:grid; place-items:center;
    background: rgba(15,23,42,.06);
    font-weight: 900;
  }
  .m-drawer__usertext{ min-width:0; }
  .m-drawer__uname{
    font-weight: 800;
    font-size: 13px;
    white-space:nowrap;
    overflow:hidden;
    text-overflow: ellipsis;
  }
  .m-drawer__urole{
    font-size: 11px;
    color: rgba(15,23,42,.55);
  }
  .m-logout{
    display:flex;
    align-items:center;
    gap: 8px;
    padding: 10px 12px;
    border-radius: 14px;
    border: 1px solid rgba(15,23,42,.10);
    text-decoration:none;
    color: rgba(15,23,42,.86);
    background:#fff;
  }

  /* Bottom nav */
  .mobile-nav{
    position: fixed;
    left: 10px;
    right: 10px;
    bottom: calc(10px + var(--safe-bottom));
    height: calc(var(--m-bottomnav-h) + var(--safe-bottom));
    display:flex;
    justify-content:space-between;
    align-items:center;
    gap: 6px;
    padding: 10px 10px calc(10px + var(--safe-bottom)) 10px;
    border-radius: 24px;
    background: rgba(255,255,255,.92);
    backdrop-filter: blur(16px);
    -webkit-backdrop-filter: blur(16px);
    border: 1px solid rgba(15,23,42,.08);
    box-shadow: 0 18px 50px rgba(15,23,42,.14);
    z-index: 1300;
  }
  .mobile-nav a{
    flex:1;
    min-width: 0;
    text-decoration:none;
    color: rgba(15,23,42,.58);
    display:flex;
    flex-direction:column;
    align-items:center;
    justify-content:center;
    gap: 5px;
    padding: 8px 6px;
    border-radius: 18px;
  }
  .mobile-nav a i{ font-size: 18px; }
  .mobile-nav a span{ font-size: 11px; font-weight: 700; white-space:nowrap; overflow:hidden; text-overflow: ellipsis; }
  /* Garantir que botões no final não fiquem atrás da bottom nav */
  .content > *:last-child{ margin-bottom: 24px; }

  .mobile-nav a.active{
    color: rgba(255,79,160,1);
    background: rgba(255,79,160,.10);
  }

  /* Action sheet */
  .m-sheet{
    position: fixed;
    inset: 0;
    z-index: 1500;
    pointer-events:none;
  }
  .m-sheet__backdrop{
    position:absolute;
    inset:0;
    border:none;
    background: rgba(15,23,42,.42);
    opacity:0;
    transition: opacity .18s ease;
  }
  .m-sheet__panel{
    position:absolute;
    left: 0; right: 0; bottom: 0;
    background:#fff;
    border-top-left-radius: 24px;
    border-top-right-radius: 24px;
    padding: 10px 14px 14px 14px;
    transform: translateY(102%);
    transition: transform .22s ease;
    box-shadow: 0 -24px 60px rgba(15,23,42,.18);
  }
  .m-sheet.is-open{ pointer-events:auto; }
  .m-sheet.is-open .m-sheet__backdrop{ opacity:1; }
  .m-sheet.is-open .m-sheet__panel{ transform: translateY(0); }

  .m-sheet__handle{
    width: 44px; height: 5px;
    border-radius: 99px;
    background: rgba(15,23,42,.14);
    margin: 6px auto 10px auto;
  }
  .m-sheet__title{
    font-weight: 900;
    font-size: 14px;
    margin-bottom: 12px;
  }
  .m-sheet__grid{
    display:grid;
    grid-template-columns: 1fr 1fr;
    gap: 10px;
  }
  .m-sheet__item{
    display:flex;
    flex-direction:column;
    gap: 8px;
    padding: 14px 12px;
    border-radius: 18px;
    border: 1px solid rgba(15,23,42,.08);
    text-decoration:none;
    color: rgba(15,23,42,.86);
    background: rgba(15,23,42,.02);
  }
  .m-sheet__item i{ font-size: 18px; }
  .m-sheet__item span{ font-weight: 800; font-size: 12px; }
  .m-sheet__item.primary{
    color: #fff;
    border: none;
    background: linear-gradient(135deg, rgba(255,79,160,1), rgba(255,119,183,1));
    box-shadow: 0 14px 34px rgba(255,79,160,.24);
  }
  .m-sheet__close{
    width: 100%;
    margin-top: 12px;
    border: 1px solid rgba(15,23,42,.10);
    background: #fff;
    border-radius: 16px;
    padding: 12px 12px;
    font-weight: 800;
  }

  /* FullCalendar: toolbar quebra certo */
  .fc .fc-toolbar{
    flex-wrap: wrap !important;
    gap: 10px !important;
  }
  .fc .fc-toolbar-title{
    font-size: 16px !important;
    line-height: 1.2 !important;
    margin: 6px 0 !important;
  }
  .fc .fc-button{
    padding: 8px 10px !important;
    border-radius: 14px !important;
  }
}


/* =========================
   Per-page Action Sheet
========================= */
.m-sheet__item.is-hidden{display:none !important;}

/* =========================
   Mobile App Pages (cards instead of tables)
========================= */
@media (max-width: 767.98px){
  .page-title{display:none !important;}
  .table-card{display:none !important;}
  .m-cardlist{display:flex; flex-direction:column; gap:12px;}
  .m-itemcard{
    background: #fff;
    border: 1px solid rgba(15, 23, 42, .10);
    border-radius: 18px;
    padding: 14px;
    box-shadow: 0 8px 22px rgba(15,23,42,.06);
  }
  .m-itemcard__top{display:flex; align-items:flex-start; justify-content:space-between; gap:10px;}
  .m-itemcard__title{font-weight:700; color:#0f172a; line-height:1.15;}
  .m-itemcard__sub{color:#64748b; font-size:.9rem; margin-top:2px;}
  .m-itemcard__meta{display:flex; flex-wrap:wrap; gap:8px; margin-top:10px;}
  .m-chip{
    display:inline-flex; align-items:center; gap:6px;
    font-size:.82rem; padding:6px 10px;
    border-radius:999px;
    background: rgba(255,79,160,.10);
    color:#a10a50;
  }
  .m-chip.m-chip--neutral{background: rgba(15,23,42,.06); color:#334155;}
  .m-itemcard__actions{display:flex; gap:8px; margin-top:12px;}
  .m-btn{
    display:inline-flex; align-items:center; justify-content:center; gap:8px;
    border-radius: 14px; padding:10px 12px; font-weight:600;
    border: 1px solid rgba(15,23,42,.12);
    background:#fff; color:#0f172a; text-decoration:none;
    width:100%;
  }
  .m-btn.primary{
    background: linear-gradient(180deg, #ff77b7, #ff4fa0);
    color:#fff; border-color: transparent;
  }
}


  /* Responsive tweaks */
  @media (max-width: 420px){
    .m-iconbtn{ width: 40px; height: 40px; }
    .m-iconbtn i{ font-size: 18px; }
  /* Appbar icon colors */
  .m-backbtn, .m-backbtn i{ color: var(--primary) !important; }
  .m-menubtn, .m-menubtn i{ color: var(--primary) !important; }

    .m-fab-mini{ width: 42px; height: 42px; border-radius: 14px; }
    .m-fab-mini i{ font-size: 17px; }
    .m-chip{ height: 34px; padding: 0 10px; font-size: 12px; gap: 6px; }
    .m-chip i{ font-size: 14px; }
    .m-fab{ height: 50px; padding: 0 14px; border-radius: 18px; gap: 8px; right: 12px; }
    .m-fab i{ font-size: 17px; }
  }

  @media (max-width: 360px){
    .m-chipbar{ gap: 6px; padding: 6px 6px; }
    .m-fab{ height: 46px; padding: 0 12px; border-radius: 16px; }
    .m-fab span{ display: none; } /* em telas muito pequenas, fica só o ícone */
  }


/* =========================
   Fix21 v11 – Responsive tweaks
   ========================= */
@media (max-width: 420px){
  .mchip{ padding: 8px 12px; font-size: .92rem; }
  .mchip i{ font-size: 1rem; }
  .m-btn, .btn.m-btn{ padding: 10px 14px; font-size: .95rem; }
  .m-fab{ right: 14px; bottom: calc(74px + env(safe-area-inset-bottom)); }
  .m-fab .label{ display:none; } /* icon-only on small phones */
  .m-fab{ width: 54px; height: 54px; border-radius: 18px; }
}
@media (max-width: 360px){
  .mchip{ padding: 7px 10px; font-size: .88rem; }
  .m-fab{ width: 50px; height: 50px; border-radius: 16px; }
}


/* Hide desktop-only elements on mobile */
@media (max-width: 991px){
  .desktop-only{display:none !important;}
}

/* Show mobile-only elements on mobile */
.mobile-only{display:none !important;}
@media (max-width: 991px){
  .mobile-only{display:block !important;}
}

/* List pages: keep search/actions compact on small screens */
@media (max-width: 991px){
  .page-actions .btn{ padding: 10px 14px; font-size: .95rem; }
  .page-actions{ flex-wrap: wrap; gap: 10px; }
  .page-title{ margin-bottom: 12px; }

  /* In some list pages (audit), inputs can stretch too much */
  .m-searchbar .form-control,
  .m-searchbar .form-select{ height: 46px; border-radius: 14px; }
  .m-searchbar .btn{ height: 46px; border-radius: 14px; }
}
/* MOBILE: remover botões de visualização do FullCalendar (Semana/Dia/Mês),
   porque já existe a chipbar no topo */
@media (max-width: 768px){
  .fc .fc-header-toolbar .fc-toolbar-chunk:last-child{
    display: none !important;
  }
}
/* FIX: botão + do appbar clicável (iOS/blur overlay) */
.m-appbar,
.m-appbar *{
  pointer-events: auto;
}

.m-appbar::before,
.m-appbar::after{
  pointer-events: none !important;
}

/* se o seu botão tiver id ou classe, isso garante prioridade */
#mActionsBtn,
.m-actions-btn,
.m-appbar .btn-plus,
.m-appbar [data-mactions-open]{
  position: relative;
  z-index: 9999;
  pointer-events: auto !important;
}
