/* ===================================================================
   ONLINE LEGAL SERVICES — inner-page styles (brown & red theme)
   Loaded in addition to /css/style.v5.css, on content pages like
   our_firm.htm, our_team.htm, etc. (not the homepage — that uses home.v5.css)
=================================================================== */

/* ---------- Page header band ---------- */
.page-header{
  background: linear-gradient(165deg, var(--cream) 0%, var(--brown-pale) 100%);
  border-bottom: 1px solid var(--line);
  padding: 52px 0 44px;
}
.page-header h1{ color: var(--brown-deep); font-size: clamp(1.9rem, 3vw + 1rem, 2.6rem); margin: .25em 0 .3em; }
.page-header .lede{ color: var(--ink-soft); font-size: 1.05rem; max-width: 64ch; margin:0; }
.crumb{
  font-family: var(--font-mono);
  font-size:.74rem;
  letter-spacing:.06em;
  color: var(--ink-soft);
  margin-bottom: 14px;
}
.crumb a{ color: var(--ink-soft); text-decoration:none; }
.crumb a:hover{ color: var(--red); }

/* ---------- Content layout ---------- */
.content-layout{
  display:grid;
  grid-template-columns: 1fr 320px;
  gap: 56px;
  padding: 56px 0;
  align-items:start;
}
.prose h2{
  font-size: 1.5rem;
  margin: 1.6em 0 .5em;
  padding-top: .2em;
}
.prose h2:first-child{ margin-top:0; }
.prose p{
  color: var(--ink-soft);
  margin: 0 0 1.1em;
  font-size: 1rem;
  line-height: 1.75;
}
.prose strong{ color: var(--ink); }

/* ---------- Sidebar ---------- */
.page-sidebar{ display:flex; flex-direction:column; gap:24px; position:sticky; top: 100px; }
.sidebar-card{
  background: var(--paper-raised);
  border: 1px solid var(--line);
  border-top: 3px solid var(--red);
  border-radius: var(--radius);
  padding: 24px 24px;
  box-shadow: var(--shadow-card);
}
.sidebar-card h4{
  font-family: var(--font-mono);
  font-size:.7rem;
  letter-spacing:.12em;
  text-transform: uppercase;
  color: var(--red);
  margin: 0 0 16px;
}
.fact-list{ list-style:none; margin:0; padding:0; display:flex; flex-direction:column; gap:16px; }
.fact-list li{ display:flex; flex-direction:column; }
.fact-list .fact-num{ font-family: var(--font-display); font-size:1.7rem; color: var(--brown-deep); line-height:1; }
.fact-list .fact-label{ font-size:.85rem; color: var(--ink-soft); margin-top:4px; }

.notice-card{
  background: var(--brown-pale);
  border: 1px solid var(--line);
  border-radius: var(--radius);
  padding: 18px 20px;
  font-size:.85rem;
  color: var(--ink);
  line-height:1.6;
}
.notice-card strong{ display:block; margin-bottom:6px; color: var(--brown-deep); }
.notice-card a{ color: var(--red); text-decoration:none; font-weight:600; }
.notice-card a:hover{ text-decoration:underline; }

