/* ================================================
   POINT OF CODE — Theme Redesign
   Font: Cairo | Colors: #3bb64a / #3bb64a / #0d1117
   ================================================ */

/* ── Variables ── */
:root {
  --poc-blue:       #3bb64a;
  --poc-blue-dark:  #3bb64a;
  --poc-blue-light: #eef2fb;
  --poc-teal:       #3bb64a;
  --poc-dark:       #0d1117;
  --poc-text:       #374151;
  --poc-muted:      #6b7280;
  --poc-border:     #e5e7eb;
  --poc-bg:         #f9fafb;
  --poc-white:      #ffffff;
  --poc-radius:     8px;
  --poc-radius-lg:  12px;
  --poc-shadow-sm:  0 1px 3px rgba(0,0,0,0.08);
  --poc-shadow:     0 4px 16px rgba(0,0,0,0.10);
  --poc-shadow-lg:  0 12px 40px rgba(0,0,0,0.12);
  --poc-trans:      0.18s ease;
}

/* ── Base font ── */
body,
body *:not(.porto-icon):not([class*="porto-icon"]):not(i):not(em) {
  font-family: 'Cairo', -apple-system, BlinkMacSystemFont, sans-serif !important;
}
body {
  font-size: 15px;
  line-height: 1.65;
  color: var(--poc-text);
  background: var(--poc-white);
  -webkit-font-smoothing: antialiased;
}

/* ── Typography ── */
h1,h2,h3,h4,h5,h6 {
  font-family: 'Cairo', sans-serif !important;
  font-weight: 700;
  color: var(--poc-dark);
  line-height: 1.25;
  letter-spacing: -0.01em;
}
h1 { font-size: clamp(24px, 3vw, 38px); }
h2 { font-size: clamp(20px, 2.4vw, 28px); }
h3 { font-size: clamp(16px, 2vw, 20px); }
h4 { font-size: 16px; }
a { color: var(--poc-blue); transition: color var(--poc-trans); }
a:hover { color: var(--poc-blue-dark); text-decoration: none; }

/* ── Page title bar ── */
.page-title-wrapper {
  background: var(--poc-white);
  padding: 28px 0 20px;
  margin-bottom: 8px;
  border-bottom: 1px solid var(--poc-border);
}
.page-title span,
.page-title-wrapper .page-title {
  font-family: 'Cairo', sans-serif !important;
  font-size: clamp(22px, 2.5vw, 32px) !important;
  font-weight: 800 !important;
  color: var(--poc-dark) !important;
  letter-spacing: -0.02em;
}

/* ── Breadcrumbs ── */
.breadcrumbs {
  padding: 10px 0;
  margin-bottom: 4px;
}
.breadcrumbs .items {
  display: flex;
  align-items: center;
  gap: 6px;
  list-style: none;
  padding: 0;
  margin: 0;
  flex-wrap: wrap;
}
.breadcrumbs .item {
  font-size: 12px;
  color: var(--poc-muted);
  display: flex;
  align-items: center;
  gap: 6px;
}
.breadcrumbs .item::after { content: '/'; color: var(--poc-border); }
.breadcrumbs .item:last-child::after { display: none; }
.breadcrumbs .item a { color: var(--poc-muted); }
.breadcrumbs .item a:hover { color: var(--poc-blue); }

/* ── HEADER ── */
.header-main {
  background: var(--poc-white);
  border-bottom: 1px solid var(--poc-border);
  box-shadow: none;
  transition: box-shadow var(--poc-trans);
}
.header-main .logo img { max-height: 42px; width: auto; }

@media (min-width: 992px) {
  /* Nav links */
  .navigation ul li.level0 > a {
    font-family: 'Cairo', sans-serif !important;
    font-size: 13px !important;
    font-weight: 700 !important;
    color: var(--poc-dark) !important;
    text-transform: uppercase !important;
    letter-spacing: 0.06em !important;
    padding: 7px 13px !important;
    border-radius: var(--poc-radius) !important;
    transition: all var(--poc-trans) !important;
  }
  .navigation ul li.level0 > a:hover,
  .navigation ul li.level0.active > a {
    color: var(--poc-blue) !important;
    background: var(--poc-blue-light) !important;
  }

  /* Nav dropdown */
  .navigation ul li.level0 .submenu {
    border: 1px solid var(--poc-border) !important;
    border-radius: var(--poc-radius-lg) !important;
    box-shadow: var(--poc-shadow-lg) !important;
    padding: 8px !important;
  }
  .navigation ul li.level0 .submenu a {
    font-size: 13px !important;
    color: var(--poc-text) !important;
    padding: 8px 12px !important;
    border-radius: var(--poc-radius) !important;
    transition: all var(--poc-trans) !important;
  }
  .navigation ul li.level0 .submenu a:hover {
    background: var(--poc-bg) !important;
    color: var(--poc-blue) !important;
  }
}

/* Header icons */
.search-toggle-icon,
.my-account,
.wishlist,
.minicart-wrapper .action.showcart {
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  width: 38px !important;
  height: 38px !important;
  border-radius: var(--poc-radius) !important;
  color: var(--poc-dark) !important;
  transition: all var(--poc-trans) !important;
}
.search-toggle-icon:hover,
.my-account:hover,
.wishlist:hover,
.minicart-wrapper .action.showcart:hover {
  background: var(--poc-bg) !important;
  color: var(--poc-blue) !important;
}

/* Cart badge */
.minicart-wrapper .action.showcart .counter.qty {
  background: var(--poc-blue) !important;
  color: #04342C !important;
  font-family: 'Cairo', sans-serif !important;
  font-size: 10px !important;
  font-weight: 700 !important;
  min-width: 18px !important;
  height: 18px !important;
  border-radius: 20px !important;
  line-height: 18px !important;
}

/* Search input */
#search, .search-form .input-text {
  font-family: 'Cairo', sans-serif !important;
  font-size: 14px !important;
  border: 1px solid var(--poc-border) !important;
  border-radius: var(--poc-radius) !important;
  padding: 10px 16px !important;
  background: var(--poc-bg) !important;
  transition: all var(--poc-trans) !important;
}
#search:focus, .search-form .input-text:focus {
  border-color: var(--poc-blue) !important;
  background: var(--poc-white) !important;
  box-shadow: 0 0 0 3px rgba(74,222,158,0.1) !important;
  outline: none !important;
}

