/* =====================================================================
   HIMACAKE - Client (header, footer, home, product, news, account, cart)
   ===================================================================== */

/* ====== HEADER (fixed · smart-hide — JS thêm/ghỡ class site-header--away) ====== */
.site-header{
  position:fixed;top:0;left:0;right:0;z-index:100;
  background:#fff;
  border-bottom:1px solid rgba(15,23,42,.06);
  box-shadow:
    0 1px 2px rgba(15,23,42,.06),
    0 6px 20px rgba(15,23,42,.055);
  transform:translate3d(0,0,0);
  backface-visibility:hidden;
  transition:transform 240ms cubic-bezier(0.4,0,0.2,1);
}
.site-header.site-header--away{
  transform:translate3d(0,-100%,0);
  pointer-events:none;
}

.site-header-spacer{
  display:block;margin:0;padding:0;border:0;width:100%;
  /* Chiều cao gán bằng JS = offsetHeight của .site-header (nav mở/đóng là thay đổi được) */
  min-height:72px;
  flex-shrink:0;
}
#main{overflow-anchor:none}

.site-header__top{
  display:grid;grid-template-rows:1fr;background:var(--color-secondary);color:#fff;font-size:var(--fs-12);
  transition:grid-template-rows .28s cubic-bezier(.33,1,.68,1);
}
.site-header__top .site-header__roll-inner{overflow:hidden;min-height:0}
.site-header__top .container{display:flex;justify-content:space-between;align-items:center;padding-top:8px;padding-bottom:8px;flex-wrap:wrap;gap:var(--sp-3)}
.site-header__top a{color:#fff;opacity:.85}
.site-header__top a:hover{opacity:1;color:var(--color-primary)}
.site-header__top ul{display:flex;gap:var(--sp-4)}

.site-header__main{
  display:grid;
  grid-template-columns:auto minmax(0,1fr) auto;
  align-items:center;
  gap:var(--sp-5);
  padding:var(--sp-3) var(--sp-4);max-width:var(--max-width);margin:0 auto;
  background:#fff;
  isolation:isolate;
  position:relative;
  z-index:2;
  transition:padding .26s cubic-bezier(.33,1,.68,1);
}
.site-header__main-start{display:flex;align-items:center;gap:var(--sp-5);justify-self:start;min-width:0}

.brand{display:inline-flex;align-items:center;gap:10px;text-decoration:none;color:var(--color-secondary);flex-shrink:0;position:relative;z-index:1}
.brand__icon-wrap{
  width:44px;height:44px;flex-shrink:0;display:grid;place-items:center;
  background:#fff;border-radius:50%;
  overflow:hidden;
  contain:paint;
  transform:translateZ(0);
}
/* Không mix-blend: một số GPU/browser làm logo “mất”; nền đen PNG vẫn thấy rõ hơn */
.brand .brand__icon-img{
  width:40px!important;
  height:40px!important;
  max-width:none;
  min-width:40px;
  min-height:40px;
  object-fit:contain;
  display:block;
  vertical-align:middle;
  mix-blend-mode:normal;
}
.brand__text{font-family:var(--font-heading);font-weight:700;font-size:var(--fs-24);letter-spacing:1px;color:var(--color-secondary)}

/* search — rộng vừa phải, căn giữa khoảng giữa logo và icon (desktop) */
.site-search{
  justify-self:center;width:100%;max-width:680px;min-width:0;position:relative;
  --sb-size:32px;
  --sb-gap:7px;
}
.site-search input{
  width:100%;min-height:46px;padding:10px calc(var(--sb-gap) + var(--sb-size) + var(--sb-gap)) 10px var(--sp-4);
  box-sizing:border-box;
  border:1px solid var(--color-border);border-radius:var(--radius-pill);
  font-size:var(--fs-14);background:var(--color-bg-soft);line-height:1.35;
}
.site-search input:focus{outline:none;border-color:var(--color-primary);background:#fff;box-shadow:0 0 0 3px var(--color-primary-light)}
.site-search button{
  position:absolute;right:var(--sb-gap);top:50%;transform:translateY(-50%);
  width:var(--sb-size);height:var(--sb-size);padding:0;margin:0;
  flex-shrink:0;border:none;background:var(--color-primary);border-radius:50%;
  cursor:pointer;display:grid;place-items:center;color:var(--color-secondary);
  box-shadow:inset 0 1px 0 rgba(255,255,255,.22);
}
.site-search button:hover{background:var(--color-primary-dark);color:#fff}
.site-search button:focus-visible{outline:2px solid var(--color-secondary);outline-offset:2px}

/* header actions — cột phải lưới */
.header-actions{display:flex;align-items:center;gap:var(--sp-2);justify-self:end;flex-shrink:0}
.header-actions a{display:flex;align-items:center;justify-content:center;gap:6px;padding:8px 12px;border-radius:var(--radius);color:var(--color-text);font-size:var(--fs-14);font-weight:500;position:relative}
.header-actions a:hover{background:var(--color-bg-soft);color:var(--color-primary-dark)}
.header-actions__user svg{width:23px;height:23px;display:block}
.header-actions__user{padding-inline:11px}
.cart-count{position:absolute;top:-2px;right:0;background:var(--color-accent);color:#fff;font-size:var(--fs-12);font-weight:700;border-radius:50%;min-width:18px;height:18px;padding:0 5px;display:grid;place-items:center}

/* nav menu — desktop: thanh brand + các mục dạng “nút” ranh giới rõ */
.site-nav{
  background:linear-gradient(180deg,var(--color-primary) 0%,#efc24a 100%);
  border-bottom:1px solid rgba(62,39,35,.2);
  box-shadow:inset 0 1px 0 rgba(255,255,255,.42);
}
@media(min-width:901px){
  /* Khối tham chiếu cho mega full-bleed theo mép vàng (.site-nav = full viewport), không theo <li> hẹp */
  .site-nav{
    position:relative;
    display:grid;
    grid-template-rows:1fr;
    transition:grid-template-rows .28s cubic-bezier(.33,1,.68,1),border-bottom-width .22s ease;
  }
  .site-nav .site-header__roll-inner{min-height:0;overflow:visible}
}

.site-nav__list{
  display:flex;
  justify-content:center;
  align-items:center;
  flex-wrap:wrap;
  max-width:var(--max-width);
  margin:0 auto;
  padding:10px var(--sp-5);
  gap:var(--sp-3);
}
.site-nav__list>li{position:relative}
.site-nav__list>li>a{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  padding:10px clamp(14px,1.85vw,22px);
  min-height:40px;
  box-sizing:border-box;
  border-radius:var(--radius-pill);
  font-weight:700;
  font-size:var(--fs-14);
  line-height:1.2;
  text-transform:none;
  letter-spacing:.01em;
  text-decoration:none;
  color:var(--color-secondary);
  background:rgba(255,253,247,.93);
  border:1px solid rgba(62,39,35,.16);
  box-shadow:
    0 1px 3px rgba(62,39,35,.07),
    inset 0 1px 0 rgba(255,255,255,.85);
  transition:
    background .18s ease,
    color .18s ease,
    border-color .18s ease,
    box-shadow .18s ease,
    transform .18s ease;
}
.site-nav__list>li>a:hover{
  background:#fff;
  border-color:rgba(62,39,35,.28);
  box-shadow:0 4px 14px rgba(62,39,35,.11);
  transform:translateY(-1px);
  color:var(--color-secondary);
}
.site-nav__list>li>a.active{
  background:var(--color-secondary);
  color:var(--color-primary-light);
  border-color:rgba(0,0,0,.2);
  box-shadow:0 3px 12px rgba(62,39,35,.28),inset 0 1px 0 rgba(255,255,255,.06);
}
.site-nav__list>li>a:focus-visible{
  outline:2px solid var(--color-secondary);
  outline-offset:3px;
}

/* dropdown nhỏ (giữ để chỗ khác có thể dùng — menu chính dùng mega) */
.site-nav__sub{position:absolute;top:100%;left:0;min-width:240px;background:#fff;box-shadow:var(--shadow-lg);border-radius:0 0 var(--radius) var(--radius);opacity:0;visibility:hidden;transform:translateY(-6px);transition:opacity var(--t-fast),transform var(--t-fast),visibility var(--t-fast);z-index:30}
.site-nav__list>li:hover .site-nav__sub{opacity:1;visibility:visible;transform:translateY(0)}
.site-nav__sub a{display:block;padding:10px var(--sp-4);font-size:var(--fs-14);color:var(--color-text);font-weight:500}
.site-nav__sub a:hover{background:var(--color-primary-light);color:var(--color-primary-dark)}

/* mega menu — full width dưới thanh vàng */
.site-nav__item--mega{position:relative;z-index:6}
@media(min-width:901px){
  /* Li static → mega full-bleed theo .site-nav (căn đúng mép); mở bằng hover + .is-mega-open (JS) */
  .site-nav__list > li.site-nav__item--mega{position:static}
}
.site-nav__mega{
  position:absolute;
  left:0;
  right:0;
  width:100%;
  top:100%;
  background:#fff;
  border-bottom:1px solid var(--color-border-soft);
  box-shadow:0 12px 32px rgba(0,0,0,.08);
  opacity:0;
  visibility:hidden;
  transform:translateY(-6px);
  transition:opacity .2s ease,transform .2s ease,visibility .2s;
  pointer-events:none;
  z-index:50;
}
.site-nav__list>li.site-nav__item--mega:hover .site-nav__mega,
.site-nav__list>li.site-nav__item--mega.is-mega-open .site-nav__mega,
.site-nav__list>li.site-nav__item--mega:focus-within .site-nav__mega{
  opacity:1;
  visibility:visible;
  transform:translateY(0);
  pointer-events:auto;
}
.site-nav__mega-inner{max-width:var(--max-width);margin:0 auto;padding:var(--sp-6) var(--sp-4) var(--sp-5)}
.site-nav__mega-grid{
  display:grid;
  grid-template-columns:repeat(5,minmax(0,1fr));
  gap:var(--sp-6) var(--sp-5);
  align-items:start;
}
@media(max-width:1100px){
  .site-nav__mega-grid{grid-template-columns:repeat(3,minmax(0,1fr))}
}
.site-nav__mega-heading{
  display:block;font-weight:700;font-size:var(--fs-14);letter-spacing:.2px;color:var(--color-secondary);text-decoration:none;
  padding-bottom:var(--sp-2);border-bottom:1px solid rgba(44,62,53,.85);
}
.site-nav__mega-heading:hover{color:var(--color-primary-dark)}
.site-nav__mega-sub{list-style:none;margin:var(--sp-3) 0 0;padding:0;display:flex;flex-direction:column;gap:var(--sp-2)}
.site-nav__mega-sub a{font-size:var(--fs-14);color:var(--color-text-soft);font-weight:500;text-decoration:none}
.site-nav__mega-sub a:hover{color:var(--color-primary-dark)}
.site-nav__mega-foot{border-top:1px solid var(--color-border-soft);margin-top:var(--sp-5);padding-top:var(--sp-4);text-align:center}
.site-nav__mega-foot a{font-size:var(--fs-14);font-weight:600;color:var(--color-primary-dark)}

/* mobile burger */
.burger{display:none;background:none;border:none;font-size:24px;cursor:pointer;padding:8px}
@media(max-width:900px){
  .site-header__main{display:flex;flex-wrap:wrap;justify-content:flex-start}
  .site-header__main-start{width:auto}
  .burger{display:block;order:1}
  .site-header__main-start .brand{order:2}
  .header-actions{order:3;margin-left:auto;margin-inline-end:0}
  .site-search{order:4;flex:1 1 100%;justify-self:stretch;width:100%;max-width:none}
  .site-nav{display:none}
  .site-nav.open{display:grid;grid-template-rows:1fr}
  .site-nav .site-header__roll-inner{overflow:visible;min-height:0}
  .site-nav__list{
    flex-direction:column;
    align-items:stretch;
    gap:var(--sp-2);
    padding:var(--sp-3) var(--sp-4);
  }
  .site-nav__list>li>a{
    width:100%;
    justify-content:flex-start;
    padding:12px var(--sp-4);
    min-height:44px;
    border-radius:var(--radius);
    text-align:left;
  }
  .site-nav__list > li.site-nav__item--mega{position:relative}
  .site-nav__mega{
    position:static;
    left:auto;right:auto;width:auto;
    box-shadow:none;border-bottom:none;background:rgba(255,255,255,.65);
    opacity:1;visibility:visible;transform:none;
    transition:none;
    pointer-events:auto;
    display:none;
    max-height:none;
    overflow:visible;
  }
  .site-nav__mega-inner{padding:var(--sp-3) var(--sp-4) var(--sp-5)}
  .site-nav__mega-grid{grid-template-columns:1fr;gap:var(--sp-4)}
  .site-nav__mega-foot{margin-top:var(--sp-3);padding-top:var(--sp-3)}
  .site-nav__list>li.site-nav__item--mega.open .site-nav__mega{display:block}
  .site-nav__sub{position:static;box-shadow:none;background:rgba(255,255,255,.6);opacity:1;visibility:visible;transform:none;display:none}
  .site-nav__list>li.open .site-nav__sub{display:block}

  /* Menu mở: cuộn trong khối vàng/chữ — không kéo nền (body khóa ở main.js; max-height chỉnh theo viewport) */
  .site-header.site-header--mob-nav-open .site-nav.open > .site-header__roll-inner{
    overflow-y:auto;
    overflow-x:hidden;
    -webkit-overflow-scrolling:touch;
    overscroll-behavior-y:contain;
    touch-action:pan-y;
    padding-bottom:calc(var(--sp-5) + env(safe-area-inset-bottom,.65rem));
    max-height:min(78vh,calc(100dvh - 148px)); /* fallback cho tới khi JS gán cụ thể */
  }
}

body.site-nav-lock{
  position:fixed;
  left:0;
  right:0;
  width:100%;
  overflow:hidden!important;
  overscroll-behavior:none;
}

/* ====== FOOTER ====== */
.site-footer{background:var(--color-secondary);color:#e0d6d2;padding-top:var(--sp-9);margin-top:var(--sp-10)}
.site-footer h4{color:#fff;font-size:var(--fs-16);margin-bottom:var(--sp-4)}
.site-footer__cols{display:grid;grid-template-columns:1.4fr 1fr 1fr 1.2fr;gap:var(--sp-7);max-width:var(--max-width);margin:0 auto;padding:0 var(--sp-4) var(--sp-7)}
.site-footer a{color:#e0d6d2;font-size:var(--fs-14)}
.site-footer a:hover{color:var(--color-primary)}
.site-footer ul li{margin-bottom:var(--sp-2)}
.site-footer__about p{font-size:var(--fs-14);line-height:1.7}
.site-footer__social{display:flex;flex-wrap:wrap;align-items:center;gap:10px;margin:var(--sp-3) 0 0;padding:0;list-style:none}
.site-footer ul.site-footer__social>li{margin-bottom:0}
.site-footer__social a{
  display:grid;place-items:center;width:42px;height:42px;border-radius:50%;
  color:#fff;background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.15);
  transition:background .2s ease,border-color .2s ease,color .2s ease,transform .2s ease;
}
.site-footer__social a:hover{
  background:var(--color-primary);border-color:var(--color-primary);color:var(--color-secondary);transform:translateY(-2px);
}
.site-footer__social svg{display:block}
.site-footer__bottom{border-top:1px solid rgba(255,255,255,.1);padding:var(--sp-4);text-align:center;font-size:var(--fs-13);color:#a89a96}
@media(max-width:900px){.site-footer__cols{grid-template-columns:repeat(2,1fr)}}
@media(max-width:560px){.site-footer__cols{grid-template-columns:1fr}}

/* ====== HOME hero/section ====== */
.hero-banners{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--sp-3);padding:var(--sp-5) var(--sp-4);max-width:var(--max-width);margin:0 auto}
.hero-banner{aspect-ratio:600/300;border-radius:var(--radius-lg);background:linear-gradient(135deg,var(--color-primary-light) 0%,#ffd685 100%);display:flex;align-items:center;justify-content:center;font-size:var(--fs-20);font-weight:700;color:var(--color-secondary)}
@media(max-width:768px){.hero-banners{grid-template-columns:1fr}}

/* ====== Collections / list ====== */
.collection-banner{aspect-ratio:1280/300;background:linear-gradient(120deg,#fff3d0 0%,#ffe1a3 100%);border-radius:var(--radius);display:grid;place-items:center;margin:var(--sp-4) 0;color:var(--color-secondary)}
.collection-banner h1{font-size:var(--fs-32);margin:0}

.collection-layout{
  display:grid;
  grid-template-columns:260px 1fr;
  grid-template-areas:"sidebar main";
  gap:var(--sp-6);
  margin:var(--sp-6) 0;
}
.collection-main{grid-area:main;min-width:0}
.collection-sidebar{
  grid-area:sidebar;
  background:#fff;
  border:1px solid var(--color-border-soft);
  border-radius:var(--radius);
  padding:var(--sp-4);
  height:fit-content;
}
.collection-sidebar ul{list-style:none;margin:0;padding:0}
.collection-sidebar ul li{margin:6px 0}
.collection-sidebar ul a{display:flex;justify-content:space-between;padding:6px 0;color:var(--color-text-soft);font-size:var(--fs-14)}
.collection-sidebar ul a:hover,.collection-sidebar ul a.active{color:var(--color-primary-dark);font-weight:600}

/* Accordion filters: mobile = đóng mặc định (JS mở khi desktop); disclosure chuẩn `<details>` */
.collection-filter-details{border:0;margin:0}
.collection-filter-details__summary{
  list-style:none;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:var(--sp-3);
  cursor:pointer;
  font-size:var(--fs-15);
  font-weight:600;
  color:var(--color-text);
  -webkit-tap-highlight-color:transparent;
}
.collection-filter-details__summary::-webkit-details-marker{display:none}
.collection-filter-details__chevron{
  flex-shrink:0;
  width:10px;height:10px;
  border-right:2px solid var(--color-text-soft);
  border-bottom:2px solid var(--color-text-soft);
  transform:rotate(45deg);
  margin-top:-4px;
  transition:transform var(--t-fast),border-color var(--t-fast);
}
.collection-filter-details[open] .collection-filter-details__chevron{
  transform:rotate(225deg);
  margin-top:2px;
}
.collection-filter-details__body{padding-top:var(--sp-2)}

.toolbar{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:var(--sp-3);margin-bottom:var(--sp-5)}
.toolbar select{padding:8px 12px;border:1px solid var(--color-border);border-radius:var(--radius);background:#fff}

@media(max-width:900px){
  .collection-layout{
    grid-template-columns:1fr;
    grid-template-areas:"main" "sidebar";
    gap:var(--sp-4);
    margin:var(--sp-4) 0;
  }
  .collection-sidebar{
    padding:0;
    background:transparent;
    border:none;
    border-radius:0;
  }
  .collection-filter-details{
    background:#fff;
    border:1px solid var(--color-border-soft);
    border-radius:var(--radius);
    overflow:hidden;
  }
  .collection-filter-details + .collection-filter-details{margin-top:12px}
  .collection-filter-details__summary{
    min-height:48px;
    padding:12px 14px;
    box-sizing:border-box;
    border-bottom:1px solid transparent;
  }
  .collection-filter-details[open] .collection-filter-details__summary{
    border-bottom-color:var(--color-border-soft);
  }
  .collection-filter-details__body{
    padding:12px 14px 14px;
  }
  .toolbar{flex-direction:column;align-items:stretch}
  .toolbar form{display:flex;flex-wrap:wrap;align-items:center;gap:8px;width:100%}
  .toolbar form select{flex:1;min-width:0}
}

@media(min-width:901px){
  .collection-filter-details + .collection-filter-details{margin-top:24px}
  .collection-filter-details__summary{
    margin:0 0 var(--sp-3) 0;
    padding-bottom:var(--sp-3);
    border-bottom:1px solid var(--color-border-soft);
  }
  html.collection-filters-wide .collection-filter-details__summary{
    pointer-events:none;
    cursor:default;
  }
  .collection-filter-details__chevron{display:none}
  .collection-filter-details__body{padding-top:0}
}

/* ====== Product detail ====== */
.product-detail{display:grid;grid-template-columns:1fr 1fr;gap:var(--sp-7);margin:var(--sp-6) 0}
.product-gallery .main{aspect-ratio:1/1;background:var(--color-bg-soft);border-radius:var(--radius);overflow:hidden;margin-bottom:var(--sp-3)}
.product-gallery .main img{width:100%;height:100%;object-fit:cover}
.product-gallery .thumbs{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--sp-2)}
.product-gallery .thumbs img{aspect-ratio:1/1;width:100%;object-fit:cover;border:2px solid transparent;border-radius:var(--radius-sm);cursor:pointer;background:var(--color-bg-soft)}
.product-gallery .thumbs img.active,.product-gallery .thumbs img:hover{border-color:var(--color-primary)}
.product-info h1{font-size:var(--fs-28);margin-bottom:var(--sp-2)}
.product-info .price{font-size:var(--fs-32);font-weight:700;color:var(--color-accent);margin:var(--sp-3) 0}
.product-info .price .old{text-decoration:line-through;color:var(--color-text-muted);font-size:var(--fs-18);margin-left:var(--sp-2);font-weight:500}
.product-meta{display:flex;flex-wrap:wrap;gap:var(--sp-4);font-size:var(--fs-14);color:var(--color-text-soft);margin-bottom:var(--sp-5)}
.product-meta strong{color:var(--color-text)}
.variant-list{position:relative;display:flex;gap:var(--sp-2);flex-wrap:wrap;margin-bottom:var(--sp-4)}
.variant-list label{padding:8px 16px;border:2px solid var(--color-border);border-radius:var(--radius);cursor:pointer;font-weight:600;font-size:var(--fs-14);transition:all var(--t-fast)}
/* Không display:none radio: một số trình duyệt không bắn change ổn định khi bấm label */
.variant-list input{
  position:absolute;
  opacity:0;
  width:1px;height:1px;
  margin:-1px; padding:0;
  overflow:hidden; clip:rect(0,0,0,0);
  border:0;
  pointer-events:none;
}
.variant-list input:checked+label{border-color:var(--color-primary);background:var(--color-primary-light);color:var(--color-secondary)}
.variant-list label.variant-pill {
  padding: 0;
  display: inline-flex;
  flex-direction: column;
  align-items: stretch;
  overflow: hidden;
  min-width: 112px;
  max-width: 148px;
  text-align: center;
}
.variant-pill__media {
  display: block;
  aspect-ratio: 1;
  background: var(--color-bg-soft);
  line-height: 0;
}
.variant-pill__media img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}
.variant-pill__placeholder {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  height: 100%;
  min-height: 96px;
  font-size: 11px;
  font-weight: 600;
  color: var(--color-text-muted);
}
.variant-pill__body {
  padding: 8px 10px 10px;
  display: flex;
  flex-direction: column;
  gap: 4px;
}
.variant-pill__name {
  font-size: var(--fs-13);
  font-weight: 600;
  line-height: 1.3;
}
.variant-pill__price {
  font-size: var(--fs-12);
  font-weight: 600;
  color: var(--color-accent);
}
.product-detail__buy-actions{display:flex;gap:12px;flex-wrap:wrap;margin-top:var(--sp-3)}
.qty-input{display:inline-flex;border:1px solid var(--color-border);border-radius:var(--radius);overflow:hidden}
.qty-input button{width:36px;height:36px;background:var(--color-bg-soft);border:none;font-size:18px;cursor:pointer}
.qty-input input{width:48px;border:none;text-align:center;font-size:var(--fs-16);font-weight:600;background:#fff;-moz-appearance:textfield}
.qty-input input::-webkit-outer-spin-button,.qty-input input::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}

.tabs{margin:var(--sp-7) 0;border-top:1px solid var(--color-border-soft)}
.tabs__nav{display:flex;gap:0;border-bottom:1px solid var(--color-border-soft)}
.tabs__nav button{padding:var(--sp-3) var(--sp-5);border:none;background:none;font-size:var(--fs-15);font-weight:600;color:var(--color-text-soft);border-bottom:3px solid transparent;cursor:pointer}
.tabs__nav button.active{color:var(--color-secondary);border-color:var(--color-primary)}
.tabs__panel{padding:var(--sp-5) 0;line-height:1.8}
.tabs__panel:not(.active){display:none}

@media(max-width:900px){.product-detail{grid-template-columns:1fr}}

/* ====== Cart ====== */
.cart-table{width:100%;border-collapse:collapse}
.cart-table th,.cart-table td{padding:var(--sp-3);border-bottom:1px solid var(--color-border-soft)}
.cart-thumb{width:60px;height:60px;object-fit:cover;border-radius:var(--radius-sm);background:var(--color-bg-soft)}
.cart-summary{background:var(--color-bg-soft);border-radius:var(--radius);padding:var(--sp-5)}
.cart-summary .row{display:flex;justify-content:space-between;margin-bottom:var(--sp-3)}
.cart-summary .row.total{font-weight:700;font-size:var(--fs-18);color:var(--color-text);border-top:1px solid var(--color-border);padding-top:var(--sp-3)}
.cart-layout{display:grid;grid-template-columns:1fr 360px;gap:var(--sp-6)}
@media(max-width:900px){.cart-layout{grid-template-columns:1fr}}

/* ====== Checkout ====== */
.checkout-layout{display:grid;grid-template-columns:1fr 380px;gap:var(--sp-6)}
@media(max-width:900px){.checkout-layout{grid-template-columns:1fr}}

/* (legacy payment-method label rules removed — dùng .payment-method trực tiếp trên checkout) */

/* ====== Account ====== */
.account-layout{display:grid;grid-template-columns:240px 1fr;gap:var(--sp-6);margin:var(--sp-6) 0}
.account-sidebar{background:#fff;border:1px solid var(--color-border-soft);border-radius:var(--radius);padding:var(--sp-3);height:fit-content}
.account-sidebar a{display:block;padding:10px var(--sp-3);border-radius:var(--radius);color:var(--color-text);font-weight:500}
.account-sidebar a:hover,.account-sidebar a.active{background:var(--color-primary-light);color:var(--color-secondary)}
.account-content{background:#fff;border:1px solid var(--color-border-soft);border-radius:var(--radius);padding:var(--sp-5)}
@media(max-width:768px){.account-layout{grid-template-columns:1fr}}

/* ====== Auth pages (login/register/otp/forgot) ====== */
.auth-wrap{
  max-width:440px;margin:var(--sp-9) auto;background:#fff;border:1px solid var(--color-border-soft);
  border-radius:var(--radius-lg);padding:var(--sp-7);box-shadow:var(--shadow);
}
.auth-brand{
  display:flex;flex-direction:column;align-items:stretch;text-align:center;
  margin:0 0 var(--sp-6);padding-bottom:var(--sp-5);border-bottom:1px solid var(--color-border-soft);
}
.auth-brand__link{
  display:flex;flex-direction:row;align-items:center;justify-content:center;gap:12px;
  width:100%;text-decoration:none;color:inherit;margin:0 auto var(--sp-3);
  box-sizing:border-box;
}
.auth-brand__mark{
  width:56px;height:56px;border-radius:50%;background:#fff;border:1px solid var(--color-border-soft);
  display:grid;place-items:center;flex-shrink:0;box-shadow:0 4px 14px rgba(62,39,35,.08);
}
.auth-brand__mark img{
  width:42px!important;height:42px!important;max-width:none;object-fit:contain;object-position:center;
  display:block;mix-blend-mode:normal;margin:0;
}
.auth-brand__name{
  font-family:var(--font-heading);font-size:clamp(20px,3.5vw,26px);font-weight:700;letter-spacing:3px;
  color:var(--color-secondary);line-height:1;margin:0;white-space:nowrap;
  /* letter-spacing thường để khoảng sau chữ cuối → cụm brand lệch phải thị giác */
  margin-inline-end:-3px;
}
.auth-brand__heading{margin:0;width:100%;text-align:center;font-size:var(--fs-20);font-weight:600;color:var(--color-text-soft);line-height:1.4}
.auth-intro{
  text-align:center;font-size:var(--fs-14);color:var(--color-text-soft);line-height:1.55;
  margin:0 0 var(--sp-5);padding:0 var(--sp-2);
}
.auth-otp-hint{
  text-align:center;font-size:var(--fs-13);color:var(--color-text-muted);line-height:1.5;
  margin:-0.35rem 0 var(--sp-4);padding:0 var(--sp-2);
}
.auth-wrap .alert{margin-bottom:var(--sp-4)}
.auth-form__password-row{display:flex!important;flex-direction:column!important;gap:0!important}
.auth-form__password-row .form-group{margin-bottom:var(--sp-4)}
.auth-form__password-row .form-group:last-child{margin-bottom:0}
.auth-form__submit{margin-top:var(--sp-2)}
.auth-form--otp .otp-input{margin-top:var(--sp-3);margin-bottom:var(--sp-5)}
.auth-wrap .links{margin-top:var(--sp-5);font-size:var(--fs-14);text-align:center;color:var(--color-text-soft)}
.auth-wrap .links a{font-weight:600;color:var(--color-primary-dark)}
.otp-input{
  display:flex;gap:var(--sp-2);justify-content:center;align-items:center;margin:var(--sp-5) 0;
  flex-wrap:nowrap;max-width:100%;
  -webkit-user-select:none;user-select:none;
}
.otp-input input{
  box-sizing:border-box;width:48px;min-width:44px;height:56px;min-height:48px;flex:0 1 48px;
  border:2px solid var(--color-border);border-radius:var(--radius);text-align:center;
  font-size:max(16px, var(--fs-20));font-variant-numeric:tabular-nums;font-weight:700;background:#fff;
  transition:border-color .15s ease, box-shadow .15s ease;-webkit-appearance:none;appearance:none;
  touch-action:manipulation;
}
.otp-input input:focus{
  outline:none;border-color:var(--color-primary);
  box-shadow:0 0 0 3px rgba(244, 180, 26, 0.38);
}
.otp-input input::selection{background:rgba(244, 180, 26, 0.25)}
@media (max-width:400px){
  .otp-input{gap:clamp(4px,2vw,8px)}
  .otp-input input{width:44px;height:52px;font-size:max(17px, 1.05rem)}
}
@media(max-width:400px){.auth-wrap{padding:var(--sp-6) var(--sp-4)}}

@media(max-width:560px){
  .site-header__main{
    padding-inline:max(var(--sp-3),env(safe-area-inset-left)) max(var(--sp-3),env(safe-area-inset-right));
  }
  .brand__text{font-size:clamp(1.05rem,4.5vw,var(--fs-24))}
}

/* ----- Client: mobile chi tiết (bổ sung) ----- */
html{scroll-padding-top:min(140px,calc(env(safe-area-inset-top) + 100px))}
.site-footer{padding-inline:env(safe-area-inset-left) env(safe-area-inset-right)}
.site-footer__bottom{padding-bottom:max(var(--sp-4),env(safe-area-inset-bottom))}

.breadcrumb{gap:var(--sp-2) 10px;line-height:1.45;margin-inline:0}
.page-cart .page-title,.page-checkout .page-title,.page-contact h1{font-size:clamp(1.25rem,5vw,var(--fs-28))}

.tabs__nav{
  gap:4px;padding-bottom:2px;margin:0 calc(-1 * var(--sp-2));
  padding-inline:max(0px,var(--sp-2));
  overflow-x:auto;-webkit-overflow-scrolling:touch;flex-wrap:nowrap;scrollbar-width:thin;
}
.tabs__nav button{
  flex:0 0 auto;padding-left:clamp(14px,3vw,22px);padding-right:clamp(14px,3vw,22px);
  white-space:nowrap;font-size:var(--fs-14)
}

.section{padding:clamp(var(--sp-7),10vw,var(--sp-9)) 0}

.collection-banner{border-radius:var(--radius)}
.collection-banner h1{font-size:clamp(1.2rem,5.5vw,var(--fs-32));text-align:center;padding:var(--sp-3) var(--sp-2)}

.product-info h1{font-size:clamp(1.35rem,4.8vw,var(--fs-28))}
.product-info .price{font-size:clamp(1.35rem,6vw,var(--fs-32))}

.product-gallery .thumbs{grid-template-columns:repeat(4,minmax(0,1fr));gap:6px}

@media(max-width:900px){
  .toolbar{align-items:flex-start}
  .cart-summary,.checkout-summary{position:static!important;top:auto;width:100%}
}

@media(max-width:768px){
  .account-layout{margin:var(--sp-4) 0;gap:var(--sp-4)}
  .account-sidebar{
    display:flex;
    flex-flow:row wrap;
    align-items:center;
    gap:8px 10px;
    overflow-x:auto;
    -webkit-overflow-scrolling:touch;
    padding:12px;
    border-radius:var(--radius);
    overscroll-behavior-x:contain;
  }
  .account-user{
    flex:1 0 100%;
    margin:0 0 6px;
    padding-bottom:10px;
    border-bottom:1px solid var(--color-border-soft);
  }
  .account-sidebar > a{
    flex:0 0 auto;
    white-space:nowrap;
    padding:10px 16px;
    font-size:var(--fs-14);
    min-height:44px;
    display:inline-flex;
    align-items:center;
  }
  .account-content{padding:var(--sp-4);border-radius:var(--radius)}
  .contact-map{height:min(56vw,280px)}
  .news-article{padding:var(--sp-4)}
  .success-card{padding:var(--sp-5) var(--sp-4);margin-inline:max(0px,var(--sp-2))}

  /* PDP: ảnh chính không zoom-crop — hiển thị trọn trong khung 4:3 */
  .product-gallery .main{
    aspect-ratio:4 / 3;
    max-height:min(72vw,480px);
  }
  .product-gallery .main img{
    object-fit:contain;
    object-position:center;
  }
}

@media(max-width:480px){
  .product-gallery .thumbs{grid-template-columns:repeat(3,minmax(0,1fr))}
  .hero-banners{padding-inline:max(var(--sp-3),env(safe-area-inset-left)) max(var(--sp-3),env(safe-area-inset-right))}
  .news-grid{gap:var(--sp-4)}
  .product-detail__buy-actions{flex-direction:column;align-items:stretch}
  .product-detail__buy-actions .btn--lg{
    width:100%;
    max-width:100%;
    box-sizing:border-box;
    margin-left:0;
    margin-right:0;
  }
}

@media(prefers-reduced-motion:reduce){
  .site-header{transition:none!important}
  .site-header__top,.site-nav,.site-header__main,.site-nav__mega{transition:none!important}
  .site-nav__list>li>a{transition:none!important}
  .site-nav__list>li>a:hover{transform:none!important}
}

/* ====== Status pills ====== */
.status-pill{display:inline-block;padding:4px 12px;border-radius:var(--radius-pill);font-size:var(--fs-12);font-weight:600}
.status-pending  {background:#fff8e1;color:#a96d00}
.status-confirmed{background:#e3f2fd;color:#0277bd}
.status-shipping {background:#e8f5e9;color:#2e7d32}
.status-completed{background:#dcedc8;color:#33691e}
.status-cancelled{background:#ffebee;color:#c62828}
.status-paid     {background:#e8f5e9;color:#2e7d32}
.status-unpaid   {background:#fff8e1;color:#a96d00}
.status-failed,.status-refunded{background:#ffebee;color:#c62828}

/* ====== Cart Page ====== */
.page-cart .page-title{margin:var(--sp-5) 0 var(--sp-4);font-size:var(--fs-28)}
.cart-empty{text-align:center;padding:var(--sp-9) 0;background:var(--color-bg-soft);border-radius:var(--radius);margin:var(--sp-5) 0}
.cart-empty p{font-size:var(--fs-18);margin-bottom:var(--sp-4);color:var(--color-text-soft)}
.cart-grid{display:grid;grid-template-columns:1fr 360px;gap:var(--sp-6);align-items:flex-start}
@media(max-width:900px){.cart-grid{grid-template-columns:1fr}}
.table-responsive .table,.table-responsive table.table--bordered{min-width:440px}

.cart-items{background:#fff;border:1px solid var(--color-border-soft);border-radius:var(--radius);overflow:hidden}
@media(max-width:900px){
  .page-cart .cart-items{overflow:visible}
}
.cart-table th{background:var(--color-bg-soft);font-size:var(--fs-13);text-align:left;color:var(--color-text-soft);font-weight:600;text-transform:uppercase;letter-spacing:.5px}
.cart-table td.cart-thumb{width:80px;padding:var(--sp-2)}
.cart-table .cart-thumb img{width:72px;height:72px;object-fit:cover;border-radius:var(--radius-sm);background:var(--color-bg-soft);display:block}
.cart-name{font-weight:600;color:var(--color-text)}
.cart-name:hover{color:var(--color-primary-dark)}
.cart-variant{font-size:var(--fs-13);color:var(--color-text-soft);margin-top:2px}
.cart-subtotal{font-weight:700;color:var(--color-accent-dark, #b71c1c)}
.qty-form{display:flex;flex-direction:column;align-items:flex-start;gap:6px}
.qty-form .btn-link{font-size:var(--fs-12)}
.btn-link{background:none;border:none;color:var(--color-primary-dark);cursor:pointer;font-size:var(--fs-13);text-decoration:underline;padding:0}
.btn-icon{background:none;border:none;cursor:pointer;color:var(--color-text-soft);padding:6px}
.btn-icon:hover{color:#c62828}
.cart-actions{display:flex;justify-content:space-between;padding:var(--sp-4);background:var(--color-bg-soft);gap:var(--sp-3);flex-wrap:wrap}

.cart-summary{background:#fff;border:1px solid var(--color-border-soft);border-radius:var(--radius);padding:var(--sp-5);position:sticky;top:120px}
.cart-summary h3{margin:0 0 var(--sp-4);font-size:var(--fs-18)}
.promo-form{margin-bottom:var(--sp-4);padding-bottom:var(--sp-4);border-bottom:1px dashed var(--color-border-soft)}
.promo-form label{display:block;margin-bottom:6px;font-weight:600;font-size:var(--fs-13)}
.promo-row{display:flex;gap:6px}
.promo-row input{flex:1;padding:9px 12px;border:1px solid var(--color-border);border-radius:var(--radius-sm);font-size:var(--fs-14)}
.summary-line{display:flex;justify-content:space-between;padding:8px 0;font-size:var(--fs-14)}
.summary-line.summary-total{font-size:var(--fs-18);font-weight:700;border-top:1px solid var(--color-border);margin-top:var(--sp-2);padding-top:var(--sp-3);color:var(--color-secondary)}
.btn-block{display:block;width:100%;text-align:center;margin-top:var(--sp-4)}
.cart-note{margin-top:var(--sp-3);font-size:var(--fs-12);color:var(--color-text-soft);line-height:1.5}
.text-danger{color:#c62828}

/* ====== Checkout Page ====== */
.page-checkout .page-title{margin:var(--sp-5) 0 var(--sp-4);font-size:var(--fs-28)}
.checkout-grid{display:grid;grid-template-columns:1fr 380px;gap:var(--sp-6);align-items:flex-start}
@media(max-width:900px){.checkout-grid{grid-template-columns:1fr}}
.checkout-form{background:#fff;border:1px solid var(--color-border-soft);border-radius:var(--radius);padding:var(--sp-5)}
.checkout-form h3{margin:var(--sp-4) 0 var(--sp-3);font-size:var(--fs-18);color:var(--color-secondary)}
.checkout-form h3:first-child{margin-top:0}
.form-row{margin-bottom:var(--sp-3)}
.form-row label{display:block;margin-bottom:6px;font-weight:600;font-size:var(--fs-14)}
.form-row .req{color:#c62828}
.form-row input,.form-row textarea,.form-row select{width:100%;padding:10px 12px;border:1px solid var(--color-border);border-radius:var(--radius-sm);font-size:var(--fs-14);font-family:inherit;background:#fff}
.form-row input:focus,.form-row textarea:focus,.form-row select:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px var(--color-primary-light)}
.form-row.two-col{display:grid;grid-template-columns:1fr 1fr;gap:var(--sp-3)}
@media(max-width:600px){.form-row.two-col{grid-template-columns:1fr}}
.payment-methods{display:flex;flex-direction:column;gap:var(--sp-2)}
.payment-method{
  display:flex;align-items:center;gap:var(--sp-3);padding:var(--sp-3);border:1.5px solid var(--color-border);
  border-radius:var(--radius);cursor:pointer;transition:border-color var(--t-fast),background var(--t-fast),box-shadow var(--t-fast);
}
.payment-method:hover{border-color:var(--color-primary)}
.payment-method:has(input:checked){border-color:var(--color-primary);background:var(--color-primary-light);box-shadow:0 0 0 1px rgba(244,180,26,.25)}
.payment-method input{margin:0;flex-shrink:0;accent-color:var(--color-primary);width:1.1rem;height:1.1rem}
.payment-method__icon{
  flex-shrink:0;width:56px;height:56px;border-radius:var(--radius-sm);background:#fff;border:1px solid var(--color-border-soft);
  display:flex;align-items:center;justify-content:center;padding:6px;box-sizing:border-box;
}
.payment-method__icon img{display:block;width:100%;height:100%;object-fit:contain}
.payment-method:has(input:checked) .payment-method__icon{border-color:var(--color-primary);background:#fff}
.payment-method__text{flex:1;min-width:0}
.payment-method b{display:block;font-size:var(--fs-15)}
.payment-method small{display:block;color:var(--color-text-soft);font-size:var(--fs-13);margin-top:2px;line-height:1.4}
@media(max-width:480px){
  .payment-method{align-items:flex-start;padding:var(--sp-3) var(--sp-2)}
  .payment-method__icon{width:52px;height:52px}
}

.checkout-summary{background:#fff;border:1px solid var(--color-border-soft);border-radius:var(--radius);padding:var(--sp-5);position:sticky;top:120px}
.checkout-summary h3{margin:0 0 var(--sp-3);font-size:var(--fs-18)}
.checkout-items{list-style:none;padding:0;margin:0 0 var(--sp-4);max-height:380px;overflow-y:auto;border-bottom:1px dashed var(--color-border-soft);padding-bottom:var(--sp-3)}
.checkout-items li{display:flex;gap:var(--sp-3);padding:var(--sp-2) 0;align-items:center;font-size:var(--fs-13)}
.checkout-items img{width:54px;height:54px;border-radius:var(--radius-sm);object-fit:cover;background:var(--color-bg-soft)}
.checkout-items .meta{flex:1;min-width:0}
.checkout-items .name{font-weight:600;color:var(--color-text);line-height:1.4}
.checkout-items .variant{color:var(--color-text-soft);font-size:var(--fs-12)}
.checkout-items .qty{color:var(--color-text-soft);font-size:var(--fs-12);margin-top:2px}
.checkout-items .amount{font-weight:700;color:var(--color-secondary);white-space:nowrap}
.cart-back{display:block;text-align:center;margin-top:var(--sp-3)}

/* ====== Order Success Page ====== */
.page-order-success{padding:var(--sp-7) 0}
.success-card{max-width:880px;margin:0 auto;background:#fff;border:1px solid var(--color-border-soft);border-radius:var(--radius-lg);padding:var(--sp-7);box-shadow:var(--shadow)}
.success-icon{text-align:center;margin-bottom:var(--sp-3)}
.success-card h1{text-align:center;color:#2E7D32;margin:0 0 var(--sp-3)}
.success-card .lead{text-align:center;font-size:var(--fs-16);color:var(--color-text-soft);margin-bottom:var(--sp-2)}
.success-card>p{text-align:center;color:var(--color-text-soft);margin-bottom:var(--sp-5)}
.order-info-grid{display:grid;grid-template-columns:1fr 1fr;gap:var(--sp-5);background:var(--color-bg-soft);padding:var(--sp-4);border-radius:var(--radius);margin-bottom:var(--sp-5)}
@media(max-width:600px){.order-info-grid{grid-template-columns:1fr}}
.order-info-grid h3{margin:0 0 var(--sp-2);font-size:var(--fs-15);color:var(--color-secondary);text-transform:uppercase;letter-spacing:.5px}
.order-info-grid p{margin:4px 0;font-size:var(--fs-14)}
.success-totals{padding:var(--sp-4);background:var(--color-bg-soft);border-radius:var(--radius);margin-top:var(--sp-3)}
.success-actions{display:flex;justify-content:center;gap:var(--sp-3);margin-top:var(--sp-5);flex-wrap:wrap}
.badge{display:inline-block;padding:3px 10px;border-radius:var(--radius-pill);font-size:var(--fs-12);font-weight:600}
.badge-PAID{background:#e8f5e9;color:#2e7d32}
.badge-UNPAID{background:#fff8e1;color:#a96d00}
.badge-FAILED,.badge-REFUNDED{background:#ffebee;color:#c62828}

/* ====== News list & detail ====== */
.news-layout{display:grid;grid-template-columns:1fr 300px;gap:var(--sp-6);margin:var(--sp-6) 0}
@media(max-width:900px){.news-layout{grid-template-columns:1fr}}
.news-list h1{margin-bottom:var(--sp-4)}

.news-grid{
  display:grid;
  grid-template-columns:repeat(auto-fill,minmax(min(100%,220px),1fr));
  gap:clamp(12px,3vw,var(--sp-4));
}
@media(min-width:640px){
  .news-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:clamp(14px,2.2vw,var(--sp-5));}
}
@media(min-width:992px){
  .news-grid{grid-template-columns:repeat(3,minmax(0,1fr));gap:clamp(14px,2vw,22px);}
}
@media(min-width:1200px){
  .news-grid{grid-template-columns:repeat(4,minmax(0,1fr));}
}

/* Trang chủ: backend chỉ 3 tin (HomeServlet.findLatest); không ép 4 cột — tránh ô trống desktop */
@media(min-width:992px) and (max-width:1199.98px){
  .news-grid--home{grid-template-columns:repeat(2,minmax(0,1fr));}
}
@media(min-width:1200px){
  .news-grid--home{grid-template-columns:repeat(3,minmax(0,1fr));}
}

.news-card{background:#fff;border:1px solid var(--color-border-soft);border-radius:var(--radius);overflow:hidden;transition:box-shadow var(--t-fast),transform var(--t-fast)}
.news-card:hover{box-shadow:var(--shadow);transform:translateY(-3px)}

.news-thumb,
.news-card__media{
  position:relative;
  display:block;
  aspect-ratio:16/10;
  overflow:hidden;
  background:var(--color-bg-soft);
  color:inherit;
  text-decoration:none;
}
.news-thumb:focus-visible,.news-card__media:focus-visible{outline:3px solid var(--color-primary);outline-offset:-3px}

.news-thumb img,
.news-card__media img{
  display:block;
  width:100%;
  height:100%;
  object-fit:cover;
  transition:transform var(--t-fast);
}
.news-card:hover .news-thumb img,
.news-card:hover .news-card__media img{transform:scale(1.035)}

.news-card__overlay{position:absolute;inset:0;pointer-events:none;background:linear-gradient(to top,rgba(18,14,22,.93) 0%,rgba(18,14,22,.52) 40%,transparent 74%)}

.news-card__overlay-title{
  position:absolute;
  left:var(--sp-3);
  right:var(--sp-3);
  bottom:var(--sp-3);
  z-index:1;
  margin:0;
  font-family:var(--font-heading);
  font-weight:700;
  font-size:clamp(var(--fs-13),2.55vw,var(--fs-15));
  line-height:1.35;
  color:#fff;
  text-shadow:0 2px 12px rgba(0,0,0,.42);
  display:-webkit-box;
  -webkit-line-clamp:3;
  -webkit-box-orient:vertical;
  overflow:hidden;
}

.news-body{padding:var(--sp-3) var(--sp-3) var(--sp-3)}
.news-card__body{padding:var(--sp-2) var(--sp-3) var(--sp-3)}
.news-card__cat{display:inline-block;margin-bottom:4px;background:var(--color-primary-light);color:var(--color-secondary);padding:2px 8px;border-radius:var(--radius-pill);font-size:var(--fs-12);font-weight:600;text-transform:uppercase;letter-spacing:.04em}

.news-card__title,
.news-body h3{
  margin:4px 0 6px;
  font-size:var(--fs-15);
  line-height:1.38;
}
.news-card__title{
  margin:6px 0 4px;
  font-weight:600;
  display:-webkit-box;
  -webkit-line-clamp:2;
  -webkit-box-orient:vertical;
  overflow:hidden;
  color:var(--color-text);
}
.news-card__title:hover,.news-body h3 a:hover{color:var(--color-primary-dark)}
.news-body h3{font-size:var(--fs-15);margin-top:8px;line-height:1.38;font-weight:600;margin-bottom:var(--sp-2)}
.news-body h3 a{color:var(--color-text)}
.news-card__date,
.news-meta{color:var(--color-text-soft);font-size:var(--fs-12);display:block;margin-top:4px}
.news-summary{font-size:var(--fs-13);color:var(--color-text-soft);line-height:1.5;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}

.news-card--titlescreen .news-body h3{display:none;}
.news-card--titlescreen .news-card__title{
  position:absolute;
  width:1px;
  height:1px;
  padding:0;
  margin:-1px;
  overflow:hidden;
  clip-path:inset(50%);
  white-space:nowrap;
  border:0;
}
@media(max-width:479px){
  .news-grid{grid-template-columns:1fr;}
}
@media(min-width:480px) and (max-width:639px){
  .news-grid{
    grid-template-columns:repeat(2,minmax(0,1fr));
    gap:10px clamp(10px,3vw,14px);
  }
  .news-card__overlay-title{-webkit-line-clamp:4;font-size:var(--fs-13);}
}

.news-cat{display:inline-block;background:var(--color-primary-light);color:var(--color-secondary);padding:2px 10px;border-radius:var(--radius-pill);font-size:var(--fs-12);font-weight:600;margin-bottom:6px}
.news-sidebar{background:var(--color-bg-soft);padding:var(--sp-4);border-radius:var(--radius);height:fit-content}
.news-sidebar h3{margin:0 0 var(--sp-3);font-size:var(--fs-16)}
.news-sidebar ul{list-style:none;padding:0;margin:0}
.news-sidebar ul li a{display:block;padding:8px 10px;border-radius:var(--radius-sm);color:var(--color-text);font-size:var(--fs-14)}
.news-sidebar ul li a:hover,.news-sidebar ul li a.active{background:var(--color-primary-light);color:var(--color-secondary);font-weight:600}

.news-article{background:#fff;padding:var(--sp-5);border:1px solid var(--color-border-soft);border-radius:var(--radius)}
.breadcrumb{font-size:var(--fs-13);color:var(--color-text-soft);margin-bottom:var(--sp-3)}
.breadcrumb a{color:var(--color-primary-dark)}
.news-meta-bar{display:flex;gap:var(--sp-3);color:var(--color-text-soft);font-size:var(--fs-13);margin:var(--sp-2) 0 var(--sp-4);flex-wrap:wrap}

.news-cover figcaption{margin:0;padding:0}
.news-title-fallback{margin:0 0 var(--sp-4);font-size:clamp(var(--fs-20),4vw,var(--fs-28));line-height:1.25;color:var(--color-secondary)}
.news-cover__inner{position:relative;border-radius:var(--radius);overflow:hidden;background:var(--color-bg-soft);aspect-ratio:16/9}
.news-cover img{display:block;width:100%;height:100%;object-fit:cover;margin:0}
.news-cover__title{
  position:absolute;
  left:0;
  right:0;
  bottom:0;
  padding:var(--sp-5) var(--sp-5) var(--sp-4);
  margin:0;
  font-size:clamp(var(--fs-18),4vw,var(--fs-24));
  line-height:1.25;
  font-weight:700;
  color:#fff;
  font-family:var(--font-heading);
  text-shadow:0 2px 20px rgba(0,0,0,.55);
  background:linear-gradient(to top,rgba(12,10,14,.94) 0%,rgba(12,10,14,.45) 50%,transparent 100%);
}

.news-summary-quote{margin:var(--sp-3) 0;padding:var(--sp-3) var(--sp-4);background:var(--color-bg-soft);border-left:4px solid var(--color-primary);font-style:italic;color:var(--color-text-soft)}
.news-content{line-height:1.72;font-size:clamp(var(--fs-14),.9vw,var(--fs-15));color:var(--color-text)}
.news-content img{max-width:100%;border-radius:var(--radius);margin:var(--sp-3) 0}
.news-content h2,.news-content h3{margin-top:var(--sp-5);color:var(--color-secondary)}
.latest-news{list-style:none;padding:0;margin:0}
.latest-news li{margin-bottom:var(--sp-3)}
.latest-news li a{display:flex;gap:10px;color:var(--color-text)}
.latest-news li img{width:60px;height:60px;border-radius:var(--radius-sm);object-fit:cover;flex-shrink:0}
.latest-news li strong{display:block;font-size:var(--fs-13);line-height:1.4}
.latest-news li small{color:var(--color-text-soft);font-size:var(--fs-12)}
.latest-news li a:hover strong{color:var(--color-primary-dark)}

/* ====== Contact ====== */
.page-contact{padding:var(--sp-6) 0}
.page-contact h1{margin-bottom:var(--sp-2)}
.contact-grid{display:grid;grid-template-columns:1fr 380px;gap:var(--sp-5);margin-top:var(--sp-5)}
@media(max-width:900px){.contact-grid{grid-template-columns:1fr}}
.contact-form{background:#fff;border:1px solid var(--color-border-soft);border-radius:var(--radius);padding:var(--sp-5)}
.contact-info{background:var(--color-bg-soft);border-radius:var(--radius);padding:var(--sp-4)}
.contact-info h3{margin:0 0 var(--sp-3);color:var(--color-secondary)}
.contact-info p{margin:6px 0;font-size:var(--fs-14)}
.contact-map{width:100%;height:240px;border:0;border-radius:var(--radius);margin-top:var(--sp-3)}

/* ====== Account sidebar polish ====== */
.account-user{padding:var(--sp-3);border-bottom:1px solid var(--color-border-soft);margin-bottom:var(--sp-2)}
.account-user strong{display:block;font-size:var(--fs-15);color:var(--color-secondary)}
.account-user small{color:var(--color-text-soft);font-size:var(--fs-12);word-break:break-word}
.account-form{max-width:680px}
.text-soft{color:var(--color-text-soft);font-size:var(--fs-14)}

/* ====== Pagination ====== */
.pagination{display:flex;gap:6px;justify-content:center;margin:var(--sp-5) 0;flex-wrap:wrap}
.pagination a{display:inline-block;padding:8px 14px;border:1px solid var(--color-border);border-radius:var(--radius-sm);color:var(--color-text);background:#fff;font-size:var(--fs-14)}
.pagination a:hover{border-color:var(--color-primary);background:var(--color-primary-light)}
.pagination a.active{background:var(--color-primary);border-color:var(--color-primary-dark);color:var(--color-secondary);font-weight:700}


