/* ===========================================================
   Law Office of Michael Yap — Design System
   Distinct premium identity: ink-navy + disciplined amber accent
   Fraunces (display) / Hanken Grotesk (body) / IBM Plex Mono (labels)
   =========================================================== */
:root{
  --ink:#0E1B2C;       /* deep navy — hero, dark sections */
  --navy:#16293F;      /* primary navy — headings/text on light */
  --slate:#566476;     /* muted body / secondary */
  --paper:#F4F6F8;     /* cool light background */
  --line:#E2E7EC;      /* hairlines */
  --amber:#E0A43B;     /* single accent */
  --amber-d:#C0851F;   /* accent hover / links on light */
  --white:#FFFFFF;
  --maxw:1140px;
  --serif:'Fraunces',Georgia,'Times New Roman',serif;
  --sans:'Hanken Grotesk',system-ui,-apple-system,sans-serif;
  --mono:'IBM Plex Mono','SFMono-Regular',monospace;
}
*{box-sizing:border-box;}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%;}
body{margin:0;background:var(--white)!important;color:var(--navy)!important;
  font-family:var(--sans)!important;font-size:17px;line-height:1.7;-webkit-font-smoothing:antialiased;}
h1,h2,h3,h4,h5{font-family:var(--serif)!important;color:var(--ink)!important;font-weight:600;
  line-height:1.13;letter-spacing:-.012em;margin:0 0 .45em;}
h1{font-size:clamp(34px,5vw,58px)!important;}
h2{font-size:clamp(26px,3.4vw,40px)!important;margin-top:0;}
h3{font-size:21px!important;letter-spacing:-.005em;}
p{margin:0 0 1.1em;color:var(--navy);}
a{color:var(--amber-d);text-decoration:none;}
a:hover{color:var(--ink);}
img{max-width:100%;height:auto;}
.eyebrow{font-family:var(--mono)!important;font-size:12.5px;font-weight:600;
  letter-spacing:.2em;text-transform:uppercase;color:var(--amber-d);display:inline-block;}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 28px;}

/* ---------- BRAND LOCKUP ---------- */
.brand{display:inline-flex;align-items:center;gap:13px;color:var(--navy);text-decoration:none;line-height:1;}
.brand-mark{width:34px;height:33px;color:inherit;flex:0 0 auto;}
.brand-words{display:flex;flex-direction:column;gap:2px;}
.brand-sm{font-family:var(--serif);font-size:10.5px;letter-spacing:.34em;text-transform:uppercase;color:inherit;opacity:.85;}
.brand-lg{font-family:var(--sans);font-weight:800;font-size:17px;letter-spacing:.04em;text-transform:uppercase;color:inherit;}
.brand-logo{display:block;height:42px;width:auto;}
.logo .brand-logo{height:40px;}
@media(max-width:560px){.brand-logo,.logo .brand-logo{height:34px;}}
footer .brand-logo,.site-footer .brand-logo,footer.main-footer .brand-logo{filter:brightness(0) invert(1);height:46px;}

/* ---------- BUTTONS ---------- */
.btn,.button_row a,.btn1,.btn3,input.btn1,.wpcf7-submit,.locations-btn>a{
  display:inline-flex;align-items:center;justify-content:center;gap:8px;
  background:var(--amber)!important;color:var(--ink)!important;
  font-family:var(--sans)!important;font-weight:700!important;font-size:15px!important;
  letter-spacing:.01em;text-transform:none!important;
  padding:14px 26px!important;border:0!important;border-radius:2px!important;
  text-decoration:none!important;cursor:pointer;transition:transform .15s,background .15s,box-shadow .15s;
  box-shadow:0 1px 0 rgba(0,0,0,.04);}
.btn:hover,.button_row a:hover,.wpcf7-submit:hover{background:#EAB14B!important;transform:translateY(-1px);
  box-shadow:0 10px 24px rgba(224,164,59,.28);color:var(--ink)!important;}
.btn-ghost{background:transparent!important;color:var(--white)!important;
  border:1px solid rgba(255,255,255,.4)!important;box-shadow:none;}
.btn-ghost:hover{background:rgba(255,255,255,.08)!important;color:var(--white)!important;border-color:#fff!important;}

/* =========================================================
   WORDPRESS INNER PAGES — restyle existing structure
   ========================================================= */
header#top,header.bg_stretch,.top,.wrapper.menu_row,.menu_row{background:var(--white)!important;
  color:var(--navy)!important;box-shadow:none!important;border-bottom:1px solid var(--line);}