/* ── BUTTONS ── */
.action.primary,
button.action.primary,
.btn-primary,
button[type="submit"],
.action.login,
.action.create,
.action.submit {
  font-family: 'Cairo', sans-serif !important;
  font-size: 14px !important;
  font-weight: 700 !important;
  text-transform: uppercase !important;
  letter-spacing: 0.07em !important;
  padding: 13px 28px !important;
  border-radius: var(--poc-radius) !important;
  background: var(--poc-blue) !important;
  color: #fff !important;
  border: none !important;
  cursor: pointer !important;
  transition: all var(--poc-trans) !important;
  box-shadow: 0 2px 8px rgba(74,222,158,0.25) !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  width: auto !important;
}
.action.primary:hover,
button.action.primary:hover,
button[type="submit"]:hover,
.action.login:hover,
.action.create:hover {
  background: var(--poc-blue-dark) !important;
  box-shadow: 0 4px 14px rgba(74,222,158,0.35) !important;
  transform: translateY(-1px) !important;
  color: #04342C !important;
  text-decoration: none !important;
}

.action.secondary,
.action.remind,
.action.back {
  font-family: 'Cairo', sans-serif !important;
  font-size: 13px !important;
  font-weight: 600 !important;
  padding: 11px 24px !important;
  border-radius: var(--poc-radius) !important;
  background: transparent !important;
  color: var(--poc-blue) !important;
  border: 1px solid var(--poc-blue) !important;
  transition: all var(--poc-trans) !important;
}
.action.secondary:hover,
.action.remind:hover {
  background: var(--poc-blue-light) !important;
  color: var(--poc-blue) !important;
}

