  /* ── TOKENS: B&W base + brand colors only on hover ── */
  :root {
    /* En reposo: blanco y negro */
    --bg:    #ffffff;
    --fg:    #111111;
    --mid:   #555555;
    --muted: #999999;
    --line:  #e0e0e0;
    --soft:  #f5f5f5;
    --softer:#fafafa;

    /* Colores de marca — SOLO en hover */
    --teal:   #477a85;
    --teal-d: #2f5a63;
    --teal-l: #6097a3;
    --cream:  #fef2e6;
    --cream-d:#f0deca;
    --lilac:  #b298b7;
    --lilac-l:#cdb8cf;
    --pale:   #ded2e0;
    --pale-d: #c8b9cb;

    --r-sm:12px; --r-md:20px; --r-lg:28px; --r-xl:100px;

    /* Transición global */
    --t: .32s ease;
  }

  /* ── RESET ── */
  *,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
  html{scroll-behavior:smooth}
  body{font-family:'Nunito',sans-serif;background:var(--bg);color:var(--fg);overflow-x:hidden}
  img{display:block;max-width:100%}
  a{text-decoration:none;color:inherit}
  ul{list-style:none}
  button{cursor:pointer;font-family:'Nunito',sans-serif;border:none}

  /* ── TOPBAR ── */
  .topbar{
    background:var(--fg);color:var(--bg);
    font-size:12px;letter-spacing:.07em;padding:9px 40px;font-weight:500;
    transition:background var(--t);
    position:relative;display:flex;align-items:center;justify-content:center;
  }
  .topbar:hover{background:var(--teal-d)}
  .topbar-center{opacity:.85;text-align:center}
  .topbar-social{
    position:absolute;right:40px;top:50%;transform:translateY(-50%);
    display:flex;align-items:center;gap:16px;
  }
  .topbar-social a{
    color:rgba(255,255,255,.5);
    transition:color var(--t);
    display:flex;align-items:center;
  }
  .topbar-social a:hover{color:var(--cream)}
  .topbar-social a svg{width:14px;height:14px;fill:currentColor}

  /* ── NAV ── */
.sp-nav{
    position:sticky;top:0;z-index:200;
    background:rgba(255,255,255,.96);backdrop-filter:blur(12px);
    border-bottom:1px solid var(--line);
    display:flex;align-items:center;justify-content:space-between;
    padding:0 60px;height:72px;
    transition:border-color var(--t);
  }
