/* ============================================================
   AXONIC — Mobile-first responsive overrides
   Breakpoints:  ≤767px (phone)  |  768–899px (tablet)
   ============================================================ */

/* ── BASE ──────────────────────────────────────────────────── */
*, *::before, *::after { box-sizing: border-box; }

html { -webkit-text-size-adjust: 100%; }

body { overflow-x: hidden; }

img, video { max-width: 100%; height: auto; }

/* container — full bleed with small gutter */
@media (max-width: 767px) {
  .container {
    width: calc(100% - 24px) !important;
    margin-left: auto !important;
    margin-right: auto !important;
  }

  body.mobile-menu-open {
    overflow: hidden !important;
  }
}

/* Header */
@media (max-width: 767px) {
  .site-header {
    position: relative !important;
    z-index: 2000 !important;
  }

  .header-inner {
    gap: 10px !important;
    min-height: 60px !important;
    padding: 0 12px !important;
  }

  .site-nav.desktop-nav {
    display: none !important;
  }

  .site-nav-panel {
    display: none !important;
    position: absolute !important;
    left: 10px !important;
    right: 10px !important;
    top: calc(100% + 8px) !important;
    width: auto !important;
    height: auto !important;
    max-height: calc(100vh - 96px) !important;
    overflow-y: auto !important;
    background: #ffffff !important;
    border: 1px solid #e8e8e8 !important;
    border-radius: 16px !important;
    box-shadow: 0 10px 26px rgba(0, 0, 0, 0.14) !important;
    z-index: 10001 !important;
    transform: none !important;
    visibility: visible !important;
    pointer-events: auto !important;
  }

  .site-nav-panel.is-open {
    display: block !important;
  }

  .site-nav-panel .header-link-row {
    display: grid !important;
    gap: 8px !important;
    padding: 10px !important;
    min-height: unset !important;
  }

  .site-nav-panel .site-nav.mobile-nav {
    display: flex !important;
    flex-direction: column !important;
    gap: 4px !important;
    width: 100% !important;
    position: static !important;
    background: #ffffff !important;
    box-shadow: none !important;
  }

  .site-nav-panel .site-nav.mobile-nav a {
    color: #0a0a0a !important;
    font-size: 0.88rem !important;
    font-weight: 600 !important;
    letter-spacing: 0.08em !important;
    text-transform: uppercase !important;
    padding: 12px 14px !important;
    border: 1px solid transparent !important;
    border-radius: 10px !important;
    display: block !important;
    pointer-events: auto !important;
    touch-action: manipulation !important;
    position: relative !important;
    z-index: 1 !important;
  }

  .site-nav-panel .site-nav.mobile-nav a.active {
    background: #f5f5f5 !important;
    border-color: #ececec !important;
  }

  .site-nav-panel .site-nav.mobile-nav a:hover {
    background: #f7f7f7 !important;
  }

  .site-nav-panel .site-nav.mobile-nav a::after {
    display: none !important;
  }

  .site-nav-panel .header-actions {
    display: flex !important;
    flex-direction: column !important;
    gap: 8px !important;
    width: 100% !important;
    margin-top: 2px !important;
    padding: 10px 4px 4px !important;
    border-top: 1px solid #f0f0f0 !important;
  }

  .site-nav-panel .header-actions a,
  .site-nav-panel .header-actions button,
  .site-nav-panel .header-actions .header-cta-link,
  .site-nav-panel .header-actions .header-user-pill {
    width: 100% !important;
    justify-content: center !important;
    text-align: center !important;
    color: #0a0a0a !important;
    border-color: #e8e8e8 !important;
  }

  .site-nav-panel .header-actions .cart-link {
    width: 100% !important;
    height: auto !important;
    justify-content: space-between !important;
    padding: 12px 14px !important;
  }

  .site-nav-panel .header-actions .cart-link span {
    position: static !important;
    min-width: 20px !important;
    height: 20px !important;
    line-height: 20px !important;
    margin-left: 8px !important;
  }

  .menu-button {
    font-size: 0.78rem !important;
    color: #0a0a0a !important;
    min-width: 74px !important;
    height: 40px !important;
    padding: 0 14px !important;
    border-radius: 999px !important;
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    border: 1px solid #e8e8e8 !important;
    background: #ffffff !important;
    position: relative !important;
    z-index: 10002 !important;
  }

  #mobile-nav-backdrop {
    /* keep backdrop below header stacking context so menu links stay clickable */
    z-index: 1990 !important;
  }

  .brandmark-plain span:last-child,
  .brandmark-plain div > span {
    font-size: 1.3rem !important;
    letter-spacing: 0.12em !important;
  }

  .brandmark small {
    font-size: 0.45rem !important;
  }

  .header-actions {
    gap: 4px !important;
    flex-direction: row !important;
    align-items: center !important;
  }

  .header-actions .primary-button,
  .header-actions .ghost-button {
    padding: 8px 12px !important;
    font-size: 0.72rem !important;
  }

  .header-actions .text-button {
    font-size: 0.72rem !important;
  }
}