.logo{background-image:none!important;max-width:none!important;width:auto!important;padding:12px 0!important;color:var(--navy)!important;display:inline-flex!important;align-items:center;gap:12px;text-decoration:none!important;}
.logo img{display:none!important;}
.top-menu a,.main-menu a,nav a{color:var(--navy)!important;font-family:var(--sans)!important;
  font-weight:600!important;font-size:15px!important;text-transform:none!important;letter-spacing:0;}
.top-menu a:hover,.main-menu a:hover{color:var(--amber-d)!important;}
.phone-box,.phone-box a{color:var(--navy)!important;font-family:var(--mono)!important;font-weight:600!important;letter-spacing:.02em;}

.main.inner,.content,.content.x{max-width:var(--maxw)!important;margin:0 auto!important;padding:22px 28px!important;}
article{font-size:17px;}
.row,.text_row{padding:30px 0;}
.col.col3,.col.col4{background:var(--paper)!important;border:1px solid var(--line)!important;border-radius:4px!important;padding:26px 24px!important;margin:10px 0!important;}
hr{border:0;border-top:1px solid var(--line);margin:36px 0;}
blockquote{font-family:var(--serif);font-size:22px;color:var(--ink);font-style:italic;
  border:0;border-left:3px solid var(--amber);background:var(--paper);margin:26px 0;padding:18px 26px;border-radius:0 4px 4px 0;}
.content a,article a{color:var(--amber-d);text-decoration:underline;text-underline-offset:2px;text-decoration-thickness:1px;}
.content a:hover,article a:hover{color:var(--ink);}

input[type=text],input[type=email],input[type=tel],textarea,.wpcf7 input,.wpcf7 textarea{
  width:100%;border:1px solid var(--line)!important;border-radius:3px!important;padding:13px 14px!important;
  font-family:var(--sans)!important;font-size:16px!important;background:var(--white)!important;margin:6px 0;}
.sidebar_form,.form{background:var(--paper);border:1px solid var(--line);border-radius:6px;padding:24px;}