/* ── FORMS & INPUTS ── */
.input-text,
select,
textarea,
input[type="text"],
input[type="email"],
input[type="password"],
input[type="tel"],
input[type="number"],
input[type="search"] {
  font-family: 'Cairo', sans-serif !important;
  font-size: 14px !important;
  color: var(--poc-dark) !important;
  border: 1px solid var(--poc-border) !important;
  border-radius: var(--poc-radius) !important;
  padding: 11px 14px !important;
  background: var(--poc-white) !important;
  width: 100% !important;
  transition: all var(--poc-trans) !important;
  box-shadow: none !important;
  appearance: none !important;
}
.input-text:focus,
select:focus,
textarea:focus,
input[type="text"]:focus,
input[type="email"]:focus,
input[type="password"]:focus {
  border-color: var(--poc-blue) !important;
  box-shadow: 0 0 0 3px rgba(74,222,158,0.1) !important;
  outline: none !important;
}
.input-text::placeholder { color: var(--poc-muted) !important; }
label,
.label {
  font-family: 'Cairo', sans-serif !important;
  font-size: 13px !important;
  font-weight: 600 !important;
  color: var(--poc-dark) !important;
  margin-bottom: 6px !important;
  display: block !important;
}
.field { margin-bottom: 18px; }
.required > .label::after { color:#e02b27 !important; }

/* ── LOGIN PAGE ── */
.customer-account-login .page-title-wrapper,
.customer-account-create .page-title-wrapper {
  background: linear-gradient(135deg, var(--poc-dark) 0%, #1a2230 100%);
  padding: 48px 0;
  margin-bottom: 40px;
}
.customer-account-login .page-title span,
.customer-account-create .page-title span {
  color: var(--poc-white) !important;
}
.login-container {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 32px;
  max-width: 860px;
  margin: 0 auto;
}
.block-customer-login,
.block-new-customer {
  background: var(--poc-white);
  border: 1px solid var(--poc-border);
  border-radius: var(--poc-radius-lg);
  padding: 32px;
  box-shadow: var(--poc-shadow-sm);
}
.block-customer-login .block-title,
.block-new-customer .block-title {
  font-size: 18px !important;
  font-weight: 800 !important;
  color: var(--poc-dark) !important;
  margin-bottom: 6px !important;
  border-bottom: none !important;
  padding-bottom: 0 !important;
}
.block-customer-login .block-title::after {
  content: '';
  display: block;
  width: 32px;
  height: 3px;
  background: var(--poc-blue);
  border-radius: 2px;
  margin-top: 8px;
  margin-bottom: 20px;
}
.block-new-customer .block-title::after {
  content: '';
  display: block;
  width: 32px;
  height: 3px;
  background: var(--poc-teal);
  border-radius: 2px;
  margin-top: 8px;
  margin-bottom: 20px;
}
.block-new-customer .block-content p {
  font-size: 13.5px;
  color: var(--poc-muted);
  line-height: 1.7;
  margin-bottom: 20px;
}
.action.remind {
  font-size: 12px !important;
  padding: 0 !important;
  border: none !important;
  background: none !important;
  color: var(--poc-blue) !important;
  box-shadow: none !important;
  display: inline !important;
}
.action.remind:hover { text-decoration: underline !important; }
@media (max-width: 767px) {
  .login-container { grid-template-columns: 1fr; }
}

/* ── ACCOUNT PAGES ── */
.account .page-title-wrapper {
  display: none !important;
  padding: 24px 0;
  margin-bottom: 24px;
  border-bottom: 1px solid var(--poc-border);
}
.account .page-title span { color: var(--poc-dark) !important; }

/* Account sidebar */
.account .sidebar-main .block-collapsible-nav {
  background: var(--poc-white);
  border: 1px solid var(--poc-border);
  border-radius: var(--poc-radius-lg);
  overflow: hidden;
  box-shadow: var(--poc-shadow-sm);
}
.account .sidebar-main .block-collapsible-nav .title {
  font-family: 'Cairo', sans-serif !important;
  font-size: 11px !important;
  font-weight: 700 !important;
  text-transform: uppercase !important;
  letter-spacing: 0.1em !important;
  color: var(--poc-muted) !important;
  padding: 14px 20px 10px !important;
  border-bottom: 1px solid var(--poc-border) !important;
  background: var(--poc-bg) !important;
}
.account .nav.items { list-style: none; padding: 8px 0; margin: 0; }
.account .nav.item a,
.account .nav.item strong {
  font-family: 'Cairo', sans-serif !important;
  font-size: 13.5px !important;
  font-weight: 500 !important;
  color: var(--poc-text) !important;
  padding: 9px 20px !important;
  display: flex !important;
  align-items: center !important;
  gap: 8px !important;
  transition: all var(--poc-trans) !important;
  border-left: 3px solid transparent !important;
  text-decoration: none !important;
}
.account .nav.item a:hover {
  background: var(--poc-bg) !important;
  color: var(--poc-blue) !important;
  border-left-color: var(--poc-blue) !important;
}
.account .nav.item.current a,
.account .nav.item.current strong {
  background: var(--poc-blue-light) !important;
  color: var(--poc-blue) !important;
  border-left-color: var(--poc-blue) !important;
  font-weight: 700 !important;
}

/* Account content area */
.account .column.main {
  background: var(--poc-white);
  border: 1px solid var(--poc-border);
  border-radius: var(--poc-radius-lg);
  padding: 32px;
  box-shadow: var(--poc-shadow-sm);
}

/* ═══════════════════════════════════════ */
/* ══ MOBILE BOTTOM NAV ═════════════════ */
/* ═══════════════════════════════════════ */

/* Hidden on desktop */
.poc-bottom-nav {
    display: none;
}

.poc-bn-search-overlay {
    display: none;
}

@media (max-width: 991px) {
    .poc-bottom-nav {
        display: flex !important;
        position: fixed !important;
        bottom: 0 !important;
        left: 0 !important;
        right: 0 !important;
        z-index: 9990 !important;
        background: #ffffff !important;
        border-top: 1px solid #f0f0f0 !important;
        box-shadow: 0 -4px 20px rgba(0,0,0,0.08) !important;
        padding: 12px 0 calc(12px + env(safe-area-inset-bottom, 0px)) !important;
        justify-content: space-around !important;
        align-items: center !important;
    }

    .poc-bn-item {
        display: flex !important;
        flex-direction: column !important;
        align-items: center !important;
        gap: 4px !important;
        text-decoration: none !important;
        color: #9ca3af !important;
        font-size: 11px !important;
        font-weight: 600 !important;
        padding: 4px 12px !important;
        transition: color 0.2s !important;
        -webkit-tap-highlight-color: transparent !important;
        position: relative !important;
        letter-spacing: 0.02em !important;
    }

    .poc-bn-item:hover,
    .poc-bn-item:active {
        color: #0d1117 !important;
        text-decoration: none !important;
    }

    .poc-bn-item svg {
        width: 24px !important;
        height: 24px !important;
        stroke-width: 1.6 !important;
    }

    .poc-bn-item span {
        font-size: 11px !important;
        line-height: 1 !important;
    }

    /* Active state */
    .poc-bn-item.active,
    .cms-poc-home .poc-bn-item[data-action="home"],
    .customer-account-index .poc-bn-item[data-action="account"],
    .customer-account-login .poc-bn-item[data-action="account"],
    .checkout-cart-index .poc-bn-item[data-action="cart"] {
        color: #3bb64a !important;
    }


    /* Add bottom padding to page so content isn't hidden behind nav */
    .page-wrapper {
        padding-bottom: 70px !important;
    }

    /* Hide header hamburger — bottom nav handles menu */
    .header-left .nav-toggle {
        display: none !important;
    }

    /* ── Search bar ── */
    .poc-bn-search-overlay {
        display: none !important;
        position: fixed !important;
        top: 0 !important;
        left: 0 !important;
        right: 0 !important;
        z-index: 10001 !important;
        background: #fff !important;
        box-shadow: 0 4px 16px rgba(0,0,0,0.1) !important;
        padding: 10px 14px !important;
    }

    .poc-bn-search-overlay.poc-search-open {
        display: block !important;
    }

    .poc-bn-search-bar {
        display: flex !important;
        align-items: center !important;
        gap: 8px !important;
    }

    .poc-bn-search-input {
        flex: 1 !important;
        border: 1.5px solid #e5e7eb !important;
        border-radius: 10px !important;
        padding: 10px 14px !important;
        font-size: 14px !important;
        height: 42px !important;
        outline: none !important;
        box-sizing: border-box !important;
        -webkit-appearance: none !important;
        background: #f9fafb !important;
        color: #0d1117 !important;
    }

    .poc-bn-search-input:focus {
        border-color: #3bb64a !important;
        background: #fff !important;
        box-shadow: 0 0 0 3px rgba(74,222,158,0.12) !important;
    }

    .poc-bn-search-submit {
        width: 42px !important;
        height: 42px !important;
        background: #3bb64a !important;
        border: none !important;
        border-radius: 10px !important;
        display: flex !important;
        align-items: center !important;
        justify-content: center !important;
        cursor: pointer !important;
        flex-shrink: 0 !important;
    }

    /* Hide back-to-top behind bottom nav */
    #totop {
        bottom: 80px !important;
    }

    /* Hide header signin button and cart on mobile — bottom nav handles them */
    .header-col.header-right #poc-header-signin-btn,
    .header-col.header-right .poc-header-cta,
    .header-col.header-right .poc-search-form,
    .header-main .header-col.header-right .search-area {
        display: none !important;
    }

    /* Also hide the "Hello, ahmed" button */
    .header-main .poc-header-cta,
    .header-main .greet.welcome,
    a[href*="customer/account"].poc-header-cta {
        display: none !important;
    }

    /* Header on mobile — logo left, cart right */
    .header-main .header.content .header-row {
        justify-content: space-between !important;
        padding: 10px 16px !important;
    }

    .header-main .header-left {
        display: flex !important;
        align-items: center !important;
        justify-content: flex-start !important;
        flex: 1 !important;
    }

    .header-main .header-col.header-right {
        display: flex !important;
        align-items: center !important;
    }

    /* Logo sizing on mobile */
    .header-main .logo img {
        max-height: 36px !important;
    }

    /* Cart badge on bottom nav */
    .poc-bn-item[data-action="cart"]::after {
        content: attr(data-count);
        position: absolute;
        top: -2px;
        right: 2px;
        min-width: 16px;
        height: 16px;
        background: #3bb64a;
        color: #0d1117;
        font-size: 9px;
        font-weight: 800;
        border-radius: 8px;
        display: none;
        align-items: center;
        justify-content: center;
        padding: 0 4px;
    }

    .poc-bn-item[data-action="cart"][data-count]::after {
        display: flex;
    }
}

@media (max-width: 991px) {
  .account .column.main {
      padding: 10px !important;
  }
}

/* Account tables */
.account .table-wrapper {
  border: 1px solid var(--poc-border);
  border-radius: var(--poc-radius-lg);
  overflow: hidden;
  margin-bottom: 24px;
}
.account table thead th {
  font-family: 'Cairo', sans-serif !important;
  font-size: 11px !important;
  font-weight: 700 !important;
  text-transform: uppercase !important;
  letter-spacing: 0.08em !important;
  color: var(--poc-muted) !important;
  background: var(--poc-bg) !important;
  padding: 12px 18px !important;
  border-bottom: 1px solid var(--poc-border) !important;
}
.account table tbody td {
  font-size: 13.5px !important;
  padding: 13px 18px !important;
  border-bottom: 1px solid var(--poc-border) !important;
  color: var(--poc-text) !important;
  vertical-align: middle !important;
}
.account table tbody tr:last-child td { border-bottom: none !important; }
.account table tbody tr:hover td { background: var(--poc-bg) !important; }

/* ── PRODUCT PAGE ── */
.catalog-product-view .page-title-wrapper {
  background: var(--poc-white);
  padding: 0px;
  margin-bottom: 0;
  border-bottom: none;
}
.catalog-product-view .page-title span {
  font-size: clamp(22px, 2.8vw, 34px) !important;
  font-weight: 800 !important;
  color: var(--poc-dark) !important;
}
.product-info-main { padding-left: 32px; }
.product-info-price {
  margin-bottom: 20px;
  padding-bottom: 20px;
  border-bottom: 1px solid var(--poc-border);
}
.product-info-price .price {
  font-size: 34px !important;
  font-weight: 800 !important;
  color: var(--poc-dark) !important;
}
.product.attribute.overview {
  font-size: 14px;
  color: var(--poc-muted);
  line-height: 1.75;
  margin-bottom: 24px;
  padding-bottom: 20px;
  border-bottom: 1px solid var(--poc-border);
}

/* Gallery */
.fotorama__stage {
  border-radius: var(--poc-radius-lg) !important;
  overflow: hidden !important;
  background: var(--poc-bg) !important;
  border: 1px solid var(--poc-border) !important;
}
.fotorama__thumb {
  border-radius: var(--poc-radius) !important;
  border: 2px solid transparent !important;
  transition: border-color var(--poc-trans) !important;
}
.fotorama__active .fotorama__thumb,
.fotorama__thumb--nav:hover { border-color: var(--poc-blue) !important; }

/* Product tabs */
.product.data.items {
  border: 1px solid var(--poc-border) !important;
  border-radius: var(--poc-radius-lg) !important;
  overflow: hidden !important;
  margin-top: 48px !important;
}
.product.data.items > .item.title > .switch {
  font-family: 'Cairo', sans-serif !important;
  font-size: 13px !important;
  font-weight: 600 !important;
  color: var(--poc-muted) !important;
  background: var(--poc-bg) !important;
  border: none !important;
  border-right: 1px solid var(--poc-border) !important;
  border-bottom: 1px solid var(--poc-border) !important;
  padding: 14px 24px !important;
  transition: all var(--poc-trans) !important;
}
.product.data.items > .item.title > .switch:hover {
  color: var(--poc-dark) !important;
  background: var(--poc-white) !important;
}
.product.data.items > .item.title.active > .switch {
  color: var(--poc-blue) !important;
  background: var(--poc-white) !important;
  border-bottom-color: var(--poc-white) !important;
  font-weight: 700 !important;
}
.product.data.items > .item.content {
  padding: 32px !important;
  border: none !important;
  font-size: 14px !important;
  line-height: 1.8 !important;
  color: var(--poc-text) !important;
}

/* ── SUPPORT / HELPDESK PAGE ── */
.page-title-wrapper .page-title span { font-weight: 800 !important; }

/* Support ticket table */
.helpdesk-table,
table.data-table {
  border: 1px solid var(--poc-border) !important;
  border-radius: var(--poc-radius-lg) !important;
  overflow: hidden !important;
  width: 100% !important;
  border-collapse: collapse !important;
}
.helpdesk-table thead th,
table.data-table thead th {
  font-family: 'Cairo', sans-serif !important;
  font-size: 11px !important;
  font-weight: 700 !important;
  text-transform: uppercase !important;
  letter-spacing: 0.08em !important;
  color: var(--poc-muted) !important;
  background: var(--poc-bg) !important;
  padding: 13px 18px !important;
  border-bottom: 1px solid var(--poc-border) !important;
  text-align: left !important;
}
.helpdesk-table tbody td,
table.data-table tbody td {
  font-size: 13.5px !important;
  padding: 13px 18px !important;
  border-bottom: 1px solid var(--poc-border) !important;
  color: var(--poc-text) !important;
  vertical-align: middle !important;
}
.helpdesk-table tbody tr:last-child td,
table.data-table tbody tr:last-child td { border-bottom: none !important; }
.helpdesk-table tbody tr:hover td,
table.data-table tbody tr:hover td { background: var(--poc-bg) !important; }

/* Status badge */
.status-open, a.status-open {
  display: inline-flex !important;
  align-items: center !important;
  gap: 5px !important;
  font-size: 11px !important;
  font-weight: 700 !important;
  text-transform: uppercase !important;
  letter-spacing: 0.06em !important;
  color: #166534 !important;
  background: #d1fae5 !important;
  padding: 3px 10px !important;
  border-radius: 20px !important;
}

/* Helpdesk form */
.helpdesk-new-ticket h2,
.helpdesk-new-ticket h3 {
  font-size: 18px !important;
  font-weight: 800 !important;
  color: var(--poc-dark) !important;
  margin-bottom: 20px !important;
  padding-bottom: 14px !important;
  border-bottom: 1px solid var(--poc-border) !important;
}
.helpdesk-new-ticket .fieldset,
.helpdesk-new-ticket form {
  background: var(--poc-white) !important;
  border: 1px solid var(--poc-border) !important;
  border-radius: var(--poc-radius-lg) !important;
  padding: 28px !important;
  margin-top: 16px !important;
}

/* ── MESSAGES ── */
.message.success, .message-success {
  background: #f0fdf4 !important;
  border: 1px solid #bbf7d0 !important;
  border-radius: var(--poc-radius) !important;
  color: #166534 !important;
  font-size: 13.5px !important;
  font-family: 'Cairo', sans-serif !important;
}
.message.error, .message-error {
  background: #fef2f2 !important;
  border: 1px solid #fecaca !important;
  border-radius: var(--poc-radius) !important;
  color: #991b1b !important;
  font-size: 13.5px !important;
}
.message.notice, .message-notice, .message.info {
  background: #eff6ff !important;
  border: 1px solid #bfdbfe !important;
  border-radius: var(--poc-radius) !important;
  color: #1e40af !important;
  font-size: 13.5px !important;
}

/* ── FOOTER ── */
.footer.content,
.page-footer {
  background: var(--poc-dark) !important;
  color: rgba(255,255,255,0.6) !important;
  border-top: none !important;
  padding: 0 0 0 !important;
}
.footer.content *,
.page-footer * { color: rgba(255,255,255,0.6); }
.footer.content h4,
.footer.content .block-title,
.footer.content .widget-title {
  font-size: 11px !important;
  font-weight: 700 !important;
  text-transform: uppercase !important;
  letter-spacing: 0.12em !important;
  color: rgba(255,255,255,0.35) !important;
  margin-bottom: 14px !important;
}
.footer.content a {
  font-size: 13.5px !important;
  color: rgba(255,255,255,0.6) !important;
  display: block !important;
  margin-bottom: 8px !important;
  transition: color var(--poc-trans) !important;
  text-decoration: none !important;
}
.footer.content a:hover { color: var(--poc-white) !important; }
.footer-bottom,
.footer.content .copyright {
  border-top: 1px solid rgba(255,255,255,0.08) !important;
  margin-top: 40px !important;
  padding: 18px 0 !important;
  font-size: 12px !important;
  color: rgba(255,255,255,0.3) !important;
  text-align: center !important;
}

/* ── MINICART ── */
.minicart-wrapper .block-minicart {
  border: 1px solid var(--poc-border) !important;
  box-shadow: var(--poc-shadow-lg) !important;
  padding: 20px !important;
  width: 340px !important;
}
.minicart-wrapper .block-minicart .block-title {
  font-size: 15px !important;
  font-weight: 700 !important;
  color: var(--poc-dark) !important;
  margin-bottom: 16px !important;
  padding-bottom: 14px !important;
  border-bottom: 1px solid var(--poc-border) !important;
}
.minicart-wrapper .action.checkout {
  background: var(--poc-blue) !important;
  color: #fff !important;
  width: 100% !important;
  text-align: center !important;
  padding: 13px !important;
  border-radius: var(--poc-radius) !important;
  font-size: 13px !important;
  font-weight: 700 !important;
  text-transform: uppercase !important;
  letter-spacing: 0.07em !important;
  margin-top: 12px !important;
  display: block !important;
  transition: all var(--poc-trans) !important;
}
.minicart-wrapper .action.checkout:hover {
  background: var(--poc-blue-dark) !important;
  text-decoration: none !important;
  color: #fff !important;
}

/* ── BACK TO TOP ── */
#totop {
  width: 40px !important;
  height: 40px !important;
  border-radius: var(--poc-radius) !important;
  background: var(--poc-dark) !important;
  color: var(--poc-white) !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  transition: all var(--poc-trans) !important;
  box-shadow: var(--poc-shadow) !important;
}
#totop:hover {
  background: var(--poc-blue) !important;
  color: #04342C !important;
  transform: translateY(-2px) !important;
}

