/* =========================================================
   01) RESET / BASE
   ========================================================= */
* {
    box-sizing: border-box
}

html,
body {
    margin: 0;
    padding: 0
}

body {
    font-family: 'Poppins', Arial, Helvetica, sans-serif;
    background: var(--bg);
    color: var(--text);
}

a {
    color: inherit;
    text-decoration: none
}

img {
    max-width: 100%;
    display: block
}

button {
    font: inherit
}


/* =========================================================
   02) ROOT VARIABLES
   ========================================================= */
:root {
    --bg: #f6f4f1;
    --card: #ffffff;
    --line: #e5ded8;
    --text: #2f2a27;
    --muted: #7f7771;
    --accent: #8e7b6d;
    --accent-2: #b7a395;
    --accent-3: #ede6df;
    --sale: #a35f67;
    --sale-dark: #8f5158;
    --shadow: 0 12px 30px rgba(42, 34, 30, .07)
}


/* =========================================================
   03) SHELL / GLOBAL LAYOUT
   ========================================================= */
.site-shell {
    width: 100%;
    background: var(--card);
    overflow: hidden;
    position: relative
}


/* =========================================================
   04) TOP NOTICE
   ========================================================= */
.top-notice {
    position: relative;
    display: flex;
    align-items: center;
    overflow: hidden;
    height: 42px;
    background: #fbfaf8;
    color: var(--muted);
    border-bottom: 1px solid var(--line);
    white-space: nowrap;
    text-transform: uppercase
}

.top-notice__marquee {
    display: flex;
    align-items: center;
    gap: 42px;
    min-width: max-content;
    padding-left: 100%;
    font-size: 12px;
    font-weight: 600;
    animation: nbMarquee 20s linear infinite
}

.top-notice__marquee span {
    display: inline-flex;
    align-items: center;
    gap: 10px
}

.top-notice__marquee strong {
    color: #a35f67;
}

@keyframes nbMarquee {
    from {
        transform: translateX(0)
    }

    to {
        transform: translateX(-100%)
    }
}


/* =========================================================
   05) HEADER
   ========================================================= */
.app-header{
  position:sticky;
  top:0;
  z-index:40;
  background:rgba(255,255,255,.94);
  backdrop-filter:blur(12px);
  border-bottom:1px solid var(--line);
}

.topbar{
  display:flex;
  align-items:center;
  justify-content:center;
  gap:60px;
  padding:10px 40px;
  position:relative;
}

.left-tools,
.right-tools{
  display:flex;
  align-items:center;
  gap:10px;
  flex:0 0 auto;
}

.left-tools{
  min-width:42px;
}

.right-tools{
  display:flex;
  align-items:center;
  justify-content:flex-end;
  gap:20px;
  flex:0 0 auto;
  min-width:150px;
}

@media (min-width:1024px){
  .left-tools{
    position:absolute;
    left:40px;
    display:none;
  }
}

.header-mainline{
  display:flex;
  align-items:center;
  justify-content:flex-start;
  gap:40px;
  flex:0 0 auto;
  min-width:0;
  overflow:hidden;
}
.desktop-nav{
  display:flex;
  align-items:center;
  justify-content:flex-start;
  gap:25px;
  flex:0 0 auto;
  min-width:0;
  padding:0;
  margin:0;
  color:#000;
  opacity:.85;
  font-size:14px;
  text-transform:uppercase;
  letter-spacing:.12em;
  white-space:nowrap;
}

.desktop-nav a{
  display:inline-flex;
  align-items:center;
  white-space:nowrap;
  font-size:14px;
  text-transform:uppercase;
  font-weight:500;
}

.desktop-nav a:hover,
.desktop-nav a.is-active{
  color:000;
  opacity:1;
}

.icon-btn{
  width:42px;
  height:42px;
  border:1px solid var(--line);
  border-radius:999px;
  display:grid;
  place-items:center;
  background:var(--card);
  position:relative;
  cursor:pointer;
  transition:.2s ease;
  padding:0;
}

.icon-btn:hover{
  transform:translateY(-1px);
  box-shadow:var(--shadow);
}

.icon{
  width:22px;
  height:22px;
  stroke:#4f4945;
  stroke-width:1.8;
  fill:none;
  stroke-linecap:round;
  stroke-linejoin:round;
}

.badge{
  position:absolute;
  top:-4px;
  right:-1px;
  min-width:18px;
  height:18px;
  padding:0 5px;
  border-radius:999px;
  background:var(--sale);
  color:#fff;
  font-size:11px;
  line-height:18px;
  text-align:center;
  font-weight:600;
  border:2px solid #fff;
}

/* masaüstünde hamburger yok */
.menu-toggle-btn{
  display:none;
}

@media (min-width:1024px) and (max-width:1250px){
  .topbar{
    gap:30px;
  }

  .header-mainline{
    gap:20px;
  }

  .desktop-nav{
    gap:15px;
  }
}


/* =========================================================
   06) MOBILE STORIES
   ========================================================= */
.mobile-stories-wrap{
  display:block;
  position:relative;
  border-top:1px solid #eee3db;
  background:#fff;
}

