@media (min-width: 1024px){
  body{
    max-width:none;
    padding-top:72px;
    padding-bottom:0;
    background:linear-gradient(180deg,#faf8f2 0%,#f3efe6 100%);
  }

  /* Product and auth screens have no nav bar — remove body top padding reserved for it */
  body:has(.product-screen),
  body:has([data-view="auth"]){
    padding-top:0;
  }

  #app{
    min-height:100vh;
  }

  .top{
    padding:18px 20px 8px;
  }

  .h1{
    font-size:42px;
    padding:0;
  }

  .search{
    margin:0;
  }

  .grid{
    grid-template-columns:repeat(4,minmax(0,1fr));
    gap:16px;
    padding:0;
  }

  /* ── Top nav bar ── */
  .nav{
    top:0;
    bottom:auto;
    left:50%;
    transform:translateX(-50%);
    width:min(1200px,calc(100% - 64px));
    max-width:none;
    display:flex;
    flex-direction:row;
    justify-content:flex-end;
    gap:4px;
    border-radius:0 0 28px 28px;
    padding:10px 20px;
  }

  .nav button{
    flex-direction:row;
    gap:6px;
    font-size:13px;
    font-weight:500;
    padding:9px 16px;
    border-radius:12px;
    white-space:nowrap;
  }

  .nav button svg{
    width:18px;
    height:18px;
  }

  .nav button.active{
    background:var(--green-soft);
  }

  .toast-wrap{
    bottom:24px;
  }

  .sticky-bar{
    max-width:1360px;
    padding:0 32px 24px;
    background:linear-gradient(180deg,transparent,rgba(246,243,236,.88) 28%,var(--bg));
  }

  .sticky-bar .inner{
    max-width:520px;
    margin-left:auto;
  }

  [data-view="home"],
  [data-view="catalog"],
  [data-view="product"]{
    width:min(1440px,calc(100% - 64px));
    margin:0 auto;
  }

  /* ── Home: single full-width column ──
     Stories flow above sections, not in a sidebar.
     Order: location → greeting → stories → order banner → collections → pwa. */
  [data-view="home"]{
    display:grid;
    grid-template-columns:1fr;
    gap:20px;
    padding:32px 0 40px;
  }

  [data-view="home"] > .js-greeting,
  [data-view="home"] > .js-order-banner,
  [data-view="home"] > .js-content,
  [data-view="home"] > .js-stories-strip,
  [data-view="home"] > .js-pwa-install{
    min-width:0;
  }

  [data-view="home"] > .js-order-banner{
    align-self:start;
    margin:0;
  }

  [data-view="home"] > .js-greeting{
    padding:12px 4px 0;
  }

  [data-view="home"] .g-hi{
    font-size:17px;
  }

  [data-view="home"] .g-name{
    font-size:42px;
  }

  /* Stories: horizontal card above product sections */
  [data-view="home"] > .js-stories-strip{
    background:var(--paper);
    border:1px solid var(--line);
    border-radius:28px;
    box-shadow:0 16px 34px rgba(35,33,28,.05);
    padding:16px 20px;
  }

  [data-view="home"] > .js-pwa-install{
    background:var(--paper);
    border:1px solid var(--line);
    border-radius:28px;
    box-shadow:0 16px 34px rgba(35,33,28,.05);
    align-self:start;
    overflow:hidden;
  }

  [data-view="home"] > .js-order-banner:empty,
  [data-view="home"] > .js-stories-strip:empty,
  [data-view="home"] > .js-pwa-install:empty{
    display:none;
  }

  /* Single scrollable horizontal row of story bubbles */
  [data-view="home"] .story-strip{
    padding:0;
    overflow:auto;
    flex-wrap:nowrap;
    gap:20px;
  }

  [data-view="home"] .story-bubble{
    width:82px;
    flex-shrink:0;
  }

  [data-view="home"] .story-ring{
    width:76px;
    height:76px;
  }

  [data-view="home"] .story-lbl{
    max-width:76px;
  }

  [data-view="home"] .order-banner{
    padding:18px 20px;
    border-radius:22px;
    box-shadow:0 12px 32px rgba(31,122,72,.08);
  }

  [data-view="home"] .ob-title{
    font-size:15px;
  }

  [data-view="home"] .ob-sub{
    font-size:13px;
  }

  /* Single-column collections, each full width */
  [data-view="home"] > .js-content{
    display:grid;
    grid-template-columns:1fr;
    gap:20px;
  }

  [data-view="home"] .coll{
    margin:0;
    background:var(--paper);
    border:1px solid var(--line);
    border-radius:28px;
    box-shadow:0 16px 34px rgba(35,33,28,.05);
    padding-bottom:10px;
  }

  [data-view="home"] .coll-hdr{
    padding:22px 22px 0;
  }

  [data-view="home"] .coll-hdr h2,
  [data-view="home"] .sec h2{
    font-size:24px;
  }

  /* 4 product cards per row — matches catalog density */
  [data-view="home"] .coll-row{
    padding:16px 22px 22px;
    display:grid;
    grid-template-columns:repeat(4,minmax(0,1fr));
    gap:16px;
    overflow:visible;
  }

  [data-view="home"] .coll-row .card{
    flex:initial;
    min-width:0;
  }

  [data-view="home"] .values{
    grid-template-columns:repeat(4,minmax(0,1fr));
    gap:16px;
    padding:18px 22px 22px;
  }

  [data-view="home"] .val-card{
    border-radius:20px;
    padding:18px;
  }

  [data-view="home"] .vc-title{
    font-size:15px;
  }

  [data-view="home"] .vc-sub{
    font-size:13px;
  }

  [data-view="home"] .sec{
    padding:22px 22px 0;
  }

  [data-view="home"] .pwa-banner{
    margin:0;
    padding:22px;
  }

  [data-view="home"] .pwa-banner h3{
    font-size:18px;
  }

  [data-view="home"] .pwa-banner p{
    font-size:14px;
  }

  [data-view="catalog"]{
    display:grid;
    grid-template-columns:minmax(0,1fr) 280px;
    gap:18px 24px;
    padding:32px 0 40px;
    align-items:start;
  }

  [data-view="catalog"] > .top,
  [data-view="catalog"] > .h1,
  [data-view="catalog"] > .search,
  [data-view="catalog"] > .js-grid{
    grid-column:1 / 2;
  }

  [data-view="catalog"] > .top{
    padding:20px 22px;
    background:rgba(255,255,255,.72);
    backdrop-filter:blur(14px);
    -webkit-backdrop-filter:blur(14px);
    border:1px solid rgba(35,33,28,.07);
    border-radius:28px;
    box-shadow:0 18px 40px rgba(35,33,28,.06);
  }

  [data-view="catalog"] > .h1{
    font-size:42px;
    letter-spacing:-.04em;
    align-self:end;
  }

  [data-view="catalog"] > .search{
    padding:14px 16px;
    border-radius:18px;
    box-shadow:0 12px 28px rgba(35,33,28,.04);
  }

  [data-view="catalog"] > .chips{
    grid-column:2 / 3;
    grid-row:1 / span 4;
    position:sticky;
    top:88px;
    display:flex;
    flex-direction:column;
    gap:10px;
    overflow:visible;
    padding:20px;
    background:var(--paper);
    border:1px solid var(--line);
    border-radius:28px;
    box-shadow:0 16px 34px rgba(35,33,28,.05);
  }

  [data-view="catalog"] > .chips::before{
    content:'Категории';
    font-size:13px;
    font-weight:700;
    letter-spacing:.08em;
    text-transform:uppercase;
    color:var(--muted);
    padding:0 2px 8px;
  }

  [data-view="catalog"] .chip{
    width:100%;
    display:flex;
    justify-content:flex-start;
    padding:12px 16px;
    border-radius:16px;
    font-size:14px;
  }

  [data-view="catalog"] .grid{
    grid-template-columns:repeat(4,minmax(0,1fr));
    gap:16px;
    padding:0;
  }

  [data-view="catalog"] .sk-card,
  [data-view="catalog"] .card{
    min-width:0;
  }

  [data-view="catalog"] .empty{
    margin:24px 0;
    background:var(--paper);
    border:1px solid var(--line);
    border-radius:24px;
  }

  /* ── Product page ── */
  [data-view="product"]{
    display:grid;
    grid-template-columns:minmax(380px,560px) minmax(420px,1fr);
    grid-template-rows:auto auto auto;
    gap:16px 32px;
    padding:24px 0 40px;
    align-items:start;
  }

  [data-view="product"] .pd-top{
    position:sticky;
    top:8px;
    grid-column:1 / -1;
    padding:0;
    max-width:none;
    margin:0;
    z-index:8;
  }

  [data-view="product"] .pd-top .pd-cbtn{
    background:rgba(255,255,255,.88);
    backdrop-filter:blur(12px);
    -webkit-backdrop-filter:blur(12px);
    box-shadow:0 10px 24px rgba(35,33,28,.08);
  }

  [data-view="product"] .pd-hero{
    grid-row:2 / 4;
    height:min(60vh,540px);
    border-radius:32px;
    box-shadow:0 24px 52px rgba(35,33,28,.12);
  }

  [data-view="product"] .pd-hero .badge{
    top:24px;
    left:24px;
  }

  [data-view="product"] .pd-sheet{
    grid-row:2;
    align-self:end;
    margin-top:0;
    padding:28px;
    background:var(--paper);
    border:1px solid var(--line);
    border-radius:32px;
    box-shadow:0 18px 40px rgba(35,33,28,.07);
  }

  [data-view="product"] .pd-drag-handle{
    display:none;
  }

  [data-view="product"] .pd-nm{
    font-size:38px;
    line-height:1.04;
  }

  [data-view="product"] .pd-meta{
    margin-top:12px;
  }

  [data-view="product"] .pd-meta .w{
    font-size:15px;
  }

  [data-view="product"] .pd-prc{
    margin:20px 0 18px;
  }

  [data-view="product"] .pd-prc .now{
    font-size:32px;
  }

  [data-view="product"] .pd-prc .old{
    font-size:18px;
  }

  [data-view="product"] .pd-desc{
    font-size:17px;
    max-width:42ch;
  }

  [data-view="product"] .sec{
    padding:26px 0 0;
  }

  [data-view="product"] .sec h2{
    font-size:22px;
  }

  [data-view="product"] .rrow{
    display:grid;
    grid-template-columns:repeat(3,minmax(0,1fr));
    overflow:visible;
    gap:14px;
    padding:16px 0 0;
  }

  [data-view="product"] .rc{
    min-width:0;
    flex:initial;
    border-radius:18px;
    padding:10px;
  }

  [data-view="product"] .rc .ri{
    font-size:56px;
    border-radius:14px;
  }

  [data-view="product"] .sticky-bar{
    position:relative;
    left:auto;
    transform:none;
    bottom:auto;
    max-width:none;
    width:auto;
    padding:0;
    background:none;
    grid-column:2 / 3;
    grid-row:3;
    z-index:6;
  }

  [data-view="product"] .pd-bar .inner{
    padding:16px 18px 16px 20px;
    border-radius:24px;
    box-shadow:0 18px 36px rgba(35,33,28,.08);
  }

  [data-view="product"] .pd-bar .pp b{
    font-size:28px;
  }

  [data-view="product"] .pd-bar .pp small{
    font-size:13px;
  }

  [data-view="product"] .pd-bar .btn{
    height:56px;
    font-size:16px;
  }
}

