/* =========================================================================
   TRIUNIQU — storefront design system
   Palette: warm paper background, ink text, deep emerald CTA, gold accent
   for price/sale, WhatsApp green reserved only for the order action.
   Type: Fraunces (display, used sparingly) + Work Sans (body / UI)
   ========================================================================= */

:root{
  --bg:        #FBF9F6;
  --paper:     #FFFFFF;
  --ink:       #211F1B;
  --ink-soft:  #6B655C;
  --line:      #E6DFD3;
  --primary:   #1F6F50;
  --primary-d: #154E38;
  --gold:      #B8893F;
  --whatsapp:  #25D366;
  --whatsapp-d:#1DA851;
  --danger:    #B3261E;
  --radius:    3px;
  --radius-lg: 10px;
  --shadow:    0 8px 24px rgba(33,31,27,.06);
  --maxw:      1180px;
}

*{box-sizing:border-box;}
html{scroll-behavior:smooth;}
body{
  margin:0;
  background:var(--bg);
  color:var(--ink);
  font-family:'Work Sans', -apple-system, Segoe UI, sans-serif;
  font-size:16px;
  line-height:1.55;
}
img{max-width:100%;display:block;}
a{color:inherit;text-decoration:none;}
.container{max-width:var(--maxw);margin:0 auto;padding:0 24px;}

h1,h2,h3,.display{
  font-family:'Fraunces', Georgia, serif;
  font-weight:600;
  letter-spacing:-0.01em;
  margin:0 0 .4em;
  color:var(--ink);
}
h1{font-size:clamp(2.1rem,4vw,3.4rem);line-height:1.05;}
h2{font-size:clamp(1.5rem,2.6vw,2.1rem);}
h3{font-size:1.25rem;}
.eyebrow{
  font-size:.72rem;letter-spacing:.16em;text-transform:uppercase;
  color:var(--ink-soft);font-weight:600;
}
p{color:var(--ink-soft);}
:focus-visible{outline:3px solid var(--gold);outline-offset:2px;}

/* ---------- buttons ---------- */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:8px;
  padding:13px 26px;border-radius:var(--radius);border:1px solid var(--ink);
  background:var(--ink);color:#fff;font-weight:600;font-size:.95rem;
  cursor:pointer;transition:.18s ease;
}
.btn:hover{background:#000;}
.btn-outline{background:transparent;color:var(--ink);}
.btn-outline:hover{background:var(--ink);color:#fff;}
.btn-block{width:100%;}
.btn-whatsapp{
  background:var(--whatsapp);border-color:var(--whatsapp);color:#0B3B23;
  font-weight:700;
}
.btn-whatsapp:hover{background:var(--whatsapp-d);}
.btn-whatsapp svg{flex:none;}
.btn[disabled]{opacity:.5;cursor:not-allowed;}

/* ---------- header ---------- */
.site-header{
  position:sticky;top:0;z-index:50;background:rgba(251,249,246,.96);
  backdrop-filter:blur(6px);border-bottom:1px solid var(--line);
}
.header-inner{display:flex;align-items:center;justify-content:space-between;height:76px;}
.logo{display:flex;align-items:center;gap:10px;font-family:'Fraunces',serif;font-size:1.5rem;font-weight:700;}
.logo img{height:38px;width:auto;}
.main-nav{display:flex;align-items:center;gap:28px;}
.main-nav a{font-size:.92rem;font-weight:500;color:var(--ink);position:relative;}
.main-nav a.active{color:var(--primary);}
.header-actions{display:flex;align-items:center;gap:16px;}
.header-actions a{font-size:.85rem;font-weight:600;}
.icon-btn{display:inline-flex;align-items:center;gap:6px;padding:8px 14px;border:1px solid var(--line);border-radius:30px;}
.nav-toggle{display:none;background:none;border:none;font-size:1.6rem;cursor:pointer;}

.announce-bar{
  background:var(--ink);color:#fff;text-align:center;font-size:.8rem;
  letter-spacing:.04em;padding:9px 0;
}

/* ---------- hero ---------- */
.hero{
  padding:64px 0 56px;border-bottom:1px solid var(--line);
}
.hero-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:48px;align-items:center;}
.hero-copy p.lead{font-size:1.08rem;max-width:440px;margin-bottom:28px;}
.hero-cta{display:flex;gap:14px;flex-wrap:wrap;}
.hero-art{
  position:relative;border-radius:var(--radius-lg);overflow:hidden;background:var(--paper);
  border:1px solid var(--line);aspect-ratio:4/5;
}
.hero-art img{width:100%;height:100%;object-fit:cover;}
.hero-tag{
  position:absolute;bottom:18px;left:18px;background:#fff;border:1px solid var(--line);
  border-radius:var(--radius-lg);padding:10px 16px;box-shadow:var(--shadow);
  font-family:'Fraunces',serif;font-weight:600;
}
.hero-tag small{display:block;font-family:'Work Sans',sans-serif;color:var(--ink-soft);font-weight:500;font-size:.7rem;text-transform:uppercase;letter-spacing:.08em;}

/* ---------- category strip ---------- */
.cat-strip{padding:48px 0;border-bottom:1px solid var(--line);}
.cat-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:18px;}
.cat-card{
  border:1px solid var(--line);border-radius:var(--radius-lg);padding:22px 18px;
  background:var(--paper);transition:.18s;
}
.cat-card:hover{border-color:var(--ink);transform:translateY(-2px);}
.cat-card .num{font-family:'Fraunces',serif;color:var(--line);font-size:1.6rem;}

