/* ============================================================================
   directory.css — shared modern template for the *business.com directory network
   Hand-authored, no build step. Per-country theming via --dir-accent.
   Design ref: recordowl.com (aesthetic only) · identity: sgpbusiness navy + steel.
   Owner: Renderer · Audit: template-redesign
   ========================================================================== */

/* ---- design tokens ------------------------------------------------------- */
:root{
  /* brand constants (network-wide) */
  --navy-900:#00004d; --navy-800:#00006e; --navy-700:#1a1f87; --navy-600:#2a3296;
  --steel-700:#0d5f86; --steel-600:#0F7ABB; --steel-500:#2d8fd0; --steel-100:#e6f1f9;
  /* per-country accent — override per site if desired; defaults to steel */
  --dir-accent:#0F7ABB; --dir-accent-700:#0d5f86; --dir-accent-100:#e6f1f9;
  /* neutrals */
  --ink:#0f172a; --slate-700:#334155; --slate-600:#475569; --slate-500:#64748b;
  --slate-400:#94a3b8; --slate-300:#cbd5e1; --slate-200:#e2e8f0; --slate-100:#f1f5f9;
  --slate-50:#f8fafc; --white:#fff;
  /* status colors */
  --ok-50:#ecfdf5; --ok-600:#059669; --ok-700:#047857; --ok-200:#a7f3d0;
  --warn-50:#fffbeb; --warn-600:#d97706; --warn-700:#b45309; --warn-200:#fde68a;
  --bad-50:#fff1f2; --bad-600:#e11d48; --bad-200:#fecdd3;
  /* shape & depth */
  --r-sm:8px; --r:12px; --r-lg:16px; --r-xl:24px; --r-full:999px;
  --shadow:0 1px 2px rgba(15,23,42,.04),0 4px 16px rgba(15,23,42,.06);
  --shadow-lg:0 10px 30px rgba(15,23,42,.12);
  --ring:1px solid var(--slate-200);
  --maxw:1180px;
  --font: "Inter",system-ui,-apple-system,"Segoe UI",Roboto,sans-serif;
  --font-display:"Plus Jakarta Sans","Inter",system-ui,sans-serif;
}

/* ---- reset / base -------------------------------------------------------- */
*,*::before,*::after{ box-sizing:border-box; }
html{ -webkit-text-size-adjust:100%; scroll-behavior:smooth; scroll-padding-top:64px; }
body{
  margin:0; font-family:var(--font); color:var(--ink); background:var(--slate-50);
  font-size:16px; line-height:1.55; -webkit-font-smoothing:antialiased;
  display:flex; flex-direction:column; min-height:100vh;   /* sticky-footer: footer hugs viewport bottom on short pages */
}
img{ max-width:100%; display:block; }
a{ color:var(--dir-accent-700); text-decoration:none; }
a:hover{ text-decoration:underline; }
h1,h2,h3,h4{ font-family:var(--font-display); color:var(--ink); line-height:1.2; margin:0; font-weight:800; }
p{ margin:0 0 1rem; }
small{ font-size:.82em; }
:focus-visible{ outline:2px solid var(--dir-accent); outline-offset:2px; }