/* ── HERO ──────────────────────────────────────────────────── */
@media (max-width: 767px) {
  .hero-banner,
  .hero-content { min-height: 56vh !important; }

  .hero-content {
    padding: 56px 0 20px !important;
    justify-content: center !important;
  }

  .hero-content h1 {
    font-size: clamp(2rem, 8vw, 2.8rem) !important;
    line-height: 1.05 !important;
  }

  .hero-description {
    font-size: 0.88rem !important;
    max-width: 100% !important;
    margin-top: 10px !important;
  }

  .hero-actions {
    flex-direction: column !important;
    gap: 10px !important;
    margin-top: 18px !important;
  }
  .hero-actions .primary-button,
  .hero-actions .ghost-button {
    width: 100% !important;
    text-align: center !important;
    padding: 13px 20px !important;
  }
}

/* ── SECTION SPACING ───────────────────────────────────────── */
@media (max-width: 767px) {
  .section-space    { padding-top: 48px !important; padding-bottom: 48px !important; }
  .section-space-sm { padding-top: 28px !important; padding-bottom: 28px !important; }
}

/* ── HOME PRODUCT GRID ─────────────────────────────────────── */
@media (max-width: 767px) {
  .product-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    gap: 8px !important;
  }
}

/* ── SHOP PAGE — sidebar collapses on mobile ───────────────── */
@media (max-width: 767px) {
  /* reset grid to single column */
  .shop-page {
    display: block !important;
  }

  /* filters bar on top, collapsible */
  .shop-filters-shell {
    position: static !important;
    max-height: none !important;
    overflow: visible !important;
    border: 1px solid #e8e8e8 !important;
    border-radius: 0 !important;
    padding: 12px 14px !important;
    margin-bottom: 18px !important;
    background: #fff !important;
  }

  /* hide filter panel by default on mobile — toggle button shows it */
  .shop-filters-shell .filter-panel {
    display: none !important;
  }
  .shop-filters-shell.mobile-open .filter-panel {
    display: grid !important;
    grid-template-columns: 1fr !important;
    margin-top: 12px !important;
  }

  /* show toggle button on mobile */
  .filter-toggle-button {
    display: flex !important;
    width: 100% !important;
    justify-content: space-between !important;
    align-items: center !important;
  }

  /* sidebar header inline */
  .shop-sidebar-header {
    margin-bottom: 0 !important;
    border-bottom: none !important;
  }

  /* product grid: 2 columns */
  .shop-product-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    gap: 8px !important;
  }
}

/* ── PRODUCT CARDS (mobile) ────────────────────────────────── */
@media (max-width: 767px) {
  .product-copy {
    padding: 8px 8px 10px !important;
  }
  .product-card-link {
    font-size: 0.76rem !important;
  }
  .product-price-row strong {
    font-size: 0.82rem !important;
  }
  .product-card-button {
    font-size: 0.7rem !important;
    padding: 7px 8px !important;
  }
}

/* ── PRODUCT DETAIL PAGE ───────────────────────────────────── */
@media (max-width: 767px) {
  .product-page { padding-top: 20px !important; }

  .product-layout {
    flex-direction: column !important;
    gap: 20px !important;
  }

  .gallery-panel,
  .product-panel { width: 100% !important; flex: none !important; }

  .product-hero-image {
    min-height: 300px !important;
    max-height: 460px !important;
    width: 100% !important;
    object-fit: cover !important;
  }

  .product-panel h1 {
    font-size: 1.5rem !important;
  }

  .detail-price-row strong { font-size: 1.25rem !important; }

  .choice-row {
    flex-wrap: wrap !important;
    gap: 8px !important;
  }
  .choice-row button {
    padding: 9px 14px !important;
    font-size: 0.76rem !important;
  }

  .detail-actions {
    flex-direction: column !important;
    gap: 10px !important;
  }
  .detail-actions .primary-button,
  .detail-actions button[type="submit"],
  .detail-actions .add-to-cart-button {
    width: 100% !important;
    padding: 14px !important;
    text-align: center !important;
    justify-content: center !important;
  }

  .thumbnail-row {
    gap: 8px !important;
    flex-wrap: wrap !important;
  }
}

