/* ================================================
   MOBILE.CSS — paste at the END of every CSS file
   or link as separate stylesheet in all HTML files
   ================================================ */

/* ── GLOBAL MOBILE BASE ── */
@media (max-width: 768px) {

  /* Prevent zoom on input focus on iOS */
  input, select, textarea {
    font-size: 16px !important;
  }

  /* Better tap targets */
  button, a {
    -webkit-tap-highlight-color: transparent;
  }

  /* No horizontal scroll anywhere */
  body, .container, .admin-wrap {
    overflow-x: hidden !important;
    max-width: 100vw !important;
  }

  /* ── MENU PAGE ── */

  /* Header stacks vertically on small screens */
  .header-inner {
    flex-direction: column !important;
    align-items: flex-start !important;
    gap: 10px !important;
    padding: 14px 16px !important;
  }

  .top-controls {
    width: 100% !important;
    justify-content: space-between !important;
  }

  input[type="number"] {
    width: 100% !important;
    max-width: 140px !important;
  }

  /* Menu grid — 2 columns on mobile */
  .grid {
    grid-template-columns: repeat(2, 1fr) !important;
    gap: 10px !important;
    padding: 12px !important;
  }

  /* Menu cards — better sizing */
  .menu-card {
    border-radius: 14px !important;
  }

  .menu-card img {
    height: 100px !important;
    border-radius: 8px !important;
  }

  .menu-card .name {
    font-size: 12px !important;
    line-height: 1.3 !important;
  }

  .menu-card .price {
    font-size: 13px !important;
  }

  .add-btn {
    padding: 8px !important;
    font-size: 12px !important;
    border-radius: 8px !important;
    min-height: 36px !important;
  }

  /* Category bar — bigger touch targets */
  .category-btn {
    padding: 9px 16px !important;
    font-size: 13px !important;
    min-height: 40px !important;
  }

  /* ── CART — MOBILE DRAWER ── */

  /* Cart panel becomes a bottom drawer */
  aside.panel, #cartPanel {
    position: fixed !important;
    bottom: 0 !important;
    left: 0 !important;
    right: 0 !important;
    z-index: 200 !important;
    border-radius: 20px 20px 0 0 !important;
    border-top: 1.5px solid var(--border) !important;
    border-left: none !important;
    border-right: none !important;
    border-bottom: none !important;
    box-shadow: 0 -8px 40px rgba(139,94,60,0.15) !important;
    max-height: 75vh !important;
    overflow-y: auto !important;
    transform: translateY(calc(100% - 68px)) !important;
    transition: transform 0.35s cubic-bezier(0.32, 0.72, 0, 1) !important;
    background: var(--panel) !important;
    backdrop-filter: blur(20px) !important;
  }

  aside.panel.open, #cartPanel.open {
    transform: translateY(0) !important;
  }

  /* Drag handle on cart */
  aside.panel .panel-head::before,
  #cartPanel .panel-head::before {
    content: '' !important;
    display: block !important;
    width: 36px !important;
    height: 4px !important;
    background: var(--border2) !important;
    border-radius: 2px !important;
    margin: 0 auto 12px !important;
  }

  aside.panel .panel-head,
  #cartPanel .panel-head {
    cursor: pointer !important;
    position: sticky !important;
    top: 0 !important;
    z-index: 10 !important;
    flex-direction: column !important;
    align-items: center !important;
    text-align: center !important;
    padding-top: 12px !important;
  }

  /* Push content up to not be hidden behind cart */
  .layout {
    padding-bottom: 80px !important;
  }

  /* Active orders section */
  #activeOrdersSection {
    padding-bottom: 80px !important;
  }

  /* Cart items inside drawer */
  .cart-row {
    padding: 10px 12px !important;
  }

  .qty-controls button {
    width: 32px !important;
    height: 32px !important;
    min-height: 32px !important;
  }

  /* Place order button — big and accessible */
  .place-order-btn {
    padding: 16px !important;
    font-size: 16px !important;
    min-height: 54px !important;
    border-radius: 14px !important;
  }

  /* ── ADMIN PANEL ── */

  .admin-wrap {
    padding: 12px 12px 80px !important;
  }

  .admin-header {
    padding: 14px 16px !important;
    border-radius: 14px !important;
    gap: 8px !important;
  }

  .admin-header h1 {
    font-size: 18px !important;
  }

  /* Tabs scroll horizontally */
  .tabs {
    overflow-x: auto !important;
    scrollbar-width: none !important;
    flex-wrap: nowrap !important;
    padding: 6px !important;
    gap: 4px !important;
    border-radius: 12px !important;
  }

  .tabs::-webkit-scrollbar { display: none !important; }

  .tab-btn {
    padding: 9px 14px !important;
    font-size: 12px !important;
    white-space: nowrap !important;
    flex-shrink: 0 !important;
    min-height: 40px !important;
  }

  /* Admin grid — single column */
  .grid.two-col {
    grid-template-columns: 1fr !important;
    padding: 12px !important;
    gap: 12px !important;
  }

  .card {
    padding: 14px !important;
    border-radius: 14px !important;
  }

  /* Order cards in admin */
  .order-card {
    padding: 12px !important;
    border-radius: 12px !important;
  }

  .order-top {
    flex-direction: column !important;
    gap: 10px !important;
  }

  .order-actions {
    width: 100% !important;
    flex-direction: row !important;
    flex-wrap: wrap !important;
    gap: 6px !important;
  }

  .order-actions .btn,
  .order-actions button {
    flex: 1 !important;
    min-height: 40px !important;
    font-size: 12px !important;
    padding: 8px 10px !important;
    text-align: center !important;
  }

  /* Form inputs bigger for mobile */
  label {
    font-size: 11px !important;
  }

  input[type="text"],
  input[type="number"],
  input[type="email"],
  input[type="password"],
  select, textarea {
    padding: 12px 14px !important;
    border-radius: 10px !important;
    min-height: 48px !important;
  }

  .btn.btn-primary {
    min-height: 48px !important;
    font-size: 14px !important;
    padding: 12px 16px !important;
  }

  /* ── KITCHEN & WAITER ── */

  .container {
    padding: 12px 12px 80px !important;
  }

  /* Header */
  header, .header {
    padding: 14px 16px !important;
    border-radius: 14px !important;
    gap: 8px !important;
  }

  header .title h1,
  .header .title h1 {
    font-size: 18px !important;
  }

  /* Tab bar scrollable */
  .tab-bar {
    overflow-x: auto !important;
    scrollbar-width: none !important;
    flex-wrap: nowrap !important;
    gap: 4px !important;
    padding: 5px !important;
    border-radius: 12px !important;
  }

  .tab-bar::-webkit-scrollbar { display: none !important; }

  .tab-bar .tab-btn {
    padding: 9px 12px !important;
    font-size: 12px !important;
    white-space: nowrap !important;
    flex-shrink: 0 !important;
    min-height: 38px !important;
  }

  /* Orders grid — single column on mobile */
  .orders-grid {
    grid-template-columns: 1fr !important;
    gap: 10px !important;
  }

  /* Order cards */
  .order-card {
    border-radius: 14px !important;
  }

  .order-top {
    flex-direction: column !important;
    gap: 10px !important;
    padding: 12px !important;
  }

  .order-actions {
    width: 100% !important;
    flex-direction: row !important;
    gap: 6px !important;
  }

  .btn-prepare, .btn-ready, .btn-serve {
    flex: 1 !important;
    min-width: 0 !important;
    min-height: 44px !important;
    font-size: 12px !important;
    padding: 10px 8px !important;
  }

  .order-items {
    padding: 10px 12px !important;
  }

  .order-items li {
    font-size: 13px !important;
    padding: 3px 0 !important;
  }

  /* Panel body */
  .panel-body, .panel-content {
    padding: 12px !important;
  }

  /* ── LOGIN & SIGNUP ── */

  .login-wrap, .signup-wrap {
    padding: 16px 0 40px !important;
  }

  .login-card, .signup-card {
    padding: 24px 20px !important;
    border-radius: 20px !important;
  }

  .login-brand .logo,
  .signup-brand .logo {
    font-size: 40px !important;
  }

  .login-brand h1,
  .signup-brand h1 {
    font-size: 24px !important;
  }

  .login-btn, .signup-btn {
    min-height: 52px !important;
    font-size: 15px !important;
  }

  .field-group input {
    min-height: 50px !important;
    font-size: 16px !important; /* prevents iOS zoom */
  }

  /* ── LANDING PAGE ── */

  .hero {
    padding: 60px 0 40px !important;
  }

  .hero-title {
    font-size: clamp(28px, 8vw, 42px) !important;
    letter-spacing: -1px !important;
  }

  .hero-sub {
    font-size: 15px !important;
    padding: 0 8px !important;
  }

  .hero-actions {
    flex-direction: column !important;
    align-items: center !important;
    gap: 10px !important;
  }

  .hero-actions .btn {
    width: 100% !important;
    max-width: 320px !important;
    min-height: 52px !important;
    font-size: 15px !important;
  }

  .phone-mockup {
    max-width: 240px !important;
  }

  .hero-stats {
    gap: 16px !important;
    margin-top: 36px !important;
    padding-top: 36px !important;
  }

  .hero-stat-value { font-size: 22px !important; }
  .hero-stat-label { font-size: 12px !important; }

  /* Features — 1 column on very small, 2 on larger */
  .features-grid {
    grid-template-columns: 1fr !important;
  }

  @media (min-width: 400px) {
    .features-grid {
      grid-template-columns: repeat(2, 1fr) !important;
    }
  }

  .feature-card {
    padding: 18px !important;
    border-radius: 14px !important;
  }

  .feature-icon {
    width: 42px !important;
    height: 42px !important;
    font-size: 20px !important;
    border-radius: 12px !important;
    margin-bottom: 12px !important;
  }

  .feature-title { font-size: 14px !important; }
  .feature-desc  { font-size: 13px !important; }

  /* Demo section */
  .demo-section {
    padding: 32px 20px !important;
    border-radius: 18px !important;
  }

  .demo-preview {
    grid-template-columns: repeat(2, 1fr) !important;
    gap: 8px !important;
    padding: 14px !important;
    margin: 20px auto !important;
  }

  .demo-card {
    padding: 12px !important;
    border-radius: 10px !important;
  }

  .demo-card-emoji { font-size: 20px !important; margin-bottom: 6px !important; }
  .demo-card-name  { font-size: 12px !important; }
  .demo-card-price { font-size: 12px !important; }

  /* Steps — vertical */
  .steps { flex-direction: column !important; gap: 20px !important; }
  .step   { padding: 0 !important; }

  .step:not(:last-child)::after { display: none !important; }

  .step-num  { width: 48px !important; height: 48px !important; font-size: 18px !important; }
  .step-icon { font-size: 28px !important; }
  .step-title { font-size: 16px !important; }
  .step-desc  { font-size: 13px !important; }

  /* Pricing — single column */
  .pricing-grid { grid-template-columns: 1fr !important; }

  .pricing-card {
    padding: 24px 20px !important;
    border-radius: 16px !important;
  }

  .plan-price { font-size: 36px !important; }

  /* Testimonials — single column */
  .testimonials-grid { grid-template-columns: 1fr !important; }

  .testimonial-card {
    padding: 20px !important;
    border-radius: 14px !important;
  }

  /* Staff links */
  .staff-links {
    gap: 8px !important;
    padding: 16px !important;
  }

  .staff-link {
    padding: 10px 14px !important;
    font-size: 12px !important;
    min-height: 44px !important;
    border-radius: 10px !important;
  }

  /* CTA section */
  .cta-section {
    padding: 40px 20px !important;
    border-radius: 18px !important;
  }

  .cta-title { font-size: clamp(20px, 5vw, 28px) !important; }
  .cta-sub   { font-size: 14px !important; }

  .cta-actions {
    flex-direction: column !important;
    align-items: center !important;
    gap: 10px !important;
  }

  .cta-actions .btn {
    width: 100% !important;
    max-width: 320px !important;
    min-height: 52px !important;
  }

  /* Section headers */
  .section-title { font-size: clamp(22px, 5vw, 32px) !important; }
  .section-sub   { font-size: 14px !important; padding: 0 8px !important; }

  /* Footer */
  footer {
    padding: 32px 20px 100px !important;
  }

  .footer-inner { gap: 20px !important; }

  .footer-links {
    gap: 14px !important;
    flex-wrap: wrap !important;
  }

  .footer-links a { font-size: 13px !important; }
  .footer-copy    { font-size: 12px !important; }

  /* Stock management */
  .stock-card {
    flex-wrap: wrap !important;
    gap: 10px !important;
    padding: 12px !important;
  }

  .stock-controls {
    width: 100% !important;
    justify-content: center !important;
  }

  .stock-toggle-btn {
    flex: 1 !important;
    min-height: 40px !important;
  }

  /* Report filters */
  #reportStartDate,
  #reportEndDate,
  #reportStatus {
    font-size: 16px !important;
    min-height: 44px !important;
  }

  /* QR codes in tables */
  .order-items img[alt="QR"] {
    width: 120px !important;
    height: 120px !important;
  }
}

/* ── EXTRA SMALL SCREENS (under 380px) ── */
@media (max-width: 380px) {
  .grid {
    grid-template-columns: 1fr !important;
  }

  .menu-card img {
    height: 90px !important;
  }

  .nav-logo span {
    display: none !important;
  }

  .hero-title {
    font-size: 26px !important;
  }

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

/* ── LANDSCAPE MOBILE ── */
@media (max-width: 768px) and (orientation: landscape) {
  .phone-mockup {
    max-width: 180px !important;
  }

  .hero {
    padding: 40px 0 20px !important;
  }

  aside.panel, #cartPanel {
    max-height: 85vh !important;
  }
}