/* ── UTILITIES ── */
.product-item-info:hover { box-shadow: none !important; }
hr { border: none !important; border-top: 1px solid var(--poc-border) !important; margin: 28px 0 !important; }

/* ── POC ICON ALIASES ── */
[class*="poc-icon-"] {
  font-family: 'porto-icons' !important;
  speak: none;
  font-style: normal;
  font-weight: normal;
  font-variant: normal;
  text-transform: none;
  -webkit-font-smoothing: antialiased;
}
.poc-icon-cart-thick-1::before { content: '\e829'; }
.poc-icon-magnifier::before    { content: '\e884'; }
.poc-icon-chart::before        { content: '\e88f'; }
.poc-icon-user-2::before       { content: '\e91a'; }
.poc-icon-wishlist-2::before   { content: '\e91b'; }
.poc-icon-up-open::before      { content: '\f800'; }

/* ── HIDE PORTO COPYRIGHT ── */
.porto-copyright, p.porto-copyright { display: none !important; }

/* ── RESPONSIVE ── */
@media (max-width: 768px) {
  .product-info-main { padding-left: 0; margin-top: 24px; }
  .minicart-wrapper .block-minicart { width: 300px !important; }
  .login-container { grid-template-columns: 1fr; }
}

/* ════════════════════════════════════════════════════════
   POC FIXES — Login page, header, footer
   ════════════════════════════════════════════════════════ */