@media (min-width: 1024px) and (max-width: 1279px){
  .grid,
  [data-view="catalog"] .grid{
    grid-template-columns:repeat(3,minmax(0,1fr));
  }

  [data-view="home"] .coll-row{
    grid-template-columns:repeat(3,minmax(0,1fr));
  }

  [data-view="home"] .values{
    grid-template-columns:repeat(2,minmax(0,1fr));
  }

  [data-view="catalog"]{
    grid-template-columns:minmax(0,1fr) 240px;
  }

  [data-view="product"]{
    grid-template-columns:1fr 1fr;
  }

  [data-view="product"] .rrow{
    grid-template-columns:repeat(2,minmax(0,1fr));
  }
}

/* ── Корзина, оформление, профиль, авторизация, заказ, правовые ── */
@media (min-width: 1024px){

  [data-view="cart"]{
    width:min(1000px,calc(100% - 64px));
    margin:0 auto;
    padding:24px 0 40px;
  }

  [data-view="cart"] > .top{
    padding:18px 22px 12px;
    background:rgba(255,255,255,.72);
    backdrop-filter:blur(14px);
    -webkit-backdrop-filter:blur(14px);
    border:1px solid rgba(35,33,28,.07);
    border-radius:28px;
    box-shadow:0 18px 40px rgba(35,33,28,.06);
    margin-bottom:16px;
  }

  [data-view="cart"] > .top:has(.htitle){
    display:none;
  }

  [data-view="cart"] .cart-empty{
    background:var(--paper);
    border:1px solid var(--line);
    border-radius:24px;
    padding:80px 20px;
    text-align:center;
  }

  [data-view="cart"] .js-body > div{
    display:grid;
    grid-template-columns:minmax(0,1fr) 320px;
    gap:20px;
    align-items:start;
  }

  [data-view="cart"] .cart-list{
    grid-row:1 / 4;
    background:var(--paper);
    border:1px solid var(--line);
    border-radius:24px;
    overflow:hidden;
  }

  [data-view="cart"] .ci{
    padding:14px 20px;
  }

  [data-view="cart"] .order-totals{
    margin:0 !important;
    background:var(--paper);
    border:1px solid var(--line);
    border-radius:24px;
    padding:18px 20px;
  }

  [data-view="cart"] .js-body > div > div:last-child{
    padding:0;
  }

  [data-view="checkout"]{
    width:min(720px,calc(100% - 64px));
    margin:0 auto;
    padding:24px 0 80px;
  }

  [data-view="checkout"] > .top{
    padding:18px 22px;
    background:rgba(255,255,255,.72);
    backdrop-filter:blur(14px);
    -webkit-backdrop-filter:blur(14px);
    border:1px solid rgba(35,33,28,.07);
    border-radius:28px;
    box-shadow:0 18px 40px rgba(35,33,28,.06);
    margin-bottom:16px;
  }

  [data-view="checkout"] .js-body{
    padding-bottom:0 !important;
  }

  [data-view="checkout"] .co-sec{
    background:var(--paper);
    border:1px solid var(--line);
    border-radius:24px;
    margin:0 0 12px !important;
  }

  [data-view="checkout"] .order-totals{
    background:var(--paper);
    border:1px solid var(--line);
    border-radius:24px;
    padding:16px 20px;
    margin:0 0 12px !important;
  }

  [data-view="profile"]{
    width:min(720px,calc(100% - 64px));
    margin:0 auto;
    padding:24px 0 80px;
  }

  [data-view="profile"] > .top{
    padding:18px 22px;
    background:rgba(255,255,255,.72);
    backdrop-filter:blur(14px);
    -webkit-backdrop-filter:blur(14px);
    border:1px solid rgba(35,33,28,.07);
    border-radius:28px;
    box-shadow:0 18px 40px rgba(35,33,28,.06);
    margin-bottom:16px;
  }

  [data-view="profile"] > .top:has(.htitle){
    display:none;
  }

  [data-view="profile"] .js-body{
    padding-bottom:0 !important;
  }

  [data-view="auth"]{
    width:min(480px,calc(100% - 64px));
    margin:0 auto;
    padding:40px 0 80px;
  }

  [data-view="order"]{
    width:min(640px,calc(100% - 64px));
    margin:0 auto;
    padding:24px 0 80px;
  }

  [data-view="order"] > .top{
    padding:18px 22px;
    background:rgba(255,255,255,.72);
    backdrop-filter:blur(14px);
    -webkit-backdrop-filter:blur(14px);
    border:1px solid rgba(35,33,28,.07);
    border-radius:28px;
    box-shadow:0 18px 40px rgba(35,33,28,.06);
    margin-bottom:16px;
  }

  [data-view="order"] .js-body{
    height:auto !important;
    overflow-y:visible !important;
    padding-bottom:0 !important;
  }

  [data-view="legal"]{
    width:min(760px,calc(100% - 64px));
    margin:0 auto;
    padding:24px 0 80px;
  }

  [data-view="legal"] > .top{
    padding:18px 22px;
    background:rgba(255,255,255,.72);
    backdrop-filter:blur(14px);
    -webkit-backdrop-filter:blur(14px);
    border:1px solid rgba(35,33,28,.07);
    border-radius:28px;
    box-shadow:0 18px 40px rgba(35,33,28,.06);
    margin-bottom:16px;
  }
}
