/* ============================================================
   3DEO Lidar — sub-page components (loaded alongside site.css)
   ============================================================ */

/* ---- breadcrumb ---- */
.breadcrumb{font-family:var(--font-mono);font-size:.72rem;letter-spacing:.1em;text-transform:uppercase;color:var(--muted);margin-bottom:1.3rem;display:flex;gap:.55em;align-items:center;flex-wrap:wrap;}
.breadcrumb a{color:var(--muted);}
.breadcrumb a:hover{color:var(--accent);}
.breadcrumb .sep{opacity:.45;}

/* ---- page hero ---- */
.page-hero{padding-block:clamp(44px,6.5vw,86px) clamp(36px,5vw,60px);border-bottom:1px solid var(--line);position:relative;overflow:hidden;}
.page-hero .eyebrow{margin-bottom:1.1rem;}
.page-hero h1{font-size:clamp(2.3rem,5vw,3.9rem);margin-bottom:1.2rem;max-width:20ch;}
.page-hero .lead{max-width:62ch;}
.page-hero .wrap-btns{margin-top:1.8rem;}
.page-hero.dark{background:var(--navy-dark);color:var(--on-dark);border-bottom:0;}
.page-hero.dark h1{color:#fff;}
.page-hero.dark .lead{color:rgba(234,241,250,.82);}
.page-hero.dark .eyebrow{color:var(--accent);}
.page-hero.dark .breadcrumb,.page-hero.dark .breadcrumb a{color:rgba(234,241,250,.6);}
.page-hero .dotfield{opacity:.45;}
.page-hero-grid{display:grid;grid-template-columns:1.1fr .9fr;gap:clamp(2rem,5vw,4.5rem);align-items:center;position:relative;z-index:1;}
@media(max-width:880px){.page-hero-grid{grid-template-columns:1fr;}}
.hero-media{border-radius:var(--radius-lg);overflow:hidden;border:1px solid var(--line-strong);background:var(--navy-dark);aspect-ratio:4/3;box-shadow:var(--shadow-lg);}
.hero-media img{width:100%;height:100%;object-fit:cover;}

/* ---- prose ---- */
.prose{max-width:68ch;}
.prose.wide{max-width:none;}
.prose p{font-size:1.06rem;margin-bottom:1.2em;}
.prose h2{margin:1.6em 0 .5em;font-size:clamp(1.5rem,2.6vw,2.1rem);}
.prose h3{margin:1.5em 0 .4em;}
.prose>:first-child{margin-top:0;}
.prose ul{margin:0 0 1.4em;padding:0;list-style:none;display:grid;gap:.75rem;}
.prose ul li{position:relative;padding-left:1.7rem;color:var(--ink-2);line-height:1.55;}
.prose ul li::before{content:"→";position:absolute;left:0;top:0;color:var(--accent);font-family:var(--font-mono);font-weight:600;}
.prose strong{color:var(--ink);}

/* ---- section heading ---- */
.shead{max-width:60ch;margin-bottom:clamp(2rem,3.4vw,3rem);}
.shead .eyebrow{margin-bottom:1rem;}
.shead h2{margin-bottom:.9rem;}

/* ---- feature card (glyph) ---- */
.feature{padding:clamp(1.4rem,2.2vw,1.9rem);border:1px solid var(--line);border-radius:var(--radius-lg);background:var(--bg);transition:border-color .2s,transform .2s,box-shadow .2s;}
.feature:hover{border-color:var(--line-strong);transform:translateY(-3px);box-shadow:var(--shadow);}
.feature .fglyph{width:38px;height:38px;color:var(--accent);margin-bottom:1.1rem;}
.feature .fglyph svg{width:100%;height:100%;}
.feature h4{margin-bottom:.5rem;}
.feature p{font-size:.96rem;color:var(--muted);margin:0;line-height:1.55;}
.feature .fnum{font-family:var(--font-mono);font-size:.74rem;color:var(--accent);letter-spacing:.1em;display:block;margin-bottom:.9rem;}

/* ---- split (image + text) ---- */
.split{display:grid;grid-template-columns:1fr 1fr;gap:clamp(2rem,4.5vw,4.5rem);align-items:center;}
.split + .split{margin-top:clamp(2.5rem,5vw,5rem);}
.split-media{border-radius:var(--radius-lg);overflow:hidden;border:1px solid var(--line);background:var(--navy-dark);aspect-ratio:4/3;}
.split-media img{width:100%;height:100%;object-fit:cover;}
.split-media.tall{aspect-ratio:3/4;}
.split .eyebrow{margin-bottom:1rem;}
.split h2,.split h3{margin-bottom:.9rem;}
@media(max-width:820px){.split{grid-template-columns:1fr;gap:1.8rem;}.split.rev .split-media{order:-1;}}

/* ---- callout ---- */
.callout{border-left:3px solid var(--accent);background:var(--bg-alt);padding:1.4rem 1.6rem;border-radius:0 var(--radius) var(--radius) 0;margin:1.6em 0;}
.callout p{margin:0;font-size:1.05rem;color:var(--ink);}
.callout .ck{font-family:var(--font-mono);font-size:.7rem;letter-spacing:.14em;text-transform:uppercase;color:var(--accent);display:block;margin-bottom:.5rem;}

/* ---- big spec / data callouts ---- */
.kpi-row{display:grid;grid-template-columns:repeat(4,1fr);gap:clamp(1rem,2vw,1.6rem);}
@media(max-width:760px){.kpi-row{grid-template-columns:1fr 1fr;}}
.kpi{border-top:2px solid var(--accent);padding-top:1rem;}
.kpi .num{font-family:var(--font-display);font-weight:800;font-size:clamp(1.8rem,3vw,2.6rem);line-height:1;color:var(--ink);letter-spacing:-.02em;}
.kpi .lab{font-size:.86rem;color:var(--muted);margin-top:.4rem;}

/* ---- systems compare table ---- */
.compare-table{width:100%;border-collapse:collapse;font-size:.95rem;}
.compare-table th,.compare-table td{text-align:left;padding:1rem 1.1rem;border-bottom:1px solid var(--line);vertical-align:top;}
.compare-table thead th{font-family:var(--font-display);font-size:1.15rem;font-weight:800;color:var(--ink);border-bottom:2px solid var(--line-strong);}
.compare-table thead th .csub{display:block;font-family:var(--font-mono);font-size:.7rem;font-weight:500;letter-spacing:.1em;color:var(--accent);text-transform:uppercase;margin-top:.3rem;}
.compare-table td:first-child,.compare-table th:first-child{font-family:var(--font-mono);font-size:.74rem;letter-spacing:.06em;text-transform:uppercase;color:var(--muted);width:200px;}
.compare-table tbody td{font-weight:600;color:var(--ink);}
.compare-table tbody tr:hover{background:var(--bg-alt);}
.table-scroll{overflow-x:auto;border:1px solid var(--line);border-radius:var(--radius-lg);}
@media(max-width:680px){.compare-table td:first-child,.compare-table th:first-child{width:130px;}}

/* ---- cta band ---- */
.cta-band{background:var(--navy-dark);color:#fff;border-radius:var(--radius-lg);padding:clamp(2rem,4vw,3.4rem);display:flex;justify-content:space-between;align-items:center;gap:2rem;flex-wrap:wrap;position:relative;overflow:hidden;}
.cta-band-copy{position:relative;z-index:1;}
.cta-band h2{color:#fff;max-width:22ch;font-size:clamp(1.6rem,3vw,2.4rem);}
.cta-band p{color:rgba(234,241,250,.8);margin:.7rem 0 0;max-width:48ch;}
.cta-band .wrap-btns{position:relative;z-index:1;}
.cta-band .dotfield{opacity:.4;}

/* ---- related links ---- */
.rel-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(14px,1.6vw,20px);}
@media(max-width:760px){.rel-grid{grid-template-columns:1fr;}}
.rel-card{display:flex;flex-direction:column;gap:.4rem;padding:1.5rem 1.6rem;border:1px solid var(--line);border-radius:var(--radius-lg);background:var(--bg);transition:border-color .2s,transform .2s;}
.rel-card:hover{border-color:var(--accent);transform:translateY(-2px);}
.rel-card .rk{font-family:var(--font-mono);font-size:.7rem;letter-spacing:.1em;text-transform:uppercase;color:var(--accent);}
.rel-card h4{margin:.1rem 0 .2rem;}
.rel-card p{font-size:.9rem;color:var(--muted);margin:0 0 .4rem;}
.rel-card .link-arrow{margin-top:auto;}

/* ---- doc / download list ---- */
.doc-list{display:grid;gap:0;border-top:1px solid var(--line);}
.doc-row{display:flex;align-items:center;gap:1.2rem;padding:1.3rem .4rem;border-bottom:1px solid var(--line);transition:background .15s;}
.doc-row:hover{background:var(--bg-alt);}
.doc-ic{width:40px;height:40px;flex-shrink:0;border:1px solid var(--line-strong);border-radius:var(--radius);display:flex;align-items:center;justify-content:center;font-family:var(--font-mono);font-size:.62rem;letter-spacing:.05em;color:var(--accent);}
.doc-row .doc-main{flex:1;min-width:0;}
.doc-row h4{margin:0 0 .2rem;font-size:1.05rem;}
.doc-row .dmeta{font-size:.85rem;color:var(--muted);}
.doc-row .link-arrow{flex-shrink:0;}

/* ---- forms ---- */
.form-card{background:var(--bg);border:1px solid var(--line);border-radius:var(--radius-lg);padding:clamp(1.6rem,3vw,2.6rem);box-shadow:var(--shadow);}
.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:1.1rem 1.2rem;}
.form-grid .full{grid-column:1/-1;}
@media(max-width:600px){.form-grid{grid-template-columns:1fr;}}
.form-field label{display:block;font-family:var(--font-mono);font-size:.7rem;letter-spacing:.1em;text-transform:uppercase;color:var(--muted);margin-bottom:.4rem;}
.form-field input,.form-field select,.form-field textarea{width:100%;padding:.8rem .9rem;border:1px solid var(--line-strong);border-radius:var(--radius);font-family:var(--font-body);font-size:1rem;color:var(--ink);background:var(--bg);transition:border-color .15s,box-shadow .15s;}
.form-field textarea{min-height:120px;resize:vertical;}
.form-field input:focus,.form-field select:focus,.form-field textarea:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px color-mix(in srgb,var(--accent) 18%,transparent);}
.form-note{font-size:.84rem;color:var(--muted);margin-top:1rem;}
.form-success{display:none;padding:1.2rem 1.4rem;border-radius:var(--radius);background:color-mix(in srgb,var(--accent) 10%,var(--bg));border:1px solid color-mix(in srgb,var(--accent) 35%,var(--line));color:var(--ink);font-weight:600;}
.form-success.show{display:block;}