/* ── LOGIN PAGE ── */

.customer-account-login .login-container {
  display: grid !important;
  grid-template-columns: 1fr 1fr !important;
  gap: 32px !important;
  max-width: 900px !important;
  margin: 40px auto !important;
  padding: 0 20px !important;
  align-items: start !important;
}

.block-customer-login,
.block-new-customer {
  background: #ffffff !important;
  border: 1px solid #e5e7eb !important;
  border-radius: 12px !important;
  padding: 36px !important;
  box-shadow: 0 1px 3px rgba(0,0,0,0.08) !important;
  width: 100% !important;
}

.block-customer-login .block-title strong,
.block-new-customer .block-title strong {
  font-size: 20px !important;
  font-weight: 800 !important;
  color: #0d1117 !important;
  display: block !important;
  margin-bottom: 20px !important;
  padding-bottom: 14px !important;
  border-bottom: 2px solid #3bb64a !important;
}

.block-new-customer .block-title strong {
  border-bottom-color: #3bb64a !important;
}

.block-customer-login .block-title,
.block-new-customer .block-title {
  border: none !important;
  margin-bottom: 0 !important;
  padding-bottom: 0 !important;
}

.customer-account-login .action.remind {
  font-size: 13px !important;
  color: #3bb64a !important;
  background: none !important;
  border: none !important;
  box-shadow: none !important;
  padding: 0 !important;
  display: inline !important;
  transform: none !important;
  font-weight: 500 !important;
  text-decoration: none !important;
}
.customer-account-login .action.remind:hover {
  text-decoration: underline !important;
  transform: none !important;
  background: none !important;
  box-shadow: none !important;
}

.customer-account-login .action.login {
  width: 100% !important;
  justify-content: center !important;
  margin-top: 8px !important;
}

.block-new-customer .action.create {
  width: 100% !important;
  justify-content: center !important;
  background: #0d6e48 !important;
  box-shadow: 0 2px 8px rgba(13,110,72,0.25) !important;
  border-color: #0d6e48 !important;
}
.block-new-customer .action.create:hover {
  background: #0a5a3a !important;
  box-shadow: 0 4px 14px rgba(13,110,72,0.35) !important;
}

.customer-account-login .column.main > .actions-toolbar {
  display: none !important;
}

.customer-account-login .page-title-wrapper {
  background: #0d1117 !important;
  padding: 40px 0 !important;
  margin-bottom: 0 !important;
  border-bottom: none !important;
}
.customer-account-login .page-title span {
  color: #ffffff !important;
  font-size: 28px !important;
}

/* ── HEADER ── */
.header-main {
  padding: 0 !important;
  border-bottom: 1px solid #e5e7eb !important;
}
.header-main .header.content {
  padding: 14px 0 !important;
  display: flex !important;
  align-items: center !important;
  gap: 24px !important;
}
@media (min-width: 992px) {
  .navigation ul {
    display: flex !important;
    align-items: center !important;
    gap: 4px !important;
  }
}

/* ── FOOTER ── */
.page-footer {
  background: #ffffff !important;
}
.footer.content {
  padding: 56px 0 0 !important;
}
.footer.content .copyright {
  border-top: 1px solid rgba(255,255,255,0.08) !important;
  margin-top: 48px !important;
  padding: 20px 0 !important;
  font-size: 12px !important;
  color: rgba(255,255,255,0.3) !important;
  text-align: center !important;
  display: block !important;
}

/* ── BUTTON HOVER FIX ── */
.action.remind:hover,
.action.back:hover {
  transform: none !important;
}

/* ── RESPONSIVE ── */
@media (max-width: 767px) {
  .customer-account-login .login-container {
    grid-template-columns: 1fr !important;
    margin: 24px auto !important;
  }
}