footer.main-footer,footer.bg_stretch{background:var(--ink)!important;color:#AEBBCB!important;border-top:3px solid var(--amber);padding:50px 0 28px!important;}
footer .inner,footer .content{max-width:var(--maxw);margin:0 auto;padding:0 28px;}
footer .logo{color:#fff!important;}
footer h3{color:#fff!important;font-family:var(--serif)!important;font-size:17px!important;text-transform:none;margin-bottom:12px;}
footer a{color:#AEBBCB!important;}
footer a:hover{color:var(--amber)!important;}
footer p,footer li{color:#9DAABC!important;font-size:14.5px;line-height:1.7;}
footer .col,footer .col4,footer .col3{background:transparent!important;border:0!important;padding:10px 0!important;}
.social a{color:#AEBBCB!important;margin-right:14px;}
img[src=""],img:not([src]){display:none;}

/* ---- hide broken WordPress chrome on inner pages (replaced by bespoke header/footer) ---- */
header#top,header.bg_stretch,.main-footer,footer.main-footer,.footer-menu-fixed,.mobile,.breadcrumbs{display:none!important;}
.site{background:#fff;}
.main.page,.main.inner{padding:0!important;}
.content,.content.x{display:block!important;max-width:var(--maxw)!important;margin:0 auto!important;padding:46px 28px 30px!important;}
.content.x article,article#post-16,article[id^="post-"]{width:100%!important;float:none!important;max-width:760px;}
.side_wrap,.side_wrap.desktop,.sidebar{width:100%!important;float:none!important;max-width:760px;margin:34px 0 0!important;padding:0!important;}
.featured.page{display:none!important;}
.content h1{margin-top:0;}
.content .inner,.featured .inner{padding:0!important;max-width:none!important;}

/* =========================================================
   BESPOKE HOMEPAGE
   ========================================================= */
.site-header{position:sticky;top:0;z-index:50;background:rgba(255,255,255,.94);
  backdrop-filter:saturate(1.4) blur(8px);border-bottom:1px solid var(--line);}
.site-header .wrap{display:flex;align-items:center;justify-content:space-between;height:74px;}
.nav{display:flex;align-items:center;gap:30px;}
.nav a{color:var(--navy);font-weight:600;font-size:15px;}
.nav a:hover{color:var(--amber-d);}
.nav .tel{font-family:var(--mono);font-weight:600;font-size:14px;letter-spacing:.02em;}
.header-cta{padding:11px 20px!important;font-size:14px!important;}
.menu-toggle{display:none;}

.hero{background:var(--ink);color:#fff;position:relative;overflow:hidden;}
.hero::before{content:"";position:absolute;inset:0;
  background:radial-gradient(900px 480px at 78% -10%,rgba(224,164,59,.16),transparent 60%);}
.hero .wrap{position:relative;display:grid;grid-template-columns:1.15fr .85fr;gap:54px;
  align-items:center;padding-top:84px;padding-bottom:88px;}
.hero h1{color:#fff!important;font-size:clamp(38px,5.4vw,64px)!important;letter-spacing:-.02em;}
.hero h1 em{font-style:italic;color:var(--amber);}
.hero .lede{font-size:19px;color:#C9D4E1;max-width:30em;margin:18px 0 30px;}
.hero-ey{color:var(--amber);margin-bottom:22px;}
.hero-actions{display:flex;flex-wrap:wrap;gap:14px;align-items:center;}
.hero-meta{margin-top:26px;font-family:var(--mono);font-size:12.5px;letter-spacing:.04em;color:#8A99AC;}
.hero-meta b{color:#C9D4E1;font-weight:600;}

/* signature: claim ledger */
.ledger{background:#0B1623;border:1px solid rgba(255,255,255,.1);border-radius:6px;padding:26px 26px 22px;
  box-shadow:0 30px 60px -30px rgba(0,0,0,.7);}
.ledger-h{font-family:var(--mono);font-size:11.5px;letter-spacing:.18em;text-transform:uppercase;color:#8A99AC;
  padding-bottom:14px;margin-bottom:6px;border-bottom:1px solid rgba(255,255,255,.1);}
.ledger-row{display:flex;justify-content:space-between;align-items:baseline;gap:16px;
  padding:13px 0;border-bottom:1px solid rgba(255,255,255,.07);}
.ledger-row:last-child{border-bottom:0;}
.ledger-row .k{color:#E7EDF3;font-weight:600;font-size:15.5px;}
.ledger-row .v{font-family:var(--mono);font-size:11.5px;letter-spacing:.06em;text-transform:uppercase;color:var(--amber);white-space:nowrap;}
.ledger-foot{margin-top:16px;font-size:13px;color:#8A99AC;}

section{padding:78px 0;}
.section-head{max-width:40em;margin-bottom:42px;}
.section-head h2{margin-top:8px;}
.section-head p{color:var(--slate);font-size:18px;}
.alt{background:var(--paper);}

/* process — real sequence, mono numerals earned */
.steps{display:grid;grid-template-columns:repeat(4,1fr);gap:0;border-top:1px solid var(--line);}
.step{padding:30px 26px 30px 0;border-right:1px solid var(--line);}
.step:last-child{border-right:0;padding-right:0;}
.step .n{font-family:var(--mono);font-size:13px;color:var(--amber-d);letter-spacing:.06em;}
.step h3{margin:14px 0 8px;font-size:20px;}
.step p{color:var(--slate);font-size:15.5px;margin:0;}

/* handle grid */
.cards{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;}
.card{background:var(--white);border:1px solid var(--line);border-radius:5px;padding:26px;transition:border-color .15s,transform .15s,box-shadow .15s;}
.card:hover{border-color:var(--amber);transform:translateY(-2px);box-shadow:0 16px 40px -24px rgba(14,27,44,.4);}
.card .ic{font-family:var(--mono);font-size:12px;color:var(--amber-d);letter-spacing:.08em;}
.card h3{margin:12px 0 8px;font-size:19px;}
.card p{color:var(--slate);font-size:15px;margin:0;}
.card a{display:inline-block;}

/* why-choose with portrait */
.why{display:grid;grid-template-columns:.9fr 1.1fr;gap:54px;align-items:center;}
.why-photo{border-radius:6px;overflow:hidden;border:1px solid var(--line);background:var(--paper);aspect-ratio:4/5;}
.why-photo img{width:100%;height:100%;object-fit:cover;display:block;}
.why-list{display:grid;gap:22px;}
.why-item{padding-left:20px;border-left:2px solid var(--amber);}
.why-item h3{font-size:19px;margin:0 0 6px;}
.why-item p{color:var(--slate);margin:0;font-size:15.5px;}

/* reassurance band */
.band{background:var(--ink);color:#fff;}
.band .wrap{padding:70px 28px;}
.band p{font-family:var(--serif);font-size:clamp(24px,3vw,33px);line-height:1.3;color:#fff;max-width:18em;margin:0;font-weight:500;}
.band .em{color:var(--amber);font-style:italic;}

/* faq */
.faq{display:grid;gap:0;border-top:1px solid var(--line);}
.faq details{border-bottom:1px solid var(--line);padding:6px 0;}
.faq summary{cursor:pointer;list-style:none;padding:20px 0;font-family:var(--serif);font-size:20px;color:var(--ink);
  display:flex;justify-content:space-between;align-items:center;gap:20px;}
.faq summary::-webkit-details-marker{display:none;}
.faq summary::after{content:"+";font-family:var(--mono);color:var(--amber-d);font-size:22px;transition:transform .2s;}
.faq details[open] summary::after{transform:rotate(45deg);}
.faq details p{color:var(--slate);font-size:16px;padding:0 0 22px;margin:0;max-width:54em;}

/* final cta */
.cta-final{background:var(--amber);}
.cta-final .wrap{padding:72px 28px;text-align:center;}
.cta-final h2{color:var(--ink)!important;margin-bottom:10px;}
.cta-final p{color:#5A4413;font-size:18px;margin-bottom:26px;}
.cta-final .btn{background:var(--ink)!important;color:#fff!important;}
.cta-final .btn:hover{background:#1c3047!important;color:#fff!important;}

/* bespoke footer */
.site-footer{background:var(--ink);color:#9DAABC;border-top:3px solid var(--amber);}
.site-footer .wrap{padding:56px 28px 30px;}
.foot-grid{display:grid;grid-template-columns:1.3fr 1fr 1fr 1.2fr;gap:34px;}
.site-footer .brand{color:#fff;margin-bottom:14px;}
.foot-col h4{font-family:var(--mono);font-size:11.5px;letter-spacing:.16em;text-transform:uppercase;color:#fff;margin:0 0 14px;}
.foot-col a,.foot-col p{color:#9DAABC;font-size:14.5px;line-height:1.85;display:block;text-decoration:none;}
.foot-col a:hover{color:var(--amber);}
.foot-addr{font-style:normal;font-size:13.5px;line-height:1.7;color:#8593A6;margin-bottom:14px;}
.foot-bottom{border-top:1px solid rgba(255,255,255,.1);margin-top:40px;padding-top:22px;
  display:flex;justify-content:space-between;flex-wrap:wrap;gap:12px;font-size:13px;color:#7A8799;}
.foot-disc{font-size:12px;color:#6B7889;max-width:62em;margin-top:14px;line-height:1.6;}

/* reveal */
.reveal{opacity:0;transform:translateY(16px);transition:opacity .6s ease,transform .6s ease;}
.reveal.in{opacity:1;transform:none;}

/* responsive */
@media(max-width:900px){
  .hero .wrap{grid-template-columns:1fr;gap:36px;padding-top:60px;padding-bottom:64px;}
  .why{grid-template-columns:1fr;gap:30px;}
  .steps{grid-template-columns:1fr 1fr;}
  .step{border-right:0;border-bottom:1px solid var(--line);padding:24px 0;}
  .cards{grid-template-columns:1fr;}
  .foot-grid{grid-template-columns:1fr 1fr;gap:26px;}
  .nav{display:none;}
  .nav.open{display:flex;position:absolute;top:74px;left:0;right:0;background:#fff;flex-direction:column;
    align-items:flex-start;gap:18px;padding:22px 28px;border-bottom:1px solid var(--line);}
  .menu-toggle{display:inline-flex;background:transparent;border:0;color:var(--navy);font-size:26px;cursor:pointer;}
}
@media(max-width:560px){
  .foot-grid{grid-template-columns:1fr;}
  .steps{grid-template-columns:1fr;}
  body{font-size:16px;}
}
@media(prefers-reduced-motion:reduce){
  *{scroll-behavior:auto!important;}
  .reveal{opacity:1;transform:none;transition:none;}
}