.story-arrow{
  display:none;
}

.story-arrow.left{
  left:8px;
}

.story-arrow.right{
  right:8px;
}

.story-arrow svg{
  width:16px;
  height:16px;
  stroke:#403731;
  stroke-width:2;
  fill:none;
  stroke-linecap:round;
  stroke-linejoin:round;
}

.mobile-stories{
  display:flex;
  gap:14px;
  overflow-x:auto;
  scroll-behavior:smooth;
  padding:14px 35px 16px 14px;
  background:transparent;
  scrollbar-width:none;
  -webkit-overflow-scrolling:touch;
}

.mobile-stories::-webkit-scrollbar{
  display:none;
}

.story{
  flex:0 0 auto;
  width:78px;
  text-align:center;
  cursor:pointer;
}

.story-ring{
  width:70px;
  height:70px;
  margin:0 auto 8px;
  border-radius:50%;
  padding:3px;
  background:#ff2d2d;
}

.story.is-muted .story-ring{
  background:#e5dede;
}

.story-ring span{
  display:block;
  width:100%;
  height:100%;
  border-radius:50%;
  border:3px solid #fff;
  overflow:hidden;
  background:#f6f2f0;
}

.story img{
  width:100%;
  height:100%;
  object-fit:cover;
}

.story-label{
  font-size:12px;
  color:var(--muted);
  white-space:nowrap;
  overflow:hidden;
  text-overflow:ellipsis;
  text-transform:uppercase;
  font-weight:600;
}


/* =========================================================
   07) MOBILE DRAWER
   ========================================================= */
.mobile-drawer{
  position:fixed;
  inset:0;
  z-index:90;
  opacity:0;
  visibility:hidden;
  pointer-events:none;
  transition:.25s ease;
}

.mobile-drawer.is-open{
  opacity:1;
  visibility:visible;
  pointer-events:auto;
}

.mobile-drawer__overlay{
  position:absolute;
  inset:0;
  background:rgba(20,16,13,.38);
}

.mobile-drawer__panel{
  position:absolute;
  top:0;
  left:0;
  width:min(310px,88vw);
  height:100%;
  background:var(--card);
  transform:translateX(-100%);
  transition:transform .28s ease;
  box-shadow:16px 0 40px rgba(0,0,0,.12);
  padding:18px 16px 24px;
  display:flex;
  flex-direction:column;
  gap:18px;
}

.mobile-drawer.is-open .mobile-drawer__panel{
  transform:translateX(0);
}

.drawer-top{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
  padding-bottom:12px;
  border-bottom:1px solid var(--line);
}

.drawer-title{
  margin:0;
  font-size:16px;
  letter-spacing:.08em;
  text-transform:uppercase;
  color:#2c241f;
}

.drawer-links{
  display:grid;
  gap:10px;
}

.drawer-links a{
  display:flex;
  align-items:center;
  justify-content:space-between;
  padding:12px 14px;
  border:none;
  border-radius:5px;
  color:#433a35;
  background:var(--card);
  transition:.2s;
}

.drawer-links a:hover{
  background:#f8f8f8;
}


/* =========================================================
   08) HEADER RESPONSIVE
   ========================================================= */
@media (max-width:1199px){
  .header-mainline{
    gap:24px;
  }

  .desktop-nav{
    gap:18px;
    font-size:12px;
    letter-spacing:.1em;
  }

  .site-brand__text{
    font-size:19px;
    letter-spacing:.1em;
  }
}

@media (max-width:991px){
  .topbar{
    padding:14px 16px;
  }

  .menu-toggle-btn{
    display:grid;
  }

  .left-tools{
    min-width:auto;
    gap:8px;
  }

  .right-tools{
    min-width:auto;
    gap:5px;
  }

  .header-mainline{
    justify-content:center;
  }

  .desktop-nav{
    display:none;
  }

  .site-brand__text{
    font-size:22px;
    letter-spacing:.1em;
  }

  .site-brand__logo{
    width:30px;
    height:30px;
    flex:0 0 30px;
  }
}

@media (max-width:640px){
  .topbar{
    padding:7px 7px;
  }

  .icon-btn{
    width:36px;
    height:36px;
    border:none;
    background:transparent;
  }

  .mobile-stories{
    padding:12px 38px 14px 12px;
    gap:12px;
  }

  .story{
    width:68px;
  }

  .story-ring{
    width:62px;
    height:62px;
    margin-bottom:6px;
  }

  .story-label{
    font-size:11px;
  }

  .site-brand{
    gap:8px;
  }

  .site-brand__text{
    font-size:17px;
    letter-spacing:.08em;
  }

  .site-brand__logo{
    width:24px;
    height:24px;
    flex:0 0 24px;
  }
}


/* =========================================================
   09) STORY MODAL
   ========================================================= */
.story-modal {
    position: fixed;
    inset: 0;
    z-index: 2000;
    background: rgba(15, 12, 10, .82);
    display: flex;
    align-items: center;
    justify-content: center;
    opacity: 0;
    visibility: hidden;
    pointer-events: none;
    transition: .25s ease
}