/* ── Login Popup Modal ── */
#poc-login-overlay {
    position: fixed;
    inset: 0;
    background: rgba(13,17,23,0.55);
    z-index: 99999;
    display: flex;
    align-items: center;
    justify-content: center;
    backdrop-filter: blur(3px);
    -webkit-backdrop-filter: blur(3px);
    padding: 20px;
}
#poc-login-modal {
    background: #ffffff;
    border-radius: 16px;
    padding: 44px 48px;
    width: 100%;
    max-width: 460px;
    position: relative;
    box-shadow: 0 24px 64px rgba(0,0,0,0.18);
    animation: pocModalIn 0.22s ease;
}
@keyframes pocModalIn {
    from { opacity: 0; transform: translateY(-12px) scale(0.98); }
    to   { opacity: 1; transform: translateY(0) scale(1); }
}
#poc-modal-close {
    position: absolute;
    top: 16px;
    right: 16px;
    width: 32px;
    height: 32px;
    border-radius: 8px;
    border: none;
    background: #f3f4f6;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: background 0.15s;
    padding: 0;
}
#poc-modal-close:hover { background: #e5e7eb; }
.poc-modal-header {
    text-align: center;
    margin-bottom: 28px;
}
.poc-modal-header h2 {
    font-size: 24px !important;
    font-weight: 800 !important;
    color: #0d1117 !important;
    margin: 0 0 6px !important;
    padding: 0 !important;
    border: none !important;
    background: none !important;
    letter-spacing: -0.02em !important;
}
.poc-modal-header p {
    font-size: 13.5px;
    color: #6b7280;
    margin: 0;
}
.poc-modal-field {
    margin-bottom: 18px;
}
.poc-modal-label-row {
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin-bottom: 7px;
}
.poc-modal-field label {
    font-size: 13px !important;
    font-weight: 600 !important;
    color: #0d1117 !important;
    display: block !important;
    margin-bottom: 7px !important;
}
.poc-modal-label-row label { margin-bottom: 0 !important; }
.poc-modal-field label span { color: #3bb64a; }
.poc-modal-field input {
    width: 100% !important;
    padding: 12px 14px !important;
    border: 1.5px solid #e5e7eb !important;
    border-radius: 8px !important;
    font-size: 14px !important;
    color: #0d1117 !important;
    background: #f9fafb !important;
    transition: border-color 0.18s, box-shadow 0.18s !important;
    outline: none !important;
    box-shadow: none !important;
    display: block !important;
}
.poc-modal-field input:focus {
    border-color: #3bb64a !important;
    background: #ffffff !important;
    box-shadow: 0 0 0 3px rgba(74,222,158,0.1) !important;
}
.poc-modal-forgot {
    font-size: 12px;
    color: #3bb64a;
    text-decoration: none;
    font-weight: 500;
}
.poc-modal-forgot:hover { text-decoration: underline; }
#poc-modal-error {
    background: #fef2f2;
    border: 1px solid #fecaca;
    border-radius: 8px;
    color: #991b1b;
    font-size: 13px;
    padding: 10px 14px;
    margin-bottom: 14px;
}
.poc-modal-btn-primary {
    width: 100% !important;
    padding: 14px !important;
    background: #3bb64a !important;
    color: #04342C !important;
    border: none !important;
    border-radius: 8px !important;
    font-size: 14px !important;
    font-weight: 700 !important;
    text-transform: uppercase !important;
    letter-spacing: 0.07em !important;
    cursor: pointer !important;
    transition: background 0.18s, box-shadow 0.18s, transform 0.18s !important;
    display: block !important;
    text-align: center !important;
    box-shadow: 0 2px 8px rgba(74,222,158,0.25) !important;
    margin-bottom: 12px !important;
}
.poc-modal-btn-primary:hover {
    background: #3bb64a !important;
    box-shadow: 0 4px 14px rgba(74,222,158,0.35) !important;
    transform: translateY(-1px) !important;
}
.poc-modal-btn-primary:disabled {
    opacity: 0.7 !important;
    cursor: not-allowed !important;
    transform: none !important;
}
.poc-modal-divider {
    text-align: center;
    position: relative;
    margin: 4px 0 12px;
}
.poc-modal-divider::before {
    content: '';
    position: absolute;
    top: 50%; left: 0; right: 0;
    height: 1px;
    background: #e5e7eb;
}
.poc-modal-divider span {
    position: relative;
    background: #ffffff;
    padding: 0 12px;
    font-size: 11px;
    color: #9ca3af;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.06em;
}
.poc-modal-btn-secondary {
    width: 100% !important;
    padding: 13px !important;
    background: transparent !important;
    color: #3bb64a !important;
    border: 1.5px solid #3bb64a !important;
    border-radius: 8px !important;
    font-size: 14px !important;
    font-weight: 700 !important;
    text-transform: uppercase !important;
    letter-spacing: 0.07em !important;
    display: block !important;
    text-align: center !important;
    text-decoration: none !important;
    transition: background 0.18s !important;
}
.poc-modal-btn-secondary:hover {
    background: #eef2fb !important;
    color: #3bb64a !important;
    text-decoration: none !important;
}
body.poc-modal-open { overflow: hidden !important; }
@media (max-width: 500px) {
    #poc-login-modal { padding: 32px 24px; }
}

/* ===================================================
   ACCOUNT PAGE LAYOUT — loaded last (order=9999),
   beats Porto styles-l.css on all rules
   =================================================== */

body.account .page-wrapper {
    background: #f0f2f5;
}

/* Force flex on columns regardless of Porto's display:block */
body.account .columns {
    display: flex !important;
    flex-direction: row !important;
    flex-wrap: nowrap !important;
    gap: 28px !important;
    align-items: flex-start !important;
    width: 100% !important;
    box-sizing: border-box !important;
    max-width: 1400px !important;
    margin: 0 auto !important;
}

/* Kill Porto clearfix pseudos that create stray flex items */
body.account .columns::before,
body.account .columns::after {
    display: none !important;
    content: none !important;
}

/* Sidebar: fixed 260px column, visually first (order:1 < main order:2) */
body.account .sidebar.sidebar-main {
    display: block !important;
    flex: 0 0 260px !important;
    width: 260px !important;
    min-width: 260px !important;
    max-width: 260px !important;
    float: none !important;
    order: 1 !important;
    padding: 0 !important;
    margin: 0 !important;
}

/* Main: fills remaining space */
body.account .column.main {
    display: block !important;
    flex: 1 1 auto !important;
    min-width: 0 !important;
    width: auto !important;
    max-width: none !important;
    float: none !important;
    order: 2 !important;
    padding: 0 !important;
    margin: 0 !important;
}

/* Hide Porto's collapsible nav — our sidebar replaces it */
body.account .sidebar.sidebar-main .block-collapsible-nav {
    display: none !important;
}

