@layer components{
  .sr-only{
    position:absolute; width:1px; height:1px; padding:0; margin:-1px; overflow:hidden;
    clip:rect(0,0,0,0); white-space:nowrap; border:0;
  }

  .top-icons a{
    color:#555; font-weight:400; font-size:.95rem;
    display:inline-flex; align-items:center; gap:6px;
    text-decoration:none; transition:color .2s ease;
  }
  .top-icons i,.top-icons svg{ color:inherit; font-weight:400; font-size:1rem; }
  .top-icons a:hover{ color:var(--blue-accent); }

  /* Sign in dropdown */
  .signin-dropdown{ position:relative; display:inline-block; }
  /* Match other header utility links (Contact Us / Cart) */
  .signin-dropdown > a{ color:inherit; text-decoration:none; font-weight:inherit; padding:0; }
  .signin-menu{
    display:none; position:absolute; top:30px; right:0; background:#fff; color:#111;
    min-width:250px; padding:15px; box-shadow:0 4px 10px rgba(0,0,0,.2);
    border-radius:8px; z-index:999;
  }
  .signin-menu.show{ display:block; }
  .signin-title{ font-weight:700; margin-bottom:10px; }
  .signin-benefits{ list-style:disc; padding-left:20px; margin-bottom:10px; font-size:13px; }
  .btn-signin,.btn-create{
    display:block; width:100%; padding:10px; text-align:center;
    border-radius:5px; text-decoration:none; font-weight:700;
  }
  .btn-signin{ background:var(--blue-accent); color:#fff; }
  .btn-create{ background:#fff; color:var(--blue-accent); border:1px solid var(--blue-accent); }

  /* Utility Links */
  .util-link img{
    width:20px; height:20px; display:inline-block; vertical-align:middle; margin-right:6px;
  }
  @media (max-width:768px){
    .util-link .label{ display:none; }
  }

  @media (max-width:768px){
    .top-icons a{ font-size:.95rem; padding:5px 10px; }
  }
  @media (max-width:576px){
    .top-icons a{ font-size:.85rem; gap:4px; }
    .top-icons i{ font-size:.9rem; }
  }

  /* ===== Card actions buttons (Search + Category) ===== */
  .card-actions{
    display:flex;
    align-items:center;
    gap:10px;
    margin-top:10px;
    flex-wrap:wrap;
  }
  .card-actions form{ margin:0; }
  .card-actions .inline-addtocart{ display:inline; }

  .card-actions .btn,
  .cmp-panel .btn{
    height:36px;
    border-radius:10px;
    padding:0 12px;
    cursor:pointer;
    border:1px solid #d9d9d9;
    background:#fff;
    font: inherit;
    line-height:1;
  }

  .card-actions .btn-cart{
    background:var(--blue-accent);
    color:#fff;
    border-color:var(--blue-accent);
  }

  .card-actions .btn-compare[aria-pressed="true"]{
    background: color-mix(in srgb, var(--blue-accent) 12%, #fff);
    border-color: var(--blue-accent);
    color: var(--blue-accent);
    font-weight: 600;
  }

  /* ===== Compare dock + tray (global) ===== */
  .cmp-dock{
    position:fixed;
    top:50%;
    left:0;
    transform:translateY(-50%);
    display:inline-flex;
    align-items:center;
    gap:8px;
    background:var(--blue-accent);
    color:#fff;
    border:1px solid var(--blue-accent);
    border-radius:0 10px 10px 0;
    padding:10px 14px;
    font-weight:700;
    z-index: var(--z-compare, 999999);
    cursor:pointer;
    user-select:none;
    box-shadow:0 4px 12px rgba(0,0,0,.25);
  }

  .cmp-dock .badge{
    display:inline-block;
    min-width:20px;
    text-align:center;
    background:#fff;
    color:var(--blue-accent);
    border-radius:999px;
    padding:0 6px;
  }

  .cmp-dock.cmp-dock--side{
    width:auto;
    justify-content:flex-start;
  }

  .cmp-panel{
    position:fixed;
    left:0;
    right:0;
    bottom:0;
    z-index: var(--z-compare, 999999);
    background:var(--blue-accent);
    color:#fff;
    padding:14px;
    box-shadow:0 -10px 24px rgba(0,0,0,.2);
  }
  .cmp-panel__head{ display:flex; align-items:center; justify-content:space-between; margin-bottom:10px; }
  .cmp-panel__head .title{ font-weight:700; }
  .cmp-panel__body{ display:flex; gap:10px; overflow:auto; padding:6px 0; }
  .cmp-panel__foot{ display:flex; gap:10px; justify-content:flex-end; margin-top:10px; }

  .cmp-panel .btn{
    background:#fff;
    color:var(--blue-accent);
    border-color:#fff;
    text-decoration:none;
    display:inline-flex;
    align-items:center;
    justify-content:center;
  }
  .cmp-panel .btn.btn-light{ background:#f6f7fb; color:var(--blue-accent); }
  .cmp-panel .btn.btn-primary{ background:#fff; color:var(--blue-accent); }

  .cmp-chip{ display:inline-flex; align-items:center; gap:8px; background:rgba(255,255,255,.15); border-radius:999px; padding:6px 10px; white-space:nowrap; }
  .cmp-chip img{ width:28px; height:28px; object-fit:cover; border-radius:6px; background:#fff; }
  .cmp-chip .x{ cursor:pointer; font-weight:700; line-height:1; padding:0 6px; border-radius:6px; }
  .cmp-chip .x:focus-visible{ outline:2px solid #fff; outline-offset:2px; }
}

/* Global typography helpers */
section h2{ font-size:2rem; color:var(--blue-accent); }
