/* FACTORAHUB — MAIN.CSS | v2.2-STABLE | AdSense Ready */

/* ── BASE RESET ───────────────────────────────────────────── */
*,::before,::after{box-sizing:border-box;border-width:0;border-style:solid;border-color:#e5e7eb}
html{line-height:1.5;-webkit-text-size-adjust:100%;tab-size:4;font-family:ui-sans-serif,system-ui,-apple-system,sans-serif;scroll-behavior:smooth}
body{margin:0;line-height:inherit;background-color:#fafafa;color:#1a1a1a;font-size:18px}
/* ── SHIMMER AD ENGINE — Always-On Shimmer (not hover-gated) ── */
.shimmer-ad-hook{
  background: linear-gradient(90deg, #fafafa 25%, #fff7e6 50%, #fafafa 75%);
  background-size: 200% 100%;
  animation: bloomberg-shimmer 2s infinite linear;
  border: 1px solid #d4af37;
  position: relative;
  overflow: hidden;
  border-radius: 1rem;
}
@keyframes bloomberg-shimmer{0%{background-position:200% 0}100%{background-position:-200% 0}}
.shimmer-sweep{display:none;}
/* Content cards min-padding */
.adv-card,.editorial-body,[class*="p-8"],[class*="p-10"]{min-padding:20px}
hr{height:0;color:inherit;border-top-width:1px}
a{color:inherit;text-decoration:inherit}
b,strong{font-weight:bolder}
button,input,optgroup,select,textarea{font-family:inherit;font-size:100%;font-weight:inherit;line-height:inherit;color:inherit;margin:0;padding:0}
button,select{text-transform:none}
button,[type='button'],[type='reset'],[type='submit']{-webkit-appearance:button;background-color:transparent;background-image:none;cursor:pointer}
:-moz-focusring{outline:auto}
:-moz-ui-invalid{box-shadow:none}
::placeholder{opacity:1;color:#9ca3af}
:disabled{cursor:default}
img,svg,video,canvas,audio,iframe,embed,object{display:block;vertical-align:middle}
img,video{max-width:100%;height:auto}
[hidden]{display:none}

/* ── LAYOUT ───────────────────────────────────────────────── */
.container{width:100%;margin-left:auto;margin-right:auto;padding-left:1.5rem;padding-right:1.5rem}
@media (min-width:768px){.container{max-width:768px}}
@media (min-width:1024px){.container{max-width:1024px}}
@media (min-width:1280px){.container{max-width:1400px}}
@media (min-width:1536px){.container{max-width:1400px}}

.mx-auto{margin-left:auto;margin-right:auto}
.max-w-4xl{max-width:56rem}
.max-w-5xl{max-width:64rem}
.max-w-xl{max-width:36rem}
.max-w-2xl{max-width:42rem}
.max-w-3xl{max-width:48rem}
.max-w-sm{max-width:24rem}
.min-h-screen{min-height:100vh}

/* ── FLEX ─────────────────────────────────────────────────── */
.flex{display:flex}
.inline-flex{display:inline-flex}
.flex-col{flex-direction:column}
.flex-row{flex-direction:row}
.flex-wrap{flex-wrap:wrap}
.items-start{align-items:flex-start}
.items-center{align-items:center}
.items-end{align-items:flex-end}
.items-stretch{align-items:stretch}
.justify-start{justify-content:flex-start}
.justify-center{justify-content:center}
.justify-end{justify-content:flex-end}
.justify-between{justify-content:space-between}
.justify-around{justify-content:space-around}
.flex-1{flex:1 1 0%}
.flex-shrink-0{flex-shrink:0}
.shrink-0{flex-shrink:0}
.grow{flex-grow:1}
.flex-grow{flex-grow:1}

/* ── GRID ─────────────────────────────────────────────────── */
.grid{display:grid}
.grid-cols-1{grid-template-columns:repeat(1,minmax(0,1fr))}
.grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}
.grid-cols-3{grid-template-columns:repeat(3,minmax(0,1fr))}
.grid-cols-4{grid-template-columns:repeat(4,minmax(0,1fr))}
@media (min-width:768px){
  .md\:grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}
  .md\:grid-cols-3{grid-template-columns:repeat(3,minmax(0,1fr))}
  .md\:grid-cols-4{grid-template-columns:repeat(4,minmax(0,1fr))}
}
@media (min-width:1024px){
  .lg\:grid-cols-3{grid-template-columns:repeat(3,minmax(0,1fr))}
  .lg\:grid-cols-4{grid-template-columns:repeat(4,minmax(0,1fr))}
  .lg\:col-span-3{grid-column:span 3/span 3}
  .lg\:col-span-4{grid-column:span 4/span 4}
  .lg\:col-span-6{grid-column:span 6/span 6}
  .lg\:col-span-8{grid-column:span 8/span 8}
  .lg\:col-span-12{grid-column:span 12/span 12}
  .lg\:grid-cols-12{grid-template-columns:repeat(12,minmax(0,1fr))}
}
.col-span-1{grid-column:span 1/span 1}

/* ── DISPLAY ──────────────────────────────────────────────── */
.block{display:block}
.inline-block{display:inline-block}
.inline{display:inline}
.hidden{display:none}
.overflow-hidden{overflow:hidden}
.overflow-x-hidden{overflow-x:hidden}
.relative{position:relative}
.absolute{position:absolute}
.fixed{position:fixed}
.sticky{position:sticky}
.inset-0{top:0;right:0;bottom:0;left:0}
.top-0{top:0}
.bottom-0{bottom:0}
.left-0{left:0}
.right-0{right:0}
.top-4{top:1rem}
.bottom-4{bottom:1rem}
.right-4{right:1rem}
.left-1\/2{left:50%}
.top-1\/2{top:50%}
.top-32{top:8rem}
.z-0{z-index:0}
.z-10{z-index:10}
.z-20{z-index:20}
.z-30{z-index:30}
.z-50{z-index:50}
.z-\[999\]{z-index:999}
.z-\[1000\]{z-index:1000}
.z-\[9999\]{z-index:9999}
.z-\[9999999\]{z-index:9999999}
.z-\[10000\]{z-index:10000}
.z-\[10001\]{z-index:10001}

/* ── SIZING ───────────────────────────────────────────────── */
.w-full{width:100%}
.w-1\/2{width:50%}
.w-2{width:.5rem}
.w-4{width:1rem}
.w-8{width:2rem}
.w-10{width:2.5rem}
.w-12{width:3rem}
.w-14{width:3.5rem}
.w-16{width:4rem}
.w-20{width:5rem}
.w-48{width:12rem}
.w-\[100vw\]{width:100vw}
.w-\[72\%\]{width:72%}
.w-\[28\%\]{width:28%}
.h-full{height:100%}
.h-\[1px\]{height:1px}
.h-\[2px\]{height:.125rem}
.h-1{height:.25rem}
.h-2\.5{height:.625rem}
.h-3{height:.75rem}
.h-8{height:2rem}
.h-10{height:2.5rem}
.h-12{height:3rem}
.h-14{height:3.5rem}
.h-16{height:4rem}
.h-20{height:5rem}
.h-48{height:12rem}
.h-\[70vh\]{height:70vh}
.h-\[305px\]{height:305px}
.h-\[650px\]{height:650px}
.min-h-\[500px\]{min-height:500px}
.min-h-\[600px\]{min-height:600px}
.min-h-\[70px\]{min-height:70px}
.aspect-video{aspect-ratio:16/9}
.aspect-\[4\/3\]{aspect-ratio:4/3}
.aspect-\[16\/9\]{aspect-ratio:16/9}
.max-w-\[200px\]{max-width:200px}
.max-w-\[1400px\]{max-width:1400px;margin-left:auto;margin-right:auto}
.article-body{font-size:1.1rem;line-height:1.8;color:#333;font-weight:400}
.article-body p{margin-bottom:1.5rem}
.article-body h2{font-size:1.8rem;font-weight:900;margin-top:2.5rem;margin-bottom:1.2rem;text-transform:uppercase;color:#111;letter-spacing:-0.02em}
.article-body h3{font-size:1.5rem;font-weight:900;margin-top:2rem;margin-bottom:1rem;text-transform:uppercase;color:#111}
.grid-equal-height{display:grid;grid-auto-rows:1fr}
.flex-equal-height{display:flex;align-items:stretch}

/* ── SPACING — PADDING ────────────────────────────────────── */
.p-0{padding:0}
.p-6{padding:1.5rem}
.p-8{padding:2rem}
.p-10{padding:2.5rem}
.p-12{padding:3rem}
.p-16{padding:4rem}
.p-24{padding:6rem}
.px-3{padding-left:.75rem;padding-right:.75rem}
.px-4{padding-left:1rem;padding-right:1rem}
.px-6{padding-left:1.5rem;padding-right:1.5rem}
.px-8{padding-left:2rem;padding-right:2rem}
.px-14{padding-left:3.5rem;padding-right:3.5rem}
.px-16{padding-left:4rem;padding-right:4rem}
.py-1\.5{padding-top:.375rem;padding-bottom:.375rem}
.py-2{padding-top:.5rem;padding-bottom:.5rem}
.py-2\.5{padding-top:.625rem;padding-bottom:.625rem}
.py-3{padding-top:.75rem;padding-bottom:.75rem}
.py-4{padding-top:1rem;padding-bottom:1rem}
.py-5{padding-top:1.25rem;padding-bottom:1.25rem}
.py-6{padding-top:1.5rem;padding-bottom:1.5rem}
.py-8{padding-top:2rem;padding-bottom:2rem}
.py-10{padding-top:2.5rem;padding-bottom:2.5rem}
.py-12{padding-top:3rem;padding-bottom:3rem}
.py-16{padding-top:4rem;padding-bottom:4rem}
.py-24{padding-top:6rem;padding-bottom:6rem}
.py-32{padding-top:8rem;padding-bottom:8rem}
.py-40{padding-top:10rem;padding-bottom:10rem}
.pt-4{padding-top:1rem}
.pt-6{padding-top:1.5rem}
.pt-8{padding-top:2rem}
.pt-10{padding-top:2.5rem}
.pt-12{padding-top:3rem}
.pt-16{padding-top:4rem}
.pt-20{padding-top:5rem}
.pt-32{padding-top:8rem}
.pb-4{padding-bottom:1rem}
.pb-6{padding-bottom:1.5rem}
.pb-8{padding-bottom:2rem}
.pb-10{padding-bottom:2.5rem}
.pb-16{padding-bottom:4rem}
.pb-24{padding-bottom:6rem}
.pb-40{padding-bottom:10rem}
.pr-6{padding-right:1.5rem}
.pl-6{padding-left:1.5rem}
@media (min-width:768px){
  .md\:px-16{padding-left:4rem;padding-right:4rem}
  .md\:p-16{padding:4rem}
  .md\:p-24{padding:6rem}
  .md\:py-32{padding-top:8rem;padding-bottom:8rem}
  .md\:w-auto{width:auto}
}
@media (min-width:1024px){
  .lg\:px-6{padding-left:1.5rem;padding-right:1.5rem}
  .lg\:p-24{padding:6rem}
  .lg\:py-32{padding-top:8rem;padding-bottom:8rem}
}

/* ── SPACING — MARGIN ─────────────────────────────────────── */
.m-0{margin:0}
.mb-0{margin-bottom:0}
.mb-2{margin-bottom:.5rem}
.mb-3{margin-bottom:.75rem}
.mb-4{margin-bottom:1rem}
.mb-6{margin-bottom:1.5rem}
.mb-8{margin-bottom:2rem}
.mb-10{margin-bottom:2.5rem}
.mb-12{margin-bottom:3rem}
.mb-16{margin-bottom:4rem}
.mb-20{margin-bottom:5rem}
.mb-24{margin-bottom:6rem}
.mb-32{margin-bottom:8rem}
.mb-40{margin-bottom:10rem}
.mt-0{margin-top:0}
.mt-2{margin-top:.5rem}
.mt-4{margin-top:1rem}
.mt-6{margin-top:1.5rem}
.mt-8{margin-top:2rem}
.mt-10{margin-top:2.5rem}
.mt-12{margin-top:3rem}
.mt-16{margin-top:4rem}
.mt-32{margin-top:8rem}
.mt-40{margin-top:10rem}
.mx-6{margin-left:1.5rem;margin-right:1.5rem}
.my-12{margin-top:3rem;margin-bottom:3rem}
.-translate-y-1{--tw-translate-y:-0.25rem;transform:translate(var(--tw-translate-x,0),var(--tw-translate-y,0)) rotate(var(--tw-rotate,0)) skewX(var(--tw-skew-x,0)) skewY(var(--tw-skew-y,0)) scaleX(var(--tw-scale-x,1)) scaleY(var(--tw-scale-y,1))}
.-translate-y-1\/2{--tw-translate-y:-50%;transform:translate(var(--tw-translate-x,0),var(--tw-translate-y,0)) rotate(var(--tw-rotate,0)) skewX(var(--tw-skew-x,0)) skewY(var(--tw-skew-y,0)) scaleX(var(--tw-scale-x,1)) scaleY(var(--tw-scale-y,1))}
.-translate-x-1\/2{--tw-translate-x:-50%;transform:translate(var(--tw-translate-x,0),var(--tw-translate-y,0)) rotate(var(--tw-rotate,0)) skewX(var(--tw-skew-x,0)) skewY(var(--tw-skew-y,0)) scaleX(var(--tw-scale-x,1)) scaleY(var(--tw-scale-y,1))}
.translate-x-\[-50\%\]{--tw-translate-x:-50%;transform:translate(var(--tw-translate-x,0),var(--tw-translate-y,0)) rotate(var(--tw-rotate,0)) skewX(var(--tw-skew-x,0)) skewY(var(--tw-skew-y,0)) scaleX(var(--tw-scale-x,1)) scaleY(var(--tw-scale-y,1))}
.translate-y-\[-50\%\]{--tw-translate-y:-50%;transform:translate(var(--tw-translate-x,0),var(--tw-translate-y,0)) rotate(var(--tw-rotate,0)) skewX(var(--tw-skew-x,0)) skewY(var(--tw-skew-y,0)) scaleX(var(--tw-scale-x,1)) scaleY(var(--tw-scale-y,1))}

/* ── GAPS ─────────────────────────────────────────────────── */
.gap-2{gap:.5rem}
.gap-3{gap:.75rem}
.gap-4{gap:1rem}
.gap-5{gap:1.25rem}
.gap-6{gap:1.5rem}
.gap-8{gap:2rem}
.gap-10{gap:2.5rem}
.gap-12{gap:3rem}
.gap-16{gap:4rem}
.gap-20{gap:5rem}
.gap-24{gap:6rem}
.space-y-6>*+*{margin-top:1.5rem}
.space-y-8>*+*{margin-top:2rem}
.space-y-10>*+*{margin-top:2.5rem}
.space-y-12>*+*{margin-top:3rem}
.space-y-16>*+*{margin-top:4rem}
@media (min-width:1024px){
  .lg\:gap-20{gap:5rem}
  .lg\:flex-row{flex-direction:row}
  .lg\:w-1\/2{width:50%}
  .lg\:w-\[72\%\]{width:72%}
  .lg\:w-\[28\%\]{width:28%}
  .lg\:hidden{display:none}
  .lg\:flex{display:flex}
  .lg\:col-span-6{grid-column:span 6/span 6}
  .lg\:col-span-3{grid-column:span 3/span 3}
  .lg\:col-span-8{grid-column:span 8/span 8}
}
@media (min-width:768px){
  .md\:flex-row{flex-direction:row}
  .md\:flex-col{flex-direction:column}
  .md\:hidden{display:none}
  .sm\:block{display:block}
  .md\:mb-0{margin-bottom:0}
  .md\:text-2xl{font-size:1.5rem;line-height:2rem}
  .md\:text-7xl{font-size:4.5rem;line-height:1}
  .md\:text-8xl{font-size:6rem;line-height:1}
  .md\:text-xl{font-size:1.25rem;line-height:1.75rem}
  .md\:text-sm{font-size:.875rem;line-height:1.25rem}
}

/* ── TYPOGRAPHY ───────────────────────────────────────────── */
.text-xs{font-size:.75rem;line-height:1rem}
.text-sm{font-size:.875rem;line-height:1.25rem}
.text-base{font-size:1rem;line-height:1.5rem}
.text-lg{font-size:1.125rem;line-height:1.75rem}
.text-xl{font-size:1.25rem;line-height:1.75rem}
.text-2xl{font-size:1.5rem;line-height:2rem}
.text-3xl{font-size:1.875rem;line-height:2.25rem}
.text-4xl{font-size:2.25rem;line-height:2.5rem}
.text-5xl{font-size:3rem;line-height:1}
.text-6xl{font-size:3.75rem;line-height:1}
.text-7xl{font-size:4.5rem;line-height:1}
.text-8xl{font-size:6rem;line-height:1}
.text-\[8px\]{font-size:8px}
.text-\[9px\]{font-size:9px}
.text-\[10px\]{font-size:10px}
.text-\[11px\]{font-size:11px}
.text-\[12px\]{font-size:12px}
.text-\[13px\]{font-size:13px}
.text-\[14px\]{font-size:14px}
.font-medium{font-weight:500}
.font-semibold{font-weight:600}
.font-bold{font-weight:700}
.font-extrabold{font-weight:800}
.font-black{font-weight:900}
.uppercase{text-transform:uppercase}
.lowercase{text-transform:lowercase}
.capitalize{text-transform:capitalize}
.tracking-tighter{letter-spacing:-.05em}
.tracking-tight{letter-spacing:-.025em}
.tracking-normal{letter-spacing:0}
.tracking-wide{letter-spacing:.025em}
.tracking-wider{letter-spacing:.05em}
.tracking-widest{letter-spacing:.1em}
.tracking-\[0\.2em\]{letter-spacing:.2em}
.tracking-\[0\.3em\]{letter-spacing:.3em}
.tracking-\[0\.4em\]{letter-spacing:.4em}
.tracking-\[0\.5em\]{letter-spacing:.5em}
.tracking-\[0\.6em\]{letter-spacing:.6em}
.text-center{text-align:center}
.text-left{text-align:left}
.text-right{text-align:right}
.leading-none{line-height:1}
.leading-tight{line-height:1.25}
.leading-snug{line-height:1.375}
.leading-normal{line-height:1.5}
.leading-relaxed{line-height:1.625}
.leading-loose{line-height:2}
.leading-\[1\.05\]{line-height:1.05}
.leading-\[1\.1\]{line-height:1.1}
.leading-\[1\.2\]{line-height:1.2}
.line-clamp-2{overflow:hidden;display:-webkit-box;-webkit-box-orient:vertical;-webkit-line-clamp:2}
.truncate{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.whitespace-nowrap{white-space:nowrap}
.italic{font-style:italic}
.underline{text-decoration-line:underline}
.no-underline{text-decoration-line:none}
.decoration-\[0\.4\]{text-decoration-opacity:.4}
.underline-offset-8{text-underline-offset:8px}
.select-none{user-select:none}

/* ── COLORS — TEXT ────────────────────────────────────────── */
.text-white{--tw-text-opacity:1;color:rgb(255 255 255/var(--tw-text-opacity))}
.text-black{--tw-text-opacity:1;color:rgb(0 0 0/var(--tw-text-opacity))}
.text-\[\#1a1a1a\]{color:#1a1a1a}
.text-\[\#d4af37\]{color:#d4af37}
.text-\[\#B8860B\]{color:#B8860B}
.text-\[\#b8962e\]{color:#b8962e}
.text-\[\#555555\]{color:#555555}
.text-\[\#aaaaaa\]{color:#aaaaaa}
.text-gray-400{color:#9ca3af}
.text-gray-500{color:#6b7280}
.text-emerald-500{color:#10b981}
.text-emerald-600{color:#059669}
.text-white\/60{color:rgb(255 255 255/.6)}
.text-white\/90{color:rgb(255 255 255/.9)}

/* ── COLORS — BACKGROUND ──────────────────────────────────── */
.bg-white{--tw-bg-opacity:1;background-color:rgb(255 255 255/var(--tw-bg-opacity))}
.bg-black{--tw-bg-opacity:1;background-color:rgb(0 0 0/var(--tw-bg-opacity))}
.bg-\[\#000000\]{background-color:#000000}
.bg-\[\#1a1a1a\]{background-color:#1a1a1a}
.bg-\[\#262626\]{background-color:#262626}
.bg-\[\#d4af37\]{background-color:#d4af37}
.bg-\[\#b8962e\]{background-color:#b8962e}
.bg-\[\#f5f5f5\]{background-color:#f5f5f5}
.bg-\[\#fafafa\]{background-color:#fafafa}
.bg-\[\#0f1115\]{background-color:#0f1115}
.bg-\[\#030712\]{background-color:#030712}
.bg-emerald-50{background-color:#ecfdf5}
.bg-red-50{background-color:#fef2f2}
.bg-\[\#d4af37\]\/5{background-color:rgb(212 175 55/.05)}
.bg-\[\#d4af37\]\/10{background-color:rgb(212 175 55/.1)}
.bg-white\/5{background-color:rgb(255 255 255/.05)}
.bg-transparent{background-color:transparent}

/* ── COLORS — BORDER ──────────────────────────────────────── */
.border{border-width:1px}
.border-2{border-width:2px}
.border-4{border-width:4px}
.border-b{border-bottom-width:1px}
.border-t{border-top-width:1px}
.border-l{border-left-width:1px}
.border-r{border-right-width:1px}
.border-y{border-top-width:1px;border-bottom-width:1px}
.border-t-4{border-top-width:4px}
.border-l-\[8px\]{border-left-width:8px}
.border-l-\[12px\]{border-left-width:12px}
.border-\[\#eeeeee\]{border-color:#eeeeee}
.border-\[\#d4af37\]{border-color:#d4af37}
.border-\[\#B8860B\]{border-color:#B8860B}
.border-\[\#1a1a1a\]{border-color:#1a1a1a}
.border-\[\#f5f5f5\]{border-color:#f5f5f5}
.border-white{border-color:#fff}
.border-white\/10{border-color:rgb(255 255 255/.1)}
.border-white\/20{border-color:rgb(255 255 255/.2)}
.border-\[\#d4af37\]\/10{border-color:rgb(212 175 55/.1)}
.border-\[\#d4af37\]\/20{border-color:rgb(212 175 55/.2)}
.border-\[\#d4af37\]\/30{border-color:rgb(212 175 55/.3)}
.border-dashed{border-style:dashed}
.border-emerald-200{border-color:#a7f3d0}
.border-red-200{border-color:#fecaca}
.divide-y>*+*{border-top-width:1px;border-style:solid;border-color:#e5e7eb}

/* ── ROUNDED ──────────────────────────────────────────────── */
.rounded{border-radius:.25rem}
.rounded-md{border-radius:.375rem}
.rounded-lg{border-radius:.5rem}
.rounded-xl{border-radius:.75rem}
.rounded-2xl{border-radius:1rem}
.rounded-3xl{border-radius:1.5rem}
.rounded-\[2\.5rem\]{border-radius:2.5rem}
.rounded-\[3rem\]{border-radius:3rem}
.rounded-\[3\.5rem\]{border-radius:3.5rem}
.rounded-\[2rem\]{border-radius:2rem}
.rounded-\[4px\]{border-radius:4px}
.rounded-full{border-radius:9999px}
.rounded-r-\[3rem\]{border-radius:0 3rem 3rem 0}

/* ── SHADOW ───────────────────────────────────────────────── */
.shadow-sm{box-shadow:0 1px 2px 0 rgb(0 0 0/.05)}
.shadow{box-shadow:0 1px 3px 0 rgb(0 0 0/.1),0 1px 2px -1px rgb(0 0 0/.1)}
.shadow-lg{box-shadow:0 10px 15px -3px rgb(0 0 0/.1),0 4px 6px -4px rgb(0 0 0/.1)}
.shadow-xl{box-shadow:0 20px 25px -5px rgb(0 0 0/.1),0 8px 10px -6px rgb(0 0 0/.1)}
.shadow-2xl{box-shadow:0 25px 50px -12px rgb(0 0 0/.25)}
.shadow-\[0_4px_15px_rgba\(0\,0\,0\,0\.05\)\]{box-shadow:0 4px 15px rgba(0,0,0,.05)}
.shadow-\[0_10px_40px_rgba\(212\,175\,55\,0\.12\)\]{box-shadow:0 10px 40px rgba(212,175,55,.12)}
.shadow-\[0_20px_60px_rgba\(212\,175\,55\,0\.08\)\,0_4px_20px_rgba\(0\,0\,0\,0\.06\)\]{box-shadow:0 20px 60px rgba(212,175,55,.08),0 4px 20px rgba(0,0,0,.06)}
.shadow-\[0_40px_100px_rgba\(0\,0\,0\,0\.04\)\]{box-shadow:0 40px 100px rgba(0,0,0,.04)}
.shadow-\[\#d4af37\]\/20{box-shadow:0 10px 15px -3px rgba(212,175,55,.2)}

/* ── OBJECT FIT ───────────────────────────────────────────── */
.object-cover{object-fit:cover}
.object-contain{object-fit:contain}
.object-center{object-position:center}

/* ── OPACITY ──────────────────────────────────────────────── */
.opacity-0{opacity:0}
.opacity-1{opacity:1}
.opacity-10{opacity:.1}
.opacity-40{opacity:.4}
.opacity-60{opacity:.6}
.opacity-80{opacity:.8}
.opacity-100{opacity:1}

/* ── TRANSITIONS & ANIMATIONS ─────────────────────────────── */
.transition{transition-property:color,background-color,border-color,text-decoration-color,fill,stroke,opacity,box-shadow,transform,filter,backdrop-filter;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:150ms}
.transition-all{transition-property:all;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:150ms}
.transition-colors{transition-property:color,background-color,border-color,text-decoration-color,fill,stroke;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:150ms}
.transition-opacity{transition-property:opacity;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:150ms}
.transition-transform{transition-property:transform;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:150ms}
.duration-300{transition-duration:300ms}
.duration-500{transition-duration:500ms}
.duration-700{transition-duration:700ms}
.duration-1000{transition-duration:1000ms}
.ease-out{transition-timing-function:cubic-bezier(0,0,.2,1)}
.animate-pulse{animation:pulse 2s cubic-bezier(.4,0,.6,1) infinite}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.5}}
.animate-spin{animation:spin 1s linear infinite}
@keyframes spin{from{transform:rotate(0deg)}to{transform:rotate(360deg)}}

/* ── HOVER STATES ─────────────────────────────────────────── */
.hover\:text-\[\#d4af37\]:hover{color:#d4af37}
.hover\:text-\[\#b8962e\]:hover{color:#b8962e}
.hover\:text-white:hover{color:#fff}
.hover\:text-black:hover{color:#000}
.hover\:bg-\[\#d4af37\]:hover{background-color:#d4af37}
.hover\:bg-\[\#b8962e\]:hover{background-color:#b8962e}
.hover\:bg-\[\#B8860B\]:hover{background-color:#B8860B}
.hover\:bg-\[\#1a1a1a\]:hover{background-color:#1a1a1a}
.hover\:border-\[\#d4af37\]:hover{border-color:#d4af37}
.hover\:border-white:hover{border-color:#fff}
.hover\:opacity-100:hover{opacity:1}
.hover\:scale-105:hover{transform:scale(1.05)}
.hover\:scale-110:hover{transform:scale(1.1)}
.hover\:scale-\[1\.02\]:hover{transform:scale(1.02)}
.hover\:-translate-y-1:hover{transform:translateY(-.25rem)}
.hover\:shadow-md:hover{box-shadow:0 4px 6px -1px rgb(0 0 0/.1),0 2px 4px -2px rgb(0 0 0/.1)}
.hover\:shadow-xl:hover{box-shadow:0 20px 25px -5px rgb(0 0 0/.1),0 8px 10px -6px rgb(0 0 0/.1)}
.hover\:shadow-2xl:hover{box-shadow:0 25px 50px -12px rgb(0 0 0/.25)}

/* ── GROUP HOVER ──────────────────────────────────────────── */
.group:hover .group-hover\:scale-105{transform:scale(1.05)}
.group:hover .group-hover\:scale-110{transform:scale(1.1)}
.group:hover .group-hover\:opacity-100{opacity:1}
.group:hover .group-hover\:text-white{color:#fff}
.group:hover .group-hover\:text-\[\#d4af37\]{color:#d4af37}
.group:hover .group-hover\:bg-\[\#d4af37\]{background-color:#d4af37}
.group:hover .group-hover\:border-\[\#d4af37\]{border-color:#d4af37}
.group:hover .group-hover\:scale-\[1\.02\]{transform:scale(1.02)}
.group:hover .group-hover\:scale-110{transform:scale(1.1)}
.scale-\[1\.1\]:hover{transform:scale(1.1)}

/* ── FOCUS ────────────────────────────────────────────────── */
.focus\:border-\[\#d4af37\]:focus{border-color:#d4af37}
.focus\:ring-2:focus{box-shadow:0 0 0 2px var(--ring-color,rgba(212,175,55,.3))}
.focus\:ring-\[\#d4af37\]\/30:focus{--ring-color:rgba(212,175,55,.3);box-shadow:0 0 0 2px var(--ring-color)}
.outline-none{outline:2px solid transparent;outline-offset:2px}
.resize-none{resize:none}

/* ── MISC UTILITIES ───────────────────────────────────────── */
.cursor-pointer{cursor:pointer}
.pointer-events-none{pointer-events:none}
.select-none{user-select:none}
.backdrop-filter{backdrop-filter:var(--tw-backdrop-filter)}
.backdrop-blur-sm{--tw-backdrop-blur:blur(4px);-webkit-backdrop-filter:var(--tw-backdrop-blur,) var(--tw-backdrop-brightness,) var(--tw-backdrop-contrast,) var(--tw-backdrop-grayscale,) var(--tw-backdrop-hue-rotate,) var(--tw-backdrop-invert,) var(--tw-backdrop-opacity,) var(--tw-backdrop-saturate,) var(--tw-backdrop-sepia,);backdrop-filter:var(--tw-backdrop-blur,) var(--tw-backdrop-brightness,) var(--tw-backdrop-contrast,) var(--tw-backdrop-grayscale,) var(--tw-backdrop-hue-rotate,) var(--tw-backdrop-invert,) var(--tw-backdrop-opacity,) var(--tw-backdrop-saturate,) var(--tw-backdrop-sepia,)}
.blur-\[120px\]{filter:blur(120px)}
.mix-blend-multiply{mix-blend-mode:multiply}
.drop-shadow-lg{filter:drop-shadow(0 10px 8px rgb(0 0 0/.04)) drop-shadow(0 4px 3px rgb(0 0 0/.1))}
.grayscale{filter:grayscale(100%)}
.scroll-mt-24{scroll-margin-top:6rem}
.bg-clip-text{-webkit-background-clip:text;background-clip:text}
.\!text-fill-transparent{-webkit-text-fill-color:transparent}
.selection\:bg-\[\#d4af37\]::selection{background-color:#d4af37}
.selection\:text-black::selection{color:#000}
.placeholder\:text-\[\#aaaaaa\]::placeholder{color:#aaaaaa}

/* ── RESPONSIVE VISIBILITY ────────────────────────────────── */
@media (min-width:640px){.sm\:block{display:block}.sm\:hidden{display:none}}
@media (min-width:768px){.md\:block{display:block}}
@media (min-width:1024px){.lg\:hidden{display:none}.lg\:block{display:block}.lg\:flex{display:flex}}
@media (min-width:1280px){.xl\:flex{display:flex}.xl\:hidden{display:none}}

/* ── SPECIFIC TAILWIND ARBITRARY COMBOS USED IN SITE ─────── */
.from-black\/30{--tw-gradient-from:rgb(0 0 0/.3) var(--tw-gradient-from-position);--tw-gradient-to:rgb(0 0 0/0) var(--tw-gradient-to-position);--tw-gradient-stops:var(--tw-gradient-from),var(--tw-gradient-to)}
.via-black\/50{--tw-gradient-to:rgb(0 0 0/0) var(--tw-gradient-to-position);--tw-gradient-stops:var(--tw-gradient-from),rgb(0 0 0/.5) var(--tw-gradient-via-position),var(--tw-gradient-to)}
.to-black\/80{--tw-gradient-to:rgb(0 0 0/.8) var(--tw-gradient-to-position)}
.bg-gradient-to-b{background-image:linear-gradient(to bottom,var(--tw-gradient-stops))}
.bg-gradient-to-t{background-image:linear-gradient(to top,var(--tw-gradient-stops))}
.from-black\/80{--tw-gradient-from:rgb(0 0 0/.8) var(--tw-gradient-from-position);--tw-gradient-to:rgb(0 0 0/0) var(--tw-gradient-to-position);--tw-gradient-stops:var(--tw-gradient-from),var(--tw-gradient-to)}


/* BUREAU MASTER DESIGN SYSTEM v2 */
:root {
    --accent: #d4af37;
    --black: #000000;
    --white: #ffffff;
    --text-main: #1a1a1a;
    --text-muted: rgba(26,26,26,0.6);
}

* { box-sizing: border-box; }

/* UTILITY SHIMS (TAILWIND REPLACEMENTS) */
.max-w-4xl { max-width: 896px; margin-left: auto; margin-right: auto; }
.max-w-7xl { max-width: 1280px; margin-left: auto; margin-right: auto; }
.bg-black { background-color: var(--black) !important; }
.text-white { color: var(--white) !important; }
.text-white\/60 { color: rgba(255,255,255,0.6) !important; }
.text-[#d4af37] { color: var(--accent) !important; }
.font-black { font-weight: 900 !important; }
.uppercase { text-transform: uppercase !important; }
.tracking-widest { letter-spacing: 0.1em !important; }
.mb-24 { margin-bottom: 6rem !important; }
.py-24 { padding-top: 6rem; padding-bottom: 6rem; }
.px-6 { padding-left: 1.5rem; padding-right: 1.5rem; }
.grid { display: grid; }
.grid-cols-1 { grid-template-columns: repeat(1, minmax(0, 1fr)); }
.gap-10 { gap: 2.5rem; }
.rounded-2xl { border-radius: 1rem; }
.border { border: 1px solid #e5e7eb; }

/* LAYOUT FIXES */
.hero-section { min-height: 60vh; display: flex; align-items: center; justify-content: center; position: relative; }
.editorial-body { line-height: 1.8; font-size: 1.1rem; color: #333; }

@media (min-width: 1024px) {
    .lg\:grid-cols-3 { grid-template-columns: repeat(3, minmax(0, 1fr)); }
    .lg\:grid-cols-2 { grid-template-columns: repeat(2, minmax(0, 1fr)); }
}

/* MAGAZINE GRID RECOVERY */
@media (min-width: 1024px) {
    .lg\:col-span-6 { grid-column: span 6 / span 6; }
    .lg\:col-span-3 { grid-column: span 3 / span 3; }
    .lg\:grid-cols-12 { grid-template-columns: repeat(12, minmax(0, 1fr)); }
}
.line-clamp-2 { overflow: hidden; display: -webkit-box; -webkit-box-orient: vertical; -webkit-line-clamp: 2; }

/* FOOTER COMPACTOR */
footer { padding-top: 4rem; padding-bottom: 2rem; background: #0a0a0a; color: white; }
.footer-grid { display: grid; grid-template-columns: repeat(1, 1fr); gap: 3rem; }
@media (min-width: 1024px) { .footer-grid { grid-template-columns: repeat(4, 1fr); } }
footer a { color: rgba(255,255,255,0.6); font-size: 13px; text-decoration: none; transition: 0.3s; }
footer a:hover { color: #d4af37; }

/* HEADER DESKTOP SEARCH BAR */
.fh-desktop-search {
    display: flex;
    align-items: center;
    background: rgba(255,255,255,0.05);
    border: 1px solid rgba(255,255,255,0.15);
    border-radius: 8px;
    padding: 6px 12px;
    min-width: 220px;
    transition: all 0.3s ease;
}
.fh-desktop-search:focus-within {
    border-color: #d4af37;
    background: rgba(255,255,255,0.08);
}
.fh-desktop-search i {
    color: #d4af37;
    font-size: 12px;
}
.fh-desktop-search input {
    background: transparent;
    border: none;
    outline: none;
    color: white;
    font-size: 10px;
    font-weight: 800;
    letter-spacing: 1.5px;
    padding: 4px 8px;
    width: 100%;
    text-transform: uppercase;
}

/* ── CATEGORY BAR & TABS ────────────────────────────────── */
.category-bar {
    background: #f5f5f5;
    padding: 12px 0;
    border-bottom: 1px solid #eeeeee;
    position: relative;
    z-index: 30;
}
.container-fh {
    max-width: 1400px;
    margin: 0 auto;
}
.category-tabs-scroll {
    padding: 4px 24px 12px;
    overflow-x: auto;
    white-space: nowrap;
    -webkit-overflow-scrolling: touch;
    display: flex;
    gap: 12px;
}
.category-tabs-scroll::-webkit-scrollbar { display: none; } /* Hide scrollbar */

.category-tab-item {
    padding: 10px 24px;
    background: white;
    border: 1px solid #eeeeee;
    color: #1a1a1a;
    font-size: 10px;
    font-weight: 900;
    text-transform: uppercase;
    letter-spacing: 0.15em;
    border-radius: 9999px;
    text-decoration: none;
    display: inline-block;
    transition: all 0.3s ease;
}
.category-tab-item:hover {
    border-color: #d4af37;
    color: #d4af37;
}
.category-tab-item.active {
    background: #d4af37;
    color: #1a1a1a;
    border-color: #d4af37;
}

.fh-desktop-search input::placeholder {
    color: rgba(255,255,255,0.4);
}
/* Mobile search button — hidden on desktop, shown on mobile */
.fh-mobile-search-btn { display: none; }
@media (max-width: 1023px) {
    .fh-desktop-search { display: none !important; }
    .fh-mobile-search-btn { display: flex !important; }
}

/* RESPONSIVE HEIGHT REPAIRS */
@media (max-width: 1023px) {
    .fh-featured-card { height: 450px !important; }
}
@media (max-width: 640px) {
    .fh-featured-card { height: 360px !important; }
}

/* ── TICKER ANIMATION ────────────────────────────────────── */
@keyframes infinite-scroll {
    0% { transform: translateX(0); }
    100% { transform: translateX(-50%); }
}
.animate-infinite-scroll {
    animation: infinite-scroll 40s linear infinite;
}
.ticker-container { overflow: hidden; }

/* ── HERO ANIMATIONS ─────────────────────────────────────── */
@keyframes fadeIn { from { opacity: 0; } to { opacity: 1; } }
@keyframes fadeInUp { from { opacity: 0; transform: translateY(24px); } to { opacity: 1; transform: translateY(0); } }
@keyframes fadeZoom { from { transform: scale(1.05); } to { transform: scale(1); } }
.animate-fade-in { animation: fadeIn 0.8s ease-out both; }
.animate-fade-in-up { animation: fadeInUp 0.8s ease-out both; }
.animate-fade-zoom { animation: fadeZoom 12s ease-out both; }
.delay-100 { animation-delay: 0.1s; }
.delay-200 { animation-delay: 0.2s; }

/* ── GOLD CTA BUTTON ─────────────────────────────────────── */
.gold-btn {
    display: inline-block;
    padding: 16px 32px;
    background: #d4af37;
    color: #1a1a1a;
    font-size: 10px;
    font-weight: 900;
    text-transform: uppercase;
    letter-spacing: 0.15em;
    text-decoration: none;
    transition: all 0.3s ease;
    border: 1px solid #d4af37;
}
.gold-btn:hover {
    background: #b8962e;
    color: #fff;
}

/* ── FOOTER GREEN DOT ────────────────────────────────────── */
.bg-green-500 { background-color: #22c55e; }

/* ── MISSING RESPONSIVE UTILITIES ────────────────────────── */
@media (min-width: 640px) {
    .sm\:grid-cols-2 { grid-template-columns: repeat(2, minmax(0, 1fr)); }
    .sm\:grid-cols-3 { grid-template-columns: repeat(3, minmax(0, 1fr)); }
    .sm\:flex-row { flex-direction: row; }
}
@media (min-width: 768px) {
    .md\:flex { display: flex; }
    .md\:grid-cols-2 { grid-template-columns: repeat(2, minmax(0, 1fr)); }
    .md\:w-auto { width: auto; }
}

/* ── ARTICLE BODY CONTENT POLISH ─────────────────────────── */
.article-body blockquote {
    border-left: 4px solid #d4af37;
    padding: 1.5rem 2rem;
    margin: 2rem 0;
    background: #fafafa;
    font-style: italic;
    color: #333;
}
.article-body ul, .article-body ol {
    margin: 1.5rem 0;
    padding-left: 2rem;
}
.article-body li {
    margin-bottom: 0.5rem;
    line-height: 1.8;
}
.article-body img {
    border-radius: 1rem;
    margin: 2rem 0;
}
.article-body a {
    color: #d4af37;
    text-decoration: underline;
    text-underline-offset: 3px;
}
.article-body a:hover {
    color: #b8962e;
}

/* ── ADSENSE COMPLIANCE: Proper ad slot spacing ──────────── */
.bureau-ad-zone {
    margin-top: 2rem;
    margin-bottom: 2rem;
    text-align: center;
}
.ad-slot-global, .ad-slot-inpost, .ad-slot-sidebar, .ad-slot-footer {
    min-height: 90px;
    display: flex;
    align-items: center;
    justify-content: center;
}

/* ── MOBILE POLISH ───────────────────────────────────────── */
@media (max-width: 767px) {
    .hero-section, .fh-hero-section {
        min-height: 70vh !important;
    }
    .fh-hero-content {
        padding-top: 40px !important;
        padding-bottom: 40px !important;
    }
    .text-5xl { font-size: 2rem; line-height: 1.1; }
    .text-7xl { font-size: 2.5rem; line-height: 1.05; }
    .md\:text-7xl { font-size: 2.5rem; line-height: 1.05; }
    .p-12, .md\:p-24 { padding: 1.5rem; }
    .px-14 { padding-left: 1.5rem; padding-right: 1.5rem; }
    .mb-24 { margin-bottom: 3rem; }
    .py-20 { padding-top: 3rem; padding-bottom: 3rem; }
    .gap-12 { gap: 1.5rem; }
}

