/*
Theme Name: SHA 2026
Theme URI: https://singaporehostessagency.com
Description: Fast, secure, SEO/GEO-optimized custom theme for Singapore Hostess Agency. No page builder, minimal JS, built-in schema.
Author: Singapore Hostess Agency
Version: 1.0.0
Requires at least: 6.0
Requires PHP: 7.4
License: GPL-2.0-or-later
Text Domain: sha2026
*/

:root{
  --ink:#141821; --ink-soft:#414a5a; --muted:#6b7488; --line:#e6e8ee; --bg:#ffffff; --bg-soft:#f7f8fb;
  --brand:#b8143c; --brand-dark:#8f0f2e; --brand-soft:#fdeef2; --gold:#c69a4b;
  --wa:#25d366; --radius:14px; --shadow:0 6px 24px rgba(20,24,33,.08); --wrap:1160px;
  --sans:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Helvetica,Arial,sans-serif;
  --serif:"Georgia",'Times New Roman',serif;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;font-family:var(--sans);color:var(--ink);background:var(--bg);line-height:1.65;font-size:17px;-webkit-font-smoothing:antialiased}
img{max-width:100%;height:auto;display:block}
a{color:var(--brand);text-decoration:none}
a:hover{text-decoration:underline}
h1,h2,h3,h4{line-height:1.2;color:var(--ink);font-weight:800;letter-spacing:-.01em}
h1{font-size:clamp(2rem,4.5vw,3.1rem);margin:.2em 0 .4em}
h2{font-size:clamp(1.5rem,3vw,2.1rem);margin:1.6em 0 .5em}
h3{font-size:1.25rem;margin:1.4em 0 .4em}
p{margin:0 0 1.1em}
.wrap{max-width:var(--wrap);margin:0 auto;padding:0 22px}
.narrow{max-width:820px}
.btn{display:inline-block;background:var(--brand);color:#fff;padding:14px 26px;border-radius:999px;font-weight:700;border:0;cursor:pointer;transition:.15s;font-size:1rem}
.btn:hover{background:var(--brand-dark);text-decoration:none;transform:translateY(-1px)}
.btn-ghost{background:#fff;color:var(--brand);border:2px solid var(--brand)}
.btn-ghost:hover{background:var(--brand-soft);color:var(--brand-dark)}
.btn-wa{background:var(--wa);color:#062e14}
.btn-wa:hover{background:#1eb257}

/* Header */
.site-header{position:sticky;top:0;z-index:50;background:rgba(255,255,255,.96);backdrop-filter:saturate(180%) blur(8px);border-bottom:1px solid var(--line)}
.hd{display:flex;align-items:center;justify-content:space-between;gap:18px;height:72px}
.brand{font-weight:900;font-size:1.15rem;color:var(--ink);letter-spacing:-.02em;display:flex;align-items:center;gap:10px}
.brand b{color:var(--brand)}
.brand:hover{text-decoration:none}
.nav{display:flex;align-items:center;gap:22px;list-style:none;margin:0;padding:0}
.nav ul{display:flex;align-items:center;gap:22px;list-style:none;margin:0;padding:0}
.nav li{list-style:none}
.nav a{color:var(--ink-soft);font-weight:600;font-size:.97rem}
.nav a:hover{color:var(--brand);text-decoration:none}
.nav .btn{color:#fff;padding:10px 20px}
.nav .btn:hover{color:#fff}
.menu-toggle{display:none;background:none;border:0;font-size:1.6rem;cursor:pointer;color:var(--ink)}

/* Hero */
.hero{background:linear-gradient(160deg,#fff 0%,var(--brand-soft) 100%);padding:60px 0 56px;border-bottom:1px solid var(--line);overflow:hidden}
.hero-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:48px;align-items:center}
.hero .eyebrow{color:var(--brand);font-weight:800;letter-spacing:.08em;text-transform:uppercase;font-size:.82rem;margin-bottom:10px}
.hero p.lead{font-size:1.18rem;color:var(--ink-soft);max-width:600px}
.hero-cta{display:flex;gap:14px;flex-wrap:wrap;margin-top:26px}
.hero-media img{border-radius:20px;box-shadow:0 18px 50px rgba(143,15,46,.18);object-fit:cover;width:100%;aspect-ratio:4/3;rotate:1.4deg}
.trust{display:flex;gap:22px;flex-wrap:wrap;margin-top:28px;color:var(--muted);font-size:.9rem;font-weight:600}
.trust span{display:flex;align-items:center;gap:7px}
.trust b{color:var(--ink)}

/* Image service cards */
.cards-img .card{padding:0;overflow:hidden;display:flex;flex-direction:column}
.cards-img .card img{width:100%;aspect-ratio:4/3;object-fit:cover;border-radius:0}
.cards-img .card-b{padding:22px 24px 26px}
.cards-img .card h3{margin:0 0 .3em}

/* Sections */
section.block{padding:52px 0}
.bg-soft{background:var(--bg-soft)}
.center{text-align:center}
.lead-sub{color:var(--muted);max-width:680px;margin:0 auto 8px}

/* Cards grid */
.grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:20px;margin-top:30px}
.card{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:26px;transition:.18s}
.card:hover{box-shadow:var(--shadow);transform:translateY(-3px);border-color:#dfe2ea}
.card h3{margin-top:0;font-size:1.15rem}
.card p{color:var(--ink-soft);font-size:.98rem;margin-bottom:.6em}
.card a.more{font-weight:700;font-size:.93rem}

/* Content article */
.article{padding:44px 0 20px}
.page-banner{margin:8px 0 28px;border-radius:16px;overflow:hidden;box-shadow:0 12px 34px rgba(20,24,33,.12)}
.page-banner img{width:100%;height:340px;object-fit:cover;object-position:center 30%;display:block}
@media(max-width:820px){.page-banner img{height:220px}}
.article ul,.article ol{margin:0 0 1.2em;padding-left:1.3em}
.article li{margin:.35em 0}
.article table{width:100%;border-collapse:collapse;margin:1.4em 0;font-size:.97rem}
.article th,.article td{text-align:left;padding:11px 14px;border-bottom:1px solid var(--line)}
.article th{background:var(--bg-soft);font-weight:800}
.article tr:hover td{background:var(--brand-soft)}
.callout{background:var(--brand-soft);border-left:4px solid var(--brand);padding:18px 22px;border-radius:0 var(--radius) var(--radius) 0;margin:1.5em 0}
.callout p:last-child{margin-bottom:0}

/* FAQ */
.faq{margin-top:24px}
.faq details{border:1px solid var(--line);border-radius:10px;margin-bottom:12px;background:#fff;overflow:hidden}
.faq summary{cursor:pointer;padding:16px 20px;font-weight:700;list-style:none;position:relative}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{content:"+";position:absolute;right:20px;color:var(--brand);font-weight:800}
.faq details[open] summary::after{content:"-"}
.faq details[open] summary{border-bottom:1px solid var(--line)}
.faq .fa{padding:6px 20px 18px;color:var(--ink-soft)}

/* CTA band */
.cta-band{background:linear-gradient(135deg,var(--brand) 0%,var(--brand-dark) 100%);color:#fff;text-align:center;padding:56px 22px;border-radius:0}
.cta-band h2{color:#fff;margin-top:0}
.cta-band p{color:rgba(255,255,255,.9);max-width:560px;margin:0 auto 22px}
.cta-band .btn{background:#fff;color:var(--brand)}
.cta-band .btn:hover{background:var(--brand-soft)}
.cta-band .btn-wa{background:var(--wa);color:#062e14}

/* Breadcrumb */
.crumb{font-size:.85rem;color:var(--muted);padding:16px 0 0}
.crumb a{color:var(--muted)}

/* Footer */
.site-footer{background:#12151c;color:#aeb6c6;padding:52px 0 26px;margin-top:20px;font-size:.93rem}
.site-footer a{color:#c9d0dd}
.foot-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:34px}
.site-footer h4{color:#fff;font-size:.95rem;text-transform:uppercase;letter-spacing:.06em;margin:0 0 14px}
.site-footer ul{list-style:none;padding:0;margin:0}
.site-footer li{margin:.4em 0}
.foot-bottom{border-top:1px solid #262b36;margin-top:34px;padding-top:18px;color:#7a8395;display:flex;justify-content:space-between;flex-wrap:wrap;gap:10px}

/* Sticky WhatsApp CTA */
.sticky-cta{position:fixed;right:20px;bottom:20px;z-index:60;display:flex;align-items:center;gap:10px}
.sticky-cta .wa{width:58px;height:58px;border-radius:50%;display:flex;align-items:center;justify-content:center;background:var(--wa);box-shadow:0 8px 22px rgba(37,211,102,.45);transition:transform .15s,box-shadow .15s;order:2}
.sticky-cta .wa:hover{transform:scale(1.06);box-shadow:0 10px 28px rgba(37,211,102,.55)}
.sticky-cta .wa svg{display:block}
.sticky-cta .wa-label{order:1;background:#fff;color:#128c3e;font-weight:700;font-size:.9rem;padding:9px 16px;border-radius:999px;box-shadow:0 6px 18px rgba(0,0,0,.14);white-space:nowrap;text-decoration:none}
.sticky-cta .wa-label:hover{background:#f2fff6;text-decoration:none}
@media(max-width:600px){.sticky-cta .wa-label{display:none}}

/* Forms */
.wpcf7-form input,.wpcf7-form textarea,.wpforms-field input,.wpforms-field textarea{width:100%;padding:12px 14px;border:1px solid var(--line);border-radius:10px;font-family:inherit;font-size:1rem;margin-bottom:12px}
.wpcf7-form .btn,input[type=submit]{background:var(--brand);color:#fff;border:0;padding:14px 28px;border-radius:999px;font-weight:700;cursor:pointer}

/* Site-wide quote form */
.quote-band{background:linear-gradient(160deg,#fff 0%,var(--brand-soft) 100%);border-top:1px solid var(--line);padding:56px 0}
.quote-band h2{margin-top:0}
.quote-band>.wrap>p{color:var(--ink-soft);margin-bottom:6px}
.sha-quote{margin-top:20px}
.sha-quote .frow{display:flex;gap:14px;flex-wrap:wrap}
.sha-quote .frow input{flex:1 1 200px;min-width:0}
.sha-quote input,.sha-quote textarea{width:100%;padding:13px 15px;border:1px solid var(--line);border-radius:10px;font-family:inherit;font-size:1rem;margin-bottom:14px;background:#fff;color:var(--ink)}
.sha-quote input:focus,.sha-quote textarea:focus{outline:none;border-color:var(--brand);box-shadow:0 0 0 3px var(--brand-soft)}
.sha-quote button{margin-top:2px}
.sha-result{margin-top:14px;font-weight:700}
.sha-result.ok{color:#1c6b31}
.sha-result.err{color:var(--brand)}

@media(max-width:820px){
  .nav{position:fixed;inset:72px 0 auto 0;background:#fff;flex-direction:column;align-items:stretch;padding:14px 22px;border-bottom:1px solid var(--line);gap:4px;display:none;box-shadow:var(--shadow)}
  .nav.open{display:flex}
  .nav a{padding:12px 4px;border-bottom:1px solid var(--line)}
  .nav .btn{text-align:center;margin-top:8px}
  .menu-toggle{display:block}
  .foot-grid{grid-template-columns:1fr;gap:24px}
  body{font-size:16px}
  .hero-grid{grid-template-columns:1fr;gap:30px}
  .hero-media{order:-1}
  .hero-media img{rotate:0deg;aspect-ratio:16/10}
  section.block{padding:40px 0}
}

/* Blog */
.hero-blog{padding:52px 0 44px}
.hero-blog .lead{max-width:640px}
.blog-grid{grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:22px;margin-top:10px}
.blog-card{padding:0}
.blog-card .card-b{padding:24px 26px 26px}
.blog-card h3{margin:.15em 0 .5em;font-size:1.2rem;line-height:1.25}
.blog-card h3 a{color:var(--ink)}
.blog-card h3 a:hover{color:var(--brand);text-decoration:none}
.blog-card p{color:var(--ink-soft);font-size:.97rem}
.post-meta{color:var(--muted);font-size:.82rem;font-weight:700;text-transform:uppercase;letter-spacing:.04em}
.post-meta-single{margin:-.2em 0 1.4em;text-transform:none;letter-spacing:0;font-size:.92rem;font-weight:600}
.pagination{display:flex;gap:8px;justify-content:center;margin-top:34px;flex-wrap:wrap}
.pagination .page-numbers{display:inline-flex;min-width:40px;height:40px;align-items:center;justify-content:center;padding:0 12px;border:1px solid var(--line);border-radius:10px;color:var(--ink-soft);font-weight:700;text-decoration:none}
.pagination .page-numbers.current{background:var(--brand);color:#fff;border-color:var(--brand)}
.pagination a.page-numbers:hover{border-color:var(--brand);color:var(--brand)}

/* Blog card thumbnails */
.blog-card{overflow:hidden}
.blog-thumb{display:block;overflow:hidden}
.blog-thumb img{width:100%;height:190px;object-fit:cover;object-position:center 28%;display:block;transition:transform .3s}
.blog-card:hover .blog-thumb img{transform:scale(1.04)}

.foot-address{color:#8a93a4;margin:.2em 0 1em;line-height:1.5}
