:root{
  --green:#006633;--green-light:#008844;--green-dark:#004d26;
  --yellow:#f5c518;--bg:#f0f2f5;--white:#ffffff;
  --gray-1:#f8f9fa;--gray-2:#e9ecef;--gray-3:#dee2e6;
  --gray-4:#adb5bd;--gray-5:#6c757d;--text:#1a1a2e;--text-light:#495057;
  --red:#dc3545;--blue:#0d6efd;--purple:#6f42c1;
  --shadow:0 2px 8px rgba(0,0,0,.10);--shadow-md:0 4px 16px rgba(0,0,0,.13);
  --radius:10px;--radius-sm:6px;
}
*{box-sizing:border-box;margin:0;padding:0}
body{font-family:'Segoe UI',system-ui,sans-serif;background:var(--bg);color:var(--text);min-height:100vh}

/* LOGIN */
#login-screen{min-height:100vh;display:flex}
/* Form panel — esquerda, 50% */
.login-form-side{flex:0 0 50%;display:flex;flex-direction:column;justify-content:center;padding:56px 72px;background:#fff;overflow-y:auto;border-left:4px solid var(--green)}
.login-form-logo{display:none;align-items:center;gap:10px;margin-bottom:32px}
.login-form-logo-emoji{font-size:28px;line-height:1}
.login-form-logo-text{font-size:22px;font-weight:900;color:var(--green);letter-spacing:-1px;line-height:1}
.login-form-inner{width:100%;max-width:400px;margin:0 auto}
.login-form-title{font-size:34px;font-weight:800;color:var(--text);margin-bottom:10px;letter-spacing:-.7px}
.login-form-sub{font-size:14px;color:var(--gray-4);margin-bottom:36px;line-height:1.6;font-weight:400}
.login-form-label{display:block;font-size:11px;font-weight:700;color:var(--text-light);text-transform:uppercase;letter-spacing:.8px;margin-bottom:9px}
.login-input{width:100%;padding:15px 18px;border:1.5px solid var(--gray-3);border-radius:10px;font-size:15px;color:var(--text);background:var(--gray-1);transition:border .2s,box-shadow .2s;outline:none;margin-bottom:20px;font-family:inherit}
.login-input:focus{border-color:var(--green);box-shadow:0 0 0 4px rgba(0,102,51,.08)}
.login-btn{width:100%;padding:16px;background:var(--green);color:#fff;border:none;border-radius:10px;font-size:15px;font-weight:700;cursor:pointer;transition:background .2s,box-shadow .2s;margin-top:4px}
.login-btn:hover{background:var(--green-dark);box-shadow:0 4px 20px rgba(0,102,51,.25)}
.login-btn:active{transform:scale(.99)}
.login-hint{margin-top:28px;background:var(--gray-1);border-radius:8px;padding:14px 16px;font-size:12px;color:var(--gray-4);border:1px solid var(--gray-2);line-height:1.8}
.login-hint strong{color:var(--green);display:block;margin-bottom:6px;font-size:11px;text-transform:uppercase;letter-spacing:.6px}
/* Brand panel — direita, 50% */
.login-brand{flex:0 0 50%;background:radial-gradient(ellipse at 50% 45%,#0d6b28 0%,#003d1a 65%,#001f0d 100%);display:flex;flex-direction:column;justify-content:center;align-items:center;padding:60px 56px;position:relative;overflow:hidden;text-align:center}
.login-brand-deco{position:absolute;line-height:1;pointer-events:none;user-select:none;opacity:.06}
.login-brand-deco.d1{font-size:340px;top:-80px;right:-80px}
.login-brand-deco.d2{font-size:240px;bottom:-60px;left:-60px}
.login-brand-emoji{font-size:64px;margin-bottom:28px;display:block}
.login-brand h1{font-size:64px;font-weight:900;color:#fff;letter-spacing:-3px;line-height:.95;margin-bottom:14px}
.login-brand-fullname{font-size:13px;color:rgba(255,255,255,.5);font-weight:500;line-height:1.6;margin-bottom:32px}
.login-brand-divider{width:40px;height:3px;background:rgba(255,255,255,.2);border-radius:2px;margin-bottom:28px}
.login-brand-tagline{display:inline-block;font-size:11px;color:rgba(255,255,255,.6);font-weight:600;letter-spacing:1.4px;text-transform:uppercase;margin-top:36px;padding:8px 20px;border:1px solid rgba(255,255,255,.18);border-radius:100px;background:rgba(255,255,255,.06);text-align:center}
.form-group{margin-bottom:16px}
.form-group label{display:block;font-size:13px;font-weight:600;color:var(--text-light);margin-bottom:6px}
.form-group input,.form-group select,.form-group textarea{width:100%;padding:10px 14px;border:1.5px solid var(--gray-3);border-radius:var(--radius-sm);font-size:14px;color:var(--text);background:var(--white);transition:border .2s;outline:none}
.form-group input:focus,.form-group select:focus,.form-group textarea:focus{border-color:var(--green)}
.btn{padding:10px 20px;border:none;border-radius:var(--radius-sm);font-size:14px;font-weight:600;cursor:pointer;transition:all .2s;display:inline-flex;align-items:center;gap:6px}
.btn-primary{background:var(--green);color:#fff}.btn-primary:hover{background:var(--green-dark)}
.btn-secondary{background:var(--gray-2);color:var(--text)}.btn-secondary:hover{background:var(--gray-3)}
.btn-danger{background:#fff0f0;color:var(--red);border:1px solid #ffc9c9}.btn-danger:hover{background:#ffe0e0}
.btn-sm{padding:6px 12px;font-size:12px}
.btn-block{width:100%;justify-content:center;padding:12px;font-size:15px}
.login-hint{margin-top:20px;background:#f0f8f3;border-radius:8px;padding:12px 14px;font-size:12px;color:var(--gray-5)}
.login-hint strong{color:var(--green);display:block;margin-bottom:4px}
.login-error{color:var(--red);font-size:13px;margin-top:8px;display:none}

/* APP */
#app{display:none;min-height:100vh}
.app-layout{display:flex;min-height:100vh}
.sidebar{width:230px;background:var(--green-dark);color:#fff;display:flex;flex-direction:column;position:fixed;top:0;left:0;height:100vh;z-index:100}
.sidebar-brand{padding:20px 18px 16px;border-bottom:1px solid rgba(255,255,255,.12)}
.sidebar-brand h2{font-size:15px;font-weight:700;margin-top:4px;line-height:1.2}
.sidebar-brand p{font-size:11px;opacity:.6}
.sidebar-nav{flex:1;padding:14px 0}
.nav-item{display:flex;align-items:center;gap:10px;padding:10px 18px;cursor:pointer;font-size:14px;color:rgba(255,255,255,.82);transition:background .15s}
.nav-item:hover{background:rgba(255,255,255,.1);color:#fff}
.nav-item.active{background:rgba(255,255,255,.18);color:#fff;font-weight:600;border-right:3px solid var(--yellow)}
.nav-item .icon{font-size:17px;width:22px;text-align:center}
.sidebar-user{padding:14px 18px;border-top:1px solid rgba(255,255,255,.12)}
.user-info{display:flex;align-items:center;gap:10px}
.user-avatar{width:34px;height:34px;background:var(--yellow);border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:14px;color:var(--green-dark);flex-shrink:0}
.user-name{font-size:13px;font-weight:600}
.user-role{font-size:11px;opacity:.6}
.btn-logout{margin-top:10px;background:rgba(255,255,255,.1);color:#fff;border:none;width:100%;padding:8px;border-radius:6px;cursor:pointer;font-size:12px}
.btn-logout:hover{background:rgba(255,255,255,.2)}
.main{margin-left:230px;flex:1;padding:28px}
.page-header{margin-bottom:24px}
.page-header h1{font-size:22px;font-weight:700}
.page-header p{color:var(--gray-5);font-size:14px;margin-top:3px}

/* STATS */
.stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-bottom:24px}
.stat-card{background:var(--white);border-radius:var(--radius);padding:18px 20px;box-shadow:var(--shadow)}
.stat-card .stat-icon{font-size:28px;margin-bottom:8px}
.stat-card .stat-value{font-size:28px;font-weight:700;color:var(--green)}
.stat-card .stat-label{font-size:13px;color:var(--gray-5);margin-top:2px}

/* CARDS */
.card{background:var(--white);border-radius:var(--radius);box-shadow:var(--shadow);margin-bottom:20px}
.card-header{padding:16px 20px;border-bottom:1px solid var(--gray-2);display:flex;align-items:center;justify-content:space-between}
.card-header h3{font-size:15px;font-weight:700}
.card-body{padding:20px}

/* TABLE */
.table-wrap{overflow-x:auto}
table{width:100%;border-collapse:collapse}
th{background:var(--gray-1);padding:10px 14px;text-align:left;font-size:12px;font-weight:700;color:var(--gray-5);text-transform:uppercase;letter-spacing:.5px;border-bottom:2px solid var(--gray-2)}
td{padding:12px 14px;font-size:14px;border-bottom:1px solid var(--gray-2);color:var(--text);vertical-align:middle}
tr:last-child td{border-bottom:none}
tr:hover td{background:var(--gray-1)}

/* BADGE */
.badge{display:inline-block;padding:3px 9px;border-radius:20px;font-size:11px;font-weight:700}
.badge-green{background:#d4edda;color:#155724}
.badge-yellow{background:#fff3cd;color:#856404}
.badge-blue{background:#cfe2ff;color:#084298}
.badge-red{background:#f8d7da;color:#842029}
.badge-gray{background:var(--gray-2);color:var(--gray-5)}
.badge-purple{background:#e8d8ff;color:#4a1080}
.badge-orange{background:#ffe5cc;color:#7d3000}
.badge-teal{background:#d0f0f0;color:#006666}

/* MODAL */
.modal-overlay{display:none;position:fixed;inset:0;background:rgba(0,0,0,.45);z-index:1000;align-items:center;justify-content:center}
.modal-overlay.open{display:flex}
.modal{background:var(--white);border-radius:14px;width:520px;max-width:96vw;box-shadow:var(--shadow-md);overflow:hidden;display:flex;flex-direction:column;max-height:90vh}
.modal-wide{width:880px}
.modal-header{padding:18px 22px;border-bottom:1px solid var(--gray-2);display:flex;justify-content:space-between;align-items:center;flex-shrink:0}
.modal-header h3{font-size:16px;font-weight:700}
.modal-close{background:none;border:none;font-size:20px;cursor:pointer;color:var(--gray-5);line-height:1}
.modal-body{padding:22px;overflow-y:auto;flex:1}
.modal-footer{padding:14px 22px;border-top:1px solid var(--gray-2);display:flex;gap:10px;justify-content:flex-end;flex-shrink:0}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.form-row-3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:14px}

/* ESCALATION GRID */
.esc-grid-wrap{overflow-x:auto;padding:0 20px 4px}
.esc-table{border-collapse:collapse;white-space:nowrap;width:100%}
.esc-table th{background:var(--gray-1);padding:6px 8px;font-size:11px;font-weight:700;color:var(--gray-5);text-align:center;border:1px solid var(--gray-2)}
.esc-table th.arb-col{text-align:left;min-width:190px;position:sticky;left:0;z-index:2;background:var(--gray-1)}
.esc-table td{padding:6px 8px;border:1px solid var(--gray-2);text-align:center;vertical-align:middle;font-size:13px}
.esc-table td.arb-name{text-align:left;background:var(--white);position:sticky;left:0;z-index:1;font-weight:600;min-width:190px}
.esc-table tfoot td{background:var(--gray-1);font-size:11px;text-align:center;border:1px solid var(--gray-2);padding:5px 8px}
.esc-table tfoot td.arb-col{text-align:left;position:sticky;left:0;z-index:1;font-weight:700}
.day-cell{min-width:58px;cursor:pointer;transition:background .12s}
.day-cell:hover{filter:brightness(.92)}
.day-weekend{background:#faf8f0 !important}
.esc-info-bar{padding:12px 20px;background:#f0f8f3;border-bottom:1px solid var(--gray-2);font-size:13px;flex-shrink:0}
.ag-bar{padding:12px 20px;background:#fffbea;border-bottom:1px solid #ffe082;display:flex;align-items:center;gap:12px;flex-shrink:0;flex-wrap:wrap}

/* CALENDAR */
.cal-nav{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px}
.cal-nav h4{font-size:15px;font-weight:700}
.cal-btn{background:var(--gray-2);border:none;border-radius:6px;padding:6px 12px;cursor:pointer;font-size:14px}
.cal-btn:hover{background:var(--gray-3)}
.cal-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:4px}
.cal-day-name{text-align:center;font-size:11px;font-weight:700;color:var(--gray-5);padding:4px 0}
.cal-day{aspect-ratio:1;display:flex;align-items:center;justify-content:center;border-radius:8px;font-size:13px;cursor:pointer;transition:all .15s}
.cal-day:hover:not(.empty):not(.past){background:var(--gray-2)}
.cal-day.empty{cursor:default}.cal-day.past{color:var(--gray-4);cursor:default}
.cal-day.available{background:#4ade80;color:#fff;font-weight:700}
.cal-day.available:hover{background:#22c55e}
.cal-day.today{border:2px solid var(--green);font-weight:700}
.cal-day.has-tournament{background:#cfe2ff;color:#084298;font-weight:700}
.cal-day.has-tournament.available{background:var(--yellow);color:var(--green-dark)}
.cal-legend{display:flex;gap:14px;margin-top:12px;font-size:12px;flex-wrap:wrap}
.cal-legend-item{display:flex;align-items:center;gap:6px}
.cal-legend-dot{width:14px;height:14px;border-radius:4px;flex-shrink:0}

/* TOURNAMENT CARDS */
.tournament-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(290px,1fr));gap:16px}
.tournament-card{background:var(--white);border-radius:var(--radius);box-shadow:var(--shadow);overflow:hidden}
.t-header-tenis{background:var(--green)}
.t-header-beach{background:linear-gradient(135deg,#e07b00,#f0a800)}
.tournament-card-header{color:#fff;padding:12px 16px}
.tournament-card-header h4{font-size:14px;font-weight:700;line-height:1.3}
.tournament-card-header p{font-size:11px;opacity:.85;margin-top:2px}
.tournament-card-body{padding:12px 16px}
.tournament-meta{font-size:12px;color:var(--gray-5);margin-bottom:4px;display:flex;gap:6px;align-items:center}
.tournament-card-footer{padding:8px 14px;border-top:1px solid var(--gray-2);display:flex;gap:6px;flex-wrap:wrap}

/* AVAILABILITY GRID */
.avail-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:4px}
.avail-day-names{display:grid;grid-template-columns:repeat(7,1fr);gap:4px;margin-bottom:4px}
.avail-cell{aspect-ratio:1;border-radius:8px;font-size:11px;display:flex;flex-direction:column;align-items:center;justify-content:center;cursor:pointer;background:var(--gray-1);border:1px solid var(--gray-2);transition:all .15s}
.avail-cell:hover:not(.empty):not(.past){border-color:var(--green)}
.avail-cell .day-num{font-size:12px;font-weight:600}
.avail-cell .avail-count{font-size:10px;font-weight:700;color:#fff;background:var(--green);border-radius:10px;padding:1px 6px;margin-top:2px}
.avail-cell.has-tournament{border-color:var(--blue);background:#f0f5ff}
.avail-cell.empty,.avail-cell.past{background:transparent;border-color:transparent;cursor:default}
.avail-cell.past .day-num{color:var(--gray-4)}

/* ASSIGN */
.assign-avatar{width:30px;height:30px;border-radius:50%;background:var(--green);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:12px;flex-shrink:0}

/* COVERAGE PILLS */
.cov-day{height:20px;padding:0 5px;border-radius:4px;font-size:10px;font-weight:700;display:inline-flex;align-items:center;justify-content:center;min-width:26px}
.cov-full{background:#d4edda;color:#155724}
.cov-partial{background:#fff3cd;color:#856404}
.cov-empty{background:#f8d7da;color:#842029}

/* TOAST */
#toast{position:fixed;bottom:24px;right:24px;background:var(--green);color:#fff;padding:12px 20px;border-radius:10px;font-size:14px;box-shadow:var(--shadow-md);z-index:9999;transform:translateY(60px);opacity:0;transition:all .3s;pointer-events:none}
#toast.show{transform:translateY(0);opacity:1}
.empty-state{text-align:center;padding:40px;color:var(--gray-5)}
.empty-state .empty-icon{font-size:40px;margin-bottom:10px}
.empty-state p{font-size:14px}
.section-label{font-size:11px;font-weight:700;color:var(--gray-5);text-transform:uppercase;letter-spacing:.5px;margin-bottom:8px}
.role-chip{display:inline-flex;align-items:center;gap:4px;padding:4px 10px;border-radius:20px;font-size:11px;font-weight:700}
.role-geral{background:#fffbea;color:#856404;border:1px solid #ffe082}
.role-auxiliar{background:#d4edda;color:#155724;border:1px solid #c3e6cb}
.role-mesa{background:#e8d8ff;color:#4a1080;border:1px solid #d4b8ff}

/* ── BOTTOM NAV (mobile) ─────────────────────────── */
#bottom-nav{display:none;position:fixed;bottom:0;left:0;right:0;background:#fff;z-index:200;border-top:1px solid var(--gray-2);padding-bottom:env(safe-area-inset-bottom,0);-webkit-transform:translateZ(0);transform:translateZ(0);will-change:transform}
.bn-items{display:flex;height:68px;align-items:center;padding:0 4px}
.bn-item{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:3px;cursor:pointer;color:var(--gray-5);border:none;background:none;transition:color .15s;padding:8px 4px;position:relative;border-radius:12px}
.bn-item.active{color:var(--green)}
.bn-item.active .bn-item-inner{background:#e8f5ee;border-radius:12px;padding:4px 14px}
.bn-item-inner{display:flex;flex-direction:column;align-items:center;gap:3px;padding:4px 14px;transition:background .15s,border-radius .15s}
.bn-item-label{font-size:10px;font-weight:600;line-height:1;text-align:center;white-space:nowrap}
.bn-badge{position:absolute;top:4px;right:calc(50% - 20px);background:var(--red);color:#fff;border-radius:8px;font-size:9px;font-weight:700;padding:1px 4px;min-width:14px;text-align:center;display:none}
.bn-item-logout{color:#e57373}
.bn-item-logout:hover{color:var(--red)}

/* ── MOBILE MEDIA QUERY ──────────────────────────── */
@media screen and (max-width:767px){
  /* layout */
  .sidebar{display:none!important}
  html,body{overflow-x:hidden;max-width:100vw}
  .main{margin-left:0;padding:12px 12px 96px;box-sizing:border-box;overflow-x:hidden;max-width:100vw}
  #bottom-nav{display:block}
  /* login */
  #login-screen{flex-direction:column;background:radial-gradient(ellipse at 50% 30%,#0d6b28 0%,#003d1a 60%,#001f0d 100%)}
  .login-brand{display:none!important}
  .login-form-side{flex:1;background:transparent!important;border:none!important;padding:48px 24px 56px;display:flex;flex-direction:column;align-items:center;justify-content:center}
  .login-form-logo{display:flex!important;justify-content:center;margin-bottom:36px;background:transparent}
  .login-form-logo img{height:auto!important;width:min(218px,56vw)!important;filter:drop-shadow(0 4px 16px rgba(0,0,0,0.4))}
  .login-form-inner{background:#fff;border-radius:20px;padding:32px 28px 28px;width:100%;max-width:400px;box-shadow:0 12px 48px rgba(0,0,0,0.35)}
  .login-form-title{font-size:24px;margin-bottom:4px}
  .login-form-sub{font-size:13px;margin-bottom:20px;color:var(--gray-4)}
  .login-input{padding:13px 16px;font-size:15px;margin-bottom:16px;background:#fff}
  .login-btn{padding:15px}
  .login-hint{font-size:11px}
  /* page header */
  .page-header{margin-bottom:16px;display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:10px}
  .page-header h1{font-size:18px}
  .page-header p{font-size:12px;margin-top:2px}
  .page-header>div{flex:1;min-width:0}
  /* stat cards */
  .stats-grid{grid-template-columns:1fr 1fr;gap:10px;margin-bottom:16px}
  .stat-card{padding:14px}
  .stat-card .stat-value{font-size:22px}
  .stat-card .stat-icon{font-size:22px;margin-bottom:6px}
  /* tournament / content grids */
  .tournament-grid{grid-template-columns:1fr}
  .mat-grid{grid-template-columns:1fr}
  /* forms */
  .form-row,.form-row-3{grid-template-columns:1fr}
  /* cards */
  .card{margin-bottom:12px;overflow:hidden;max-width:100%}
  .card-body{padding:12px 14px}
  .card-header{padding:12px 14px}
  .card-header h3{font-size:14px}
  /* modals → bottom sheet */
  .modal-overlay{align-items:flex-end;padding:0}
  .modal,.modal-wide{width:100%;max-width:100%;border-radius:16px 16px 0 0;max-height:92vh}
  .modal-header{padding:14px 16px}
  .modal-body{padding:16px}
  .modal-footer{padding:12px 16px}
  /* tables */
  .table-wrap,.esc-grid-wrap{-webkit-overflow-scrolling:touch}
  th{padding:8px 10px;font-size:11px}
  td{padding:10px 10px;font-size:13px}
  .esc-table th.arb-col{min-width:120px}
  .esc-table td.arb-name{min-width:120px}
  .esc-grid-wrap{padding:0 0 4px}
  /* profile grid */
  .profile-grid-2col{grid-template-columns:1fr!important}
  /* badges / pills wrap */
  .badge{font-size:10px;padding:2px 7px}
  /* buttons */
  .btn{font-size:13px}
  .btn-sm{font-size:11px;padding:5px 10px}
  /* prevent flex/grid children from overflowing */
  .page-header{min-width:0}
  .page-header>*{min-width:0}
  .page-header>div{overflow:hidden}
  .page-header h1{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
  /* search bar */
  input[type="text"],input[type="email"],input[type="date"],input[type="search"],select,textarea{box-sizing:border-box;max-width:100%}
  /* flex containers safe on mobile */
  [style*="display:flex"]{min-width:0}
  .tournament-card{max-width:100%}
  .mat-card{max-width:100%}
}
.login-mobile-logo{display:none}

/* ── MORE MENU ───────────────────────────────────── */
#more-menu-overlay{display:none;position:fixed;inset:0;z-index:300;background:rgba(0,0,0,.3)}
#more-menu{position:fixed;bottom:-420px;left:0;right:0;z-index:301;background:#fff;border-radius:20px 20px 0 0;border-top:1px solid var(--gray-2);padding:10px 0 calc(20px + env(safe-area-inset-bottom,0));transition:bottom .28s cubic-bezier(.4,0,.2,1);-webkit-transform:translateZ(0);transform:translateZ(0)}
.more-menu-item{display:flex;align-items:center;gap:14px;padding:14px 24px;color:var(--text);cursor:pointer;font-size:15px;font-weight:500;transition:background .15s}
.more-menu-item:active{background:var(--gray-1)}
.more-menu-sep{height:1px;background:var(--gray-2);margin:6px 16px}
.more-menu-danger{color:var(--red)}

/* ── MATERIAL CARDS ──────────────────────────────── */
.mat-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:16px}
.mat-card{background:var(--white);border-radius:var(--radius);box-shadow:var(--shadow);overflow:hidden;display:flex;flex-direction:column}
.mat-card-header{padding:14px 16px;display:flex;align-items:flex-start;gap:12px}
.mat-icon-wrap{width:44px;height:44px;border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:22px;flex-shrink:0}
.mat-card-body{padding:0 16px 14px;flex:1}
.mat-card-footer{padding:10px 14px;border-top:1px solid var(--gray-2);display:flex;gap:8px}
.mat-type-pill{display:inline-block;padding:2px 8px;border-radius:10px;font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.5px}
@media screen and (max-width:767px){
  .mat-grid{grid-template-columns:1fr}
  #more-menu-overlay.open{display:block}
}

