/* ============================================================
   Vive Arthritis Gloves – Indonesian Landing
   bold-editorial | pill | subtle | accent-bar | gradient
   #5A9F77 sage · #9B59B6 lavender · #2C7FB2 teal · #E74C3C coral
   ============================================================ */
:root {
    --sage:   #5A9F77;
    --lav:    #9B59B6;
    --teal:   #2C7FB2;
    --coral:  #E74C3C;
    --bg:     #f6fbf8;
    --surf:   #ffffff;
    --text:   #10200a;
    --muted:  #4a6050;
    --border: #d4e8da;
    --r-card: 24px;
    --r-btn:  50px;
    --r-sm:   16px;
    --font:   'Inter', sans-serif;
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:var(--font);font-size:clamp(14px,4vw,16px);background:var(--bg);color:var(--text);line-height:1.7;overflow-x:hidden}
img{max-width:100%;height:auto;display:block}

/* HEADER — accent-bar: sage */
.site-header{background:var(--sage);border-bottom:3px solid var(--lav);padding:1rem 1.25rem;position:sticky;top:0;z-index:100;box-shadow:0 2px 12px rgba(90,159,119,.2)}
.header-inner{max-width:1200px;margin:0 auto;display:flex;justify-content:center}
.site-name{color:#fff;font-size:clamp(13px,3.2vw,16px);font-weight:600;text-align:center;letter-spacing:.01em}

/* PRODUCT */
.product-section{max-width:1200px;margin:0 auto;padding:3rem 1rem 0}
.product-grid{display:grid;grid-template-columns:1fr;gap:2.5rem}
@media(min-width:768px){.product-grid{grid-template-columns:1fr 1fr;gap:3.5rem;align-items:start}}

/* GALLERY — pill, subtle */
.gallery-wrap{background:var(--surf);border-radius:var(--r-card);box-shadow:0 2px 12px rgba(90,159,119,.1);padding:1.25rem;transition:box-shadow .25s,transform .25s}
.gallery-wrap:hover{box-shadow:0 8px 26px rgba(90,159,119,.18);transform:translateY(-2px)}
.gallery-wrap input[type=radio]{display:none}
.slides{position:relative;width:100%;aspect-ratio:1/1;overflow:hidden;border-radius:var(--r-sm);background:linear-gradient(135deg,#f0fbf5,#f5f0fc)}
.slide{position:absolute;inset:0;opacity:0;transition:opacity .35s ease;display:flex;align-items:center;justify-content:center}
.slide img{width:100%;height:100%;object-fit:contain}
#s1:checked~.slides #slide1,#s2:checked~.slides #slide2,#s3:checked~.slides #slide3,#s4:checked~.slides #slide4{opacity:1}
.gallery-dots{display:flex;justify-content:center;gap:8px;margin-top:1rem}
.gallery-dots label{width:10px;height:10px;border-radius:50%;background:var(--border);cursor:pointer;transition:background .2s,transform .2s;display:block}
.gallery-dots label:hover{transform:scale(1.3)}
#s1:checked~.gallery-dots label[for=s1],#s2:checked~.gallery-dots label[for=s2],#s3:checked~.gallery-dots label[for=s3],#s4:checked~.gallery-dots label[for=s4]{background:var(--sage)}
.gallery-thumbs{display:flex;gap:.5rem;margin-top:.85rem;flex-wrap:wrap}
.gallery-thumbs label{cursor:pointer;border:2px solid transparent;border-radius:12px;overflow:hidden;flex:0 0 58px;transition:border-color .2s}
.gallery-thumbs label img{width:58px;height:58px;object-fit:cover}
.gallery-thumbs label:hover{border-color:var(--sage)}
#s1:checked~.gallery-thumbs label[for=s1],#s2:checked~.gallery-thumbs label[for=s2],#s3:checked~.gallery-thumbs label[for=s3],#s4:checked~.gallery-thumbs label[for=s4]{border-color:var(--sage)}

/* INFO */
.product-info{display:flex;flex-direction:column;gap:1.25rem}

/* TRUST BADGES ROW */
.trust-row{display:flex;flex-wrap:wrap;gap:.4rem}
.tr-badge{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.04em;padding:.28rem .7rem;border-radius:var(--r-btn);background:rgba(90,159,119,.1);border:1px solid rgba(90,159,119,.3);color:var(--sage)}

/* BOLD-EDITORIAL TITLE */
.product-title{font-size:clamp(24px,5vw,40px);font-weight:700;line-height:1.12;color:var(--text);letter-spacing:-.025em;padding-bottom:1rem;border-bottom:3px solid var(--lav)}

/* MATERIAL PILLS */
.mat-pills{display:flex;flex-wrap:wrap;gap:.4rem}
.mp{font-size:12px;font-weight:600;padding:.28rem .7rem;border-radius:var(--r-btn);background:rgba(155,89,182,.08);border:1px solid rgba(155,89,182,.25);color:var(--lav)}

/* FEATURES — diamond bullet */
.features{display:flex;flex-direction:column;gap:0}
.feat{display:flex;gap:.8rem;align-items:flex-start;padding:.85rem 0;border-bottom:1px solid var(--border)}
.feat:last-child{border-bottom:none}
.fn{font-size:.85rem;color:var(--sage);flex-shrink:0;margin-top:.25rem;filter:brightness(.85)}
.feat strong{display:block;font-size:clamp(13px,3.5vw,14px);font-weight:700;color:var(--text);margin-bottom:.2rem}
.feat p{font-size:clamp(13px,3.8vw,14px);line-height:1.65;color:var(--text)}

/* CTA — gradient pill */
.cta-section{max-width:1200px;margin:0 auto;padding:2.5rem 1rem;display:flex;justify-content:center}
.cta-btn{display:inline-block;width:100%;max-width:560px;text-align:center;padding:1.1rem 2.5rem;min-height:58px;font-size:clamp(16px,4vw,19px);font-weight:700;color:#fff;background:linear-gradient(135deg,var(--sage) 0%,var(--teal) 100%);border-radius:var(--r-btn);text-decoration:none;letter-spacing:.02em;border:none;box-shadow:0 6px 22px rgba(44,127,178,.22);transition:filter .22s,box-shadow .22s,transform .18s}
.cta-btn:hover{filter:brightness(1.08);box-shadow:0 12px 32px rgba(44,127,178,.32);transform:translateY(-2px)}

/* REVIEWS */
.reviews-section{max-width:860px;margin:0 auto;padding:0 1rem 3.5rem}
.reviews-title{font-size:clamp(20px,5vw,26px);font-weight:700;color:var(--text);margin-bottom:1.5rem;padding-bottom:.55rem;border-bottom:2px solid var(--border);letter-spacing:-.02em}
.review{padding:1.5rem 0;border-bottom:1px solid var(--border)}
.review:last-child{border-bottom:none}
.review-header{display:flex;align-items:flex-start;gap:.85rem;margin-bottom:.4rem}
.review-avatar{flex-shrink:0}
.review-avatar img{width:44px;height:44px;border-radius:50%;object-fit:cover;border:2px solid var(--border);box-shadow:0 2px 6px rgba(90,159,119,.1)}
.review-meta{display:flex;flex-direction:column;gap:.1rem}
.reviewer-name{font-weight:700;font-size:clamp(14px,3.5vw,15px);color:var(--text)}
.stars{color:var(--lav);font-size:1rem;letter-spacing:1px;filter:brightness(.85)}
.review-headline{font-weight:600;font-size:clamp(14px,3.5vw,15px);color:var(--sage);filter:brightness(.82);line-height:1.4}
.review-date{font-size:13px;color:var(--muted);margin-bottom:.2rem}
.review-attr{font-size:13px;color:var(--muted);margin-bottom:.65rem}
.review-body{display:flex;flex-direction:column;gap:.55rem;font-size:clamp(14px,4vw,15px);line-height:1.75}

/* FOOTER */
.site-footer{background:var(--teal);color:rgba(255,255,255,.65);padding:1.75rem 1rem;margin-top:2rem;border-top:3px solid var(--sage)}
.footer-inner{max-width:1200px;margin:0 auto;display:flex;flex-direction:column;align-items:center;gap:1rem;text-align:center}
@media(min-width:768px){.footer-inner{flex-direction:row;justify-content:space-between;text-align:left}}
.footer-brand{font-weight:700;font-size:clamp(12px,3vw,14px);color:#fff}
.footer-links{display:flex;flex-wrap:wrap;justify-content:center;gap:.4rem 1.25rem}
.footer-links a{color:rgba(255,255,255,.58);text-decoration:none;font-size:13px;transition:color .2s}
.footer-links a:hover{color:rgba(255,255,255,.95)}