/* Desktop: hide mobile tabs */
@media (min-width: 769px) {
    .poc-account-tabs-wrap {
        display: none !important;
    }
}

/* Mobile: collapse to single column, hide sidebar, show tabs */
@media (max-width: 768px) {
    body.account .columns {
        flex-direction: column !important;
        padding: 16px !important;
        gap: 16px !important;
        max-width: 100% !important;
    }
    body.account .sidebar.sidebar-main {
        display: none !important;
        flex: none !important;
        width: 100% !important;
        min-width: unset !important;
        max-width: unset !important;
    }
    body.account .column.main {
        width: 100% !important;
        flex: 1 0 100% !important;
    }
    .poc-account-tabs-wrap {
        display: block !important;
    }
}

/* HelpDesk ticket page */
body.pointofcodehelpdesk-ticket-index .page-title-wrapper,
body.pointofcodehelpdesk-ticket-view .page-title-wrapper {
    display: none !important;
}

/* ===== HELPDESK TICKET PAGE ===== */

/* Remove Porto interference on tabs */
body.pointofcodehelpdesk-ticket-index .poc-ticket-tabs {
    display: flex !important;
    gap: 0 !important;
    border-bottom: 2px solid #f3f4f6 !important;
    margin-bottom: 28px !important;
    background: transparent !important;
    padding: 0 !important;
}

body.pointofcodehelpdesk-ticket-index .poc-ticket-tab {
    padding: 14px 28px !important;
    font-size: 14px !important;
    font-weight: 600 !important;
    color: #6b7280 !important;
    cursor: pointer !important;
    border: none !important;
    border-bottom: 2px solid transparent !important;
    margin-bottom: -2px !important;
    transition: all 0.2s !important;
    background: transparent !important;
    outline: none !important;
    box-shadow: none !important;
}

body.pointofcodehelpdesk-ticket-index .poc-ticket-tab:hover {
    color: #0d1117 !important;
    background: transparent !important;
    border-bottom-color: #e5e7eb !important;
}

body.pointofcodehelpdesk-ticket-index .poc-ticket-tab.active {
    color: #0d1117 !important;
    border-bottom-color: #3bb64a !important;
    background: transparent !important;
}

body.pointofcodehelpdesk-ticket-index .poc-ticket-tab:focus,
body.pointofcodehelpdesk-ticket-index .poc-ticket-tab:active {
    outline: none !important;
    box-shadow: none !important;
    background: transparent !important;
}

/* Ticket card */
body.pointofcodehelpdesk-ticket-index .poc-ticket-card {
    background: #fff !important;
    border-radius: 14px !important;
    box-shadow: 0 1px 4px rgba(0,0,0,0.06) !important;
    border: 1px solid #f0f0f0 !important;
    overflow: hidden !important;
}

/* Table */
body.pointofcodehelpdesk-ticket-index .poc-ticket-table {
    border: none !important;
}

body.pointofcodehelpdesk-ticket-index .poc-ticket-table thead th {
    font-size: 11px !important;
    font-weight: 700 !important;
    text-transform: uppercase !important;
    letter-spacing: 0.5px !important;
    color: #9ca3af !important;
    padding: 14px 20px !important;
    border-bottom: 1px solid #f3f4f6 !important;
    background: #f9fafb !important;
    border-top: none !important;
}

body.pointofcodehelpdesk-ticket-index .poc-ticket-table tbody td {
    padding: 16px 20px !important;
    font-size: 14px !important;
    color: #374151 !important;
    border-bottom: 1px solid #f9fafb !important;
    border-top: none !important;
}

body.pointofcodehelpdesk-ticket-index .poc-ticket-table tbody tr:hover td {
    background: #f9fafb !important;
}

/* Create form card */
body.pointofcodehelpdesk-ticket-index .poc-create-card {
    background: #fff !important;
    border-radius: 14px !important;
    padding: 32px !important;
    box-shadow: 0 1px 4px rgba(0,0,0,0.06) !important;
    border: 1px solid #f0f0f0 !important;
}

/* Form fields */
body.pointofcodehelpdesk-ticket-index .poc-form-field label {
    font-size: 13px !important;
    font-weight: 600 !important;
    color: #374151 !important;
    margin-bottom: 6px !important;
    display: block !important;
}

body.pointofcodehelpdesk-ticket-index .poc-form-field label em {
    color: #ef4444 !important;
    font-style: normal !important;
}

body.pointofcodehelpdesk-ticket-index .poc-form-field input[type="text"],
body.pointofcodehelpdesk-ticket-index .poc-form-field select,
body.pointofcodehelpdesk-ticket-index .poc-form-field textarea {
    width: 100% !important;
    padding: 12px 14px !important;
    border: 1.5px solid #e5e7eb !important;
    border-radius: 8px !important;
    font-size: 14px !important;
    color: #0d1117 !important;
    box-sizing: border-box !important;
    transition: border-color 0.2s !important;
    background: #fff !important;
    font-family: inherit !important;
    height: auto !important;
    box-shadow: none !important;
}

body.pointofcodehelpdesk-ticket-index .poc-form-field input:focus,
body.pointofcodehelpdesk-ticket-index .poc-form-field select:focus,
body.pointofcodehelpdesk-ticket-index .poc-form-field textarea:focus {
    border-color: #3bb64a !important;
    outline: none !important;
    box-shadow: 0 0 0 3px rgba(74,222,158,0.1) !important;
}

body.pointofcodehelpdesk-ticket-index .poc-form-field textarea {
    min-height: 140px !important;
    resize: vertical !important;
}

/* Attachment area */
body.pointofcodehelpdesk-ticket-index .poc-form-attachment {
    padding: 20px !important;
    background: #f9fafb !important;
    border-radius: 10px !important;
    border: 1.5px dashed #d1d5db !important;
    margin-bottom: 20px !important;
}

body.pointofcodehelpdesk-ticket-index .poc-form-attachment label {
    font-size: 13px !important;
    color: #6b7280 !important;
    font-weight: 500 !important;
    margin-bottom: 10px !important;
    display: block !important;
}

/* Submit button full width */
body.pointofcodehelpdesk-ticket-index .poc-submit-btn {
    width: 100% !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    padding: 16px !important;
    background: #3bb64a !important;
    color: #fff !important;
    border: none !important;
    border-radius: 10px !important;
    font-size: 15px !important;
    font-weight: 700 !important;
    cursor: pointer !important;
    transition: all 0.2s !important;
    text-transform: uppercase !important;
    letter-spacing: 0.5px !important;
    box-shadow: 0 4px 14px rgba(74,222,158,0.3) !important;
    margin-top: 8px !important;
}

