/* GLITCHZONE UI polish layer: spacing, touch comfort, and responsive smoothing. */
:root{
  --gz-page-x:clamp(16px,3vw,32px);
  --gz-page-y:clamp(28px,5vw,56px);
  --gz-gap-sm:10px;
  --gz-gap:16px;
  --gz-gap-lg:24px;
  --gz-touch:44px;
  --gz-focus:0 0 0 3px rgba(17,24,39,.14);
  --gz-radius:12px;
  --gz-radius-sm:8px;
  --gz-max-page:1440px;
  --gz-skeleton-base:rgba(17,24,39,.055);
  --gz-skeleton-shine:rgba(255,255,255,.82);
}

*,
*::before,
*::after{
  box-sizing:border-box;
}

html{
  -webkit-text-size-adjust:100%;
  text-size-adjust:100%;
  scroll-padding-top:92px;
}

body{
  text-rendering:optimizeLegibility;
  -webkit-font-smoothing:antialiased;
  overflow-wrap:anywhere;
  min-width:320px;
}

img,
picture,
svg,
video,
canvas{
  max-width:100%;
}

img,
video{
  height:auto;
}

.gz-img-loading{
  filter:blur(18px);
  opacity:.62;
  transform:scale(1.015);
}

.gz-img-loaded{
  filter:none;
  opacity:1;
  transform:none;
  transition:filter .28s ease,opacity .28s ease,transform .28s ease;
}

.gz-content-loading{
  position:relative;
  overflow:hidden;
  filter:blur(3px);
  opacity:.78;
  transform:translateY(4px);
  transition:filter .22s ease,opacity .22s ease,transform .22s ease;
}

.gz-content-loading::after{
  content:"";
  position:absolute;
  inset:0;
  z-index:20;
  pointer-events:none;
  background:
    linear-gradient(100deg,transparent 0%,var(--gz-skeleton-shine) 46%,transparent 72%),
    linear-gradient(135deg,var(--gz-skeleton-base),rgba(255,255,255,.018));
  background-size:220% 100%,100% 100%;
  animation:gz-skeleton-sweep 1.05s ease-in-out infinite;
  animation-delay:var(--gz-skeleton-delay,0ms);
  backdrop-filter:blur(8px);
}

.gz-form-loading{
  position:relative;
  pointer-events:none;
}

.gz-form-loading::after{
  content:"";
  position:absolute;
  inset:-2px;
  border-radius:inherit;
  background:linear-gradient(100deg,transparent,rgba(255,255,255,.08),transparent);
  background-size:220% 100%;
  animation:gz-skeleton-sweep .9s ease-in-out infinite;
  pointer-events:none;
}