/* ---------- section heading row ---------- */
.section{padding:56px 0;}
.section-head{display:flex;align-items:baseline;justify-content:space-between;margin-bottom:28px;flex-wrap:wrap;gap:10px;}
.section-head a{font-size:.85rem;font-weight:600;border-bottom:1px solid var(--ink);}

/* ---------- product grid / cards ---------- */
.product-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(230px,1fr));gap:28px 22px;}
.product-card{position:relative;}
.product-thumb{
  position:relative;border-radius:var(--radius-lg);overflow:hidden;background:var(--paper);
  border:1px solid var(--line);aspect-ratio:3/4;margin-bottom:12px;
}
.product-thumb img{width:100%;height:100%;object-fit:cover;transition:.4s ease;}
.product-card:hover .product-thumb img{transform:scale(1.04);}
.badge-sale{
  position:absolute;top:10px;left:10px;background:var(--gold);color:#fff;
  font-size:.7rem;font-weight:700;padding:4px 9px;border-radius:30px;letter-spacing:.02em;
}
.product-card h3{font-size:1rem;margin-bottom:2px;}
.product-cat{font-size:.75rem;color:var(--ink-soft);text-transform:uppercase;letter-spacing:.05em;}
.price-row{display:flex;align-items:center;gap:8px;margin-top:6px;}
.price-sell{font-weight:700;color:var(--ink);}
.price-orig{font-size:.85rem;color:var(--ink-soft);text-decoration:line-through;}
.rating-row{font-size:.8rem;color:var(--gold);margin-top:4px;}
.rating-row span{color:var(--ink-soft);}