/* ---- contact aside ---- */
.contact-grid{display:grid;grid-template-columns:1.4fr 1fr;gap:clamp(2rem,4vw,3.5rem);align-items:start;}
@media(max-width:820px){.contact-grid{grid-template-columns:1fr;}}
.info-block{margin-bottom:1.8rem;}
.info-block .ik{font-family:var(--font-mono);font-size:.7rem;letter-spacing:.12em;text-transform:uppercase;color:var(--muted);margin-bottom:.4rem;}
.info-block a{color:var(--accent);}

/* ---- point-cloud gallery ---- */
.pc-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(16px,2vw,24px);}
@media(max-width:900px){.pc-grid{grid-template-columns:1fr 1fr;}}
@media(max-width:560px){.pc-grid{grid-template-columns:1fr;}}
.pc-tile{position:relative;border-radius:var(--radius-lg);overflow:hidden;border:1px solid var(--line);background:var(--navy-dark);cursor:pointer;}
.pc-tile .pcimg{aspect-ratio:4/3;background-size:cover;background-position:center;}
.pc-tile .pc-over{position:absolute;inset:0;display:flex;flex-direction:column;justify-content:flex-end;padding:1.2rem;background:linear-gradient(180deg,rgba(10,21,37,0) 40%,rgba(8,17,30,.9));}
.pc-tile .pc-name{color:#fff;font-family:var(--font-display);font-weight:700;font-size:1.1rem;}
.pc-tile .pc-tag{font-family:var(--font-mono);font-size:.68rem;letter-spacing:.1em;color:rgba(234,241,250,.7);text-transform:uppercase;}
.pc-tile .pc-lockbadge{position:absolute;top:12px;right:12px;font-family:var(--font-mono);font-size:.62rem;letter-spacing:.12em;background:rgba(8,16,30,.6);backdrop-filter:blur(4px);color:#fff;padding:5px 9px;border-radius:100px;text-transform:uppercase;}
[data-unlocked="true"] .pc-lockbadge{background:color-mix(in srgb,var(--accent) 80%,#000);}

/* unlock state banner */
.unlock-banner{display:flex;align-items:center;gap:1rem;flex-wrap:wrap;padding:1.1rem 1.4rem;border-radius:var(--radius-lg);border:1px dashed var(--line-strong);background:var(--bg-alt);margin-bottom:2rem;font-size:.95rem;}
.unlock-banner .ub-ic{font-size:1.1rem;}
[data-unlocked="true"] .unlock-banner.locked-only{display:none;}
.unlock-banner.unlocked-only{display:none;}
[data-unlocked="true"] .unlock-banner.unlocked-only{display:flex;background:color-mix(in srgb,var(--accent) 8%,var(--bg-alt));border-color:color-mix(in srgb,var(--accent) 30%,var(--line-strong));}

/* generic media frame caption */
.figcap{font-family:var(--font-mono);font-size:.72rem;color:var(--muted);margin-top:.7rem;letter-spacing:.02em;}

/* tag pills */
.pill-row{display:flex;flex-wrap:wrap;gap:.5rem;margin-top:1.2rem;}
