/* =====================================================================
   Diamond Crest Wagyu — theme
   Premium dark + gold, inspired by high-end Wagyu retailers.
   ===================================================================== */

:root{
  --ink:#1a1410;          /* near-black brown */
  --ink-2:#241c16;
  --charcoal:#2c2620;
  --cream:#f6f1e7;
  --cream-2:#efe7d8;
  --gold:#c8a24a;
  --gold-bright:#e3c374;
  --gold-deep:#9c7c2f;
  --wine:#7a1f1f;
  --wine-2:#9c2b22;
  --muted:#8c8378;
  --line:rgba(200,162,74,.25);
  --shadow:0 18px 50px rgba(0,0,0,.35);
  --radius:14px;
  --maxw:1200px;
  --serif:"Playfair Display",Georgia,"Times New Roman",serif;
  --sans:"Inter","Helvetica Neue",Arial,sans-serif;
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;font-family:var(--sans);color:var(--ink);
  background:var(--cream);line-height:1.6;font-size:16px;
  -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:700;line-height:1.15;margin:0 0 .5em}
.container{max-width:var(--maxw);margin:0 auto;padding:0 22px}
.section{padding:72px 0}
.muted{color:var(--muted)}
.center{text-align:center}
.gold{color:var(--gold-deep)}

/* ---------- Buttons ---------- */
.btn{
  display:inline-flex;align-items:center;gap:.5rem;justify-content:center;
  padding:14px 26px;border-radius:999px;font-weight:600;letter-spacing:.02em;
  border:1.5px solid transparent;cursor:pointer;transition:.2s ease;font-size:.95rem;
  font-family:var(--sans);
}
.btn-gold{background:linear-gradient(135deg,var(--gold-bright),var(--gold));color:var(--ink);box-shadow:0 8px 24px rgba(200,162,74,.35)}
.btn-gold:hover{transform:translateY(-2px);box-shadow:0 12px 30px rgba(200,162,74,.45)}
.btn-dark{background:var(--ink);color:var(--cream)}
.btn-dark:hover{background:var(--charcoal)}
.btn-outline{border-color:var(--gold);color:var(--gold-deep);background:transparent}
.btn-outline:hover{background:var(--gold);color:var(--ink)}
.btn-ghost{border-color:rgba(255,255,255,.4);color:#fff}
.btn-ghost:hover{background:rgba(255,255,255,.12)}
.btn-block{width:100%}
.btn-sm{padding:9px 16px;font-size:.85rem}

/* ---------- Header ---------- */
.site-header{position:sticky;top:0;z-index:60;background:var(--ink);color:var(--cream);
  border-bottom:1px solid var(--line)}
.nav{display:flex;align-items:center;justify-content:space-between;height:78px}
.brand{display:flex;align-items:center;gap:12px}
.brand .logo{height:46px;width:auto}
.brand-name{font-family:var(--serif);font-size:1.15rem;letter-spacing:.16em;
  color:var(--gold-bright);text-transform:uppercase}
.brand-name small{display:block;font-size:.6rem;letter-spacing:.4em;color:var(--cream-2);font-family:var(--sans)}
.menu{display:flex;align-items:center;gap:28px;list-style:none;margin:0;padding:0}
.menu a{font-size:.82rem;letter-spacing:.12em;text-transform:uppercase;color:var(--cream-2);transition:.2s}
.menu a:hover,.menu a.active{color:var(--gold-bright)}
.nav-actions{display:flex;align-items:center;gap:18px}
.cart-link{position:relative;color:var(--cream-2)}
.cart-link:hover{color:var(--gold-bright)}
.cart-badge{position:absolute;top:-8px;right:-10px;background:var(--wine-2);color:#fff;
  font-size:.65rem;font-weight:700;min-width:18px;height:18px;border-radius:9px;
  display:flex;align-items:center;justify-content:center;padding:0 4px}
.nav-toggle{display:none;background:none;border:0;color:var(--cream);cursor:pointer}
.nav-toggle svg{width:26px;height:26px}

/* ---------- Hero ---------- */
.hero{position:relative;background:var(--ink);color:var(--cream);overflow:hidden}
.hero::before{content:"";position:absolute;inset:0;
  background:radial-gradient(1100px 500px at 70% -10%,rgba(200,162,74,.20),transparent 60%);}
.hero-inner{position:relative;display:grid;grid-template-columns:1.05fr .95fr;gap:40px;
  align-items:center;padding:90px 0}
.hero .eyebrow{letter-spacing:.34em;text-transform:uppercase;font-size:.72rem;
  color:var(--gold-bright);margin-bottom:18px}
.hero h1{font-size:clamp(2.4rem,5vw,4rem);color:var(--cream)}
.hero h1 em{color:var(--gold-bright);font-style:normal}
.hero p{color:var(--cream-2);font-size:1.08rem;max-width:46ch;margin:18px 0 30px}
.hero-cta{display:flex;gap:14px;flex-wrap:wrap}
.hero-art{position:relative;border-radius:var(--radius);overflow:hidden;
  aspect-ratio:4/5;box-shadow:var(--shadow);border:1px solid var(--line)}
.hero-art .marble{position:absolute;inset:0;
  background:
   radial-gradient(circle at 30% 30%,rgba(255,255,255,.10) 0 8%,transparent 9%),
   radial-gradient(circle at 60% 50%,rgba(255,255,255,.08) 0 6%,transparent 7%),
   linear-gradient(135deg,#6e2a26,#3c1714 70%);}

/* ---------- Hotel CTA band ---------- */
.hotels{background:var(--ink-2);color:var(--cream);border-top:1px solid var(--line);
  border-bottom:1px solid var(--line)}
.hotels-grid{display:grid;grid-template-columns:1fr 1fr;gap:24px;padding:56px 0}
.hotel-card{border:1px solid var(--line);border-radius:var(--radius);padding:34px;
  background:linear-gradient(160deg,rgba(200,162,74,.08),transparent);text-align:center;
  transition:.25s}
.hotel-card:hover{transform:translateY(-4px);border-color:var(--gold)}
.hotel-card .eyebrow{letter-spacing:.3em;font-size:.68rem;color:var(--gold-bright);text-transform:uppercase}
.hotel-card h3{color:var(--cream);font-size:1.6rem;margin:10px 0 16px}

/* ---------- Section headings ---------- */
.section-head{text-align:center;max-width:680px;margin:0 auto 46px}
.section-head .eyebrow{letter-spacing:.32em;text-transform:uppercase;font-size:.72rem;
  color:var(--gold-deep);margin-bottom:12px}
.section-head h2{font-size:clamp(1.9rem,3.5vw,2.7rem)}

/* ---------- Product grid ---------- */
.product-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:26px}
.product-grid.cols-2{grid-template-columns:repeat(2,1fr)}
.card{background:#fff;border-radius:var(--radius);overflow:hidden;border:1px solid #e7ddca;
  display:flex;flex-direction:column;transition:.25s;box-shadow:0 6px 20px rgba(26,20,16,.05)}
.card:hover{transform:translateY(-5px);box-shadow:0 16px 38px rgba(26,20,16,.14)}
.card-media{position:relative;aspect-ratio:1/1;overflow:hidden;background:#efe7d8}
.card-media img{width:100%;height:100%;object-fit:cover;transition:.4s}
.card:hover .card-media img{transform:scale(1.06)}
.badges{position:absolute;top:12px;left:12px;display:flex;flex-direction:column;gap:6px;z-index:2}
.badge{font-size:.66rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;
  padding:5px 11px;border-radius:999px;color:#fff}
.badge-seller{background:var(--gold-deep)}
.badge-fast{background:var(--wine-2)}
.badge-soldout{background:#555}
.card-body{padding:18px 18px 22px;display:flex;flex-direction:column;flex:1}
.card-breed{font-size:.66rem;letter-spacing:.18em;text-transform:uppercase;color:var(--gold-deep);margin-bottom:6px}
.card-title{font-family:var(--serif);font-size:1.18rem;margin:0 0 4px;color:var(--ink)}
.card-weight{font-size:.8rem;color:var(--muted);margin-bottom:12px}
.card-foot{margin-top:auto;display:flex;align-items:center;justify-content:space-between;gap:10px}
.price{font-weight:700;font-size:1.15rem;color:var(--ink)}
.price .was{color:var(--muted);text-decoration:line-through;font-weight:500;font-size:.9rem;margin-right:6px}
.stars{color:var(--gold);letter-spacing:2px;font-size:.95rem}

/* ---------- Shop layout ---------- */
.shop-wrap{display:grid;grid-template-columns:230px 1fr;gap:36px;align-items:start}
.shop-side h4{font-size:.78rem;letter-spacing:.18em;text-transform:uppercase;color:var(--gold-deep);
  border-bottom:1px solid var(--line);padding-bottom:10px;margin-bottom:14px}
.cat-list{list-style:none;margin:0 0 28px;padding:0}
.cat-list li{margin-bottom:4px}
.cat-list a{display:block;padding:9px 12px;border-radius:8px;font-size:.92rem;color:var(--charcoal)}
.cat-list a:hover,.cat-list a.active{background:var(--ink);color:var(--gold-bright)}
.shop-toolbar{display:flex;justify-content:space-between;align-items:center;margin-bottom:24px;
  flex-wrap:wrap;gap:12px}
.shop-toolbar select{padding:10px 14px;border-radius:8px;border:1px solid #d9cdb4;background:#fff;font-family:var(--sans)}

/* ---------- Product detail ---------- */
.pd{display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:start}
.pd-media{border-radius:var(--radius);overflow:hidden;aspect-ratio:1/1;background:#efe7d8;border:1px solid #e7ddca}
.pd-media img{width:100%;height:100%;object-fit:cover}
.pd h1{font-size:2.4rem;margin:6px 0 10px}
.pd .price{font-size:1.7rem}
.pd .breed{font-size:.74rem;letter-spacing:.2em;text-transform:uppercase;color:var(--gold-deep)}
.pd .desc{margin:22px 0;color:#3f372e}
.qty-row{display:flex;align-items:center;gap:14px;margin:22px 0}
.qty-input{width:84px;padding:12px;border:1px solid #d9cdb4;border-radius:8px;font-size:1rem;text-align:center}
.meta-list{list-style:none;padding:0;margin:24px 0 0;border-top:1px solid var(--line)}
.meta-list li{display:flex;justify-content:space-between;padding:11px 0;border-bottom:1px solid var(--line);font-size:.92rem}

/* ---------- Cart / checkout ---------- */
.table{width:100%;border-collapse:collapse;background:#fff;border-radius:var(--radius);overflow:hidden}
.table th,.table td{padding:14px 16px;text-align:left;border-bottom:1px solid #ece3d2;font-size:.92rem}
.table th{background:var(--ink);color:var(--cream-2);font-size:.72rem;letter-spacing:.12em;text-transform:uppercase}
.cart-thumb{width:64px;height:64px;border-radius:8px;object-fit:cover}
.cart-layout{display:grid;grid-template-columns:1fr 360px;gap:34px;align-items:start}
.summary{background:#fff;border:1px solid #e7ddca;border-radius:var(--radius);padding:26px}
.summary h3{font-size:1.3rem;margin-bottom:18px}
.summary-row{display:flex;justify-content:space-between;padding:9px 0;font-size:.95rem}
.summary-row.total{border-top:1px solid var(--line);margin-top:10px;padding-top:16px;font-size:1.2rem;font-weight:700}
.field{margin-bottom:16px}
.field label{display:block;font-size:.8rem;letter-spacing:.06em;text-transform:uppercase;color:var(--charcoal);margin-bottom:6px}
.field input,.field textarea,.field select{width:100%;padding:12px 14px;border:1px solid #d9cdb4;
  border-radius:9px;font-family:var(--sans);font-size:.95rem;background:#fff}
.field textarea{min-height:110px;resize:vertical}
.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.form-card{background:#fff;border:1px solid #e7ddca;border-radius:var(--radius);padding:30px}

/* ---------- Alerts ---------- */
.alert{padding:14px 18px;border-radius:10px;margin-bottom:20px;font-size:.92rem}
.alert-success{background:#e8f3e3;color:#2c5320;border:1px solid #b9d8a9}
.alert-error{background:#f8e6e4;color:#7a1f1f;border:1px solid #e3b3ad}
.errors{background:#f8e6e4;color:#7a1f1f;border:1px solid #e3b3ad;border-radius:10px;padding:12px 16px;margin-bottom:18px;font-size:.9rem}

/* ---------- About ---------- */
.about-hero{background:var(--ink);color:var(--cream);text-align:center;padding:90px 0}
.about-hero h1{color:var(--cream);font-size:clamp(2.2rem,4.5vw,3.4rem)}
.about-hero p{color:var(--cream-2);max-width:60ch;margin:16px auto 0}
.values{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.value{background:#fff;border:1px solid #e7ddca;border-radius:var(--radius);padding:30px;text-align:center}
.value .ico{width:54px;height:54px;margin:0 auto 16px;border-radius:50%;
  background:linear-gradient(135deg,var(--gold-bright),var(--gold));display:flex;align-items:center;justify-content:center;color:var(--ink);font-weight:700;font-size:1.3rem;font-family:var(--serif)}

/* ---------- Footer ---------- */
.site-footer{background:var(--ink);color:var(--cream-2);padding:60px 0 28px;margin-top:80px}
.footer-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr 1.2fr;gap:34px}
.site-footer h5{font-family:var(--serif);color:var(--gold-bright);font-size:1.05rem;margin-bottom:16px}
.site-footer ul{list-style:none;padding:0;margin:0}
.site-footer li{margin-bottom:9px}
.site-footer a:hover{color:var(--gold-bright)}
.footer-bottom{border-top:1px solid var(--line);margin-top:40px;padding-top:22px;
  display:flex;justify-content:space-between;flex-wrap:wrap;gap:10px;font-size:.82rem;color:var(--muted)}

/* ---------- Admin ---------- */
.admin-body{background:#f1ece2}
.admin-shell{display:grid;grid-template-columns:240px 1fr;min-height:100vh}
.admin-side{background:var(--ink);color:var(--cream-2);padding:26px 18px}
.admin-side .brand-name{font-size:1rem}
.admin-nav{list-style:none;padding:0;margin:28px 0 0}
.admin-nav a{display:flex;justify-content:space-between;padding:12px 14px;border-radius:9px;font-size:.92rem;margin-bottom:4px}
.admin-nav a:hover,.admin-nav a.active{background:var(--charcoal);color:var(--gold-bright)}
.admin-main{padding:34px}
.admin-topbar{display:flex;justify-content:space-between;align-items:center;margin-bottom:28px}
.stat-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:20px;margin-bottom:34px}
.stat{background:#fff;border:1px solid #e2d8c5;border-radius:var(--radius);padding:22px}
.stat .n{font-family:var(--serif);font-size:2rem;color:var(--ink)}
.stat .l{font-size:.76rem;letter-spacing:.12em;text-transform:uppercase;color:var(--muted)}
.panel{background:#fff;border:1px solid #e2d8c5;border-radius:var(--radius);padding:26px;margin-bottom:24px}
.pill{font-size:.7rem;font-weight:700;padding:4px 10px;border-radius:999px;text-transform:uppercase;letter-spacing:.06em}
.pill-pending{background:#fdeccd;color:#8a5b00}
.pill-paid{background:#d8ecff;color:#1c5a9c}
.pill-shipped{background:#e4d8ff;color:#5a3aa0}
.pill-completed{background:#dff0d8;color:#2c5320}
.pill-cancelled{background:#f4d6d3;color:#7a1f1f}

/* ---------- Login ---------- */
.login-wrap{min-height:100vh;display:flex;align-items:center;justify-content:center;
  background:var(--ink);padding:24px}
.login-card{background:#fff;border-radius:18px;padding:42px;width:100%;max-width:400px;box-shadow:var(--shadow)}
.login-card h1{font-size:1.6rem;text-align:center;margin-bottom:4px}
.login-card .sub{text-align:center;color:var(--muted);font-size:.85rem;margin-bottom:26px}

/* ---------- Responsive ---------- */
@media(max-width:1000px){
  .product-grid{grid-template-columns:repeat(3,1fr)}
  .footer-grid{grid-template-columns:1fr 1fr}
  .admin-shell{grid-template-columns:1fr}
  .admin-side{display:none}
}
@media(max-width:860px){
  .menu{display:none;position:absolute;top:78px;left:0;right:0;background:var(--ink);
    flex-direction:column;gap:0;padding:10px 0;border-bottom:1px solid var(--line)}
  .menu.open{display:flex}
  .menu li{width:100%}
  .menu a{display:block;padding:14px 22px}
  .nav-toggle{display:block}
  .hero-inner{grid-template-columns:1fr;padding:60px 0}
  .hero-art{display:none}
  .hotels-grid,.pd,.cart-layout,.shop-wrap{grid-template-columns:1fr}
  .product-grid{grid-template-columns:repeat(2,1fr)}
  .values,.stat-grid{grid-template-columns:1fr}
  .stat-grid{grid-template-columns:repeat(2,1fr)}
}
@media(max-width:520px){
  .product-grid,.product-grid.cols-2{grid-template-columns:1fr 1fr;gap:14px}
  .grid-2{grid-template-columns:1fr}
  .section{padding:48px 0}
}

/* =====================================================================
   v2 additions — toasts, announcement bar, stars, search, polish
   ===================================================================== */

/* ---------- Announcement bar ---------- */
.announce{background:var(--gold-deep);color:#fff;text-align:center;font-size:.8rem;
  letter-spacing:.08em;padding:9px 16px;font-weight:500}
.announce strong{color:#fff}

/* ---------- Toasts ---------- */
.toast-wrap{position:fixed;top:18px;right:18px;z-index:9999;display:flex;flex-direction:column;gap:10px;max-width:340px}
.toast{display:flex;align-items:flex-start;gap:10px;background:#fff;color:var(--ink);
  border:1px solid #e7ddca;border-left:4px solid var(--gold);border-radius:12px;
  padding:13px 14px;box-shadow:0 12px 34px rgba(26,20,16,.22);
  opacity:0;transform:translateX(20px);transition:opacity .3s,transform .3s;font-size:.9rem}
.toast.show{opacity:1;transform:translateX(0)}
.toast-success{border-left-color:#2c7a2c}
.toast-error{border-left-color:var(--wine-2)}
.toast-info{border-left-color:var(--gold)}
.toast-ico{flex:0 0 22px;width:22px;height:22px;border-radius:50%;color:#fff;display:flex;
  align-items:center;justify-content:center;font-weight:700;font-size:.8rem;margin-top:1px}
.toast-success .toast-ico{background:#2c7a2c}
.toast-error .toast-ico{background:var(--wine-2)}
.toast-info .toast-ico{background:var(--gold-deep)}
.toast-msg{flex:1;line-height:1.4}
.toast-x{background:none;border:0;color:var(--muted);font-size:1.2rem;line-height:1;cursor:pointer;padding:0 2px}
.toast-x:hover{color:var(--ink)}
@media(max-width:520px){.toast-wrap{left:12px;right:12px;top:12px;max-width:none}}

/* ---------- Star ratings ---------- */
.rating{display:flex;align-items:center;gap:6px;margin-bottom:10px}
.rating .stars{color:var(--gold);letter-spacing:1px;font-size:.95rem;line-height:1}
.rating .stars .empty{color:#d8ccb4}
.rating .count{font-size:.78rem;color:var(--muted)}

/* ---------- Card add button + loading ---------- */
.card .card-foot .btn{white-space:nowrap}
.btn.is-loading{position:relative;color:transparent !important;pointer-events:none}
.btn.is-loading::after{content:"";position:absolute;width:16px;height:16px;border-radius:50%;
  border:2px solid rgba(0,0,0,.25);border-top-color:rgba(0,0,0,.7);
  left:50%;top:50%;margin:-8px 0 0 -8px;animation:dcwspin .6s linear infinite}
.btn-gold.is-loading::after{border-color:rgba(26,20,16,.3);border-top-color:var(--ink)}
@keyframes dcwspin{to{transform:rotate(360deg)}}

.cart-badge.pop{animation:badgepop .35s ease}
@keyframes badgepop{0%{transform:scale(1)}40%{transform:scale(1.45)}100%{transform:scale(1)}}

/* ---------- Search + price filter ---------- */
.search-bar{display:flex;gap:8px;margin-bottom:18px}
.search-bar input{flex:1;padding:11px 14px;border:1px solid #d9cdb4;border-radius:9px;font-family:var(--sans)}
.filter-box{border-top:1px solid var(--line);padding-top:16px;margin-top:6px}
.filter-box .row{display:flex;gap:8px;margin-bottom:10px}
.filter-box input{width:100%;padding:9px 10px;border:1px solid #d9cdb4;border-radius:8px}
.price-presets{display:flex;flex-direction:column;gap:4px;margin-bottom:14px}
.price-presets a{font-size:.88rem;padding:7px 12px;border-radius:8px;color:var(--charcoal)}
.price-presets a:hover{background:var(--ink);color:var(--gold-bright)}
.active-filter{display:inline-flex;align-items:center;gap:6px;background:var(--ink);color:var(--gold-bright);
  font-size:.8rem;padding:5px 12px;border-radius:999px;margin-bottom:14px}
.active-filter a{color:var(--cream-2);font-weight:700}

/* ---------- Field error state ---------- */
.field.has-error input,.field.has-error textarea,.field.has-error select{border-color:var(--wine-2);background:#fdf4f3}
.field.has-error label{color:var(--wine-2)}

/* ---------- Free shipping progress ---------- */
.ship-progress{margin:6px 0 20px}
.ship-progress .track{height:8px;background:#e7ddca;border-radius:999px;overflow:hidden}
.ship-progress .bar{height:100%;width:0;background:linear-gradient(90deg,var(--gold),var(--gold-bright));transition:width .3s}
.ship-progress .note{font-size:.8rem;color:var(--gold-deep);margin-top:8px;font-weight:600}

/* ---------- Cart qty control ---------- */
.qty-control{display:inline-flex;align-items:center;border:1px solid #d9cdb4;border-radius:8px;overflow:hidden}
.qty-control button{width:30px;height:34px;border:0;background:#f3ecdd;cursor:pointer;font-size:1rem;color:var(--ink)}
.qty-control button:hover{background:var(--gold);color:#fff}
.qty-control input{width:46px;height:34px;border:0;border-left:1px solid #e3d8c2;border-right:1px solid #e3d8c2;text-align:center;font-size:.95rem}

/* ---------- Trust strip / shipping icons ---------- */
.trust-strip{background:#fff;border-top:1px solid #ece3d2;border-bottom:1px solid #ece3d2}
.trust-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:20px;padding:30px 0;text-align:center}
.trust-grid .t .ico{font-size:1.5rem;color:var(--gold-deep)}
.trust-grid .t h4{font-family:var(--sans);font-size:.92rem;margin:8px 0 2px}
.trust-grid .t p{font-size:.78rem;color:var(--muted);margin:0}
@media(max-width:760px){.trust-grid{grid-template-columns:1fr 1fr}}

/* ---------- Testimonials ---------- */
.testimonials{background:var(--ink-2);color:var(--cream)}
.testi-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.testi{border:1px solid var(--line);border-radius:var(--radius);padding:26px;background:linear-gradient(160deg,rgba(200,162,74,.06),transparent)}
.testi .stars{color:var(--gold-bright);letter-spacing:2px;margin-bottom:10px}
.testi p{color:var(--cream-2);font-style:italic;margin:0 0 14px}
.testi .who{font-family:var(--serif);color:var(--gold-bright);font-size:.95rem}
@media(max-width:760px){.testi-grid{grid-template-columns:1fr}}

/* ---------- FAQ ---------- */
.faq{max-width:760px;margin:0 auto}
.faq details{border-bottom:1px solid var(--line);padding:16px 0}
.faq summary{cursor:pointer;font-family:var(--serif);font-size:1.12rem;list-style:none;display:flex;justify-content:space-between;align-items:center}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{content:"+";color:var(--gold-deep);font-size:1.4rem;line-height:1}
.faq details[open] summary::after{content:"–"}
.faq p{color:#4a4136;margin:12px 0 0}

/* ---------- Wire-transfer payment box ---------- */
.pay-box{background:#faf6ee;border:1px solid #e7ddca;border-radius:12px;padding:18px}
.pay-box-title{font-weight:700;font-size:.9rem;margin:0 0 12px;color:var(--ink)}
.pay-accounts{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.pay-account{background:#fff;border:1px solid #ece3d2;border-radius:10px;padding:12px 14px;display:flex;flex-direction:column;gap:2px}
.pay-account strong{font-size:.82rem;color:var(--gold-deep);text-transform:uppercase;letter-spacing:.06em;margin-bottom:4px}
.pay-account span{font-size:.86rem;color:#3f372e}
@media(max-width:520px){.pay-accounts{grid-template-columns:1fr}}

/* ---------- AOS fallback (in case CDN fails, content still visible) ---------- */
[data-aos]{transition-property:transform,opacity}
.no-aos [data-aos]{opacity:1 !important;transform:none !important}

/* =====================================================================
   Diamond Concierge — AI Chat Widget
   ===================================================================== */
.chat-widget{position:fixed;bottom:28px;right:28px;z-index:9000;display:flex;flex-direction:column;align-items:flex-end;gap:12px}

/* Toggle bubble */
.chat-toggle{
  width:58px;height:58px;border-radius:50%;border:none;cursor:pointer;
  background:linear-gradient(135deg,var(--gold-bright),var(--gold));
  color:var(--ink);box-shadow:0 6px 24px rgba(200,162,74,.5);
  display:flex;align-items:center;justify-content:center;
  transition:transform .2s,box-shadow .2s;
}
.chat-toggle:hover{transform:scale(1.08);box-shadow:0 10px 30px rgba(200,162,74,.6)}
.chat-ico--close{display:none}
.chat-widget.is-open .chat-ico--open{display:none}
.chat-widget.is-open .chat-ico--close{display:block}

/* Panel */
.chat-panel{
  width:360px;max-height:520px;border-radius:18px;overflow:hidden;
  background:var(--ink);border:1px solid var(--line);
  box-shadow:0 24px 60px rgba(0,0,0,.55);
  display:flex;flex-direction:column;
  animation:chatSlideUp .25s cubic-bezier(.22,.68,0,1.2);
}
@keyframes chatSlideUp{from{opacity:0;transform:translateY(18px) scale(.97)}to{opacity:1;transform:none}}

/* Header */
.chat-header{
  display:flex;align-items:center;gap:12px;
  padding:14px 16px;background:var(--ink-2);border-bottom:1px solid var(--line);
  flex-shrink:0;
}
.chat-avatar{
  width:38px;height:38px;border-radius:50%;flex-shrink:0;
  background:linear-gradient(135deg,var(--gold-bright),var(--gold));
  color:var(--ink);font-size:1rem;font-weight:700;
  display:flex;align-items:center;justify-content:center;
}
.chat-title{font-family:var(--serif);font-weight:700;color:var(--gold-bright);font-size:.95rem}
.chat-subtitle{font-size:.72rem;color:var(--muted);letter-spacing:.02em;margin-top:1px}

/* Messages */
.chat-messages{
  flex:1;overflow-y:auto;padding:16px 14px;
  display:flex;flex-direction:column;gap:10px;
  scrollbar-width:thin;scrollbar-color:var(--charcoal) transparent;
}
.chat-messages::-webkit-scrollbar{width:4px}
.chat-messages::-webkit-scrollbar-track{background:transparent}
.chat-messages::-webkit-scrollbar-thumb{background:var(--charcoal);border-radius:4px}

.chat-bubble{
  max-width:88%;padding:10px 14px;border-radius:14px;
  font-size:.875rem;line-height:1.55;word-break:break-word;
}
.chat-bubble--ai{
  background:var(--charcoal);color:var(--cream-2);
  border-bottom-left-radius:4px;align-self:flex-start;
}
.chat-bubble--user{
  background:linear-gradient(135deg,var(--gold-bright),var(--gold));
  color:var(--ink);font-weight:500;
  border-bottom-right-radius:4px;align-self:flex-end;
}
.chat-bubble--lead{
  background:rgba(200,162,74,.12);border:1px solid var(--line);
  color:var(--gold);font-size:.78rem;text-align:center;
  align-self:center;max-width:96%;border-radius:8px;padding:7px 12px;
}

/* Typing indicator */
.chat-typing{display:flex;gap:5px;align-items:center;padding:10px 14px;align-self:flex-start}
.chat-typing span{width:7px;height:7px;border-radius:50%;background:var(--muted);animation:chatDot 1.2s infinite}
.chat-typing span:nth-child(2){animation-delay:.2s}
.chat-typing span:nth-child(3){animation-delay:.4s}
@keyframes chatDot{0%,80%,100%{transform:scale(.7);opacity:.4}40%{transform:scale(1);opacity:1}}

/* Input form */
.chat-form{
  display:flex;align-items:center;gap:8px;
  padding:10px 12px;border-top:1px solid var(--line);flex-shrink:0;
}
.chat-input{
  flex:1;background:var(--charcoal);border:1px solid rgba(200,162,74,.2);
  border-radius:999px;padding:9px 16px;font-size:.875rem;
  color:var(--cream);font-family:var(--sans);outline:none;
  transition:border-color .2s;
}
.chat-input::placeholder{color:var(--muted)}
.chat-input:focus{border-color:var(--gold)}
.chat-send{
  width:38px;height:38px;border-radius:50%;border:none;cursor:pointer;flex-shrink:0;
  background:linear-gradient(135deg,var(--gold-bright),var(--gold));
  color:var(--ink);display:flex;align-items:center;justify-content:center;
  transition:.2s;
}
.chat-send:hover{transform:scale(1.08)}
.chat-send:disabled{opacity:.5;cursor:not-allowed;transform:none}

@media(max-width:420px){
  .chat-widget{bottom:16px;right:14px}
  .chat-panel{width:calc(100vw - 28px);max-height:60vh}
}
