/*
Theme Name: Skharti — Agile Intelligence
Theme URI: https://skharti.ge
Author: Skharti
Author URI: https://skharti.ge
Description: Custom theme for Skharti, an agile intelligence hub for the Caucasus and Central Asia. Includes a filterable Insights Hub (custom post type + taxonomies with AJAX filtering), Services, Academy, Media and About templates. Fully responsive (3/2/1 grid, sidebar collapses to drawer below 1024px).
Version: 1.0.0
Requires at least: 6.0
Tested up to: 6.5
Requires PHP: 7.4
License: GNU General Public License v2 or later
License URI: http://www.gnu.org/licenses/gpl-2.0.html
Text Domain: skharti
*/

/* =========================================================================
   DESIGN TOKENS
   ========================================================================= */
:root{
  --navy:#1D2549;
  --navy-soft:#2a3160;
  --navy-light:#232a52;
  --paper:#f6f4ef;
  --paper-card:#faf8f4;
  --line:#e4e0d6;
  --orange:#E75333;
  --orange-deep:#cf4527;
  --orange-soft:#ff8a6b;
  --gray:#6a6e85;
  --ink:#1c1f2e;
  --white:#ffffff;
  --serif:"Playfair Display", Georgia, "Times New Roman", serif;
  --mono:"IBM Plex Mono", ui-monospace, "SF Mono", Menlo, monospace;
  --sans:"Inter", system-ui, -apple-system, "Segoe UI", Roboto, sans-serif;
  --maxw:1160px;
  --radius:14px;
}

/* =========================================================================
   RESET / BASE
   ========================================================================= */
*,*::before,*::after{box-sizing:border-box;}
html{scroll-behavior:smooth;}
body{
  margin:0;
  font-family:var(--sans);
  color:var(--ink);
  background:var(--paper);
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
}
img{max-width:100%;height:auto;}
a{color:inherit;text-decoration:none;}
h1,h2,h3,h4{font-family:var(--serif);color:var(--navy);line-height:1.15;margin:0 0 .5em;font-weight:600;}
h1{font-size:clamp(34px,5vw,52px);}
h2{font-size:clamp(26px,3.4vw,38px);}
h3{font-size:20px;}
h4{font-size:15px;}
p{margin:0 0 1em;color:var(--gray);}
section{padding:72px 0;}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 24px;}
.center{text-align:center;margin-left:auto;margin-right:auto;}

/* =========================================================================
   SHARED ELEMENTS
   ========================================================================= */
.eyebrow{
  display:inline-flex;align-items:center;gap:8px;
  font-family:var(--mono);font-size:12px;letter-spacing:.14em;text-transform:uppercase;
  color:var(--orange-deep);font-weight:600;margin-bottom:14px;
}
.eyebrow.on-dark{color:var(--orange-soft);}
.eyebrow.center{justify-content:center;}
.eyebrow .wedge{width:22px;height:22px;}
.num{
  display:inline-block;font-family:var(--mono);font-size:12px;letter-spacing:.1em;
  text-transform:uppercase;color:var(--orange-deep);font-weight:600;margin-bottom:10px;
}
.lede{font-size:clamp(16px,1.7vw,19px);color:var(--gray);max-width:680px;}
.lede.center{margin-left:auto;margin-right:auto;}

/* Wedge / logo mark */
.wedge{display:inline-block;border-radius:6px;overflow:hidden;}