.gz-page-busy::before,
.gz-link-loading::before{
  content:"";
  position:fixed;
  top:0;
  left:0;
  right:0;
  z-index:99999;
  height:3px;
  background:linear-gradient(90deg,#111827,#ffffff,#4b5563,#111827);
  background-size:220% 100%;
  animation:gz-loading-bar .85s linear infinite;
}

.gz-page-busy-body .main,
.gz-page-busy-body main,
.gz-page-busy-body .content,
.gz-page-busy-body .checkout-shell,
.gz-page-busy-body .layout{
  filter:blur(2px);
  transition:filter .16s ease;
}

.gz-document-leaving{
  opacity:.7;
  filter:blur(8px);
  transition:opacity .09s ease,filter .09s ease;
}

.gz-document-entering{
  animation:gz-document-in .18s ease both;
}

.gz-toast{
  position:fixed;
  left:18px;
  bottom:18px;
  z-index:100000;
  max-width:min(420px,calc(100vw - 36px));
  padding:13px 15px;
  border:1px solid rgba(28,39,54,.10);
  border-radius:12px;
  background:rgba(255,255,255,.96);
  color:#1b2430;
  box-shadow:0 18px 50px rgba(27,36,48,.12);
  opacity:0;
  transform:translateY(12px);
  pointer-events:none;
  transition:opacity .2s ease,transform .2s ease;
}

.gz-toast[data-type="error"]{
  border-color:rgba(226,125,136,.35);
}

.gz-toast.show{
  opacity:1;
  transform:none;
}

@keyframes gz-skeleton-sweep{
  from{background-position:120% 0,0 0;}
  to{background-position:-120% 0,0 0;}
}

@keyframes gz-loading-bar{
  from{background-position:0 0;}
  to{background-position:220% 0;}
}

@keyframes gz-document-in{
  from{opacity:.72;filter:blur(8px);transform:translateY(4px);}
  to{opacity:1;filter:none;transform:none;}
}

button,
a,
input,
select,
textarea{
  -webkit-tap-highlight-color:rgba(17,24,39,.12);
}

button,
[role="button"],
input[type="submit"],
input[type="button"],
.btn,
.btn-next,
.btn-prev,
.checkout-btn,
.promo-btn,
.nav-icon-btn,
.act-btn,
.card-action{
  min-height:var(--gz-touch);
}

button:focus-visible,
a:focus-visible,
input:focus-visible,
select:focus-visible,
textarea:focus-visible,
[tabindex]:focus-visible{
  outline:none;
  box-shadow:var(--gz-focus);
}

input,
select,
textarea{
  line-height:1.45;
}

textarea{
  min-height:120px;
  resize:vertical;
}

table{
  border-collapse:separate;
  border-spacing:0;
}

.content,
.checkout-left,
.order-summary,
.layout,
.page-wrap,
.site-page-shell{
  min-width:0;
}

.panel,
.card,
.contact-card,
.store-card,
.summary-panel,
.order-card,
.track-card,
.product-card,
.feat-card{
  overflow-wrap:break-word;
}

.content-wrap,
.checkout-shell,
.wrap,
.hero-wrap,
.main-grid,
.profile-shell,
.site-page-shell,
.confirm-wrap,
.page-shell{
  width:min(100%,var(--gz-max-page));
}

.content-wrap,
.checkout-shell,
.wrap,
.hero-wrap,
.main-grid,
.profile-shell,
.site-page-shell,
.page-shell{
  margin-inline:auto;
}

.hero-wrap,
.content-wrap,
.checkout-shell,
.profile-shell,
.site-page-shell,
.page-shell{
  padding-left:max(var(--gz-page-x),env(safe-area-inset-left));
  padding-right:max(var(--gz-page-x),env(safe-area-inset-right));
}

.page-header h1,
.search-title,
.hh1,
.title,
.left-headline{
  text-wrap:balance;
}

.page-header p,
.sec-sub,
.form-sub,
.sub,
.site-page-summary,
.search-sub{
  text-wrap:pretty;
}

.alert-success,
.alert-error,
.toast{
  line-height:1.7;
}

@media (hover:hover){
  a,
  button,
  .card,
  .product-card,
  .feat-card,
  .coll-card{
    transition-duration:.18s;
  }
}

@media (max-width:900px){
  html{
    scroll-padding-top:76px;
  }

  body{
    font-size:14px;
  }

  .checkout-layout,
  .layout{
    gap:var(--gz-gap-lg);
  }

  .checkout-left,
  .order-summary,
  .content,
  .page-wrap,
  .site-page-shell{
    padding-left:var(--gz-page-x) !important;
    padding-right:var(--gz-page-x) !important;
  }

  .panel-head,
  .panel-body,
  .summary-head,
  .summary-body,
  .card,
  .contact-card,
  .store-card{
    padding:clamp(16px,4vw,22px) !important;
  }

  .table-wrap,
  .orders-table-wrap,
  .admin-table-wrap{
    overflow-x:auto;
    -webkit-overflow-scrolling:touch;
  }
}

@media (max-width:640px){
  :root{
    --gz-touch:46px;
    --gz-gap:14px;
  }

  body{
    line-height:1.75;
  }

  nav{
    padding-left:var(--gz-page-x) !important;
    padding-right:var(--gz-page-x) !important;
  }

  .steps-bar,
  .steps-wrap{
    padding-left:var(--gz-page-x) !important;
    padding-right:var(--gz-page-x) !important;
  }

  .sec-header,
  .panel-head,
  .block-title,
  .contact-card-head,
  .store-card-head,
  .card-head{
    align-items:flex-start;
    gap:12px;
  }

  .actions,
  .step-nav,
  .contact-actions,
  .store-actions,
  .delete-modal-actions{
    gap:10px;
  }

  input,
  select,
  textarea{
    font-size:16px;
  }

  .modal,
  .delete-modal{
    max-height:calc(100dvh - 28px);
  }

  .modal-head,
  .modal-footer,
  .delete-modal-actions,
  .actions,
  .contact-actions,
  .store-actions,
  .step-nav{
    flex-wrap:wrap;
  }

  .modal-footer > *,
  .delete-modal-actions > *,
  .actions > *,
  .contact-actions > *,
  .store-actions > *,
  .step-nav > *{
    min-width:min(100%,180px);
  }

  .toast{
    width:calc(100vw - 28px);
    max-width:420px;
  }
}

@media (max-width:420px){
  .sum-row,
  .meta-row{
    gap:8px;
  }

  .sum-total,
  .sum-row{
    align-items:flex-start;
  }

  .sum-total-value,
  .sum-value{
    white-space:normal;
    text-align:left;
  }
}

/* Page-specific spacing refinements without changing the visual system. */
.page-header,
.track-hero,
.profile-hero,
.confirm-wrap,
.checkout-shell{
  isolation:isolate;
}

.page-header p,
.sec-sub,
.form-sub,
.sub,
.site-page-summary{
  max-width:72ch;
}

.product-grid,
.featured-grid,
.deals-grid,
.collections-grid,
.stats-grid,
.profile-grid,
.quick-stats,
.status-grid,
.ship-grid,
.mini-meta{
  align-items:stretch;
}

.product-card,
.feat-card,
.rel-card,
.pc,
.coll-card,
.deal-card,
.review-card,
.dashboard-order-card,
.cart-item,
.cat-pill,
.shop-quick-card,
.why-card,
.testimonial-card,
.brand-card,
.mini-card,
.status-card{
  content-visibility:auto;
  contain-intrinsic-size:260px;
}

.reviews-section,
.related-section,
.deals-section,
.collections-section,
.featured-section{
  content-visibility:auto;
  contain-intrinsic-size:700px;
}

.cart-item,
.sum-item,
.ship-option,
.address-card,
.wish-item,
.order-item,
.contact-item,
.dashboard-order-card{
  scroll-margin-top:92px;
}

.form-section,
.block,
.summary-panel,
.order-summary,
.right-panel,
.left-panel,
.panel,
.box{
  box-shadow:
    0 18px 54px rgba(27,36,48,.08),
    inset 0 1px 0 rgba(255,255,255,.018);
}

.panel,
.card,
.contact-card,
.store-card,
.summary-panel,
.order-card,
.track-card,
.product-card,
.feat-card,
.form-section,
.block,
.right-panel,
.left-panel,
.box,
.table-card{
  border-radius:min(var(--gz-radius),18px);
}

.field-input,
.form-input,
.form-select,
.form-textarea,
.promo-input,
.contact-input,
.contact-textarea,
.store-input,
.store-textarea{
  min-height:44px;
}

.filter-option,
.size-option,
.color-option,
.chip,
.tab-btn,
.filter-tab,
.auth-tab{
  touch-action:manipulation;
}

.table-card{
  scrollbar-gutter:stable;
}

.table-card table,
.variant-table,
.orders-table,
.admin-table{
  width:100%;
}

.table-card th,
.table-card td{
  vertical-align:middle;
}

.right-panel,
.order-summary,
.sidebar,
.content,
.modal-body{
  overscroll-behavior:contain;
}

@media (min-width:901px){
  .product-card,
  .feat-card,
  .cart-item,
  .contact-card,
  .store-card,
  .dashboard-order-card{
    will-change:transform;
  }
}

@media (max-width:900px){
  .page-header{
    padding-top:clamp(24px,6vw,38px) !important;
    padding-bottom:clamp(20px,5vw,30px) !important;
  }

  .sidebar{
    scrollbar-width:none;
  }

  .sidebar::-webkit-scrollbar{
    display:none;
  }

  .filter-options{
    gap:8px !important;
  }

  .filter-option,
  .ship-option,
  .address-card{
    min-height:52px;
  }

  .order-summary{
    height:auto !important;
    max-height:none !important;
  }

  .right-panel{
    min-height:100dvh;
  }

  .topbar-actions,
  .table-toolbar,
  .filter-tabs,
  .quick-orders,
  .cat-tabs{
    overflow-x:auto;
    -webkit-overflow-scrolling:touch;
    scrollbar-width:none;
  }

  .topbar-actions::-webkit-scrollbar,
  .table-toolbar::-webkit-scrollbar,
  .filter-tabs::-webkit-scrollbar,
  .quick-orders::-webkit-scrollbar,
  .cat-tabs::-webkit-scrollbar{
    display:none;
  }

  .topbar-btn,
  .filter-tab,
  .cat-tab,
  .quick-btn{
    flex:0 0 auto;
  }
}

@media (max-width:640px){
  .page-header h1,
  .title,
  .left-headline{
    line-height:1.35;
  }

  .product-grid,
  .featured-grid,
  .deals-grid,
  .collections-grid{
    gap:14px !important;
  }

  .cart-item,
  .sum-item,
  .form-section,
  .block,
  .ship-option,
  .status-card,
  .mini-card,
  .progress-card{
    border-radius:14px !important;
  }

  .auth-tabs{
    position:sticky;
    top:0;
    z-index:5;
    background:var(--surface,#fff);
  }

  .form-panel{
    padding:24px var(--gz-page-x) !important;
  }

  .field-row,
  .form-grid.two,
  .ship-grid,
  .status-grid,
  .mini-meta{
    grid-template-columns:1fr !important;
  }

  .table-card{
    margin-left:calc(var(--gz-page-x) * -1);
    margin-right:calc(var(--gz-page-x) * -1);
    border-radius:0 !important;
    border-left:0;
    border-right:0;
  }

  .page-header h1,
  .search-title,
  .hh1{
    font-size:clamp(28px,9vw,40px) !important;
  }

  .brand,
  .logo,
  .sidebar-brand{
    max-width:100%;
  }

  .meta-row,
  .sum-row,
  .ship-row,
  .order-line,
  .info-row{
    grid-template-columns:1fr !important;
    align-items:start !important;
  }

  .meta-row > *,
  .sum-row > *,
  .ship-row > *,
  .order-line > *,
  .info-row > *{
    min-width:0;
  }
}

@media (prefers-reduced-motion:reduce){
  *,
  *::before,
  *::after{
    animation-duration:.01ms !important;
    animation-iteration-count:1 !important;
    scroll-behavior:auto !important;
    transition-duration:.01ms !important;
  }
}

/* Checkout and cart flow polish. */
.checkout-layout{
  max-width:1440px;
  margin-inline:auto;
}

.checkout-left{
  min-width:0;
}

.order-summary,
.summary-panel{
  border-inline-start:1px solid rgba(28,39,54,.08);
}

.cart-item{
  background:#fff;
  border:1px solid rgba(28,39,54,.08) !important;
  margin-bottom:12px;
}

.cart-item:last-child{
  margin-bottom:0;
}

.item-name,
.sum-item-name,
.rel-name,
.prod-name{
  overflow-wrap:anywhere;
}

.item-img,
.sum-img{
  background:linear-gradient(135deg,rgba(17,24,39,.055),rgba(255,255,255,.72));
}

.item-controls > div:last-child{
  min-width:fit-content;
}

.promo-actions{
  padding:12px;
  background:rgba(17,24,39,.045);
  border:1px solid rgba(28,39,54,.08);
  border-radius:16px;
}

.promo-row{
  min-width:0;
}

.checkout-btn,
.btn-next,
.btn-prev,
.apply-btn,
.clear-btn{
  border-radius:12px;
  font-weight:700;
}

.summary-items{
  max-height:42vh;
  overflow:auto;
  padding-inline-end:4px;
}

.sum-item{
  border:1px solid rgba(28,39,54,.08);
}

.sum-total{
  border-top:1px solid rgba(28,39,54,.12);
}

.steps-bar,
.steps-wrap{
  position:sticky;
  top:0;
  z-index:30;
  background:rgba(255,255,255,.86);
  backdrop-filter:blur(16px);
}

.form-section,
.block,
.status-card,
.mini-card,
.ship-option{
  border-color:rgba(28,39,54,.09) !important;
}

.form-grid{
  gap:12px;
}

.form-group{
  min-width:0;
}

.ship-grid,
.status-grid,
.mini-meta{
  gap:12px;
}

.ship-item,
.status-card,
.mini-card{
  min-width:0;
}

.ship-value{
  overflow-wrap:anywhere;
}

@media (max-width:900px){
  .order-summary,
  .summary-panel{
    border-inline-start:0;
  }

  .summary-items{
    max-height:none;
  }

  .checkout-left,
  .order-summary{
    padding-block:24px !important;
  }
}

@media (max-width:640px){
  .cart-item{
    gap:12px !important;
  }

  .item-controls{
    align-items:stretch !important;
  }

  .item-controls > div:last-child{
    width:100%;
    justify-content:space-between;
  }

  .promo-actions{
    padding:10px;
  }

  .promo-row,
  .step-nav,
  .actions{
    width:100%;
  }

  .steps-bar .step-label,
  .steps-wrap .step-label{
    line-height:1.35;
  }

  .summary-panel,
  .order-summary{
    border-radius:0 !important;
  }
}

/* Theme enforcement layer. Keep in sync with assets/css/theme.css. */
:root{
  --bg:#f7f8fb;
  --surface:#ffffff;
  --surface2:#f1f4f8;
  --surface3:#e8edf4;
  --border:#e1e7f0;
  --border2:#cfd8e6;
  --accent:#111827;
  --accent2:#4b5563;
  --accent-dim:rgba(17,24,39,.08);
  --accent-light:#2f3a4a;
  --brand-ink:#1b2430;
  --brand-muted:#687385;
  --brand-dim:#98a3b3;
  --brand-line:rgba(28,39,54,.10);
  --brand-soft:rgba(255,255,255,.72);
  --brand-glow:rgba(17,24,39,.08);
  --brand-warm:#4b5563;
  --green:#78a7c7;
  --green-dim:rgba(120,167,199,.14);
  --red:#e27d88;
  --red-dim:rgba(226,125,136,.14);
  --amber:#e3b56b;
  --amber-dim:rgba(227,181,107,.16);
  --pink:#e9a5b0;
  --pink-dim:rgba(233,165,176,.15);
  --text:#1b2430;
  --text-muted:#687385;
  --text-dim:#9aa5b5;
}

/* Modal containment: keep long popups and their actions inside the viewport. */
.modal-overlay,
.delete-modal-overlay,
.cancel-modal-overlay,
.review-delete-popup-overlay{
  padding:max(14px,env(safe-area-inset-top)) max(12px,env(safe-area-inset-right)) max(14px,env(safe-area-inset-bottom)) max(12px,env(safe-area-inset-left)) !important;
  overflow:auto !important;
  -webkit-overflow-scrolling:touch;
}

.modal,
.delete-modal,
.cancel-modal,
.featured-login-modal-box,
.login-modal-box,
.review-delete-popup-box{
  max-width:calc(100vw - 24px) !important;
  max-height:min(90vh,calc(100dvh - 28px)) !important;
}

.modal{
  display:flex !important;
  flex-direction:column;
  overflow:hidden !important;
  min-height:0;
}

.modal > form{
  display:flex;
  flex:1 1 auto;
  min-height:0;
  overflow:hidden;
  flex-direction:column;
  width:100%;
}

.modal-head,
.modal-footer{
  flex:0 0 auto;
}

.modal-body{
  flex:1 1 auto;
  min-height:0;
  overflow-y:auto !important;
  -webkit-overflow-scrolling:touch;
}

.modal-footer{
  position:relative;
  z-index:2;
  align-items:center;
  background:var(--surface,#fff) !important;
}

.modal-footer .btn,
.delete-modal-actions button,
.cancel-modal-actions button,
.review-delete-popup-actions button,
.login-modal-btn,
.featured-login-modal-btn{
  justify-content:center;
  min-width:0 !important;
  max-width:100%;
  white-space:normal;
}

@media (max-width:640px){
  .modal-overlay,
  .delete-modal-overlay,
  .cancel-modal-overlay,
  .review-delete-popup-overlay{
    padding:max(10px,env(safe-area-inset-top)) max(10px,env(safe-area-inset-right)) max(10px,env(safe-area-inset-bottom)) max(10px,env(safe-area-inset-left)) !important;
  }

  .modal{
    width:100% !important;
    max-width:100% !important;
    max-height:calc(100dvh - 20px) !important;
    margin:auto;
  }

  .modal-head{
    padding:14px 16px !important;
  }

  .modal-body{
    max-height:none !important;
    padding:16px !important;
  }

  .modal-footer,
  .delete-modal-actions,
  .cancel-modal-actions,
  .review-delete-popup-actions,
  .login-modal-actions,
  .featured-login-modal-actions{
    display:grid !important;
    grid-template-columns:repeat(2,minmax(0,1fr));
    gap:10px !important;
    width:100%;
  }

  .modal-footer{
    padding:12px 16px calc(12px + env(safe-area-inset-bottom)) !important;
  }

  .modal-footer > *,
  .delete-modal-actions > *,
  .cancel-modal-actions > *,
  .review-delete-popup-actions > *,
  .login-modal-actions > *,
  .featured-login-modal-actions > *{
    width:100% !important;
    min-width:0 !important;
  }

  .review-delete-popup-box{
    overflow:auto;
  }
}

@media (max-width:380px){
  .modal-footer,
  .delete-modal-actions,
  .cancel-modal-actions,
  .review-delete-popup-actions,
  .login-modal-actions,
  .featured-login-modal-actions{
    grid-template-columns:1fr;
  }
}

/* Mobile admin notifications should escape the scrollable topbar actions row. */
@media (max-width:640px){
  .topbar,
  .topbar-actions,
  .admin-notifications{
    overflow:visible !important;
  }

  .admin-notifications-panel{
    position:fixed !important;
    top:var(--admin-notifications-top,86px) !important;
    right:max(12px,env(safe-area-inset-right)) !important;
    left:max(12px,env(safe-area-inset-left)) !important;
    width:auto !important;
    max-width:none !important;
    max-height:calc(100dvh - var(--admin-notifications-top,86px) - 14px) !important;
    z-index:10050 !important;
  }

  .admin-notifications-panel .notif-list{
    max-height:calc(100dvh - var(--admin-notifications-top,86px) - 88px) !important;
  }
}

/* Admin tables: keep horizontal movement inside the table card on mobile. */
.sidebar + .main,
.sidebar + .main .content,
.sidebar + .main .page{
  min-width:0;
  max-width:100%;
}

.sidebar + .main .content{
  overflow-x:hidden !important;
}

.sidebar + .main .table-card,
.sidebar + .main .contact-table-wrap{
  width:100%;
  max-width:100%;
  min-width:0;
  overflow-x:auto !important;
  -webkit-overflow-scrolling:touch;
  overscroll-behavior-inline:contain;
}

.sidebar + .main .table-card table{
  min-width:max(760px,100%);
}

.sidebar + .main .contact-table-wrap .admin-table{
  min-width:max(980px,100%);
}

@media (max-width:640px){
  .sidebar + .main .table-card{
    margin-inline:0 !important;
    border-inline:1px solid var(--border) !important;
    border-radius:10px !important;
  }

  .sidebar + .main .table-card table{
    min-width:max(720px,100%);
  }

  .sidebar + .main .contact-table-wrap .admin-table{
    min-width:max(900px,100%);
  }
}
