/* Goodhue, Coleman & Owens, P.C. — site stylesheet */
:root{
  --navy:#16243d;
  --navy-2:#1f3354;
  --navy-3:#2a4370;
  --gold:#b08c3e;
  --gold-light:#d4b06a;
  --ink:#252b3a;
  --muted:#5b6478;
  --bg:#fafaf7;
  --card:#ffffff;
  --line:#e6e3da;
  --radius:10px;
  --shadow:0 2px 14px rgba(22,36,61,.08);
  --serif:"Fraunces","Georgia",serif;
  --sans:"Inter","Segoe UI",system-ui,-apple-system,sans-serif;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:var(--sans);color:var(--ink);background:var(--bg);line-height:1.65;font-size:16.5px}
img{max-width:100%;height:auto}
a{color:var(--navy-3)}
a:hover{color:var(--gold)}

/* ---------- accessibility ---------- */
/* Visible keyboard focus indicator for all interactive elements (WCAG 2.4.7) */
a:focus-visible,button:focus-visible,input:focus-visible,select:focus-visible,
textarea:focus-visible,summary:focus-visible,[tabindex]:focus-visible{
  outline:3px solid var(--gold-light);outline-offset:2px;border-radius:4px}
/* On dark (navy) surfaces, use a white ring so focus stays visible */
.topbar a:focus-visible,.hero a:focus-visible,.page-hero a:focus-visible,
.cta-band a:focus-visible,.site-footer a:focus-visible{outline-color:#fff}
/* Skip-to-content link: hidden until focused (WCAG 2.4.1 Bypass Blocks) */
.skip-link{position:absolute;left:8px;top:-60px;z-index:200;background:var(--navy);
  color:#fff !important;padding:10px 16px;border-radius:8px;font-size:.9rem;
  font-weight:600;text-decoration:none;transition:top .15s}
.skip-link:focus{top:8px;outline:3px solid var(--gold-light);outline-offset:2px}
#main-content:focus{outline:none}
/* Respect users who prefer reduced motion (WCAG 2.3.3) */
@media (prefers-reduced-motion: reduce){
  html{scroll-behavior:auto}
  *,*::before,*::after{animation-duration:.001ms !important;
    animation-iteration-count:1 !important;transition-duration:.001ms !important;
    scroll-behavior:auto !important}
}
h1,h2,h3,h4{font-family:var(--serif);color:var(--navy);line-height:1.25;font-weight:600}
.container{max-width:1140px;margin:0 auto;padding:0 22px}

/* ---------- top bar ---------- */
.topbar{background:var(--navy);color:#cfd6e4;font-size:.82rem}
.topbar .container{display:flex;justify-content:flex-end;gap:1.6em;padding-top:.45em;padding-bottom:.45em}
.topbar a{color:#e8ddc2;text-decoration:none}
.topbar a:hover{color:#fff}

/* ---------- header / nav ---------- */
.site-header{background:#fff;border-bottom:1px solid var(--line);position:sticky;top:0;z-index:50}
.site-header .container{display:flex;align-items:center;justify-content:space-between;gap:18px;padding-top:14px;padding-bottom:14px}
.brand{text-decoration:none;line-height:1.2}
.brand .brand-name{font-family:var(--serif);font-size:1.18rem;font-weight:700;color:var(--navy);letter-spacing:.02em;display:block}
.brand .brand-tag{font-size:.68rem;letter-spacing:.24em;color:var(--gold);text-transform:uppercase}
.nav-toggle{display:none;background:none;border:1px solid var(--line);border-radius:8px;padding:8px 11px;cursor:pointer;font-size:1.15rem;color:var(--navy)}
nav.main-nav>ul{display:flex;list-style:none;gap:2px;align-items:center;flex-wrap:wrap}
nav.main-nav>ul>li{position:relative}
nav.main-nav a,nav.main-nav button.submenu-btn{display:block;padding:9px 11px;text-decoration:none;color:var(--ink);font-size:.86rem;font-weight:500;background:none;border:none;cursor:pointer;font-family:var(--sans);border-radius:7px;white-space:nowrap}
nav.main-nav>ul>li>a:hover,nav.main-nav button.submenu-btn:hover,nav.main-nav>ul>li>a[aria-current="page"]{background:#f1eee6;color:var(--navy)}
.submenu-btn::after{content:" ▾";font-size:.7em;color:var(--gold)}
.submenu{display:none;position:absolute;top:100%;left:0;background:#fff;border:1px solid var(--line);border-radius:10px;box-shadow:var(--shadow);min-width:280px;padding:8px;list-style:none;z-index:60}
li.has-submenu.open .submenu{display:block}
.submenu a{padding:8px 12px;font-size:.84rem;border-radius:7px}
.submenu a:hover{background:#f1eee6}
.nav-cta{margin-left:8px}
.btn{display:inline-block;background:var(--gold);color:#fff !important;padding:10px 20px;border-radius:8px;text-decoration:none;font-weight:600;font-size:.88rem;border:none;cursor:pointer;font-family:var(--sans);transition:background .15s}
.btn:hover{background:#977733;color:#fff}
.btn-outline{background:transparent;color:var(--navy) !important;border:1.5px solid var(--navy)}
.btn-outline:hover{background:var(--navy);color:#fff !important}
.btn-lg{padding:14px 28px;font-size:.97rem}

/* ---------- hero ---------- */
.hero{background:linear-gradient(135deg,var(--navy) 0%,var(--navy-2) 60%,var(--navy-3) 100%);color:#fff;padding:84px 0 90px}
.hero h1{color:#fff;font-size:clamp(2rem,4.6vw,3.3rem);max-width:18em;margin-bottom:.4em}
.hero .kicker{color:var(--gold-light);text-transform:uppercase;letter-spacing:.28em;font-size:.8rem;font-weight:600;margin-bottom:1.2em}
.hero p.lede{font-size:1.13rem;max-width:44em;color:#d9dfeb;margin-bottom:2em}
.hero .hero-actions{display:flex;gap:14px;flex-wrap:wrap}
.hero .btn-outline{color:#fff !important;border-color:rgba(255,255,255,.55)}
.hero .btn-outline:hover{background:#fff;color:var(--navy) !important}

/* ---------- page hero (interior) ---------- */
.page-hero{background:linear-gradient(135deg,var(--navy),var(--navy-2));color:#fff;padding:46px 0 50px}
.page-hero h1{color:#fff;font-size:clamp(1.6rem,3.2vw,2.4rem)}
.page-hero .crumb{font-size:.78rem;letter-spacing:.18em;text-transform:uppercase;color:var(--gold-light);margin-bottom:.7em}

/* ---------- sections ---------- */
.section{padding:64px 0}
.section.alt{background:#fff;border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.section h2{font-size:clamp(1.45rem,2.6vw,2rem);margin-bottom:.7em}
.section .section-kicker{color:var(--gold);text-transform:uppercase;letter-spacing:.24em;font-size:.76rem;font-weight:700;margin-bottom:.9em}
.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.grid-2{display:grid;grid-template-columns:repeat(2,1fr);gap:24px}
.card{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);padding:26px;box-shadow:var(--shadow)}
.card h3{font-size:1.08rem;margin-bottom:.5em}
.card p{font-size:.93rem;color:var(--muted)}
.card a.more{font-size:.86rem;font-weight:600;text-decoration:none}
.steps{counter-reset:step;display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.step{position:relative;padding:26px 24px 24px;background:#fff;border:1px solid var(--line);border-radius:var(--radius)}
.step::before{counter-increment:step;content:counter(step);position:absolute;top:-18px;left:22px;background:var(--gold);color:#fff;width:36px;height:36px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:700;font-family:var(--serif)}
.step p{font-size:.92rem;color:var(--muted)}

/* ---------- testimonials ---------- */
.quote-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:22px}
blockquote.review{background:#fff;border:1px solid var(--line);border-left:4px solid var(--gold);border-radius:var(--radius);padding:22px 24px;font-size:.92rem;color:var(--muted);font-style:italic}
blockquote.review::before{content:"\201C";font-family:var(--serif);font-size:2.2rem;color:var(--gold);display:block;line-height:.6;margin-bottom:.35em;font-style:normal}

/* ---------- CTA band ---------- */
.cta-band{background:var(--navy);color:#fff;padding:54px 0;text-align:center}
.cta-band h2{color:#fff;margin-bottom:.5em}
.cta-band p{color:#c8d0e0;max-width:46em;margin:0 auto 1.6em}

/* ---------- prose (generic content pages) ---------- */
.prose{max-width:780px}
.prose h2{margin:1.4em 0 .55em;font-size:1.5rem}
.prose h3{margin:1.3em 0 .5em;font-size:1.15rem}
.prose p{margin-bottom:1.05em}
.prose ul,.prose ol{margin:0 0 1.05em 1.4em}
.prose li{margin-bottom:.4em}
.prose strong{color:var(--navy)}
.prose blockquote{border-left:3px solid var(--gold);padding:6px 0 6px 18px;margin:1.2em 0;color:var(--muted);font-style:italic}
.prose hr{border:none;border-top:1px solid var(--line);margin:2em 0}
.layout-sidebar{display:grid;grid-template-columns:minmax(0,1fr) 300px;gap:44px;align-items:start}
.sidebar .card{position:sticky;top:90px}
.sidebar .card h3{font-size:1rem}
.sidebar .card p{font-size:.88rem}
.sidebar .card .btn{width:100%;text-align:center;margin-top:10px}
.sidebar .phone-line{font-size:.9rem;color:var(--navy);font-weight:600;margin-top:12px}

/* ---------- team ---------- */
.team-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:26px}
.person{background:#fff;border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow)}
.person img{width:100%;aspect-ratio:1/1;object-fit:cover;object-position:center top;background:#e9e6dd}
.person .person-body{padding:22px 24px 24px}
.person h3{font-size:1.12rem}
.person .role{color:var(--gold);font-size:.8rem;text-transform:uppercase;letter-spacing:.14em;font-weight:600;margin-bottom:.8em}
.person p{font-size:.9rem;color:var(--muted)}
.person details{margin-top:.6em}
.person details summary{cursor:pointer;font-size:.86rem;font-weight:600;color:var(--navy-3)}
.person details p{margin-top:.7em}
.person .person-links{margin-top:1em;display:flex;gap:10px;flex-wrap:wrap}
.person .person-links a{font-size:.84rem;font-weight:600;text-decoration:none}

/* ---------- FAQ ---------- */
.faq details{background:#fff;border:1px solid var(--line);border-radius:var(--radius);margin-bottom:12px;padding:0}
.faq summary{cursor:pointer;font-weight:600;color:var(--navy);padding:16px 20px;font-size:.97rem;list-style:none;position:relative;padding-right:44px}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{content:"+";position:absolute;right:18px;top:12px;font-size:1.4rem;color:var(--gold);font-weight:400}
.faq details[open] summary::after{content:"–"}
.faq .answer{padding:0 20px 18px;color:var(--muted);font-size:.93rem}
.faq .answer p{margin-bottom:.9em}
.faq .answer ol,.faq .answer ul{margin:0 0 .9em 1.4em}
.faq h2{margin:1.6em 0 .8em}

/* ---------- forms ---------- */
.form-card{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:34px;box-shadow:var(--shadow);max-width:720px}
.form-grid{display:grid;grid-template-columns:minmax(0,1fr) minmax(0,1fr);gap:16px}
.form-field{display:flex;flex-direction:column;gap:6px;margin-bottom:16px;min-width:0}
.form-field.full{grid-column:1/-1}
.form-field label{font-size:.84rem;font-weight:600;color:var(--navy)}
.form-field label .req{color:#b3261e}
.form-field input:not([type=checkbox]):not([type=radio]),.form-field textarea,.form-field select{padding:11px 13px;border:1px solid #cfcabd;border-radius:8px;font-family:var(--sans);font-size:.93rem;background:#fdfdfb;width:100%;max-width:100%;box-sizing:border-box}
.form-field input:focus,.form-field textarea:focus{outline:2px solid var(--gold-light);border-color:var(--gold)}
.form-note{font-size:.8rem;color:var(--muted);margin:14px 0 18px}
.form-status{display:none;padding:14px 16px;border-radius:8px;margin-top:16px;font-size:.92rem}
.form-status.ok{display:block;background:#eef6ee;border:1px solid #bcd9bc;color:#235123}
.form-status.err{display:block;background:#fbeeee;border:1px solid #e3b8b8;color:#7a2222}
.hp-field{position:absolute;left:-9999px;opacity:0;height:0;overflow:hidden}

/* ---------- embeds ---------- */
.tool-frame{width:100%;height:78vh;min-height:560px;border:1px solid var(--line);border-radius:var(--radius);background:#fff}
.notice{background:#fdf6e7;border:1px solid #ecd9a8;border-radius:var(--radius);padding:16px 20px;font-size:.9rem;color:#6b5418;margin:18px 0}

/* ---------- footer ---------- */
.site-footer{background:var(--navy);color:#aeb8cc;margin-top:70px;font-size:.88rem}
.site-footer .container{padding-top:54px;padding-bottom:30px}
.footer-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:36px;padding-bottom:34px;border-bottom:1px solid rgba(255,255,255,.12)}
.site-footer h4{color:#fff;font-size:.95rem;margin-bottom:.9em;font-family:var(--sans);font-weight:600;letter-spacing:.06em;text-transform:uppercase}
.site-footer a{color:#cdd5e3;text-decoration:none}
.site-footer a:hover{color:var(--gold-light)}
.site-footer ul{list-style:none}
.site-footer li{margin-bottom:.55em}
.footer-brand{font-family:var(--serif);color:#fff;font-size:1.1rem;margin-bottom:.6em}
.footer-legal{display:flex;justify-content:space-between;gap:18px;flex-wrap:wrap;padding-top:20px;font-size:.78rem;color:#8392ab}
.footer-legal a{color:#9aa7bd;margin-right:14px}

/* ---------- responsive ---------- */
@media (max-width:980px){
  .grid-3,.steps{grid-template-columns:1fr 1fr}
  .footer-grid{grid-template-columns:1fr 1fr}
  .layout-sidebar{grid-template-columns:1fr}
  .sidebar .card{position:static}
  .nav-toggle{display:block}
  nav.main-nav{display:none;position:absolute;top:100%;left:0;right:0;background:#fff;border-bottom:1px solid var(--line);box-shadow:var(--shadow);max-height:calc(100vh - 70px);overflow:auto}
  nav.main-nav.open{display:block}
  nav.main-nav>ul{flex-direction:column;align-items:stretch;padding:12px 18px 20px;gap:0}
  .submenu{position:static;border:none;box-shadow:none;min-width:0;padding-left:16px}
  .nav-cta{margin:12px 0 0}
}
@media (max-width:640px){
  .grid-3,.grid-2,.steps,.form-grid{grid-template-columns:1fr}
  .footer-grid{grid-template-columns:1fr}
  .hero{padding:56px 0 60px}
  .section{padding:46px 0}
}

/* tmsearchapi.html live demo widget */
.tm-demo{margin:34px 0;padding:26px;background:var(--card);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow)}
.tm-demo h2{margin-top:0}
.tm-demo>p{color:var(--muted);font-size:.93rem}
.tm-demo-form{margin:16px 0 4px}
.tm-demo-controls{display:flex;gap:8px;flex-wrap:wrap}
.tm-demo-controls select,.tm-demo-controls input{font-family:var(--sans);font-size:.92rem;padding:10px 12px;border:1px solid var(--line);border-radius:8px;background:#fff;color:var(--ink)}
.tm-demo-controls input{flex:1 1 220px;min-width:0}
.tm-demo-controls select{flex:0 0 auto}
.tm-demo-controls input:focus,.tm-demo-controls select:focus{outline:none;border-color:var(--gold)}
.tm-demo-status{font-size:.88rem;color:var(--muted);min-height:1.2em;margin:10px 0 0}
.tm-demo-status.err{color:#a12d2d}
.tm-demo-results{margin-top:14px;display:grid;gap:10px}
.tm-result{border:1px solid var(--line);border-radius:8px;padding:12px 14px;background:var(--bg)}
.tm-result .tm-mark{font-family:var(--serif);font-weight:600;font-size:1rem;color:var(--navy)}
.tm-result .tm-owner{font-size:.86rem;color:var(--ink);margin-top:2px}
.tm-result .tm-meta{font-size:.78rem;color:var(--muted);margin-top:6px;display:flex;gap:14px;flex-wrap:wrap}
.tm-result .tm-goods{font-size:.8rem;color:var(--muted);margin-top:7px;line-height:1.5;overflow-wrap:break-word}
.tm-result .tm-uspto{margin-top:8px}
.tm-result .tm-uspto a{font-size:.8rem;font-weight:600;color:var(--navy);text-decoration:none;border-bottom:1px solid var(--gold)}
.tm-result .tm-uspto a:hover{color:var(--gold)}
.tm-demo-note{font-size:.8rem;color:var(--muted);margin-top:14px}

/* WHOIS lookup result card */
.whois-card{border:1px solid var(--line);border-radius:8px;background:var(--bg);overflow:hidden}
.whois-row{display:flex;gap:14px;padding:10px 14px;font-size:.88rem;border-top:1px solid var(--line)}
.whois-row:first-child{border-top:none}
.whois-label{flex:0 0 120px;color:var(--muted);font-weight:600}
.whois-value{flex:1 1 auto;min-width:0;color:var(--ink);overflow-wrap:break-word}
.whois-tag{display:inline-block;font-size:.74rem;background:#fbf8f0;border:1px solid var(--line);border-radius:999px;padding:2px 9px;margin:2px 4px 2px 0;color:var(--navy)}

/* live trademark search preview on intake / disclosure forms */
.tm-preview{border:1px solid var(--line);border-left:4px solid var(--gold);border-radius:var(--radius);background:#fbf8f0;padding:18px 20px}
.tm-preview-head{font-family:var(--serif);font-weight:600;color:var(--navy);font-size:1rem;display:flex;align-items:center;gap:10px;flex-wrap:wrap}
.tm-preview-tag{font-family:var(--sans);font-size:.62rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:#fff;background:var(--gold);padding:3px 8px;border-radius:999px}
.tm-preview-intro{font-size:.83rem;color:var(--muted);margin:8px 0 0;line-height:1.55}
.tm-preview-intro strong{color:var(--navy)}
.tm-preview-status{font-size:.85rem;color:var(--navy);margin-top:12px;min-height:1.2em}
.tm-preview-status.err{color:#a12d2d}
.tm-preview-results{margin-top:12px;display:grid;gap:10px}
.tm-pv-item{border:1px solid var(--line);border-radius:8px;background:#fff;padding:12px 14px}
.tm-pv-mark{font-family:var(--serif);font-weight:600;font-size:.98rem;color:var(--navy)}
.tm-pv-owner{font-size:.84rem;color:var(--ink);margin-top:2px}
.tm-pv-meta{font-size:.76rem;color:var(--muted);margin-top:6px;display:flex;gap:12px;flex-wrap:wrap}
.tm-pv-goods{font-size:.8rem;color:var(--muted);margin-top:7px;line-height:1.5}
.tm-pv-uspto{margin-top:8px}
.tm-pv-uspto a{font-size:.79rem;font-weight:600;color:var(--navy);text-decoration:none;border-bottom:1px solid var(--gold)}
.tm-pv-uspto a:hover{color:var(--gold)}

/* One-time "email me these results" block on the USPTO status tools */
.tm-email{margin-top:16px;padding-top:16px;border-top:1px solid var(--line)}
.tm-email label{display:block;font-size:.85rem;color:var(--muted);margin-bottom:8px}
.tm-email input[type="email"]{font-family:var(--sans);font-size:.92rem;padding:10px 12px;border:1px solid var(--line);border-radius:8px;background:#fff;color:var(--ink);flex:1 1 220px;min-width:0}
.tm-email input[type="email"]:focus{outline:none;border-color:var(--gold)}

/* Patent assignment / chain-of-title entries */
.pa-heading{font-size:1rem;margin:18px 0 10px}
.pa-assign{border:1px solid var(--line);border-left:4px solid var(--gold);border-radius:8px;background:var(--bg);padding:12px 14px;margin-top:10px}
.pa-conveyance{font-family:var(--serif);font-weight:600;font-size:.95rem;color:var(--navy)}
.pa-meta{font-size:.78rem;color:var(--muted);margin-top:6px}
.pa-party{font-size:.84rem;color:var(--ink);margin-top:5px;overflow-wrap:break-word}
.pa-party span{color:var(--muted);font-weight:600}

/* Owner lookup — two-column trademark + patent results (ownership-transfer page) */
.owner-cols{display:grid;grid-template-columns:1fr 1fr;gap:22px;margin-top:16px}
@media (max-width:680px){.owner-cols{grid-template-columns:1fr}}
.owner-col h3{font-size:1rem;margin:0 0 10px;color:var(--navy)}
.owner-count{font-size:.8rem;color:var(--muted);font-weight:400;margin-left:6px}
.owner-item{border:1px solid var(--line);border-left:4px solid var(--gold);border-radius:8px;background:#fff;padding:12px 14px;margin-bottom:10px}
.owner-item-title{font-family:var(--serif);font-weight:600;font-size:.95rem;color:var(--ink);overflow-wrap:break-word}
.owner-item-meta{font-size:.8rem;color:var(--muted);margin-top:5px;overflow-wrap:break-word}
.owner-item-link{font-size:.8rem;margin-top:6px}
.owner-empty{font-size:.86rem;color:var(--muted);font-style:italic}

/* Keyboard focus indicator for the search/demo inputs that suppress the mouse outline */
.tm-demo-controls input:focus-visible,.tm-demo-controls select:focus-visible,
.tm-email input[type="email"]:focus-visible{outline:3px solid var(--gold-light);outline-offset:1px}
