/* =========================================================
   ALFANAR — Interior Furniture & Bathroom Fittings
   Clean White / Aqua / Soft Gray design system
   ========================================================= */
:root{
  --charcoal:#18242f;
  --charcoal-2:#273746;
  --copper:#27c7bd;
  --copper-2:#76e3dc;
  --copper-deep:#07958e;
  --ivory:#ffffff;
  --ivory-2:#f4fbfb;
  --mist:#e5f2f2;
  --clay:#dff7f5;
  --olive:#27c7bd;
  --bronze:#07958e;
  --smoke:rgba(24,36,47,.46);
  --line:rgba(24,36,47,.10);
  --product-bg:#f8fcfc;
  --radius-lg:22px;
  --radius-md:14px;
  --shadow-soft:0 18px 50px -30px rgba(24,36,47,.22);
  --shadow-card:0 24px 58px -34px rgba(24,36,47,.28);
  --serif:Arial,Calibri,Helvetica,sans-serif;
  --sans:Arial,Calibri,Helvetica,sans-serif;
  --mono:Arial,Calibri,Helvetica,sans-serif;
}
*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{
  font-family:var(--sans);
  color:var(--charcoal);
  background:var(--ivory);
  line-height:1.55;
  -webkit-font-smoothing:antialiased;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
h1,h2,h3,h4{font-family:var(--serif);font-weight:500;letter-spacing:-.01em;color:var(--charcoal)}
h1{font-size:clamp(2.4rem,5vw,4.6rem);line-height:1.05}
h2{font-size:clamp(1.9rem,3.5vw,3rem);line-height:1.1}
h3{font-size:1.4rem;line-height:1.2}
p{color:#3a342f}
.eyebrow{font-family:var(--mono);font-size:.72rem;letter-spacing:.28em;text-transform:uppercase;color:var(--copper-deep)}
.container{max-width:1240px;margin:0 auto;padding:0 28px}
.section{padding:96px 0}
.section-sm{padding:56px 0}
.divider{height:1px;background:var(--line);margin:0}

/* Header */
.site-header{
  position:sticky;top:0;z-index:50;
  backdrop-filter:saturate(140%) blur(14px);
  -webkit-backdrop-filter:saturate(140%) blur(14px);
  background:rgba(244,236,220,.78);
  border-bottom:1px solid var(--line);
}
.nav{display:flex;align-items:center;justify-content:space-between;padding:18px 0}
.brand{display:flex;align-items:baseline;gap:10px;font-family:var(--serif);font-size:1.5rem;letter-spacing:.04em}
.brand .dot{width:7px;height:7px;background:var(--copper);display:inline-block;border-radius:50%}
.brand small{font-family:var(--mono);font-size:.62rem;letter-spacing:.3em;color:var(--copper-deep);text-transform:uppercase}
.nav-links{display:flex;gap:30px;align-items:center}
.nav-links a{font-size:.92rem;color:var(--charcoal-2);position:relative;padding:6px 0}
.nav-links a:hover{color:var(--copper-deep)}
.nav-links a.active::after{content:"";position:absolute;left:0;right:0;bottom:-2px;height:2px;background:var(--copper)}
.nav-actions{display:flex;align-items:center;gap:14px}
.cart-btn{
  position:relative;display:inline-flex;align-items:center;gap:8px;
  padding:9px 16px;border-radius:999px;background:var(--charcoal);color:var(--ivory);
  font-size:.85rem;letter-spacing:.04em;transition:transform .2s, background .2s;
}
.cart-btn:hover{background:var(--copper-deep);transform:translateY(-1px)}
.cart-badge{
  position:absolute;top:-6px;right:-6px;min-width:20px;height:20px;padding:0 6px;
  background:var(--copper);color:#fff;font-size:.7rem;font-weight:600;
  border-radius:999px;display:none;align-items:center;justify-content:center;
}
.cart-badge.show{display:inline-flex}
.menu-toggle{display:none;background:none;border:0;font-size:1.6rem;color:var(--charcoal);cursor:pointer}

@media (max-width: 900px){
  .menu-toggle{display:block}
  .nav-links{
    position:absolute;top:100%;left:0;right:0;flex-direction:column;gap:0;
    background:var(--ivory);border-bottom:1px solid var(--line);padding:0;
    max-height:0;overflow:hidden;transition:max-height .35s ease;
  }
  .nav-links.open{max-height:420px;padding:8px 0 20px}
  .nav-links a{padding:14px 28px;width:100%;border-bottom:1px solid var(--line)}
}

/* Buttons */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:10px;
  padding:14px 26px;border-radius:999px;font-size:.92rem;letter-spacing:.04em;
  border:1px solid transparent;cursor:pointer;transition:all .25s ease;
  font-family:var(--sans);font-weight:500;
}
.btn-primary{background:var(--copper);color:#fff}
.btn-primary:hover{background:var(--copper-deep);transform:translateY(-2px);box-shadow:var(--shadow-soft)}
.btn-dark{background:var(--charcoal);color:var(--ivory)}
.btn-dark:hover{background:#000;transform:translateY(-2px)}
.btn-ghost{background:transparent;color:var(--charcoal);border-color:var(--charcoal)}
.btn-ghost:hover{background:var(--charcoal);color:var(--ivory)}
.btn-outline-copper{background:transparent;color:var(--copper-deep);border-color:var(--copper)}
.btn-outline-copper:hover{background:var(--copper);color:#fff}
.btn-block{width:100%}

/* Hero (Home) */
.hero{
  position:relative;overflow:hidden;
  background:linear-gradient(135deg,#1d1815 0%,#2d2520 60%,#3a2c20 100%);
  color:var(--ivory);padding:140px 0 120px;
}
.hero::before{
  content:"";position:absolute;inset:0;
  background:radial-gradient(ellipse at 80% 30%,rgba(200,145,96,.22),transparent 55%);
  pointer-events:none;
}
.hero-grid{display:grid;grid-template-columns:1.1fr .9fr;gap:60px;align-items:center;position:relative}
.hero h1{color:var(--ivory)}
.hero h1 em{font-style:italic;color:var(--copper-2)}
.hero p{color:rgba(244,236,220,.78);font-size:1.1rem;max-width:520px;margin-top:24px}
.hero-actions{margin-top:34px;display:flex;gap:14px;flex-wrap:wrap}
.hero-stats{display:flex;gap:36px;margin-top:60px}
.hero-stats div span:first-child{font-family:var(--serif);font-size:2rem;display:block;color:var(--copper-2)}
.hero-stats div span:last-child{font-family:var(--mono);font-size:.7rem;letter-spacing:.22em;text-transform:uppercase;color:rgba(244,236,220,.55)}
.hero-image{
  position:relative;border-radius:var(--radius-lg);overflow:hidden;
  background:var(--product-bg);aspect-ratio:4/5;box-shadow:var(--shadow-card);
  display:flex;align-items:center;justify-content:center;
}
.hero-image img{width:88%;height:88%;object-fit:contain}
.hero-image::after{
  content:"";position:absolute;inset:0;border:1px solid rgba(255,255,255,.06);
  border-radius:var(--radius-lg);pointer-events:none;
}
.hero-tag{
  position:absolute;left:20px;bottom:20px;background:rgba(33,28,25,.78);color:var(--ivory);
  padding:10px 14px;border-radius:999px;font-family:var(--mono);font-size:.7rem;letter-spacing:.22em;
}
@media (max-width:900px){.hero-grid{grid-template-columns:1fr}.hero{padding:80px 0 60px}}

/* Page hero */
.page-hero{
  background:linear-gradient(180deg,var(--ivory-2) 0%,var(--ivory) 100%);
  padding:90px 0 60px;border-bottom:1px solid var(--line);
}
.page-hero .eyebrow{display:block;margin-bottom:14px}
.page-hero p{max-width:640px;font-size:1.05rem}

/* Sections – editorial */
.intro-grid{display:grid;grid-template-columns:.6fr 1fr;gap:80px;align-items:start}
.intro-grid h2{margin:8px 0 24px}
.intro-grid .lead{font-size:1.15rem;color:var(--charcoal-2)}
@media (max-width:900px){.intro-grid{grid-template-columns:1fr;gap:24px}}

/* Categories */
.cat-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:18px}
.cat-card{
  position:relative;border-radius:var(--radius-md);overflow:hidden;aspect-ratio:3/4;
  background:var(--product-bg);display:flex;align-items:flex-end;padding:20px;
  transition:transform .35s ease, box-shadow .35s ease;
}
.cat-card img{position:absolute;inset:6%;width:88%;height:60%;object-fit:contain;transition:transform .5s ease}
.cat-card:hover{transform:translateY(-6px);box-shadow:var(--shadow-card)}
.cat-card:hover img{transform:scale(1.04)}
.cat-card span{
  position:relative;z-index:1;font-family:var(--serif);font-size:1.25rem;color:var(--charcoal);
}
.cat-card::after{
  content:"";position:absolute;left:0;right:0;bottom:0;height:55%;
  background:linear-gradient(180deg,transparent, rgba(244,236,220,.85) 70%);
}
@media (max-width:900px){.cat-grid{grid-template-columns:repeat(2,1fr)}}

/* Why grid */
.why-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.why-card{
  background:#fff;border:1px solid var(--line);border-radius:var(--radius-md);
  padding:32px;transition:transform .3s, box-shadow .3s;
}
.why-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-soft)}
.why-card .num{font-family:var(--serif);font-size:2.2rem;color:var(--copper-deep)}
.why-card h3{margin:10px 0 8px}
@media (max-width:800px){.why-grid{grid-template-columns:1fr}}

/* Editorial split */
.split{display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:center}
.split.reverse{direction:rtl}
.split.reverse > *{direction:ltr}
.split .ph{aspect-ratio:4/5;background:var(--product-bg);border-radius:var(--radius-lg);display:flex;align-items:center;justify-content:center;overflow:hidden;box-shadow:var(--shadow-soft)}
.split .ph img{width:82%;height:82%;object-fit:contain}
@media (max-width:900px){.split{grid-template-columns:1fr;gap:24px}}

/* Featured products preview */
.feat-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
@media (max-width:900px){.feat-grid{grid-template-columns:1fr 1fr}}
@media (max-width:600px){.feat-grid{grid-template-columns:1fr}}

/* Product card */
.product-card{
  background:#fff;border-radius:var(--radius-md);overflow:hidden;
  border:1px solid var(--line);transition:transform .35s, box-shadow .35s;
  display:flex;flex-direction:column;
}
.product-card:hover{transform:translateY(-6px);box-shadow:var(--shadow-card)}
.product-card .ph{
  aspect-ratio:1/1;background:var(--product-bg);display:flex;align-items:center;justify-content:center;
  overflow:hidden;position:relative;
}
.product-card .ph img{width:78%;height:78%;object-fit:contain;transition:transform .55s ease}
.product-card:hover .ph img{transform:scale(1.05)}
.product-card .body{padding:20px 22px 24px;display:flex;flex-direction:column;gap:8px;flex:1}
.product-card .cat{font-family:var(--mono);font-size:.65rem;letter-spacing:.22em;text-transform:uppercase;color:var(--copper-deep)}
.product-card .name{font-family:var(--serif);font-size:1.2rem;color:var(--charcoal)}
.product-card .desc{font-size:.88rem;color:#5a5048;flex:1}
.product-card .row{display:flex;align-items:center;justify-content:space-between;margin-top:10px;gap:10px}
.product-card .price{font-family:var(--serif);font-size:1.3rem;color:var(--copper-deep)}
.product-card .actions{display:flex;gap:8px;margin-top:14px}
.product-card .actions .btn{flex:1;padding:11px 14px;font-size:.82rem}

/* Pagination */
.pagination{display:flex;justify-content:center;gap:8px;margin-top:60px}
.pagination button{
  width:42px;height:42px;border-radius:50%;border:1px solid var(--line);background:#fff;
  font-family:var(--mono);font-size:.85rem;cursor:pointer;transition:all .2s;
}
.pagination button:hover{border-color:var(--copper)}
.pagination button.active{background:var(--charcoal);color:var(--ivory);border-color:var(--charcoal)}
.pagination button[disabled]{opacity:.4;cursor:not-allowed}

/* Product detail */
.pd-grid{display:grid;grid-template-columns:1.05fr 1fr;gap:60px}
.pd-gallery .main{
  aspect-ratio:1/1;background:var(--product-bg);border-radius:var(--radius-lg);
  display:flex;align-items:center;justify-content:center;overflow:hidden;box-shadow:var(--shadow-soft);
}
.pd-gallery .main img{width:80%;height:80%;object-fit:contain;transition:opacity .3s}
.pd-thumbs{display:flex;gap:12px;margin-top:16px;flex-wrap:wrap}
.pd-thumbs button{
  width:84px;height:84px;border-radius:12px;overflow:hidden;background:var(--product-bg);
  border:2px solid transparent;cursor:pointer;padding:6px;transition:border .2s;
}
.pd-thumbs button img{width:100%;height:100%;object-fit:contain}
.pd-thumbs button.active{border-color:var(--copper)}
.pd-info .price{font-family:var(--serif);font-size:2rem;color:var(--copper-deep);margin:12px 0}
.pd-info .actions{display:flex;gap:12px;flex-wrap:wrap;margin:24px 0}
.pd-info h3{margin:28px 0 10px;font-size:1.05rem;font-family:var(--mono);text-transform:uppercase;letter-spacing:.2em;color:var(--charcoal-2)}
.pd-info ul{padding-left:18px;margin:0}
.pd-info ul li{margin:6px 0;color:#3a342f}
.pd-info .spec-table{width:100%;border-collapse:collapse;margin-top:8px}
.pd-info .spec-table td{padding:10px 0;border-bottom:1px solid var(--line);font-size:.92rem}
.pd-info .spec-table td:first-child{color:#6b6158;width:40%}
@media (max-width:900px){.pd-grid{grid-template-columns:1fr;gap:30px}}

/* Cart page */
.cart-grid{display:grid;grid-template-columns:1.4fr .8fr;gap:40px;align-items:start}
.cart-item{
  display:grid;grid-template-columns:120px 1fr auto;gap:20px;align-items:center;
  background:#fff;border:1px solid var(--line);border-radius:var(--radius-md);padding:16px;margin-bottom:14px;
}
.cart-item .ph{aspect-ratio:1/1;background:var(--product-bg);border-radius:10px;display:flex;align-items:center;justify-content:center;overflow:hidden}
.cart-item .ph img{width:80%;height:80%;object-fit:contain}
.cart-item .cat{font-family:var(--mono);font-size:.65rem;letter-spacing:.2em;text-transform:uppercase;color:var(--copper-deep)}
.cart-item h3{font-size:1.1rem;margin:4px 0 8px}
.cart-item .qty{display:inline-flex;align-items:center;border:1px solid var(--line);border-radius:999px;overflow:hidden}
.cart-item .qty button{width:34px;height:34px;background:transparent;border:0;cursor:pointer;font-size:1rem}
.cart-item .qty button:hover{background:var(--ivory-2)}
.cart-item .qty span{min-width:28px;text-align:center;font-family:var(--mono);font-size:.9rem}
.cart-item .right{display:flex;flex-direction:column;align-items:flex-end;gap:8px}
.cart-item .sub{font-family:var(--serif);font-size:1.15rem;color:var(--copper-deep)}
.cart-item .remove{background:none;border:0;color:#8a6a4a;font-size:.8rem;cursor:pointer;text-decoration:underline}
.summary{
  position:sticky;top:100px;background:#fff;border:1px solid var(--line);
  border-radius:var(--radius-md);padding:28px;box-shadow:var(--shadow-soft);
}
.summary h3{font-family:var(--mono);text-transform:uppercase;letter-spacing:.2em;font-size:.85rem;color:var(--charcoal-2);margin-bottom:18px}
.summary .row{display:flex;justify-content:space-between;padding:10px 0;border-bottom:1px solid var(--line);font-size:.92rem}
.summary .total{display:flex;justify-content:space-between;font-family:var(--serif);font-size:1.5rem;color:var(--copper-deep);margin-top:18px}
.summary .btns{display:flex;flex-direction:column;gap:10px;margin-top:18px}
.empty-state{text-align:center;padding:80px 20px;background:#fff;border:1px dashed var(--line);border-radius:var(--radius-lg)}
.empty-state .ic{font-size:3.4rem;color:var(--copper-deep)}
.empty-state h2{margin:14px 0 8px}
@media (max-width:900px){.cart-grid{grid-template-columns:1fr}.cart-item{grid-template-columns:90px 1fr;}.cart-item .right{grid-column:1/-1;align-items:flex-start}}

/* Checkout */
.checkout-grid{display:grid;grid-template-columns:1.2fr .9fr;gap:40px;align-items:start}
.form-card{background:#fff;border:1px solid var(--line);border-radius:var(--radius-md);padding:30px;box-shadow:var(--shadow-soft)}
.form-card h3{font-family:var(--mono);text-transform:uppercase;letter-spacing:.2em;font-size:.85rem;color:var(--charcoal-2);margin:0 0 20px}
.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.field{display:flex;flex-direction:column;gap:6px}
.field.full{grid-column:1/-1}
.field label{font-size:.78rem;text-transform:uppercase;letter-spacing:.15em;color:#6b6158}
.field input,.field textarea,.field select{
  width:100%;background:var(--ivory-2);border:1px solid transparent;border-radius:10px;
  padding:12px 14px;font:inherit;color:var(--charcoal);transition:border .2s, background .2s;
}
.field input:focus,.field textarea:focus,.field select:focus{outline:none;background:#fff;border-color:var(--copper)}
.field textarea{min-height:120px;resize:vertical}
.method-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-top:6px}
.method{
  border:1px solid var(--line);border-radius:12px;padding:18px;cursor:pointer;display:flex;
  flex-direction:column;gap:6px;background:#fff;transition:border .2s, transform .2s;
}
.method:hover{transform:translateY(-2px)}
.method.active{border-color:var(--copper);box-shadow:0 0 0 2px rgba(176,122,74,.18)}
.method strong{font-family:var(--serif);font-size:1.1rem}
.method small{color:#6b6158}
.summary-line{display:flex;gap:14px;align-items:center;padding:10px 0;border-bottom:1px solid var(--line)}
.summary-line .ph{width:60px;height:60px;background:var(--product-bg);border-radius:10px;display:flex;align-items:center;justify-content:center;overflow:hidden;flex-shrink:0}
.summary-line .ph img{width:80%;height:80%;object-fit:contain}
.summary-line .meta{flex:1;font-size:.88rem}
.summary-line .meta .cat{font-family:var(--mono);font-size:.62rem;letter-spacing:.2em;text-transform:uppercase;color:var(--copper-deep)}
.summary-line .price{font-family:var(--serif);color:var(--copper-deep)}
@media (max-width:900px){.checkout-grid{grid-template-columns:1fr}.form-grid{grid-template-columns:1fr}}

/* Thank you */
.thank{
  text-align:center;max-width:680px;margin:0 auto;padding:80px 20px;
}
.thank .check{
  width:90px;height:90px;border-radius:50%;background:var(--copper);color:#fff;
  display:flex;align-items:center;justify-content:center;margin:0 auto 28px;font-size:2.5rem;
}
.thank .ref{font-family:var(--mono);font-size:.85rem;color:var(--copper-deep);margin-top:8px}
.thank .info{background:#fff;border:1px solid var(--line);border-radius:var(--radius-md);padding:28px;margin:30px 0;text-align:left}
.thank .actions{display:flex;gap:12px;justify-content:center;flex-wrap:wrap}

/* FAQ */
.faq-item{
  background:#fff;border:1px solid var(--line);border-radius:14px;margin-bottom:12px;overflow:hidden;
}
.faq-q{
  display:flex;justify-content:space-between;align-items:center;gap:20px;
  padding:22px 24px;font-family:var(--serif);font-size:1.15rem;color:var(--charcoal);
  cursor:pointer;background:transparent;border:0;width:100%;text-align:left;
}
.faq-q .ic{transition:transform .3s;color:var(--copper-deep);font-size:1.2rem}
.faq-item.open .faq-q .ic{transform:rotate(45deg)}
.faq-a{max-height:0;overflow:hidden;transition:max-height .35s ease;padding:0 24px;color:#3a342f}
.faq-item.open .faq-a{max-height:400px;padding:0 24px 24px}

/* Contact */
.contact-grid{display:grid;grid-template-columns:1fr 1.2fr;gap:48px;align-items:start}
.contact-info{background:var(--charcoal);color:var(--ivory);border-radius:var(--radius-lg);padding:36px;box-shadow:var(--shadow-card)}
.contact-info h3{color:var(--ivory);font-family:var(--serif);font-size:1.6rem;margin:0 0 18px}
.contact-info .item{display:flex;gap:12px;align-items:flex-start;padding:14px 0;border-bottom:1px solid rgba(244,236,220,.12)}
.contact-info .item:last-child{border-bottom:0}
.contact-info .item strong{display:block;color:var(--copper-2);font-size:.7rem;letter-spacing:.2em;text-transform:uppercase;font-family:var(--mono);margin-bottom:4px}
.contact-info .item span{color:rgba(244,236,220,.85);font-size:.95rem}
.inquiry-types{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin:8px 0 18px}
.inquiry-types .method{padding:14px}
.preview-list{background:var(--ivory-2);border-radius:12px;padding:14px;margin-bottom:14px;max-height:300px;overflow:auto}
.preview-list .summary-line{border-color:rgba(40,32,28,.08)}

/* Footer */
.site-footer{background:var(--charcoal);color:rgba(244,236,220,.78);padding:70px 0 30px;margin-top:80px}
.site-footer .brand{color:var(--ivory)}
.foot-grid{display:grid;grid-template-columns:1.6fr 1fr 1fr 1.2fr;gap:36px}
.foot-grid h4{color:var(--ivory);font-family:var(--mono);text-transform:uppercase;font-size:.78rem;letter-spacing:.2em;margin:0 0 16px}
.foot-grid a{display:block;padding:5px 0;color:rgba(244,236,220,.7);font-size:.92rem}
.foot-grid a:hover{color:var(--copper-2)}
.foot-grid p, .foot-grid .biz span{font-size:.9rem;line-height:1.7;color:rgba(244,236,220,.7)}
.foot-grid .biz strong{display:block;color:var(--ivory);font-family:var(--serif);font-size:1.05rem;margin-bottom:8px}
.foot-grid .biz span{display:block}
.foot-bottom{border-top:1px solid rgba(244,236,220,.1);margin-top:50px;padding-top:24px;display:flex;justify-content:space-between;flex-wrap:wrap;gap:10px;font-size:.8rem;color:rgba(244,236,220,.55)}
@media (max-width:900px){.foot-grid{grid-template-columns:1fr 1fr}}
@media (max-width:600px){.foot-grid{grid-template-columns:1fr}}

/* Toast */
.toast{
  position:fixed;bottom:24px;left:50%;transform:translateX(-50%) translateY(20px);
  background:var(--charcoal);color:var(--ivory);padding:14px 22px;border-radius:999px;
  font-size:.9rem;box-shadow:var(--shadow-card);opacity:0;pointer-events:none;
  transition:opacity .3s, transform .3s;z-index:200;
}
.toast.show{opacity:1;transform:translateX(-50%) translateY(0)}

/* Cookie banner */
.cookie{
  position:fixed;bottom:20px;left:20px;right:20px;max-width:560px;margin:0 auto;
  background:rgba(33,28,25,.96);color:var(--ivory);border-radius:18px;padding:20px 22px;
  box-shadow:var(--shadow-card);z-index:150;display:none;animation:slideUp .4s ease;
  backdrop-filter:blur(10px);
}
.cookie.show{display:block}
.cookie p{color:rgba(244,236,220,.85);margin:0 0 14px;font-size:.9rem}
.cookie .row{display:flex;gap:10px}
.cookie .btn{padding:10px 18px;font-size:.85rem}
@keyframes slideUp{from{transform:translateY(40px);opacity:0}to{transform:translateY(0);opacity:1}}

/* Scroll reveal */
.reveal{opacity:0;transform:translateY(24px);transition:opacity .8s ease, transform .8s ease}
.reveal.in{opacity:1;transform:translateY(0)}

/* Editorial typography helper */
.kicker{font-family:var(--mono);font-size:.7rem;letter-spacing:.28em;text-transform:uppercase;color:var(--copper-deep);margin-bottom:14px;display:inline-block}

/* Testimonial */
.testi-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.testi{background:#fff;border:1px solid var(--line);border-radius:var(--radius-md);padding:28px;display:flex;flex-direction:column;gap:14px}
.testi p{font-family:var(--serif);font-size:1.1rem;color:var(--charcoal);line-height:1.4}
.testi .by{font-family:var(--mono);font-size:.7rem;letter-spacing:.2em;text-transform:uppercase;color:var(--copper-deep)}
@media (max-width:900px){.testi-grid{grid-template-columns:1fr}}

/* Newsletter / CTA */
.cta-band{
  background:linear-gradient(120deg,#2a221d,#3a2a1f);color:var(--ivory);
  border-radius:var(--radius-lg);padding:60px;display:grid;grid-template-columns:1.4fr 1fr;gap:30px;align-items:center;
  box-shadow:var(--shadow-card);
}
.cta-band h2{color:var(--ivory)}
.cta-band p{color:rgba(244,236,220,.78);margin-top:14px}
.cta-band form{display:flex;gap:8px;background:rgba(244,236,220,.08);border:1px solid rgba(244,236,220,.2);border-radius:999px;padding:6px}
.cta-band input{flex:1;background:transparent;border:0;color:var(--ivory);padding:10px 16px;font:inherit;outline:none}
.cta-band input::placeholder{color:rgba(244,236,220,.5)}
@media (max-width:900px){.cta-band{grid-template-columns:1fr;padding:36px}}

/* Process steps */
.process{display:grid;grid-template-columns:repeat(4,1fr);gap:20px}
.process .step{background:#fff;border:1px solid var(--line);border-radius:var(--radius-md);padding:26px;position:relative}
.process .step .num{font-family:var(--serif);font-size:2.6rem;color:var(--copper);line-height:1}
.process .step h3{margin:10px 0 8px;font-size:1.2rem}
@media (max-width:900px){.process{grid-template-columns:1fr 1fr}}
@media (max-width:500px){.process{grid-template-columns:1fr}}

/* Legal pages */
.legal{max-width:820px;margin:0 auto}
.legal h2{margin-top:40px}
.legal h3{margin-top:28px;font-size:1.2rem}
.legal p,.legal li{font-size:.97rem;color:#3a342f}
.legal ul{padding-left:20px}


/* =========================================================
   CLEAN AQUA OVERRIDE
   Purpose: remove dirty beige/brown feeling
   Style: white porcelain + light aqua + soft gray
   ========================================================= */

/* Base */
html,body{
  background:#ffffff;
}

body{
  font-family:Arial,Calibri,Helvetica,sans-serif;
  color:#18242f;
}

h1,h2,h3,h4,
.brand,
.product-card .name,
.product-card .price,
.pd-info .price,
.summary .total,
.faq-q,
.testi p{
  font-family:Arial,Calibri,Helvetica,sans-serif;
  color:#18242f;
  font-weight:800;
  letter-spacing:-.025em;
}

p,
.legal p,
.legal li,
.product-card .desc{
  color:#5f6f7b;
}

.container{
  max-width:1240px;
}

/* Header clean */
.site-header{
  background:rgba(255,255,255,.96);
  border-bottom:1px solid #e8eef1;
  backdrop-filter:blur(12px);
}

.nav{
  padding:16px 0;
}

.brand{
  align-items:center;
  font-size:1.22rem;
  letter-spacing:.03em;
}

.brand .dot{
  width:30px;
  height:30px;
  border-radius:10px;
  background:linear-gradient(135deg,#16b8b0,#7ee7e0);
  box-shadow:0 10px 20px rgba(22,184,176,.16);
  position:relative;
}

.brand .dot::after{
  content:"";
  position:absolute;
  width:10px;
  height:10px;
  border-radius:50%;
  right:6px;
  top:6px;
  background:#fff;
}

.brand small{
  font-family:Arial,Calibri,Helvetica,sans-serif;
  color:#71808b;
  letter-spacing:.12em;
  font-weight:700;
}

.nav-links{
  gap:8px;
}

.nav-links a{
  padding:9px 14px;
  border-radius:999px;
  color:#465763;
  font-weight:700;
}

.nav-links a:hover,
.nav-links a.active{
  color:#07958e;
  background:#e9fbfa;
}

.nav-links a.active::after{
  display:none;
}

.cart-btn{
  background:#07958e;
  color:#ffffff;
  border:1px solid #07958e;
  box-shadow:0 12px 24px rgba(7,149,142,.18);
}

.cart-btn:hover{
  background:#067a74;
}

.cart-badge{
  background:#ffffff;
  color:#07958e;
}

/* Buttons clean */
.btn{
  font-family:Arial,Calibri,Helvetica,sans-serif;
  font-weight:800;
  border-radius:999px;
}

.btn-primary{
  background:#07958e;
  color:#ffffff;
}

.btn-primary:hover{
  background:#067a74;
  box-shadow:0 16px 34px rgba(7,149,142,.20);
}

.btn-dark{
  background:#18242f;
  color:#ffffff;
}

.btn-dark:hover{
  background:#0d151d;
}

.btn-ghost,
.btn-outline-copper{
  background:#ffffff;
  color:#07958e;
  border-color:#bcefed;
}

.btn-ghost:hover,
.btn-outline-copper:hover{
  background:#07958e;
  border-color:#07958e;
  color:#ffffff;
}

/* Small labels */
.eyebrow,
.kicker,
.product-card .cat,
.cart-item .cat,
.summary-line .meta .cat,
.foot-grid h4,
.form-card h3,
.pd-info h3{
  font-family:Arial,Calibri,Helvetica,sans-serif;
  color:#07958e;
  font-weight:800;
  letter-spacing:.14em;
}

/* Hero clean bright */
.hero{
  background:
    radial-gradient(circle at 78% 24%, rgba(39,199,189,.16), transparent 36%),
    linear-gradient(135deg,#ffffff 0%,#ffffff 50%,#f1fcfc 100%);
  color:#18242f;
  padding:120px 0 100px;
  border-bottom:1px solid #e8eef1;
}

.hero::before{
  background:none;
}

.hero h1{
  color:#18242f;
}

.hero h1 em{
  color:#07958e;
  font-style:normal;
}

.hero p{
  color:#5f6f7b;
}

.hero-stats div span:first-child{
  font-family:Arial,Calibri,Helvetica,sans-serif;
  color:#07958e;
  font-weight:800;
}

.hero-stats div span:last-child{
  font-family:Arial,Calibri,Helvetica,sans-serif;
  color:#7c8a94;
  letter-spacing:.12em;
}

.hero-image{
  background:#f8fcfc;
  border:1px solid #e0eff0;
  box-shadow:0 24px 58px -34px rgba(24,36,47,.24);
}

.hero-image::after{
  border:1px solid rgba(7,149,142,.12);
}

.hero-tag{
  background:rgba(255,255,255,.92);
  color:#07958e;
  border:1px solid #d8f2f1;
  font-family:Arial,Calibri,Helvetica,sans-serif;
  letter-spacing:.12em;
}

/* Page hero */
.page-hero{
  background:linear-gradient(180deg,#f3fcfc 0%,#ffffff 100%);
  border-bottom:1px solid #e8eef1;
}

/* Sections */
.section:nth-of-type(even){
  background:#ffffff;
}

.divider{
  background:#e8eef1;
}

/* Cards and product backgrounds */
.cat-card,
.product-card,
.why-card,
.testi,
.process .step,
.faq-item,
.form-card,
.summary,
.cart-item{
  background:#ffffff;
  border:1px solid #e8eef1;
  box-shadow:0 14px 36px -30px rgba(24,36,47,.20);
}

.cat-card:hover,
.product-card:hover,
.why-card:hover{
  border-color:#a8ebe8;
  box-shadow:0 24px 58px -34px rgba(7,149,142,.22);
}

.cat-card,
.product-card .ph,
.pd-gallery .main,
.pd-thumbs button,
.cart-item .ph,
.summary-line .ph,
.split .ph{
  background:#f8fcfc;
}

.cat-card::after{
  background:linear-gradient(180deg,transparent,rgba(255,255,255,.94) 72%);
}

.cat-card span,
.product-card .name{
  color:#18242f;
}

.product-card .cat,
.product-card .price,
.why-card .num,
.process .step .num,
.pd-info .price,
.cart-item .sub,
.summary .total,
.summary-line .price,
.faq-q .ic,
.testi .by{
  color:#07958e;
}

.product-card .actions .btn{
  border-radius:999px;
}

/* Split image section */
.split .ph{
  border:1px solid #e0eff0;
  box-shadow:0 24px 58px -34px rgba(24,36,47,.22);
}

/* Product detail */
.pd-thumbs button.active{
  border-color:#07958e;
}

.pd-info .spec-table td,
.summary .row,
.cart-item,
.summary-line{
  border-color:#e8eef1;
}

/* Cart */
.cart-item .qty{
  border-color:#dbe7eb;
}

.cart-item .qty button:hover{
  background:#e9fbfa;
}

.cart-item .remove{
  color:#07958e;
}

/* Checkout forms */
.field input,
.field textarea,
.field select{
  background:#f8fcfc;
  border:1px solid #e0eff0;
  color:#18242f;
}

.field input:focus,
.field textarea:focus,
.field select:focus{
  background:#ffffff;
  border-color:#27c7bd;
  box-shadow:0 0 0 3px rgba(39,199,189,.12);
}

.field label{
  color:#71808b;
}

.method{
  background:#ffffff;
  border-color:#e0eff0;
}

.method.active{
  border-color:#07958e;
  box-shadow:0 0 0 3px rgba(39,199,189,.14);
}

.method small{
  color:#71808b;
}

/* Contact */
.contact-info{
  background:#f1fcfc;
  color:#18242f;
  border:1px solid #d8f2f1;
  box-shadow:0 18px 50px -30px rgba(7,149,142,.20);
}

.contact-info h3{
  color:#18242f;
}

.contact-info .item{
  border-bottom:1px solid #d8f2f1;
}

.contact-info .item strong{
  color:#07958e;
}

.contact-info .item span{
  color:#5f6f7b;
}

.preview-list{
  background:#f8fcfc;
}

/* Thank */
.thank .check{
  background:#07958e;
}

/* FAQ */
.faq-q{
  color:#18242f;
}

/* CTA clean */
.cta-band{
  background:
    radial-gradient(circle at 90% 20%, rgba(39,199,189,.14), transparent 34%),
    linear-gradient(135deg,#f1fcfc,#ffffff);
  color:#18242f;
  border:1px solid #d8f2f1;
  box-shadow:0 22px 56px -34px rgba(7,149,142,.22);
}

.cta-band h2{
  color:#18242f;
}

.cta-band p{
  color:#5f6f7b;
}

.cta-band form{
  background:#ffffff;
  border:1px solid #d8f2f1;
}

.cta-band input{
  color:#18242f;
}

.cta-band input::placeholder{
  color:#98a6af;
}

/* Footer bright, not dirty */
.site-footer{
  background:#f8fcfc;
  color:#5f6f7b;
  border-top:1px solid #e0eff0;
}

.site-footer .brand{
  color:#18242f;
}

.foot-grid h4{
  color:#18242f;
}

.foot-grid a,
.foot-grid p,
.foot-grid .biz span{
  color:#5f6f7b;
}

.foot-grid a:hover{
  color:#07958e;
}

.foot-grid .biz strong{
  color:#18242f;
  font-family:Arial,Calibri,Helvetica,sans-serif;
  font-weight:800;
}

.foot-bottom{
  border-top:1px solid #e0eff0;
  color:#7c8a94;
}

/* Toast / Cookie clean */
.toast{
  background:#18242f;
  color:#ffffff;
}

.cookie{
  background:rgba(255,255,255,.97);
  color:#18242f;
  border:1px solid #d8f2f1;
}

.cookie p{
  color:#5f6f7b;
}

/* Mobile nav */
@media (max-width: 900px){
  .nav-links{
    background:#ffffff;
    border-bottom:1px solid #e8eef1;
  }

  .nav-links.open{
    box-shadow:0 20px 44px rgba(24,36,47,.08);
  }

  .nav-links a{
    border-bottom:1px solid #e8eef1;
  }
}
/* =========================================================
   ALFANAR HOME ATELIER CSS
   White + Aqua + Cool Gray
   Hero style: centered showroom runway, not left/right split
   File path: assets/css/home-atelier.css
========================================================= */

:root{
  --ha-white:#ffffff;
  --ha-bg:#f7fbfc;
  --ha-panel:#eefafa;
  --ha-aqua:#0faaa3;
  --ha-aqua-2:#69ddd7;
  --ha-dark:#142531;
  --ha-text:#172936;
  --ha-muted:#627381;
  --ha-line:#e0edf0;
  --ha-soft-line:#ccefed;
  --ha-shadow:0 26px 70px rgba(20,37,49,.10);
  --ha-shadow-soft:0 16px 42px rgba(20,37,49,.07);
  --ha-radius:28px;
}

.home-atelier{
  margin:0;
  font-family:Arial, Calibri, Helvetica, sans-serif;
  color:var(--ha-text);
  background:#fff;
}

.home-atelier *{
  box-sizing:border-box;
}

.home-atelier img{
  max-width:100%;
  display:block;
}

.home-atelier a{
  text-decoration:none;
}

.home-atelier .container{
  width:min(1180px, calc(100% - 32px));
  margin:0 auto;
  padding:0;
}

/* Header */
.home-atelier .site-header{
  background:rgba(255,255,255,.96);
  border-bottom:1px solid var(--ha-line);
  backdrop-filter:blur(12px);
}

.home-atelier .nav{
  min-height:74px;
  padding:0;
}

.home-atelier .brand{
  display:flex;
  align-items:center;
  gap:11px;
  font-family:Arial, Calibri, Helvetica, sans-serif;
  font-size:1.14rem;
  font-weight:900;
  color:var(--ha-dark);
  letter-spacing:.02em;
}

.home-atelier .brand .dot{
  width:31px;
  height:31px;
  border-radius:50%;
  background:linear-gradient(135deg,var(--ha-aqua),var(--ha-aqua-2));
  box-shadow:0 10px 22px rgba(15,170,163,.20);
}

.home-atelier .brand .dot::after{
  display:none;
}

.home-atelier .brand small{
  color:#73838f;
  font-family:Arial, Calibri, Helvetica, sans-serif;
  font-size:.66rem;
  font-weight:800;
  letter-spacing:.08em;
  text-transform:uppercase;
}

.home-atelier .nav-links{
  gap:6px;
}

.home-atelier .nav-links a{
  padding:9px 14px;
  border-radius:999px;
  color:#465965;
  font-size:.9rem;
  font-weight:800;
}

.home-atelier .nav-links a:hover,
.home-atelier .nav-links a.active{
  color:var(--ha-aqua);
  background:#e9fbfa;
}

.home-atelier .nav-links a.active::after{
  display:none;
}

.home-atelier .cart-btn{
  background:var(--ha-aqua);
  color:#fff;
  border-radius:999px;
  box-shadow:0 12px 24px rgba(15,170,163,.20);
}

.home-atelier .cart-btn:hover{
  background:#087f7a;
}

.home-atelier .cart-badge{
  background:#fff;
  color:var(--ha-aqua);
}

.home-atelier .menu-toggle{
  color:var(--ha-dark);
}

/* Typography */
.home-atelier h1,
.home-atelier h2,
.home-atelier h3,
.home-atelier h4{
  font-family:Arial, Calibri, Helvetica, sans-serif;
  color:var(--ha-dark);
  font-weight:900;
  letter-spacing:-.045em;
}

.home-atelier p{
  color:var(--ha-muted);
}

.home-atelier .section{
  padding:88px 0;
}

.home-atelier .atelier-bg{
  background:var(--ha-bg);
}

.home-atelier .atelier-label{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:10px;
  margin-bottom:14px;
  color:var(--ha-aqua);
  font-size:.74rem;
  font-weight:900;
  letter-spacing:.13em;
  text-transform:uppercase;
}

.home-atelier .atelier-label::before,
.home-atelier .atelier-label::after{
  content:"";
  width:30px;
  height:2px;
  border-radius:999px;
  background:var(--ha-aqua-2);
}

.home-atelier .section-head{
  display:flex;
  align-items:flex-end;
  justify-content:space-between;
  gap:22px;
  flex-wrap:wrap;
  margin-bottom:34px;
}

.home-atelier .section-head .atelier-label{
  justify-content:flex-start;
}

.home-atelier .section-head .atelier-label::after{
  display:none;
}

.home-atelier .section-head h2,
.home-atelier .center-head h2{
  margin:0;
  font-size:clamp(30px,4vw,50px);
  line-height:1.07;
}

.home-atelier .center-head{
  max-width:760px;
  margin:0 auto 42px;
  text-align:center;
}

/* Buttons */
.home-atelier .btn{
  min-height:48px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  padding:12px 22px;
  border-radius:999px;
  border:1px solid transparent;
  font-family:Arial, Calibri, Helvetica, sans-serif;
  font-weight:900;
  transition:.22s ease;
}

.home-atelier .btn-primary{
  background:var(--ha-aqua);
  color:#fff;
  box-shadow:0 14px 30px rgba(15,170,163,.22);
}

.home-atelier .btn-primary:hover{
  background:#087f7a;
  transform:translateY(-2px);
}

.home-atelier .btn-outline{
  color:var(--ha-aqua);
  background:#fff;
  border-color:var(--ha-soft-line);
  box-shadow:var(--ha-shadow-soft);
}

.home-atelier .btn-outline:hover{
  transform:translateY(-2px);
  border-color:var(--ha-aqua-2);
}

/* New hero */
.atelier-hero{
  position:relative;
  overflow:hidden;
  padding:72px 0 80px;
  background:
    radial-gradient(circle at 15% 20%, rgba(105,221,215,.14), transparent 28%),
    radial-gradient(circle at 88% 24%, rgba(105,221,215,.18), transparent 34%),
    linear-gradient(180deg,#ffffff 0%,#f7fbfc 100%);
  border-bottom:1px solid var(--ha-line);
}

.atelier-hero::before{
  content:"";
  position:absolute;
  left:50%;
  top:50px;
  width:min(820px, 86vw);
  height:min(820px, 86vw);
  transform:translateX(-50%);
  border-radius:50%;
  border:1px solid rgba(15,170,163,.11);
  pointer-events:none;
}

.hero-center{
  position:relative;
  z-index:2;
  max-width:880px;
  margin:0 auto 44px;
  text-align:center;
}

.hero-center h1{
  margin:0 auto 18px;
  font-size:clamp(42px, 6.8vw, 86px);
  line-height:.98;
}

.hero-center p{
  max-width:720px;
  margin:0 auto;
  font-size:1.08rem;
  line-height:1.72;
}

.hero-center-actions{
  display:flex;
  justify-content:center;
  gap:12px;
  flex-wrap:wrap;
  margin-top:30px;
}

/* Runway hero: completely different from old split */
.hero-runway{
  position:relative;
  z-index:2;
  display:grid;
  grid-template-columns:260px 1fr 235px;
  gap:18px;
  align-items:stretch;
  padding:18px;
  border:1px solid var(--ha-line);
  border-radius:36px;
  background:rgba(255,255,255,.82);
  box-shadow:var(--ha-shadow);
  backdrop-filter:blur(10px);
}

.runway-left{
  min-height:390px;
  padding:26px;
  display:flex;
  flex-direction:column;
  justify-content:space-between;
  border-radius:26px;
  background:var(--ha-dark);
}

.runway-small{
  color:var(--ha-aqua-2);
  font-size:.74rem;
  font-weight:900;
  text-transform:uppercase;
  letter-spacing:.12em;
}

.runway-left strong{
  display:block;
  margin-top:18px;
  color:#fff;
  font-size:2.2rem;
  line-height:1.02;
  letter-spacing:-.04em;
}

.runway-left p{
  margin:16px 0 0;
  color:rgba(255,255,255,.72);
}

.runway-tabs{
  display:flex;
  flex-wrap:wrap;
  gap:8px;
  margin-top:28px;
}

.runway-tabs a{
  padding:8px 11px;
  border-radius:999px;
  color:#dffafa;
  background:rgba(255,255,255,.10);
  font-size:.78rem;
  font-weight:800;
}

.runway-tabs a:hover{
  background:rgba(105,221,215,.22);
}

.runway-product{
  position:relative;
  display:flex;
  align-items:center;
  justify-content:center;
  overflow:hidden;
  border:1px solid var(--ha-line);
  border-radius:28px;
  background:#fff;
  transition:.22s ease;
}

.runway-product:hover{
  transform:translateY(-4px);
  border-color:var(--ha-aqua-2);
}

.runway-product img{
  width:100%;
  height:100%;
  object-fit:contain;
  padding:34px;
  background:
    linear-gradient(135deg,#ffffff 0%,#f0fbfb 100%);
}

.runway-product span{
  position:absolute;
  left:16px;
  right:16px;
  bottom:16px;
  padding:11px 13px;
  border:1px solid var(--ha-line);
  border-radius:999px;
  background:rgba(255,255,255,.90);
  color:var(--ha-dark);
  font-size:.86rem;
  font-weight:900;
  text-align:center;
}

.runway-main{
  min-height:390px;
}

.runway-main img{
  padding:48px;
}

.runway-side{
  display:grid;
  gap:18px;
}

.runway-side .runway-product{
  min-height:186px;
}

.runway-info{
  position:absolute;
  right:34px;
  bottom:-26px;
  width:150px;
  height:90px;
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:center;
  border:1px solid var(--ha-soft-line);
  border-radius:24px;
  background:#e9fbfa;
  box-shadow:var(--ha-shadow-soft);
}

.runway-info strong{
  color:var(--ha-aqua);
  font-size:2rem;
  line-height:1;
}

.runway-info span{
  color:var(--ha-muted);
  font-size:.78rem;
  font-weight:800;
  text-transform:uppercase;
}

/* Chips */
.atelier-chip-section{
  background:#fff;
  border-bottom:1px solid var(--ha-line);
}

.chip-grid{
  display:flex;
  flex-wrap:wrap;
  gap:10px;
  justify-content:center;
  padding:22px 0;
}

.chip-grid a{
  padding:10px 15px;
  border:1px solid var(--ha-line);
  border-radius:999px;
  background:#fff;
  color:#465965;
  font-weight:800;
  font-size:.9rem;
}

.chip-grid a:hover{
  color:var(--ha-aqua);
  border-color:var(--ha-aqua-2);
  background:#e9fbfa;
}

/* Intro */
.intro-grid{
  display:grid;
  grid-template-columns:.9fr 1.1fr;
  gap:58px;
  align-items:start;
}

.intro-grid .atelier-label{
  justify-content:flex-start;
}

.intro-grid .atelier-label::after{
  display:none;
}

.intro-grid h2{
  margin:0;
  font-size:clamp(30px,4vw,52px);
  line-height:1.06;
}

.intro-grid .lead{
  color:#415462;
  font-size:1.12rem;
}

/* Category cards */
.home-atelier .category-board{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:18px;
}

.home-atelier .cat-card{
  min-height:246px;
  padding:15px;
  border:1px solid var(--ha-line);
  border-radius:28px;
  background:#fff;
  box-shadow:var(--ha-shadow-soft);
  transition:.24s ease;
}

.home-atelier .cat-card:hover{
  transform:translateY(-6px);
  border-color:var(--ha-aqua-2);
  box-shadow:var(--ha-shadow);
}

.home-atelier .cat-card img{
  width:100%;
  height:168px;
  padding:18px;
  object-fit:contain;
  border-radius:22px;
  background:#f7fbfc;
}

.home-atelier .cat-card span{
  display:flex;
  align-items:center;
  justify-content:space-between;
  margin-top:14px;
  color:var(--ha-dark);
  font-weight:900;
}

.home-atelier .cat-card span::after{
  content:"→";
  color:var(--ha-aqua);
}

/* Split */
.atelier-split{
  display:grid;
  grid-template-columns:.9fr 1.1fr;
  gap:56px;
  align-items:center;
}

.split-copy .atelier-label{
  justify-content:flex-start;
}

.split-copy .atelier-label::after{
  display:none;
}

.split-copy h2{
  margin:0 0 18px;
  font-size:clamp(30px,4vw,52px);
  line-height:1.07;
}

.atelier-points{
  display:grid;
  gap:12px;
  margin-top:28px;
}

.atelier-points div{
  display:flex;
  gap:14px;
  align-items:center;
  padding:15px;
  border:1px solid var(--ha-line);
  border-radius:18px;
  background:#fff;
}

.atelier-points strong{
  color:var(--ha-aqua);
}

.atelier-points span{
  color:var(--ha-dark);
  font-weight:800;
}

.split-product-stack{
  position:relative;
  min-height:520px;
}

.stack-card{
  position:absolute;
  display:flex;
  align-items:center;
  justify-content:center;
  border:1px solid var(--ha-line);
  border-radius:32px;
  background:#fff;
  box-shadow:var(--ha-shadow);
  overflow:hidden;
}

.stack-card img{
  width:100%;
  height:100%;
  object-fit:contain;
  padding:32px;
  background:linear-gradient(135deg,#ffffff,#effafa);
}

.stack-card span{
  position:absolute;
  left:16px;
  bottom:16px;
  padding:10px 13px;
  border-radius:999px;
  background:#fff;
  color:var(--ha-dark);
  border:1px solid var(--ha-line);
  font-weight:900;
  font-size:.85rem;
}

.stack-card.large{
  left:0;
  top:40px;
  width:68%;
  height:410px;
}

.stack-card.small{
  right:0;
  width:38%;
  height:210px;
}

.stack-card.top{
  top:0;
}

.stack-card.bottom{
  bottom:18px;
}

/* Why / Process / Featured */
.home-atelier .why-grid,
.home-atelier .process,
.home-atelier .feat-grid{
  display:grid;
  gap:18px;
}

.home-atelier .why-grid{
  grid-template-columns:repeat(3,1fr);
}

.home-atelier .process{
  grid-template-columns:repeat(4,1fr);
}

.home-atelier .feat-grid{
  grid-template-columns:repeat(4,1fr);
}

.home-atelier .why-card,
.home-atelier .step{
  padding:28px;
  border:1px solid var(--ha-line);
  border-radius:28px;
  background:#fff;
  box-shadow:var(--ha-shadow-soft);
}

.home-atelier .num{
  width:44px;
  height:44px;
  display:grid;
  place-items:center;
  margin-bottom:18px;
  border-radius:50%;
  color:#fff;
  background:var(--ha-aqua);
  font-weight:900;
}

.home-atelier .why-card h3,
.home-atelier .step h3{
  margin:0 0 10px;
  font-size:1.2rem;
}

/* Product cards rendered by main.js */
.home-atelier .product-card{
  border:1px solid var(--ha-line);
  border-radius:26px;
  background:#fff;
  box-shadow:var(--ha-shadow-soft);
}

.home-atelier .product-card .ph{
  background:#f7fbfc;
}

.home-atelier .product-card .ph img{
  object-fit:contain;
}

.home-atelier .product-card .cat,
.home-atelier .product-card .price{
  color:var(--ha-aqua);
}

/* CTA */
.atelier-cta{
  display:grid;
  grid-template-columns:1.1fr .9fr;
  gap:28px;
  align-items:center;
  padding:46px;
  border:1px solid var(--ha-soft-line);
  border-radius:34px;
  background:
    radial-gradient(circle at 92% 18%, rgba(105,221,215,.18), transparent 34%),
    linear-gradient(135deg,#e9fbfa,#ffffff);
  box-shadow:var(--ha-shadow);
}

.atelier-cta .atelier-label{
  justify-content:flex-start;
}

.atelier-cta .atelier-label::after{
  display:none;
}

.atelier-cta h2{
  margin:0 0 12px;
  font-size:clamp(30px,4vw,50px);
  line-height:1.08;
}

.atelier-cta form{
  display:flex;
  gap:10px;
  padding:8px;
  border:1px solid var(--ha-soft-line);
  border-radius:999px;
  background:#fff;
}

.atelier-cta input{
  flex:1;
  min-width:0;
  min-height:46px;
  padding:0 14px;
  border:0;
  outline:0;
  font-family:Arial, Calibri, Helvetica, sans-serif;
}

/* Footer */
.home-atelier .site-footer{
  margin-top:0;
  padding:68px 0 28px;
  background:#f7fbfc;
  border-top:1px solid var(--ha-line);
  color:var(--ha-muted);
}

.home-atelier .foot-grid{
  display:grid;
  grid-template-columns:1.25fr .7fr .7fr 1.1fr;
  gap:34px;
}

.home-atelier .foot-grid h4{
  margin:0 0 14px;
  color:var(--ha-dark);
  font-family:Arial, Calibri, Helvetica, sans-serif;
  font-size:.8rem;
  font-weight:900;
  letter-spacing:.1em;
}

.home-atelier .foot-grid a,
.home-atelier .foot-grid p,
.home-atelier .foot-grid .biz span{
  color:var(--ha-muted);
}

.home-atelier .foot-grid a:hover{
  color:var(--ha-aqua);
}

.home-atelier .foot-grid .biz strong{
  color:var(--ha-dark);
  font-family:Arial, Calibri, Helvetica, sans-serif;
  font-weight:900;
}

.home-atelier .foot-bottom{
  display:flex;
  justify-content:space-between;
  gap:14px;
  flex-wrap:wrap;
  margin-top:42px;
  padding-top:22px;
  border-top:1px solid var(--ha-line);
  color:#71808a;
}

/* Reveal */
.home-atelier .reveal{
  opacity:0;
  transform:translateY(18px);
  transition:.6s ease;
}

.home-atelier .reveal.is-visible,
.home-atelier .reveal.in{
  opacity:1;
  transform:translateY(0);
}

/* Responsive */
@media (max-width:1060px){
  .hero-runway{
    grid-template-columns:1fr;
  }

  .runway-left{
    min-height:auto;
  }

  .runway-side{
    grid-template-columns:1fr 1fr;
  }

  .runway-side .runway-product{
    min-height:220px;
  }

  .runway-info{
    position:static;
    width:100%;
    height:auto;
    padding:18px;
  }

  .intro-grid,
  .atelier-split,
  .atelier-cta{
    grid-template-columns:1fr;
  }

  .home-atelier .category-board,
  .home-atelier .feat-grid,
  .home-atelier .process{
    grid-template-columns:repeat(2,1fr);
  }

  .home-atelier .why-grid,
  .home-atelier .foot-grid{
    grid-template-columns:1fr 1fr;
  }
}

@media (max-width:760px){
  .home-atelier .nav-links{
    position:absolute;
    top:74px;
    left:16px;
    right:16px;
    display:none;
    flex-direction:column;
    align-items:stretch;
    padding:12px;
    border:1px solid var(--ha-line);
    border-radius:22px;
    background:#fff;
    box-shadow:var(--ha-shadow);
  }

  .home-atelier .nav-links.open{
    display:flex;
  }

  .home-atelier .menu-toggle{
    display:inline-grid;
    place-items:center;
  }

  .home-atelier .brand small{
    display:none;
  }

  .atelier-hero{
    padding:50px 0 58px;
  }

  .home-atelier .section{
    padding:62px 0;
  }

  .hero-center h1{
    font-size:clamp(38px,12vw,58px);
  }

  .hero-runway{
    padding:12px;
    border-radius:26px;
  }

  .runway-main,
  .runway-left{
    min-height:320px;
  }

  .runway-main img{
    padding:32px;
  }

  .runway-side,
  .home-atelier .category-board,
  .home-atelier .feat-grid,
  .home-atelier .process,
  .home-atelier .why-grid,
  .home-atelier .foot-grid{
    grid-template-columns:1fr;
  }

  .split-product-stack{
    min-height:auto;
    display:grid;
    gap:14px;
  }

  .stack-card,
  .stack-card.large,
  .stack-card.small,
  .stack-card.top,
  .stack-card.bottom{
    position:relative;
    left:auto;
    right:auto;
    top:auto;
    bottom:auto;
    width:100%;
    height:300px;
  }

  .atelier-cta{
    padding:28px;
    border-radius:26px;
  }

  .atelier-cta form{
    flex-direction:column;
    border-radius:22px;
  }

  .home-atelier .foot-bottom{
    flex-direction:column;
  }
}


/* =========================================================
   FINAL FIX PATCH
   Fix 1: Number badges in Why / Process cards bị style.css gốc đè
   Fix 2: Hero "22 selected products" badge bị tràn ra ngoài
   Fix 3: Hero runway image/card spacing gọn hơn, không bị quá nặng
========================================================= */

/* Make all number badges clean and consistent */
.home-atelier .why-card .num,
.home-atelier .process .step .num,
.home-atelier .atelier-points strong{
  width:46px !important;
  height:46px !important;
  min-width:46px !important;
  min-height:46px !important;
  display:inline-grid !important;
  place-items:center !important;
  border-radius:16px !important;
  background:var(--ha-aqua) !important;
  color:#ffffff !important;
  font-family:Arial, Calibri, Helvetica, sans-serif !important;
  font-size:1rem !important;
  line-height:1 !important;
  font-weight:900 !important;
  letter-spacing:0 !important;
  margin:0 0 18px 0 !important;
  padding:0 !important;
  box-shadow:none !important;
}

/* Process cards: keep the content aligned and remove the oversized old number look */
.home-atelier .process .step{
  min-height:245px;
  display:flex;
  flex-direction:column;
  justify-content:flex-start;
  gap:0;
}

.home-atelier .process .step h3,
.home-atelier .why-card h3{
  margin:0 0 12px 0 !important;
  color:var(--ha-dark) !important;
  font-size:1.25rem !important;
  line-height:1.25 !important;
  letter-spacing:-.025em !important;
}

.home-atelier .process .step p,
.home-atelier .why-card p{
  margin:0 !important;
  color:var(--ha-muted) !important;
  font-size:1rem !important;
  line-height:1.55 !important;
}

/* Why cards: prevent badge clipping and align consistently */
.home-atelier .why-card{
  min-height:230px;
  display:flex;
  flex-direction:column;
  justify-content:flex-start;
}

/* Hero runway: put the 22 selected products badge inside the hero, not outside */
.home-atelier .runway-info{
  position:absolute !important;
  right:34px !important;
  bottom:24px !important;
  width:auto !important;
  height:auto !important;
  min-width:160px !important;
  padding:13px 18px !important;
  display:flex !important;
  flex-direction:row !important;
  align-items:center !important;
  justify-content:center !important;
  gap:10px !important;
  border-radius:999px !important;
  background:#ffffff !important;
  border:1px solid var(--ha-soft-line) !important;
  box-shadow:0 14px 34px rgba(20,37,49,.10) !important;
  z-index:8 !important;
}

.home-atelier .runway-info strong{
  color:var(--ha-aqua) !important;
  font-size:1.7rem !important;
  line-height:1 !important;
  font-weight:900 !important;
}

.home-atelier .runway-info span{
  color:var(--ha-muted) !important;
  font-size:.72rem !important;
  line-height:1.1 !important;
  font-weight:900 !important;
  text-transform:uppercase !important;
}

/* Make runway visual more balanced */
.home-atelier .hero-runway{
  overflow:hidden;
  padding:20px;
  align-items:stretch;
}

.home-atelier .runway-left{
  min-height:360px;
}

.home-atelier .runway-main{
  min-height:360px;
}

.home-atelier .runway-product img{
  padding:30px !important;
}

.home-atelier .runway-main img{
  padding:42px !important;
  max-height:100%;
}

.home-atelier .runway-product span{
  bottom:14px;
  left:18px;
  right:18px;
  max-width:calc(100% - 36px);
}

/* Make image cards less huge on common laptop widths */
@media (max-width:1280px){
  .home-atelier .hero-runway{
    grid-template-columns:250px 1fr 220px;
  }

  .home-atelier .runway-left,
  .home-atelier .runway-main{
    min-height:330px;
  }

  .home-atelier .runway-side .runway-product{
    min-height:155px;
  }

  .home-atelier .runway-main img{
    padding:36px !important;
  }
}

/* Tablet: badge becomes normal block */
@media (max-width:1060px){
  .home-atelier .runway-info{
    position:static !important;
    width:100% !important;
    min-width:0 !important;
    border-radius:22px !important;
    padding:18px !important;
  }

  .home-atelier .process .step{
    min-height:220px;
  }
}

/* Mobile cleanup */
@media (max-width:760px){
  .home-atelier .why-card .num,
  .home-atelier .process .step .num{
    width:42px !important;
    height:42px !important;
    min-width:42px !important;
    min-height:42px !important;
    font-size:.95rem !important;
    border-radius:14px !important;
  }

  .home-atelier .process .step,
  .home-atelier .why-card{
    min-height:auto;
  }

  .home-atelier .runway-left,
  .home-atelier .runway-main{
    min-height:300px;
  }

  .home-atelier .runway-product img,
  .home-atelier .runway-main img{
    padding:26px !important;
  }
}


/* =========================================================
   FINAL HEADER SYNC
   Force index.html header (.home-atelier) to match the other pages
   ========================================================= */

/* Use the same clean header style across index and all sub pages */
.home-atelier .site-header,
.site-header{
  position:sticky;
  top:0;
  z-index:50;
  background:rgba(255,255,255,.96) !important;
  border-bottom:1px solid #e8eef1 !important;
  backdrop-filter:blur(12px) !important;
  -webkit-backdrop-filter:blur(12px) !important;
}

/* Same nav spacing as other pages */
.home-atelier .nav,
.nav{
  display:flex;
  align-items:center;
  justify-content:space-between;
  padding:16px 0 !important;
  min-height:auto !important;
}

/* Logo text: same font and lighter weight */
.home-atelier .brand,
.site-header .brand,
.brand{
  display:flex;
  align-items:center !important;
  gap:10px !important;
  font-family:Arial, Calibri, Helvetica, sans-serif !important;
  font-size:1.22rem !important;
  font-weight:400 !important;
  letter-spacing:.02em !important;
  color:#18242f !important;
}

/* Logo dot: same as normal pages */
.home-atelier .brand .dot,
.site-header .brand .dot,
.brand .dot{
  width:30px !important;
  height:30px !important;
  min-width:30px !important;
  min-height:30px !important;
  display:inline-block !important;
  border-radius:10px !important;
  background:linear-gradient(135deg,#16b8b0,#7ee7e0) !important;
  box-shadow:0 10px 20px rgba(22,184,176,.16) !important;
  position:relative !important;
}

/* Keep the small white dot inside logo mark */
.home-atelier .brand .dot::after,
.site-header .brand .dot::after,
.brand .dot::after{
  content:"" !important;
  display:block !important;
  position:absolute !important;
  width:10px !important;
  height:10px !important;
  border-radius:50% !important;
  right:6px !important;
  top:6px !important;
  background:#fff !important;
}

/* Brand small text: same as sub pages, not bold */
.home-atelier .brand small,
.site-header .brand small,
.brand small{
  font-family:Arial, Calibri, Helvetica, sans-serif !important;
  color:#71808b !important;
  font-size:.65rem !important;
  font-weight:400 !important;
  letter-spacing:.08em !important;
  text-transform:uppercase !important;
}

/* Nav links: remove bold on index, keep consistent with other pages */
.home-atelier .nav-links,
.nav-links{
  display:flex;
  align-items:center;
  gap:8px !important;
}

.home-atelier .nav-links a,
.site-header .nav-links a,
.nav-links a{
  padding:9px 14px !important;
  border-radius:999px !important;
  color:#465763 !important;
  font-family:Arial, Calibri, Helvetica, sans-serif !important;
  font-size:.92rem !important;
  font-weight:400 !important;
  letter-spacing:0 !important;
  position:relative;
}

/* Active/hover only slightly stronger */
.home-atelier .nav-links a:hover,
.home-atelier .nav-links a.active,
.site-header .nav-links a:hover,
.site-header .nav-links a.active,
.nav-links a:hover,
.nav-links a.active{
  color:#07958e !important;
  background:#e9fbfa !important;
  font-weight:500 !important;
}

/* Remove underline active style to keep consistent pill style */
.home-atelier .nav-links a.active::after,
.site-header .nav-links a.active::after,
.nav-links a.active::after{
  display:none !important;
}

/* Cart button: same clean style but not bold */
.home-atelier .cart-btn,
.site-header .cart-btn,
.cart-btn{
  position:relative !important;
  display:inline-flex !important;
  align-items:center !important;
  gap:8px !important;
  padding:9px 16px !important;
  border-radius:999px !important;
  background:#07958e !important;
  color:#ffffff !important;
  border:1px solid #07958e !important;
  font-family:Arial, Calibri, Helvetica, sans-serif !important;
  font-size:.85rem !important;
  font-weight:400 !important;
  letter-spacing:0 !important;
  box-shadow:0 12px 24px rgba(7,149,142,.18) !important;
  transition:transform .2s, background .2s !important;
}

.home-atelier .cart-btn:hover,
.site-header .cart-btn:hover,
.cart-btn:hover{
  background:#067a74 !important;
  transform:translateY(-1px) !important;
}

/* Badge consistent */
.home-atelier .cart-badge,
.site-header .cart-badge,
.cart-badge{
  min-width:20px !important;
  height:20px !important;
  padding:0 6px !important;
  border-radius:999px !important;
  background:#ffffff !important;
  color:#07958e !important;
  font-family:Arial, Calibri, Helvetica, sans-serif !important;
  font-size:.7rem !important;
  font-weight:500 !important;
  align-items:center !important;
  justify-content:center !important;
}

/* Mobile menu consistent */
.home-atelier .menu-toggle,
.site-header .menu-toggle,
.menu-toggle{
  background:none !important;
  border:0 !important;
  font-family:Arial, Calibri, Helvetica, sans-serif !important;
  font-size:1.6rem !important;
  font-weight:400 !important;
  color:#18242f !important;
  cursor:pointer !important;
}

@media (max-width:900px){
  .home-atelier .nav-links,
  .nav-links{
    position:absolute !important;
    top:100% !important;
    left:0 !important;
    right:0 !important;
    flex-direction:column !important;
    gap:0 !important;
    background:#ffffff !important;
    border-bottom:1px solid #e8eef1 !important;
    padding:0 !important;
    max-height:0 !important;
    overflow:hidden !important;
    transition:max-height .35s ease !important;
    box-shadow:0 20px 44px rgba(24,36,47,.08) !important;
  }

  .home-atelier .nav-links.open,
  .nav-links.open{
    max-height:420px !important;
    padding:8px 0 20px !important;
  }

  .home-atelier .nav-links a,
  .nav-links a{
    width:100% !important;
    padding:14px 28px !important;
    border-bottom:1px solid #e8eef1 !important;
    border-radius:0 !important;
  }

  .home-atelier .menu-toggle,
  .menu-toggle{
    display:block !important;
  }
}

.cat-card small {
  display: block;
  margin-top: 8px;
  font-size: 0.82rem;
  line-height: 1.45;
  color: #6b6158;
}

.category-section .category-board {
display: grid;
grid-template-columns: repeat(4, minmax(0, 1fr));
gap: 20px;
}

.category-section .cat-card {
display: flex;
flex-direction: column;
justify-content: flex-start;
min-height: 340px;
padding: 16px;
border-radius: 22px;
background: #ffffff;
border: 1px solid rgba(0, 150, 150, 0.14);
box-shadow: 0 18px 40px rgba(15, 35, 45, 0.08);
text-decoration: none;
overflow: hidden;
}

.category-section .cat-img {
width: 100%;
height: 155px;
border-radius: 18px;
background: #f6fbfb;
display: flex;
align-items: center;
justify-content: center;
overflow: hidden;
}

.category-section .cat-img img {
width: 100%;
height: 100%;
object-fit: contain;
padding: 12px;
}

.category-section .cat-info {
padding-top: 18px;
}

.category-section .cat-info span {
display: block;
font-size: 1.18rem;
line-height: 1.25;
font-weight: 800;
color: #102333;
margin-bottom: 8px;
}

.category-section .cat-info small {
display: block;
font-size: 0.88rem;
line-height: 1.45;
color: #6b7680;
}

.category-section .cat-card:hover {
transform: translateY(-4px);
}

@media (max-width: 1024px) {
.category-section .category-board {
grid-template-columns: repeat(2, minmax(0, 1fr));
}
}

@media (max-width: 560px) {
.category-section .category-board {
grid-template-columns: 1fr;
}

.category-section .cat-card {
min-height: auto;
}
}

.category-section-v2 .category-grid-v2 {
display: grid;
grid-template-columns: repeat(4, minmax(0, 1fr));
gap: 22px;
}

.category-section-v2 .category-tile-v2 {
display: flex;
flex-direction: column;
min-height: 330px;
padding: 16px;
border-radius: 24px;
background: #ffffff;
border: 1px solid rgba(0, 170, 170, 0.18);
box-shadow: 0 18px 42px rgba(15, 35, 45, 0.08);
text-decoration: none;
overflow: hidden;
transition: transform 0.25s ease, box-shadow 0.25s ease, border-color 0.25s ease;
}

.category-section-v2 .category-tile-v2:hover {
transform: translateY(-5px);
border-color: rgba(0, 170, 170, 0.45);
box-shadow: 0 24px 55px rgba(15, 35, 45, 0.12);
}

.category-section-v2 .category-img-v2 {
width: 100%;
height: 190px;
border-radius: 18px;
background: #f6fbfb;
display: flex;
align-items: center;
justify-content: center;
overflow: hidden;
}

.category-section-v2 .category-img-v2 img {
width: 100%;
height: 100%;
object-fit: contain;
padding: 10px;
display: block;
}

.category-section-v2 .category-text-v2 {
padding: 18px 4px 2px;
}

.category-section-v2 .category-text-v2 h3 {
margin: 0 0 8px;
font-size: 1.08rem;
line-height: 1.25;
font-weight: 800;
color: #102333;
}

.category-section-v2 .category-text-v2 p {
margin: 0;
font-size: 0.86rem;
line-height: 1.45;
color: #677681;
}

@media (max-width: 1100px) {
.category-section-v2 .category-grid-v2 {
grid-template-columns: repeat(2, minmax(0, 1fr));
}
}

@media (max-width: 560px) {
.category-section-v2 .category-grid-v2 {
grid-template-columns: 1fr;
}

.category-section-v2 .category-tile-v2 {
min-height: auto;
}

.category-section-v2 .category-img-v2 {
height: 220px;
}
}
