/* ============================================================
   Phone Book of the World — shared stylesheet (pbof.css)
   Design system aligned with the new homepage (Fraunces + Outfit).
   Replicable across the 250 country pages.
   ============================================================ */

:root{
  --ink:#16202e;--muted:#5a6878;--accent:#1b4e8e;--accent-dark:#123862;
  --gold:#b08a3e;--gold-soft:#d9c08a;--bg:#fbfaf7;--bg-soft:#f3f1ea;--card:#fff;
  --border:#e6e2d7;--shadow:0 1px 3px rgba(20,30,45,.06),0 8px 24px rgba(20,30,45,.05);
  --shadow-lg:0 12px 48px rgba(20,30,45,.12);--radius:16px;--maxw:1180px;
  /* pillar accents */
  --white-c:#5a6878;--yellow-c:#c79a16;--travel-c:#b0442e;
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{font-family:'Outfit',sans-serif;color:var(--ink);background:var(--bg);line-height:1.6;-webkit-font-smoothing:antialiased;overflow-x:hidden}
a{color:inherit;text-decoration:none}
img{max-width:100%;height:auto}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 24px}
h1,h2,h3,h4{font-family:'Fraunces',serif;font-weight:600;line-height:1.1;letter-spacing:-.5px}
body::before{content:"";position:fixed;inset:0;pointer-events:none;z-index:1;opacity:.4;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='120' height='120'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='2'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='.04'/%3E%3C/svg%3E")}

/* ---------- NAV ---------- */
header.nav{position:sticky;top:0;z-index:100;background:rgba(251,250,247,.92);backdrop-filter:blur(12px);border-bottom:1px solid var(--border)}
.nav-inner{display:flex;align-items:center;justify-content:space-between;height:66px;max-width:var(--maxw);margin:0 auto;padding:0 24px}
.brand{font-family:'Fraunces',serif;font-size:1.3rem;font-weight:600;letter-spacing:-.5px;display:flex;align-items:center;gap:9px}
.brand .dot{width:9px;height:9px;border-radius:50%;background:var(--gold);box-shadow:0 0 0 4px rgba(176,138,62,.18)}
.brand span{color:var(--accent)}
.navlinks{display:flex;align-items:center;gap:2px}
.navlinks>a,.dropbtn{font-size:.9rem;font-weight:500;color:var(--ink);padding:8px 13px;border-radius:50px;transition:background .15s,color .15s;cursor:pointer;background:none;border:0;font-family:inherit;white-space:nowrap}
.navlinks>a:hover,.dropbtn:hover{background:var(--bg-soft);color:var(--accent)}
.navlinks .cta{background:var(--accent);color:#fff}
.navlinks .cta:hover{background:var(--accent-dark);color:#fff}
.burger{display:none;background:none;border:0;cursor:pointer;flex-direction:column;gap:5px;padding:6px}
.burger span{width:24px;height:2px;background:var(--ink);border-radius:2px}
.dropdown{position:relative}
.dropmenu{position:absolute;top:calc(100% + 8px);right:0;background:#fff;border:1px solid var(--border);border-radius:14px;box-shadow:var(--shadow-lg);padding:16px;width:560px;max-width:90vw;display:none;grid-template-columns:1fr 1fr 1fr;gap:4px 20px;z-index:200}
.dropdown.open .dropmenu{display:grid}
.dropcol h5{font-family:'Outfit';font-size:.66rem;text-transform:uppercase;letter-spacing:1.2px;color:var(--gold);margin-bottom:6px;font-weight:700;border-bottom:1px solid var(--border);padding-bottom:4px}
.dropcol a{display:block;font-size:.85rem;font-weight:500;padding:4px 0;color:var(--ink);transition:color .15s}
.dropcol a:hover{color:var(--accent)}
@media(max-width:980px){
  .navlinks{position:absolute;top:66px;left:0;right:0;background:#fff;flex-direction:column;align-items:stretch;gap:0;padding:8px 0;border-bottom:1px solid var(--border);box-shadow:var(--shadow);transform:translateY(-180%);transition:transform .3s;pointer-events:none;max-height:84vh;overflow-y:auto}
  .navlinks.open{transform:translateY(0);pointer-events:auto}
  .navlinks>a,.dropbtn{padding:13px 24px;border-radius:0;text-align:left}
  .navlinks .cta{margin:8px 24px;border-radius:50px;text-align:center}
  .burger{display:flex}
  .dropdown{width:100%}
  .dropmenu{position:static;width:auto;box-shadow:none;border:0;border-radius:0;padding:4px 24px 8px;grid-template-columns:1fr 1fr}
}

/* ---------- COUNTRY SUB-BAR (sticky city / pages selector) ---------- */
.subbar{position:sticky;top:66px;z-index:95;background:#fff;border-bottom:1px solid var(--border);box-shadow:0 2px 12px rgba(20,30,45,.04)}
.subbar-inner{display:flex;align-items:center;gap:14px;max-width:var(--maxw);margin:0 auto;padding:10px 24px;flex-wrap:wrap}
.subbar .ctry{display:flex;align-items:center;gap:9px;font-weight:600;font-size:.95rem;color:var(--ink)}
.subbar .ctry .fl{font-size:1.25rem}
.subbar .code{font-family:'Outfit';font-weight:700;color:var(--accent);font-size:.85rem;background:var(--bg-soft);padding:2px 9px;border-radius:50px}
.subbar select{font-family:'Outfit';font-size:.88rem;font-weight:500;color:var(--ink);background:var(--bg-soft);border:1px solid var(--border);border-radius:50px;padding:8px 14px;cursor:pointer;outline:none;max-width:200px}
.subbar select:focus{border-color:var(--accent)}
.subbar .spacer{margin-left:auto}
.subbar .pagelinks{display:flex;gap:6px}
.subbar .pagelinks a{font-size:.82rem;font-weight:600;padding:6px 13px;border-radius:50px;border:1px solid var(--border);transition:.15s}
/* country-home button (returns to the country page) */
.subbar .pagelinks a.home{background:var(--accent);color:#fff;border-color:var(--accent)}
.subbar .pagelinks a.home:hover{background:var(--accent-dark);border-color:var(--accent-dark)}
/* category-coded hovers */
.subbar .pagelinks a.wp:hover{background:var(--white-c);color:#fff;border-color:var(--white-c)}
.subbar .pagelinks a.yp:hover{background:var(--yellow-c);color:#fff;border-color:var(--yellow-c)}
.subbar .pagelinks a.gov:hover{background:var(--accent);color:#fff;border-color:var(--accent)}
.subbar .pagelinks a.visit:hover{background:var(--travel-c);color:#fff;border-color:var(--travel-c)}
@media(max-width:640px){.subbar .pagelinks{display:none}.subbar .spacer{display:none}}

/* ---------- BREADCRUMB ---------- */
.crumb{font-size:.82rem;color:var(--muted);padding:16px 0 0}
.crumb a{color:var(--accent);font-weight:500}
.crumb a:hover{text-decoration:underline}
.crumb .sep{margin:0 7px;color:var(--gold-soft)}

/* ---------- HERO (country) ---------- */
.c-hero{position:relative;z-index:2;padding:26px 0 30px}
.c-hero .wrap{position:relative;z-index:2}
.c-hero .flagline{display:flex;align-items:center;gap:14px;margin-bottom:14px}
.c-hero .flagline img{height:42px;border-radius:6px;border:1px solid var(--border);box-shadow:var(--shadow)}
.c-hero .eyebrow{display:inline-flex;align-items:center;gap:8px;font-family:'Outfit';font-size:.74rem;font-weight:700;text-transform:uppercase;letter-spacing:2px;color:var(--gold)}
.c-hero .eyebrow::before{content:"";width:26px;height:1px;background:var(--gold)}
.c-hero h1{font-size:clamp(2rem,5vw,3.3rem);max-width:20ch;margin-bottom:10px}
.c-hero h1 em{font-style:italic;color:var(--accent)}
.c-hero .lede{font-size:1.08rem;color:var(--muted);max-width:62ch;margin-bottom:24px}

/* Google CSE search styled */
.cse-box{max-width:680px;background:#fff;border:2px solid var(--border);border-radius:18px;box-shadow:var(--shadow);padding:8px 10px;transition:border-color .2s,box-shadow .2s}
.cse-box:focus-within{border-color:var(--accent);box-shadow:0 0 0 4px rgba(27,78,142,.12),var(--shadow)}
.cse-box .gsc-control-cse{background:transparent!important;border:0!important;padding:0!important;font-family:'Outfit',sans-serif!important}
.cse-box .gsc-input-box{border:0!important;background:transparent!important}
.cse-results{margin-top:18px}
.c-hero .stats{display:flex;gap:36px;margin-top:28px;flex-wrap:wrap}
.c-hero .stat .n{font-family:'Fraunces',serif;font-size:1.9rem;font-weight:600;color:var(--accent);line-height:1}
.c-hero .stat .l{font-size:.8rem;color:var(--muted);text-transform:uppercase;letter-spacing:1px;margin-top:4px}

/* ---------- SECTIONS ---------- */
section{position:relative;z-index:2;padding:40px 0}
.sec-head{margin-bottom:26px}
.sec-head .kicker{font-family:'Outfit';font-size:.72rem;font-weight:700;text-transform:uppercase;letter-spacing:2px;color:var(--gold);margin-bottom:10px}
.sec-head h2{font-size:clamp(1.6rem,3.2vw,2.3rem);max-width:24ch}
.sec-head p{color:var(--muted);max-width:64ch;margin-top:10px;font-size:1.02rem}

/* ---------- AD SLOTS (monetization) ---------- */
/* Clean on production; pbof.js adds .show-ph in local preview only. */
.ad-slot{position:relative;margin:6px auto;display:flex;align-items:center;justify-content:center;overflow:hidden}
.ad-slot ins{width:100%}
.ad-slot.show-ph{min-height:100px;border:1px dashed var(--gold-soft);border-radius:12px;background:repeating-linear-gradient(135deg,#fcfbf8,#fcfbf8 12px,#f7f4ec 12px,#f7f4ec 24px)}
.ad-slot.show-ph::before{content:"Advertising · AdSense";position:absolute;top:8px;left:12px;font-family:'Outfit';font-size:.6rem;font-weight:700;letter-spacing:1.5px;text-transform:uppercase;color:var(--gold);opacity:.85}
.ad-slot.show-ph::after{content:"Google Ad loads once the site is online";color:var(--muted);font-size:.85rem;font-family:'Outfit'}

/* preview placeholder injected by pbof.js for CSE / Booking / Stay22 */
.mount-ph{width:100%;min-height:120px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:6px;text-align:center;padding:24px;border:1px dashed var(--gold-soft);border-radius:12px;background:repeating-linear-gradient(135deg,#fcfbf8,#fcfbf8 12px,#f7f4ec 12px,#f7f4ec 24px);color:var(--muted)}
.mount-ph .i{font-size:1.8rem}
.mount-ph .t{font-weight:600;color:var(--ink);font-size:.98rem}
.mount-ph small{font-size:.76rem;color:var(--gold)}
/* CSE box placeholder should look like the real search bar */
.cse-box .mount-ph{border:0;background:none;min-height:0;flex-direction:row;justify-content:flex-start;gap:12px;padding:14px 18px}
.cse-box .mount-ph .i{font-size:1.3rem}
.cse-box .mount-ph small{display:none}

/* ---------- THREE PILLARS (White / Yellow / Travel) ---------- */
.pillars{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
@media(max-width:900px){.pillars{grid-template-columns:1fr}}
.pillar{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow);overflow:hidden;display:flex;flex-direction:column;transition:transform .2s,box-shadow .2s}
.pillar:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg)}
.pillar .top{padding:20px 22px;color:#fff;position:relative}
.pillar.white .top{background:linear-gradient(135deg,#6b7888,#5a6878)}
.pillar.yellow .top{background:linear-gradient(135deg,#d9aa1c,#c79a16)}
.pillar.travel .top{background:linear-gradient(135deg,#c4523a,#b0442e)}
.pillar .top .lbl{font-family:'Outfit';font-size:.66rem;font-weight:700;letter-spacing:1.5px;text-transform:uppercase;opacity:.85}
.pillar .top h3{color:#fff;font-size:1.4rem;margin-top:3px}
.pillar .top .sub{font-size:.82rem;opacity:.9;margin-top:2px;font-family:'Outfit'}
.pillar .body{padding:18px 22px 22px;flex:1}
.pillar .lk{display:flex;align-items:center;gap:11px;padding:10px 0;border-bottom:1px solid var(--bg-soft);font-size:.92rem;font-weight:500;transition:color .12s}
.pillar .lk:last-child{border-bottom:0}
.pillar .lk:hover{color:var(--accent)}
.pillar .lk img{width:30px;height:30px;border-radius:7px;object-fit:cover;background:var(--bg-soft);border:1px solid var(--border);flex:0 0 auto}
.pillar .lk .ic{width:30px;height:30px;border-radius:7px;background:var(--bg-soft);display:flex;align-items:center;justify-content:center;font-size:1rem;flex:0 0 auto}
.pillar .lk .ext{margin-left:auto;color:var(--gold-soft);font-size:.78rem}
.pillar .cta{display:block;text-align:center;margin-top:16px;background:var(--bg-soft);color:var(--accent);font-weight:600;font-size:.9rem;padding:11px;border-radius:50px;transition:.15s}
.pillar .cta:hover{background:var(--accent);color:#fff}
/* category-coded CTA hovers */
.pillar.white .cta:hover{background:var(--white-c);color:#fff}
.pillar.yellow .cta:hover{background:var(--yellow-c);color:#fff}
.pillar.travel .cta:hover{background:var(--travel-c);color:#fff}

/* ---------- EMBED CARDS (Stay22 / GYG / Kayak / Maps) ---------- */
.embed-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:20px}
.embed-card{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow);overflow:hidden}
.embed-card .ec-head{display:flex;align-items:center;gap:10px;padding:14px 18px;border-bottom:1px solid var(--border)}
.embed-card .ec-head .ic{font-size:1.2rem}
.embed-card .ec-head h4{font-size:1.02rem;font-family:'Fraunces'}
.embed-card .ec-head .tag{margin-left:auto;font-family:'Outfit';font-size:.6rem;font-weight:700;letter-spacing:1px;text-transform:uppercase;color:var(--gold);border:1px solid var(--gold-soft);padding:3px 8px;border-radius:50px}
.embed-card .ec-body{padding:0}
.embed-card iframe{display:block;width:100%;border:0}
.embed-ph{min-height:280px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;text-align:center;padding:30px;color:var(--muted);background:repeating-linear-gradient(135deg,#fcfbf8,#fcfbf8 12px,#f7f4ec 12px,#f7f4ec 24px)}
.embed-ph .big{font-size:2rem}
.embed-ph .note{font-size:.82rem;max-width:34ch}
.embed-cta{display:inline-block;margin-top:6px;background:var(--accent);color:#fff;font-weight:600;font-size:.86rem;padding:9px 20px;border-radius:50px}

/* Booking.com search form */
.bk-form{padding:6px 0;display:flex;flex-direction:column;gap:12px}
.bk-form label{font-family:'Outfit';font-size:.78rem;font-weight:600;color:var(--muted);display:flex;flex-direction:column;gap:6px}
.bk-form input{font-family:'Outfit';font-size:.95rem;padding:13px 14px;border:1px solid var(--border);border-radius:10px;outline:none;color:var(--ink)}
.bk-form input:focus{border-color:var(--accent);box-shadow:0 0 0 3px rgba(27,78,142,.12)}
.bk-form button{font-family:'Outfit';font-size:.92rem;font-weight:600;background:var(--accent);color:#fff;border:0;border-radius:50px;padding:12px;cursor:pointer;transition:background .15s}
.bk-form button:hover{background:var(--accent-dark)}
.bk-form small{color:var(--muted);font-size:.74rem;text-align:center}

/* Belt-and-suspenders: never let an auto-placed ad sit inside a protected box.
   Primary control remains AdSense → Excluded areas (selectors: [data-no-ads]). */
[data-no-ads] .google-auto-placed,[data-no-ads] ins.adsbygoogle{display:none!important}

/* ---------- MAPS row ---------- */
.maps-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
@media(max-width:820px){.maps-grid{grid-template-columns:1fr}}
.maps-grid .m{border-radius:var(--radius);overflow:hidden;border:1px solid var(--border);box-shadow:var(--shadow);aspect-ratio:4/3;background:var(--bg-soft)}
.maps-grid .m iframe,.maps-grid .m img{width:100%;height:100%;object-fit:cover;border:0;display:block}

/* ---------- COUNTRY FACTS ---------- */
.facts{display:grid;grid-template-columns:1.2fr 1fr;gap:28px;align-items:start}
@media(max-width:820px){.facts{grid-template-columns:1fr}}
.fact-card{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow);padding:26px 28px}
.fact-card h3{font-size:1.3rem;margin-bottom:14px}
.fact-row{display:flex;justify-content:space-between;gap:14px;padding:9px 0;border-bottom:1px solid var(--bg-soft);font-size:.94rem}
.fact-row:last-child{border-bottom:0}
.fact-row .k{color:var(--muted)}
.fact-row .v{font-weight:600;text-align:right}
.fact-row .v .code{color:var(--accent)}
.borders{display:flex;flex-wrap:wrap;gap:8px;margin-top:8px}
.borders a{font-size:.84rem;font-weight:500;background:var(--bg-soft);border:1px solid var(--border);padding:6px 13px;border-radius:50px;transition:.15s}
.borders a:hover{background:var(--accent);color:#fff;border-color:var(--accent)}
.borders a .km{color:var(--muted);font-size:.76rem;margin-left:5px}
.borders a:hover .km{color:#cdd9ea}

/* ---------- BANNER (pop-up store etc.) ---------- */
.banner{display:block;border-radius:var(--radius);overflow:hidden;border:1px solid var(--border);box-shadow:var(--shadow);background:var(--bg-soft)}
.banner img{width:100%;display:block}

/* ---------- FOOTER ---------- */
footer{background:#16202e;color:#c5cdd8;padding:54px 0 26px;position:relative;z-index:2}
.foot-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:30px}
footer h5{font-family:'Outfit';font-size:.74rem;text-transform:uppercase;letter-spacing:1.5px;color:#fff;margin-bottom:14px;font-weight:700}
footer a{display:block;font-size:.9rem;padding:4px 0;color:#a7b2c0;transition:color .15s}
footer a:hover{color:var(--gold-soft)}
.foot-brand .brand{color:#fff;font-size:1.4rem;margin-bottom:10px}
.foot-brand .brand span{color:var(--gold-soft)}
.foot-brand p{font-size:.9rem;color:#8d99a8;max-width:32ch}
.foot-bottom{border-top:1px solid rgba(255,255,255,.1);margin-top:40px;padding-top:22px;text-align:center;font-size:.84rem;color:#8d99a8}
@media(max-width:860px){.foot-grid{grid-template-columns:1fr 1fr}}
@media(max-width:480px){.foot-grid{grid-template-columns:1fr}}

/* ============================================================
   VARIANT 2 — "logo-rich directory"
   Real brand logos restored + Google-favicon partner wall.
   ============================================================ */
.pillar.v2{background:#fff}
.pillar.v2 .top{background:none;color:var(--ink);border-top:5px solid var(--accent);padding-bottom:8px}
.pillar.v2.white .top{border-top-color:var(--white-c)}
.pillar.v2.yellow .top{border-top-color:var(--yellow-c)}
.pillar.v2.travel .top{border-top-color:var(--travel-c)}
.pillar.v2 .top .lbl{color:var(--gold)}
.pillar.v2 .top h3{color:var(--ink)}
.pillar.v2 .top .sub{color:var(--muted)}
.brand-row{display:flex;align-items:center;gap:14px;padding:11px 6px;border-bottom:1px solid var(--bg-soft);transition:background .12s;border-radius:8px}
.brand-row:last-child{border-bottom:0}
.brand-row:hover{background:var(--bg-soft)}
.brand-row .logo{flex:0 0 auto;width:108px;height:38px;display:flex;align-items:center;justify-content:center;background:#fff;border:1px solid var(--border);border-radius:8px;overflow:hidden}
.brand-row .logo img{max-width:100%;max-height:100%;object-fit:contain}
.brand-row .txt{flex:1;min-width:0}
.brand-row .txt b{font-size:.9rem;font-weight:600;display:block;line-height:1.2}
.brand-row .txt small{font-size:.76rem;color:var(--muted)}
.brand-row .ext{margin-left:auto;color:var(--gold-soft);font-size:.85rem;flex:0 0 auto}
.fav{width:22px;height:22px;border-radius:5px;background:#fff;border:1px solid var(--border);object-fit:contain;flex:0 0 auto}
.logowall{display:grid;grid-template-columns:repeat(auto-fit,minmax(130px,1fr));gap:14px}
.logowall a{display:flex;flex-direction:column;align-items:center;gap:9px;background:#fff;border:1px solid var(--border);border-radius:14px;padding:20px 14px;box-shadow:var(--shadow);transition:transform .2s,box-shadow .2s;text-align:center}
.logowall a:hover{transform:translateY(-3px);box-shadow:var(--shadow-lg)}
.logowall a img{width:42px;height:42px;border-radius:10px;object-fit:contain;background:var(--bg-soft);padding:5px}
.logowall a .nm{font-size:.85rem;font-weight:600;color:var(--ink)}
.logowall a .ro{font-size:.7rem;color:var(--muted);text-transform:uppercase;letter-spacing:.5px}

/* ============================================================
   GLOBAL SEARCH (loupe in nav) — searches the whole site index
   ============================================================ */
.navsearch-btn{background:none;border:0;cursor:pointer;color:var(--ink);padding:8px 11px;border-radius:50px;display:flex;align-items:center;transition:background .15s,color .15s}
.navsearch-btn:hover{background:var(--bg-soft);color:var(--accent)}
.navsearch-btn svg{width:20px;height:20px}
.gsearch{position:fixed;inset:0;z-index:300;background:rgba(20,30,45,.45);backdrop-filter:blur(3px);display:none;align-items:flex-start;justify-content:center;padding:14vh 20px 20px}
.gsearch.open{display:flex}
.gsearch-panel{width:100%;max-width:640px;background:#fff;border-radius:18px;box-shadow:var(--shadow-lg);overflow:hidden}
.gsearch-field{position:relative;display:flex;align-items:center;padding:6px}
.gsearch-field svg.ico{width:22px;height:22px;color:var(--muted);margin:0 8px 0 14px;flex:0 0 auto}
.gsearch-field input{flex:1;font-family:'Outfit';font-size:1.1rem;border:0;outline:none;padding:16px 8px;background:transparent;color:var(--ink)}
.gsearch-field .esc{font-size:.7rem;font-weight:700;color:var(--muted);background:var(--bg-soft);border:1px solid var(--border);border-radius:6px;padding:4px 8px;margin-right:10px}
.gsearch-results{max-height:54vh;overflow-y:auto;border-top:1px solid var(--border)}
.gsearch-results a{display:flex;align-items:center;gap:12px;padding:12px 18px;border-bottom:1px solid var(--bg-soft);transition:background .12s}
.gsearch-results a:last-child{border-bottom:0}
.gsearch-results a:hover,.gsearch-results a.sel{background:var(--bg-soft)}
.gsearch-results .ic{width:30px;height:30px;border-radius:8px;background:var(--bg-soft);display:flex;align-items:center;justify-content:center;font-size:1rem;flex:0 0 auto}
.gsearch-results .nm{font-weight:600;font-size:.95rem}
.gsearch-results .nm small{display:block;font-weight:400;color:var(--muted);font-size:.78rem}
.gsearch-results .badge{margin-left:auto;font-family:'Outfit';font-size:.62rem;font-weight:700;letter-spacing:.5px;text-transform:uppercase;color:var(--gold);border:1px solid var(--gold-soft);padding:3px 8px;border-radius:50px;flex:0 0 auto}
.gsearch-empty{padding:22px 18px;color:var(--muted);font-size:.92rem;text-align:center}
.gsearch-hint{padding:10px 18px;font-size:.78rem;color:var(--muted);border-top:1px solid var(--bg-soft);background:var(--bg);display:flex;gap:14px;flex-wrap:wrap}
.gsearch-hint b{color:var(--ink);font-weight:600}

/* ============================================================
   DIRECTORY SUB-PAGES (White Pages / Yellow Pages)
   ============================================================ */
/* Tinted page backgrounds recalling each pillar's colour (subtle) */
body.page-wp{--bg:#dbe2e9;--bg-soft:#c8d3de}
body.page-wp header.nav{background:rgba(219,226,233,.94)}
body.page-yp{--bg:#fbeaba;--bg-soft:#f4dd9c}
body.page-yp header.nav{background:rgba(251,234,186,.94)}

/* Google CSE / AdSense-for-Search form (works without JS, no preview hang) */
.cse-form{display:flex;gap:8px;max-width:680px;background:#fff;border:2px solid var(--border);border-radius:60px;padding:7px 7px 7px 18px;box-shadow:var(--shadow);align-items:center}
.cse-form:focus-within{border-color:var(--accent);box-shadow:0 0 0 4px rgba(27,78,142,.12),var(--shadow)}
.cse-form svg{width:20px;height:20px;color:var(--muted);flex:0 0 auto}
.cse-form input[type=text]{flex:1;border:0;outline:none;font-family:'Outfit';font-size:1.05rem;background:transparent;color:var(--ink);min-width:0}
.cse-form button{flex:0 0 auto;background:var(--accent);color:#fff;border:0;border-radius:50px;font-family:'Outfit';font-weight:600;font-size:.92rem;padding:11px 22px;cursor:pointer;transition:background .15s}
.cse-form button:hover{background:var(--accent-dark)}
.cse-form.sm{padding:5px 5px 5px 14px}
.cse-form.sm input[type=text]{font-size:.95rem}
.cse-form.sm button{padding:9px 16px;font-size:.86rem}

/* Legacy AdSense-for-Search (CSE v1) form, mounted inside .cse-box */
.cse-box #cse-search-box{display:flex;align-items:center;gap:8px;width:100%}
.cse-box #cse-search-box svg{width:20px;height:20px;color:var(--muted);margin-left:6px;flex:0 0 auto}
.cse-box #cse-search-box input[type=text]{flex:1;border:0;outline:none;font-family:'Outfit';font-size:1.05rem;background:transparent;color:var(--ink);min-width:0;padding:12px 4px}
.cse-box #cse-search-box button{flex:0 0 auto;background:var(--accent);color:#fff;border:0;border-radius:50px;font-family:'Outfit';font-weight:600;font-size:.92rem;padding:11px 22px;cursor:pointer;transition:background .15s}
.cse-box #cse-search-box button:hover{background:var(--accent-dark)}
#cse-search-results{margin-top:18px}

/* All-in-one CSE container (box + results render inside, on the same page) */
.cse-allwrap{max-width:760px;margin-top:6px}
.cse-allwrap .gsc-control-cse{background:transparent!important;border:0!important;padding:0!important;font-family:'Outfit',sans-serif!important}
.cse-allwrap .gsc-input-box{border-radius:50px!important;padding:6px 10px!important}
.cse-allwrap .gsc-search-button-v2{border-radius:50px!important;padding:12px 18px!important}

/* Category cards grid */
.dircards{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:20px}
.dircard{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow);padding:22px 24px;display:flex;flex-direction:column}
.dircard .hd{display:flex;align-items:center;gap:10px;margin-bottom:14px;padding-bottom:12px;border-bottom:1px solid var(--bg-soft)}
.dircard .hd .n{font-family:'Outfit';font-size:.66rem;font-weight:700;color:var(--gold);background:var(--bg-soft);padding:3px 9px;border-radius:50px;letter-spacing:.5px}
.dircard .hd h3{font-size:1.12rem}
.dircard .hd .ic{font-size:1.2rem}
.dircard p.lead{color:var(--muted);font-size:.9rem;margin-bottom:12px}
.dircard.span2{grid-column:span 2}
@media(max-width:900px){.dircard.span2{grid-column:span 1}}

/* ============================================================
   GOVERNMENT (faithful table) + ENTITY SUB-PAGES + NEWSPAPERS
   ============================================================ */
/* Government directory table: Name | Phone | Photo */
.dirtable{width:100%;border-collapse:separate;border-spacing:0;background:var(--card);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow)}
.dirtable th{font-family:'Outfit';font-size:.7rem;text-transform:uppercase;letter-spacing:1px;color:var(--gold);text-align:left;padding:14px 18px;border-bottom:1px solid var(--border);background:var(--bg-soft);font-weight:700}
.dirtable td{padding:14px 18px;border-bottom:1px solid var(--bg-soft);vertical-align:middle}
.dirtable tr:last-child td{border-bottom:0}
.dirtable tbody tr{transition:background .12s}
.dirtable tbody tr:hover td{background:var(--bg-soft)}
.dirtable .ename{font-weight:600;font-size:1.02rem;color:var(--accent)}
.dirtable .ename small{display:block;font-weight:400;color:var(--muted);font-size:.8rem}
.dirtable .ephone a{color:var(--ink);font-variant-numeric:tabular-nums;font-weight:500}
.dirtable .ephone a:hover{color:var(--accent)}
.dirtable .ephoto img{width:180px;height:100px;object-fit:cover;border-radius:8px;border:1px solid var(--border);display:block}
@media(max-width:680px){
  .dirtable thead{display:none}
  .dirtable,.dirtable tbody,.dirtable tr,.dirtable td{display:block;width:100%}
  .dirtable tr{border-bottom:1px solid var(--border);padding:6px 0}
  .dirtable tr:last-child{border-bottom:0}
  .dirtable td{border:0;padding:5px 16px}
  .dirtable .ephoto img{width:100%;height:auto;aspect-ratio:16/9}
}

/* Entity sub-page (ministry / president / parliament): photo + info + map */
.entity{display:grid;grid-template-columns:1fr 1fr;gap:26px;align-items:start}
@media(max-width:820px){.entity{grid-template-columns:1fr}}
.entity .ecard{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow);overflow:hidden}
.entity .ecard img.photo{width:100%;display:block;aspect-ratio:16/10;object-fit:cover;border-bottom:1px solid var(--border)}
.entity .ecard .pad{padding:22px 24px}
.entity .ecard h3{font-size:1.25rem;margin-bottom:10px}
.entity .erow{display:flex;gap:10px;padding:8px 0;border-bottom:1px solid var(--bg-soft);font-size:.94rem}
.entity .erow:last-child{border-bottom:0}
.entity .erow .k{color:var(--muted);min-width:90px}
.entity .erow .v{font-weight:500}
.entity .erow .v a{color:var(--accent);font-weight:600}
.entity .ecta{display:inline-flex;align-items:center;gap:8px;margin-top:14px;background:var(--accent);color:#fff;font-weight:600;padding:11px 22px;border-radius:50px;transition:.15s}
.entity .ecta:hover{background:var(--accent-dark)}
.entity .emap{border-radius:var(--radius);overflow:hidden;border:1px solid var(--border);box-shadow:var(--shadow);aspect-ratio:4/3;background:var(--bg-soft)}
.entity .emap iframe{width:100%;height:100%;border:0;display:block}

/* Newspaper / press logos grid */
.newsgrid{display:grid;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:14px}
.newsgrid a{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:9px;background:#fff;border:1px solid var(--border);border-radius:12px;padding:16px 12px;box-shadow:var(--shadow);transition:transform .2s,box-shadow .2s;text-align:center;min-height:110px}
.newsgrid a:hover{transform:translateY(-3px);box-shadow:var(--shadow-lg)}
.newsgrid img{max-width:100%;max-height:50px;object-fit:contain}
.newsgrid .nn{font-size:.78rem;font-weight:600;color:var(--ink)}

/* P.A. (Press Archive) sub-bar button + mobile sub-page selector */
.subbar .pagelinks a.pa:hover{background:var(--ink);color:#fff;border-color:var(--ink)}
.subnav-mobile{display:none}
@media(max-width:640px){
  .subnav-mobile{display:inline-block}
}

/* ============================================================
   INCONTOURNABLES — must-see places & museums (sourced images)
   ============================================================ */
.incgrid{display:grid;grid-template-columns:repeat(auto-fill,minmax(190px,1fr));gap:16px}
.inc-card{border-radius:14px;overflow:hidden;border:1px solid var(--border);box-shadow:var(--shadow);background:var(--card);transition:transform .2s,box-shadow .2s;display:flex;flex-direction:column}
.inc-card:hover{transform:translateY(-3px);box-shadow:var(--shadow-lg)}
.inc-thumb{position:relative;aspect-ratio:4/3;background:linear-gradient(135deg,var(--accent),#0a7d3b)}
.inc-thumb .inc-ph{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;font-size:2.2rem}
.inc-thumb img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;display:block}
.inc-body{padding:11px 13px;flex:1;display:flex;flex-direction:column}
.inc-body .nm{font-weight:600;font-size:.92rem;line-height:1.2;display:block;color:var(--ink)}
.inc-body .ct{font-size:.74rem;color:var(--muted);margin-top:2px}
.inc-actions{display:flex;gap:7px;margin-top:auto;padding-top:10px;flex-wrap:wrap}
.inc-actions a{font-size:.72rem;font-weight:600;padding:4px 11px;border-radius:50px;border:1px solid var(--border);color:var(--accent);transition:.15s;line-height:1.5}
.inc-actions a:hover{background:var(--accent);color:#fff;border-color:var(--accent)}
.inc-actions a.src{color:var(--muted)}
.inc-actions a.src:hover{background:var(--muted);border-color:var(--muted);color:#fff}

/* ============================================================
   GENERAL RULE — protected zones where ads must NEVER appear:
   the top frame (hero), inside the footer, and below the footer.
   (Belt-and-suspenders; also set these as Excluded areas in AdSense.)
   ============================================================ */
/* Top frame / hero (homepage .hero and country .c-hero) */
.hero ins.adsbygoogle, .hero .google-auto-placed,
.c-hero ins.adsbygoogle, .c-hero .google-auto-placed,
/* Inside the footer */
footer ins.adsbygoogle, footer .google-auto-placed,
/* Below the footer */
body > footer ~ ins.adsbygoogle, body > footer ~ .google-auto-placed,
body > footer ~ ins, body > footer ~ div[id^="aswift"]{display:none!important}

/* ============================================================
   WORLD MAP (bottom of country pages) — shared component
   Geometry + behaviour in assets/worldmap.js
   ============================================================ */
.map-wrap{position:relative;background:var(--card);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow);padding:14px}
.map-frame{position:relative;width:100%;background:linear-gradient(180deg,#eef2f6,#e8edf2);border-radius:12px;overflow:hidden}
#worldmap{width:100%;height:auto;display:block;touch-action:manipulation}
#worldmap path.cty{fill:#cfd8e3;stroke:#fbfaf7;stroke-width:.4;cursor:pointer;transition:fill .15s}
#worldmap path.cty:hover{fill:var(--gold)}
#worldmap path.cty.active{fill:var(--gold)}
.map-tip{position:absolute;pointer-events:none;background:var(--ink);color:#fff;font-size:.82rem;font-weight:600;padding:5px 11px;border-radius:50px;transform:translate(-50%,-140%);opacity:0;transition:opacity .12s;white-space:nowrap;z-index:5;font-family:'Outfit'}
.map-tip.show{opacity:1}
.map-tip .cc{color:var(--gold-soft);font-weight:400;margin-left:5px}

/* ---------- TO TOP ---------- */
.totop{position:fixed;right:26px;bottom:26px;width:48px;height:48px;border-radius:50%;background:var(--accent);color:#fff;border:0;cursor:pointer;box-shadow:0 6px 20px rgba(20,30,45,.28);display:flex;align-items:center;justify-content:center;opacity:0;transform:translateY(16px) scale(.85);pointer-events:none;transition:opacity .3s,transform .3s,background .15s;z-index:90}
.totop.show{opacity:1;transform:none;pointer-events:auto}
.totop:hover{background:var(--accent-dark)}
.totop svg{width:22px;height:22px}
@media(max-width:600px){.totop{right:16px;bottom:16px;width:44px;height:44px}}