.story-modal.is-open {
    opacity: 1;
    visibility: visible;
    pointer-events: auto
}

.story-modal__dialog {
    position: relative;
    width: min(380px, 92vw);
    aspect-ratio: 9/16;
    border-radius: 16px;
    overflow: hidden;
    background: #201914;
    transform: scale(.88);
    transition: transform .28s ease;
    box-shadow: 0 28px 70px rgba(0, 0, 0, .34)
}

.story-modal.is-open .story-modal__dialog {
    transform: scale(1)
}

.story-modal__image {
    width: 100%;
    height: 100%;
    object-fit: cover
}

.story-modal__overlay {
    position: absolute;
    inset: 0;
    background: linear-gradient(180deg, rgba(0, 0, 0, .34) 0%, rgba(0, 0, 0, .08) 34%, rgba(0, 0, 0, .36) 100%)
}

.story-progress {
    position: absolute;
    top: 10px;
    left: 10px;
    right: 10px;
    height: 4px;
    border-radius: 999px;
    background: rgba(255, 255, 255, .26);
    overflow: hidden;
    z-index: 2
}

.story-progress__bar {
    width: 0;
    height: 100%;
    background: var(--card)
}

.story-modal.is-playing .story-progress__bar {
    animation: storyProgress 4s linear forwards
}

@keyframes storyProgress {
    from {
        width: 0
    }

    to {
        width: 100%
    }
}

.story-modal__top {
    position: absolute;
    top: 22px;
    left: 14px;
    right: 14px;
    z-index: 2;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px
}

.story-modal__meta {
    display: flex;
    align-items: center;
    gap: 10px;
    min-width: 0;
    color: #fff
}

.story-modal__avatar {
    width: 38px;
    height: 38px;
    border-radius: 50%;
    border: 2px solid rgba(255, 255, 255, .88);
    object-fit: cover;
    flex: 0 0 38px
}

.story-modal__title {
    font-size: 13px;
    font-weight: 600;
    letter-spacing: .06em;
    text-transform: uppercase;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis
}

.story-modal__close {
    width: 36px;
    height: 36px;
    border: none;
    border-radius: 999px;
    display: grid;
    place-items: center;
    background: rgba(255, 255, 255, .16);
    cursor: pointer;
    padding: 0
}

.story-modal__close svg,
.story-modal__nav svg {
    width: 18px;
    height: 18px;
    stroke: #fff;
    stroke-width: 2;
    fill: none;
    stroke-linecap: round;
    stroke-linejoin: round
}

.story-modal__caption {
    position: absolute;
    left: 16px;
    right: 16px;
    bottom: 18px;
    z-index: 2;
    color: #fff
}

.story-modal__caption strong {
    display: block;
    margin-bottom: 6px;
    font-size: 22px;
    line-height: 1.1;
    letter-spacing: .08em;
    text-transform: uppercase
}

.story-modal__caption span {
    display: block;
    font-size: 14px;
    line-height: 1.5;
    color: rgba(255, 255, 255, .86)
}

.story-modal__nav {
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    width: 40px;
    height: 40px;
    border: none;
    border-radius: 999px;
    background: rgba(255, 255, 255, .14);
    display: grid;
    place-items: center;
    cursor: pointer;
    z-index: 2;
    padding: 0
}

.story-modal__nav.prev {
    left: 12px
}

.story-modal__nav.next {
    right: 12px
}


/* =========================================================
   10) MAIN LAYOUT / CONTENT
   ========================================================= */
.layout {
    display: block;
    background: var(--card)
}

.content{
  width:min(1400px, 100%);
  max-width:1400px;
  padding:0 0 20px;
  margin:0 auto;
}


/* =========================================================
   NORA HERO / TEK PARÇA
   ========================================================= */
.nb-hero{
  position:relative;
  width:100vw;
  max-width:none;
  margin-left:calc(-50vw + 50%);
  margin-right:calc(-50vw + 50%);
  min-height:520px;
  overflow:hidden;
  display:flex;
  align-items:center;
  border:1px solid rgba(240,215,198,.9);
  box-shadow:0 18px 40px rgba(42,34,30,.08);
  background:
    url('https://www.noraboutique.tr/wp-content/uploads/2026/04/nora-boutique-magazasi.png') center/cover no-repeat;
}

.nb-hero::before{
  content:"";
  position:absolute;
  inset:0;
  background:linear-gradient(90deg, rgba(0,0,0,.74) 0%, rgba(0,0,0,.42) 48%, rgba(0,0,0,.12) 100%);
  z-index:0;
}

.nb-hero::after{
  content:"";
  position:absolute;
  inset:0;
  background:linear-gradient(180deg, rgba(255,255,255,.04) 0%, rgba(255,255,255,0) 30%);
  z-index:0;
  pointer-events:none;
}

.nb-hero__inner{
  position:relative;
  z-index:1;
  width:100%;
  padding:0 72px;
}

.nb-hero__content{
  max-width:520px;
}

