
:root{
    --bg:#fcfbfb;
    --surface:#ffffff;
    --surface-soft:#fff7f8;
    --text:#141414;
    --muted:#6d6d72;
    --border:rgba(122,17,32,.12);
    --accent:#781428;
    --accent-2:#9a2535;
    --shadow:0 24px 70px rgba(20,20,20,.08);
    --radius-xl:34px;
    --radius-lg:26px;
    --radius-md:20px;
    --container:1240px;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
    margin:0;
    font-family: Inter, ui-sans-serif, system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
    color:var(--text);
    background:
      radial-gradient(circle at top, rgba(122,17,32,.08), transparent 28%),
      linear-gradient(to bottom,#fffefe,rgba(255,255,255,.97),#fcfbfb);
    min-height:100vh;
}
body::before{
    content:"";
    position:fixed;
    inset:0;
    pointer-events:none;
    background-image:radial-gradient(rgba(122,17,32,.12) .8px, transparent .8px);
    background-size:30px 30px;
    opacity:.10;
    mask-image:linear-gradient(to bottom, rgba(0,0,0,.4), transparent 70%);
}
a{color:inherit;text-decoration:none}
img{display:block;max-width:100%}
.container{width:min(var(--container), calc(100% - 48px)); margin:0 auto}
.page-shell{padding-top:86px}
.section{padding:96px 0}
.section-tight{padding:60px 0}
.section-title{
    font-family: Georgia, "Times New Roman", serif;
    font-size: clamp(2.2rem, 5vw, 4rem);
    line-height:1.02;
    letter-spacing:-.03em;
    margin:0;
}
.section-kicker,
.eyebrow{
    margin:0 0 18px;
    color:rgba(122,17,32,.74);
    font-size:11px;
    letter-spacing:.30em;
    text-transform:uppercase;
}
.lead{
    font-size:clamp(1.05rem, 1.5vw, 1.22rem);
    line-height:1.85;
    color:var(--muted);
}
.card{
    background:linear-gradient(180deg, #fff, rgba(255,248,249,.96));
    border:1px solid rgba(0,0,0,.05);
    border-radius:var(--radius-lg);
    box-shadow:0 18px 48px rgba(20,20,20,.05);
}
.site-header{
    position:fixed; inset:0 0 auto 0; z-index:40;
    backdrop-filter: blur(18px);
    background:rgba(255,255,255,.72);
    border-bottom:1px solid rgba(0,0,0,.05);
}
.header-inner{
    display:flex; align-items:center; justify-content:space-between;
    min-height:86px; gap:18px;
}
.brand{display:flex;align-items:center;gap:14px}
.brand-logo{height:40px;width:auto;color:var(--accent)}
.brand-texts{display:grid;gap:2px}
.brand-kicker{font-size:11px; letter-spacing:.30em; text-transform:uppercase; color:rgba(122,17,32,.74)}
.brand-name{font-size:14px; font-weight:600; letter-spacing:.08em}
.desktop-nav{display:flex; gap:26px; align-items:center}
.desktop-nav a{
    color:#434349;
    font-size:14px;
    transition:.25s ease;
}
.desktop-nav a:hover,.desktop-nav a.is-active{color:var(--accent)}
.menu-toggle,.menu-close,.btn,.btn-secondary,button{
    font:inherit
}
.menu-toggle{
    display:none; border:1px solid var(--border); background:#fff;
    color:var(--accent); border-radius:999px; padding:11px 18px; cursor:pointer;
    box-shadow:0 0 24px rgba(122,17,32,.08);
}
.mobile-menu{
    position:fixed; inset:0; z-index:70;
    background:linear-gradient(135deg,#7a1120,#4f0b15);
    color:#fff;
}
.mobile-menu-panel{
    min-height:100%; padding:32px;
    display:flex; flex-direction:column; justify-content:space-between;
}
.menu-close{
    align-self:flex-end; background:none; border:0; color:#fff;
    text-transform:uppercase; letter-spacing:.28em; cursor:pointer;
}
.mobile-nav{display:grid; gap:24px}
.mobile-nav a{font-family:Georgia,serif; font-size:clamp(2.2rem,8vw,4.4rem)}
.mobile-menu-text{max-width:460px; line-height:1.9; color:rgba(255,255,255,.72)}
.hero{
    min-height:calc(100vh - 86px);
    display:grid;
    grid-template-columns:1.08fr .92fr;
    align-items:end;
    gap:56px;
    padding:30px 0 64px;
}
.hero-badge{
    display:inline-flex; align-items:center; gap:8px;
    padding:12px 18px;
    border-radius:999px;
    border:1px solid var(--border);
    background:rgba(255,255,255,.85);
    color:var(--accent);
    font-size:11px;
    letter-spacing:.28em;
    text-transform:uppercase;
    box-shadow:0 0 35px rgba(122,17,32,.08);
}
.hero-title{
    margin:24px 0 0;
    font-family:Georgia, "Times New Roman", serif;
    font-size:clamp(3rem, 7vw, 6.7rem);
    line-height:.96;
    letter-spacing:-.045em;
}
.hero-title .accent{color:var(--accent)}
.hero-actions{display:flex; flex-wrap:wrap; gap:14px; margin-top:30px}
.btn,.btn-secondary{
    display:inline-flex; align-items:center; justify-content:center; gap:10px;
    padding:15px 24px; border-radius:999px; font-size:14px; font-weight:600;
    transition:transform .25s ease, box-shadow .25s ease, background .25s ease;
}
.btn{
    color:#fff; background:var(--accent); box-shadow:0 0 60px rgba(122,17,32,.28)
}
.btn:hover,.btn-secondary:hover,.logo-hover:hover{transform:translateY(-2px)}
.btn-secondary{
    color:var(--accent); background:#fff; border:1px solid var(--border);
    box-shadow:0 0 28px rgba(122,17,32,.08)
}
.metrics{
    margin-top:40px; padding-top:28px; border-top:1px solid rgba(0,0,0,.06);
    display:grid; grid-template-columns:repeat(3,1fr); gap:24px;
}
.metrics p{margin:0}
.metrics .label{font-size:12px; text-transform:uppercase; letter-spacing:.22em; color:#90909a}
.metrics .value{margin-top:8px; color:var(--muted); line-height:1.6; font-size:14px}
.hero-panel{
    position:relative;
}
.hero-glow{
    position:absolute; inset:-36px;
    background:radial-gradient(circle at center, rgba(122,17,32,.18), transparent 60%);
    filter:blur(34px);
}
.panel{
    position:relative;
    border:1px solid var(--border);
    border-radius:36px;
    background:rgba(255,255,255,.82);
    box-shadow:var(--shadow);
    padding:20px;
    backdrop-filter:blur(18px);
}
.panel-inner{
    border:1px solid rgba(0,0,0,.05);
    border-radius:30px;
    background:linear-gradient(180deg,#fff, rgba(255,247,248,.94));
    padding:28px;
}
.panel-top{display:flex; align-items:flex-start; justify-content:space-between; gap:18px}
.panel-icon{
    width:64px; height:64px; border-radius:22px; display:grid; place-items:center;
    background:var(--accent); color:#fff; box-shadow:0 0 55px rgba(122,17,32,.42);
    font-size:28px; font-weight:700;
}
.entity-list{display:grid; gap:14px; margin-top:28px}
.entity-item{
    padding:20px; border-radius:24px; background:#fff; border:1px solid var(--border);
    box-shadow:0 0 28px rgba(122,17,32,.06); transition:transform .25s ease;
}
.entity-item:hover{transform:translateY(-4px)}
.entity-top{display:flex; justify-content:space-between; gap:12px}
.entity-dot{
    width:12px;height:12px;border-radius:50%; background:var(--accent);
    box-shadow:0 0 18px rgba(122,17,32,.75); margin-top:6px;
}
.columns{display:grid; grid-template-columns:.86fr 1.14fr; gap:56px}
.rich-text p{margin:0 0 26px; line-height:1.95; color:var(--muted); font-size:18px}
.grid-3{display:grid; grid-template-columns:repeat(3,1fr); gap:22px}
.grid-4{display:grid; grid-template-columns:repeat(4,1fr); gap:22px}
.tile{padding:26px}
.tile small{display:block; color:var(--accent); letter-spacing:.22em; text-transform:uppercase}
.tile h3{margin:16px 0 0; font-size:28px; line-height:1.2}
.tile p{margin:14px 0 0; line-height:1.8; color:var(--muted); font-size:14px}
.timeline{display:grid; gap:14px}
.timeline-item{
    display:flex; gap:18px; padding:24px; border-radius:24px;
    background:#fff; border:1px solid var(--border); box-shadow:0 16px 40px rgba(20,20,20,.04);
}
.timeline-step{
    width:48px;height:48px;border-radius:18px; flex:0 0 48px;
    display:grid; place-items:center; color:#fff; background:var(--accent);
    box-shadow:0 0 35px rgba(122,17,32,.28); font-weight:700;
}
.feature-band{
    position:relative; overflow:hidden;
    padding:34px;
    border-radius:36px;
    background:linear-gradient(135deg,#7a1120,#5a0d18);
    color:#fff;
    box-shadow:0 40px 100px rgba(122,17,32,.32);
}
.feature-band::before{
    content:""; position:absolute; inset:0;
    background:
        radial-gradient(circle at top right, rgba(255,255,255,.16), transparent 30%),
        radial-gradient(circle at bottom left, rgba(255,255,255,.10), transparent 32%);
}
.feature-band > *{position:relative}
.contact-form{
    display:grid; gap:16px;
}
.form-grid{display:grid; grid-template-columns:1fr 1fr; gap:16px}
input, textarea{
    width:100%; padding:15px 16px; border-radius:18px;
    border:1px solid rgba(0,0,0,.08); background:#fff; color:var(--text);
    font:inherit;
}
textarea{min-height:180px; resize:vertical}
label{display:grid; gap:8px; font-size:14px; color:#4c4c51}
.alert{
    padding:16px 18px; border-radius:18px; margin-bottom:18px;
}
.alert.success{background:#eef9f1; color:#15653a; border:1px solid #cfead7}
.alert.error{background:#fff0f1; color:#8d1526; border:1px solid #f1cad0}
.honeypot{position:absolute; left:-9999px; opacity:0}
.press-card{padding:24px}
.press-date{font-size:12px; color:#8d8d96; letter-spacing:.18em; text-transform:uppercase}
.site-footer{padding:22px 0 56px}
.footer-inner{
    border-top:1px solid rgba(0,0,0,.05);
    padding-top:28px;
    display:flex; justify-content:space-between; gap:24px; align-items:flex-end;
}
.footer-title{margin:0; font-family:Georgia,serif; font-size:32px}
.footer-copy{margin:10px 0 0; line-height:1.85; color:var(--muted); font-size:14px}
.footer-links{display:grid; gap:8px; text-align:right}
.footer-links a{color:var(--muted)}
.footer-links a:hover{color:var(--accent)}

#loader{
    position:fixed; inset:0; display:flex; align-items:center; justify-content:center;
    background:#fff; z-index:100; transition:opacity .6s ease, visibility .6s ease;
}
.loader-wrap{text-align:center; color:var(--accent)}
.loader-mark{width:126px; height:auto}
.loader-title{
    margin-top:20px; font-size:12px; letter-spacing:.35em; text-transform:uppercase; color:var(--accent);
}
.logo-animated path{
    fill: transparent;
    stroke: #781428;
    stroke-width: 2;
    stroke-dasharray: 1800;
    stroke-dashoffset: 1800;
    animation: drawLogo 2s ease forwards, fillLogo 1s ease 1.7s forwards;
}
@keyframes drawLogo{to{stroke-dashoffset:0}}
@keyframes fillLogo{to{fill:currentColor; stroke-width:0}}
.logo-hover{transition:transform .35s ease, filter .35s ease}
.logo-hover:hover{transform:scale(1.04); filter:drop-shadow(0 0 8px rgba(122,17,32,.42))}

.ecosystem-visual{
    position:relative;
    min-height:460px;
    border-radius:36px;
    border:1px solid var(--border);
    background:linear-gradient(180deg,#fff, rgba(255,247,248,.94));
    overflow:hidden;
    box-shadow:var(--shadow);
}
.ecosystem-core{
    position:absolute; inset:50% auto auto 50%;
    transform:translate(-50%,-50%);
    width:180px;height:180px;border-radius:50%;
    background:var(--accent); color:#fff;
    display:grid; place-items:center;
    text-align:center; padding:18px;
    box-shadow:0 0 70px rgba(122,17,32,.28);
}
.ecosystem-core span{font-family:Georgia,serif; font-size:28px; line-height:1.1}
.ecosystem-node{
    position:absolute;
    width:190px;
    padding:18px;
    border-radius:22px;
    background:#fff;
    border:1px solid var(--border);
    box-shadow:0 18px 40px rgba(20,20,20,.08);
    animation: floatNode 6s ease-in-out infinite;
}
.ecosystem-node h3{margin:0 0 8px; font-size:18px}
.ecosystem-node p{margin:0; color:var(--muted); line-height:1.6; font-size:14px}
.node-1{top:8%; left:8%}
.node-2{top:12%; right:8%; animation-delay:1.2s}
.node-3{bottom:12%; left:9%; animation-delay:2.4s}
.node-4{bottom:10%; right:10%; animation-delay:3.6s}
.ecosystem-line{
    position:absolute;
    inset:0;
    pointer-events:none;
}
@keyframes floatNode{
    0%,100%{transform:translateY(0)}
    50%{transform:translateY(-10px)}
}
.admin-shell{
    min-height:100vh;
    display:grid;
    grid-template-columns:280px 1fr;
    background:#f7f4f5;
}
.admin-sidebar{
    background:#1e1114;
    color:#fff;
    padding:28px 22px;
}
.admin-sidebar h1{font-size:22px; margin:0 0 20px; font-family:Georgia,serif}
.admin-sidebar nav{display:grid; gap:10px}
.admin-sidebar a{
    color:rgba(255,255,255,.8);
    padding:12px 14px;
    border-radius:14px;
}
.admin-sidebar a:hover,.admin-sidebar a.active{
    background:rgba(255,255,255,.08);
    color:#fff;
}
.admin-content{
    padding:30px;
}
.admin-card{
    background:#fff;
    border:1px solid rgba(0,0,0,.06);
    border-radius:24px;
    padding:24px;
    box-shadow:0 12px 36px rgba(20,20,20,.05);
}
.admin-grid{display:grid; gap:22px}
pre.codebox, textarea.codebox{
    background:#111; color:#f4f4f4; border-radius:18px; padding:18px;
    width:100%; min-height:320px; font-family:ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, monospace;
    font-size:13px; line-height:1.6; border:0;
}
.table{
    width:100%; border-collapse:collapse; font-size:14px;
}
.table th,.table td{
    padding:12px 10px; border-bottom:1px solid rgba(0,0,0,.06); text-align:left; vertical-align:top;
}
.login-wrap{
    min-height:100vh; display:grid; place-items:center; padding:30px;
}
.login-card{
    width:min(540px,100%);
    background:#fff; border:1px solid rgba(0,0,0,.06); border-radius:26px;
    padding:28px; box-shadow:var(--shadow);
}

@media (max-width: 980px){
    .hero,.columns,.grid-3,.grid-4,.form-grid,.admin-shell{
        grid-template-columns:1fr;
    }
    .desktop-nav{display:none}
    .menu-toggle{display:inline-flex}
    .metrics{grid-template-columns:1fr}
    .footer-inner{flex-direction:column; align-items:flex-start}
    .footer-links{text-align:left}
}
