/* =============================================================
   PAGE-LEVEL STYLES — extends styles-v3.css
   For interior pages (services, cases, team, process, contact, legal)
   ============================================================= */

/* PAGE HERO — smaller than home hero, dark band */
.page-hero { background: var(--ink); color: #fff; padding: 100px 0 80px; border-bottom: 1px solid var(--line-dark); position: relative; overflow: hidden; }
.page-hero::before { content: ''; position: absolute; inset: 0; background: radial-gradient(ellipse at 80% -10%, rgba(1,170,236,0.14), transparent 55%); pointer-events: none; }
.page-hero .container { position: relative; }
.page-hero .crumbs { font-family: var(--mono); font-size: 11px; letter-spacing: 0.1em; text-transform: uppercase; color: var(--text-dim); margin-bottom: 24px; }
.page-hero .crumbs a { color: var(--text-dim); text-decoration: none; transition: color .2s; }
.page-hero .crumbs a:hover { color: #fff; }
.page-hero .crumbs .sep { margin: 0 10px; opacity: 0.5; }
.page-hero h1 { font-size: clamp(44px, 6vw, 80px); font-weight: 600; letter-spacing: -0.035em; line-height: 1.05; max-width: 22ch; margin-bottom: 24px; }
.page-hero h1 .accent { color: var(--blue-bright); }
.page-hero .sub { font-size: 18px; color: #c8cdd9; line-height: 1.55; max-width: 64ch; }

/* SECTION shells */
.sec { padding: 100px 0; background: var(--paper); }
.sec--alt { background: var(--paper-2); }
.sec--dark { background: var(--ink); color: #fff; }
.sec .head { display: grid; grid-template-columns: 1fr 1fr; gap: 32px; margin-bottom: 64px; align-items: end; }
.sec .head h2 { font-size: 44px; font-weight: 600; letter-spacing: -0.03em; line-height: 1.05; }
.sec .head p { color: var(--text-mid); font-size: 16px; max-width: 48ch; }
.sec--dark .head p { color: #c8cdd9; }
.sec--dark .tag { color: var(--blue-bright); }

/* ============ SERVICIOS index ============ */
.svc-index-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 1px; background: var(--line); border: 1px solid var(--line); }
.svc-card { background: var(--paper); padding: 48px 36px; display: flex; flex-direction: column; gap: 20px; text-decoration: none; color: var(--text); transition: background 0.3s; position: relative; }
.svc-card:hover { background: var(--paper-2); }
.svc-card .num { font-family: var(--mono); font-size: 11px; letter-spacing: 0.12em; text-transform: uppercase; color: var(--blue); font-weight: 600; }
.svc-card h3 { font-size: 30px; font-weight: 600; letter-spacing: -0.025em; line-height: 1.1; }
.svc-card p { font-size: 15px; color: var(--text-mid); line-height: 1.6; }
.svc-card .arrow { margin-top: auto; padding-top: 16px; font-family: var(--mono); font-size: 12px; letter-spacing: 0.08em; text-transform: uppercase; color: var(--blue); display: flex; align-items: center; gap: 8px; transition: gap 0.3s; }
.svc-card:hover .arrow { gap: 14px; }

/* ============ SERVICIO detalle ============ */
.svc-detail { padding: 100px 0; }
.svc-detail-grid { display: grid; grid-template-columns: 1fr 1.6fr; gap: 80px; align-items: start; }
.svc-detail .sticky { position: sticky; top: 96px; }
.svc-detail .tag { color: var(--blue); display: block; margin-bottom: 12px; }
.svc-detail h2 { font-size: 44px; font-weight: 600; letter-spacing: -0.03em; line-height: 1.05; margin-bottom: 24px; }
.svc-detail .lead { font-size: 18px; line-height: 1.55; color: var(--text); margin-bottom: 24px; max-width: 48ch; font-weight: 500; }
.svc-detail .meta-list { list-style: none; padding: 0; margin: 32px 0 0; border-top: 1px solid var(--line); }
.svc-detail .meta-list li { display: grid; grid-template-columns: 140px 1fr; gap: 16px; padding: 16px 0; border-bottom: 1px solid var(--line); font-size: 14px; }
.svc-detail .meta-list .k { font-family: var(--mono); font-size: 11px; letter-spacing: 0.08em; text-transform: uppercase; color: var(--text-dim); padding-top: 2px; }
.svc-detail .meta-list .v { color: var(--text); }

.svc-section { margin-bottom: 64px; }
.svc-section:last-child { margin-bottom: 0; }
.svc-section h3 { font-size: 24px; font-weight: 600; letter-spacing: -0.02em; margin-bottom: 16px; padding-bottom: 12px; border-bottom: 2px solid var(--ink); }
.svc-section p { font-size: 16px; line-height: 1.65; color: var(--text-mid); margin-bottom: 16px; max-width: 64ch; }
.svc-section ul { list-style: none; padding: 0; margin: 16px 0; }
.svc-section ul li { padding: 14px 0; border-bottom: 1px solid var(--line); font-size: 15px; line-height: 1.55; display: flex; gap: 16px; align-items: flex-start; }
.svc-section ul li::before { content: ''; width: 8px; height: 8px; background: var(--blue); margin-top: 8px; flex-shrink: 0; transform: rotate(45deg); }
.svc-section ul li strong { display: block; font-weight: 600; margin-bottom: 4px; color: var(--text); }
.svc-section ul li span { color: var(--text-mid); }

.deliverables-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; margin-top: 24px; }
.deliv-card { padding: 24px; border: 1px solid var(--line); border-radius: 10px; background: var(--paper); transition: border-color 0.3s, transform 0.3s; }
.deliv-card:hover { border-color: var(--blue); transform: translateY(-2px); }
.deliv-card .num { font-family: var(--mono); font-size: 11px; letter-spacing: 0.1em; color: var(--text-dim); text-transform: uppercase; margin-bottom: 10px; }
.deliv-card h4 { font-size: 16px; font-weight: 600; margin-bottom: 6px; letter-spacing: -0.01em; }
.deliv-card p { font-size: 13px; color: var(--text-mid); line-height: 1.5; margin: 0; }

/* ============ CASOS listado ============ */
.cases-list { padding: 80px 0 100px; }
.cases-list .filter-bar { display: flex; gap: 8px; margin-bottom: 48px; flex-wrap: wrap; padding-bottom: 28px; border-bottom: 1px solid var(--line); }
.filter-pill { padding: 8px 16px; border: 1px solid var(--line); border-radius: 100px; font-family: var(--mono); font-size: 11px; letter-spacing: 0.06em; text-transform: uppercase; cursor: pointer; background: var(--paper); transition: all 0.2s; }
.filter-pill:hover { border-color: var(--ink); }
.filter-pill.active { background: var(--ink); color: #fff; border-color: var(--ink); }

.cases-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 1px; background: var(--line); border: 1px solid var(--line); }
.case-tile { background: var(--paper); padding: 36px; text-decoration: none; color: var(--text); display: flex; flex-direction: column; gap: 20px; transition: background 0.3s; min-height: 280px; }
.case-tile:hover { background: var(--paper-2); }
.case-tile.featured { background: var(--ink); color: #fff; }
.case-tile.featured:hover { background: #1a2238; }
.case-tile .featured-badge { font-family: var(--mono); font-size: 10px; letter-spacing: 0.12em; text-transform: uppercase; color: var(--blue-bright); font-weight: 600; }
.case-tile .top { display: flex; align-items: center; gap: 14px; }
.case-tile .logo-box { width: 56px; height: 56px; flex-shrink: 0; border: 1px solid var(--line); border-radius: 10px; background: var(--paper); display: flex; align-items: center; justify-content: center; padding: 8px; overflow: hidden; }
.case-tile.featured .logo-box { background: var(--paper); border-color: transparent; }
.case-tile .logo-box img { max-width: 100%; max-height: 100%; object-fit: contain; }
.case-tile .name { font-size: 22px; font-weight: 600; letter-spacing: -0.02em; line-height: 1.1; }
.case-tile .sector { font-family: var(--mono); font-size: 11px; letter-spacing: 0.06em; text-transform: uppercase; color: var(--text-dim); margin-top: 4px; }
.case-tile .what { font-size: 15px; color: var(--text-mid); line-height: 1.55; flex: 1; }
.case-tile.featured .what { color: #c8cdd9; }
.case-tile .arrow { font-family: var(--mono); font-size: 12px; letter-spacing: 0.08em; text-transform: uppercase; color: var(--blue); display: flex; align-items: center; gap: 8px; transition: gap 0.3s; }
.case-tile.featured .arrow { color: var(--blue-bright); }
.case-tile:hover .arrow { gap: 14px; }
.case-tile .micro-metrics { display: flex; gap: 16px; padding-top: 16px; border-top: 1px solid var(--line); }
.case-tile.featured .micro-metrics { border-top-color: var(--line-dark); }
.case-tile .micro-metric .v { font-size: 18px; font-weight: 600; color: var(--blue); }
.case-tile.featured .micro-metric .v { color: var(--blue-bright); }
.case-tile .micro-metric .k { font-family: var(--mono); font-size: 9px; letter-spacing: 0.06em; text-transform: uppercase; color: var(--text-dim); margin-top: 2px; }

/* ============ CASO detalle ============ */
.case-hero { background: var(--ink); color: #fff; padding: 100px 0 80px; }
.case-hero .crumbs { font-family: var(--mono); font-size: 11px; letter-spacing: 0.1em; text-transform: uppercase; color: var(--text-dim); margin-bottom: 24px; }
.case-hero .crumbs a { color: var(--text-dim); text-decoration: none; }
.case-hero .crumbs a:hover { color: #fff; }
.case-hero .crumbs .sep { margin: 0 10px; opacity: 0.5; }
.case-hero .top { display: flex; align-items: center; gap: 24px; margin-bottom: 32px; }
.case-hero .logo-box { width: 88px; height: 88px; border: 1px solid var(--line-dark); border-radius: 14px; background: var(--paper); display: flex; align-items: center; justify-content: center; padding: 14px; }
.case-hero .logo-box img { max-width: 100%; max-height: 100%; object-fit: contain; }
.case-hero h1 { font-size: clamp(44px, 6vw, 76px); font-weight: 600; letter-spacing: -0.035em; line-height: 1.02; }
.case-hero .sector { font-family: var(--mono); font-size: 12px; letter-spacing: 0.08em; text-transform: uppercase; color: var(--blue-bright); margin-top: 6px; font-weight: 600; }
.case-hero .lead { font-size: 18px; color: #c8cdd9; max-width: 64ch; line-height: 1.55; margin-top: 20px; }

.case-stats { background: var(--ink-2); border-top: 1px solid var(--line-dark); border-bottom: 1px solid var(--line-dark); padding: 40px 0; color: #fff; }
.case-stats .grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 32px; }
.case-stats .item .v { font-size: 48px; font-weight: 600; letter-spacing: -0.03em; color: var(--blue-bright); font-variant-numeric: tabular-nums; line-height: 1; }
.case-stats .item .k { font-family: var(--mono); font-size: 11px; letter-spacing: 0.08em; text-transform: uppercase; color: var(--text-dim); margin-top: 14px; }

.case-body { padding: 100px 0; }
.case-body-grid { display: grid; grid-template-columns: 220px 1fr; gap: 64px; align-items: start; }
.case-aside { position: sticky; top: 96px; }
.case-aside .lbl { font-family: var(--mono); font-size: 10px; letter-spacing: 0.1em; text-transform: uppercase; color: var(--text-dim); margin-bottom: 6px; }
.case-aside dl { margin: 0; }
.case-aside dt { font-family: var(--mono); font-size: 10px; letter-spacing: 0.08em; text-transform: uppercase; color: var(--text-dim); margin-top: 20px; }
.case-aside dd { font-size: 14px; color: var(--text); margin: 4px 0 0; }
.case-section { margin-bottom: 56px; }
.case-section:last-child { margin-bottom: 0; }
.case-section h2 { font-size: 28px; font-weight: 600; letter-spacing: -0.025em; margin-bottom: 20px; padding-bottom: 12px; border-bottom: 2px solid var(--ink); }
.case-section p { font-size: 17px; line-height: 1.65; color: var(--text-mid); margin-bottom: 16px; max-width: 68ch; }
.case-section .pull { font-size: 22px; line-height: 1.4; font-weight: 500; color: var(--text); padding: 28px 32px; background: var(--paper-2); border-left: 3px solid var(--blue); border-radius: 0 10px 10px 0; margin: 28px 0; }
.case-section ul { padding: 0; list-style: none; margin: 16px 0; }
.case-section ul li { padding: 12px 0; border-bottom: 1px solid var(--line); font-size: 15px; color: var(--text-mid); display: flex; gap: 14px; }
.case-section ul li::before { content: '→'; color: var(--blue); font-weight: 600; flex-shrink: 0; }

.case-related { padding: 100px 0; background: var(--paper-2); }
.case-related h3 { font-size: 28px; font-weight: 600; letter-spacing: -0.025em; margin-bottom: 32px; }
.case-related .grid { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; }

/* ============ EQUIPO page ============ */
.team-history { padding: 100px 0 80px; background: var(--paper); }
.team-history .layout { display: grid; grid-template-columns: 1fr 1fr; gap: 80px; align-items: start; }
.team-history .tag { color: var(--blue); display: block; margin-bottom: 12px; }
.team-history h2 { font-size: 48px; font-weight: 600; letter-spacing: -0.03em; line-height: 1.05; margin-bottom: 24px; }
.team-history .lead { font-size: 20px; line-height: 1.5; font-weight: 500; color: var(--text); margin-bottom: 24px; max-width: 52ch; }
.team-history p { font-size: 16px; line-height: 1.65; color: var(--text-mid); margin-bottom: 16px; max-width: 58ch; }
.team-history .timeline { padding: 0; list-style: none; border-left: 2px solid var(--line); padding-left: 28px; margin-top: 24px; }
.team-history .timeline li { padding: 16px 0; position: relative; }
.team-history .timeline li::before { content: ''; position: absolute; left: -34px; top: 24px; width: 10px; height: 10px; background: var(--blue); border-radius: 50%; }
.team-history .timeline .y { font-family: var(--mono); font-size: 11px; letter-spacing: 0.08em; color: var(--blue); font-weight: 600; }
.team-history .timeline .t { font-size: 15px; color: var(--text); margin-top: 4px; }

.team-roster { padding: 100px 0; background: var(--paper-2); }
.team-roster-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 32px 24px; }
.member-card { text-align: left; }
.member-card .photo-wrap { position: relative; aspect-ratio: 1; border-radius: 50%; overflow: hidden; margin-bottom: 18px; background: var(--paper); border: 1px solid var(--line); transition: transform 0.3s, border-color 0.3s; }
.member-card:hover .photo-wrap { transform: translateY(-4px); border-color: var(--blue); }
.member-card .photo-wrap img { width: 100%; height: 100%; object-fit: cover; display: block; }
.member-card .name { font-size: 18px; font-weight: 600; letter-spacing: -0.015em; }
.member-card .role { font-family: var(--mono); font-size: 11px; letter-spacing: 0.06em; text-transform: uppercase; color: var(--blue); margin-top: 4px; font-weight: 600; }
.team-roster-note { text-align: center; margin-top: 56px; font-family: var(--mono); font-size: 11px; letter-spacing: 0.08em; text-transform: uppercase; color: var(--text-dim); padding-top: 32px; border-top: 1px solid var(--line); }

/* ============ PROCESO full page ============ */
.process-full-hero { background: var(--ink); color: #fff; padding: 100px 0 80px; }
.process-full { padding: 100px 0; background: var(--paper); }
.process-full .row { display: grid; grid-template-columns: 1fr 1.6fr; gap: 80px; align-items: start; padding: 56px 0; border-top: 1px solid var(--line); }
.process-full .row:first-of-type { border-top: 2px solid var(--ink); }
.process-full .row .num-block { position: sticky; top: 96px; }
.process-full .row .num { font-family: var(--mono); font-size: 96px; font-weight: 300; color: var(--blue); letter-spacing: -0.04em; line-height: 0.9; }
.process-full .row .lbl { font-family: var(--mono); font-size: 12px; letter-spacing: 0.1em; text-transform: uppercase; color: var(--text-dim); margin-top: 12px; }
.process-full .row .dur { font-family: var(--mono); font-size: 14px; color: var(--blue); margin-top: 8px; font-weight: 600; }
.process-full .row h3 { font-size: 32px; font-weight: 600; letter-spacing: -0.025em; margin-bottom: 16px; }
.process-full .row p { font-size: 17px; line-height: 1.6; color: var(--text-mid); margin-bottom: 16px; max-width: 64ch; }
.process-full .row ul { list-style: none; padding: 0; margin-top: 24px; }
.process-full .row ul li { padding: 12px 0; border-bottom: 1px solid var(--line); font-size: 15px; line-height: 1.5; display: flex; gap: 14px; }
.process-full .row ul li::before { content: ''; width: 6px; height: 6px; background: var(--blue); border-radius: 50%; margin-top: 8px; flex-shrink: 0; }

/* ============ CONTACTO page ============ */
.contact-page { background: var(--ink); color: #fff; min-height: calc(100vh - 65px); padding: 80px 0 100px; }
.contact-page .layout { display: grid; grid-template-columns: 1fr 1.2fr; gap: 80px; align-items: start; }
.contact-page .tag { color: var(--blue-bright); display: block; margin-bottom: 16px; }
.contact-page h1 { font-size: clamp(44px, 5vw, 64px); font-weight: 600; letter-spacing: -0.035em; line-height: 1.02; margin-bottom: 24px; }
.contact-page .sub { font-size: 18px; color: #c8cdd9; line-height: 1.55; margin-bottom: 48px; }
.contact-info { border-top: 1px solid var(--line-dark); padding-top: 32px; }
.contact-info dt { font-family: var(--mono); font-size: 10px; letter-spacing: 0.1em; text-transform: uppercase; color: var(--text-dim); margin-top: 24px; }
.contact-info dt:first-child { margin-top: 0; }
.contact-info dd { font-size: 15px; color: #fff; margin: 6px 0 0; }
.contact-info dd a { color: #fff; text-decoration: none; border-bottom: 1px solid var(--blue-bright); padding-bottom: 1px; }
.contact-info dd a:hover { color: var(--blue-bright); }

.contact-form { background: rgba(255,255,255,0.03); border: 1px solid var(--line-dark); border-radius: 14px; padding: 40px; }
.contact-form h2 { font-size: 22px; font-weight: 600; letter-spacing: -0.02em; margin-bottom: 6px; }
.contact-form .form-sub { font-size: 13px; color: var(--text-dim); margin-bottom: 28px; font-family: var(--mono); letter-spacing: 0.04em; }
.cf-row { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; margin-bottom: 16px; }
.cf-full { margin-bottom: 16px; }
.contact-form label span { display: block; font-family: var(--mono); font-size: 10px; letter-spacing: 0.08em; text-transform: uppercase; color: var(--text-dim); margin-bottom: 6px; }
.contact-form input, .contact-form select, .contact-form textarea { width: 100%; background: rgba(255,255,255,0.05); border: 1px solid var(--line-dark); color: #fff; padding: 12px 14px; border-radius: 8px; font-family: var(--sans); font-size: 14px; outline: none; transition: border-color 0.2s, background 0.2s; }
.contact-form textarea { min-height: 120px; resize: vertical; }
.contact-form input:focus, .contact-form select:focus, .contact-form textarea:focus { border-color: var(--blue-bright); background: rgba(1,170,236,0.05); }
.contact-form .check { display: flex; gap: 10px; align-items: flex-start; font-size: 13px; color: var(--text-dim); margin: 16px 0 24px; }
.contact-form .check input { width: auto; margin-top: 2px; }
.contact-form .check a { color: var(--blue-bright); }
.contact-form .submit { background: var(--blue); color: #fff; border: none; padding: 14px 28px; border-radius: 8px; font-family: var(--sans); font-weight: 600; font-size: 14px; cursor: pointer; width: 100%; transition: background 0.2s; }
.contact-form .submit:hover { background: var(--blue-bright); }

/* ============ LEGAL pages ============ */
.legal { padding: 80px 0 100px; background: var(--paper); }
.legal-grid { display: grid; grid-template-columns: 220px 1fr; gap: 80px; align-items: start; }
.legal-toc { position: sticky; top: 96px; }
.legal-toc .lbl { font-family: var(--mono); font-size: 10px; letter-spacing: 0.1em; text-transform: uppercase; color: var(--text-dim); margin-bottom: 12px; }
.legal-toc ul { list-style: none; padding: 0; }
.legal-toc li { padding: 8px 0; font-size: 13px; }
.legal-toc a { color: var(--text-mid); text-decoration: none; }
.legal-toc a:hover { color: var(--blue); }
.legal-content h2 { font-size: 26px; font-weight: 600; letter-spacing: -0.02em; margin: 40px 0 16px; padding-bottom: 10px; border-bottom: 1px solid var(--line); }
.legal-content h2:first-child { margin-top: 0; }
.legal-content h3 { font-size: 18px; font-weight: 600; margin: 24px 0 12px; }
.legal-content p, .legal-content li { font-size: 15px; line-height: 1.65; color: var(--text-mid); margin-bottom: 12px; }
.legal-content ul, .legal-content ol { padding-left: 24px; margin: 12px 0 16px; }
.legal-content ul li, .legal-content ol li { padding: 4px 0; }
.legal-content strong { color: var(--text); font-weight: 600; }
.legal-content a { color: var(--blue); text-decoration: underline; }
.legal-content table { width: 100%; border-collapse: collapse; margin: 16px 0; font-size: 14px; }
.legal-content th, .legal-content td { padding: 12px; border: 1px solid var(--line); text-align: left; vertical-align: top; }
.legal-content th { background: var(--paper-2); font-weight: 600; font-family: var(--mono); font-size: 11px; letter-spacing: 0.06em; text-transform: uppercase; }

/* CTA strip (reusable) */
.cta-strip { padding: 80px 0; background: var(--ink); color: #fff; text-align: center; border-top: 1px solid var(--line-dark); border-bottom: 1px solid var(--line-dark); }
.cta-strip h2 { font-size: clamp(32px, 4vw, 48px); font-weight: 600; letter-spacing: -0.03em; line-height: 1.05; max-width: 22ch; margin: 0 auto 24px; }
.cta-strip h2 .accent { color: var(--blue-bright); }
.cta-strip p { color: #c8cdd9; font-size: 16px; max-width: 52ch; margin: 0 auto 28px; }
.cta-strip .btn { background: var(--blue); color: #fff; padding: 14px 28px; border-radius: 8px; text-decoration: none; font-weight: 600; font-size: 14px; display: inline-block; transition: background .2s; }
.cta-strip .btn:hover { background: var(--blue-bright); }

/* Big footer (overrides simple ftr from styles-v3) */
.ftr .ftr-top { display: grid; grid-template-columns: 1.4fr 2fr; gap: 64px; padding: 56px 0 48px; border-bottom: 1px solid var(--line-dark); align-items: start; }
.ftr .ftr-brand img { height: 24px; filter: brightness(0) invert(1); margin-bottom: 16px; opacity: 0.95; }
.ftr .ftr-brand p { color: var(--text-dim); font-size: 14px; line-height: 1.6; max-width: 32ch; }
.ftr .ftr-cols { display: grid; grid-template-columns: repeat(3, 1fr); gap: 32px; }
.ftr .ftr-cols h5 { font-family: var(--mono); font-size: 11px; letter-spacing: 0.1em; text-transform: uppercase; color: #fff; font-weight: 600; margin-bottom: 16px; }
.ftr .ftr-cols a { display: block; color: var(--text-dim); text-decoration: none; padding: 6px 0; font-size: 13px; transition: color .2s; }
.ftr .ftr-cols a:hover { color: #fff; }
.ftr .ftr-social { display: flex; flex-wrap: wrap; gap: 14px 28px; padding: 28px 0; border-top: 1px solid var(--line-dark); }
.ftr .ftr-social-item { display: inline-flex; align-items: center; gap: 10px; color: var(--text-dim); font-size: 13px; }
.ftr .ftr-social-item svg { color: var(--blue-bright); flex-shrink: 0; }
.ftr .ftr-bottom { display: flex; justify-content: space-between; align-items: center; padding: 24px 0; font-size: 12px; color: var(--text-dim); font-family: var(--mono); letter-spacing: 0.04em; flex-wrap: wrap; gap: 12px; border-top: 1px solid var(--line-dark); }
.ftr .ftr-mail { color: var(--text-dim); }
@media (max-width: 1000px) {
  .ftr .ftr-top { grid-template-columns: 1fr; gap: 40px; }
  .ftr .ftr-cols { grid-template-columns: repeat(2, 1fr); }
}

/* Responsive */
@media (max-width: 1000px) {
  .svc-index-grid { grid-template-columns: 1fr; }
  .svc-detail-grid, .case-body-grid, .legal-grid, .contact-page .layout, .team-history .layout, .process-full .row, .case-related .grid, .cases-grid { grid-template-columns: 1fr !important; gap: 32px; }
  .case-aside, .legal-toc, .svc-detail .sticky, .process-full .row .num-block { position: static; }
  .team-roster-grid { grid-template-columns: repeat(2, 1fr); }
  .case-stats .grid { grid-template-columns: repeat(2, 1fr); }
  .deliverables-grid { grid-template-columns: 1fr; }
  .case-tile { min-height: 0; }
}

@media (max-width: 640px) {
  .page-hero { padding: 60px 0 48px; }
  .sec { padding: 64px 0; }
  .sec .head { grid-template-columns: 1fr; gap: 20px; }
  .sec .head h2, .team-history h2, .process-full .row h3 { font-size: 32px; }
  .cf-row { grid-template-columns: 1fr; }
  .svc-row-head { grid-template-columns: 1fr auto; gap: 16px; padding: 24px 20px; }
  .svc-row-head .num { display: none; }
  .svc-row-inner { padding: 0 20px 32px; grid-template-columns: 1fr; gap: 32px; }
  .case-stats .item .v { font-size: 36px; }
  .team-roster-grid { grid-template-columns: repeat(2, 1fr); gap: 24px 16px; }
  .process-full .row { padding: 40px 0; }
  .process-full .row .num { font-size: 64px; }
  .case-hero .top { flex-direction: column; gap: 16px; }
  .cta-strip { padding: 60px 0; }
  .contact-page { padding: 60px 0 80px; }
}