body.pointofcodehelpdesk-ticket-index .poc-submit-btn:hover {
    background: #2ab87a !important;
    color: #fff !important;
    box-shadow: 0 6px 20px rgba(42,184,122,0.45) !important;
}

/* Status badges */
body.pointofcodehelpdesk-ticket-index .poc-ticket-status {
    display: inline-flex !important;
    align-items: center !important;
    gap: 6px !important;
    font-size: 12px !important;
    font-weight: 600 !important;
    padding: 5px 14px !important;
    border-radius: 20px !important;
}

/* Main content card */
body.pointofcodehelpdesk-ticket-index .column.main {
    background: transparent !important;
    box-shadow: none !important;
    border: none !important;
    padding: 0 !important;
}

/* Grid spacing */
body.pointofcodehelpdesk-ticket-index .poc-form-grid {
    gap: 20px !important;
    margin-bottom: 20px !important;
}

body.pointofcodehelpdesk-ticket-index .poc-form-grid-2 {
    gap: 20px !important;
    margin-bottom: 20px !important;
}

body.pointofcodehelpdesk-ticket-index .poc-form-full {
    margin-bottom: 20px !important;
}

/* ═══════════════════════════════════════ */
/* ══ MOBILE RESPONSIVE ═════════════════ */
/* ═══════════════════════════════════════ */

/* Remove white overlay/shadow from page-main-inner on all pages */
.page-main-inner {
    background: transparent !important;
    box-shadow: none !important;
    border: none !important;
}

@media (max-width: 991px) {

    /* Let Porto handle its own mobile header — don't override */

    /* Show Porto hamburger menu on mobile */
    .nav-toggle {
        display: block !important;
        position: relative !important;
        order: -1 !important;
        z-index: 1 !important;
        width: 28px !important;
        height: 28px !important;
        flex-shrink: 0 !important;
    }

    /* Shrink signin button on mobile instead of hiding */
    #poc-header-signin-btn,
    .poc-header-cta {
        padding: 6px 14px !important;
        font-size: 12px !important;
    }

    /* Product page 2-col to single col */
    .poc-product-layout {
        grid-template-columns: 1fr !important;
        gap: 16px !important;
    }

    .poc-product-card {
        position: static !important;
    }

    /* Checkout single col */
    .poc-co-layout {
        grid-template-columns: 1fr !important;
        gap: 16px !important;
    }

    /* Account sidebar hide — mobile uses tabs */
    body.account .sidebar.sidebar-main {
        display: none !important;
    }

    body.account .columns {
        flex-direction: column !important;
    }

    /* Dashboard grid single col */
    .poc-dashboard-grid {
        grid-template-columns: 1fr !important;
    }

    /* Ticket form grid single col */
    .poc-form-grid {
        grid-template-columns: 1fr !important;
    }

    .poc-form-grid-2 {
        grid-template-columns: 1fr !important;
    }
}

@media (max-width: 767px) {

    /* Product title smaller */
    .poc-product-left .page-title-wrapper h1.page-title {
        font-size: 20px !important;
    }

    /* Product card */
    .poc-product-card {
        padding: 18px !important;
        border-radius: 12px !important;
    }

    .poc-product-card .price-box .price {
        font-size: 24px !important;
    }

    /* Login page single col */
    .customer-account-login .login-container {
        flex-direction: column !important;
    }

    /* Hamburger menu icon */
    .nav-toggle {
        display: block !important;
        cursor: pointer !important;
        width: 28px !important;
        height: 28px !important;
        position: relative !important;
        z-index: 1 !important;
    }

    .nav-toggle::before {
        content: '\f0c9' !important;
        font-family: 'Font Awesome 5 Free', 'FontAwesome' !important;
        font-weight: 900 !important;
        font-size: 20px !important;
        color: #0d1117 !important;
        display: flex !important;
        align-items: center !important;
        justify-content: center !important;
        width: 100% !important;
        height: 100% !important;
    }

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

    /* Header layout on mobile — hamburger | logo | signin | cart */
    .header-main .header.content .header-row {
        display: flex !important;
        align-items: center !important;
    }

    .header-main .header-col.header-right {
        display: flex !important;
        align-items: center !important;
        gap: 8px !important;
    }

    /* Sign in button smaller */
    #poc-header-signin-btn,
    .poc-header-cta {
        padding: 6px 14px !important;
        font-size: 11px !important;
        border-radius: 6px !important;
    }
}

.columns .column.main{

  padding-bottom: 0px !important;
}

body {
  display: flex;
  flex-direction: column;
  min-height: 100vh;
}

.page-wrapper {
  display: flex;
  flex-direction: column;
  flex: 1;
}

.page-main {
  flex: 1;
}

.minicart-wrapper.minicart-offcanvas .minicart-overlay svg {
  top: 0px !important;
  right: 340px !important;
}
a.action.viewcart {
  display: none;
}

.page-product-downloadable .product-options-wrapper {
  width: 100% !important;
}
.page-product-downloadable .product-options-bottom {
  width: 100% !important;
}

.product-social-links{

  display:none !important;
}

/* Empty cart page redesign — fixed */
body.checkout-cart-index .page-title-wrapper {
  display: none !important;
}

body.checkout-cart-index .cart-empty.text-center {
  display: flex !important;
  flex-direction: column;
  align-items: center;
  justify-content: flex-start;
  text-align: center;
  padding: 80px 20px !important;
  border: none !important;
}

body.checkout-cart-index .cart-empty.text-center > * {
  flex: none !important;
}

body.checkout-cart-index i.cart-empty.porto-icon-bag-2 {
  display: inline-flex !important;
  align-items: center;
  justify-content: center;
  font-size: 56px;
  color: #bdcab8;
  width: 90px;
  height: 90px;
  border-radius: 50%;
  background: #f2f4f6;
  margin: 0 auto 24px !important;
}

body.checkout-cart-index p.cart-empty {
  font-family: 'Cairo', sans-serif;
  font-size: 15px;
  color: #6e7b6a;
  margin: 0 0 28px !important;
  max-width: 380px;
}

body.checkout-cart-index .return-to-shop {
  margin: 0 !important;
}

body.checkout-cart-index .btn-go-shop {
  display: inline-flex !important;
  align-items: center;
  gap: 8px;
  background: #3bb64a !important;
  color: #fff !important;
  padding: 13px 32px !important;
  border-radius: 8px !important;
  font-family: 'Cairo', sans-serif;
  font-size: 14px;
  font-weight: 700;
  text-decoration: none !important;
  transition: all 0.2s;
  border: none !important;
}

body.checkout-cart-index .btn-go-shop:hover {
  background: #2ea33d !important;
  transform: translateY(-2px);
  box-shadow: 0 8px 20px rgba(59,182,74,0.25);
  color: #fff !important;
}