
@import url('https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700;800;900&family=Parisienne&display=swap');
:root{--bg:#030712;--bg2:#071026;--panel:rgba(8,18,45,.68);--border:rgba(99,145,255,.18);--text:#fff;--muted:#b8c1d9;--blue:#28a8ff;--purple:#7d45ff;--pink:#a855f7;--shadow:0 30px 100px rgba(0,0,0,.35)}body.light{--bg:#f6f8ff;--bg2:#eef3ff;--panel:rgba(255,255,255,.78);--border:rgba(23,87,180,.16);--text:#0f172a;--muted:#5b6478;--shadow:0 30px 80px rgba(20,60,140,.12)}*{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth}body{min-height:100vh;color:var(--text);font-family:Inter,sans-serif;background:radial-gradient(circle at 8% 12%,rgba(40,168,255,.18),transparent 32%),radial-gradient(circle at 78% 16%,rgba(125,69,255,.22),transparent 34%),linear-gradient(135deg,var(--bg),var(--bg2));overflow-x:hidden}.site-glow{position:fixed;width:520px;height:520px;border-radius:50%;background:radial-gradient(circle,rgba(40,168,255,.16),transparent 68%);pointer-events:none;z-index:-1;transform:translate(-50%,-50%)}

.topbar{width:calc(100% - 40px);margin:10px auto 0;min-height:106px;padding:18px 34px;display:flex;align-items:center;justify-content:space-between;gap:24px;background:linear-gradient(180deg,rgba(9,20,52,.82),rgba(4,10,28,.68));border:1px solid var(--border);border-radius:20px;box-shadow:var(--shadow);backdrop-filter:blur(22px);position:sticky;top:5px;z-index:100}

body.light .topbar,body.light .service-strip,body.light .contact-card{background:rgba(255,255,255,.72)}

.brand img{
    height:62px;
    filter:drop-shadow(0 0 18px rgba(40,168,255,.18))
}



/* 
.nav{display:flex;align-items:center;gap:36px}

.nav a{color:var(--text);text-decoration:none;font-weight:600;opacity:.92;}

.nav a:hover,.nav a.active{color:var(--purple)} */

.nav {
    display: flex;
    align-items: center;
    gap: 0;
}

.nav a {
    color: var(--text);
    text-decoration: none;
    font-weight: 600;
    opacity: .92;

    display: flex;
    align-items: center;

    padding: 0 18px;

    min-height: 42px;

    position: relative;
    font-size:20px;
}

.nav a:hover,
.nav a.active {
    color: var(--purple);
}

@media (min-width:1131px){

    .nav a:not(:last-of-type)::after {

        content: "";

        position: absolute;

        top: 10%;
        right: 0;

        width: 1px;
        height: 80%;

        background: rgba(255,255,255,.18);

        pointer-events: none;
    }

}



.top-actions{display:flex;align-items:center;gap:16px}

select{    
    
    color:var(--text);background:rgba(7,15,38,.8);border:1px solid var(--border);border-radius:14px;
    
    padding:11px 16px;outline:none;font-weight:700}
body.light select{background:rgba(255,255,255,.76)}


.theme-toggle input{display:none}.theme-toggle span{width:74px;height:40px;border-radius:999px;border:1px solid var(--border);background:linear-gradient(135deg,rgba(40,168,255,.25),rgba(125,69,255,.32));display:flex;align-items:center;justify-content:space-between;padding:4px;cursor:pointer;position:relative}.theme-toggle span:after{content:"";position:absolute;width:32px;height:32px;right:4px;border-radius:50%;background:#fff;box-shadow:0 0 20px rgba(255,255,255,.45);transition:.35s}.theme-toggle input:checked+span:after{transform:translateX(-34px)}.theme-toggle b{width:32px;height:32px;display:grid;place-items:center;font-size:.95rem;z-index:1}.mobile-menu{display:none}.hero-shell{width:calc(100% - 60px);margin:10px auto 0;min-height:650px;display:grid;grid-template-columns:1fr 1fr;align-items:center;gap:46px}.eyebrow{width:max-content;max-width:100%;padding:10px 18px;border-radius:999px;border:1px solid var(--border);color:#7dd3ff;font-weight:800;letter-spacing:.04em}.hero-left h1{margin-top:28px;font-size:clamp(3rem,5vw,5.4rem);line-height:1.16;letter-spacing:-.055em;font-weight:900}

.gradient-text{background: linear-gradient(
        135deg,
        #2bb8ff 0%,
        #5b7cff 45%,
        #8b5cff 100%
    );-webkit-background-clip:text;-webkit-text-fill-color:transparent;filter:drop-shadow(0 0 18px rgba(40,168,255,.24))}

.script-words{display:flex;align-items:center;gap:36px;flex-wrap:wrap;margin-top:36px;font-size:clamp(1.5rem,1.5vw,2.5rem);}
.script-words i{width:7px;height:7px;border-radius:50%;background:linear-gradient(135deg,var(--blue),var(--pink));box-shadow:0 0 18px var(--blue)}
.hero-text{margin-top:34px;max-width:720px;color:var(--muted);font-size:1.22rem;line-height:1.75}.hero-actions{display:flex;gap:28px;flex-wrap:wrap;margin-top:38px}.btn{min-height:58px;padding:0 28px;display:inline-flex;align-items:center;gap:14px;border-radius:12px;text-decoration:none;color:#fff;font-weight:800;border:1px solid var(--border);transition:.3s}.btn:hover{transform:translateY(-3px)}

.btn.primary{
    background: linear-gradient(
        135deg,
        #2bb8ff 0%,
        #5b7cff 45%,
        #8b5cff 100%
    );

    box-shadow:
        0 10px 30px rgba(43,184,255,.18),
        0 0 40px rgba(139,92,255,.12);
    border:none;
}

.btn.secondary{color:var(--text)}
.bubble-icon{font-size:20px}

.hero-right{min-height:620px;position:relative;display:grid;place-items:center}.hologram-scene{width:min(700px,100%);aspect-ratio:1.05/1;position:relative;perspective:1200px}.platform{position:absolute;left:50%;bottom:13%;width:430px;height:210px;transform:translateX(-50%) rotateX(68deg) rotateZ(-4deg);border-radius:50%;background:radial-gradient(circle,rgba(40,168,255,.9),rgba(40,168,255,.10) 32%,rgba(125,69,255,.18) 58%,transparent 68%);filter:drop-shadow(0 0 46px rgba(40,168,255,.36));animation:platformPulse 3.8s ease-in-out infinite}.platform-ring{position:absolute;inset:18px;border-radius:50%;border:2px solid rgba(80,196,255,.52);box-shadow:0 0 28px rgba(40,168,255,.48)}.ring-b{inset:44px;border-color:rgba(156,77,255,.6)}.platform-core{position:absolute;left:50%;top:50%;width:110px;height:110px;transform:translate(-50%,-50%);border-radius:50%;background:radial-gradient(circle,#90f3ff,rgba(40,168,255,.15) 55%,transparent 70%);filter:blur(2px)}@keyframes platformPulse{0%,100%{opacity:.86;filter:drop-shadow(0 0 40px rgba(40,168,255,.32))}50%{opacity:1;filter:drop-shadow(0 0 70px rgba(125,69,255,.45))}}.holo-logo{position:absolute;left:50%;top:48%;width:245px;height:245px;transform:translate(-50%,-50%);display:grid;place-items:center;transform-style:preserve-3d;animation:holoSpin 8s linear infinite;filter:drop-shadow(0 0 32px rgba(40,168,255,.48))}.holo-logo img{width:100%;height:100%;object-fit:contain}@keyframes holoSpin{0%{transform:translate(-50%,-50%) rotateY(0deg)}50%{transform:translate(-50%,-50%) rotateY(180deg) translateZ(18px)}100%{transform:translate(-50%,-50%) rotateY(360deg)}}.beam{position:absolute;left:50%;bottom:30%;width:5px;height:330px;transform-origin:bottom;background:linear-gradient(to top,rgba(40,168,255,.72),transparent);filter:blur(3px);opacity:.55;animation:beamMove 4s ease-in-out infinite}.beam-one{transform:rotate(-18deg)}.beam-two{transform:rotate(0deg);animation-delay:-1.2s}.beam-three{transform:rotate(19deg);animation-delay:-2.4s}@keyframes beamMove{0%,100%{opacity:.25;height:280px}50%{opacity:.72;height:360px}}.orbit{position:absolute;left:50%;top:37%;width:420px;height:160px;border:1px solid rgba(125,69,255,.32);border-radius:50%;transform:translate(-50%,-50%) rotateX(70deg);animation:orbitSpin 10s linear infinite}.orbit-two{width:520px;height:200px;border-color:rgba(40,168,255,.24);animation-duration:14s;animation-direction:reverse}@keyframes orbitSpin{from{transform:translate(-50%,-50%) rotateX(70deg) rotateZ(0)}to{transform:translate(-50%,-50%) rotateX(70deg) rotateZ(360deg)}}.floating-panel{position:absolute;background:linear-gradient(180deg,rgba(11,24,60,.82),rgba(6,12,34,.64));border:1px solid rgba(80,130,255,.3);box-shadow:0 18px 55px rgba(0,0,0,.32),inset 0 0 20px rgba(40,168,255,.05);backdrop-filter:blur(16px);border-radius:16px;animation:float 5s ease-in-out infinite}.code-panel{left:2%;top:22%;width:220px;min-height:150px;padding:18px;transform:rotateY(-18deg) rotateZ(-6deg)}.panel-dots{display:flex;gap:7px;margin-bottom:12px}.panel-dots span{width:7px;height:7px;border-radius:50%;background:var(--blue);opacity:.8}pre{color:#60d9ff;font-family:Consolas,monospace;line-height:1.55;font-size:.86rem}.chart-panel{right:5%;top:34%;width:150px;height:120px;transform:rotateY(16deg) rotateZ(8deg);animation-delay:-1.8s}.mini-chart{position:absolute;inset:24px;display:flex;align-items:flex-end;gap:10px}.mini-chart span{width:18px;border-radius:8px 8px 0 0;background:linear-gradient(to top,var(--blue),var(--purple));box-shadow:0 0 15px rgba(40,168,255,.35)}.mini-chart span:nth-child(1){height:34px}.mini-chart span:nth-child(2){height:62px}.mini-chart span:nth-child(3){height:48px}.mini-chart span:nth-child(4){height:82px}.gear-panel{right:10%;bottom:22%;width:130px;height:130px;display:grid;place-items:center;transform:rotateY(16deg);animation-delay:-.9s}.gear{font-size:4rem;color:#5788ff;filter:drop-shadow(0 0 18px rgba(40,168,255,.45));animation:gearRotate 8s linear infinite}@keyframes gearRotate{to{transform:rotate(360deg)}}@keyframes float{0%,100%{translate:0 0}50%{translate:0 -18px}}.particles span{position:absolute;left:50%;top:50%;width:3px;height:3px;border-radius:50%;background:#9edfff;box-shadow:0 0 10px #4aa8ff;transform:rotate(calc(var(--i)*13deg)) translateX(calc(120px + var(--i)*8px));animation:particle 5s ease-in-out infinite;animation-delay:calc(var(--i)*-.18s)}@keyframes particle{0%,100%{opacity:.15;translate:0 0}50%{opacity:1;translate:0 -26px}}.service-strip{width:calc(100% - 40px);margin:40px auto 70px;padding:38px 40px;display:grid;grid-template-columns:repeat(4,1fr);gap:26px;background:linear-gradient(180deg,rgba(9,20,52,.82),rgba(4,10,28,.68));border:1px solid var(--border);border-radius:24px;box-shadow:var(--shadow);backdrop-filter:blur(22px)}.service-item{display:grid;grid-template-columns:74px 1fr;gap:20px;align-items:center}.service-icon{width:74px;height:74px;border-radius:14px;display:grid;place-items:center;color:#7ed8ff;font-weight:900;font-size:1.7rem;background:linear-gradient(180deg,rgba(40,168,255,.15),rgba(125,69,255,.12));border:1px solid var(--border);box-shadow:inset 0 0 28px rgba(40,168,255,.09)}.service-item h3{font-size:1rem;margin-bottom:10px}.service-item p{color:var(--muted);line-height:1.6;font-size:.95rem}.contact-layout{width:calc(100% - 40px);min-height:650px;margin:70px auto;display:grid;place-items:center}.contact-card{width:min(820px,100%);background:linear-gradient(180deg,rgba(9,20,52,.82),rgba(4,10,28,.68));border:1px solid var(--border);border-radius:24px;box-shadow:var(--shadow);padding:48px}.contact-card h1{margin-top:22px;font-size:clamp(2.4rem,5vw,4.4rem)}.contact-card p{margin-top:16px;color:var(--muted)}form{margin-top:34px;display:grid;gap:22px}label{display:grid;gap:10px;color:var(--muted);font-weight:700}input,textarea{width:100%;border:1px solid var(--border);background:rgba(8,18,45,.62);color:var(--text);border-radius:14px;padding:16px 18px;outline:none;font-family:Inter,sans-serif}body.light input,body.light textarea{background:rgba(255,255,255,.82)}textarea{min-height:180px;resize:vertical}.response{min-height:24px;color:#65d6ff;font-weight:800}.footer{width:calc(100% - 40px);margin:0 auto 34px;display:flex;justify-content:center;gap:10px;color:var(--muted)}
.sun{
    margin-left:-1px;
    margin-top:-1px;
}
.moon{
    margin-top:-1px;
}

.logo{
    display:block;
}
.just-logo{
    display:none;
}

.arrow{
    transition:
        transform .25s ease,
        opacity .25s ease;
}

.btn:hover .arrow,
.btn:focus .arrow{
    transform: translateX(5px);
    opacity: .85;
}

.mobile-menu {
    display: none;
    width: 40px;
    height: 40px;
    position: relative;
    background: transparent;
    border: 1px solid var(--border);
    border-radius: 10px;
    cursor: pointer;
    padding: 0;
    flex-shrink: 0;
}

.mobile-menu span {
    position: absolute;
    left: 50%;
    width: 20px;
    height: 2px;
    background: var(--text);
    border-radius: 999px;
    transition:
        transform .3s ease,
        opacity .3s ease,
        top .3s ease;
}

/* burger */
.mobile-menu span:nth-child(1) {
    top: 12px;
    transform: translateX(-50%);
}

.mobile-menu span:nth-child(2) {
    top: 19px;
    transform: translateX(-50%);
}

.mobile-menu span:nth-child(3) {
    top: 26px;
    transform: translateX(-50%);
}

/* croix */
.mobile-menu.active span:nth-child(1) {
    top: 19px;
    transform: translateX(-50%) rotate(45deg);
}

.mobile-menu.active span:nth-child(2) {
    opacity: 0;
}

.mobile-menu.active span:nth-child(3) {
    top: 19px;
    transform: translateX(-50%) rotate(-45deg);
}


@media(max-width:1180px){
    .hero-shell{grid-template-columns:1fr}.hero-right{min-height:560px}.service-strip{grid-template-columns:repeat(2,1fr)}
    
    /* .nav{gap:18px} */
    .topbar{
        min-height: 50px;
    }
}
@media(max-width:1130px){
    .topbar,.service-strip,.contact-layout,.footer{width:calc(100% - 32px)}.topbar{margin-top:5px;padding:16px;flex-wrap:wrap}

    .brand img{height:40px}
    
    .mobile-menu{display:block;margin-left:auto;background:transparent;color:var(--text);border:1px solid var(--border);border-radius:10px;padding:8px 10px}
    
    .nav{display:none;order:4;width:100%;flex-direction:column;align-items:flex-start;gap:0px;}
    
    .nav.open{display:flex}.top-actions{width:100%;justify-content:space-between}

    .nav a {
        width: 100%;

        padding: 11px 0;

        border-top: 1px solid var(--border);

        display: flex;
        align-items: center;
        justify-content: space-between;

        text-decoration: none;
        color: var(--text);

        min-height: 50px;
    }

    .nav a::after {
        content: "→";
        font-size:30px;
        transition: transform .25s ease;
    }

    .nav a:hover::after,
    .nav a:focus::after {
        transform: translateX(4px);
    }
    
    .hero-shell{margin-top:10px}

    .hero-right{min-height:430px}.code-panel,.chart-panel,.gear-panel{scale:.72}.platform{width:330px}.holo-logo{width:180px;height:180px}.service-strip{grid-template-columns:1fr;padding:24px}.contact-card{padding:28px}

    .top-actions {
        width: 100%;
        margin-left: 0;
        padding-top: 18px;
        border-top: 1px solid var(--border);
        justify-content: space-between;
    }

    .hero-shell {
        width:calc(100% - 64px);
    }
}

@media (max-width: 800px){

    .hero-actions{
        display:flex;
        flex-wrap:wrap;
        gap:16px;
    }

    .hero-actions > *{
        flex:1 1 calc(50% - 8px);
    }

    .arrow,
    .bubble-icon{
        margin-left:auto;
    }

}

@media(max-width:600px){
    .script-words{
        gap:20px;
    }
    .script-words i{
        display:none;
    }
}

@media(max-width:455px){
    .eyebrow{
        width:100%;
        display: block;
        text-align: center;
    }
}

@media(max-width:330px){
    .logo{
        display:none;
    }
    .just-logo{
        display:block;
    }
}

html{
    scroll-padding-top:150px;
}

.page-section{
    scroll-margin-top:150px;
}

.hero-title-line,
.hero-title-break{
    display:block;
}

.section-heading .section-lead{
    font-size:clamp(1.42rem,2.2vw,2.12rem);
}

.section-heading p,
.contact-copy p{
    font-size:1.16rem;
}

.holo-logo{
    display:none;
    animation:none;
}

@media(max-width:760px){
    html{
        scroll-padding-top:120px;
    }

    .page-section{
        scroll-margin-top:120px;
    }
}

.project-card-actions{
    position:absolute;
    z-index:3;
    left:22px;
    bottom:72px;
    display:flex;
    align-items:center;
    gap:10px;
    flex-wrap:wrap;
}

.project-card-actions .project-label{
    position:static;
    left:auto;
    bottom:auto;
}

.project-card-actions .project-demo-btn{
    position:static;
    right:auto;
    top:auto;
    min-height:34px;
    padding:0 14px;
    opacity:0;
    transform:translateY(8px);
}

.project-card:hover .project-card-actions .project-demo-btn,
.project-card:focus-within .project-card-actions .project-demo-btn{
    opacity:1;
    transform:translateY(0);
}

.demo-crud-app{
    min-height:520px;
    display:grid;
    grid-template-columns:74px minmax(0,1fr);
    overflow:hidden;
    border:1px solid rgba(126,216,255,.2);
    border-radius:8px;
    background:linear-gradient(145deg,rgba(5,12,34,.9),rgba(5,12,34,.62)),radial-gradient(circle at 80% 10%,rgba(125,69,255,.18),transparent 36%);
}

body.light .demo-crud-app{
    background:linear-gradient(145deg,rgba(255,255,255,.92),rgba(238,244,255,.78)),radial-gradient(circle at 80% 10%,rgba(125,69,255,.1),transparent 36%);
}

.demo-crud-sidebar{
    padding:18px 12px;
    display:grid;
    align-content:start;
    justify-items:center;
    gap:18px;
    border-right:1px solid rgba(126,216,255,.18);
    background:rgba(3,7,18,.2);
}

.demo-crud-sidebar strong{
    color:#65d6ff;
    font-size:1.35rem;
}

.demo-crud-sidebar span{
    width:42px;
    height:42px;
    display:grid;
    place-items:center;
    border-radius:8px;
    color:var(--muted);
    border:1px solid transparent;
}

.demo-crud-sidebar span.is-active{
    color:#65d6ff;
    border-color:rgba(40,168,255,.26);
    background:rgba(40,168,255,.12);
    box-shadow:0 0 26px rgba(40,168,255,.22);
}

.demo-crud-main{
    min-width:0;
    padding:24px;
    display:grid;
    gap:16px;
    align-content:start;
}

.demo-crud-head{
    display:flex;
    align-items:center;
    justify-content:space-between;
    gap:16px;
}

.demo-crud-head strong{
    display:block;
    color:var(--text);
    font-size:clamp(1.3rem,2vw,1.8rem);
    line-height:1.1;
    text-transform:uppercase;
}

.demo-crud-head span,
.demo-crud-search span{
    color:var(--muted);
    font-size:.92rem;
}

.demo-crud-head button,
.demo-crud-form button{
    min-height:42px;
    padding:0 18px;
    border:0;
    border-radius:8px;
    color:#fff;
    background:linear-gradient(135deg,var(--blue),var(--purple));
    font-weight:900;
    cursor:pointer;
}

.demo-crud-search{
    margin:0;
    display:grid;
    gap:8px;
}

.demo-crud-table-wrap{
    overflow:auto;
    border:1px solid rgba(126,216,255,.14);
    border-radius:8px;
}

.demo-crud-table{
    width:100%;
    min-width:850px;
    border-collapse:collapse;
    color:var(--text);
    font-size:.88rem;
}

.demo-crud-table th,
.demo-crud-table td{
    padding:13px 12px;
    border-bottom:1px solid rgba(126,216,255,.1);
    text-align:left;
    white-space:nowrap;
}

.demo-crud-table th{
    color:var(--muted);
    font-size:.76rem;
    text-transform:uppercase;
    letter-spacing:.06em;
}

.demo-crud-table tr.is-selected{
    background:rgba(40,168,255,.08);
}

.demo-crud-table td:last-child{
    display:flex;
    gap:8px;
}

.demo-crud-table button{
    min-height:30px;
    padding:0 10px;
    border:1px solid rgba(126,216,255,.22);
    border-radius:999px;
    color:var(--text);
    background:rgba(255,255,255,.05);
    font-size:.78rem;
    font-weight:800;
    cursor:pointer;
}

.demo-crud-table button[data-crud-action="delete"]{
    border-color:rgba(251,113,133,.36);
    color:#fb7185;
}

.demo-status{
    display:inline-flex;
    min-width:62px;
    justify-content:center;
    padding:5px 9px;
    border-radius:8px;
    font-weight:900;
    font-size:.78rem;
}

.demo-status.is-active{
    color:#70f0a2;
    background:rgba(34,197,94,.16);
}

.demo-status.is-inactive{
    color:#ff8ab0;
    background:rgba(236,72,153,.16);
}

.demo-crud-form{
    margin-top:0;
    display:grid;
    grid-template-columns:repeat(5,minmax(0,1fr)) auto;
    gap:10px;
    align-items:end;
}

.demo-crud-form label{
    margin:0;
    gap:7px;
}

.demo-crud-form input,
.demo-crud-form select,
.demo-crud-search input{
    min-height:42px;
    border-radius:8px;
}

@media(max-width:960px){
    .demo-crud-app{
        grid-template-columns:1fr;
    }

    .demo-crud-sidebar{
        grid-auto-flow:column;
        grid-auto-columns:max-content;
        justify-content:start;
        overflow:auto;
        border-right:0;
        border-bottom:1px solid rgba(126,216,255,.18);
    }

    .demo-crud-form{
        grid-template-columns:1fr 1fr;
    }
}

@media(max-width:760px){
    .project-card-actions .project-demo-btn{
        opacity:1;
        transform:none;
    }

    .demo-crud-head,
    .demo-crud-form{
        grid-template-columns:1fr;
    }

    .demo-crud-head{
        display:grid;
    }
}

.project-card-actions{
    position:absolute;
    z-index:3;
    left:22px;
    bottom:72px;
    display:flex;
    align-items:center;
    gap:10px;
    flex-wrap:wrap;
}

.project-card-actions .project-label{
    position:static;
    left:auto;
    bottom:auto;
}

.project-card-actions .project-demo-btn{
    position:static;
    right:auto;
    top:auto;
    min-height:34px;
    padding:0 14px;
    opacity:0;
    transform:translateY(8px);
}

.project-card:hover .project-card-actions .project-demo-btn,
.project-card:focus-within .project-card-actions .project-demo-btn{
    opacity:1;
    transform:translateY(0);
}

@media(max-width:760px){
    .project-card-actions .project-demo-btn{
        opacity:1;
        transform:none;
    }
}

.contact-section-title{
    margin:0;
}

.contact-section{
    min-height:640px;
    display:grid;
    grid-template-columns:minmax(0,760px) minmax(0,calc(100%));
    gap:44px;
    align-items:start;
}

.contact-headline{
    margin-top:16px;
    font-size:clamp(1.8rem,2.7vw,3rem);
    line-height:1.12;
    font-weight:900;
    letter-spacing:0;
}

.location-card{
    position:relative;
    margin-top:34px;
    min-height:280px;
    display:grid;
    grid-template-columns:minmax(220px,.9fr) minmax(0,1fr);
    gap:24px;
    overflow:hidden;
    border:1px solid rgba(126,216,255,.24);
    border-radius:8px;
    background:linear-gradient(145deg,rgba(12,26,64,.9),rgba(5,12,34,.72)),radial-gradient(circle at 18% 24%,rgba(40,168,255,.22),transparent 38%),radial-gradient(circle at 82% 76%,rgba(168,85,247,.2),transparent 36%);
    box-shadow:var(--shadow);
}

body.light .location-card{
    background:linear-gradient(145deg,rgba(255,255,255,.92),rgba(238,244,255,.76)),radial-gradient(circle at 18% 24%,rgba(40,168,255,.15),transparent 38%),radial-gradient(circle at 82% 76%,rgba(168,85,247,.13),transparent 36%);
}

.location-card::before{
    content:"";
    position:absolute;
    inset:18px;
    border:1px solid rgba(126,216,255,.14);
    border-radius:8px;
    pointer-events:none;
}

.location-map{
    position:relative;
    min-height:280px;
    overflow:hidden;
    border-right:1px solid rgba(126,216,255,.16);
}

.location-grid{
    position:absolute;
    inset:0;
    
    background-size:34px 34px;
    mask-image:radial-gradient(circle at center,#000 0 52%,transparent 76%);
}

.location-dot{
    position:absolute;
    width:18px;
    height:18px;
    border-radius:50%;
    background:#65d6ff;
    border:4px solid rgba(255,255,255,.82);
    box-shadow:0 0 0 10px rgba(101,214,255,.12),0 0 30px rgba(101,214,255,.65);
}

.location-dot b{
    position:absolute;
    left:50%;
    top:24px;
    transform:translateX(-50%);
    padding:7px 10px;
    border:1px solid rgba(126,216,255,.2);
    border-radius:999px;
    color:var(--text);
    background:rgba(5,12,34,.74);
    backdrop-filter:blur(12px);
    font-size:.78rem;
    line-height:1;
}

body.light .location-dot b{
    background:rgba(255,255,255,.76);
}

.location-dot-rouen{
    left:22%;
    top:28%;
}

.location-dot-louviers{
    position:absolute;
    left:50%;
    top:55%;
    width:10px;
    height:10px;
    transform:translate(-50%,-50%);
}

.location-dot-louviers::before{
    content:"";
    position:absolute;
    inset:0;
    border-radius:50%;
    background:var(--purple);
    box-shadow:0 0 22px rgba(125,69,255,.9);
    animation:louviersPulse 1.7s ease-in-out infinite;
}

.location-dot-louviers b{
    top:20px;
    position:absolute;
    left:50%;
    transform:translateX(-50%);
    padding:7px 10px;
    border:1px solid rgba(126,216,255,.2);
    border-radius:999px;
    color:var(--text);
    background:rgba(5,12,34,.74);
    backdrop-filter:blur(12px);
    font-size:.78rem;
    line-height:1;
}

body.light .location-dot-louviers b{
    background:rgba(255,255,255,.76);
}

@keyframes louviersPulse{
    0%,100%{
        opacity:.78;
        transform:scale(1);
        box-shadow:0 0 16px rgba(125,69,255,.8),0 0 0 0 rgba(125,69,255,.34);
    }

    50%{
        opacity:1;
        transform:scale(1.55);
        box-shadow:0 0 24px var(--purple),0 0 0 12px rgba(125,69,255,0);
    }
}

.location-dot-evreux{
    right:20%;
    bottom:25%;
    background:#a855f7;
    box-shadow:0 0 0 10px rgba(168,85,247,.12),0 0 30px rgba(168,85,247,.58);
}

.location-content{
    position:relative;
    z-index:1;
    padding:34px 34px 34px 0;
    display:flex;
    flex-direction:column;
    justify-content:center;
}

.location-content span{
    width:max-content;
    max-width:100%;
    padding:8px 12px;
    border:1px solid rgba(125,69,255,.42);
    border-radius:999px;
    color:var(--purple);
    font-size:.76rem;
    font-weight:900;
    text-transform:uppercase;
    letter-spacing:.08em;
}

.location-content strong{
    margin-top:18px;
    font-size:clamp(1.45rem,2.2vw,2.35rem);
    line-height:1.05;
}

.contact-copy .location-content p{
    margin:16px 0 0;
    max-width:460px;
    font-size:1rem;
    line-height:1.72;
}

.office-card{
    margin-top:24px;
    padding-top:22px;
    border-top:1px solid rgba(126,216,255,.16);
}

.office-card > span{
    width:max-content;
    max-width:100%;
    padding:8px 12px;
    border:1px solid rgba(125,69,255,.42);
    border-radius:999px;
    color:var(--purple);
    font-size:.76rem;
    font-weight:900;
    line-height:1;
    text-transform:uppercase;
    letter-spacing:.08em;
}

.contact-copy .office-line{
    margin:16px 0 0;
    max-width:none;
    display:flex;
    align-items:flex-start;
    gap:12px;
    color:var(--muted);
    font-size:.96rem;
    line-height:1.55;
}

.office-icon{
    width:34px;
    height:34px;
    flex:0 0 34px;
    display:grid;
    place-items:center;
    border:1px solid rgba(125,69,255,.34);
    border-radius:8px;
    color:var(--purple);
    box-shadow:0 0 22px rgba(125,69,255,.12);
}

.office-icon svg{
    width:18px;
    height:18px;
    stroke:currentColor;
    stroke-width:2;
    stroke-linecap:round;
    stroke-linejoin:round;
    fill:none;
}

.office-address{
    color:var(--text);
    font-style:normal;
}

.office-line a{
    color:var(--text);
    text-decoration:none;
}

.office-line a:hover{
    color:var(--purple);
}

.field-counter{
    margin-top:-2px;
    justify-self:end;
    color:var(--muted);
    font-size:.78rem;
    font-weight:800;
    line-height:1;
}

.field-counter.is-warning,
.field-counter.is-danger{
    color:#fb7185;
}

.contact-form input.is-invalid,
.contact-form textarea.is-invalid{
    border-color:#fb7185;
    box-shadow:0 0 0 3px rgba(251,113,133,.16),0 0 28px rgba(251,113,133,.18);
}

.contact-form label.has-error > span{
    color:#fb7185;
}

.form-row{
    display:grid;
    grid-template-columns:repeat(2,minmax(0,1fr));
    gap:16px;
}

.phone-control{
    display:grid;
    grid-template-columns:104px minmax(0,1fr);
    gap:10px;
}

.phone-country-wrap{
    position:relative;
    min-width:0;
}

.phone-country-wrap::after{
    content:"";
    position:absolute;
    right:12px;
    top:50%;
    width:7px;
    height:7px;
    border-right:2px solid var(--muted);
    border-bottom:2px solid var(--muted);
    pointer-events:none;
    transform:translateY(-62%) rotate(45deg);
}

.phone-flag{
    position:absolute;
    left:12px;
    top:50%;
    z-index:1;
    width:22px;
    height:16px;
    border-radius:3px;
    background-size:cover;
    background-position:center;
    box-shadow:0 0 0 1px rgba(255,255,255,.32),0 6px 16px rgba(0,0,0,.18);
    pointer-events:none;
    transform:translateY(-50%);
}

.phone-flag.is-fr{
    background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 3 2'%3E%3Cpath fill='%23002395' d='M0 0h1v2H0z'/%3E%3Cpath fill='%23fff' d='M1 0h1v2H1z'/%3E%3Cpath fill='%23ed2939' d='M2 0h1v2H2z'/%3E%3C/svg%3E");
}

.phone-flag.is-en{
    background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 60 30'%3E%3CclipPath id='a'%3E%3Cpath d='M0 0h60v30H0z'/%3E%3C/clipPath%3E%3Cg clip-path='url(%23a)'%3E%3Cpath fill='%23012169' d='M0 0h60v30H0z'/%3E%3Cpath stroke='%23fff' stroke-width='6' d='m0 0 60 30m0-30L0 30'/%3E%3Cpath stroke='%23c8102e' stroke-width='4' d='m0 0 60 30m0-30L0 30'/%3E%3Cpath stroke='%23fff' stroke-width='10' d='M30 0v30M0 15h60'/%3E%3Cpath stroke='%23c8102e' stroke-width='6' d='M30 0v30M0 15h60'/%3E%3C/g%3E%3C/svg%3E");
}

.phone-country{
    width:100%;
    height:100%;
    padding-left:42px;
    padding-right:30px;
    font-weight:900;
    appearance:none;
}

.toast-stack{
    position:fixed;
    top:132px;
    right:24px;
    z-index:300;
    width:min(380px,calc(100vw - 32px));
    display:grid;
    gap:12px;
    pointer-events:none;
}

.toast{
    position:relative;
    overflow:hidden;
    padding:16px 46px 16px 18px;
    border:1px solid rgba(126,216,255,.24);
    border-radius:8px;
    color:var(--text);
    background:linear-gradient(145deg,rgba(12,26,64,.94),rgba(5,12,34,.86)),radial-gradient(circle at 12% 12%,rgba(40,168,255,.18),transparent 38%);
    box-shadow:0 22px 70px rgba(0,0,0,.36);
    backdrop-filter:blur(18px);
    pointer-events:auto;
    transform:translateX(18px);
    opacity:0;
    animation:toastIn .32s ease forwards;
}

body.light .toast{
    background:linear-gradient(145deg,rgba(255,255,255,.94),rgba(238,244,255,.86)),radial-gradient(circle at 12% 12%,rgba(40,168,255,.12),transparent 38%);
    box-shadow:0 22px 60px rgba(20,60,140,.18);
}

.toast::before{
    content:"";
    position:absolute;
    inset:0 auto 0 0;
    width:4px;
    background:#65d6ff;
}

.toast.is-success::before{
    background:#22c55e;
}

.toast.is-error::before{
    background:#fb7185;
}

.toast.is-info::before{
    background:#65d6ff;
}

.toast strong{
    display:block;
    font-size:.82rem;
    line-height:1;
    text-transform:uppercase;
    letter-spacing:.08em;
    color:#9ae6ff;
}

.toast p{
    margin-top:8px;
    color:var(--muted);
    font-size:.95rem;
    line-height:1.5;
}

.toast-close{
    position:absolute;
    top:10px;
    right:10px;
    width:30px;
    height:30px;
    display:grid;
    place-items:center;
    border:1px solid rgba(126,216,255,.2);
    border-radius:8px;
    color:var(--text);
    background:rgba(255,255,255,.06);
    font-size:1.1rem;
    line-height:1;
    cursor:pointer;
}

.toast.is-leaving{
    animation:toastOut .24s ease forwards;
}

@keyframes toastIn{
    to{
        transform:translateX(0);
        opacity:1;
    }
}

@keyframes toastOut{
    to{
        transform:translateX(18px);
        opacity:0;
    }
}

@media(max-width:1180px){
    .contact-copy{
        max-width:100%;
    }

    .section-heading p,
    .contact-copy p{
        max-width:none;
    }
}

@media(max-width:760px){
    .toast-stack{
        top:104px;
        right:16px;
        left:16px;
        width:auto;
    }

    .location-card{
        grid-template-columns:1fr;
    }

    .location-map{
        min-height:220px;
        border-right:0;
        border-bottom:1px solid rgba(126,216,255,.16);
    }

    .location-content{
        padding:0 24px 26px;
    }

    .form-row{
        grid-template-columns:1fr;
    }

    .phone-control{
        grid-template-columns:96px minmax(0,1fr);
    }
}

.project-card{
    isolation:isolate;
}

.project-card > img{
    width:100%;
    height:100%;
    display:block;
    object-fit:cover;
    object-position:top left;
    transform-origin:center;
}

.project-card::before{
    content:"";
    position:absolute;
    inset:0;
    z-index:1;
    background:linear-gradient(180deg,transparent 30%,rgba(3,7,18,.2) 56%,rgba(3,7,18,.9));
    pointer-events:none;
}

.project-demo-btn{
    position:absolute;
    right:22px;
    top:22px;
    z-index:3;
    min-height:42px;
    padding:0 18px;
    border:1px solid rgba(126,216,255,.42);
    border-radius:999px;
    color:#fff;
    background:linear-gradient(135deg,rgba(40,168,255,.92),rgba(125,69,255,.92));
    box-shadow:0 14px 32px rgba(40,168,255,.24);
    font-weight:900;
    cursor:pointer;
    opacity:0;
    transform:translateY(-8px);
    transition:opacity .24s ease,transform .24s ease,box-shadow .24s ease;
}

.project-card:hover .project-demo-btn,
.project-card:focus-within .project-demo-btn{
    opacity:1;
    transform:translateY(0);
}

.project-demo-btn:hover,
.project-demo-btn:focus-visible{
    box-shadow:0 18px 44px rgba(125,69,255,.34);
}

.demo-modal{
    position:fixed;
    inset:0;
    z-index:500;
    display:none;
    place-items:center;
    padding:24px;
}

.demo-modal.is-open{
    display:grid;
}

.demo-modal-backdrop{
    position:absolute;
    inset:0;
    background:rgba(3,7,18,.72);
    backdrop-filter:blur(12px);
}

.demo-modal-panel{
    position:relative;
    z-index:1;
    width:min(1040px,100%);
    max-height:min(760px,calc(100vh - 48px));
    overflow:hidden;
    display:grid;
    grid-template-rows:auto minmax(0,1fr);
    border:1px solid rgba(126,216,255,.26);
    border-radius:8px;
    background:linear-gradient(145deg,rgba(12,26,64,.96),rgba(5,12,34,.94)),radial-gradient(circle at 90% 10%,rgba(125,69,255,.22),transparent 34%);
    box-shadow:0 30px 100px rgba(0,0,0,.48);
}

body.light .demo-modal-panel{
    background:linear-gradient(145deg,rgba(255,255,255,.98),rgba(238,244,255,.94)),radial-gradient(circle at 90% 10%,rgba(125,69,255,.12),transparent 34%);
}

.demo-modal-head{
    padding:26px 30px 18px;
    border-bottom:1px solid rgba(126,216,255,.16);
}

.demo-modal-head span{
    color:var(--purple);
    font-size:.78rem;
    font-weight:900;
    text-transform:uppercase;
    letter-spacing:.08em;
}

.demo-modal-head h3{
    margin-top:10px;
    font-size:clamp(1.5rem,2.4vw,2.4rem);
    line-height:1.08;
}

.demo-modal-close{
    position:absolute;
    right:18px;
    top:18px;
    z-index:2;
    width:38px;
    height:38px;
    display:grid;
    place-items:center;
    border:1px solid rgba(126,216,255,.24);
    border-radius:8px;
    color:var(--text);
    background:rgba(255,255,255,.06);
    font-size:1.35rem;
    cursor:pointer;
}

.demo-modal-body{
    overflow:auto;
    padding:24px 30px 30px;
}

.demo-shell,
.demo-toolbar,
.demo-grid,
.demo-board,
.demo-list{
    display:grid;
    gap:12px;
}

.demo-shell{
    gap:18px;
}

.demo-toolbar{
    grid-template-columns:repeat(3,minmax(0,1fr));
}

.demo-kpi,
.demo-panel,
.demo-row,
.demo-zone{
    border:1px solid rgba(126,216,255,.18);
    border-radius:8px;
    background:rgba(255,255,255,.05);
    padding:16px;
}

.demo-kpi strong,
.demo-panel strong,
.demo-zone strong{
    display:block;
    color:var(--text);
    font-size:1.08rem;
}

.demo-kpi span,
.demo-panel span,
.demo-row span,
.demo-zone span{
    color:var(--muted);
    font-size:.88rem;
}

.demo-actions{
    display:flex;
    flex-wrap:wrap;
    gap:10px;
}

.demo-actions button,
.demo-row button,
.demo-zone button,
.demo-add button{
    min-height:38px;
    padding:0 14px;
    border:1px solid rgba(126,216,255,.28);
    border-radius:999px;
    color:var(--text);
    background:rgba(255,255,255,.06);
    font-weight:800;
    cursor:pointer;
}

.demo-actions button.is-active,
.demo-row.is-done,
.demo-zone.is-active{
    border-color:rgba(125,69,255,.52);
    background:rgba(125,69,255,.14);
}

.demo-grid,
.demo-board{
    grid-template-columns:repeat(3,minmax(0,1fr));
}

.demo-list{
    margin-top:8px;
}

.demo-row{
    display:grid;
    grid-template-columns:minmax(0,1fr) auto;
    align-items:center;
}

.demo-add{
    display:grid;
    grid-template-columns:minmax(0,1fr) auto;
    gap:10px;
}

.demo-add input{
    margin:0;
}

.demo-meter{
    height:10px;
    overflow:hidden;
    border-radius:999px;
    background:rgba(255,255,255,.08);
}

.demo-meter i{
    display:block;
    height:100%;
    width:var(--value,50%);
    border-radius:inherit;
    background:linear-gradient(90deg,var(--blue),var(--purple));
}

@media(max-width:760px){
    .project-demo-btn{
        opacity:1;
        transform:none;
    }

    .demo-modal{
        padding:12px;
    }

    .demo-toolbar,
    .demo-grid,
    .demo-board{
        grid-template-columns:1fr;
    }

    .demo-modal-head,
    .demo-modal-body{
        padding-left:18px;
        padding-right:18px;
    }
}

.location-grid{
    position:absolute;
    inset:0;
    background:linear-gradient(rgba(126,216,255,.4) 1px,transparent 1px),linear-gradient(90deg,rgba(126,216,255,.4) 1px,transparent 1px);
    background-size:34px 34px;
    mask-image:radial-gradient(circle at center,#000 0 52%,transparent 76%);
}

.demo-modal{
    padding:0;
    overflow:hidden;
}

.demo-modal-panel{
    width:100vw;
    height:100dvh;
    max-height:none;
    border:0;
    border-radius:0;
}

.demo-modal-head{
    padding:clamp(14px,2vh,22px) clamp(18px,3vw,32px) clamp(10px,1.5vh,16px);
}

.demo-modal-head h3{
    margin-top:6px;
    font-size:clamp(1.25rem,2vw,2rem);
}

.demo-modal-body{
    min-height:0;
    overflow:auto;
    overscroll-behavior:contain;
    padding:clamp(12px,2vw,24px);
}

.demo-modal-body:has(.demo-crud-app){
    overflow:auto;
}

.demo-crud-app{
    position:relative;
    width:100%;
    height:100%;
    min-height:0;
    max-height:100%;
    grid-template-columns:64px minmax(0,1fr);
}

.demo-crud-sidebar{
    min-height:0;
    padding:clamp(10px,1.6vh,16px) 10px;
    gap:clamp(8px,1.6vh,16px);
}

.demo-crud-sidebar span{
    width:clamp(34px,4vh,42px);
    height:clamp(34px,4vh,42px);
}

.demo-crud-main{
    height:100%;
    min-height:0;
    padding:clamp(12px,2vw,22px);
    grid-template-rows:auto auto minmax(0,1fr) auto;
    align-content:stretch;
    gap:clamp(8px,1.4vh,14px);
}

.demo-crud-head strong{
    font-size:clamp(1.05rem,1.6vw,1.55rem);
}

.demo-crud-head button,
.demo-crud-form button,
.demo-crud-form input,
.demo-crud-form select,
.demo-crud-search input{
    min-height:clamp(34px,4.5vh,42px);
}

.demo-crud-table-wrap{
    min-height:0;
    max-height:100%;
}

.demo-crud-table th,
.demo-crud-table td{
    padding:clamp(8px,1.25vh,12px) 10px;
}

.demo-crud-form{
    min-height:0;
    gap:clamp(8px,1.2vh,10px);
}

.demo-crud-dialog-root{
    position:absolute;
    inset:0;
    z-index:8;
    pointer-events:none;
}

.demo-crud-dialog{
    position:absolute;
    inset:0;
    display:grid;
    place-items:center;
    padding:clamp(14px,3vw,32px);
    pointer-events:auto;
}

.demo-crud-dialog-backdrop{
    position:absolute;
    inset:0;
    background:rgba(3,7,18,.58);
    backdrop-filter:blur(10px);
}

.demo-crud-dialog-panel{
    position:relative;
    z-index:1;
    width:min(620px,100%);
    max-height:min(720px,calc(90dvh - 96px));
    overflow:auto;
    display:grid;
    gap:18px;
    padding:clamp(20px,3vw,30px);
    border:1px solid rgba(126,216,255,.28);
    border-radius:8px;
    background:linear-gradient(145deg,rgba(10,22,54,.98),rgba(5,12,34,.96)),radial-gradient(circle at 86% 12%,rgba(125,69,255,.2),transparent 34%);
    box-shadow:0 24px 80px rgba(0,0,0,.48);
}

body.light .demo-crud-dialog-panel{
    background:linear-gradient(145deg,rgba(255,255,255,.98),rgba(238,244,255,.96)),radial-gradient(circle at 86% 12%,rgba(125,69,255,.12),transparent 34%);
}

.demo-crud-dialog-panel-small{
    width:min(440px,100%);
}

.demo-crud-dialog-head{
    padding-right:36px;
}

.demo-crud-dialog-head strong{
    display:block;
    color:var(--text);
    font-size:clamp(1.25rem,2vw,1.7rem);
    line-height:1.12;
}

.demo-crud-dialog-head span{
    display:block;
    margin-top:8px;
    color:var(--muted);
    line-height:1.55;
}

.demo-crud-dialog-close{
    position:absolute;
    top:14px;
    right:14px;
    width:34px;
    height:34px;
    display:grid;
    place-items:center;
    border:1px solid rgba(126,216,255,.24);
    border-radius:8px;
    color:var(--text);
    background:rgba(255,255,255,.06);
    font-size:1.2rem;
    cursor:pointer;
}

.demo-crud-dialog-grid{
    display:grid;
    grid-template-columns:repeat(2,minmax(0,1fr));
    gap:14px;
}

.demo-crud-dialog-grid label{
    margin:0;
    gap:8px;
}

.demo-crud-dialog-grid label:last-child{
    grid-column:1 / -1;
}

.demo-crud-dialog-grid input,
.demo-crud-dialog-grid select{
    min-height:42px;
    border-radius:8px;
}

.demo-crud-dialog-actions{
    display:flex;
    justify-content:flex-end;
    gap:10px;
    flex-wrap:wrap;
}

.demo-crud-dialog-actions button{
    min-height:40px;
    padding:0 16px;
    border:1px solid rgba(126,216,255,.24);
    border-radius:8px;
    color:var(--text);
    background:rgba(255,255,255,.06);
    font-weight:900;
    cursor:pointer;
}

.demo-crud-dialog-actions button[type="submit"]{
    border-color:transparent;
    color:#fff;
    background:linear-gradient(135deg,var(--blue),var(--purple));
}

.demo-crud-dialog-actions .is-danger{
    border-color:rgba(251,113,133,.38);
    color:#fff;
    background:linear-gradient(135deg,#fb7185,#be123c);
}

@media(max-width:960px){
    .demo-crud-app{
        grid-template-columns:1fr;
        grid-template-rows:auto minmax(0,1fr);
    }

    .demo-crud-sidebar{
        padding:10px 12px;
    }

    .demo-crud-form{
        grid-template-columns:repeat(3,minmax(0,1fr));
    }
}

@media(max-width:760px){
    .demo-modal-close{
        right:12px;
        top:12px;
    }

    .demo-modal-head,
    .demo-modal-body{
        padding-left:12px;
        padding-right:12px;
    }

    .demo-crud-main{
        padding:12px;
    }

    .demo-crud-head{
        gap:8px;
    }

    .demo-crud-form{
        grid-template-columns:repeat(2,minmax(0,1fr));
    }

    .demo-crud-form button{
        grid-column:1 / -1;
    }

    .demo-crud-dialog{
        padding:12px;
    }

    .demo-crud-dialog-grid{
        grid-template-columns:1fr;
    }

    .demo-crud-dialog-actions{
        justify-content:stretch;
    }

    .demo-crud-dialog-actions button{
        flex:1 1 150px;
    }
}

@media(max-width:520px){
    .demo-crud-table{
        min-width:720px;
    }

    .demo-crud-form{
        grid-template-columns:1fr;
    }
}

@media(max-height:720px){
    .demo-crud-sidebar{
        display:none;
    }

    .demo-crud-app{
        grid-template-columns:1fr;
    }

    .demo-crud-head span,
    .demo-crud-search span,
    .demo-crud-form label > span{
        font-size:.78rem;
    }
}

*{
    scrollbar-width:thin;
    scrollbar-color:rgba(125,69,255,.82) rgba(5,12,34,.46);
}

::-webkit-scrollbar{
    width:12px;
    height:12px;
}

::-webkit-scrollbar-track{
    background:linear-gradient(180deg,rgba(5,12,34,.54),rgba(12,26,64,.42));
    border-radius:999px;
}

::-webkit-scrollbar-thumb{
    min-height:44px;
    /* border:3px solid rgba(5,12,34,.84); */
    border-radius:999px;
    background:linear-gradient(135deg,rgba(40,168,255,.92),rgba(125,69,255,.96));
    box-shadow:inset 0 0 0 1px rgba(255,255,255,.18),0 0 18px rgba(125,69,255,.34);
}

::-webkit-scrollbar-thumb:hover{
    background:linear-gradient(135deg,rgba(101,214,255,1),rgba(168,85,247,1));
    box-shadow:inset 0 0 0 1px rgba(255,255,255,.28),0 0 24px rgba(125,69,255,.54);
}

::-webkit-scrollbar-corner{
    background:rgba(5,12,34,.72);
}

body.light *{
    scrollbar-color:rgba(125,69,255,.82) rgba(224,235,255,.72);
}

body.light ::-webkit-scrollbar-track{
    background:linear-gradient(180deg,rgba(237,244,255,.9),rgba(217,228,255,.74));
}

body.light ::-webkit-scrollbar-thumb{
    border-color:rgba(237,244,255,.92);
}

.project-card-actions .project-demo-btn{
    position:relative;
    overflow:hidden;
    isolation:isolate;
    transition:opacity .24s ease,transform .24s ease,border-color .24s ease,box-shadow .24s ease,background .24s ease;
}

.project-card-actions .project-demo-btn::before{
    content:"";
    position:absolute;
    inset:-40% -120%;
    z-index:-1;
    background:linear-gradient(110deg,transparent 35%,rgba(255,255,255,.36) 50%,transparent 65%);
    transform:translateX(-42%);
    transition:transform .58s ease;
}

.project-card-actions .project-demo-btn:hover,
.project-card-actions .project-demo-btn:focus-visible{
    border-color:rgba(168,85,247,.82);
    background:linear-gradient(135deg,rgba(125,69,255,.98),rgba(40,168,255,.92));
    box-shadow:0 18px 46px rgba(125,69,255,.42),0 0 0 4px rgba(125,69,255,.16);
    transform:translateY(-2px);
}

.project-card-actions .project-demo-btn:hover::before,
.project-card-actions .project-demo-btn:focus-visible::before{
    transform:translateX(48%);
}

.demo-modal-close,
.demo-crud-dialog-close,
.demo-crud-table button,
.demo-crud-dialog-actions button,
.demo-crud-head button{
    transition:transform .22s ease,border-color .22s ease,color .22s ease,background .22s ease,box-shadow .22s ease,opacity .22s ease;
}

.demo-modal-close:hover,
.demo-modal-close:focus-visible,
.demo-crud-dialog-close:hover,
.demo-crud-dialog-close:focus-visible{
    color:#fff;
    border-color:rgba(168,85,247,.68);
    background:linear-gradient(135deg,rgba(40,168,255,.18),rgba(125,69,255,.28));
    box-shadow:0 0 0 4px rgba(125,69,255,.14),0 16px 34px rgba(0,0,0,.28);
    transform:rotate(90deg) scale(1.06);
}

.demo-crud-head button:hover,
.demo-crud-head button:focus-visible,
.demo-crud-dialog-actions button:hover,
.demo-crud-dialog-actions button:focus-visible,
.demo-crud-table button:hover,
.demo-crud-table button:focus-visible{
    border-color:rgba(168,85,247,.58);
    color:#fff;
    background:linear-gradient(135deg,rgba(40,168,255,.22),rgba(125,69,255,.3));
    box-shadow:0 12px 28px rgba(125,69,255,.24);
    transform:translateY(-1px);
}

.demo-crud-table button[data-crud-action="delete"]:hover,
.demo-crud-table button[data-crud-action="delete"]:focus-visible,
.demo-crud-dialog-actions .is-danger:hover,
.demo-crud-dialog-actions .is-danger:focus-visible{
    border-color:rgba(251,113,133,.72);
    background:linear-gradient(135deg,rgba(251,113,133,.22),rgba(190,18,60,.38));
    box-shadow:0 12px 30px rgba(251,113,133,.24);
}

.demo-crud-dialog-actions button:disabled,
.demo-crud-dialog-actions button[aria-disabled="true"]{
    cursor:not-allowed;
    opacity:.46;
    transform:none;
    box-shadow:none;
}

.demo-crud-delete-name{
    display:inline-flex;
    align-items:center;
    width:max-content;
    max-width:100%;
    margin-right:6px;
    padding:5px 10px;
    border:1px solid rgba(251,113,133,.38);
    border-radius:999px;
    color:#fff;
    background:linear-gradient(135deg,rgba(251,113,133,.24),rgba(125,69,255,.22));
    font-weight:900;
    box-shadow:0 0 24px rgba(251,113,133,.18);
}

.demo-crud-view-list{
    display:grid;
    gap:10px;
    margin:0;
}

.demo-crud-view-list div{
    display:grid;
    grid-template-columns:minmax(92px,.34fr) minmax(0,1fr);
    gap:12px;
    align-items:center;
    padding:12px;
    border:1px solid rgba(126,216,255,.14);
    border-radius:8px;
    background:rgba(255,255,255,.045);
}

.demo-crud-view-list dt{
    color:var(--muted);
    font-size:.78rem;
    font-weight:900;
    text-transform:uppercase;
}

.demo-crud-view-list dd{
    margin:0;
    color:var(--text);
    font-weight:800;
    overflow-wrap:anywhere;
}

.demo-crud-sidebar strong{
    color:var(--purple);
    text-shadow:0 0 22px rgba(125,69,255,.55);
}

.demo-crud-table-wrap{
    overflow:auto;
    overscroll-behavior:contain;
    max-height:min(100%,58vh);
}

.demo-crud-table th:first-child,
.demo-crud-table td:first-child,
.demo-crud-table th:last-child,
.demo-crud-table td:last-child{
    position:sticky;
    z-index:2;
    background:linear-gradient(145deg,rgba(7,15,38,.98),rgba(5,12,34,.96));
    box-shadow:12px 0 20px rgba(0,0,0,.18);
}

.demo-crud-table th:first-child,
.demo-crud-table td:first-child{
    left:0;
}

.demo-crud-table th:last-child,
.demo-crud-table td:last-child{
    right:0;
    box-shadow:-12px 0 20px rgba(0,0,0,.18);
}

.demo-crud-table th:first-child,
.demo-crud-table th:last-child{
    z-index:3;
}

.demo-crud-table tbody tr:hover{
    background:rgba(40,168,255,.08);
}

.demo-crud-table tbody tr:hover td:first-child,
.demo-crud-table tbody tr:hover td:last-child,
.demo-crud-table tr.is-selected td:first-child,
.demo-crud-table tr.is-selected td:last-child{
    background:linear-gradient(145deg,rgba(9,27,63,.98),rgba(9,17,46,.98));
}

.demo-crud-table tr.is-flash-add,
.demo-crud-table tr.is-flash-add td:first-child,
.demo-crud-table tr.is-flash-add td:last-child{
    animation:crudFlashAdd 2s ease forwards;
}

.demo-crud-table tr.is-flash-edit,
.demo-crud-table tr.is-flash-edit td:first-child,
.demo-crud-table tr.is-flash-edit td:last-child{
    animation:crudFlashEdit 2s ease forwards;
}

@keyframes crudFlashAdd{
    0%,28%{background:rgba(34,197,94,.28)}
    100%{background:transparent}
}

@keyframes crudFlashEdit{
    0%,28%{background:rgba(40,168,255,.28)}
    100%{background:transparent}
}

.demo-crud-dialog-primary,
.demo-crud-dialog-actions button[type="submit"]{
    border-color:transparent;
    color:#fff;
    background:linear-gradient(135deg,var(--blue),var(--purple));
}

.demo-crud-dialog-grid input[type="date"]{
    color-scheme:dark;
}

.demo-crud-dialog-grid input[type="date"]::-webkit-calendar-picker-indicator{
    cursor:pointer;
    filter:invert(1) brightness(1.35);
    opacity:.92;
}

.demo-crud-dialog-grid input[type="date"]::-webkit-calendar-picker-indicator:hover{
    filter:invert(1) brightness(1.8) drop-shadow(0 0 6px rgba(125,69,255,.65));
}

.demo-crud-delete-line{
    display:flex!important;
    align-items:center;
    gap:6px;
    flex-wrap:wrap;
}

.demo-crud-delete-name{
    margin-right:0;
    padding:4px 8px;
    font-size:.86rem;
    line-height:1.1;
}

.demo-crud-view-list div{
    border-color:rgba(126,216,255,.28);
}

body.light .demo-modal-close:hover,
body.light .demo-modal-close:focus-visible,
body.light .demo-crud-dialog-close:hover,
body.light .demo-crud-dialog-close:focus-visible,
body.light .demo-crud-head button:hover,
body.light .demo-crud-head button:focus-visible,
body.light .demo-crud-dialog-actions button:hover,
body.light .demo-crud-dialog-actions button:focus-visible,
body.light .demo-crud-table button:hover,
body.light .demo-crud-table button:focus-visible{
    color:#071126;
}

body.light .demo-status.is-active{
    color:#047857;
    background:rgba(16,185,129,.26);
    box-shadow:inset 0 0 0 1px rgba(4,120,87,.18),0 8px 22px rgba(16,185,129,.14);
}

body.light .demo-status.is-inactive{
    color:#be123c;
    background:rgba(244,63,94,.22);
    box-shadow:inset 0 0 0 1px rgba(190,18,60,.18),0 8px 22px rgba(244,63,94,.14);
}

body.light .demo-crud-table th:first-child,
body.light .demo-crud-table td:first-child,
body.light .demo-crud-table th:last-child,
body.light .demo-crud-table td:last-child{
    background:linear-gradient(145deg,rgba(255,255,255,.98),rgba(239,244,255,.96));
}

body.light .demo-crud-table tbody tr:hover td:first-child,
body.light .demo-crud-table tbody tr:hover td:last-child,
body.light .demo-crud-table tr.is-selected td:first-child,
body.light .demo-crud-table tr.is-selected td:last-child{
    background:linear-gradient(145deg,rgba(232,242,255,.98),rgba(239,233,255,.98));
}

body.light .demo-crud-dialog-grid input[type="date"]{
    color-scheme:light;
}

body.light .demo-crud-dialog-grid input[type="date"]::-webkit-calendar-picker-indicator{
    filter:none;
}

.toast-stack{
    z-index:2400;
}

.demo-crud-main{
    overflow:hidden;
}

.demo-crud-table-wrap{
    height:100%;
    max-height:100%;
    overflow:auto;
    touch-action:pan-x pan-y;
}

.demo-crud-table th:last-child,
.demo-crud-table td:last-child{
    box-shadow:none;
}

.demo-crud-primary-btn.demo-crud-dialog-primary{
    border:1px solid rgba(126,216,255,.24);
}

.demo-crud-dialog-head .demo-crud-delete-line{
    display:inline-flex!important;
    width:auto;
    max-width:100%;
    align-items:center;
    gap:6px;
    flex-wrap:nowrap;
    white-space:nowrap;
}

.demo-crud-dialog-head .demo-crud-delete-name{
    display:inline-flex;
    margin-top:0;
    padding:3px 8px;
    font-size:.78rem;
    line-height:1;
}

@media(min-width:1131px){
    body.light .nav a:not(:last-of-type)::after{
        background:rgba(7,17,38,.28);
    }
}

.demo-crud-table thead th{
    position:sticky;
    top:0;
    z-index:4;
    background:linear-gradient(145deg,rgba(7,15,38,.99),rgba(5,12,34,.98));
    box-shadow:0 1px 0 rgba(126,216,255,.16),0 10px 24px rgba(0,0,0,.18);
}

.demo-crud-table thead th:first-child,
.demo-crud-table thead th:last-child{
    z-index:6;
}

body.light .demo-crud-table thead th{
    background:linear-gradient(145deg,rgba(255,255,255,.99),rgba(239,244,255,.98));
    box-shadow:0 1px 0 rgba(7,17,38,.12),0 10px 24px rgba(30,64,175,.08);
}

body.light .toast strong{
    color:var(--purple);
}

.demo-crud-dialog-grid input.is-invalid,
.demo-crud-dialog-grid select.is-invalid{
    border-color:#fb7185;
    box-shadow:0 0 0 3px rgba(251,113,133,.18),0 0 22px rgba(251,113,133,.18);
}

.demo-crud-dialog-grid label.has-error > span{
    color:#fb7185;
}

.demo-crud-field-error{
    min-height:1.2em;
    color:#fb7185;
    font-size:.76rem;
    font-weight:800;
    line-height:1.35;
}

.field-error{
    margin-top:-8px;
    color:#fb7185;
    font-size:.78rem;
    font-weight:800;
    line-height:1.35;
}

.contact-form label:has(.field-error:not(:empty)){
    gap:8px;
}

.contact-form .btn:disabled,
.contact-form .btn[aria-disabled="true"]{
    cursor:not-allowed;
    opacity:.48;
    filter:saturate(.72);
    transform:none;
    box-shadow:none;
}

.toast-stack{
    right:24px;
    left:auto;
    align-items:end;
}

.toast{
    width:100%;
}

.demo-crud-dialog-head .demo-crud-delete-line{
    white-space:normal;
    overflow-wrap:anywhere;
}

.demo-crud-dialog-head .demo-crud-delete-name{
    flex:0 0 auto;
    white-space:nowrap;
}

.demo-crud-dialog-panel-delete{
    width:min(560px,100%);
}

.demo-crud-dialog-panel-delete .demo-crud-delete-line{
    display:flex!important;
    width:100%;
    min-width:0;
    align-items:center;
    gap:7px;
    flex-wrap:wrap;
    white-space:normal;
    overflow-wrap:normal;
}

.demo-crud-delete-text{
    min-width:0;
    overflow-wrap:anywhere;
}

.contact-form label:has(.field-counter){
    grid-template-columns:minmax(0,1fr) auto;
    align-items:start;
}

.contact-form label:has(.field-counter) > span,
.contact-form label:has(.field-counter) > input,
.contact-form label:has(.field-counter) > textarea{
    grid-column:1 / -1;
}

.contact-form label:has(.field-counter) > .field-error{
    grid-column:1;
    grid-row:4;
    margin-top:-2px;
}

.contact-form label:has(.field-counter) > .field-counter{
    grid-column:2;
    grid-row:4;
    margin-top:-2px;
}

.contact-form label:not(:has(.field-counter)) > .field-error{
    margin-top:4px;
}

.contact-form .btn.is-disabled,
.contact-form .btn[aria-disabled="true"]{
    cursor:not-allowed;
    opacity:.48;
    filter:saturate(.72);
    transform:none;
    box-shadow:none;
}

@media (max-width: 560px){
    .demo-crud-dialog-panel-delete .demo-crud-delete-line{
        display:grid!important;
        gap:8px;
        align-items:start;
    }

    .demo-crud-dialog-panel-delete .demo-crud-delete-text{
        display:block;
        width:100%;
    }
}

.topbar{
    transition:transform .32s ease, opacity .32s ease, box-shadow .32s ease, background .32s ease;
    will-change:transform;
}

.topbar.is-hidden{
    transform:translateY(calc(-100% - 18px));
    opacity:0;
    pointer-events:none;
}

.topbar.is-scrolled{
    box-shadow:0 18px 54px rgba(0,0,0,.34);
}

@media(max-width:760px){
    input,
    select,
    textarea{
        font-size:16px;
    }
}

@media(max-width:600px){
    .script-words{
        gap:7px;
        margin-top:12px;
    font-size:clamp(.5rem,5vw,3rem);
    }

    .script-words .eyebrow{
        padding:4px 7px;
        border-radius:12px;
        font-size:inherit;
        line-height:1.15;
    }
}

.hero-left h1{
    font-size:clamp(2.8rem,5vw,5.4rem);
}

@media(max-width:760px){
    .hero-actions{
        flex-direction:column;
        gap:14px;
    }

    .hero-actions > *{
        width:100%;
        flex:1 1 auto;
        justify-content:center;
    }

    .hero-actions .arrow,
    .hero-actions .bubble-icon{
        margin-left:auto;
    }
}

@media(max-width:600px){
    .service-card ul{
        grid-template-columns:1fr;
    }

    .service-card ul li,
    .service-card ul li.service-list-wide{
        grid-column:1/-1;
        width:100%;
        white-space:normal;
        overflow-wrap:anywhere;
        min-width:0;
    }
}
.service-list-wide{white-space:normal;overflow-wrap:anywhere;word-break:normal;min-width:0;line-height:1.25;text-align:center}
.service-card ul li.service-list-wide{white-space:normal;overflow-wrap:anywhere;word-break:normal;min-width:0;line-height:1.25;text-align:center}
.service-card li{
    width:auto;
    min-width:0;
    flex:1 1 calc(100% - 10px);
    padding:9px 13px;
    color:var(--muted);
    font-size:.92rem;
    text-align:center;
    white-space:nowrap;
}

@media(max-width:600px){
    .service-card ul{
        display:flex;
        flex-wrap:wrap;
    }

    .service-card ul li,
    .service-card ul li.service-list-wide{
        width:auto;
        min-width:0;
        flex:1 1 calc(100% - 10px);
        padding:9px 13px;
        color:var(--muted);
        font-size:.92rem;
        text-align:center;
        white-space:nowrap;
    }
}
@media(max-width:500px){
    .demo-crud-table td.demo-crud-actions-cell{
        position:sticky;
        right:0;
        z-index:5;
        display:table-cell!important;
        overflow:visible;
        min-width:54px;
        text-align:center;
        background:linear-gradient(145deg,rgba(7,15,38,.98),rgba(5,12,34,.96));
    }

    body.light .demo-crud-table td.demo-crud-actions-cell{
        background:linear-gradient(145deg,rgba(255,255,255,.98),rgba(239,244,255,.96));
    }
}
/* Demo modal scroll refinements */
.demo-crud-view-dialog{
    grid-template-rows:auto minmax(0,1fr) auto;
    max-height:min(560px,calc(100dvh - 24px));
}

.demo-crud-view-dialog .demo-crud-dialog-body{
    min-height:0;
    overflow:auto;
    -webkit-overflow-scrolling:touch;
}

.demo-tpm-detail-dialog{
    width:min(1180px,calc(100vw - 24px));
    max-height:calc(100dvh - 32px);
    grid-template-rows:auto minmax(0,1fr) auto;
}

.demo-tpm-detail-dialog .demo-crud-dialog-body{
    min-height:0;
    display:grid;
    gap:14px;
    overflow:auto;
    -webkit-overflow-scrolling:touch;
}

.demo-tpm-detail-table-wrap{
    max-height:none;
    overflow-x:auto;
    overflow-y:visible;
}

.demo-tpm-detail-table-wrap th{
    position:static;
}

@media(max-width:760px){
    .demo-crud-view-dialog,
    .demo-tpm-detail-dialog{
        max-height:calc(100dvh - 24px);
    }
}
