{% include '@Application/inc/central_header.html.twig' %}
{% include '@HoneybeeWeb/inc/_web_design_system.html.twig' %}
{# ─── HONEYCORE EDGE+ — Energy & Site Intelligence (business-first) ─────────── #}
<style>
/* ── Design Tokens ─────────────────────────────────────────────────────────── */
:root {
--n-cream: #F7F5F0;
--n-cream-2: #F0EDE5;
--n-cream-3: #E8E3D9;
--n-white: #FFFFFF;
--n-dark: #1A1D2E;
--n-dark-2: #252840;
--n-navy: #1E3A6E;
--n-amber: #C07D2A;
--n-amber-lt: #D4954A;
--n-amber-dim: rgba(192,125,42,.10);
--n-sage: #3D6B52;
--n-sage-dim: rgba(61,107,82,.09);
--n-slate: #3D4F72;
--n-slate-dim: rgba(61,79,114,.08);
--n-muted: #6B6E7F;
--n-muted-2: #9395A5;
--n-border: rgba(26,29,46,.07);
--n-border-md: rgba(26,29,46,.12);
--n-shadow-xs: 0 1px 4px rgba(26,29,46,.05);
--n-shadow-sm: 0 2px 12px rgba(26,29,46,.07);
--n-shadow-md: 0 8px 32px rgba(26,29,46,.09);
--n-shadow-lg: 0 20px 64px rgba(26,29,46,.10);
--n-radius-sm: 8px;
--n-radius: 12px;
--n-radius-lg: 20px;
--n-font: 'DM Sans', 'Poppins', system-ui, sans-serif;
}
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
body { background: var(--n-cream); font-family: var(--n-font); color: var(--n-dark); }
a { text-decoration: none; }
/* ── Utilities ─────────────────────────────────────────────────────────────── */
.n-wrap { max-width: 1160px; margin: 0 auto; padding: 0 28px; }
.n-wrap-sm { max-width: 820px; margin: 0 auto; padding: 0 28px; }
.n-sec { padding: 100px 0; }
.n-sec-sm { padding: 64px 0; }
.n-label {
display: inline-flex; align-items: center; gap: 8px;
font-size: 11px; font-weight: 700; letter-spacing: .18em; text-transform: uppercase;
color: var(--n-amber); margin-bottom: 16px;
}
.n-label::before { content:''; width: 18px; height: 1.5px; background: currentColor; border-radius: 2px; }
.n-h2 { font-family:'Montserrat',sans-serif; font-size: clamp(26px,3.5vw,42px); font-weight: 800; line-height: 1.12; letter-spacing: -.02em; }
.n-h3 { font-family:'Montserrat',sans-serif; font-size: 18px; font-weight: 700; line-height: 1.3; }
.n-body { font-size: 16px; line-height: 1.75; color: var(--n-muted); }
.n-body-sm { font-size: 14px; line-height: 1.7; color: var(--n-muted); }
.n-center { text-align: center; }
.n-center .n-label { justify-content: center; }
.n-center .n-body { max-width: 600px; margin: 0 auto; }
.n-mt-4 { margin-top: 16px; }
.n-mt-6 { margin-top: 24px; }
.n-mt-8 { margin-top: 32px; }
.n-mt-12 { margin-top: 48px; }
em.n-em { font-style: normal; color: var(--n-amber); }
/* ── Buttons ────────────────────────────────────────────────────────────────── */
.n-btn {
display: inline-flex; align-items: center; gap: 8px;
padding: 13px 26px; border-radius: var(--n-radius-sm);
font-size: 14px; font-weight: 600; letter-spacing: .01em;
border: none; cursor: pointer; text-decoration: none; transition: all .18s;
white-space: nowrap; font-family: var(--n-font);
}
.n-btn-primary { background: var(--n-dark); color: #fff; }
.n-btn-primary:hover { background: var(--n-dark-2); color: #fff; transform: translateY(-1px); box-shadow: var(--n-shadow-md); }
.n-btn-amber { background: var(--n-amber); color: #fff; }
.n-btn-amber:hover { background: var(--n-amber-lt); color: #fff; transform: translateY(-1px); box-shadow: 0 6px 20px rgba(192,125,42,.3); }
.n-btn-outline { background: transparent; border: 1.5px solid var(--n-border-md); color: var(--n-dark); }
.n-btn-outline:hover { border-color: var(--n-dark); color: var(--n-dark); transform: translateY(-1px); }
.n-btn-ghost-light { background: rgba(255,255,255,.12); border: 1.5px solid rgba(255,255,255,.2); color: #fff; }
.n-btn-ghost-light:hover { background: rgba(255,255,255,.2); color: #fff; }
.n-btn-light { background: #fff; color: var(--n-dark); }
.n-btn-light:hover { background: var(--n-cream-2); color: var(--n-dark); }
.n-btn i, .n-btn .fa { font-size: 15px; }
/* ── Navbar overrides ───────────────────────────────────────────────────────── */
.navbar {
background: rgba(247,245,240,.96) !important;
backdrop-filter: blur(16px) saturate(180%);
border-bottom: 1px solid var(--n-border) !important;
box-shadow: none !important;
}
.navbar .nav-link { color: var(--n-dark) !important; font-size: 13.5px; font-weight: 500; opacity: .8; transition: opacity .15s; }
.navbar .nav-link:hover,
.navbar .nav-link.active { opacity: 1; color: var(--n-dark) !important; }
.navbar .login-btn {
background: var(--n-dark) !important; color: #fff !important;
border: none !important; border-radius: var(--n-radius-sm) !important;
padding: 8px 20px !important; font-size: 13px !important; font-weight: 600 !important;
}
.navbar .login-btn:hover { background: var(--n-dark-2) !important; }
/* ── HERO ───────────────────────────────────────────────────────────────────── */
.n-hero {
background: var(--n-cream);
padding: 130px 0 84px;
position: relative; overflow: hidden;
}
.n-hero::before {
content: '';
position: absolute; top: 0; right: 0; width: 55%; height: 100%;
background: radial-gradient(ellipse 80% 70% at 80% 30%, rgba(192,125,42,.08) 0%, transparent 65%),
radial-gradient(ellipse 50% 60% at 95% 80%, rgba(61,107,82,.06) 0%, transparent 60%);
pointer-events: none;
}
.n-hero::after {
content: '';
position: absolute; bottom: 0; left: 0; right: 0; height: 1px;
background: linear-gradient(90deg, transparent, var(--n-border-md), transparent);
}
.n-hero-inner { position: relative; max-width: 760px; }
.n-hero-tag {
display: inline-flex; align-items: center; gap: 8px; white-space: nowrap;
background: var(--n-amber-dim); border: 1px solid rgba(192,125,42,.2);
color: var(--n-amber); font-size: 11px; font-weight: 700;
letter-spacing: .16em; text-transform: uppercase;
padding: 6px 14px 6px 10px; border-radius: 4px; margin-bottom: 26px;
}
.n-hero-tag span:first-child { width: 6px; height: 6px; background: var(--n-amber); border-radius: 50%; display: block; flex-shrink: 0; }
.n-hero-h1 {
font-family: 'Montserrat', sans-serif;
font-size: clamp(36px, 5vw, 60px);
font-weight: 900; line-height: 1.06; letter-spacing: -.025em;
color: var(--n-dark); margin-bottom: 24px;
}
.n-hero-h1 em { font-style: normal; color: var(--n-amber); }
.n-hero-desc {
font-size: 17px; line-height: 1.75; color: var(--n-muted);
max-width: 620px; margin-bottom: 32px;
}
.n-hero-actions { display: flex; gap: 12px; flex-wrap: wrap; }
/* ── Pain / outcome split ───────────────────────────────────────────────────── */
.n-split { display: grid; grid-template-columns: 1fr 1fr; gap: 20px; margin-top: 48px; }
.n-split-card {
background: var(--n-white); border: 1px solid var(--n-border);
border-radius: var(--n-radius); padding: 36px;
}
.n-split-card.pain { border-left: 3px solid var(--n-amber); }
.n-split-card.outcome { border-left: 3px solid var(--n-sage); }
.n-split-card .n-split-tag {
font-size: 11px; font-weight: 700; letter-spacing: .12em; text-transform: uppercase;
font-family: monospace; margin-bottom: 12px; display: block;
}
.n-split-card.pain .n-split-tag { color: var(--n-amber); }
.n-split-card.outcome .n-split-tag { color: var(--n-sage); }
.n-split-card h3 { font-family:'Montserrat',sans-serif; font-size: 19px; font-weight: 800; color: var(--n-dark); margin-bottom: 12px; }
.n-split-card p { font-size: 15px; color: var(--n-muted); line-height: 1.75; }
/* ── Design path band ───────────────────────────────────────────────────────── */
.n-band { background: var(--n-white); border-top: 1px solid var(--n-border); border-bottom: 1px solid var(--n-border); }
.n-design-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; margin-top: 32px; }
.n-design-chip {
font-size: 13px; color: var(--n-dark); padding: 12px 16px;
background: var(--n-cream); border: 1px solid var(--n-border-md);
border-radius: var(--n-radius-sm); display: flex; align-items: flex-start; gap: 10px;
}
.n-design-chip::before { content: '→'; color: var(--n-amber); font-family: monospace; flex-shrink: 0; margin-top: 1px; }
/* ── Two-list (does / connects) ─────────────────────────────────────────────── */
.n-twolist { display: grid; grid-template-columns: 1fr 1fr; gap: 20px; margin-top: 48px; }
.n-list-card { background: var(--n-white); border: 1px solid var(--n-border); border-radius: var(--n-radius); padding: 32px; }
.n-list-card h3 { font-family:'Montserrat',sans-serif; font-size: 17px; font-weight: 800; color: var(--n-dark); margin-bottom: 6px; }
.n-list-card .n-list-sub { font-size: 13px; color: var(--n-muted); margin-bottom: 20px; }
.n-chips { list-style: none; display: flex; flex-wrap: wrap; gap: 6px; }
.n-chips li {
font-size: 12px; color: var(--n-muted); padding: 5px 11px;
background: var(--n-cream); border: 1px solid var(--n-border-md);
border-radius: 4px; font-family: monospace;
}
/* ── Capabilities grid ──────────────────────────────────────────────────────── */
.n-cap-grid {
display: grid; grid-template-columns: repeat(3, 1fr);
gap: 1px; background: var(--n-border-md);
border: 1px solid var(--n-border-md); border-radius: var(--n-radius); overflow: hidden;
margin-top: 48px;
}
.n-cap-card { background: var(--n-white); padding: 22px 24px; transition: background .2s; }
.n-cap-card:hover { background: var(--n-cream); }
.n-cap-card h4 { font-family:'Montserrat',sans-serif; font-size: 14px; font-weight: 700; color: var(--n-dark); display: flex; align-items: center; gap: 9px; }
.n-cap-card h4::before { content: ''; width: 7px; height: 7px; background: var(--n-sage); border-radius: 50%; flex-shrink: 0; }
/* ── Integration (technical, later) ─────────────────────────────────────────── */
.n-integ { background: var(--n-dark); position: relative; overflow: hidden; }
.n-integ::before {
content: ''; position: absolute; top: -40%; right: -5%; width: 60%; height: 150%;
background: radial-gradient(ellipse 70% 60% at 70% 50%, rgba(192,125,42,.12) 0%, transparent 65%);
pointer-events: none;
}
.n-integ .n-label { color: var(--n-amber); }
.n-integ .n-label::before { background: var(--n-amber); }
.n-integ-h2 { font-family:'Montserrat',sans-serif; font-size: clamp(26px,3.5vw,40px); font-weight: 900; color: #fff; line-height: 1.12; letter-spacing: -.02em; }
.n-integ-lead { font-size: 15px; line-height: 1.75; color: rgba(255,255,255,.6); max-width: 560px; margin-top: 14px; }
.n-integ-chips { list-style: none; display: flex; flex-wrap: wrap; gap: 8px; margin-top: 36px; }
.n-integ-chips li {
font-size: 12.5px; color: rgba(255,255,255,.78); padding: 7px 14px;
background: rgba(255,255,255,.05); border: 1px solid rgba(255,255,255,.12);
border-radius: 5px; font-family: monospace;
}
/* ── Compliance ─────────────────────────────────────────────────────────────── */
.n-comply-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 20px; margin-top: 48px; }
.n-comply-card { background: var(--n-white); border: 1px solid var(--n-border); border-radius: var(--n-radius); padding: 28px; text-align: center; }
.n-comply-card .n-comply-icon {
width: 44px; height: 44px; border-radius: 10px; margin: 0 auto 16px;
background: var(--n-sage-dim); border: 1px solid rgba(61,107,82,.2);
display: flex; align-items: center; justify-content: center; color: var(--n-sage); font-size: 18px;
}
.n-comply-card h4 { font-family:'Montserrat',sans-serif; font-size: 15px; font-weight: 700; color: var(--n-dark); margin-bottom: 8px; }
.n-comply-card p { font-size: 13px; color: var(--n-muted); line-height: 1.65; }
.n-comply-note { text-align: center; font-size: 12.5px; color: var(--n-muted-2); margin-top: 28px; max-width: 640px; margin-left: auto; margin-right: auto; line-height: 1.6; }
/* ── Final CTA ──────────────────────────────────────────────────────────────── */
.n-cta-final { background: var(--n-cream-2); padding: 110px 0; text-align: center; border-top: 1px solid var(--n-border); }
.n-cta-final h2 { font-family:'Montserrat',sans-serif; font-size: clamp(28px,3.5vw,44px); font-weight: 900; color: var(--n-dark); margin-bottom: 16px; }
.n-cta-final h2 em { font-style: normal; color: var(--n-amber); }
.n-cta-final p { max-width: 56ch; margin: 0 auto 32px; color: var(--n-muted); font-size: 16px; line-height: 1.7; }
.n-cta-actions { display: flex; gap: 12px; justify-content: center; flex-wrap: wrap; }
.n-cta-link { display: inline-block; margin-top: 22px; font-size: 13.5px; font-weight: 600; color: var(--n-amber); }
.n-cta-link:hover { color: var(--n-amber-lt); }
.n-price-note { font-size: 12.5px; color: var(--n-muted-2); margin-top: 24px; font-family: monospace; }
/* ── Responsive ─────────────────────────────────────────────────────────────── */
@media (max-width: 1040px) {
.n-split { grid-template-columns: 1fr; }
.n-twolist { grid-template-columns: 1fr; }
.n-design-grid{ grid-template-columns: 1fr; }
.n-cap-grid { grid-template-columns: 1fr 1fr; }
.n-comply-grid{ grid-template-columns: 1fr; }
}
@media (max-width: 640px) {
.n-cap-grid { grid-template-columns: 1fr; }
}
</style>
{# ══ HERO ══════════════════════════════════════════════════════════════════════ #}
<section class="n-hero">
<div class="n-wrap">
<div class="n-hero-inner">
<div class="n-hero-tag">
<span></span>
<span>HoneyCore Edge EMS · Energy & Site Intelligence</span>
</div>
<h1 class="n-hero-h1">Connect site energy data with <em>business decisions.</em></h1>
<p class="n-hero-desc">
HoneyCore Edge EMS links IoT, solar PV, grid, generators, batteries, meters, sensors, utilities,
cold-chain, and industrial equipment with O&M, billing, finance, alarms, reporting, and
sustainability evidence.
</p>
<div class="n-hero-actions">
<a href="{{ url('honeybee_contact') }}" class="n-btn n-btn-amber">
Request HoneyCore Edge+ Site Assessment <i class="fa-solid fa-arrow-right"></i>
</a>
<a href="{{ url('honeybee_edge_projects') }}" class="n-btn n-btn-outline">
HoneyCore Edge+ Projects
</a>
</div>
</div>
</div>
</section>
{# ══ 1+2. BUSINESS PAIN → BUSINESS OUTCOME ════════════════════════════════════ #}
<section class="n-sec">
<div class="n-wrap">
<div class="n-center">
<span class="n-label">From scattered dashboards to decisions</span>
<h2 class="n-h2">Site data is everywhere.<br><em class="n-em">The decisions are not.</em></h2>
</div>
<div class="n-split">
<div class="n-split-card pain">
<span class="n-split-tag">The business pain</span>
<h3>Separate dashboards, manual reporting</h3>
<p>
Energy and infrastructure sites often have separate dashboards for solar, generators, meters,
sensors, alarms, O&M, billing, and finance. This creates delays, manual reporting, and weak
operational visibility.
</p>
</div>
<div class="n-split-card outcome">
<span class="n-split-tag">The business outcome</span>
<h3>Site data becomes business decisions</h3>
<p>
HoneyCore Edge EMS turns site data into business decisions by connecting infrastructure data with
O&M, billing, finance, reporting, and management dashboards.
</p>
</div>
</div>
</div>
</section>
{# ══ 3. DESIGN PATH ═══════════════════════════════════════════════════════════ #}
<section class="n-sec n-band">
<div class="n-wrap">
<div class="n-center">
<span class="n-label">HoneyCore Edge+ design path</span>
<h2 class="n-h2">Structure the project <em class="n-em">before deployment.</em></h2>
<p class="n-body n-mt-6">
Before deployment, HoneyBee can help structure the HoneyCore Edge+ project design — so the site is
scoped, costed, and ready to commission.
</p>
</div>
<div class="n-design-grid">
<div class="n-design-chip">Site requirements</div>
<div class="n-design-chip">Data point mapping</div>
<div class="n-design-chip">Sensor and meter schedules</div>
<div class="n-design-chip">Gateway planning</div>
<div class="n-design-chip">Protocol mapping</div>
<div class="n-design-chip">Edge controller sizing</div>
<div class="n-design-chip">BoQ and quote</div>
<div class="n-design-chip">Commissioning checklist and O&M handover</div>
</div>
<div class="n-center n-mt-12">
<a href="{{ url('honeybee_contact') }}" class="n-btn n-btn-primary">
Request HoneyCore Edge+ Design Assessment <i class="fa-solid fa-arrow-right"></i>
</a>
</div>
</div>
</section>
{# ══ 4. WHAT IT DOES / WHAT IT CONNECTS ═══════════════════════════════════════ #}
<section class="n-sec">
<div class="n-wrap">
<div class="n-center">
<span class="n-label">What HoneyCore Edge EMS does</span>
<h2 class="n-h2">One layer between <em class="n-em">site and business.</em></h2>
</div>
<div class="n-twolist">
<div class="n-list-card">
<h3>What it does</h3>
<p class="n-list-sub">Edge intelligence that processes, translates, and aggregates site data.</p>
<ul class="n-chips">
<li>Edge processing</li>
<li>Protocol translation</li>
<li>Local control</li>
<li>Data aggregation</li>
<li>EMS</li>
<li>SCADA</li>
<li>Historian</li>
<li>Local dashboard</li>
<li>Cloud fleet sync</li>
<li>Digital twin</li>
</ul>
</div>
<div class="n-list-card">
<h3>What it connects</h3>
<p class="n-list-sub">Assets and sites across energy, utilities, cold-chain, and industry.</p>
<ul class="n-chips">
<li>Solar PV</li>
<li>Hybrid energy</li>
<li>Batteries</li>
<li>Generators</li>
<li>Grid</li>
<li>Meters</li>
<li>Sensors</li>
<li>Pumps</li>
<li>Boilers</li>
<li>Compressors</li>
<li>Cold-chain</li>
<li>Freezers</li>
<li>Agri-PV</li>
<li>Industrial utilities</li>
<li>Hotels</li>
<li>Malls</li>
<li>Industrial parks</li>
</ul>
</div>
</div>
</div>
</section>
{# ══ 5. KEY CAPABILITIES (dashboard & O&M) ════════════════════════════════════ #}
<section class="n-sec n-band">
<div class="n-wrap">
<div class="n-center">
<span class="n-label">Dashboard & O&M workflow</span>
<h2 class="n-h2">Key capabilities</h2>
<p class="n-body n-mt-6">
Offline-first operation with local and cloud dashboards, decision-grade reporting, and an
O&M workflow that closes the loop from alarm to action.
</p>
</div>
<div class="n-cap-grid">
<div class="n-cap-card"><h4>Offline-first</h4></div>
<div class="n-cap-card"><h4>Local & cloud dashboards</h4></div>
<div class="n-cap-card"><h4>Constraint-aware dispatch</h4></div>
<div class="n-cap-card"><h4>PV curtailment</h4></div>
<div class="n-cap-card"><h4>Genset minimum-load protection</h4></div>
<div class="n-cap-card"><h4>IEC 61724 KPI support</h4></div>
<div class="n-cap-card"><h4>Curtailment / revenue-loss reporting</h4></div>
<div class="n-cap-card"><h4>Meter reconciliation</h4></div>
<div class="n-cap-card"><h4>Alarm lifecycle</h4></div>
<div class="n-cap-card"><h4>Decision logs</h4></div>
<div class="n-cap-card"><h4>Anomaly detection</h4></div>
<div class="n-cap-card"><h4>Root-cause analysis</h4></div>
<div class="n-cap-card"><h4>Predictive maintenance</h4></div>
<div class="n-cap-card"><h4>Solar forecast</h4></div>
<div class="n-cap-card"><h4>Digital twin sync</h4></div>
</div>
</div>
</section>
{# ══ 6. INTEGRATION (technical — placed later) ════════════════════════════════ #}
<section class="n-sec n-integ">
<div class="n-wrap">
<span class="n-label">Integration & protocols</span>
<h2 class="n-integ-h2">Speaks the protocols your<br>site already runs on.</h2>
<p class="n-integ-lead">
HoneyCore Edge EMS connects to industrial and energy systems through standard field and IT protocols,
with secure transport and role-based access — so business teams get clean data without ripping out
existing equipment.
</p>
<ul class="n-integ-chips">
<li>Modbus TCP/RTU</li>
<li>IEC 60870-5-104</li>
<li>Siemens S7</li>
<li>SunSpec</li>
<li>LoRaWAN</li>
<li>MQTT</li>
<li>REST</li>
<li>Webhooks</li>
<li>OpenAPI</li>
<li>TLS</li>
<li>RBAC</li>
<li>MFA</li>
<li>Local retention</li>
</ul>
</div>
</section>
{# ══ 7. COMPLIANCE & SECURITY ═════════════════════════════════════════════════ #}
<section class="n-sec">
<div class="n-wrap">
<div class="n-center">
<span class="n-label">Compliance & governance support</span>
<h2 class="n-h2">Built to support your <em class="n-em">evidence and governance.</em></h2>
</div>
<div class="n-comply-grid">
<div class="n-comply-card">
<div class="n-comply-icon"><i class="fa-solid fa-solar-panel"></i></div>
<h4>IEC 61724 KPI support</h4>
<p>Performance KPIs aligned to IEC 61724 reporting, where applicable to your site.</p>
</div>
<div class="n-comply-card">
<div class="n-comply-icon"><i class="fa-solid fa-shield-halved"></i></div>
<h4>NIS2-aware governance support</h4>
<p>Governance support designed to be NIS2-aware, where applicable to your operations.</p>
</div>
<div class="n-comply-card">
<div class="n-comply-icon"><i class="fa-solid fa-lock"></i></div>
<h4>GDPR-aligned data handling</h4>
<p>Data handling aligned to GDPR principles across local and cloud deployments.</p>
</div>
</div>
<p class="n-comply-note">
IEC 61724 KPI support where applicable · NIS2-aware governance support where applicable ·
GDPR-aligned data handling. These describe support and roadmap capabilities and are not certifications.
</p>
</div>
</section>
{# ══ 8. FINAL CTA ═════════════════════════════════════════════════════════════ #}
<section class="n-cta-final">
<div class="n-wrap-sm">
<h2>Turn your site into a <em>business decision engine.</em></h2>
<p>
Start with a site assessment or a design assessment — and connect your energy and infrastructure data
to O&M, billing, finance, and reporting.
</p>
<div class="n-cta-actions">
<a href="{{ url('honeybee_contact') }}" class="n-btn n-btn-amber">
Request HoneyCore Edge+ Site Assessment <i class="fa-solid fa-arrow-right"></i>
</a>
<a href="{{ url('honeybee_contact') }}" class="n-btn n-btn-outline">
Request HoneyCore Edge+ Design Assessment
</a>
<a href="{{ url('honeybee_contact') }}" class="n-btn n-btn-outline">
Download HoneyCore Edge EMS Datasheet
</a>
</div>
<div>
<a href="{{ url('honeybee_edge_projects') }}" class="n-cta-link">
Explore HoneyCore Edge+ Projects <i class="fa-solid fa-arrow-right"></i>
</a>
</div>
<p class="n-price-note">HoneyCore Edge+ from €2,999 / site · final pricing depends on site scope.</p>
</div>
</section>
{% include '@HoneybeeWeb/footer/central_footer.html.twig' %}