.nb-hero__title{
  margin:0;
  font-size:56px;
  line-height:1.04;
  font-weight:600;
  letter-spacing:0;
  text-transform:none;
  color:#fff;
  text-shadow:0 8px 24px rgba(0,0,0,.22);
}

.nb-hero__desc{
  margin:16px 0 0;
  max-width:460px;
  font-size:16px;
  line-height:1.6;
  color:#e9e2db;
}

/* =========================
   TABLET
   ========================= */
@media (max-width:991px){
  .nb-hero{
    min-height:380px;
    align-items:flex-end;
  }

  .nb-hero__inner{
    padding:0 28px 28px;
  }

  .nb-hero__content{
    max-width:360px;
  }

  .nb-hero__title{
    font-size:40px;
    line-height:1.05;
  }

  .nb-hero__desc{
    margin-top:12px;
    font-size:14px;
    line-height:1.5;
  }
}

/* =========================
   MOBILE
   ========================= */
@media (max-width:640px){
  .nb-hero{
    min-height:260px;
    align-items:flex-end;
  }

  .nb-hero__inner{
    padding:0 18px 18px;
  }

  .nb-hero__content{
    max-width:235px;
  }

  .nb-hero__title{
    font-size:28px;
    line-height:1.02;
    text-transform:uppercase;
    font-weight:700;
  }

  .nb-hero__desc{
    display:none;
  }
}

/* =========================================================
   12) GENERIC SECTIONS
   ========================================================= */
.section {
    margin-top: 34px
}

.section-head {
    display: flex;
    align-items: end;
    justify-content: space-between;
    gap: 16px;
    margin-bottom: 18px
}

.section-title {
    font-family: Georgia, "Times New Roman", serif !important;
    margin: 5px;
    font-size: 20px;
    color: var(--text);
    letter-spacing: .01em;
    font-weight: 600
    
}

.section-link {
    margin: 8px;
    font-size: 13px;
    text-transform: uppercase;
    letter-spacing: .16em;
    color: var(--accent);
    font-weight: 600
}


/* =========================================================
   13) CATEGORY GRID
   ========================================================= */
/* masaüstü */
.category-grid{
    display:grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap:22px;
}

/* tablet */
@media (max-width:991px){
    .category-grid{
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
}

/* mobil */
@media (max-width:640px){
    .category-grid{
        grid-template-columns: repeat(2, minmax(0, 1fr));
        gap:14px;
    }
}

.category-card {
    position: relative;
    min-height: 360px;
    border-radius: 0;
    overflow: hidden;
    border: 1px solid var(--line);
    background: #eee8e2;
    box-shadow: 0 14px 34px rgba(42, 34, 30, .05)
}

.category-card img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: transform .45s ease
}

.category-card:hover img {
    transform: scale(1.04)
}

.category-card::after {
    content: "";
    position: absolute;
    inset: 0;
    background: linear-gradient(180deg, rgba(20, 13, 8, .04) 0%, rgba(20, 13, 8, .24) 100%)
}

.category-card span {
    position: absolute;
    left: 22px;
    bottom: 20px;
    z-index: 1;
    font-size: 34px;
    letter-spacing: .14em;
    text-transform: uppercase;
    color: #fffaf6;
    font-family: Georgia, "Times New Roman", serif
}


/* =========================================================
   14) PRODUCT LIST / GRID
   ========================================================= */

/* masaüstü */
.product-row{
  display:grid;
  grid-template-columns: repeat(6, minmax(0, 1fr));
  gap:10px;
}



/* tablet */
@media (max-width:991px){
  .product-row{
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }
}