/* ---- layout -------------------------------------------------------------- */
.dir-container{ max-width:var(--maxw); margin:0 auto; padding:0 16px; }
.dir-section{ padding:48px 0; }
.dir-grid{ display:grid; gap:16px; }
.dir-grid-2{ grid-template-columns:repeat(2,1fr); }
.dir-grid-3{ grid-template-columns:repeat(3,1fr); }
.dir-grid-4{ grid-template-columns:repeat(4,1fr); }
.dir-main-aside{ display:grid; grid-template-columns:minmax(0,1fr); gap:32px; }
.dir-main-aside>*{ min-width:0; }   /* let grid children shrink so a fixed-width legacy ad can't widen its column */
@media(min-width:992px){ .dir-main-aside{ grid-template-columns:minmax(0,2fr) minmax(0,1fr); } }
/* 3-column: left scrollable section-nav | main | right rail (content-intense pages) */
.dir-3col{ display:grid; grid-template-columns:1fr; gap:28px; }
@media(min-width:768px){ .dir-3col{ grid-template-columns:190px minmax(0,1fr); } .dir-3col>aside{ grid-column:1 / -1; } }
@media(min-width:1100px){ .dir-3col{ grid-template-columns:190px minmax(0,1fr) 300px; } .dir-3col>aside{ grid-column:auto; } }
.dir-sidenav{ position:sticky; top:78px; align-self:start; max-height:calc(100vh - 96px); overflow-y:auto; padding-right:4px; }
.dir-sidenav .h{ font-size:11px; text-transform:uppercase; letter-spacing:.05em; color:var(--slate-400); font-weight:700; padding:0 10px 8px; }
.dir-sidenav a{ display:flex; align-items:center; gap:9px; padding:7px 10px; border-radius:8px; font-size:13.5px; color:var(--slate-600); }
.dir-sidenav a:hover{ background:var(--slate-100); color:var(--navy-800); text-decoration:none; }
.dir-sidenav a.active{ background:var(--dir-accent-100); color:var(--dir-accent-700); font-weight:600; }
.dir-sidenav a i{ width:16px; text-align:center; color:var(--slate-400); font-size:12px; }
.dir-sidenav a.active i{ color:var(--dir-accent); }
.dir-sidenav::-webkit-scrollbar{ width:6px; } .dir-sidenav::-webkit-scrollbar-thumb{ background:var(--slate-200); border-radius:3px; }
@media(max-width:767px){ .dir-sidenav{ display:none; } }
.dir-stack{ margin-bottom:20px; }
.dir-stack>*+*{ margin-top:24px; }