/* ── CART ──────────────────────────────────────────────────── */
@media (max-width: 767px) {
  .cart-layout {
    flex-direction: column !important;
    gap: 20px !important;
  }

  .cart-items,
  .cart-summary { width: 100% !important; }

  .cart-item {
    flex-direction: row !important;
    gap: 12px !important;
    align-items: start !important;
  }

  .cart-item-controls {
    flex-direction: column !important;
    align-items: flex-start !important;
    gap: 8px !important;
  }
}

/* ── CHECKOUT ──────────────────────────────────────────────── */
@media (max-width: 767px) {
  .checkout-grid {
    grid-template-columns: 1fr !important;
    gap: 20px !important;
  }

  .checkout-summary {
    order: -1 !important;
    width: 100% !important;
  }

  .checkout-form {
    width: 100% !important;
  }

  .dashboard-form-grid,
  .dashboard-form-grid-wide {
    grid-template-columns: 1fr !important;
  }
}

/* ── AUTH (login/signup) ───────────────────────────────────── */
@media (max-width: 767px) {
  .auth-layout {
    grid-template-columns: 1fr !important;
    border: none !important;
  }

  /* hide the dark copy panel on mobile */
  .auth-copy-panel { display: none !important; }

  .auth-form-panel {
    padding: 32px 20px !important;
  }

  .auth-inline-row {
    grid-template-columns: 1fr !important;
    gap: 0 !important;
  }
}

/* ── ACCOUNT DASHBOARD ─────────────────────────────────────── */
@media (max-width: 767px) {
  .dashboard-grid {
    grid-template-columns: 1fr !important;
    gap: 16px !important;
  }

  .dashboard-two-column {
    grid-template-columns: 1fr !important;
  }

  .dashboard-metrics {
    grid-template-columns: repeat(2, 1fr) !important;
    gap: 10px !important;
  }

  .dashboard-sidebar {
    border-right: none !important;
    border-bottom: 1px solid rgba(255,255,255,0.08) !important;
    padding: 20px !important;
  }
}

/* ── ORDER CARDS ───────────────────────────────────────────── */
@media (max-width: 767px) {
  .orders-stack { gap: 8px !important; }

  .order-card { padding: 0 12px !important; }

  .order-card-grid {
    flex-direction: column !important;
    gap: 10px !important;
  }

  .order-card-grid div { min-width: 0 !important; width: 100% !important; }
}

/* ── FOOTER ────────────────────────────────────────────────── */
@media (max-width: 767px) {
  .site-footer .container {
    padding-top: 36px !important;
    padding-bottom: 24px !important;
  }

  .footer-grid {
    grid-template-columns: 1fr !important;
    gap: 28px !important;
  }

  .footer-legal {
    flex-direction: column !important;
    align-items: flex-start !important;
    gap: 8px !important;
    font-size: 0.75rem !important;
  }
}

/* ── TWO-COLUMN SECTIONS ───────────────────────────────────── */
@media (max-width: 767px) {
  .two-column {
    flex-direction: column !important;
    gap: 20px !important;
  }
  .two-column > * { width: 100% !important; }
}

/* ── CONTACT PAGE ──────────────────────────────────────────── */
@media (max-width: 767px) {
  .contact-grid {
    flex-direction: column !important;
    gap: 32px !important;
  }
  .contact-form { width: 100% !important; }
  .contact-card { width: 100% !important; }
}

/* ── BREADCRUMB ────────────────────────────────────────────── */
@media (max-width: 767px) {
  .breadcrumb { font-size: 0.72rem !important; }
}

/* ── SHOP HERO PANEL ───────────────────────────────────────── */
@media (max-width: 767px) {
  .shop-hero-panel {
    padding: 16px 0 14px !important;
    margin-bottom: 12px !important;
  }
  .shop-hero-panel h1 {
    font-size: clamp(1.4rem, 6vw, 2rem) !important;
  }
}

/* ── CATEGORY GRID ─────────────────────────────────────────── */
@media (max-width: 767px) {
  .category-grid {
    grid-template-columns: repeat(2, 1fr) !important;
    gap: 8px !important;
  }
}

/* ── TRUST / VALUE GRIDS ───────────────────────────────────── */
@media (max-width: 767px) {
  .trust-grid,
  .value-grid,
  .stats-grid {
    grid-template-columns: repeat(2, 1fr) !important;
    gap: 12px !important;
  }
}

/* ── SECTION HEADERS ───────────────────────────────────────── */
@media (max-width: 767px) {
  .section-header {
    flex-direction: column !important;
    align-items: flex-start !important;
    gap: 8px !important;
  }

  h1, h2 { word-break: break-word; }
}

/* ── MODALS / OVERLAYS ─────────────────────────────────────── */
@media (max-width: 767px) {
  .modal-overlay { padding: 0 !important; align-items: flex-end !important; }
  .modal {
    border-radius: 0 !important;
    max-width: 100% !important;
    max-height: 92vh !important;
  }
}