/* mobil */
@media (max-width:640px){
  .product-row{
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

.product-card {
    width: auto;
    margin: 0;
    background: var(--card);
    border: 1px solid var(--line);
    border-radius: 0;
    overflow: hidden;
    box-shadow: 0 14px 34px rgba(42, 34, 30, .05);
    display: flex;
    flex-direction: column;
    height: 100%;
}

.product-media {
    position:relative;
    display:block;
    aspect-ratio:4/5;
    background:#f4efea;
    overflow:hidden;
}

.product-media img{
  display:block;
  width:100%;
  height:100%;
  object-fit:cover;
  object-position:center;
  margin:0;
}

.discount-badge{
  position:absolute;
  top:10px;
  left:10px;
  z-index:3;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-height:24px;
  padding:0 8px;
  border-radius:4px;
  background:#e11d48;
  color:#fff;
  font-size:10px;
  font-weight:700;
  line-height:24px;
  letter-spacing:0;
  box-shadow:none;
}

.discount-badge::before,
.discount-badge::after{
  display:none;
}

.product-name {
    margin: 0 0 8px;
    font-size: 15px;
    color: var(--text);
    padding: 0;
    line-height: 1.4;
}

.product-meta{
  display:flex;
  align-items:flex-end;
  justify-content:space-between;
  gap:8px;
  margin-top:auto;
}

.tag{
  font-size:12px;
  color:var(--muted);
  white-space:nowrap;
}

.price-box {
    display: flex;
    flex-direction: column;
    gap: 4px;
    justify-content: flex-end;
}

.tag {
    font-size: 12px;
    color: var(--muted)
}


/* =========================================================
   15) POST / ENTRY CARDS
   ========================================================= */
.post-list {
    display: grid;
    gap: 18px
}

.post-card,
.entry-card {
    background: var(--card);
    border: 1px solid var(--line);
    padding: 15px;
    box-shadow: 0 14px 34px rgba(42, 34, 30, .05)
}

.post-card__title {
    margin: 0 0 10px;
    font-size: 24px
}


/* =========================================================
   16) FOOTER
   ========================================================= */
.nb-footer{
  margin-top:0;
  border-top:1px solid var(--line);
  background:var(--card);
}

.nb-footer__inner{
  display:grid;
  grid-template-columns:1.15fr .75fr .55fr .95fr;
  gap:18px;
  align-items:start;
  padding:24px 20px 18px;
}

.nb-footer__col{
  min-width:0;
}

.nb-footer__brand{
  max-width:340px;
}

.nb-footer__logo{
  display:inline-block;
  margin:0 0 10px;
  color:var(--text);
  font-size:24px;
  font-weight:600;
  letter-spacing:.12em;
  text-transform:uppercase;
}

.nb-footer__text{
  margin:0;
  color:var(--muted);
  font-size:14px;
  line-height:1.6;
}

.nb-footer__links{
  list-style:none;
  margin:0;
  padding:0;
  display:grid;
  gap:8px;
}

.nb-footer__links a{
  color:var(--muted);
  font-size:14px;
  transition:.2s ease;
}

.nb-footer__links a:hover{
  color:var(--accent);
}

.nb-footer__contact{
  display:flex;
  flex-direction:column;
  gap:8px;
  font-size:13px;
  line-height:1.55;
  color:var(--muted);
}

.nb-footer__contact-item strong{
  color:var(--text);
  font-weight:600;
}

.nb-footer__contact a{
  color:var(--text);
  text-decoration:none;
}

.nb-footer__contact a:hover{
  text-decoration:underline;
}

.nb-footer__social{
  display:flex;
  align-items:center;
  gap:10px;
  margin-top:4px;
}

.nb-footer__social a{
  width:42px;
  height:42px;
  border:1px solid #ddd5ce;
  border-radius:999px;
  display:flex;
  align-items:center;
  justify-content:center;
  background:#fff;
  color:#867c75;
  transition:.2s ease;
}

.nb-footer__social a:hover{
  border-color:var(--accent);
  color:var(--accent);
  transform:translateY(-1px);
}

.nb-footer__social svg{
  width:18px;
  height:18px;
  display:block;
  fill:currentColor;
  stroke:none;
}

.nb-footer__secure{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:14px;
  padding:10px 20px;
  border-top:1px solid #efe6df;
  border-bottom:1px solid #efe6df;
  background:#fff;
}

.nb-footer__secure-left{
  display:flex;
  align-items:center;
  gap:16px;
  flex-wrap:wrap;
}

.nb-footer__secure-item{
  display:inline-flex;
  align-items:center;
  gap:7px;
  color:var(--muted);
  font-size:12px;
  line-height:1.4;
  font-weight:500;
}

.nb-footer__secure-item svg{
  width:15px;
  height:15px;
  flex:0 0 15px;
  fill:none;
  stroke:#7c746e;
  stroke-width:1.8;
  stroke-linecap:round;
  stroke-linejoin:round;
}

.nb-footer__card{
  min-width:54px;
  height:28px;
  padding:0 8px;
  border:1px solid var(--line);
  background:#fff;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:4px;
  color:#7d746d;
  font-size:10px;
  font-weight:600;
}

.nb-footer__card svg{
  width:34px;
  height:14px;
  display:block;
  fill:none;
  stroke:currentColor;
  stroke-width:1.7;
}

.nb-footer__card--visa svg,
.nb-footer__card--troy svg{
  width:38px;
  height:14px;
}

.nb-footer__card--visa svg text,
.nb-footer__card--troy svg text{
  fill:currentColor;
  stroke:none;
  font-family:Arial, Helvetica, sans-serif;
  font-weight:600;
  letter-spacing:.02em;
}

.nb-footer__card--mc svg{
  width:26px;
  height:14px;
}

.nb-footer__card--mc svg circle:first-child{
  fill:#241815;
  opacity:.9;
  stroke:none;
}

.nb-footer__card--mc svg circle:last-child{
  fill:#c7b2a6;
  stroke:none;
}

.nb-footer__card--secure svg{
  width:18px;
  height:18px;
}

.nb-footer__card--secure svg path:first-child,
.nb-footer__card--secure svg path:last-child{
  fill:none;
  stroke:currentColor;
  stroke-width:1.8;
}

.nb-footer__bottom{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
  padding:12px 20px;
  border-top:1px solid var(--line);
  color:var(--muted);
  font-size:13px;
}

.nb-footer__bottom-links{
  display:flex;
  flex-wrap:wrap;
  gap:12px;
}

.nb-footer__bottom-links a{
  color:#7b726b;
}

.nb-footer__bottom-links a:hover{
  color:var(--accent);
}

.nb-footer .site-brand{
  justify-content:flex-start;
}

.nb-footer .site-brand__text{
  font-size:18px;
  letter-spacing:.1em;
}

.product-body{
  padding:12px;
  display:flex;
  flex-direction:column;
  flex:1;
}

@media (max-width:991px){
  .nb-footer__inner{
    grid-template-columns:1fr 1fr;
    gap:18px;
    padding:22px 18px 16px;
  }

  .nb-footer__secure{
    padding:10px 18px;
  }

  .nb-footer__bottom{
    padding:12px 18px;
  }
}

@media (max-width:640px){
  .nb-footer__inner{
    grid-template-columns:1fr;
    gap:16px;
  }

  .nb-footer__secure{
    flex-direction:column;
    align-items:flex-start;
  }

  .nb-footer__bottom{
    flex-direction:column;
    align-items:flex-start;
  }
}


/* =========================================================
   17) MOBILE BOTTOM BAR
   ========================================================= */
.mobile-bottom-bar {
    display: none;
    position: fixed;
    left: 0;
    right: 0;
    bottom: 0;
    z-index: 999;
    background: rgba(255, 255, 255, .98);
    backdrop-filter: blur(12px);
    border-top: 1px solid var(--line);
    padding: 0px 0px calc(8px + env(safe-area-inset-bottom));
    box-shadow: 0 -10px 24px rgba(0, 0, 0, .06)
}

.mobile-bottom-nav {
    display: grid;
    grid-template-columns: repeat(5, 1fr);
    gap: 6px
}

.mobile-bottom-nav a {
    display: grid;
    justify-items: center;
    gap: 4px;
    padding: 8px 4px;
    color: #574f49;
    font-size: 11px
}

.mobile-bottom-nav .icon-btn {
    width: 30px;
    height: 30px;
    border: none;
    background: transparent;
    box-shadow: none
}

.mobile-bottom-nav .badge {
    top: -2px;
    right: -2px
}


/* =========================================================
   18) TRUST MINI
   ========================================================= */
   
/* =========================================================
   TRUST STRIP
   ========================================================= */
.nb-trust-strip{
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:12px;
  margin:22px 0 0;
  padding-top:18px;
  border-top:1px solid var(--line);
}

.nb-trust-strip__item{
  display:flex;
  align-items:flex-start;
  gap:12px;
  padding:14px 14px;
  border:1px solid var(--line);
  background:#fff;
}

.nb-trust-strip__icon{
  width:38px;
  height:38px;
  flex:0 0 38px;
  display:flex;
  align-items:center;
  justify-content:center;
  background:#faf7f4;
  border:1px solid #eee4dc;
}

.nb-trust-strip__icon svg{
  width:18px;
  height:18px;
  display:block;
  fill:none;
  stroke:#7c746e;
  stroke-width:1.8;
  stroke-linecap:round;
  stroke-linejoin:round;
}

.nb-trust-strip__text{
  display:flex;
  flex-direction:column;
  gap:3px;
  min-width:0;
}

.nb-trust-strip__text strong{
  display:block;
  margin:0;
  font-size:13px;
  line-height:1.3;
  font-weight:600;
  color:var(--text);
}

.nb-trust-strip__text span{
  display:block;
  font-size:12px;
  line-height:1.45;
  color:var(--muted);
}

@media (max-width:640px){
  .nb-trust-strip{
    grid-template-columns:1fr;
    gap:10px;
    margin-top:18px;
    padding-top:16px;
  }

  .nb-trust-strip__item{
    padding:12px;
  }

  .nb-trust-strip__icon{
    width:34px;
    height:34px;
    flex:0 0 34px;
  }

  .nb-trust-strip__icon svg{
    width:17px;
    height:17px;
  }

  .nb-trust-strip__text strong{
    font-size:12.5px;
  }

  .nb-trust-strip__text span{
    font-size:11.5px;
  }
}

/* =========================================================
   19) BRAND
   ========================================================= */
.site-brand{
  display:flex;
  align-items:center;
  justify-content:center;
  gap:10px;
  max-width:100%;
  overflow:hidden;
  text-decoration:none;
  color:var(--text);
  white-space:nowrap;
}

@media (max-width:991px){
  .header-mainline{
    flex:1 1 auto;
    overflow:visible;
    justify-content:center;
  }

  .site-brand{
    overflow:visible;
  }
}

.site-brand__logo{
  display:block;
  width:36px;
  height:36px;
  object-fit:contain;
  flex:0 0 36px;
}

.site-brand__text{
  font-size:24px;
  letter-spacing:.14em;
  font-weight:500;
  text-transform:uppercase;
  line-height:1;
}


/* =========================================================
   20) GLOBAL RESPONSIVE
   ========================================================= */
@media (min-width:992px) {
    .mobile-stories {
        justify-content: center
    }
}

@media (max-width:991px) {
    body {
        padding-bottom: 78px
    }

    .site-shell {
        width: 100%;
        margin: 0;
        border: none;
        box-shadow: none
    }

    .topbar {
        padding: 10px 10px
    }

    .brand {
        font-size: 20px;
        letter-spacing: .1em
    }

    .left-tools,
    .right-tools {
        min-width: auto;
        gap: 5px
    }

    .desktop-nav {
        display: none
    }

    .content {
        padding: 16px 16px 24px;
        max-width: none
    }

    .hero {
        min-height: 190px;
        padding: 26px 20px;
        border-radius: 0
    }

    .hero::after {
        background: linear-gradient(90deg, rgba(0, 0, 0, .88) 0%, rgba(0, 0, 0, .58) 44%, rgba(0, 0, 0, .20) 78%, rgba(0, 0, 0, .08) 100%)
    }

    .hero p,
    .hero-actions {
        display: none
    }

    .hero h1 {
        font-size: clamp(28px, 8vw, 42px);
        max-width: 260px;
        text-align: center;
        line-height: 1.06
    }

    .hero-content {
        max-width: 100%;
        width: 100%;
        display: flex;
        flex-direction: column;
        align-items: center;
        justify-content: center
    }

    .category-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
        gap: 14px
    }

    .category-card {
        min-height: 230px
    }

    .category-card span {
        left: 12px;
        bottom: 12px;
        font-size: 18px;
        letter-spacing: .12em;
        color: #fff7f0;
        background: rgba(0, 0, 0, .18);
        padding: 4px 8px
    }

    .nb-footer {
        margin-top: 22px
    }

    .nb-footer__inner {
        grid-template-columns: 1fr 1fr;
        gap: 22px 18px;
        padding: 24px 16px 18px
    }

    .nb-footer__brand {
        grid-column: 1/-1;
        max-width: none
    }

    .nb-footer__bottom {
        flex-direction: column;
        align-items: flex-start;
        padding: 12px 16px 10px
    }

    .nb-footer__secure{
      flex-direction:column;
      align-items:flex-start;
      padding:12px 16px;
    }

    .nb-footer__secure-left{
      gap:10px 14px;
    }

    .nb-footer__cards{
      width:100%;
    }

    .mobile-bottom-bar {
        display: block
    }

    .site-brand__text{
      font-size:22px;
      letter-spacing:.1em;
    }

    .site-brand__logo{
      width:30px;
      height:30px;
      flex:0 0 30px;
    }
}

@media (max-width:640px) {
    body {
        background: var(--card)
    }

    .app-header {
        position: relative
    }

    .topbar {
        padding: 8px 8px
    }

    .icon-btn {
        width: 36px;
        height: 36px;
        border: none;
        background: transparent
    }

    .brand {
        font-size: 17px;
        letter-spacing: .08em
    }

    .mobile-stories{
      padding:12px 38px 14px 12px;
      gap:12px
    }

    .story {
        width: 68px
    }

    .story-ring {
        width: 62px;
        height: 62px;
        margin-bottom: 6px
    }

    .story-label {
        font-size: 11px
    }

    .content {
        padding: 12px 12px 22px
    }

    .section {
        margin-top: 10px
    }

    .section-head {
        margin-bottom: 12px
    }

    .section-title {
        font-size: 22px
    }

    .hero {
        border: 1px solid #ffd8c2;
        min-height: 150px
    }

    .hero::after {
        background: linear-gradient(90deg, rgba(0, 0, 0, .88) 0%, rgba(0, 0, 0, .58) 44%, rgba(0, 0, 0, .20) 78%, rgba(0, 0, 0, .08) 100%)
    }

    .category-card {
        min-height: 184px
    }

    .product-body {
        padding: 12px
    }
    
    .product-name {
        font-size: 13px
    }

    .discount-badge{
      top:8px;
      left:8px;
      min-height:24px;
      padding:0 8px;
      font-size:10px;
      line-height:24px;
      border-radius:4px;
    }

    .discount-badge::before,
    .discount-badge::after{
      display:none;
    }

    .story-arrow{
      display:none;
    }

    .nb-footer__inner {
        grid-template-columns: 1fr;
        gap: 18px
    }

    .nb-footer__logo {
        font-size: 20px
    }

    .nb-footer__text,
    .nb-footer__links a {
        font-size: 13px
    }

    .nb-footer__bottom {
        font-size: 12px
    }

    .nb-footer__secure-item{
      font-size:11px;
    }

    .nb-footer__card{
      min-width:50px;
      height:26px;
      font-size:9px;
      padding:0 7px;
    }

    .nb-trust-mini{
      gap:3px;
      padding-top:8px;
    }

    .nb-trust-mini__icon{
      width:15px;
      height:15px;
    }

    .nb-trust-mini__text{
      font-size:12px;
    }

    .site-brand{
      gap:8px;
    }

    .site-brand__text{
      font-size:17px;
      letter-spacing:.08em;
    }

    .site-brand__logo{
      width:24px;
      height:24px;
      flex:0 0 24px;
    }
}


/* =========================================================
   21) PAGE-SPECIFIC / TYPOGRAPHY / MINOR GLOBALS
   ========================================================= */
   
body:not(.home):not(.front-page) .mobile-stories-wrap{
  display:none;
}

.nb-footer__links--grid{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:8px 20px;
}

.nb-footer__links--grid li{
  list-style:none;
}

.nb-footer__links--grid a{
  display:block;
  font-size:14px;
  color:var(--muted);
}

.woocommerce .related.products > h2,
.woocommerce div.product .woocommerce-tabs .panel h2,
.woocommerce #reviews #comments h2,
.woocommerce-Reviews-title,

body:not(.woocommerce) h2{
  font-size:22px;
  font-weight:600;
}

h3{
  font-size:18px;
  font-weight:600;
  line-height:1.35;
  color:#2f2a27;
}

.story-ring,
.story.is-muted .story-ring{
  background:#ff7a7a;
}

.price{
  color:#000;
  font-weight:400;
}

.old-price{
  color:#000;
  opacity:.4;
  text-decoration:line-through;
}

.nb-footer__cards{
  display:flex;
  align-items:center;
  justify-content:flex-end;
  gap:8px;
  flex-wrap:wrap;
}

.nb-footer__cards-image{
  max-height:26px;
  width:auto;
  display:block;
  opacity:.9;
}


/* =========================================================
   22) HEADER / FOOTER BRAND IMAGE SIZING
   ========================================================= */
.app-header .site-brand__logo{
  display:block;
  height:48px;
  width:auto;
  max-width:260px;
  flex:0 0 auto;
}

@media (max-width:640px){
  .app-header .site-brand__logo{
    height:38px;
    max-width:170px;
  }
}

.nb-footer .site-brand{
  display:flex;
  align-items:center;
  max-width:100%;
  overflow:hidden;
}

.nb-footer .site-brand__logo{
  display:block;
  height:40px;
  width:auto;
  max-width:220px;
  flex:0 0 auto;
}

@media (max-width:640px){
  .nb-footer .site-brand__logo{
    height:50px;
    max-width:260px;
  }
}

/* =========================================================
   PREMIUM RED SYSTEM
   ========================================================= */
:root{
  --sale:#B03A48;
  --sale-dark:#922F3C;
}

/* üst bar güçlü kelimeler */
.top-notice__marquee strong{
  color:#B03A48;
}

/* sepet adedi */
.badge{
  background:#B03A48;
  color:#fff;
}

/* ana butonlar */
.btn-primary,
.woocommerce div.product form.cart .button.single_add_to_cart_button,
button.single_add_to_cart_button,
.woocommerce button.single_add_to_cart_button,
.woocommerce div.product form.cart .button,
.woocommerce .related.products ul.products li.product .button,
.nb-product-card__button,
.woocommerce ul.products li.product .button,
.woocommerce-message .button,
.woocommerce-notices-wrapper .woocommerce-message .button{
  background:#B03A48;
  border-color:#B03A48;
  color:#fff;
  box-shadow:0 10px 24px rgba(176,58,72,.14);
}

.btn-primary:hover,
.woocommerce div.product form.cart .button.single_add_to_cart_button:hover,
button.single_add_to_cart_button:hover,
.woocommerce button.single_add_to_cart_button:hover,
.woocommerce div.product form.cart .button:hover,
.woocommerce .related.products ul.products li.product .button:hover,
.nb-product-card__button:hover,
.woocommerce ul.products li.product .button:hover,
.woocommerce-message .button:hover,
.woocommerce-notices-wrapper .woocommerce-message .button:hover{
  background:#922F3C;
  border-color:#922F3C;
  color:#fff;
  box-shadow:0 12px 26px rgba(146,47,60,.18);
}

/* ürün detay büyük indirim şeridi */
.woocommerce span.onsale{
  background:#C14555;
  color:#fff;
  box-shadow:0 8px 20px rgba(193,69,85,.20);
}

.woocommerce span.onsale::before{
  border-left-color:#C14555;
}

.woocommerce span.onsale::after{
  border-top-color:#74242F;
}

/* kart üstü küçük kampanya etiketleri */
.nb-product-card__badge,
.discount-badge{
  background:#B03A48;
  color:#fff;
}

/* story halkası */
.story-ring,
.story.is-muted .story-ring{
  background:#B03A48;
}

/* aktif sekme alt çizgisi */
.woocommerce div.product .woocommerce-tabs ul.tabs li.active a{
  border-bottom-color:#B03A48;
}

/* fiyat vurguları */
.woocommerce .related.products ul.products li.product .price,
.nb-product-card__price,
.woocommerce ul.products li.product .price,
.nb-product-card__price ins,
.woocommerce ul.products li.product .price ins{
  color:#B03A48;
}

/* üst bar / bilgi alanı içindeki hafif vurgu gerekiyorsa */
.woocommerce-message,
.woocommerce-notices-wrapper .woocommerce-message{
  background:#F6E8EA;
}

/* bazı kırmızıya yakın sabit yazılmış alanları da toparla */
.story-ring,
.story.is-muted .story-ring,
.top-notice__marquee strong{
  color:inherit;
}

.top-notice__marquee strong{
  color:#B03A48;
}

.top-notice{
  display:flex !important;
}