/* Homepage v2 — magazine layout. .nb- prefix scopes everything; sits on top */
/* of Bootstrap 5.3.8 + Carrier Atlas chrome. Brand teal + crimson accents.  */
.nb-root { color:#1a1d22; background:#fff; }
.nb-section { padding: 2.5rem 0; }
.nb-section.is-tinted { background:#fbfbfd; border-top:1px solid #f1f3f5; border-bottom:1px solid #f1f3f5; }
.nb-eyebrow {
	display:inline-flex; align-items:center; gap:.5rem;
	font-size:.7rem; font-weight:800; letter-spacing:.18em;
	text-transform:uppercase; color:#0f766e;
	padding-bottom:.4rem; border-bottom:2px solid #0f766e; margin-bottom:1rem;
}
.nb-eyebrow.is-hot { color:#dc2626; border-color:#dc2626; }
.nb-h2 { font-size:clamp(1.5rem, 3vw, 2rem); font-weight:800;
	letter-spacing:-.02em; margin:0 0 .35rem; color:#1a1d22; }
.nb-h2-sub { color:#6c757d; font-size:.95rem; margin:0 0 1.6rem; }

/* ── Trending ticker ── */
.nb-ticker { background:#0b0f17; color:#e9ecef; padding:.6rem 0; font-size:.85rem; }
.nb-ticker-row { display:flex; align-items:center; gap:1.25rem; flex-wrap:wrap; }
.nb-ticker-label {
	display:inline-flex; align-items:center; gap:.4rem;
	background:#dc2626; color:#fff; padding:.25rem .65rem;
	border-radius:.25rem; font-size:.7rem; font-weight:700;
	letter-spacing:.12em; text-transform:uppercase; flex-shrink:0;
}
.nb-ticker-label::before {
	content:""; width:.4rem; height:.4rem; background:#fff;
	border-radius:50%; animation: nb-pulse 1.4s infinite;
}
@keyframes nb-pulse { 0%,100% { opacity:1; } 50% { opacity:.4; } }
.nb-ticker-list {
	flex:1; min-width:0; overflow:hidden; position:relative;
	-webkit-mask-image: linear-gradient(to right, transparent 0, #000 32px, #000 calc(100% - 32px), transparent 100%);
	mask-image: linear-gradient(to right, transparent 0, #000 32px, #000 calc(100% - 32px), transparent 100%);
}
.nb-ticker-track {
	display:flex; width:max-content;
	animation: nb-marquee 120s linear infinite;
}
.nb-ticker-list:hover .nb-ticker-track,
.nb-ticker-list:focus-within .nb-ticker-track { animation-play-state: paused; }
.nb-ticker-set { display:flex; align-items:center; gap:0.85rem; padding-right:0.85rem; flex-shrink:0; }
.nb-ticker-set a { color:#e9ecef; text-decoration:none; font-weight:500;
	font-size:0.78rem; white-space:nowrap; }
.nb-ticker-set a:hover { color:#5eead4; }
.nb-ticker-sep { color:#475569; font-size:.7rem; flex-shrink:0; }
@keyframes nb-marquee {
	from { transform: translateX(0); }
	to   { transform: translateX(-50%); }
}
@media (prefers-reduced-motion: reduce) {
	.nb-ticker-track { animation: none; }
	.nb-ticker-list  { -webkit-mask-image: none; mask-image: none; overflow-x: auto; }
}

/* ── Asymmetric hero ── */
.nb-hero { display:grid; grid-template-columns: 1.6fr 1fr; gap:1.75rem; }
.nb-hero-feature {
	position:relative; aspect-ratio: 16/10; border-radius:.4rem; overflow:hidden;
	background:#0b0f17; display:block; text-decoration:none;
}
.nb-hero-feature img { width:100%; height:100%; object-fit:cover; display:block;
	transition: transform .4s ease; }
.nb-hero-feature:hover img { transform: scale(1.03); }
.nb-hero-feature-overlay {
	position:absolute; inset:auto 0 0 0; padding:1.6rem 1.6rem 1.4rem;
	background: linear-gradient(180deg, transparent 0%, rgba(0,0,0,.85) 80%);
	color:#fff;
}
.nb-hero-cat {
	display:inline-block; font-size:.65rem; font-weight:700;
	letter-spacing:.14em; text-transform:uppercase;
	padding:.25rem .65rem; background:#dc2626; border-radius:.2rem;
	margin-bottom:.6rem;
}
.nb-hero-feature h1 {
	font-size:clamp(1.4rem, 2.6vw, 1.95rem); font-weight:800;
	line-height:1.15; margin:0 0 .5rem; color:#fff;
}
.nb-hero-byline { font-size:.82rem; color:#cbd5e1; }

.nb-hero-side { display:flex; flex-direction:column; gap:1rem; }
.nb-side-card {
	display:flex; gap:.85rem; padding-bottom:1rem;
	border-bottom:1px solid #e9ecef; text-decoration:none; color:inherit;
	transition: transform .15s;
}
.nb-side-card:last-child { border-bottom:none; padding-bottom:0; }
.nb-side-card:hover { transform: translateX(2px); color:inherit; }
.nb-side-thumb {
	flex-shrink:0; width:96px; aspect-ratio:1; border-radius:.3rem;
	overflow:hidden; background:#f1f3f5;
}
.nb-side-thumb img { width:100%; height:100%; object-fit:cover; display:block; }
.nb-side-meta { flex:1; min-width:0; display:flex; flex-direction:column;
	justify-content:center; }
.nb-side-cat {
	font-size:.62rem; font-weight:700; letter-spacing:.14em;
	text-transform:uppercase; color:#0f766e; margin-bottom:.25rem;
}
.nb-side-h3 { font-size:.92rem; font-weight:700; line-height:1.25;
	margin:0 0 .3rem; color:#1a1d22; }
.nb-side-card:hover .nb-side-h3 { color:#0f766e; }
.nb-side-date { font-size:.72rem; color:#6c757d; }

/* ── Fuel stat strip ── */
.nb-fuel-strip { display:grid; grid-template-columns: repeat(4, 1fr); gap:1rem; }
.nb-fuel-stat {
	background:#fff; border:1px solid #e9ecef; border-left:4px solid #0f766e;
	padding:1rem 1.2rem; border-radius:.3rem;
}
.nb-fuel-stat-label {
	font-size:.7rem; font-weight:700; letter-spacing:.1em;
	text-transform:uppercase; color:#6c757d; margin-bottom:.3rem;
}
.nb-fuel-stat-value {
	font-size:clamp(1.4rem, 2.4vw, 1.75rem); font-weight:800;
	color:#1a1d22; line-height:1.05;
}
.nb-fuel-stat-sub { font-size:.78rem; color:#6c757d; margin-top:.15rem; }
.nb-delta-pos { color:#dc2626; }
.nb-delta-neg { color:#059669; }

/* ── Editor's Picks 3-col grid ── */
.nb-picks { display:grid; grid-template-columns: repeat(3, 1fr); gap:1.5rem; }
.nb-pick { display:flex; flex-direction:column; gap:.75rem;
	text-decoration:none; color:inherit; }
.nb-pick-art {
	display:block; aspect-ratio: 16/10; border-radius:.4rem;
	overflow:hidden; background:#f1f3f5;
}
.nb-pick-art img { width:100%; height:100%; object-fit:cover; display:block;
	transition: transform .3s ease; }
.nb-pick:hover .nb-pick-art img { transform: scale(1.03); }
.nb-pick-cat {
	font-size:.65rem; font-weight:700; letter-spacing:.14em;
	text-transform:uppercase; color:#0f766e;
}
.nb-pick-h3 { font-size:1.1rem; font-weight:700; line-height:1.25; margin:0;
	color:#1a1d22; }
.nb-pick:hover .nb-pick-h3 { color:#0f766e; }
.nb-pick-byline { font-size:.78rem; color:#6c757d; }

/* ── Three-column beat sidebars ── */
.nb-beats { display:grid; grid-template-columns: repeat(3, 1fr); gap:1.75rem; }
.nb-beat {
	background:#fff; border:1px solid #e9ecef; border-radius:.4rem; padding:1.4rem;
}
.nb-beat-h3 {
	font-size:1rem; font-weight:800; letter-spacing:-.01em;
	margin:0 0 1rem; padding-bottom:.55rem;
	border-bottom:2px solid #1a1d22;
}
.nb-beat ol { list-style:none; padding:0; margin:0; counter-reset: nb-rank; }
.nb-beat li {
	display:flex; gap:.85rem; padding:.85rem 0;
	border-bottom:1px solid #f1f3f5; counter-increment: nb-rank;
}
.nb-beat li:last-child { border-bottom:none; padding-bottom:0; }
.nb-beat li::before {
	content: counter(nb-rank, decimal-leading-zero);
	flex-shrink:0; font-size:.85rem; font-weight:800;
	color:#dc2626; opacity:.4; min-width:1.4rem;
}
.nb-beat-item { flex:1; min-width:0; }
.nb-beat-item a {
	color:#1a1d22; text-decoration:none; font-weight:600;
	font-size:.88rem; line-height:1.3;
}
.nb-beat-item a:hover { color:#0f766e; }
.nb-beat-meta { font-size:.7rem; color:#6c757d; margin-top:.2rem; }

/* ── Fuel deep-dive ── */
.nb-fuel-deep { display:grid; grid-template-columns: 1.5fr 1fr; gap:1.5rem; }
.nb-chart-card, .nb-fuel-table-card {
	background:#fff; border:1px solid #e9ecef; border-radius:.4rem;
	padding:1.25rem 1.5rem;
}
.nb-chart-h3 {
	font-size:.95rem; font-weight:700; margin:0 0 1rem;
	padding-bottom:.55rem; border-bottom:1px solid #e9ecef;
}
.nb-chart-wrap { position:relative; height:280px; }
.nb-fuel-table-card h4 {
	font-size:.78rem; font-weight:700; letter-spacing:.06em;
	color:#1a1d22; margin:0 0 .65rem;
}
.nb-fuel-table-card h4:not(:first-child) { margin-top:1.4rem; }
.nb-fuel-table-card table { width:100%; font-size:.85rem; }
.nb-fuel-table-card td { padding:.4rem .25rem; border-bottom:1px solid #f1f3f5; }
.nb-fuel-table-card tr:last-child td { border-bottom:none; }
.nb-fuel-table-card td:nth-child(2),
.nb-fuel-table-card td:nth-child(3) {
	text-align:right; font-variant-numeric:tabular-nums; font-weight:600;
}
.nb-fuel-table-card td:nth-child(3) { font-size:.76rem; width:4rem; }

/* ── Directory split-banner ── */
.nb-dirad-banner {
	display:grid; grid-template-columns: 1fr 1fr; gap:0;
	border-radius:.5rem; overflow:hidden;
}
.nb-dirad {
	padding:2.5rem 2rem; text-decoration:none; color:#fff;
	display:flex; flex-direction:column; gap:.6rem;
	transition: filter .15s;
}
.nb-dirad:hover { color:#fff; filter: brightness(1.1); }
.nb-dirad.is-carriers { background: linear-gradient(135deg, #0f766e 0%, #115e59 100%); }
.nb-dirad.is-truckstops { background: linear-gradient(135deg, #1d4ed8 0%, #1e40af 100%); }
.nb-dirad-eyebrow {
	font-size:.7rem; font-weight:700; letter-spacing:.16em;
	text-transform:uppercase; opacity:.8;
}
.nb-dirad h3 { font-size:1.5rem; font-weight:800; margin:0 0 .35rem; color:#fff; }
.nb-dirad p { font-size:.92rem; opacity:.92; margin:0 0 .8rem; line-height:1.5; }
.nb-dirad-cta {
	margin-top:auto; font-weight:700; font-size:.88rem;
	display:inline-flex; align-items:center; gap:.4rem;
}
.nb-dirad-cta::after { content:"→"; transition: transform .15s; }
.nb-dirad:hover .nb-dirad-cta::after { transform: translateX(4px); }

/* ── Recently-updated split ── */
.nb-fresh { display:grid; grid-template-columns: 1fr 1fr; gap:2rem; }
.nb-fresh-h3 {
	font-size:1.05rem; font-weight:800; margin:0 0 1rem;
	padding-bottom:.55rem; border-bottom:2px solid #1a1d22;
}
.nb-fresh-list { display:flex; flex-direction:column; gap:.7rem; }
.nb-fresh-item {
	display:flex; gap:.85rem; padding:.85rem; background:#fff;
	border:1px solid #e9ecef; border-radius:.3rem;
	text-decoration:none; color:inherit;
	transition: border-color .15s, transform .15s;
	align-items:center;
}
.nb-fresh-item:hover { border-color:#0f766e; transform: translateX(2px); color:inherit; }
.nb-fresh-thumb {
	flex-shrink:0; width:56px; height:56px; border-radius:.3rem;
	overflow:hidden; background:#f1f3f5;
	display:flex; align-items:center; justify-content:center;
	color:#94a3b8; font-size:1.3rem;
}
.nb-fresh-thumb img { width:100%; height:100%; object-fit:cover; }
.nb-fresh-name { font-size:.9rem; font-weight:700; line-height:1.25; color:#1a1d22; }
.nb-fresh-meta { font-size:.74rem; color:#6c757d; margin-top:.15rem; }
.nb-chain-pill {
	display:inline-block; font-size:.6rem; font-weight:700;
	letter-spacing:.08em; text-transform:uppercase;
	padding:.13rem .4rem; border-radius:.2rem; margin-right:.3rem;
}
.nb-chain-pill.chain-pilot { background:#fef3c7; color:#92400e; }
.nb-chain-pill.chain-loves { background:#fee2e2; color:#991b1b; }
.nb-chain-pill.chain-ta    { background:#dbeafe; color:#1e40af; }
.nb-chain-pill.chain-petro { background:#e0e7ff; color:#3730a3; }
.nb-chain-pill.chain-other { background:#e5e7eb; color:#374151; }

/* ── Lead form + hiring ── */
.nb-cta-row { display:grid; grid-template-columns: 1.4fr 1fr; gap:1.5rem; }
.nb-lead-card {
	background:#fff; border:1px solid #e9ecef; border-radius:.5rem; padding:2rem;
	position: relative;
}
.nb-lead-card h2 { font-size:1.5rem; font-weight:800; margin:0 0 .35rem; }
.nb-lead-card .nb-lead-sub { color:#6c757d; margin:0 0 1.25rem; }
.nb-lead-form .form-control {
	border-radius:.3rem; border:1px solid #d4d8de;
	padding:.75rem .9rem; margin-bottom:.65rem; font-size:.95rem;
}
.nb-lead-form .form-control:focus {
	border-color:#0f766e; box-shadow: 0 0 0 .15rem rgba(15,118,110,.15);
}
.nb-lead-submit {
	background:#1a1d22; color:#fff; border:none; border-radius:.3rem;
	padding:.85rem 1.5rem; font-weight:700; cursor:pointer;
	transition: background .15s;
}
.nb-lead-submit:hover:not(:disabled) { background:#0f766e; }
.nb-lead-submit:disabled { opacity:.6; cursor:wait; }
.nb-honeypot { position:absolute; left:-9999px; top:auto;
	width:1px; height:1px; overflow:hidden; }
.nb-lead-trust {
	list-style:none; padding:0; margin:1rem 0 0; display:grid;
	grid-template-columns: repeat(2, 1fr); gap:.4rem .9rem;
	font-size:.8rem; color:#495057;
}
.nb-lead-trust li { display:flex; align-items:center; gap:.4rem; }
.nb-lead-trust i { color:#0f766e; }
.nb-lead-confirm { text-align:center; padding:1.5rem 1rem; }
.nb-hiring-card {
	background: linear-gradient(135deg,#1a1d22 0%, #0b0f17 100%);
	color:#e9ecef; border-radius:.5rem; padding:2rem;
	display:flex; flex-direction:column; justify-content:center;
	min-height:100%; position:relative; overflow:hidden;
}
.nb-hiring-card::before {
	content:""; position:absolute; inset:auto -30% -30% auto;
	width:80%; height:80%;
	background: radial-gradient(circle at 70% 70%, rgba(94,234,212,.18), transparent 60%);
	pointer-events:none;
}
.nb-hiring-eyebrow {
	font-size:.7rem; font-weight:700; letter-spacing:.16em;
	text-transform:uppercase; color:#5eead4; margin-bottom:.7rem;
	position:relative;
}
.nb-hiring-card h2 {
	font-size:1.6rem; font-weight:800; line-height:1.2;
	margin:0 0 .85rem; color:#fff; position:relative;
}
.nb-hiring-card p { color:#cbd5e1; font-size:.93rem; line-height:1.55;
	margin:0 0 1.5rem; position:relative; }
.nb-hiring-cta {
	display:inline-flex; align-items:center; gap:.5rem;
	background:#5eead4; color:#0b0f17;
	padding:.85rem 1.4rem; border-radius:.3rem;
	font-weight:700; text-decoration:none;
	align-self:flex-start; position:relative;
	transition: background .15s, transform .15s;
}
.nb-hiring-cta:hover { background:#34d399; color:#0b0f17; transform: translateX(2px); }

/* ── Carousel section ── */
.nb-carousel-grid { display:grid; grid-template-columns: repeat(3, 1fr); gap:1.5rem; }
.nb-carousel .carousel-control-prev,
.nb-carousel .carousel-control-next {
	width:3rem; opacity:1; background: rgba(0,0,0,.04);
	border-radius:.3rem; top:1rem; bottom:1rem;
}
.nb-carousel .carousel-control-prev-icon,
.nb-carousel .carousel-control-next-icon { filter: invert(40%); }
.nb-carousel .carousel-indicators { bottom:-2.5rem; }
.nb-carousel .carousel-indicators button { background:#0f766e; }

/* ── Mobile breakpoints ── */
@media (max-width: 992px) {
	.nb-hero, .nb-fuel-deep, .nb-dirad-banner, .nb-cta-row, .nb-fresh,
	.nb-beats { grid-template-columns: 1fr; }
	.nb-fuel-strip, .nb-picks, .nb-carousel-grid { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 576px) {
	.nb-section { padding: 2rem 0; }
	.nb-fuel-strip, .nb-picks, .nb-carousel-grid { grid-template-columns: 1fr; }
	.nb-side-card { padding-bottom:.85rem; }
	.nb-side-thumb { width:80px; }
}