.sp-nav:hover{border-bottom-color:var(--teal-l)}

  .nav-logo{display:flex;align-items:center;gap:11px;text-decoration:none}
  .nav-logo img{width:44px;height:44px;object-fit:contain;border-radius:50%}
  
  .nav-brand{font-family:'Cormorant Garamond',serif;font-size:18px;font-weight:500;color:var(--fg);letter-spacing:.06em;line-height:1;display:block;transition:color var(--t)}
  .nav-logo:hover .nav-brand{color:var(--teal)}
  .nav-sub{font-size:10px;letter-spacing:.18em;text-transform:uppercase;color:var(--muted);display:block;margin-top:3px;font-weight:700;transition:color var(--t)}
  .nav-logo:hover .nav-sub{color:var(--lilac)}

  .nav-links{display:flex;gap:30px;list-style:none}
  .nav-links a{font-size:13.5px;color:var(--mid);font-weight:500;transition:color var(--t);position:relative;padding-bottom:3px}
  .nav-links a::after{content:'';position:absolute;bottom:0;left:0;width:0;height:1.5px;background:var(--teal);transition:width var(--t)}
  .nav-links a:hover{color:var(--teal)}
  .nav-links a:hover::after{width:100%}

  .nav-actions{display:flex;align-items:center;gap:12px}
  .nav-icon{background:none;border:none;cursor:pointer;color:var(--mid);padding:6px;transition:color var(--t);display:flex;align-items:center;text-decoration:none}
  .nav-icon:hover{color:var(--teal)}
  a.btn-cart{text-decoration:none}
  .mobile-menu-links{display:contents}
  .mobile-menu-links li{list-style:none}

  .btn-cart{
    background:var(--teal);color:var(--cream);border:none;border-radius:var(--r-xl);
    padding:9px 22px;font-size:13px;font-weight:700;cursor:pointer;
    transition:background var(--t),transform .15s;
    display:flex;align-items:center;gap:6px;
    box-shadow:0 3px 14px rgba(71,122,133,.3);
  }
  .btn-cart:hover{background:var(--teal-d);transform:translateY(-1px)}

  /* ── HERO SLIDER ── */
  .hero-slider{position:relative;width:100%;height:90vh;min-height:560px;overflow:hidden}
  .slide{position:absolute;inset:0;display:grid;grid-template-columns:54% 46%;opacity:0;transition:opacity .9s ease;pointer-events:none}
  .slide.active{opacity:1;pointer-events:all}

  .slide-left{
    display:flex;flex-direction:column;justify-content:center;
    padding:72px 60px 72px 80px;position:relative;overflow:hidden;
    background:var(--bg);
    transition:background var(--t);
  }
  /* Blob decorativo — invisible en reposo, aparece en hover */
  .slide-left::before{
    content:'';position:absolute;pointer-events:none;
    border-radius:63% 37% 54% 46% / 55% 48% 52% 45%;
    opacity:0;transition:opacity .6s;
    animation:blobmove 9s ease-in-out infinite alternate;
  }
  .slide:nth-child(1) .slide-left::before{width:400px;height:400px;background:var(--lilac);top:-90px;right:-100px}
  .slide:nth-child(2) .slide-left::before{width:360px;height:360px;background:var(--teal);bottom:-80px;right:-80px}
  .slide:nth-child(3) .slide-left::before{width:380px;height:380px;background:var(--teal-d);top:-60px;right:-90px}
  .slide-left:hover::before{opacity:.12}

  @keyframes blobmove{
    from{border-radius:63% 37% 54% 46% / 55% 48% 52% 45%}
    to  {border-radius:42% 58% 38% 62% / 62% 35% 65% 38%}
  }

  .slide-eyebrow{
    font-size:11px;letter-spacing:.2em;text-transform:uppercase;font-weight:700;
    margin-bottom:20px;color:var(--muted);
    opacity:0;transform:translateY(14px);
    transition:opacity .6s .3s,transform .6s .3s, color var(--t);
    display:flex;align-items:center;gap:10px;
  }
  .slide-eyebrow::before{content:'';width:24px;height:2px;background:currentColor;border-radius:2px;flex-shrink:0}
  .slide.active .slide-eyebrow{opacity:1;transform:translateY(0)}
  .slide-left:hover .slide-eyebrow{color:var(--lilac)}
  .slide:nth-child(2) .slide-left:hover .slide-eyebrow{color:var(--teal)}
  .slide:nth-child(3) .slide-left:hover .slide-eyebrow{color:var(--teal-d)}

  .slide-h1{
    font-family:'Cormorant Garamond',serif;font-size:clamp(44px,5.5vw,70px);
    line-height:1.08;font-weight:400;color:var(--fg);margin-bottom:20px;
    opacity:0;transform:translateY(22px);transition:opacity .7s .45s,transform .7s .45s;
  }
  .slide.active .slide-h1{opacity:1;transform:translateY(0)}
  .slide-h1 em{
    font-style:italic;font-weight:300;color:var(--fg);display:block;
    transition:color var(--t);
  }
  .slide-left:hover .slide-h1 em{color:var(--teal)}
  .slide:nth-child(2) .slide-left:hover .slide-h1 em{color:var(--teal-d)}
  .slide:nth-child(3) .slide-left:hover .slide-h1 em{color:var(--teal)}

  .slide-sub{
    font-size:15.5px;line-height:1.78;font-weight:500;color:var(--mid);
    max-width:400px;margin-bottom:40px;
    opacity:0;transform:translateY(14px);transition:opacity .7s .6s,transform .7s .6s;
  }
  .slide.active .slide-sub{opacity:1;transform:translateY(0)}

  .slide-ctas{
    display:flex;gap:14px;flex-wrap:wrap;
    opacity:0;transform:translateY(10px);transition:opacity .7s .75s,transform .7s .75s;
  }
  .slide.active .slide-ctas{opacity:1;transform:translateY(0)}

  /* Buttons — negro en reposo, teal en hover */
  .btn-primary{
    background:var(--teal);color:var(--cream);border:none;border-radius:var(--r-xl);
    padding:14px 34px;font-size:13.5px;font-weight:700;cursor:pointer;
    text-decoration:none;display:inline-block;
    transition:background var(--t),transform .15s,box-shadow var(--t);
    box-shadow:0 5px 20px rgba(71,122,133,.28);
  }
  .btn-primary:hover{background:var(--teal-d);transform:translateY(-2px);box-shadow:0 8px 28px rgba(71,122,133,.42)}

  .btn-ghost{
    background:transparent;color:var(--teal);
    border:2px solid var(--teal);border-radius:var(--r-xl);
    padding:12px 28px;font-size:13.5px;font-weight:700;cursor:pointer;
    text-decoration:none;display:inline-block;
    transition:all var(--t);
  }
  .btn-ghost:hover{background:var(--teal);color:var(--cream);border-color:var(--teal);transform:translateY(-2px)}

  .btn-sm{
    background:var(--teal);color:var(--cream);border:none;border-radius:var(--r-xl);
    padding:8px 18px;font-size:11.5px;font-weight:700;cursor:pointer;
    transition:background var(--t);
  }
  .btn-sm:hover{background:var(--teal-d)}

  /* Slide right panel */
  .slide-right{
    position:relative;overflow:hidden;
    display:flex;align-items:center;justify-content:center;
    background:var(--soft);
    transition:background var(--t);
  }
  .slide:nth-child(1) .slide-right:hover{background:var(--pale)}
  .slide:nth-child(2) .slide-right:hover{background:var(--lilac)}
  .slide:nth-child(3) .slide-right:hover{background:var(--teal)}

  .blob-deco{position:absolute;pointer-events:none;opacity:0;transition:opacity .5s;animation:blobmove 10s ease-in-out infinite alternate}
  .slide-right:hover .blob-deco{opacity:.22}
  .b1{width:320px;height:320px;border-radius:63% 37% 48% 52% / 55% 60% 40% 45%;background:rgba(0,0,0,.08);top:-60px;right:-60px}
  .b2{width:200px;height:200px;border-radius:50%;background:rgba(0,0,0,.05);bottom:30px;left:20px}
  .b3{width:300px;height:300px;border-radius:48% 52% 63% 37% / 60% 40% 55% 45%;background:rgba(254,242,230,.5);bottom:-40px;left:-40px}
  .b4{width:180px;height:180px;border-radius:50%;background:rgba(254,242,230,.4);top:30px;right:50px}
  .b5{width:340px;height:340px;border-radius:55% 45% 40% 60% / 48% 60% 40% 52%;background:rgba(30,48,53,.15);top:-80px;left:-80px}
  .b6{width:200px;height:200px;border-radius:50%;background:rgba(254,242,230,.3);bottom:40px;right:40px}

  /* Slide card — negro/blanco en reposo */
  .slide-card{
    position:relative;z-index:2;background:var(--bg);
    border-radius:var(--r-lg);width:285px;overflow:hidden;
    box-shadow:0 28px 70px rgba(0,0,0,.14);
    border:1px solid var(--line);
    opacity:0;transform:translateY(30px);
    transition:opacity .8s .4s,transform .8s .4s, box-shadow var(--t), border-color var(--t);
  }
  .slide.active .slide-card{opacity:1;transform:translateY(0)}
  .slide-card:hover{transform:translateY(-7px) !important;transition:transform .3s ease !important; box-shadow:0 32px 80px rgba(71,122,133,.25) !important; border-color:var(--teal-l) !important}

  .card-img{width:100%;height:240px;overflow:hidden;position:relative}
  .card-img img{width:100%;height:100%;object-fit:cover;transition:transform .5s ease}
  .slide-card:hover .card-img img{transform:scale(1.06)}

  .card-chip{
    position:absolute;top:14px;left:14px;
    background:var(--fg);color:var(--bg);
    font-size:10px;font-weight:700;letter-spacing:.07em;
    padding:5px 13px;border-radius:var(--r-xl);text-transform:uppercase;z-index:2;
    transition:background var(--t);
  }
  .slide-card:hover .card-chip{background:var(--teal)}

  .card-body{padding:18px 20px 22px}
  .card-body h3{font-family:'Cormorant Garamond',serif;font-size:19px;font-weight:500;color:var(--fg);margin-bottom:4px}
  .card-body p{font-size:12.5px;color:var(--muted);margin-bottom:14px;font-weight:600;letter-spacing:.03em}
  .card-footer{display:flex;justify-content:space-between;align-items:center}
  .card-price{font-family:'Cormorant Garamond',serif;font-size:22px;font-weight:500;color:var(--fg);transition:color var(--t)}
  .slide-card:hover .card-price{color:var(--teal)}

  /* Slider controls */
  .slider-dots{position:absolute;bottom:28px;left:50%;transform:translateX(-50%);display:flex;gap:10px;z-index:10}
  .dot{width:8px;height:8px;border-radius:50%;background:rgba(0,0,0,.15);cursor:pointer;transition:all .3s;border:none;padding:0}
  .dot.active{background:var(--teal);transform:scale(1.55)}
  .dot:hover{background:var(--teal-d)}

  .slider-arrow{
    position:absolute;top:50%;transform:translateY(-50%);z-index:10;
    background:var(--bg);border:1.5px solid var(--line);border-radius:50%;
    width:46px;height:46px;cursor:pointer;font-size:17px;
    display:flex;align-items:center;justify-content:center;
    color:var(--fg);transition:all var(--t);box-shadow:0 4px 16px rgba(0,0,0,.1);
  }
  .slider-arrow:hover{background:var(--teal);color:var(--bg);border-color:var(--teal)}
  .slider-prev{left:22px}.slider-next{right:22px}

  .slide-counter{position:absolute;bottom:32px;right:50px;z-index:10;font-size:12px;color:var(--muted);font-weight:600;display:flex;align-items:center;gap:7px}
  .counter-n{font-family:'Cormorant Garamond',serif;font-size:24px;font-weight:400;color:var(--fg);line-height:1;transition:color var(--t)}

  /* ── MARQUEE ── */
  .strip{background:var(--fg);padding:13px 0;overflow:hidden;white-space:nowrap;transition:background var(--t)}
  .strip:hover{background:var(--teal-d)}
  .strip-inner{display:inline-flex;animation:marquee 24s linear infinite}
  .strip-item{font-size:11.5px;letter-spacing:.14em;text-transform:uppercase;color:var(--bg);font-weight:600;padding:0 30px;opacity:.85}
  .strip-dot{color:rgba(255,255,255,.3);font-size:7px;align-self:center;opacity:.7}
  @keyframes marquee{from{transform:translateX(0)}to{transform:translateX(-50%)}}

  /* ── SCROLL REVEAL ── */
  .rev{opacity:0;transform:translateY(28px);transition:opacity .75s,transform .75s}
  .rev.in{opacity:1;transform:none}
  .rev-l{opacity:0;transform:translateX(-28px);transition:opacity .75s,transform .75s}
  .rev-l.in{opacity:1;transform:none}
  .rev-r{opacity:0;transform:translateX(28px);transition:opacity .75s,transform .75s}
  .rev-r.in{opacity:1;transform:none}

  /* ── SECTION HEADER ── */
  .sec-head{text-align:center;margin-bottom:56px}
  .sec-eye{font-size:11px;letter-spacing:.22em;text-transform:uppercase;color:var(--muted);font-weight:700;margin-bottom:13px;display:block;transition:color var(--t)}
  .sec-head:hover .sec-eye{color:var(--teal)}
  .sec-title{font-family:'Cormorant Garamond',serif;font-size:clamp(30px,4vw,50px);color:var(--fg);font-weight:400;line-height:1.15}
  .sec-title em{font-style:italic;color:var(--fg);transition:color var(--t)}
  .sec-head:hover .sec-title em{color:var(--teal)}
  .sec-rule{width:44px;height:3px;background:var(--line);border-radius:3px;margin:16px auto 0;transition:background var(--t)}
  .sec-head:hover .sec-rule{background:var(--teal)}

  /* ── CATEGORIES ── */
  .categories{padding:88px 72px;background:var(--bg)}
  .cat-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:20px}

  .cat-card{
    border-radius:var(--r-lg);overflow:hidden;cursor:pointer;
    position:relative;aspect-ratio:3/4;
    border:1px solid var(--line);
    transition:transform .35s,box-shadow .35s, border-color var(--t);
    box-shadow:0 4px 16px rgba(0,0,0,.06);
  }
  .cat-card:hover{transform:translateY(-8px);box-shadow:0 20px 52px rgba(71,122,133,.2);border-color:var(--teal-l)}
  .cat-card:hover .cat-bg img{transform:scale(1.07)}
  .cat-bg{width:100%;height:100%;overflow:hidden}
  .cat-bg img{
    width:100%;height:100%;object-fit:cover;
    transition:transform .5s ease;
  }
  .cat-info{
    position:absolute;bottom:0;left:0;right:0;z-index:2;
    padding:40px 22px 22px;
    background:linear-gradient(transparent,rgba(0,0,0,.75));
    color:#fff;
  }
  .cat-info h3{font-family:'Cormorant Garamond',serif;font-size:22px;font-weight:500;margin-bottom:4px;letter-spacing:.05em}
  .cat-info p{font-size:12px;letter-spacing:.07em;opacity:.88;font-weight:600}

  /* ── PRODUCTS ── */
  .featured{padding:88px 72px;background:var(--soft)}
  .products-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:20px}

  .product-card{
    background:var(--bg);border-radius:var(--r-lg);cursor:pointer;overflow:hidden;
    position:relative;border:1px solid var(--line);
    transition:transform .3s,box-shadow .3s, border-color var(--t);
    box-shadow:0 4px 16px rgba(0,0,0,.05);
  }
  .product-card:hover{transform:translateY(-7px);box-shadow:0 18px 46px rgba(71,122,133,.18);border-color:var(--teal-l)}
  .product-card:hover .add-btn{opacity:1;transform:translateY(0)}
  .product-card:hover .product-img img{transform:scale(1.06)}
  .product-img{width:100%;aspect-ratio:1;overflow:hidden;position:relative}
  .product-img img{
    width:100%;height:100%;object-fit:cover;
    transition:transform .5s ease;
  }

  .p-badge{
    position:absolute;top:12px;left:12px;
    background:var(--fg);color:var(--bg);
    font-size:10px;font-weight:700;letter-spacing:.07em;
    padding:4px 12px;border-radius:var(--r-xl);text-transform:uppercase;z-index:2;
    transition:background var(--t);
  }
  .p-badge.new{background:var(--fg)}
  .product-card:hover .p-badge{background:var(--teal)}
  .product-card:hover .p-badge.new{background:var(--lilac)}

  .add-btn{
    position:absolute;bottom:0;left:0;right:0;
    background:var(--teal);color:var(--bg);border:none;
    padding:13px;font-family:'Nunito',sans-serif;font-size:12px;
    letter-spacing:.08em;cursor:pointer;opacity:0;
    transform:translateY(6px);transition:all .25s;text-transform:uppercase;font-weight:700;z-index:2;
  }

  .product-info{padding:16px 18px 20px}
  .product-info h3{font-family:'Cormorant Garamond',serif;font-size:17px;color:var(--fg);margin-bottom:6px;font-weight:500}
  .product-meta{display:flex;justify-content:space-between;align-items:center;margin-top:4px}
  .p-price{font-family:'Cormorant Garamond',serif;font-size:17px;font-weight:500;color:var(--fg);transition:color var(--t)}
  .p-price s{font-size:13px;color:var(--muted);font-weight:400;margin-right:3px}
  .product-card:hover .p-price{color:var(--teal-d)}
  .p-stars{font-size:12px;color:var(--line);letter-spacing:1px;transition:color var(--t)}
  .product-card:hover .p-stars{color:var(--teal)}

  /* ── ABOUT ── */
  .about-wrap{display:grid;grid-template-columns:1fr 1fr}

  .about-left{
    background:var(--fg);padding:88px 60px 88px 72px;
    position:relative;overflow:hidden;
    transition:background var(--t);
  }
  .about-left:hover{background:var(--teal)}
  .about-left::after{
    content:'';position:absolute;bottom:-70px;right:-70px;width:320px;height:320px;
    border-radius:55% 45% 60% 40% / 48% 58% 42% 52%;
    background:rgba(255,255,255,.04);pointer-events:none;
    animation:blobmove 10s ease-in-out infinite alternate;
  }
  .about-left .sec-eye{color:rgba(255,255,255,.5);text-align:left;margin-bottom:10px;transition:color var(--t)}
  .about-left:hover .sec-eye{color:rgba(222,210,224,.85)}
  .about-left h2{font-family:'Cormorant Garamond',serif;font-size:clamp(30px,3.5vw,50px);font-weight:400;line-height:1.18;margin-bottom:22px;color:var(--bg)}
  .about-left h2 em{font-style:italic;color:rgba(255,255,255,.6);font-weight:300;transition:color var(--t)}
  .about-left:hover h2 em{color:var(--pale)}
  .about-left p{font-size:15.5px;line-height:1.78;color:rgba(255,255,255,.65);margin-bottom:36px;font-weight:500;transition:color var(--t)}
  .about-left:hover p{color:rgba(254,242,230,.92)}

  .btn-outline-light{
    background:transparent;color:var(--bg);
    border:2px solid rgba(255,255,255,.35);border-radius:var(--r-xl);
    padding:12px 28px;font-size:13px;font-weight:700;cursor:pointer;
    text-decoration:none;display:inline-block;transition:all var(--t);
  }
  .btn-outline-light:hover{background:rgba(255,255,255,.15);border-color:rgba(255,255,255,.8)}

  .about-right{
    background:#1a1a1a;padding:88px 60px;
    display:flex;flex-direction:column;justify-content:center;
    transition:background var(--t);
  }
  .about-right:hover{background:var(--teal-d)}

  .stats{display:flex;flex-direction:column;gap:0}
  .stat{padding:26px 0;border-bottom:1px solid rgba(255,255,255,.1);display:flex;align-items:center;gap:28px;transition:border-color var(--t)}
  .stat:first-child{border-top:1px solid rgba(255,255,255,.1)}
  .about-right:hover .stat{border-bottom-color:rgba(254,242,230,.15)}
  .stat-num{font-family:'Cormorant Garamond',serif;font-size:52px;font-weight:300;color:rgba(255,255,255,.4);min-width:92px;line-height:1;transition:color var(--t)}
  .about-right:hover .stat-num{color:var(--pale)}
  .stat-label{font-size:12px;letter-spacing:.1em;text-transform:uppercase;color:rgba(255,255,255,.5);font-weight:700;transition:color var(--t)}
  .about-right:hover .stat-label{color:rgba(254,242,230,.92)}
  .stat-desc{font-size:13px;color:rgba(255,255,255,.3);margin-top:3px;font-weight:500;transition:color var(--t)}
  .about-right:hover .stat-desc{color:rgba(254,242,230,.55)}

  /* ── WORKSHOPS ── */
  .workshop{padding:88px 72px;background:var(--bg)}
  .workshop-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}

  .w-card{
    background:var(--softer);border-radius:var(--r-lg);overflow:hidden;
    border:1px solid var(--line);
    transition:transform .3s,box-shadow .3s, border-color var(--t), background var(--t);
    box-shadow:0 4px 16px rgba(0,0,0,.05);
  }
  .w-card:hover{transform:translateY(-7px);box-shadow:0 20px 46px rgba(71,122,133,.18);border-color:var(--teal-l);background:var(--bg)}
  .w-card:hover .w-img img{transform:scale(1.06)}

  .w-img{width:100%;height:210px;overflow:hidden}
  .w-img img{width:100%;height:100%;object-fit:cover;transition:transform .5s ease}

  .w-body{padding:26px}
  .w-tag{font-size:10.5px;letter-spacing:.14em;text-transform:uppercase;color:var(--muted);font-weight:700;margin-bottom:10px;display:block;transition:color var(--t)}
  .w-card:hover .w-tag{color:var(--teal)}
  .w-body h3{font-family:'Cormorant Garamond',serif;font-size:22px;font-weight:500;color:var(--fg);margin-bottom:10px}
  .w-body p{font-size:14.5px;color:var(--mid);line-height:1.72;margin-bottom:22px;font-weight:500}
  .w-footer{display:flex;justify-content:space-between;align-items:center;padding-top:18px;border-top:2px solid var(--line);transition:border-color var(--t)}
  .w-card:hover .w-footer{border-top-color:var(--pale-d)}
  .w-price{font-family:'Cormorant Garamond',serif;font-size:24px;font-weight:500;color:var(--fg);transition:color var(--t)}
  .w-card:hover .w-price{color:var(--teal)}

  /* ── TESTIMONIALS ── */
  .testimonials{padding:88px 72px;background:var(--soft)}
  .testi-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}

  .testi-card{
    background:var(--bg);border-radius:var(--r-lg);padding:32px 28px;
    border:1px solid var(--line);
    box-shadow:0 4px 16px rgba(0,0,0,.04);transition:transform .3s, border-color var(--t), background var(--t);
  }
  .testi-card:hover{transform:translateY(-5px);border-color:var(--pale-d);background:var(--cream)}

  .testi-stars{color:var(--line);font-size:14px;letter-spacing:2px;margin-bottom:16px;transition:color var(--t)}
  .testi-card:hover .testi-stars{color:var(--teal)}
  .testi-text{font-family:'Cormorant Garamond',serif;font-size:17px;line-height:1.7;color:var(--fg);font-style:italic;font-weight:400;margin-bottom:22px}
  .testi-rule{width:32px;height:3px;background:var(--line);border-radius:3px;margin-bottom:18px;transition:background var(--t)}
  .testi-card:hover .testi-rule{background:var(--pale-d)}
  .testi-author{display:flex;align-items:center;gap:12px}
  .testi-av{
    width:42px;height:42px;border-radius:50%;
    display:flex;align-items:center;justify-content:center;
    font-family:'Cormorant Garamond',serif;font-size:19px;font-weight:500;
    color:var(--bg);flex-shrink:0;
    background:var(--fg);transition:background var(--t);
  }
  .testi-card:nth-child(1):hover .testi-av{background:var(--lilac)}
  .testi-card:nth-child(2):hover .testi-av{background:var(--teal)}
  .testi-card:nth-child(3):hover .testi-av{background:var(--teal-d)}
  .testi-name{font-size:14px;font-weight:700;color:var(--fg)}
  .testi-city{font-size:12px;color:var(--muted);font-weight:600;transition:color var(--t)}
  .testi-card:hover .testi-city{color:var(--teal)}

  /* ── NEWSLETTER ── */
  .newsletter{
    background:var(--fg);padding:88px 72px;
    display:grid;grid-template-columns:1fr 1fr;gap:72px;align-items:center;
    position:relative;overflow:hidden;
    transition:background var(--t);
  }
  .newsletter:hover{background:var(--teal)}
  .newsletter::before{
    content:'';position:absolute;pointer-events:none;
    width:480px;height:480px;
    border-radius:60% 40% 55% 45% / 48% 60% 40% 52%;
    background:rgba(255,255,255,.04);right:-100px;top:-100px;
    animation:blobmove 12s ease-in-out infinite alternate;
    transition:background var(--t);
  }
  .newsletter:hover::before{background:rgba(254,242,230,.06)}
  .nl-eye{font-size:11px;letter-spacing:.22em;text-transform:uppercase;color:rgba(255,255,255,.45);font-weight:700;margin-bottom:12px;display:block;transition:color var(--t)}
  .newsletter:hover .nl-eye{color:rgba(222,210,224,.85)}
  .newsletter h2{font-family:'Cormorant Garamond',serif;font-size:clamp(28px,3.5vw,46px);color:var(--bg);font-weight:400;line-height:1.2;margin-bottom:14px}
  .newsletter h2 em{font-style:italic;color:rgba(255,255,255,.5);font-weight:300;transition:color var(--t)}
  .newsletter:hover h2 em{color:var(--pale)}
  .newsletter p{font-size:15.5px;color:rgba(255,255,255,.6);font-weight:500;line-height:1.72;transition:color var(--t)}
  .newsletter:hover p{color:rgba(254,242,230,.92)}

  .nl-form{display:flex;flex-direction:column;gap:12px;position:relative;z-index:1}
  .nl-form input{
    background:rgba(255,255,255,.08);border:2px solid rgba(255,255,255,.18);
    border-radius:var(--r-md);padding:14px 18px;
    font-family:'Nunito',sans-serif;font-size:14px;color:var(--bg);outline:none;
    transition:border-color var(--t), background var(--t);
  }
  .nl-form input::placeholder{color:rgba(255,255,255,.35)}
  .nl-form input:focus{border-color:rgba(255,255,255,.55);background:rgba(255,255,255,.12)}
  .nl-form button{
    background:var(--cream);color:var(--teal-d);border:none;border-radius:var(--r-xl);
    padding:14px 32px;font-family:'Nunito',sans-serif;font-size:13.5px;font-weight:700;
    cursor:pointer;text-transform:uppercase;letter-spacing:.08em;align-self:flex-start;
    transition:background var(--t),transform .15s;
    box-shadow:0 4px 16px rgba(0,0,0,.15);
  }
  .nl-form button:hover{background:var(--pale);transform:translateY(-2px)}

  /* ── FOOTER ── */
  footer{background:var(--fg);color:var(--bg);padding:72px 72px 36px;transition:background var(--t)}
  footer:hover{background:#111}
  .footer-grid{display:grid;grid-template-columns:2.2fr 1fr 1fr 1fr;gap:48px;margin-bottom:52px}
  .footer-brand img{width:44px;height:44px;object-fit:contain;border-radius:50%}
  
  .footer-brand-name{font-family:'Cormorant Garamond',serif;font-weight:500;letter-spacing:.07em;color:rgba(255,255,255,.7);font-size:19px;line-height:1}
  .footer-brand-sub{font-size:9.5px;letter-spacing:.2em;color:rgba(255,255,255,.25);text-transform:uppercase;margin-top:3px;font-weight:700}
  .footer-brand p{font-size:14px;line-height:1.78;color:rgba(255,255,255,.35);margin:16px 0 24px;max-width:250px;font-weight:500}

  .social-links{display:flex;gap:10px}
  .social-btn{
    width:38px;height:38px;border-radius:50%;
    border:1.5px solid rgba(255,255,255,.15);
    display:flex;align-items:center;justify-content:center;
    text-decoration:none;color:rgba(255,255,255,.35);font-size:12px;font-weight:700;
    transition:all var(--t);
  }
  .social-btn:hover{background:var(--teal);color:var(--bg);border-color:var(--teal)}

  .footer-col h4{font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:rgba(255,255,255,.25);font-weight:700;margin-bottom:20px;transition:color var(--t)}
  .footer-col:hover h4{color:rgba(255,255,255,.5)}
  .footer-col ul{list-style:none}
  .footer-col li{margin-bottom:11px}
  .footer-col a{text-decoration:none;color:rgba(255,255,255,.35);font-size:13.5px;font-weight:500;transition:color var(--t)}
  .footer-col a:hover{color:var(--cream)}

  .footer-bottom{
    border-top:1px solid rgba(255,255,255,.08);padding-top:26px;
    display:flex;justify-content:space-between;align-items:center;
    font-size:12px;color:rgba(255,255,255,.2);letter-spacing:.04em;
  }

  /* ── HAMBURGER MENU ── */
  .hamburger{
    display:none;background:none;border:none;cursor:pointer;
    width:36px;height:36px;position:relative;padding:0;
    flex-direction:column;align-items:center;justify-content:center;gap:5px;
  }
  .hamburger span{
    display:block;width:22px;height:2px;background:var(--fg);border-radius:2px;
    transition:transform .3s,opacity .3s;
  }
  .hamburger.active span:nth-child(1){transform:translateY(7px) rotate(45deg)}
  .hamburger.active span:nth-child(2){opacity:0}
  .hamburger.active span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

  .mobile-menu{
    display:none;position:fixed;top:0;left:0;right:0;bottom:0;z-index:199;
    background:rgba(255,255,255,.98);backdrop-filter:blur(16px);
    flex-direction:column;align-items:center;justify-content:center;gap:28px;
    opacity:0;transition:opacity .3s;pointer-events:none;
  }
  .mobile-menu.open{display:flex;opacity:1;pointer-events:all}
  .mobile-menu a{
    font-family:'Cormorant Garamond',serif;font-size:28px;color:var(--fg);
    font-weight:400;letter-spacing:.04em;transition:color var(--t);
  }
  .mobile-menu a:hover{color:var(--teal)}

  /* ── RESPONSIVE ── */

  /* Tablet landscape */
  @media(max-width:1100px){
    .sp-nav,.categories,.featured,.workshop,.testimonials,.newsletter,footer{padding-left:36px;padding-right:36px}
    .about-left,.about-right{padding-left:40px;padding-right:40px}
    .cat-grid,.products-grid{grid-template-columns:repeat(2,1fr)}
    .footer-grid{grid-template-columns:1fr 1fr}
    .slide-left{padding:56px 36px}
  }

  /* Tablet portrait */
  @media(max-width:900px){
    .topbar-social{display:none}
    .topbar{padding:9px 20px}
    .workshop-grid,.testi-grid{grid-template-columns:repeat(2,1fr)}
    .footer-grid{grid-template-columns:1fr 1fr;gap:32px}
    .stat-num{font-size:40px;min-width:72px}
    .slider-arrow{width:38px;height:38px;font-size:14px}
    .slide-counter{right:28px;bottom:24px}
  }

  /* Mobile */
  @media(max-width:768px){
    .sp-nav{padding:0 20px;height:62px}
    .nav-links{display:none}
    .hamburger{display:flex}
    .nav-logo img{width:36px;height:36px}
    .nav-brand{font-size:16px}
    .nav-sub{font-size:9px}
    .btn-cart{padding:7px 16px;font-size:12px}

    .hero-slider{height:75vh;min-height:480px}
    .slide{grid-template-columns:1fr}
    .slide-right{display:none}
    .slide-left{padding:48px 24px}
    .slide-h1{font-size:clamp(32px,8vw,48px)}
    .slide-sub{font-size:14px}
    .slider-arrow{width:34px;height:34px;font-size:13px}
    .slider-prev{left:12px}.slider-next{right:12px}
    .slide-counter{right:16px;bottom:20px}

    .categories,.featured,.workshop,.testimonials{padding:56px 20px}
    .cat-grid,.products-grid{grid-template-columns:repeat(2,1fr);gap:14px}

    .about-wrap{grid-template-columns:1fr}
    .about-left,.about-right{padding:48px 24px}
    .stat-num{font-size:36px;min-width:auto}
    .stats{gap:0}

    .workshop-grid,.testi-grid{grid-template-columns:1fr}
    .newsletter{grid-template-columns:1fr;padding:48px 24px;gap:28px}
    .nl-form button{align-self:stretch;text-align:center}

    footer{padding:48px 24px 24px}
    .footer-grid{grid-template-columns:1fr;gap:28px}
    .footer-bottom{flex-direction:column;gap:10px;text-align:center}
  }

  /* Small mobile */
  @media(max-width:420px){
    .topbar{font-size:10px;padding:8px 16px}
    .topbar-center{line-height:1.5}
    .cat-grid,.products-grid{grid-template-columns:1fr}
    .slide-left{padding:40px 18px}
    .slide-ctas{flex-direction:column}
    .slide-ctas .btn-primary,.slide-ctas .btn-ghost{width:100%;text-align:center}
    .categories,.featured,.workshop,.testimonials{padding:44px 16px}
    .about-left,.about-right{padding:40px 18px}
    .newsletter{padding:40px 18px}
    footer{padding:40px 18px 20px}
    .nav-actions .nav-icon{display:none}
  }