.social-row{ display:flex; gap:10px; }
.social-row a{
  display:flex; align-items:center; justify-content:center;
  width:36px; height:36px;
  border-radius:50%;
  background: var(--brown-pale);
  color: var(--brown-deep);
  text-decoration:none;
  font-family: var(--font-mono);
  font-size:.7rem;
  font-weight:700;
  transition: background .15s ease, color .15s ease;
}
.social-row a:hover{ background: var(--red); color:#fff; }

.team-cta{
  background: var(--brown-deep);
  color: var(--cream-text);
  border-radius: var(--radius);
  padding: 22px 24px;
}
.team-cta h4{ color:#fff; font-family: var(--font-display); font-size:1.1rem; margin:0 0 8px; }
.team-cta p{ color: var(--tan-soft); font-size:.88rem; margin:0 0 14px; }

@media (max-width: 880px){
  .content-layout{ grid-template-columns: 1fr; }
  .page-sidebar{ position:static; }
}

/* ---------- FAQ accordion ---------- */
.faq-list{ display:flex; flex-direction:column; gap:10px; }
.faq-list details{
  background: var(--paper-raised);
  border: 1px solid var(--line);
  border-radius: var(--radius);
  padding: 4px 22px;
}
.faq-list summary{
  cursor:pointer;
  padding: 16px 0;
  font-weight:600;
  color: var(--brown-deep);
  list-style:none;
  display:flex;
  justify-content:space-between;
  align-items:center;
  gap:12px;
}
.faq-list summary::-webkit-details-marker{ display:none; }
.faq-list summary::after{
  content:"+";
  font-family: var(--font-display);
  font-size:1.3rem;
  color: var(--red);
  flex:none;
}
.faq-list details[open] summary::after{ content:"\2212"; }
.faq-list .faq-answer{ color: var(--ink-soft); padding: 0 0 18px; line-height:1.7; }

/* ---------- Client list ---------- */
.client-list{ list-style:none; margin:0; padding:0; display:grid; grid-template-columns: 1fr 1fr; gap:14px; }
.client-list li{
  background: var(--paper-raised);
  border: 1px solid var(--line);
  border-left: 3px solid var(--brown);
  border-radius: var(--radius);
  padding: 16px 18px;
  font-weight:600;
  color: var(--brown-deep);
}
@media (max-width: 560px){ .client-list{ grid-template-columns: 1fr; } }

/* ---------- Testimonial cards (list page) ---------- */
.testimonial-grid{ display:flex; flex-direction:column; gap:18px; }
.testimonial-card{
  background: var(--paper-raised);
  border: 1px solid var(--line);
  border-left: 4px solid var(--red);
  border-radius: var(--radius);
  padding: 24px 28px;
  box-shadow: var(--shadow-card);
}
.testimonial-card p{ color: var(--ink); margin: 0 0 12px; line-height:1.7; }
.testimonial-card cite{
  font-style:normal;
  font-family: var(--font-mono);
  font-size:.78rem;
  color: var(--ink-soft);
  letter-spacing:.03em;
}

/* ---------- Pricing table ---------- */
.pricing-table{ width:100%; border-collapse: collapse; margin: 1.4em 0; font-size:.92rem; }
.pricing-table th{
  text-align:left;
  font-family: var(--font-mono);
  font-size:.7rem;
  letter-spacing:.08em;
  text-transform: uppercase;
  color: var(--red);
  border-bottom: 2px solid var(--brown);
  padding: 10px 12px;
}
.pricing-table td{ padding: 12px; border-bottom: 1px solid var(--line); color: var(--ink); vertical-align:top; }
.pricing-table tr:last-child td{ border-bottom:none; }

/* ---------- Document checklist ---------- */
.doc-checklist{ list-style:none; margin: 1em 0 1.6em; padding:0; display:flex; flex-direction:column; gap:8px; }
.doc-checklist li{
  position:relative;
  padding-left: 28px;
  color: var(--ink-soft);
  font-size:.96rem;
}
.doc-checklist li::before{
  content:"";
  position:absolute; left:0; top:.35em;
  width:14px; height:14px;
  border: 2px solid var(--brown);
  border-radius:3px;
}

/* ---------- Related services list (sidebar) ---------- */
.related-list{ list-style:none; margin:0; padding:0; display:flex; flex-direction:column; gap:9px; }
.related-list a{
  display:flex; justify-content:space-between;
  text-decoration:none; color: var(--ink); font-size:.9rem;
  padding: 8px 0; border-bottom: 1px dashed var(--line);
}
.related-list a:hover{ color: var(--red); }
.related-list a::after{ content:"\2192"; color: var(--ink-soft); }
.related-list a:hover::after{ color: var(--red); }

/* ---------- Expandable "more cities" block ---------- */
.more-cities{ margin: .8em 0 1.4em; }
.more-cities summary{
  cursor:pointer;
  color: var(--red);
  font-weight:600;
  font-size:.9rem;
}
.more-cities p{ color: var(--ink-soft); font-size:.88rem; line-height:1.8; margin-top:.8em; }

/* =========================================
   Practice Areas Directory Grid
   ========================================= */
.pa-grid{
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(min(100%, 340px), 1fr));
  gap: 1.5rem;
}

.pa-card{
  background: var(--paper-raised);
  border: 1px solid var(--line);
  border-top: 3px solid var(--brown);
  border-radius: 4px;
  overflow: hidden;
}

.pa-card--wide{
  grid-column: 1 / -1;   /* spans full row */
}

.pa-card-head{
  display: flex;
  align-items: baseline;
  gap: .75rem;
  padding: 1.1rem 1.4rem .8rem;
  border-bottom: 1px solid var(--line);
  background: var(--cream);
}

.pa-num{
  font-family: 'IBM Plex Mono', monospace;
  font-size: .72rem;
  font-weight: 600;
  color: var(--red);
  letter-spacing: .06em;
  flex-shrink: 0;
}

.pa-card-head h2{
  margin: 0;
  font-size: 1.05rem;
  font-weight: 700;
  line-height: 1.3;
}

.pa-card-head h2 a{
  color: var(--brown-deep);
  text-decoration: none;
}

.pa-card-head h2 a:hover{
  color: var(--red);
}

.pa-card-body{
  padding: 1.1rem 1.4rem 1.3rem;
}

.pa-label{
  font-family: 'IBM Plex Mono', monospace;
  font-size: .67rem;
  font-weight: 600;
  letter-spacing: .08em;
  text-transform: uppercase;
  color: var(--ink-soft);
  margin: 1rem 0 .4rem;
  padding-bottom: .3rem;
  border-bottom: 1px solid var(--line);
}

.pa-label:first-child{ margin-top: 0; }

.pa-card-body ul{
  margin: 0 0 .3rem;
  padding: 0;
  list-style: none;
}

.pa-card-body ul li{
  padding: .28rem 0;
  border-bottom: 1px dashed var(--line);
  font-size: .9rem;
  line-height: 1.4;
}

.pa-card-body ul li:last-child{ border-bottom: none; }

.pa-card-body ul li a{
  color: var(--ink);
  text-decoration: none;
  display: flex;
  align-items: center;
  gap: .4rem;
}

.pa-card-body ul li a::before{
  content: '›';
  color: var(--red);
  font-weight: 700;
  flex-shrink: 0;
}

.pa-card-body ul li a:hover{ color: var(--red); }

/* Wide card body — three column lists */
.pa-card-body--cols{
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(200px, 1fr));
  gap: 0 2rem;
}