/* ---------- filters ---------- */
.filter-bar{display:flex;gap:10px;flex-wrap:wrap;margin-bottom:32px;}
.filter-bar a{
  padding:8px 16px;border:1px solid var(--line);border-radius:30px;font-size:.85rem;font-weight:500;
}
.filter-bar a.active{background:var(--ink);color:#fff;border-color:var(--ink);}

/* ---------- product detail page ---------- */
.product-page{padding:48px 0 72px;}
.product-layout{display:grid;grid-template-columns:1fr 1fr;gap:54px;}
.gallery-main{
  border:1px solid var(--line);border-radius:var(--radius-lg);overflow:hidden;
  aspect-ratio:1/1;background:var(--paper);margin-bottom:14px;
}
.gallery-main img{width:100%;height:100%;object-fit:cover;}
.gallery-thumbs{display:flex;gap:10px;flex-wrap:wrap;}
.gallery-thumbs img{
  width:74px;height:90px;object-fit:cover;border-radius:var(--radius);
  border:1px solid var(--line);cursor:pointer;opacity:.7;
}
.gallery-thumbs img.active{opacity:1;border-color:var(--ink);}

.product-info .eyebrow{margin-bottom:10px;}
.product-info h1{font-size:1.9rem;margin-bottom:8px;}
.product-info .price-row{font-size:1.3rem;margin:14px 0 6px;}
.product-info .short-desc{margin-bottom:18px;}
.discount-pill{background:#FBEFDD;color:var(--gold);font-weight:700;font-size:.75rem;padding:3px 10px;border-radius:30px;}

.option-block{margin:22px 0;}
.option-label{font-size:.78rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em;margin-bottom:10px;display:block;}
.swatches{display:flex;gap:10px;flex-wrap:wrap;}
.swatch{
  padding:9px 16px;border:1px solid var(--line);border-radius:30px;font-size:.86rem;font-weight:500;
  cursor:pointer;background:#fff;
}
.swatch.selected{border-color:var(--ink);background:var(--ink);color:#fff;}
.swatch.disabled{opacity:.35;cursor:not-allowed;text-decoration:line-through;}

.qty-row{display:flex;align-items:center;gap:14px;margin:22px 0;}
.qty-control{display:flex;border:1px solid var(--line);border-radius:30px;overflow:hidden;}
.qty-control button{width:38px;height:38px;border:none;background:#fff;font-size:1.1rem;cursor:pointer;}
.qty-control input{width:42px;border:none;text-align:center;font-weight:600;}

.order-box{
  border:1px dashed var(--whatsapp-d);background:#F2FBF6;border-radius:var(--radius-lg);
  padding:18px;margin-top:24px;
}
.order-box .btn-whatsapp{width:100%;font-size:1rem;padding:15px;}
.order-hint{font-size:.78rem;color:var(--ink-soft);margin-top:10px;}

.meta-table{margin-top:30px;border-top:1px solid var(--line);padding-top:20px;font-size:.88rem;}
.meta-table div{display:flex;justify-content:space-between;padding:8px 0;border-bottom:1px solid var(--line);}
.meta-table div span:first-child{color:var(--ink-soft);}

.tabs-nav{display:flex;gap:24px;border-bottom:1px solid var(--line);margin:48px 0 24px;}
.tabs-nav button{
  background:none;border:none;padding:12px 0;font-size:.95rem;font-weight:600;cursor:pointer;
  color:var(--ink-soft);border-bottom:2px solid transparent;
}
.tabs-nav button.active{color:var(--ink);border-color:var(--primary);}
.tab-panel{display:none;}
.tab-panel.active{display:block;}

/* ---------- reviews ---------- */
.review-summary{display:flex;align-items:center;gap:18px;margin-bottom:24px;}
.review-summary .big{font-family:'Fraunces',serif;font-size:2.6rem;}
.review{border-bottom:1px solid var(--line);padding:18px 0;}
.review .stars{color:var(--gold);font-size:.95rem;}
.review .who{font-weight:700;font-size:.9rem;margin-top:4px;}
.review .when{font-size:.75rem;color:var(--ink-soft);}
.review-form{margin-top:32px;background:var(--paper);border:1px solid var(--line);border-radius:var(--radius-lg);padding:22px;}
.star-input{display:flex;gap:6px;font-size:1.6rem;color:var(--line);cursor:pointer;margin-bottom:14px;}
.star-input span.active{color:var(--gold);}

/* ---------- forms (auth, contact, admin) ---------- */
.form-card{
  max-width:440px;margin:60px auto;background:var(--paper);border:1px solid var(--line);
  border-radius:var(--radius-lg);padding:36px;
}
.form-group{margin-bottom:18px;}
label{display:block;font-size:.82rem;font-weight:600;margin-bottom:7px;}
input[type=text],input[type=email],input[type=password],input[type=tel],input[type=number],
textarea,select{
  width:100%;padding:12px 14px;border:1px solid var(--line);border-radius:var(--radius);
  font-family:inherit;font-size:.95rem;background:#fff;color:var(--ink);
}
textarea{resize:vertical;}
input:focus,textarea:focus,select:focus{border-color:var(--ink);}
.form-foot{margin-top:18px;font-size:.88rem;color:var(--ink-soft);}
.alert{padding:13px 16px;border-radius:var(--radius);margin-bottom:18px;font-size:.9rem;}
.alert-error{background:#FBEAE8;color:var(--danger);border:1px solid #F0C8C3;}
.alert-success{background:#E9F5EE;color:var(--primary-d);border:1px solid #BFE3CC;}

/* ---------- legal pages ---------- */
.legal-page{padding:56px 0 80px;}
.legal-page .content{max-width:760px;}
.legal-page .content h2{margin-top:1.4em;}
.legal-page .content p,.legal-page .content li{color:var(--ink-soft);}

/* ---------- footer ---------- */
.site-footer{background:var(--ink);color:#E7E3DC;padding:56px 0 28px;margin-top:40px;}
.footer-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:36px;margin-bottom:36px;}
.site-footer h4{font-family:'Fraunces',serif;color:#fff;font-size:1rem;margin-bottom:14px;}
.site-footer p{color:#B9B3A6;font-size:.88rem;}
.footer-links a{display:block;color:#B9B3A6;font-size:.88rem;padding:5px 0;}
.footer-links a:hover{color:#fff;}
.social-row{display:flex;gap:12px;margin-top:14px;}
.social-row a{
  width:34px;height:34px;border:1px solid #4A463F;border-radius:50%;display:flex;
  align-items:center;justify-content:center;
}
.social-row a:hover{background:#fff;color:var(--ink);}
.footer-bottom{
  border-top:1px solid #3C3934;padding-top:20px;display:flex;justify-content:space-between;
  font-size:.78rem;color:#8D877A;flex-wrap:wrap;gap:8px;
}

/* ---------- whatsapp floating button ---------- */
.wa-float{
  position:fixed;bottom:22px;right:22px;background:var(--whatsapp);color:#0B3B23;
  width:58px;height:58px;border-radius:50%;display:flex;align-items:center;justify-content:center;
  box-shadow:0 10px 24px rgba(0,0,0,.18);z-index:60;
}

/* ---------- pagination ---------- */
.pagination{display:flex;gap:8px;justify-content:center;margin-top:36px;}
.pagination a{width:36px;height:36px;display:flex;align-items:center;justify-content:center;border:1px solid var(--line);border-radius:50%;font-size:.85rem;}
.pagination a.active{background:var(--ink);color:#fff;border-color:var(--ink);}

/* ---------- responsive ---------- */
@media (max-width:860px){
  .hero-grid,.product-layout,.footer-grid{grid-template-columns:1fr;}
  .footer-grid{gap:30px;}
  .main-nav{position:fixed;top:76px;left:0;right:0;background:var(--bg);flex-direction:column;
    align-items:flex-start;padding:18px 24px;border-bottom:1px solid var(--line);display:none;gap:14px;}
  .main-nav.open{display:flex;}
  .nav-toggle{display:block;}
  .header-actions a span.label{display:none;}
}
@media (prefers-reduced-motion: reduce){
  *{transition:none !important;animation:none !important;}
}