/* ---- header / nav -------------------------------------------------------- */
.dir-header{
  background:#fff; border-bottom:var(--ring);   /* not sticky — scrolls away with the page */
}
.dir-nav{ display:flex; align-items:center; gap:24px; height:64px; }
.dir-logo{ display:flex; align-items:center; gap:8px; flex-shrink:0; font-family:var(--font-display); font-weight:800; font-size:18px; }
.dir-logo:hover{ text-decoration:none; }
.dir-logo .mark{ display:grid; place-items:center; width:36px; height:36px; border-radius:var(--r-sm);
  background:var(--navy-800); color:#fff; font-weight:800; }
.dir-logo .name b{ color:var(--navy-800); } .dir-logo .name span{ color:var(--dir-accent); }
.dir-navlinks{ display:none; align-items:center; gap:2px; font-size:14px; font-weight:500; }
@media(min-width:992px){ .dir-navlinks{ display:flex; } }
.dir-navlinks a{ color:var(--slate-600); padding:8px 12px; border-radius:var(--r-sm); }
.dir-navlinks a:hover{ background:var(--slate-100); color:var(--navy-800); text-decoration:none; }
.dir-nav-spacer{ margin-left:auto; }
.dir-nav-toggle{ margin-left:auto; display:inline-flex; background:none; border:0; padding:8px; cursor:pointer; color:var(--slate-700); }
@media(min-width:992px){ .dir-nav-toggle{ display:none; } }
.dir-mobilemenu{ display:none; border-top:var(--ring); background:#fff; }
.dir-mobilemenu.open{ display:block; }
.dir-mobilemenu a{ display:block; padding:12px 16px; color:var(--slate-700); border-bottom:var(--ring); }

/* ---- search -------------------------------------------------------------- */
.dir-search{ position:relative; width:100%; max-width:380px; }
.dir-search input{ width:100%; padding:9px 12px 9px 36px; font-size:14px; border:1px solid var(--slate-300);
  border-radius:var(--r-sm); outline:none; background:#fff; }
.dir-search input:focus{ border-color:var(--dir-accent); box-shadow:0 0 0 3px var(--dir-accent-100); }
.dir-search .icon{ position:absolute; left:11px; top:50%; transform:translateY(-50%); color:var(--slate-400); }
@media(max-width:767px){ .dir-nav .dir-search{ display:none; } }
/* page search block (search results / non-home pages) */
.dir-searchblock{ position:relative; display:flex; gap:8px; max-width:560px; }
.dir-searchblock .ico{ position:absolute; left:14px; top:50%; transform:translateY(-50%); color:var(--slate-400); z-index:1; }
.dir-searchblock input{ flex:1; min-width:0; padding:11px 12px 11px 40px; border:1px solid var(--slate-300); border-radius:var(--r-sm); outline:none; }
.dir-searchblock input:focus{ border-color:var(--dir-accent); box-shadow:0 0 0 3px var(--dir-accent-100); }
.dir-searchblock button{ flex-shrink:0; }
.dir-page-h1{ font-size:26px; margin:8px 0 0; }

/* ---- buttons ------------------------------------------------------------- */
.dir-btn{ display:inline-flex; align-items:center; gap:6px; padding:9px 16px; border-radius:var(--r-sm);
  font-weight:600; font-size:14px; border:1px solid transparent; cursor:pointer; transition:.15s; }
.dir-btn:hover{ text-decoration:none; }
.dir-btn-primary{ background:var(--dir-accent); color:#fff; }
.dir-btn-primary:hover{ background:var(--dir-accent-700); color:#fff; }
.dir-btn-navy{ background:var(--navy-800); color:#fff; } .dir-btn-navy:hover{ background:var(--navy-700); color:#fff; }
.dir-btn-ghost{ background:#fff; color:var(--navy-800); border-color:var(--slate-300); }
.dir-btn-ghost:hover{ background:var(--slate-100); }
.dir-btn-glass{ background:rgba(255,255,255,.12); color:#fff; border-color:rgba(255,255,255,.25); }
.dir-btn-glass:hover{ background:rgba(255,255,255,.22); color:#fff; }

/* ---- hero ---------------------------------------------------------------- */
.dir-hero{ color:#fff; text-align:center;
  background:radial-gradient(1200px 500px at 80% -10%,var(--navy-600) 0%,transparent 60%),
             linear-gradient(135deg,var(--navy-900) 0%,var(--navy-800) 55%,var(--steel-700) 130%); }
.dir-hero-inner{ padding:64px 16px; }
@media(min-width:768px){ .dir-hero-inner{ padding:88px 16px; } }
.dir-hero h1{ color:#fff; font-size:clamp(28px,5vw,48px); max-width:760px; margin:0 auto; }
.dir-hero p{ color:rgba(255,255,255,.8); max-width:640px; margin:18px auto 0; font-size:clamp(15px,2vw,18px); }
.dir-eyebrow{ display:inline-flex; align-items:center; gap:8px; font-size:12px; font-weight:600;
  letter-spacing:.06em; text-transform:uppercase; background:rgba(255,255,255,.1);
  border:1px solid rgba(255,255,255,.2); border-radius:var(--r-full); padding:5px 14px; margin-bottom:22px; }
.dir-hero-search{ max-width:660px; margin:30px auto 0; }
.dir-hero-search form{ display:flex; flex-direction:column; gap:8px; background:#fff; padding:8px;
  border-radius:var(--r-lg); box-shadow:var(--shadow-lg); }
@media(min-width:640px){ .dir-hero-search form{ flex-direction:row; } }
.dir-hero-search .field{ position:relative; flex:1; }
.dir-hero-search input{ width:100%; padding:14px 16px 14px 46px; border:0; border-radius:var(--r); font-size:16px;
  color:var(--ink); outline:none; text-transform:uppercase; }
.dir-hero-search input::placeholder{ text-transform:none; color:var(--slate-400); }
.dir-hero-search .icon{ position:absolute; left:14px; top:50%; transform:translateY(-50%); color:var(--slate-400); }
.dir-hero-search button{ padding:14px 28px; border:0; border-radius:var(--r); background:var(--navy-800);
  color:#fff; font-weight:600; cursor:pointer; }
.dir-hero-search button:hover{ background:var(--navy-700); }
.dir-hero-popular{ margin-top:14px; font-size:14px; color:rgba(255,255,255,.65); }
.dir-hero-popular a{ color:rgba(255,255,255,.85); text-decoration:underline; }

/* ---- stat counters ------------------------------------------------------- */
.dir-stats{ position:relative; z-index:10; margin-top:-40px; }
.dir-stat{ background:#fff; border:1px solid var(--slate-100); border-radius:var(--r-lg);
  box-shadow:var(--shadow); padding:20px; }
.dir-stat .num{ font-family:var(--font-display); font-size:30px; font-weight:800; color:var(--navy-800); }
.dir-stat .num em{ color:var(--dir-accent); font-style:normal; }
.dir-stat .lbl{ margin-top:4px; font-size:14px; color:var(--slate-500); }

/* ---- cards --------------------------------------------------------------- */
.dir-card{ background:#fff; border:1px solid var(--slate-100); border-radius:var(--r-lg); box-shadow:var(--shadow); }
.dir-card-pad{ padding:20px; }
.dir-card-head{ padding:16px 20px; border-bottom:var(--ring); }
.dir-card-head h2,.dir-card-head h3{ font-size:18px; }
.dir-card-head .sub{ font-size:14px; color:var(--slate-500); margin-top:2px; }
.dir-section-head{ display:flex; align-items:flex-end; justify-content:space-between; gap:16px; margin-bottom:16px; }
.dir-section-head h2{ font-size:24px; }
.dir-section-head .sub{ font-size:14px; color:var(--slate-500); }
.dir-morelink{ font-size:14px; font-weight:600; color:var(--dir-accent); flex-shrink:0; }

/* ---- list rows (recently-updated / nearby / search results) ------------- */
.dir-list{ display:flex; flex-direction:column; }
.dir-list>*+*{ border-top:var(--ring); }
.dir-row{ display:flex; align-items:center; gap:16px; padding:14px 16px; }
.dir-row:hover{ background:var(--slate-50); text-decoration:none; }
.dir-avatar{ display:grid; place-items:center; width:44px; height:44px; border-radius:var(--r);
  background:var(--dir-accent-100); color:var(--dir-accent-700); font-weight:700; flex-shrink:0; }
.dir-avatar.warn{ background:var(--warn-50); color:var(--warn-700); }
.dir-avatar.bad{ background:var(--bad-50); color:var(--bad-600); }
.dir-row .body{ min-width:0; flex:1; }
.dir-row .title{ font-weight:600; color:var(--ink); white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.dir-row .meta{ font-size:14px; color:var(--slate-500); white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.dir-row .when{ font-size:14px; color:var(--slate-400); white-space:nowrap; }
.dir-chev{ color:var(--slate-300); flex-shrink:0; }
@media(max-width:639px){ .dir-row .when{ display:none; } }

/* card grid items (new registrations) */
.dir-tile{ display:block; background:#fff; border:1px solid var(--slate-100); border-radius:var(--r-lg);
  box-shadow:var(--shadow); padding:20px; transition:.15s; }
.dir-tile:hover{ border-color:var(--dir-accent-500,var(--steel-500)); text-decoration:none; }
.dir-tile .row1{ display:flex; align-items:center; justify-content:space-between; }
.dir-tile .name{ margin-top:12px; font-weight:600; color:var(--ink); }
.dir-tile .addr{ font-size:14px; color:var(--slate-500); margin-top:4px; }

/* ---- badges -------------------------------------------------------------- */
.dir-badge{ display:inline-flex; align-items:center; gap:5px; font-size:12px; font-weight:600;
  padding:3px 10px; border-radius:var(--r-full); border:1px solid transparent; }
.dir-badge-ok{ background:var(--ok-50); color:var(--ok-700); border-color:var(--ok-200); }
.dir-badge-warn{ background:var(--warn-50); color:var(--warn-700); border-color:var(--warn-200); }
.dir-badge-bad{ background:var(--bad-50); color:var(--bad-600); border-color:var(--bad-200); }
.dir-badge-info{ background:var(--dir-accent-100); color:var(--dir-accent-700); }
.dir-badge-neutral{ background:var(--slate-100); color:var(--slate-600); }

/* ---- popular activities / linklist (sidebar) ----------------------------- */
.dir-linklist{ list-style:none; margin:0; padding:0; }
.dir-linklist li{ display:flex; align-items:center; justify-content:space-between; gap:8px; padding:6px 0; font-size:14px; }
.dir-linklist li+li{ border-top:1px dashed var(--slate-100); }
.dir-linklist a{ color:var(--slate-600); }
.dir-linklist a:hover{ color:var(--dir-accent-700); }
.dir-linklist .count{ font-size:12px; font-weight:600; color:var(--slate-400); }

/* related sidebar — lighter, richer list (name + status sub-line) */
.dir-rellist{ list-style:none; margin:0; padding:0; }
.dir-rellist li{ padding:10px 0; }
.dir-rellist li:first-child{ padding-top:2px; }
.dir-rellist li+li{ border-top:1px solid var(--slate-100); }
.dir-rellist a{ display:block; font-weight:500; color:var(--ink); font-size:14px; line-height:1.4; }
.dir-rellist a:hover{ color:var(--dir-accent-700); text-decoration:none; }
.dir-rellist .sub{ display:block; font-size:12px; margin-top:2px; color:var(--slate-500); }
.dir-rellist .sub i{ color:var(--slate-400); margin-right:4px; }
.dir-rellist .st-ok{ color:var(--ok-600); }
.dir-rellist .st-warn{ color:var(--warn-600); }
.dir-rellist .st-bad{ color:var(--bad-600); }

/* ---- alerts / warning cards (enforcement / gazette) ---------------------- */
.dir-alert{ display:flex; gap:12px; padding:16px 18px; border-radius:var(--r-lg); border:1px solid var(--warn-200); background:var(--warn-50); }
.dir-alert .ico{ font-size:20px; flex-shrink:0; }
.dir-alert .t{ font-weight:700; color:var(--warn-700); }
.dir-alert .d{ font-size:14px; color:var(--warn-700); margin-top:2px; }
.dir-alert-bad{ border-color:var(--bad-200); background:var(--bad-50); }
.dir-alert-bad .t,.dir-alert-bad .d{ color:var(--bad-600); }
.dir-alert-l{ border-left:4px solid var(--bad-600); }

/* ---- ad slots: stand-alone, NO placeholder box (Steven 2026-06-19) ------- */
/* A live ad slot must render NOTHING when the ad does not fill — no min-height,
   no dashed border, no white background — so an unfilled / blocked / still-loading
   ad leaves no empty box. The slot collapses to zero height until an ad iframe lands. */
.dir-adslot{ display:block; text-align:center; max-width:100%; overflow:hidden; }
.dir-colmain>.dir-adslot:has(iframe){ margin:0 0 24px 0; }   /* top:0 aligns the main ad with the side/sidebar ads; 24px below it once an ad renders */
/* legacy fixed-size AdSense units (336x280 / 728x15) must never exceed their column width */
ins.adsbygoogle{ max-width:100%; }
/* BS3 `hidden-xs` (faithful restore): the 728x15 link ads are desktop/tablet-only; the redesign dropped
   Bootstrap so this utility went inert and they rendered on mobile, forcing horizontal page overflow
   (about-page mobile overflow, Steven 2026-06-19). Only Ads.php link units carry the class. */
@media(max-width:767px){ .hidden-xs{ display:none !important; } }

/* ---- trust strip --------------------------------------------------------- */
.dir-trust{ background:#fff; border-top:var(--ring); border-bottom:var(--ring); }
.dir-trust .dir-grid{ text-align:center; padding:40px 0; }
.dir-trust .ico{ font-size:24px; }
.dir-trust .t{ font-weight:600; margin-top:6px; }
.dir-trust .d{ font-size:14px; color:var(--slate-500); }

/* ============================ COMPANY PROFILE ============================= */
.dir-cphdr{ color:#fff;
  background:linear-gradient(135deg,var(--navy-900) 0%,var(--navy-800) 60%,var(--steel-700) 130%); }
.dir-cphdr-inner{ padding:24px 16px 0; }
.dir-crumb{ font-size:12px; color:rgba(255,255,255,.6); display:flex; flex-wrap:wrap; gap:6px; margin-bottom:16px; }
.dir-crumb a{ color:rgba(255,255,255,.7); } .dir-crumb a:hover{ color:#fff; }
.dir-crumb .cur{ color:rgba(255,255,255,.85); }
.dir-cptop{ display:flex; flex-direction:column; gap:18px; padding-bottom:22px; }
@media(min-width:640px){ .dir-cptop{ flex-direction:row; align-items:flex-start; } }
.dir-cpmark{ display:grid; place-items:center; width:64px; height:64px; border-radius:var(--r-lg);
  background:rgba(255,255,255,.1); border:1px solid rgba(255,255,255,.2); font-family:var(--font-display);
  font-size:26px; font-weight:800; flex-shrink:0; }
.dir-cpid{ min-width:0; flex:1; }
.dir-cpid h1{ color:#fff; font-size:clamp(22px,3.4vw,30px); display:inline; }
.dir-cpid .sub{ color:rgba(255,255,255,.7); margin-top:6px; }
.dir-cpactions{ display:flex; gap:8px; flex-shrink:0; }
.dir-tabsbar{ position:-webkit-sticky; position:sticky; top:0; z-index:40; background:#fff; border-bottom:1px solid var(--slate-200); box-shadow:0 1px 2px rgba(15,23,42,.04); }
.dir-tabs{ display:flex; gap:2px; overflow-x:auto; font-size:14px; font-weight:500; -webkit-overflow-scrolling:touch; scrollbar-width:none; }
.dir-tabs::-webkit-scrollbar{ height:0; display:none; }
.dir-tabs a{ padding:14px 16px; color:var(--slate-600); border-bottom:2px solid transparent; white-space:nowrap; }
.dir-tabs a:hover{ color:var(--dir-accent-700); text-decoration:none; }
.dir-tabs a.active{ color:var(--dir-accent); border-bottom-color:var(--dir-accent); }
/* fade hint shown only when the tab bar overflows (added by JS) */
.dir-tabsbar.is-scroll::after{ content:""; position:absolute; top:0; right:0; bottom:0; width:40px; background:linear-gradient(90deg, rgba(255,255,255,0), rgba(255,255,255,.97)); pointer-events:none; }

/* definition list (general information) */
.dir-dl{ font-size:14px; }
.dir-dl>div{ display:grid; grid-template-columns:1fr; gap:2px; padding:12px 20px; }
.dir-dl>div+div{ border-top:var(--ring); }
@media(min-width:640px){ .dir-dl>div{ grid-template-columns:1fr 2fr; gap:8px; } }
.dir-dl dt{ color:var(--slate-500); }
.dir-dl dd{ margin:0; color:var(--ink); font-weight:500; }

/* click-to-copy (matches sgpbusiness.com .copy-to-clipboard) */
.copy-to-clipboard{ cursor:pointer; position:relative; border-bottom:1px dashed var(--slate-300); }
.copy-to-clipboard:hover{ border-bottom-color:var(--dir-accent); color:var(--dir-accent-700); }
.copy-to-clipboard.copied{ border-bottom-color:var(--ok-600); }
.copy-to-clipboard.copied::after{ content:"Copied!"; position:absolute; left:50%; bottom:100%; transform:translate(-50%,-5px); background:var(--navy-800); color:#fff; font-size:11px; font-weight:600; padding:3px 8px; border-radius:6px; white-space:nowrap; z-index:5; pointer-events:none; }

/* SSIC / classification tiles */
.dir-ssic{ background:var(--slate-50); border-radius:var(--r); padding:16px; }
.dir-ssic .k{ font-size:12px; text-transform:uppercase; letter-spacing:.04em; color:var(--slate-500); }
.dir-ssic .code{ font-family:var(--font-display); font-size:24px; font-weight:800; color:var(--navy-800); margin-top:4px; }

/* timeline */
.dir-timeline{ list-style:none; margin:0; padding:0 0 0 8px; border-left:2px solid var(--slate-100); }
.dir-timeline li{ position:relative; margin-left:20px; padding-bottom:22px; }
.dir-timeline li:last-child{ padding-bottom:0; }
.dir-timeline .dot{ position:absolute; left:-27px; top:4px; width:12px; height:12px; border-radius:50%;
  background:var(--slate-300); box-shadow:0 0 0 4px #fff; }
.dir-timeline li:first-child .dot{ background:var(--dir-accent); box-shadow:0 0 0 4px var(--dir-accent-100); }
.dir-timeline .when{ font-size:12px; color:var(--slate-400); }
.dir-timeline .what{ font-weight:600; color:var(--ink); }
.dir-timeline .det{ font-size:14px; color:var(--slate-500); }

/* people / officers chips */
.dir-people{ display:grid; grid-template-columns:1fr; gap:12px; }
@media(min-width:640px){ .dir-people{ grid-template-columns:1fr 1fr; } }
.dir-person{ display:flex; align-items:center; gap:12px; border:var(--ring); border-radius:var(--r); padding:12px; }
.dir-person .pa{ display:grid; place-items:center; width:36px; height:36px; border-radius:50%;
  background:var(--navy-800); color:#fff; font-size:12px; font-weight:700; flex-shrink:0; }
.dir-person .pn{ font-weight:500; } .dir-person .pr{ font-size:12px; color:var(--slate-500); }

/* shareholders — share-distribution bar */
.dir-sharebar{ display:flex; height:16px; border-radius:var(--r-full); overflow:hidden; background:var(--slate-100); margin:4px 0 16px; cursor:default; }
.dir-sharebar span{ display:block; height:100%; min-width:2px; transition:filter .12s, box-shadow .12s; }
.dir-sharebar span.hl{ filter:brightness(1.18); box-shadow:inset 0 0 0 2px rgba(255,255,255,.7); }
.dir-swatch{ display:inline-block; width:10px; height:10px; border-radius:3px; margin-right:7px; vertical-align:middle; }
.dir-shrow{ padding:12px 8px; margin:0 -8px; border-top:1px solid var(--slate-100); border-radius:10px; transition:background .12s; cursor:default; }
.dir-shrow.hl{ background:var(--dir-accent-100); }

/* generic prose block (About / company information) */
.dir-prose{ font-size:14px; color:var(--slate-600); line-height:1.7; }
.dir-prose strong{ color:var(--ink); }
.dir-prose h2{ font-size:18px; margin:20px 0 8px; }
.dir-prose h3{ font-size:16px; margin:16px 0 6px; }
.dir-prose ul{ margin:8px 0; padding-left:20px; }
.dir-prose li{ margin:4px 0; }
.dir-prose a{ color:var(--dir-accent-700); }

/* ---- footer (cross-network) --------------------------------------------- */
.dir-footer{ background:var(--navy-900); color:var(--slate-300); margin-top:auto; }
.dir-footer-grid{ display:grid; grid-template-columns:1fr; gap:32px; padding:48px 0; font-size:14px; }
@media(min-width:768px){ .dir-footer-grid{ grid-template-columns:1.6fr 1fr 1fr; } }
.dir-footer h4{ color:#fff; font-size:16px; font-weight:600; margin:0 0 12px; }
.dir-footer a{ color:var(--slate-400); } .dir-footer a:hover{ color:#fff; }
.dir-footer ul{ list-style:none; margin:0; padding:0; }
.dir-footer li{ margin:3px 0 0 0; }
.dir-footer-search{ display:flex; align-items:center; margin-top:12px; max-width:300px; background:rgba(255,255,255,.08); border:1px solid rgba(255,255,255,.15); border-radius:var(--r-sm); overflow:hidden; }
.dir-footer-search input{ flex:1; min-width:0; background:transparent; border:0; color:#fff; padding:9px 12px; font-size:13px; font-family:var(--font); outline:none; }
.dir-footer-search input::placeholder{ color:var(--slate-400); text-transform:none; }
.dir-footer-search button{ background:transparent; border:0; color:var(--slate-300); padding:0 12px; align-self:stretch; cursor:pointer; font-size:14px; }
.dir-footer-search button:hover{ color:#fff; }
.dir-footer .brand{ display:flex; align-items:center; gap:8px; margin-bottom:12px; }
.dir-footer .brand .mark{ display:grid; place-items:center; width:32px; height:32px; border-radius:var(--r-sm);
  background:rgba(255,255,255,.1); color:#fff; font-weight:800; font-family:var(--font-display); }
.dir-footer .brand .name{ color:#fff; font-size:16px; font-weight:800; font-family:var(--font-display); }
.dir-footer .lede{ color:var(--slate-400); line-height:1.6; }
.dir-footer-bar{ border-top:1px solid rgba(255,255,255,.1); }
.dir-footer-bar .in{ display:flex; flex-direction:column; gap:6px; justify-content:space-between;
  padding:18px 0; font-size:12px; color:var(--slate-500); }
@media(min-width:640px){ .dir-footer-bar .in{ flex-direction:row; } }
.dir-flag{ display:inline-block; width:1.2em; margin-right:.4em; }  /* flag-icon-css adds the image */
.dir-disclaimer{ font-size:12px; color:var(--slate-500); line-height:1.6; margin-top:8px; }

/* ---- pagination ---------------------------------------------------------- */
.dir-pager{ display:flex; flex-wrap:wrap; gap:4px; list-style:none; padding:0; margin:16px 0 0; }
.dir-pager a,.dir-pager span{ display:inline-flex; min-width:38px; height:38px; align-items:center; justify-content:center;
  padding:0 10px; border:var(--ring); border-radius:var(--r-sm); background:#fff; color:var(--slate-600); font-size:14px; }
.dir-pager a:hover{ background:var(--slate-100); text-decoration:none; }
.dir-pager .active span,.dir-pager .active a{ background:var(--dir-accent); color:#fff; border-color:var(--dir-accent); }
.dir-pager .disabled span{ color:var(--slate-300); }

/* A–Z alpha nav */
.dir-alpha{ display:flex; flex-wrap:wrap; gap:4px; list-style:none; padding:0; margin:0 0 16px; }
.dir-alpha a{ display:grid; place-items:center; width:36px; height:36px; border:var(--ring); border-radius:var(--r-sm);
  background:#fff; color:var(--slate-600); font-weight:600; font-size:14px; }
.dir-alpha a:hover{ background:var(--slate-100); text-decoration:none; }
.dir-alpha .active a{ background:var(--navy-800); color:#fff; border-color:var(--navy-800); }

/* company-list — single-column enriched rows (sgpbusiness-style) */
.dir-coylist{ display:flex; flex-direction:column; background:#fff; border:var(--ring); border-radius:var(--r-lg); box-shadow:var(--shadow); overflow:hidden; }
.dir-coylist .item{ display:flex; gap:14px; padding:14px 16px; align-items:flex-start; }
.dir-coylist .item:hover{ background:var(--slate-50); text-decoration:none; }
.dir-coylist .item+.item{ border-top:var(--ring); }
.dir-coylist .av{ display:grid; place-items:center; width:44px; height:44px; border-radius:var(--r); background:var(--dir-accent-100); color:var(--dir-accent-700); font-weight:700; font-size:14px; flex-shrink:0; }
.dir-coylist .body{ min-width:0; flex:1; }
.dir-coylist .nm{ display:block; font-weight:600; color:var(--ink); }
.dir-coylist .item:hover .nm{ color:var(--dir-accent-700); }
.dir-coylist .nm .dir-badge{ vertical-align:middle; margin-left:6px; font-weight:600; }
.dir-coylist .meta{ display:block; font-size:13.5px; color:var(--slate-500); margin-top:4px; line-height:1.55; }
.dir-coylist .meta i{ color:var(--slate-400); margin-right:5px; }

/* ---- data table (shareholders, etc.) ------------------------------------ */
.dir-table-wrap{ overflow-x:auto; }
.dir-table{ width:100%; border-collapse:collapse; font-size:14px; }
.dir-table th{ text-align:left; font-weight:600; color:var(--slate-500); font-size:11px; text-transform:uppercase; letter-spacing:.04em; padding:8px 10px; border-bottom:1px solid var(--slate-200); white-space:nowrap; }
.dir-table td{ padding:10px; border-bottom:1px solid var(--slate-100); vertical-align:top; }
.dir-table tr:last-child td{ border-bottom:0; }
.dir-table td.num, .dir-table th.num{ text-align:right; font-variant-numeric:tabular-nums; white-space:nowrap; }
.dir-table tbody tr:hover td{ background:var(--slate-50); }
.dir-rank{ color:var(--slate-400); font-variant-numeric:tabular-nums; }

/* ---- mobile polish (phones) ---------------------------------------------- */
@media(max-width:640px){
  .dir-cphdr-inner{ padding:16px 16px 0; }
  .dir-cpmark{ width:48px; height:48px; font-size:20px; border-radius:var(--r); }
  .dir-cpid h1{ font-size:21px; }
  .dir-cptop{ gap:12px; padding-bottom:16px; }
  .dir-card-pad{ padding:16px; }
  .dir-card-head{ padding:14px 16px; }
  .dir-dl>div{ padding:10px 16px; }
  .dir-table{ font-size:13px; }
  .dir-table th, .dir-table td{ padding:8px; }
  .dir-section-head h2{ font-size:20px; }
  .dir-hero-inner{ padding:48px 16px; }
  .dir-tabs a{ padding:13px 13px; }
}

/* ---- utilities ----------------------------------------------------------- */
.dir-muted{ color:var(--slate-500); }
.dir-mt{ margin-top:24px; } .dir-mb{ margin-bottom:24px; }
.dir-hide-sm{ display:none; } @media(min-width:640px){ .dir-hide-sm{ display:initial; } }
.dir-truncate{ white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.dir-responsive-embed{ position:relative; padding-bottom:56.25%; height:0; overflow:hidden; border-radius:var(--r); }
.dir-responsive-embed iframe{ position:absolute; inset:0; width:100%; height:100%; border:0; }