.pa-card-body--cols ul{ margin: 0; }

@media (max-width: 640px){
  .pa-card-body--cols{ grid-template-columns: 1fr; }
}

/* =========================================
   Order Form & Steps
   ========================================= */
.order-how{
  background: var(--cream);
  border: 1px solid var(--line);
  border-left: 4px solid var(--red);
  border-radius: 4px;
  padding: 1.4rem 1.6rem 1.6rem;
  margin-bottom: 2rem;
}

.order-how h2{
  margin: 0 0 1rem;
  font-size: 1.05rem;
}

.order-steps{
  margin: 0; padding: 0;
  list-style: none;
  display: flex;
  flex-direction: column;
  gap: .6rem;
}

.order-steps li{
  display: flex;
  align-items: baseline;
  gap: .75rem;
  font-size: .92rem;
  line-height: 1.5;
}

.step-num{
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 1.5rem;
  height: 1.5rem;
  border-radius: 50%;
  background: var(--red);
  color: #fff;
  font-family: 'IBM Plex Mono', monospace;
  font-size: .68rem;
  font-weight: 700;
  flex-shrink: 0;
}

/* Form */
.order-form-wrap h2{
  margin: 0 0 1.2rem;
  font-size: 1.05rem;
}

.order-form{
  display: flex;
  flex-direction: column;
  gap: 1.1rem;
}

.form-row{ display: flex; gap: 1rem; }
.form-row--2 > .form-field{ flex: 1 1 0; min-width: 0; }

.form-field{
  display: flex;
  flex-direction: column;
  gap: .35rem;
}

.form-field label{
  font-size: .82rem;
  font-weight: 600;
  color: var(--ink);
  letter-spacing: .01em;
}

.req{ color: var(--red); }

.form-field input,
.form-field select,
.form-field textarea{
  width: 100%;
  padding: .6rem .75rem;
  border: 1px solid var(--line);
  border-radius: 4px;
  background: var(--paper-raised);
  color: var(--ink);
  font-family: 'Inter', sans-serif;
  font-size: .9rem;
  line-height: 1.5;
  transition: border-color .15s;
  box-sizing: border-box;
}

.form-field input:focus,
.form-field select:focus,
.form-field textarea:focus{
  outline: none;
  border-color: var(--brown);
  box-shadow: 0 0 0 3px rgba(107,68,35,.1);
}

.form-field select{
  appearance: none;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%237C6B59' stroke-width='1.5' fill='none' stroke-linecap='round'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: right .75rem center;
  padding-right: 2.2rem;
}

.form-field textarea{ resize: vertical; min-height: 110px; }

.form-note{
  font-size: .8rem;
  color: var(--ink-soft);
  background: var(--cream);
  border: 1px solid var(--line);
  border-radius: 4px;
  padding: .7rem .9rem;
  margin: 0;
  line-height: 1.6;
}

@media (max-width: 600px){
  .form-row--2{ flex-direction: column; }
}