/* =========================================================================
   BUTTONS
   ========================================================================= */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:8px;
  font-family:var(--sans);font-weight:600;font-size:14px;
  padding:11px 20px;border-radius:10px;border:1.5px solid transparent;
  cursor:pointer;transition:.18s ease;white-space:nowrap;
}
.btn-lg{padding:15px 28px;font-size:15px;}
.btn-orange{background:var(--orange);color:#fff;}
.btn-orange:hover{background:var(--orange-deep);}
.btn-outline{border-color:rgba(255,255,255,.4);color:#fff;}
.btn-outline:hover{border-color:#fff;background:rgba(255,255,255,.08);}
.btn-outline-navy{border-color:var(--navy);color:var(--navy);}
.btn-outline-navy:hover{background:var(--navy);color:#fff;}

/* =========================================================================
   HEADER
   ========================================================================= */
header.site{
  position:sticky;top:0;z-index:50;
  background:var(--navy);color:#fff;
  border-bottom:1px solid rgba(255,255,255,.08);
}
.header-inner{
  max-width:var(--maxw);margin:0 auto;padding:14px 24px;
  display:flex;align-items:center;gap:28px;
}
.logo{display:flex;align-items:center;gap:11px;}
.logo .mark{width:34px;height:34px;flex:none;display:inline-flex;align-items:center;justify-content:center;}
.skharti-mark{display:block;}
.logo .word{display:block;font-family:var(--serif);font-weight:700;font-size:18px;letter-spacing:.04em;color:#fff;}
.logo .sub{display:block;font-family:var(--mono);font-size:9px;letter-spacing:.22em;color:var(--orange-soft);}
nav.main{display:flex;gap:26px;margin-left:8px;}
nav.main a{font-size:14px;font-weight:500;color:#cfd2e6;padding:6px 0;position:relative;transition:.15s;}
nav.main a:hover{color:#fff;}
nav.main a.active{color:#fff;}
nav.main a.active::after{
  content:"";position:absolute;left:0;right:0;bottom:-2px;height:2px;background:var(--orange);border-radius:2px;
}
.header-right{display:flex;align-items:center;gap:12px;margin-left:auto;}
.icon-btn{background:none;border:none;color:#cfd2e6;cursor:pointer;display:flex;padding:4px;}
.icon-btn:hover{color:#fff;}
.lang-toggle{display:flex;gap:2px;font-family:var(--mono);font-size:11px;font-weight:600;}
.lang-toggle span{padding:3px 6px;border-radius:5px;color:#9499c4;cursor:pointer;}
.lang-toggle span.active{background:rgba(255,255,255,.12);color:#fff;}
.hamburger{display:none;background:none;border:none;cursor:pointer;padding:4px;}

/* Mobile nav drawer */
.mobile-drawer{
  display:none;position:fixed;inset:0;z-index:60;
}
.mobile-drawer.open{display:block;}
.mobile-drawer .scrim{position:absolute;inset:0;background:rgba(8,9,24,.55);}
.mobile-drawer .panel{
  position:absolute;top:0;right:0;height:100%;width:min(320px,84vw);
  background:var(--navy);padding:24px 22px;display:flex;flex-direction:column;gap:6px;
  box-shadow:-12px 0 40px rgba(0,0,0,.4);overflow-y:auto;
}
.mobile-drawer .panel a.m-nav{color:#cfd2e6;font-size:16px;font-weight:500;padding:12px 0;border-bottom:1px solid rgba(255,255,255,.07);}
.mobile-drawer .panel a.m-nav.active{color:#fff;}
.mobile-drawer .panel .m-actions{margin-top:18px;display:flex;flex-direction:column;gap:10px;}
.mobile-drawer .close-x{align-self:flex-end;background:none;border:none;color:#fff;cursor:pointer;margin-bottom:8px;}

/* =========================================================================
   HERO
   ========================================================================= */
.hero{background:var(--navy);color:#fff;padding:90px 0 84px;}
.hero-inner{max-width:var(--maxw);margin:0 auto;padding:0 24px;}
.hero h1{color:#fff;max-width:840px;}
.hero .lede{color:#c4c7e0;}
.hero-ctas{display:flex;flex-wrap:wrap;gap:14px;margin-top:30px;}

/* =========================================================================
   DARK SECTION
   ========================================================================= */
.section-dark{background:var(--navy);color:#fff;}
.section-dark h1,.section-dark h2,.section-dark h3{color:#fff;}
.section-dark p{color:#b9bdd6;}
.section-dark .card{background:var(--navy-soft);border-color:rgba(255,255,255,.08);}
.section-dark .card h3{color:#fff;}
.section-dark .card p{color:#b9bdd6;}

/* =========================================================================
   GRID + CARDS
   ========================================================================= */
.grid-2{display:grid;grid-template-columns:repeat(2,1fr);gap:22px;}
.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;}
.card{
  background:var(--white);border:1px solid var(--line);border-radius:var(--radius);
  padding:26px 24px;transition:.18s ease;
}
.card:hover{transform:translateY(-2px);box-shadow:0 12px 30px rgba(22,25,63,.08);}
.card h3{margin-bottom:8px;}
.card p:last-child{margin-bottom:0;}
a.card{display:block;}

/* Team cards */
.team-card h3{margin-top:18px;margin-bottom:2px;}
.team-card .role{font-family:var(--mono);font-size:12px;letter-spacing:.06em;text-transform:uppercase;color:var(--orange-deep);font-weight:600;margin-bottom:14px;}

/* Pricing tiers */
.price-tier{display:flex;flex-direction:column;}
.price-tier .price{font-family:var(--serif);font-size:30px;color:var(--navy);font-weight:700;margin:6px 0 16px;}
.price-tier ul{list-style:none;padding:0;margin:0 0 22px;}
.price-tier ul li{position:relative;padding:6px 0 6px 22px;font-size:14px;color:var(--gray);}
.price-tier ul li::before{content:"";position:absolute;left:0;top:13px;width:8px;height:8px;border-radius:50%;background:var(--orange);}
.price-tier.featured{border:2px solid var(--orange);box-shadow:0 12px 30px rgba(242,106,50,.12);}

/* =========================================================================
   INSIGHTS HUB
   ========================================================================= */
.hub-intro{max-width:var(--maxw);margin:0 auto;padding:56px 24px 8px;}
.hub-title{margin:6px 0 12px;}
.hub-sub{font-size:clamp(16px,1.7vw,19px);color:var(--gray);max-width:760px;}

.hub-layout{
  max-width:var(--maxw);margin:0 auto;padding:28px 24px 64px;
  display:grid;grid-template-columns:280px 1fr;gap:34px;align-items:start;
}

/* Filters sidebar */
.filters{
  position:sticky;top:84px;
  max-height:calc(100vh - 104px);overflow-y:auto;
  background:var(--paper-card);border:1px solid var(--line);border-radius:var(--radius);
  padding:18px;
}
.search-field{
  display:flex;align-items:center;gap:8px;background:#fff;border:1px solid var(--line);
  border-radius:9px;padding:9px 12px;margin-bottom:16px;color:var(--gray);
}
.search-field input{border:none;outline:none;width:100%;font-size:14px;background:transparent;color:var(--ink);}
.filter-group{border-top:1px solid var(--line);padding:6px 0;}
.filter-head{
  width:100%;background:none;border:none;cursor:pointer;
  display:flex;align-items:center;justify-content:space-between;
  font-family:var(--sans);font-weight:600;font-size:14px;color:var(--navy);
  padding:10px 2px;
}
.filter-head .chev{transition:.2s;}
.filter-group.collapsed .filter-body{display:none;}
.filter-group.collapsed .chev{transform:rotate(-90deg);}
.filter-body{padding:2px 2px 10px;overflow-y:auto;}
.check-row{
  display:flex;align-items:center;gap:9px;padding:6px 2px;font-size:13.5px;color:var(--ink);cursor:pointer;
}
.check-row input{display:none;}
.check-box{width:16px;height:16px;border:1.5px solid var(--line);border-radius:4px;flex:none;position:relative;transition:.15s;}
.check-row input:checked + .check-box{background:var(--orange);border-color:var(--orange);}
.check-row input:checked + .check-box::after{
  content:"";position:absolute;left:4px;top:1px;width:4px;height:8px;border:solid #fff;border-width:0 2px 2px 0;transform:rotate(45deg);
}
.check-row .count{margin-left:auto;font-family:var(--mono);font-size:11px;color:var(--gray);}
.pill-row{display:flex;flex-wrap:wrap;gap:6px;}
.pill-toggle{
  font-family:var(--mono);font-size:12px;padding:5px 11px;border-radius:20px;
  border:1px solid var(--line);background:#fff;color:var(--gray);cursor:pointer;transition:.15s;
}
.pill-toggle.active{background:var(--navy);border-color:var(--navy);color:#fff;}
.clear-filters{
  width:100%;margin-top:14px;background:none;border:1px solid var(--line);border-radius:9px;
  padding:10px;font-family:var(--sans);font-size:13px;font-weight:600;color:var(--gray);cursor:pointer;
}
.clear-filters:hover{border-color:var(--orange);color:var(--orange-deep);}

/* Active chips */
.active-chips{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:18px;}
.chip{
  display:inline-flex;align-items:center;gap:6px;background:var(--navy);color:#fff;
  font-size:12.5px;font-weight:500;padding:5px 6px 5px 12px;border-radius:20px;
}
.chip button{background:rgba(255,255,255,.2);border:none;color:#fff;width:18px;height:18px;border-radius:50%;cursor:pointer;line-height:1;font-size:13px;}

/* Toolbar */
.toolbar{display:flex;align-items:center;justify-content:space-between;gap:16px;flex-wrap:wrap;margin-bottom:20px;}
.results-count{margin:0;font-size:14px;color:var(--gray);}
.results-count b{color:var(--navy);}
.sort-tabs{display:flex;gap:4px;background:var(--paper-card);border:1px solid var(--line);border-radius:9px;padding:3px;}
.sort-tab{background:none;border:none;font-family:var(--sans);font-size:13px;font-weight:500;color:var(--gray);padding:7px 13px;border-radius:7px;cursor:pointer;}
.sort-tab.active{background:#fff;color:var(--navy);font-weight:600;box-shadow:0 1px 3px rgba(0,0,0,.06);}

/* Insight grid + cards */
.insight-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:18px;}
.insight-grid--3{grid-template-columns:repeat(3,1fr);}
.insight-grid--2{grid-template-columns:repeat(2,1fr);}

/* News & Updates (homepage) — left rail + cards */
.news-section{background:var(--paper-card);border-top:1px solid var(--line);border-bottom:1px solid var(--line);}
.news-layout{display:grid;grid-template-columns:300px 1fr;gap:40px;align-items:start;}
.news-aside{position:sticky;top:96px;}
.news-aside h2{margin:6px 0 12px;}
.news-aside-sub{font-size:15px;color:var(--gray);margin-bottom:20px;}
.news-filter{display:block;margin-bottom:20px;}
.news-filter span{display:block;font-family:var(--mono);font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:var(--gray);margin-bottom:7px;}
.news-filter select{
  width:100%;appearance:none;-webkit-appearance:none;
  background:#fff url("data:image/svg+xml;charset=utf8,%3Csvg xmlns='http://www.w3.org/2000/svg' width='14' height='14' viewBox='0 0 24 24' fill='none'%3E%3Cpath d='m6 9 6 6 6-6' stroke='%236a6e85' stroke-width='2' stroke-linecap='round'/%3E%3C/svg%3E") no-repeat right 14px center;
  border:1px solid var(--line);border-radius:10px;padding:12px 40px 12px 14px;
  font-family:var(--sans);font-size:14.5px;font-weight:600;color:var(--navy);cursor:pointer;
}
.news-filter select:focus{outline:none;border-color:var(--orange);}
.news-main .insight-grid{transition:opacity .15s;}
.news-main .insight-grid.is-loading{opacity:.45;pointer-events:none;}
.insight-card{
  background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:22px;
  display:flex;flex-direction:column;transition:.18s ease;
}
.insight-card:hover{transform:translateY(-2px);box-shadow:0 12px 30px rgba(22,25,63,.08);}
.card-tags{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:12px;}
.tag{font-family:var(--mono);font-size:10.5px;letter-spacing:.04em;text-transform:uppercase;font-weight:600;padding:4px 9px;border-radius:6px;}
.tag.sector{background:#eef0fb;color:var(--navy);}
.tag.focus{background:#fdeee7;color:var(--orange-deep);}
.tag.type{background:var(--navy);color:#fff;}
.card-meta{display:flex;align-items:center;gap:8px;font-family:var(--mono);font-size:11.5px;color:var(--gray);margin-bottom:10px;}
.card-meta .dot{width:3px;height:3px;border-radius:50%;background:var(--gray);display:inline-block;}
.card-title{margin:0 0 8px;font-size:18px;}
.card-preview{font-size:14px;color:var(--gray);margin-bottom:16px;}
.card-link{margin-top:auto;display:inline-flex;align-items:center;gap:6px;font-size:13px;font-weight:600;color:var(--orange-deep);}
.card-link:hover{gap:9px;}
.load-more-wrap{display:flex;justify-content:center;margin-top:34px;}
.load-more{
  display:inline-flex;align-items:center;gap:8px;background:#fff;border:1px solid var(--line);
  border-radius:10px;padding:13px 24px;font-family:var(--sans);font-weight:600;font-size:14px;color:var(--navy);cursor:pointer;
}
.load-more:hover{border-color:var(--orange);color:var(--orange-deep);}
.no-results{padding:40px;text-align:center;color:var(--gray);grid-column:1/-1;}
.is-loading{opacity:.5;pointer-events:none;}

.annot{max-width:var(--maxw);margin:0 auto 30px;padding:0 24px;font-family:var(--mono);font-size:12px;color:var(--gray);}

/* =========================================================================
   INSIGHT CONTENT MEDIA (galleries, video embeds, file attachments)
   ========================================================================= */
.insight-content{font-size:16px;color:var(--ink);line-height:1.7;}
.insight-content p{color:var(--ink);}
.insight-content h2,.insight-content h3{margin-top:1.4em;}
.insight-content img{border-radius:10px;}
.insight-content figure{margin:1.6em 0;}
.insight-content .wp-block-gallery{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;list-style:none;padding:0;}
.insight-content .wp-block-gallery .wp-block-image{margin:0;}
.insight-content .wp-block-gallery img{width:100%;height:100%;object-fit:cover;aspect-ratio:1/1;}
/* Responsive video/oEmbed */
.insight-content .wp-block-embed__wrapper{position:relative;padding-top:56.25%;}
.insight-content .wp-block-embed__wrapper iframe{position:absolute;inset:0;width:100%;height:100%;border:0;border-radius:10px;}
.insight-content video{width:100%;border-radius:10px;}
/* File / download block */
.insight-content .wp-block-file{
  display:flex;align-items:center;justify-content:space-between;gap:14px;flex-wrap:wrap;
  background:var(--paper-card);border:1px solid var(--line);border-radius:10px;padding:14px 18px;margin:1.2em 0;
}
.insight-content .wp-block-file__button{
  background:var(--orange);color:#fff;border-radius:8px;padding:9px 16px;font-weight:600;font-size:13px;text-decoration:none;
}
@media(max-width:560px){.insight-content .wp-block-gallery{grid-template-columns:repeat(2,1fr);}}

/* =========================================================================
   FOOTER
   ========================================================================= */
footer.site{background:var(--navy);color:#fff;}
.footer-top{
  max-width:var(--maxw);margin:0 auto;padding:56px 24px 40px;
  display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:34px;
}
.foot-brand .logo{margin-bottom:16px;}
.foot-tagline{color:#9499c4;font-size:14px;max-width:300px;}
.foot-social{display:flex;gap:10px;margin-top:16px;}
.foot-social a{width:34px;height:34px;border-radius:8px;background:rgba(255,255,255,.08);display:flex;align-items:center;justify-content:center;color:#cfd2e6;transition:.15s;}
.foot-social a:hover{background:var(--orange);color:#fff;}
.foot-col h4{font-family:var(--sans);color:#fff;font-size:13px;letter-spacing:.04em;text-transform:uppercase;margin-bottom:16px;}
.foot-col ul{list-style:none;padding:0;margin:0;}
.foot-col ul li{padding:5px 0;color:#9499c4;font-size:14px;}
.foot-col ul li a:hover{color:#fff;}
.footer-bottom{border-top:1px solid rgba(255,255,255,.08);}
.footer-bottom-inner{max-width:var(--maxw);margin:0 auto;padding:18px 24px;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:12px;}
.footer-bottom-inner p{margin:0;color:#9499c4;font-size:13px;}
.legal-links{display:flex;flex-wrap:wrap;gap:18px;}
.legal-links a{color:#9499c4;font-size:13px;}
.legal-links a:hover{color:#fff;}

/* =========================================================================
   RESPONSIVE
   ========================================================================= */
@media(max-width:1024px){
  nav.main,.lang-toggle,.header-right .btn,.icon-btn{display:none;}
  .hamburger{display:flex;}
  .hub-layout{grid-template-columns:1fr;}
  .filters{
    position:fixed;top:0;left:0;height:100%;width:min(340px,88vw);z-index:60;
    border-radius:0;transform:translateX(-105%);transition:.25s ease;overflow-y:auto;
  }
  .filters.open{transform:translateX(0);box-shadow:12px 0 40px rgba(0,0,0,.3);}
  .filter-toggle-btn{display:inline-flex;}
}
@media(max-width:820px){
  section{padding:52px 0;}
  .grid-3{grid-template-columns:repeat(2,1fr);}
  .footer-top{grid-template-columns:1fr 1fr;}
  .insight-grid{grid-template-columns:1fr;}
  .insight-grid--2,.insight-grid--3{grid-template-columns:1fr;}
  .news-layout{grid-template-columns:1fr;gap:24px;}
  .news-aside{position:static;}
  [style*="grid-column:span 3"]{grid-column:auto !important;}
}
@media(max-width:560px){
  .grid-2,.grid-3{grid-template-columns:1fr;}
  .footer-top{grid-template-columns:1fr;}
  .hero{padding:60px 0 56px;}
  .footer-bottom-inner{flex-direction:column;align-items:flex-start;}
}

/* Filter toggle button (mobile only) */
.filter-toggle-btn{
  display:none;align-items:center;gap:8px;margin-bottom:18px;
  background:var(--navy);color:#fff;border:none;border-radius:10px;
  padding:11px 18px;font-family:var(--sans);font-weight:600;font-size:14px;cursor:pointer;
}

/* ------------------------------------------------------------------ */
/* Partners "Trusted by" logo bar                                     */
/* ------------------------------------------------------------------ */
.partners-section {
	padding: 48px 0 56px;
	background: var(--paper-card);
	border-top: 1px solid var(--line);
}
.partners-title {
	text-align: center;
	font-family: var(--mono);
	font-size: 12px;
	letter-spacing: 0.14em;
	text-transform: uppercase;
	color: var(--gray);
	margin: 0 0 28px;
}
/* Static centered row (few logos) */
.partners-row {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	justify-content: center;
	gap: 44px;
}
.partner-logo {
	display: inline-flex;
	align-items: center;
	justify-content: center;
}
.partner-logo img {
	max-height: 46px;
	width: auto;
	object-fit: contain;
	filter: grayscale(1);
	opacity: 0.65;
	transition: filter 0.25s ease, opacity 0.25s ease;
}
.partner-logo:hover img {
	filter: grayscale(0);
	opacity: 1;
}
/* Scrolling marquee (many logos) */
.partners-marquee {
	overflow: hidden;
	position: relative;
	-webkit-mask-image: linear-gradient(90deg, transparent, #000 8%, #000 92%, transparent);
	        mask-image: linear-gradient(90deg, transparent, #000 8%, #000 92%, transparent);
}
.partners-track {
	display: inline-flex;
	align-items: center;
	gap: 56px;
	white-space: nowrap;
	will-change: transform;
	animation: skharti-marquee 40s linear infinite;
}
.partners-marquee:hover .partners-track {
	animation-play-state: paused;
}
@keyframes skharti-marquee {
	from { transform: translateX(0); }
	to   { transform: translateX(-50%); }
}
@media (max-width: 560px) {
	.partners-row { gap: 28px; }
	.partner-logo img { max-height: 38px; }
	.partners-track { gap: 40px; }
}

/* ------------------------------------------------------------------ */
/* Sticky social rail (right edge, all pages)                          */
/* ------------------------------------------------------------------ */
.social-rail {
	position: fixed;
	right: 0;
	top: 50%;
	transform: translateY(-50%);
	z-index: 900;
	display: flex;
	flex-direction: column;
	gap: 2px;
	background: var(--navy);
	border-radius: 10px 0 0 10px;
	padding: 8px 6px;
	box-shadow: 0 6px 24px rgba(0,0,0,0.18);
}
.social-rail a {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 38px;
	height: 38px;
	border-radius: 8px;
	color: #fff;
	opacity: 0.85;
	transition: background 0.2s ease, opacity 0.2s ease, transform 0.2s ease;
}
.social-rail a:hover {
	background: var(--orange);
	opacity: 1;
	transform: translateX(-2px);
}
@media (max-width: 768px) {
	/* On phones, move to bottom as a horizontal bar so it never covers content */
	.social-rail {
		right: 50%;
		top: auto;
		bottom: 14px;
		transform: translateX(50%);
		flex-direction: row;
		border-radius: 12px;
		padding: 6px 8px;
	}
	.social-rail a { width: 40px; height: 40px; }
	.social-rail a:hover { transform: none; }
}