/* ── TABLET (768-899px) ────────────────────────────────────── */
@media (min-width: 768px) and (max-width: 899px) {
  .shop-product-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  }
  .product-layout {
    gap: 28px !important;
  }
  .checkout-grid {
    grid-template-columns: 1fr !important;
  }
  .product-grid {
    grid-template-columns: repeat(4, minmax(0, 1fr)) !important;
    gap: 10px !important;
  }
}

/* ── PREVENT HORIZONTAL SCROLL ─────────────────────────────── */
@media (max-width: 767px) {
  .hero-banner { overflow: hidden !important; }
  .shop-page, .product-page, .cart-page, .checkout-page { overflow-x: hidden !important; }
}

/* ── DRAWER ACTIONS (Orders + Logout) ──────────────────────── */
@media (max-width: 767px) {
  .drawer-actions {
    margin-top: auto;
    border-top: 1px solid rgba(255,255,255,0.1);
    padding: 12px 0;
  }

  .drawer-action-link {
    display: flex;
    align-items: center;
    gap: 10px;
    width: 100%;
    padding: 14px 28px;
    font-family: 'DM Sans', sans-serif;
    font-size: 0.88rem;
    font-weight: 600;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    color: rgba(255,255,255,0.75);
    background: transparent;
    border: none;
    border-bottom: 1px solid rgba(255,255,255,0.07);
    cursor: pointer;
    text-decoration: none;
    text-align: left;
    transition: background 0.12s, color 0.12s;
  }
  .drawer-action-link:last-child { border-bottom: none; }
  .drawer-action-link:hover { background: rgba(255,255,255,0.06); color: #fff; }
  .drawer-action-danger { color: rgba(255,100,100,0.85) !important; }
  .drawer-action-danger:hover { color: #ff6464 !important; }
}

/* ── DESKTOP: panel stays visible (contains cart + profile) ── */
@media (min-width: 768px) {
  /* reset the drawer styles so panel is inline on desktop */
  .site-nav-panel {
    position: static !important;
    transform: none !important;
    width: auto !important;
    max-width: none !important;
    height: auto !important;
    background: transparent !important;
    box-shadow: none !important;
    overflow: visible !important;
    transition: none !important;
    display: block !important;
  }

  /* hide only the mobile nav list inside the panel */
  .site-nav-panel .site-nav.mobile-nav { display: none !important; }

  /* hide drawer-only injected actions */
  .drawer-actions { display: none !important; }

  /* header-link-row: horizontal on desktop */
  .site-nav-panel .header-link-row {
    display: flex !important;
    flex-direction: row !important;
    align-items: center !important;
    padding: 0 !important;
    min-height: auto !important;
    gap: 12px !important;
  }

  /* header-actions: restore horizontal row */
  .site-nav-panel .header-actions {
    flex-direction: row !important;
    align-items: center !important;
    gap: 10px !important;
    padding: 0 !important;
    margin-top: 0 !important;
    border-top: none !important;
  }
  .site-nav-panel .header-actions a,
  .site-nav-panel .header-actions button {
    color: #0a0a0a !important;
    padding: 0 !important;
  }
}

/* ── MOBILE HEADER ICONS ───────────────────────────────────── */
@media (max-width: 767px) {
  #mobile-header-icons {
    display: flex !important;
    align-items: center !important;
    gap: 6px !important;
    margin-left: auto !important;
    margin-right: 6px !important;
  }

  /* profile trigger in header */
  #mobile-header-icons #profile-trigger {
    width: 34px !important;
    height: 34px !important;
  }

  /* cart link in header */
  #mobile-header-icons .cart-link {
    font-size: 1.1rem !important;
    display: flex !important;
    align-items: center !important;
    gap: 4px !important;
    color: #0a0a0a !important;
    text-decoration: none !important;
    position: relative !important;
  }
  #mobile-header-icons .cart-link span {
    font-size: 0.65rem !important;
    min-width: 18px !important;
    height: 18px !important;
    padding: 0 4px !important;
    border-radius: 50% !important;
  }
}

/* mobile cloned profile trigger */
@media (max-width: 767px) {
  #mobile-profile-trigger {
    width: 34px !important;
    height: 34px !important;
    border-radius: 50% !important;
    background: #0a0a0a !important;
    color: #fff !important;
    border: none !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    cursor: pointer !important;
  }
}

/* mobile profile link (anchor, not button) */
@media (max-width: 767px) {
  a#mobile-profile-trigger {
    width: 34px !important;
    height: 34px !important;
    border-radius: 50% !important;
    background: #0a0a0a !important;
    color: #fff !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    text-decoration: none !important;
    flex-shrink: 0 !important;
  }
}
