/* ============================================================
   GILAMCHILIK.UZ — Premium Milliy Gilam Marketplace
   Design system: Luxury · Elegant · Uzbek national ornament
   ============================================================ */

/* ---------- DESIGN TOKENS ---------- */
:root{
  /* Surface */
  --cream:        #F6EFE2;
  --cream-soft:   #FBF6EC;
  --beige:        #E9DCC4;
  --beige-deep:   #D8C7A4;
  --paper:        #FFFDF8;

  /* Ink / dark */
  --ink:          #2A1810;
  --ink-soft:     #4A3322;
  --espresso:     #1A0F08;

  /* Brand — carpet reds & gold */
  --carmine:      #8B1E1E;
  --carmine-deep: #6B1414;
  --rust:         #B5491F;
  --terracotta:   #C56A38;
  --gold:         #C9962E;
  --gold-light:   #E2B84B;
  --gold-bright:  #E5B84B;
  --gold-pale:    #F0D89A;

  /* Accent (kilim) */
  --indigo:       #2A3A5C;
  --forest:       #3B5436;

  /* Functional */
  --gray:         #7A6B58;
  --line:         rgba(42,24,16,.12);
  --line-soft:    rgba(42,24,16,.07);

  /* Typography */
  --display: "Cormorant Garamond", "Playfair Display", Georgia, serif;
  --body:    "Manrope", "Raleway", -apple-system, sans-serif;

  /* Shadow */
  --sh-sm:  0 2px 10px rgba(42,24,16,.06);
  --sh-md:  0 14px 40px -12px rgba(42,24,16,.18);
  --sh-lg:  0 30px 70px -20px rgba(42,24,16,.32);
  --sh-gold:0 18px 44px -14px rgba(201,150,46,.45);

  /* Motion */
  --ease:   cubic-bezier(.22,.61,.36,1);
  --ease-soft: cubic-bezier(.4,0,.2,1);

  --radius: 22px;
  --radius-sm: 14px;
  --maxw: 1240px;
}
/* ---------- RESET ---------- */
*,*::before,*::after{ box-sizing:border-box; margin:0; padding:0; }
html{ scroll-behavior:smooth; -webkit-text-size-adjust:100%; }
body{
  font-family:var(--body);
  background:var(--cream);
  color:var(--ink);
  line-height:1.7;
  font-size:16px;
  font-weight:400;
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
main{ overflow-x:clip; }
img{ max-width:100%; display:block; }
a{ color:inherit; text-decoration:none; }
button,input,textarea,select{ font:inherit; color:inherit; }
ul{ list-style:none; }
::selection{ background:var(--gold); color:var(--espresso); }

/* ---------- SCROLLBAR ---------- */
::-webkit-scrollbar{ width:11px; }
::-webkit-scrollbar-track{ background:var(--beige); }
::-webkit-scrollbar-thumb{
  background:linear-gradient(var(--carmine),var(--gold));
  border-radius:20px; border:2px solid var(--beige);
}

/* ---------- TYPOGRAPHY ---------- */
h1,h2,h3,h4{ font-family:var(--display); font-weight:600; line-height:1.12; letter-spacing:-.01em; }
.display{ font-family:var(--display); }
em{ font-style:italic; }

/* ---------- LAYOUT HELPERS ---------- */
.container{ width:100%; max-width:var(--maxw); margin-inline:auto; padding-inline:clamp(20px,5vw,64px); }
.section{ padding-block:clamp(72px,11vw,140px); position:relative; }

.eyebrow{
  display:inline-flex; align-items:center; gap:10px;
  font-family:var(--body); font-weight:700;
  font-size:12.5px; letter-spacing:.22em; text-transform:uppercase;
  color:var(--carmine);
}
.eyebrow::before,.eyebrow.center::after{
  content:""; width:30px; height:1.5px;
  background:linear-gradient(90deg,transparent,var(--gold));
}
.eyebrow.center::before{ background:linear-gradient(90deg,var(--gold),transparent); }
.eyebrow.light{ color:var(--gold-light); }

.sec-head{ max-width:640px; }
.sec-head.center{ margin-inline:auto; text-align:center; }
.sec-title{
  font-size:clamp(2.1rem,4.6vw,3.5rem);
  margin-top:18px; color:var(--ink);
}
.sec-title.light{ color:var(--cream); }
.sec-sub{
  margin-top:18px; color:var(--gray);
  font-size:1.04rem; line-height:1.8;
}
.sec-sub.light{ color:rgba(246,239,226,.7); }

/* ornament divider */
.ornament{
  display:flex; align-items:center; justify-content:center; gap:14px;
  margin-top:22px;
}
.sec-head.center .ornament{ margin-inline:auto; }
.ornament span{ height:1.5px; width:46px; background:linear-gradient(90deg,transparent,var(--gold)); }
.ornament span:last-child{ background:linear-gradient(90deg,var(--gold),transparent); }
.ornament svg{ width:26px; height:26px; color:var(--carmine); }

/* ---------- BUTTONS ---------- */
.btn{
  display:inline-flex; align-items:center; justify-content:center; gap:10px;
  font-family:var(--body); font-weight:700; font-size:15px;
  padding:15px 32px; border-radius:60px; border:1.5px solid transparent;
  cursor:pointer; position:relative; overflow:hidden;
  transition:transform .4s var(--ease), box-shadow .4s var(--ease), background .3s, color .3s;
  letter-spacing:.01em; white-space:nowrap;
}
.btn i{ font-size:14px; transition:transform .35s var(--ease); }
.btn-primary{
  background:linear-gradient(135deg,var(--carmine),var(--carmine-deep));
  color:var(--cream-soft);
  box-shadow:0 14px 34px -12px rgba(139,30,30,.6);
}
.btn-primary::after{
  content:""; position:absolute; inset:0;
  background:linear-gradient(135deg,var(--gold),var(--rust));
  opacity:0; transition:opacity .4s var(--ease);
}
.btn-primary span,.btn-primary i{ position:relative; z-index:1; }
.btn-primary:hover{ transform:translateY(-3px); box-shadow:var(--sh-gold); }
.btn-primary:hover::after{ opacity:1; }
.btn-primary:hover i{ transform:translateX(4px); }

.btn-gold{
  background:linear-gradient(135deg,var(--gold-light),var(--gold));
  color:var(--espresso);
  box-shadow:var(--sh-gold);
}
.btn-gold:hover{ transform:translateY(-3px); box-shadow:0 24px 50px -14px rgba(201,150,46,.6); }
.btn-gold:hover i{ transform:translateX(4px); }

.btn-outline{
  background:transparent; color:var(--ink);
  border-color:var(--line);
}
.btn-outline:hover{
  border-color:var(--carmine); color:var(--carmine);
  transform:translateY(-3px); background:rgba(139,30,30,.04);
}
.btn-outline.light{ color:var(--cream); border-color:rgba(246,239,226,.3); }
.btn-outline.light:hover{ border-color:var(--gold-light); color:var(--gold-light); background:rgba(246,239,226,.05); }

/* ---------- NAVBAR ---------- */
.nav{
  position:fixed; inset:0 0 auto 0; z-index:1000;
  display:flex; align-items:center; justify-content:space-between;
  padding:20px clamp(20px,5vw,64px);
  transition:padding .4s var(--ease), background .4s var(--ease),
             box-shadow .4s var(--ease), backdrop-filter .4s;
}
.nav.scrolled{
  padding:13px clamp(20px,5vw,64px);
  background:rgba(246,239,226,.82);
  backdrop-filter:blur(18px) saturate(160%);
  -webkit-backdrop-filter:blur(18px) saturate(160%);
  box-shadow:0 1px 0 var(--line), 0 14px 34px -22px rgba(42,24,16,.4);
}
.brand{ display:flex; align-items:center; gap:13px; }
.brand-mark{
  width:46px; height:46px; border-radius:13px; flex-shrink:0;
  display:grid; place-items:center;
  background:linear-gradient(135deg,var(--carmine),var(--carmine-deep));
  box-shadow:0 8px 20px -8px rgba(139,30,30,.6);
  position:relative; overflow:hidden;
}
.brand-mark svg{ width:26px; height:26px; color:var(--gold-light); position:relative; z-index:1; }
.brand-mark::after{
  content:""; position:absolute; inset:0;
  background:radial-gradient(circle at 30% 25%,rgba(229,184,75,.4),transparent 60%);
}
.brand-name{ font-family:var(--display); font-size:1.5rem; font-weight:700; line-height:1; color:var(--ink); }
.brand-name b{ color:var(--carmine); font-weight:700; }
.brand-tag{ font-size:9.5px; letter-spacing:.28em; text-transform:uppercase; color:var(--gray); margin-top:3px; }

.nav-links{ display:flex; align-items:center; gap:6px; }
.nav-links a{
  font-size:14.5px; font-weight:600; color:var(--ink-soft);
  padding:9px 16px; border-radius:40px; position:relative;
  transition:color .25s, background .25s;
}
.nav-links a::after{
  content:""; position:absolute; left:50%; bottom:4px;
  width:0; height:2px; background:var(--gold);
  transform:translateX(-50%); transition:width .3s var(--ease);
}
.nav-links a:hover{ color:var(--carmine); }
.nav-links a:hover::after{ width:18px; }

.nav-actions{ display:flex; align-items:center; gap:14px; }
.nav-cta{ padding:11px 24px; font-size:14px; }

.burger{
  display:none; width:44px; height:44px; border:none; background:transparent;
  cursor:pointer; flex-direction:column; gap:5px; align-items:center; justify-content:center;
}
.burger span{
  width:24px; height:2px; background:var(--ink); border-radius:2px;
  transition:transform .35s var(--ease), opacity .25s;
}
.burger.open span:nth-child(1){ transform:translateY(7px) rotate(45deg); }
.burger.open span:nth-child(2){ opacity:0; }
.burger.open span:nth-child(3){ transform:translateY(-7px) rotate(-45deg); }

/* mobile drawer */
.drawer{
  position:fixed; inset:0; z-index:999;
  background:rgba(26,15,8,.55); backdrop-filter:blur(6px);
  opacity:0; pointer-events:none; transition:opacity .35s;
}
.drawer.open{ opacity:1; pointer-events:auto; }
.drawer-panel{
  position:absolute; right:0; top:0; height:100%;
  width:min(330px,84vw);
  background:var(--cream-soft);
  padding:100px 34px 40px;
  transform:translateX(100%);
  transition:transform .45s var(--ease);
  box-shadow:var(--sh-lg);
  display:flex; flex-direction:column; gap:6px;
}
.drawer.open .drawer-panel{ transform:translateX(0); }
.drawer-panel a{
  font-family:var(--display); font-size:1.5rem; font-weight:600;
  padding:13px 4px; border-bottom:1px solid var(--line-soft);
  color:var(--ink); transition:color .2s, padding-left .25s;
}
.drawer-panel a:hover{ color:var(--carmine); padding-left:10px; }
.drawer-panel .btn{ margin-top:22px; }

/* ============================================================
   HERO
   ============================================================ */
.hero{
  position:relative; min-height:100svh;
  display:flex; align-items:center;
  padding-top:120px; padding-bottom:60px;
  background:
    radial-gradient(900px 600px at 88% 12%, rgba(201,150,46,.16), transparent 70%),
    radial-gradient(700px 500px at 6% 90%, rgba(139,30,30,.12), transparent 70%),
    var(--cream);
  overflow:hidden;
}
.hero-grid{
  display:grid; grid-template-columns:1.05fr .95fr;
  gap:clamp(30px,5vw,80px); align-items:center; width:100%;
}
.hero-badge{
  display:inline-flex; align-items:center; gap:9px;
  background:var(--paper);
  border:1px solid var(--line);
  padding:8px 16px 8px 9px; border-radius:60px;
  font-size:12.5px; font-weight:700; color:var(--ink-soft);
  box-shadow:var(--sh-sm); margin-bottom:26px;
}
.hero-badge .dot{
  width:24px; height:24px; border-radius:50%;
  background:linear-gradient(135deg,var(--carmine),var(--gold));
  display:grid; place-items:center;
}
.hero-badge .dot svg{ width:13px; height:13px; color:#fff; }
.hero h1{
  font-size:clamp(2.7rem,6.4vw,5.1rem);
  color:var(--ink); letter-spacing:-.02em;
}
.hero h1 em{
  color:var(--carmine); position:relative; white-space:nowrap;
}
.hero h1 em::after{
  content:""; position:absolute; left:0; right:0; bottom:.06em;
  height:.16em; background:linear-gradient(90deg,var(--gold),var(--rust));
  border-radius:4px; opacity:.55; transform:scaleX(0);
  transform-origin:left; animation:underline 1s var(--ease) .9s forwards;
}
@keyframes underline{ to{ transform:scaleX(1); } }
.hero p.lead{
  margin-top:24px; max-width:480px;
  font-size:1.08rem; color:var(--ink-soft); line-height:1.8;
}
.hero-btns{ display:flex; gap:14px; margin-top:34px; flex-wrap:wrap; }
.hero-stats{
  display:flex; gap:clamp(20px,4vw,44px); margin-top:46px;
  padding-top:32px; border-top:1px solid var(--line);
}
.hero-stat .num{
  font-family:var(--display); font-size:2.5rem; font-weight:700;
  color:var(--carmine); line-height:1;
}
.hero-stat .num small{ font-size:1.4rem; color:var(--gold); }
.hero-stat .lbl{ font-size:12.5px; color:var(--gray); margin-top:6px; font-weight:600; }

/* hero visual */
.hero-visual{ position:relative; }
.hero-frame{
  position:relative; border-radius:var(--radius);
  overflow:hidden; aspect-ratio:4/4.4;
  box-shadow:var(--sh-lg);
  border:7px solid var(--paper);
  outline:1px solid var(--line);
}
.hero-frame img{
  width:100%; height:100%; object-fit:cover;
  transform:scale(1.04); transition:transform 1.4s var(--ease);
}
.hero-frame:hover img{ transform:scale(1.11); }
.hero-frame::after{
  content:""; position:absolute; inset:0;
  background:linear-gradient(180deg,transparent 55%,rgba(26,15,8,.45));
}
.hero-tag{
  position:absolute; left:18px; bottom:18px; z-index:2;
  background:rgba(246,239,226,.92); backdrop-filter:blur(8px);
  border-radius:14px; padding:13px 18px;
  display:flex; align-items:center; gap:12px;
  box-shadow:var(--sh-md);
}
.hero-tag .ic{
  width:38px; height:38px; border-radius:10px; display:grid; place-items:center;
  background:linear-gradient(135deg,var(--carmine),var(--gold)); color:#fff;
}
.hero-tag .ic svg{ width:18px; height:18px; }
.hero-tag b{ font-family:var(--display); font-size:1.05rem; display:block; line-height:1.2; }
.hero-tag span{ font-size:11.5px; color:var(--gray); }

.hero-float{
  position:absolute; top:26px; right:-26px; z-index:3;
  background:var(--paper); border-radius:16px;
  padding:14px 18px; box-shadow:var(--sh-lg);
  display:flex; align-items:center; gap:12px;
  animation:floaty 4.5s ease-in-out infinite;
}
@keyframes floaty{ 50%{ transform:translateY(-12px); } }
.hero-float .stars{ color:var(--gold); font-size:13px; letter-spacing:1px; }
.hero-float b{ font-family:var(--display); font-size:1.35rem; line-height:1; }
.hero-float span{ font-size:11px; color:var(--gray); }

.hero-medallion{
  position:absolute; left:-44px; bottom:8%; z-index:3;
  width:108px; height:108px;
  animation:spin 38s linear infinite;
  filter:drop-shadow(0 10px 22px rgba(42,24,16,.28));
}
@keyframes spin{ to{ transform:rotate(360deg); } }

.scroll-cue{
  position:absolute; left:50%; bottom:26px; transform:translateX(-50%);
  display:flex; flex-direction:column; align-items:center; gap:7px;
  font-size:10.5px; letter-spacing:.2em; text-transform:uppercase; color:var(--gray);
}
.scroll-cue .line{
  width:1.5px; height:42px;
  background:linear-gradient(var(--gold),transparent);
  position:relative; overflow:hidden;
}
.scroll-cue .line::after{
  content:""; position:absolute; top:0; left:0; width:100%; height:40%;
  background:var(--carmine); animation:scrolldot 1.8s var(--ease) infinite;
}
@keyframes scrolldot{ to{ transform:translateY(250%); } }

/* ============================================================
   MARQUEE / PATTERN STRIP
   ============================================================ */
.marquee{
  background:linear-gradient(135deg,var(--espresso),var(--ink));
  padding:18px 0; overflow:hidden; position:relative;
}
.marquee::before,.marquee::after{
  content:""; position:absolute; top:0; bottom:0; width:120px; z-index:2;
}
.marquee::before{ left:0; background:linear-gradient(90deg,var(--espresso),transparent); }
.marquee::after{ right:0; background:linear-gradient(-90deg,var(--espresso),transparent); }
.marquee-track{
  display:flex; gap:46px; width:max-content;
  animation:marquee 60s linear infinite;
}
.marquee:hover .marquee-track{ animation-play-state:paused; }
@keyframes marquee{ to{ transform:translateX(-50%); } }
.marquee-item{
  display:flex; align-items:center; gap:14px;
  font-family:var(--display); font-size:1.35rem; color:var(--gold-pale);
  white-space:nowrap;
}
.marquee-item svg{ width:18px; height:18px; color:var(--carmine); flex-shrink:0; }
.marquee-item.muted{ color:rgba(240,216,154,.4); }

/* ============================================================
   ABOUT
   ============================================================ */
.about{ background:var(--cream); }
.about-grid{
  display:grid; grid-template-columns:1fr 1.05fr;
  gap:clamp(36px,6vw,84px); align-items:center;
}
.about-visual{ position:relative; }
.about-img-main{
  border-radius:var(--radius); overflow:hidden;
  aspect-ratio:5/6; box-shadow:var(--sh-lg);
  border:7px solid var(--paper); outline:1px solid var(--line);
}
.about-img-main img{ width:100%; height:100%; object-fit:cover; }
.about-img-sub{
  position:absolute; right:-28px; bottom:-34px;
  width:46%; border-radius:18px; overflow:hidden;
  aspect-ratio:1/1; box-shadow:var(--sh-lg);
  border:6px solid var(--paper);
}
.about-img-sub img{ width:100%; height:100%; object-fit:cover; }
.about-exp{
  position:absolute; left:-30px; top:34px;
  background:linear-gradient(135deg,var(--carmine),var(--carmine-deep));
  color:var(--cream-soft); border-radius:18px;
  padding:20px 24px; box-shadow:var(--sh-lg); text-align:center;
}
.about-exp b{ font-family:var(--display); font-size:2.6rem; line-height:1; color:var(--gold-light); }
.about-exp span{ font-size:11.5px; display:block; margin-top:4px; letter-spacing:.05em; }

.about-feats{
  display:grid; grid-template-columns:1fr 1fr;
  gap:14px; margin-top:30px;
}
.feat{
  display:flex; gap:13px; align-items:flex-start;
  background:var(--paper); border:1px solid var(--line-soft);
  border-radius:14px; padding:15px 16px;
  transition:transform .35s var(--ease), box-shadow .35s var(--ease), border-color .3s;
}
.feat:hover{ transform:translateY(-4px); box-shadow:var(--sh-md); border-color:var(--gold); }
.feat .fic{
  width:40px; height:40px; flex-shrink:0; border-radius:11px;
  display:grid; place-items:center;
  background:linear-gradient(135deg,rgba(201,150,46,.18),rgba(139,30,30,.12));
  color:var(--carmine);
}
.feat .fic svg{ width:19px; height:19px; }
.feat p{ font-size:13.5px; font-weight:600; color:var(--ink-soft); line-height:1.45; }

/* ============================================================
   PROCESS
   ============================================================ */
.process{
  background:linear-gradient(160deg,var(--espresso),var(--ink) 60%);
  color:var(--cream); position:relative; overflow:hidden;
}
.process .pattern-bg{ opacity:.06; }
.process-grid{
  display:grid; grid-template-columns:repeat(4,1fr);
  gap:22px; margin-top:54px;
}
.pstep{
  position:relative; padding:30px 24px;
  background:rgba(246,239,226,.04);
  border:1px solid rgba(246,239,226,.09);
  border-radius:var(--radius-sm);
  transition:transform .4s var(--ease), background .35s, border-color .35s;
}
.pstep:hover{
  transform:translateY(-8px);
  background:rgba(246,239,226,.07);
  border-color:rgba(229,184,75,.4);
}
.pstep .pnum{
  font-family:var(--display); font-size:3.4rem; font-weight:700;
  color:rgba(229,184,75,.22); line-height:.8;
}
.pstep .pic{
  width:48px; height:48px; border-radius:13px; margin:16px 0 14px;
  display:grid; place-items:center;
  background:linear-gradient(135deg,var(--carmine),var(--gold));
  color:#fff;
}
.pstep .pic svg{ width:23px; height:23px; }
.pstep h3{ font-size:1.32rem; color:var(--cream); }
.pstep p{ font-size:13.5px; color:rgba(246,239,226,.6); margin-top:8px; line-height:1.7; }
.pstep .pline{
  position:absolute; top:48px; right:-13px; width:26px; height:1.5px;
  background:linear-gradient(90deg,var(--gold),transparent); z-index:2;
}
.pstep:last-child .pline{ display:none; }

/* ============================================================
   PRODUCTS
   ============================================================ */
.products{ background:var(--cream); }
.products-top{
  display:flex; justify-content:space-between; align-items:flex-end;
  gap:30px; flex-wrap:wrap; margin-bottom:14px;
}
.filter-bar{
  display:flex; gap:8px; flex-wrap:wrap; margin:30px 0 40px;
}
.filter-btn{
  padding:9px 19px; border-radius:40px;
  border:1.5px solid var(--line); background:var(--paper);
  font-size:13px; font-weight:700; color:var(--ink-soft);
  cursor:pointer; transition:all .3s var(--ease);
}
.filter-btn:hover{ border-color:var(--gold); color:var(--carmine); }
.filter-btn.active{
  background:linear-gradient(135deg,var(--carmine),var(--carmine-deep));
  color:var(--cream-soft); border-color:transparent;
  box-shadow:0 10px 22px -10px rgba(139,30,30,.6);
}

.products-grid{
  display:grid; grid-template-columns:repeat(auto-fill,minmax(290px,1fr));
  gap:26px;
}
.pcard{
  background:var(--paper); border-radius:var(--radius);
  overflow:hidden; border:1px solid var(--line-soft);
  box-shadow:var(--sh-sm);
  transition:transform .5s var(--ease), box-shadow .5s var(--ease), border-color .35s;
  display:flex; flex-direction:column;
}
.pcard:hover{
  transform:translateY(-10px);
  box-shadow:var(--sh-lg);
  border-color:var(--gold);
}
.pcard-media{
  position:relative; aspect-ratio:4/3.2; overflow:hidden;
}
.pcard-media .pc-emoji{
  position:absolute; inset:0; display:grid; place-items:center;
  font-size:4.5rem;
}
.pcard-media img{
  width:100%; height:100%; object-fit:cover;
  transition:transform 1s var(--ease);
}
.pcard:hover .pcard-media img{ transform:scale(1.1); }
.pcard-media::after{
  content:""; position:absolute; inset:0;
  background:linear-gradient(180deg,transparent 60%,rgba(26,15,8,.3));
  opacity:0; transition:opacity .4s;
}
.pcard:hover .pcard-media::after{ opacity:1; }
.pc-cat{
  position:absolute; top:14px; left:14px; z-index:2;
  background:rgba(246,239,226,.92); backdrop-filter:blur(6px);
  font-size:11px; font-weight:700; letter-spacing:.04em;
  padding:6px 13px; border-radius:30px; color:var(--carmine);
}
.pc-fav{
  position:absolute; top:12px; right:12px; z-index:2;
  width:36px; height:36px; border-radius:50%;
  background:rgba(246,239,226,.92); backdrop-filter:blur(6px);
  border:none; cursor:pointer; display:grid; place-items:center;
  color:var(--ink-soft); transition:transform .3s var(--ease), color .25s, background .25s;
}
.pc-fav svg{ width:17px; height:17px; }
.pc-fav:hover{ transform:scale(1.15); color:#fff; background:var(--carmine); }
.pc-fav.active{ color:#fff; background:var(--carmine); }
.pc-fav.active svg{ fill:currentColor; }

.pcard-body{ padding:20px 22px 22px; display:flex; flex-direction:column; flex:1; }
.pc-rating{
  display:flex; align-items:center; gap:6px;
  font-size:12px; color:var(--gray); margin-bottom:8px;
}
.pc-rating .stars{ color:var(--gold); letter-spacing:1px; }
.pcard-body h3{ font-size:1.32rem; color:var(--ink); line-height:1.25; }
.pcard-body p{
  font-size:13.5px; color:var(--gray); margin-top:8px; line-height:1.65; flex:1;
}
.pc-foot{
  display:flex; align-items:center; justify-content:space-between;
  margin-top:18px; padding-top:16px; border-top:1px solid var(--line-soft);
}
.pc-price b{ font-family:var(--display); font-size:1.5rem; color:var(--carmine); }
.pc-price span{ font-size:11px; color:var(--gray); display:block; }
.pc-buy{
  width:44px; height:44px; border-radius:13px; border:none; cursor:pointer;
  background:linear-gradient(135deg,var(--carmine),var(--carmine-deep));
  color:var(--cream-soft); display:grid; place-items:center;
  transition:transform .3s var(--ease), box-shadow .3s;
}
.pc-buy svg{ width:19px; height:19px; }
.pc-buy:hover{ transform:translateY(-3px) rotate(-6deg); box-shadow:var(--sh-gold); }

/* skeletons */
.pcard-skel{
  background:var(--paper); border-radius:var(--radius);
  overflow:hidden; border:1px solid var(--line-soft); height:430px;
}
.skel-media{ height:62%; background:var(--beige); }
.skel-body{ padding:20px 22px; }
.skel-line{
  height:13px; border-radius:7px; background:var(--beige);
  margin-bottom:11px;
}
.skel-line.w70{ width:70%; } .skel-line.w40{ width:40%; }
.shimmer{ position:relative; overflow:hidden; }
.shimmer::after{
  content:""; position:absolute; inset:0;
  background:linear-gradient(90deg,transparent,rgba(255,255,255,.6),transparent);
  transform:translateX(-100%); animation:shimmer 1.5s infinite;
}
@keyframes shimmer{ to{ transform:translateX(100%); } }

.products-empty,.products-error{
  grid-column:1/-1; text-align:center; padding:56px 20px; color:var(--gray);
}
.products-empty svg,.products-error svg{
  width:48px; height:48px; color:var(--beige-deep); margin-bottom:14px;
}

/* ============================================================
   GALLERY (masonry)
   ============================================================ */
.gallery{ background:var(--cream-soft); }
.masonry{
  columns:3; column-gap:18px; margin-top:48px;
}
.gphoto{
  break-inside:avoid; margin-bottom:18px;
  border-radius:18px; overflow:hidden; position:relative;
  cursor:pointer; box-shadow:var(--sh-sm);
  border:1px solid var(--line-soft);
  transition:transform .5s var(--ease), box-shadow .5s var(--ease);
}
.gphoto img{ width:100%; transition:transform 1s var(--ease); }
.gphoto:hover{ transform:translateY(-6px); box-shadow:var(--sh-lg); }
.gphoto:hover img{ transform:scale(1.08); }
.gphoto-ov{
  position:absolute; inset:0;
  background:linear-gradient(180deg,transparent 50%,rgba(26,15,8,.78));
  opacity:0; transition:opacity .4s;
  display:flex; flex-direction:column; justify-content:flex-end;
  padding:22px; color:var(--cream);
}
.gphoto:hover .gphoto-ov{ opacity:1; }
.gphoto-ov .gp-cat{
  font-size:11px; letter-spacing:.18em; text-transform:uppercase;
  color:var(--gold-light); font-weight:700;
}
.gphoto-ov h4{ font-size:1.3rem; margin-top:4px; }
.gphoto-ov .gp-zoom{
  position:absolute; top:18px; right:18px;
  width:40px; height:40px; border-radius:50%;
  background:rgba(246,239,226,.95); display:grid; place-items:center;
  color:var(--carmine); transform:scale(.6); transition:transform .4s var(--ease);
}
.gphoto:hover .gp-zoom{ transform:scale(1); }
.gp-zoom svg{ width:18px; height:18px; }

/* lightbox */
.lightbox{
  position:fixed; inset:0; z-index:2000;
  background:rgba(15,8,4,.95); backdrop-filter:blur(8px);
  display:flex; align-items:center; justify-content:center;
  opacity:0; pointer-events:none; transition:opacity .35s;
  padding:30px;
}
.lightbox.open{ opacity:1; pointer-events:auto; }
.lightbox img{
  max-width:90vw; max-height:82vh; border-radius:14px;
  box-shadow:var(--sh-lg); border:5px solid var(--paper);
  transform:scale(.9); transition:transform .4s var(--ease);
}
.lightbox.open img{ transform:scale(1); }
.lb-close,.lb-nav{
  position:absolute; background:rgba(246,239,226,.12);
  border:1px solid rgba(246,239,226,.2); color:var(--cream);
  cursor:pointer; display:grid; place-items:center;
  border-radius:50%; transition:background .25s, transform .25s;
}
.lb-close{ top:26px; right:26px; width:50px; height:50px; }
.lb-nav{ top:50%; transform:translateY(-50%); width:54px; height:54px; }
.lb-nav.prev{ left:26px; } .lb-nav.next{ right:26px; }
.lb-close:hover,.lb-nav:hover{ background:var(--carmine); }
.lb-close svg,.lb-nav svg{ width:22px; height:22px; }
.lb-caption{
  position:absolute; bottom:26px; left:50%; transform:translateX(-50%);
  color:var(--gold-pale); font-family:var(--display); font-size:1.2rem;
}

/* ============================================================
   SERVICES
   ============================================================ */
.services{ background:var(--cream); }
.services-grid{
  display:grid; grid-template-columns:repeat(3,1fr);
  gap:24px; margin-top:50px;
}
.scard{
  position:relative; padding:38px 30px;
  background:var(--paper); border-radius:var(--radius);
  border:1px solid var(--line-soft); overflow:hidden;
  transition:transform .5s var(--ease), box-shadow .5s var(--ease);
}
.scard::before{
  content:""; position:absolute; left:0; top:0; right:0; height:4px;
  background:linear-gradient(90deg,var(--carmine),var(--gold));
  transform:scaleX(0); transform-origin:left;
  transition:transform .5s var(--ease);
}
.scard:hover{ transform:translateY(-10px); box-shadow:var(--sh-lg); }
.scard:hover::before{ transform:scaleX(1); }
.scard .sic{
  width:62px; height:62px; border-radius:17px;
  display:grid; place-items:center; margin-bottom:22px;
  background:linear-gradient(135deg,rgba(139,30,30,.12),rgba(201,150,46,.16));
  color:var(--carmine); transition:transform .5s var(--ease);
}
.scard:hover .sic{ transform:rotate(-8deg) scale(1.08); }
.scard .sic svg{ width:28px; height:28px; }
.scard h3{ font-size:1.5rem; color:var(--ink); }
.scard p{ font-size:14px; color:var(--gray); margin-top:10px; line-height:1.75; }
.scard ul{ margin-top:16px; display:flex; flex-direction:column; gap:8px; }
.scard ul li{
  font-size:13px; color:var(--ink-soft); display:flex; gap:9px; align-items:center;
}
.scard ul li svg{ width:15px; height:15px; color:var(--gold); flex-shrink:0; }
.scard .snum{
  position:absolute; top:24px; right:26px;
  font-family:var(--display); font-size:1.5rem; font-weight:700;
  color:var(--beige-deep);
}

/* ============================================================
   TESTIMONIALS
   ============================================================ */
.testimonials{
  background:linear-gradient(160deg,var(--ink),var(--espresso));
  color:var(--cream); position:relative; overflow:hidden;
}
.testimonials .pattern-bg{ opacity:.05; }
.tslider{ margin-top:50px; position:relative; }
.ttrack{ overflow:hidden; }
.tslides{ display:flex; transition:transform .6s var(--ease); }
.tslide{ min-width:100%; padding:0 4px; }
.tcard{
  max-width:780px; margin-inline:auto; text-align:center;
  background:rgba(246,239,226,.05);
  border:1px solid rgba(246,239,226,.1);
  border-radius:var(--radius); padding:clamp(34px,5vw,56px);
}
.tcard .quote-mark{
  font-family:var(--display); font-size:5rem; line-height:.4;
  color:var(--gold); height:38px;
}
.tcard .ttext{
  font-family:var(--display); font-size:clamp(1.25rem,2.6vw,1.7rem);
  line-height:1.55; color:var(--cream); font-style:italic;
}
.tcard .tstars{ color:var(--gold); font-size:15px; letter-spacing:3px; margin:22px 0 18px; }
.tperson{ display:flex; align-items:center; justify-content:center; gap:14px; }
.tperson .tav{
  width:54px; height:54px; border-radius:50%;
  display:grid; place-items:center; font-family:var(--display);
  font-size:1.4rem; font-weight:700; color:var(--espresso);
  background:linear-gradient(135deg,var(--gold-light),var(--gold));
}
.tperson .tinfo{ text-align:left; }
.tperson .tinfo b{ font-family:var(--display); font-size:1.1rem; color:var(--cream); }
.tperson .tinfo span{ font-size:12px; color:rgba(246,239,226,.55); }
.tnav{ display:flex; align-items:center; justify-content:center; gap:18px; margin-top:34px; }
.tnav button{
  width:48px; height:48px; border-radius:50%;
  background:rgba(246,239,226,.07); border:1px solid rgba(246,239,226,.18);
  color:var(--cream); cursor:pointer; display:grid; place-items:center;
  transition:background .25s, transform .25s;
}
.tnav button:hover{ background:var(--carmine); transform:scale(1.08); }
.tnav button svg{ width:18px; height:18px; }
.tdots{ display:flex; gap:8px; }
.tdot{
  width:8px; height:8px; border-radius:50%;
  background:rgba(246,239,226,.22); border:none; cursor:pointer;
  transition:all .3s var(--ease);
}
.tdot.active{ width:26px; border-radius:5px; background:var(--gold); }

/* ============================================================
   CONTACT
   ============================================================ */
.contact{ background:var(--cream-soft); }
.contact-grid{
  display:grid; grid-template-columns:1fr 1.1fr;
  gap:clamp(30px,5vw,64px); margin-top:48px;
  align-items:start;
}
.contact-cards{ display:flex; flex-direction:column; gap:14px; margin-top:30px; }
.ccard{
  display:flex; gap:16px; align-items:center;
  background:var(--paper); border:1px solid var(--line-soft);
  border-radius:16px; padding:18px 20px;
  transition:transform .35s var(--ease), box-shadow .35s, border-color .3s;
}
.ccard:hover{ transform:translateX(6px); box-shadow:var(--sh-md); border-color:var(--gold); }
.ccard .cic{
  width:48px; height:48px; flex-shrink:0; border-radius:13px;
  display:grid; place-items:center; color:#fff;
  background:linear-gradient(135deg,var(--carmine),var(--carmine-deep));
}
.ccard .cic svg{ width:21px; height:21px; }
.ccard .cinfo small{ font-size:11px; letter-spacing:.12em; text-transform:uppercase; color:var(--gray); font-weight:700; }
.ccard .cinfo b{ display:block; font-size:15px; color:var(--ink); margin-top:3px; }

.contact-socials{ display:flex; gap:10px; margin-top:20px; }
.contact-socials a{
  width:46px; height:46px; border-radius:13px;
  display:grid; place-items:center;
  background:var(--paper); border:1px solid var(--line);
  color:var(--ink-soft);
  transition:transform .3s var(--ease), background .3s, color .3s, border-color .3s;
}
.contact-socials a svg{ width:20px; height:20px; }
.contact-socials a:hover{
  transform:translateY(-4px); color:#fff;
  background:linear-gradient(135deg,var(--carmine),var(--gold));
  border-color:transparent;
}

/* form */
.cform{
  background:var(--paper); border-radius:var(--radius);
  padding:clamp(28px,4vw,44px);
  border:1px solid var(--line-soft); box-shadow:var(--sh-md);
  position:relative; overflow:hidden;
}
.cform::before{
  content:""; position:absolute; top:0; left:0; right:0; height:5px;
  background:linear-gradient(90deg,var(--carmine),var(--gold),var(--carmine));
}
.cform h3{ font-size:1.7rem; color:var(--ink); }
.cform .cform-sub{ font-size:13.5px; color:var(--gray); margin:6px 0 26px; }
.fgroup{ margin-bottom:18px; }
.fgroup label{
  display:block; font-size:12.5px; font-weight:700;
  color:var(--ink-soft); margin-bottom:7px;
}
.fgroup label span{ color:var(--carmine); }
.fctrl{
  width:100%; padding:13px 16px;
  background:var(--cream-soft);
  border:1.5px solid var(--line); border-radius:12px;
  font-size:14.5px; transition:border-color .25s, box-shadow .25s, background .25s;
}
.fctrl::placeholder{ color:var(--beige-deep); }
.fctrl:focus{
  outline:none; border-color:var(--carmine);
  background:var(--paper);
  box-shadow:0 0 0 4px rgba(139,30,30,.08);
}
textarea.fctrl{ resize:vertical; min-height:108px; font-family:var(--body); }
.cform .btn{ width:100%; margin-top:6px; }
.fresult{
  margin-top:16px; padding:13px 16px; border-radius:12px;
  font-size:13.5px; font-weight:600; display:none;
}
.fresult.show{ display:block; animation:fadeUp .4s var(--ease); }
.fresult.ok{ background:rgba(59,84,54,.12); color:var(--forest); border:1px solid rgba(59,84,54,.25); }
.fresult.err{ background:rgba(139,30,30,.1); color:var(--carmine); border:1px solid rgba(139,30,30,.25); }
@keyframes fadeUp{ from{ opacity:0; transform:translateY(8px); } }

.map-wrap{
  margin-top:46px; border-radius:var(--radius); overflow:hidden;
  border:7px solid var(--paper); outline:1px solid var(--line);
  box-shadow:var(--sh-md); height:340px;
}
.map-wrap iframe{ width:100%; height:100%; border:0; filter:saturate(1.05); }

/* ============================================================
   FOOTER
   ============================================================ */
.footer{
  background:linear-gradient(180deg,var(--ink),var(--espresso));
  color:var(--cream); position:relative; overflow:hidden;
  padding-top:72px;
}
.footer .pattern-bg{ opacity:.045; }
.footer-grid{
  display:grid; grid-template-columns:1.6fr 1fr 1fr 1.2fr;
  gap:44px; padding-bottom:50px;
  border-bottom:1px solid rgba(246,239,226,.1);
}
.footer-brand .brand-name{ color:var(--cream); }
.footer-brand .brand-name b{ color:var(--gold-light); }
.footer-brand .brand-tag{ color:rgba(246,239,226,.5); }
.footer-brand p{
  font-size:13.5px; color:rgba(246,239,226,.6);
  margin-top:18px; max-width:300px; line-height:1.8;
}
.footer-col h4{
  font-family:var(--body); font-size:13px; font-weight:800;
  letter-spacing:.14em; text-transform:uppercase;
  color:var(--gold-light); margin-bottom:18px;
}
.footer-col ul{ display:flex; flex-direction:column; gap:11px; }
.footer-col ul a{
  font-size:13.5px; color:rgba(246,239,226,.62);
  transition:color .25s, padding-left .25s;
}
.footer-col ul a:hover{ color:var(--gold-light); padding-left:6px; }
.footer-news p{ font-size:13.5px; color:rgba(246,239,226,.6); margin-bottom:14px; }
.news-field{ display:flex; gap:8px; }
.news-field input{
  flex:1; padding:11px 14px; border-radius:11px;
  background:rgba(246,239,226,.07); border:1px solid rgba(246,239,226,.15);
  color:var(--cream); font-size:13px;
}
.news-field input::placeholder{ color:rgba(246,239,226,.4); }
.news-field input:focus{ outline:none; border-color:var(--gold); }
.news-field button{
  width:46px; border-radius:11px; border:none; cursor:pointer;
  background:linear-gradient(135deg,var(--carmine),var(--gold));
  color:#fff; display:grid; place-items:center;
  transition:transform .25s;
}
.news-field button:hover{ transform:scale(1.06); }
.news-field button svg{ width:18px; height:18px; }
.footer-social{ display:flex; gap:10px; margin-top:20px; }
.footer-social a{
  width:42px; height:42px; border-radius:11px;
  display:grid; place-items:center;
  background:rgba(246,239,226,.06); border:1px solid rgba(246,239,226,.13);
  color:rgba(246,239,226,.7);
  transition:transform .3s var(--ease), background .3s, color .3s;
}
.footer-social a svg{ width:18px; height:18px; }
.footer-social a:hover{
  transform:translateY(-4px); color:#fff;
  background:linear-gradient(135deg,var(--carmine),var(--gold));
}
.footer-bottom{
  display:flex; justify-content:space-between; align-items:center;
  flex-wrap:wrap; gap:14px; padding:26px 0;
  font-size:12.5px; color:rgba(246,239,226,.5);
}
.footer-bottom a{ color:var(--gold-light); }
.footer-bottom .heart{ color:var(--carmine); }

/* ============================================================
   ORNAMENT PATTERN (decorative background)
   ============================================================ */
.pattern-bg{
  position:absolute; inset:0; z-index:0; pointer-events:none;
  background-repeat:repeat;
  background-size:120px 120px;
}
.section > .container,
.process > .container,
.testimonials > .container,
.footer > .container{ position:relative; z-index:1; }

/* ============================================================
   PAGE LOADER
   ============================================================ */
.loader{
  position:fixed; inset:0; z-index:5000;
  background:var(--espresso);
  display:flex; flex-direction:column; align-items:center; justify-content:center;
  gap:26px; transition:opacity .6s var(--ease), visibility .6s;
}
.loader.hide{ opacity:0; visibility:hidden; }
.loader-mark{
  width:90px; height:90px; position:relative;
}
.loader-mark svg{
  width:100%; height:100%; color:var(--gold);
  animation:loaderSpin 2.4s var(--ease) infinite;
}
@keyframes loaderSpin{
  0%{ transform:rotate(0) scale(.85); opacity:.5; }
  50%{ transform:rotate(180deg) scale(1); opacity:1; }
  100%{ transform:rotate(360deg) scale(.85); opacity:.5; }
}
.loader-name{
  font-family:var(--display); font-size:2rem; color:var(--cream);
  letter-spacing:.04em;
}
.loader-name b{ color:var(--gold-light); }
.loader-bar{
  width:180px; height:3px; border-radius:3px;
  background:rgba(246,239,226,.12); overflow:hidden;
}
.loader-bar i{
  display:block; height:100%; width:40%;
  background:linear-gradient(90deg,var(--carmine),var(--gold));
  animation:loaderBar 1.3s var(--ease) infinite;
}
@keyframes loaderBar{
  0%{ transform:translateX(-100%); }
  100%{ transform:translateX(350%); }
}

/* ============================================================
   SCROLL REVEAL (custom AOS-style)
   ============================================================ */
[data-reveal]{
  opacity:0; transform:translateY(40px);
  transition:opacity .8s var(--ease), transform .8s var(--ease);
}
[data-reveal="left"]{ transform:translateX(-50px); }
[data-reveal="right"]{ transform:translateX(50px); }
[data-reveal="scale"]{ transform:scale(.92); }
[data-reveal].in{ opacity:1; transform:none; }
[data-delay="1"]{ transition-delay:.1s; }
[data-delay="2"]{ transition-delay:.2s; }
[data-delay="3"]{ transition-delay:.3s; }
[data-delay="4"]{ transition-delay:.4s; }

/* back to top */
.to-top{
  position:fixed; right:24px; bottom:24px; z-index:900;
  width:50px; height:50px; border-radius:50%;
  background:linear-gradient(135deg,var(--carmine),var(--carmine-deep));
  color:var(--cream-soft); border:none; cursor:pointer;
  display:grid; place-items:center;
  box-shadow:var(--sh-md);
  opacity:0; transform:translateY(20px) scale(.8); pointer-events:none;
  transition:opacity .35s var(--ease), transform .35s var(--ease), box-shadow .3s;
}
.to-top.show{ opacity:1; transform:none; pointer-events:auto; }
.to-top:hover{ box-shadow:var(--sh-gold); transform:translateY(-3px); }
.to-top svg{ width:20px; height:20px; }

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media (max-width:1080px){
  .hero-grid{ grid-template-columns:1fr; gap:54px; }
  .hero-visual{ max-width:480px; margin-inline:auto; }
  .hero-medallion{ width:84px; left:-20px; }
  .hero-float{ right:-10px; }
  .about-grid{ grid-template-columns:1fr; gap:70px; }
  .about-img-sub{ right:0; }
  .process-grid{ grid-template-columns:repeat(2,1fr); }
  .pstep .pline{ display:none; }
  .services-grid{ grid-template-columns:1fr; max-width:480px; margin-inline:auto; }
  .contact-grid{ grid-template-columns:1fr; }
  .masonry{ columns:2; }
  .footer-grid{ grid-template-columns:1fr 1fr; gap:34px; }
}
@media (max-width:760px){
  .nav-links,.nav-cta{ display:none; }
  .burger{ display:flex; }
  .hero{ padding-top:108px; }
  .hero-stats{ gap:20px; flex-wrap:wrap; }
  .hero-stat .num{ font-size:2rem; }
  .about-feats{ grid-template-columns:1fr; }
  .process-grid{ grid-template-columns:1fr; }
  .masonry{ columns:1; }
  .footer-grid{ grid-template-columns:1fr; }
  .footer-bottom{ flex-direction:column; text-align:center; }
  .sec-title{ font-size:2rem; }
  .lb-nav{ width:44px; height:44px; }
  .lb-nav.prev{ left:10px; } .lb-nav.next{ right:10px; }
}
@media (max-width:440px){
  .container{ padding-inline:18px; }
  .hero h1{ font-size:2.4rem; }
  .hero-btns{ flex-direction:column; }
  .hero-btns .btn{ width:100%; }
  .products-grid{ grid-template-columns:1fr; }
}

/* reduce motion */
@media (prefers-reduced-motion:reduce){
  *,*::before,*::after{
    animation-duration:.01ms !important;
    transition-duration:.01ms !important;
    scroll-behavior:auto !important;
  }
  [data-reveal]{ opacity:1; transform:none; }
}