*{
    margin:0;
    padding:0;
    box-sizing:border-box;
}

:root{
    --bg:#07080d;
    --panel:#10121a;
    --panel-soft:rgba(16,18,26,.78);
    --orange:#ff9b3d;
    --orange-soft:rgba(255,155,61,.22);
    --text:#f5f5f5;
    --muted:#9ca3af;
    --line:rgba(255,155,61,.16);
}

html,
body{
    min-height:100%;
    scroll-behavior:smooth;
}

body{
    background:
        radial-gradient(circle at 20% 10%, rgba(255,155,61,.10), transparent 30%),
        radial-gradient(circle at 80% 20%, rgba(80,120,255,.06), transparent 30%),
        var(--bg);
    color:var(--text);
    font-family:'Rajdhani', Arial, sans-serif;
    overflow-x:hidden;
}

body::before{
    content:'';
    position:fixed;
    inset:0;
    background:
        radial-gradient(circle at 20% 20%, rgba(255,155,61,.05), transparent 28%),
        radial-gradient(circle at 80% 30%, rgba(64,120,255,.04), transparent 28%);
    animation:ambientMove 30s ease-in-out infinite alternate;
    pointer-events:none;
    z-index:-1;
    opacity:.7;
}

@keyframes ambientMove{
    0%{ transform:translate3d(0,0,0) scale(1); }
    100%{ transform:translate3d(-40px,-30px,0) scale(1.08); }
}

h1,
h2,
h3,
.brand,
.section-label{
    font-family:'Orbitron', sans-serif;
    letter-spacing:.04em;
}

.navbar,
.hero,
.about-section,
.section-heading,
.portfolio-grid,
.portfolio-more,
.portfolio-page-header,
.project-hero,
.contact-page,
.footer{
    position:relative;
    z-index:1;
}

.bg-particles{
    position:fixed;
    inset:0;
    overflow:hidden;
    pointer-events:none;
    z-index:0;
}

.bg-particles::before,
.bg-particles::after{
    content:'';
    position:absolute;
    inset:-20%;
    background-image:
        radial-gradient(rgba(255,155,61,.16) 1px, transparent 1px),
        radial-gradient(rgba(255,255,255,.08) 1px, transparent 1px);
    background-size:180px 180px,240px 240px;
    animation:particlesFloat 30s linear infinite;
    opacity:.35;
}

.bg-particles::after{
    animation-duration:45s;
    opacity:.18;
    transform:scale(1.2);
}

@keyframes particlesFloat{
    from{ transform:translateY(0); }
    to{ transform:translateY(-120px); }
}

.card-link{
    text-decoration:none;
    color:inherit;
    display:block;
}

.section-label{
    color:var(--orange);
    font-weight:800;
    text-transform:uppercase;
    letter-spacing:2px;
    font-size:.8rem;
}
.card-description{
    margin-top:24px;
    color:#b0b0b0;
    line-height:1.8;
}
.btn{
    display:inline-flex;
    align-items:center;
    justify-content:center;
    padding:14px 24px;
    border-radius:999px;
    text-decoration:none;
    font-weight:700;
    position:relative;
    overflow:hidden;
    transition:transform .35s ease, box-shadow .35s ease, border-color .35s ease, background .35s ease;
}

.btn.primary{
    background:var(--orange);
    color:#0b0b0f;
}

.btn.secondary{
    border:1px solid rgba(255,155,61,.4);
    color:var(--text);
}

.btn:hover{
    transform:translateY(-2px) scale(1.02);
}

.btn::before,
.project-back-btn::before{
    content:'';
    position:absolute;
    top:0;
    left:-120%;
    width:80%;
    height:100%;
    background:linear-gradient(90deg, transparent, rgba(255,255,255,.28), transparent);
    transform:skewX(-20deg);
    transition:.55s;
}

.btn:hover::before,
.project-back-btn:hover::before{
    left:140%;
}

.navbar{
    position:fixed;
    top:0;
    left:0;
    width:100%;
    padding:24px 60px;
    display:flex;
    justify-content:space-between;
    align-items:center;
    z-index:100;
    background:rgba(7,8,13,.72);
    backdrop-filter:blur(18px);
    border-bottom:1px solid var(--line);
}

.brand{
    color:var(--orange);
    font-size:1.4rem;
    font-weight:800;
}
.card-description{
    display:block;
    margin-top:36px !important;
    padding-top:24px;
    border-top:1px solid rgba(255,255,255,.06);
}
.nav-links{
    display:flex;
    gap:30px;
}

.nav-links a{
    color:var(--text);
    text-decoration:none;
    transition:.25s;
}

.nav-links a:hover{
    color:var(--orange);
}

.hero{
    min-height:100vh;
    display:flex;
    justify-content:center;
    align-items:center;
    text-align:center;
    padding:120px 40px 40px;
    overflow:hidden;
}

.hero-video{
    position:absolute;
    inset:0;
    width:100%;
    height:100%;
    object-fit:cover;
    z-index:0;
}

.hero-overlay{
    position:absolute;
    inset:0;
    background:linear-gradient(rgba(11,11,15,.65), rgba(11,11,15,.88));
    z-index:1;
}

.hero::after{
    content:'';
    position:absolute;
    left:0;
    bottom:0;
    width:100%;
    height:220px;
    background:linear-gradient(to bottom, rgba(11,11,15,0), rgba(11,11,15,.45), var(--bg));
    z-index:1;
}

.hero-content{
    position:relative;
    z-index:2;
    max-width:900px;
}

.hero-logo{
    width:250px;
    max-width:90%;
    user-select:none;
    filter:drop-shadow(0 0 25px rgba(255,155,61,.22));
}

.subtitle{
    margin-top:20px;
    color:var(--muted);
    font-size:1.25rem;
    line-height:1.6;
}

.hero-buttons{
    margin-top:35px;
    display:flex;
    justify-content:center;
    gap:20px;
}

.about-section{
    background:transparent;
    padding:100px 60px;
}

.about-section::before{
    content:'';
    display:block;
    width:720px;
    max-width:90%;
    height:2px;
    margin:0 auto 80px;
    background:linear-gradient(90deg, transparent, rgba(255,155,61,.9), transparent);
    box-shadow:0 0 20px rgba(255,155,61,.35);
}

.about-content,
.project-panel,
.contact-card,
.card{
    background:linear-gradient(145deg, rgba(18,20,30,.92), rgba(8,9,14,.92));
    border:1px solid var(--line);
    box-shadow:0 0 30px rgba(255,155,61,.08), inset 0 0 20px rgba(255,255,255,.02);
    backdrop-filter:blur(12px);
}

.about-content{
    max-width:900px;
    margin:0 auto;
    border-radius:28px;
    padding:50px;
}

.about-content h2{
    margin-top:18px;
    font-size:2.5rem;
    line-height:1.2;
}

.about-content p{
    margin-top:22px;
    color:#b0b0b0;
    font-size:1.1rem;
    line-height:1.8;
}

.section-heading{
    background:transparent;
    text-align:center;
    padding:80px 40px 20px;
}

.section-heading h2{
    margin-top:16px;
    font-size:3rem;
}

.section-heading p{
    margin:18px auto 0;
    max-width:700px;
    color:var(--muted);
    line-height:1.7;
}

.portfolio-grid{
    display:grid;
    grid-template-columns:repeat(auto-fit,minmax(420px,1fr));
    gap:40px;
    padding:80px;
    background:transparent;
}

.card{
    border-radius:24px;
    overflow:hidden;
    padding:24px;
    transition:transform .35s ease, border-color .35s ease, box-shadow .35s ease, background .35s ease;
    will-change:transform;
    cursor:pointer;
    position:relative;
}

.card:hover,
.project-panel:hover{
    border-color:var(--orange);
    box-shadow:0 0 40px rgba(255,155,61,.22), inset 0 0 20px rgba(255,255,255,.03), 0 20px 60px rgba(0,0,0,.45);
}

.card:hover{
    transform:translateY(-10px) scale(1.01);
}

.card-badge{
    display:inline-block;
    margin-bottom:20px;
    padding:6px 12px;
    border-radius:999px;
    background:rgba(255,155,61,.12);
    color:var(--orange);
    font-size:.8rem;
    font-weight:800;
    text-transform:uppercase;
}

.card h2,
.project-panel h2,
.project-block h2{
    color:var(--orange);
}

.card p,
.project-panel p{
    color:#b0b0b0;
    line-height:1.8;
}

.card-top h2{
    display:flex;
    justify-content:space-between;
    align-items:center;
    gap:20px;
    margin-bottom:18px;
}

.card-meta{
    display:flex;
    flex-direction:column;
    align-items:flex-end;
    color:#6b7280;
    font-size:.8rem;
    white-space:nowrap;
}

.card-video,
.card-image{
    width:100%;
    aspect-ratio:16/9;
    border-radius:18px;
    background:#000;
    object-fit:cover;
    border:1px solid rgba(255,155,61,.08);
    box-shadow:0 0 30px rgba(255,155,61,.05);
}

.card-video.small{ max-height:220px; }
.card-video.medium{ max-height:420px; }
.card-video.large{ aspect-ratio:21/9; max-height:920px; }
.card-video.fullscreen{ height:80vh; aspect-ratio:21/9; }

.model-placeholder{
    width:100%;
    aspect-ratio:16/9;
    border-radius:16px;
    margin-bottom:22px;
    background:linear-gradient(135deg,#15151c,#09090b);
    border:1px solid rgba(255,155,61,.2);
    display:flex;
    align-items:center;
    justify-content:center;
    color:var(--orange);
    font-weight:800;
}

.portfolio-more{
    width:100%;
    display:flex;
    justify-content:center;
    align-items:center;
    padding:40px 0 120px;
    background:transparent;
}

.portfolio-more .btn{
    display:inline-flex;
    align-items:center;
    justify-content:center;
}

.portfolio-page-header{
    padding:180px 40px 80px;
    text-align:center;
    background:transparent;
}

.portfolio-page-header h1,
.project-content h1,
.contact-info h1{
    font-size:4rem;
    color:var(--orange);
    text-shadow:0 0 24px rgba(255,155,61,.25), 0 0 70px rgba(255,155,61,.12);
}

.portfolio-page-header p{
    margin:24px auto 0;
    max-width:800px;
    color:var(--muted);
    line-height:1.8;
    font-size:1.1rem;
}

.project-hero{
    min-height:100vh;
    padding:180px 60px 120px;
    background:
        linear-gradient(rgba(7,8,13,.70), rgba(7,8,13,.88)),
        repeating-linear-gradient(90deg, rgba(255,255,255,.025) 0, rgba(255,255,255,.025) 1px, transparent 1px, transparent 90px),
        repeating-linear-gradient(0deg, rgba(255,255,255,.018) 0, rgba(255,255,255,.018) 1px, transparent 1px, transparent 90px);
}

.project-content{
    position:relative;
    max-width:1200px;
    margin:0 auto;
}

.project-content::before{
    content:'';
    position:absolute;
    top:80px;
    left:50%;
    width:520px;
    height:520px;
    transform:translateX(-50%);
    background:radial-gradient(circle, rgba(255,155,61,.14), transparent 65%);
    filter:blur(20px);
    pointer-events:none;
    z-index:0;
}

.project-content > *{
    position:relative;
    z-index:1;
}

.project-topbar{
    display:flex;
    align-items:center;
    justify-content:space-between;
    gap:20px;
    margin-bottom:40px;
}

.project-back-btn{
    display:inline-flex;
    align-items:center;
    gap:10px;
    padding:14px 22px;
    border-radius:18px;
    text-decoration:none;
    color:var(--text);
    background:rgba(18,20,30,.82);
    border:1px solid var(--line);
    backdrop-filter:blur(10px);
    transition:transform .35s ease, box-shadow .35s ease, border-color .35s ease, background .35s ease;
    font-weight:700;
    position:relative;
    overflow:hidden;
}

.project-back-btn:hover{
    border-color:var(--orange);
    box-shadow:0 0 25px rgba(255,155,61,.18);
    transform:translateY(-2px) scale(1.02);
}

.project-type-pill{
    padding:10px 18px;
    border-radius:999px;
    background:rgba(255,155,61,.12);
    border:1px solid rgba(255,155,61,.2);
    color:var(--orange);
    font-size:.82rem;
    font-weight:800;
    text-transform:uppercase;
    letter-spacing:.08em;
    box-shadow:0 0 18px rgba(255,155,61,.12);
    transition:box-shadow .35s ease, transform .35s ease;
}

.project-type-pill:hover{
    box-shadow:0 0 30px rgba(255,155,61,.28);
}

.project-description{
    margin-top:24px;
    max-width:900px;
    color:#b0b0b0;
    line-height:1.8;
    font-size:1.1rem;
}

.project-meta{
    margin-top:18px;
    color:#6b7280;
    font-size:.9rem;
}

.project-media{
    width:100%;
    margin-top:50px;
    border-radius:24px;
    aspect-ratio:16/9;
    background:#000;
    object-fit:cover;
    transition:transform .45s ease, box-shadow .45s ease, border-color .45s ease;
    border:1px solid rgba(255,155,61,.08);
    box-shadow:0 0 30px rgba(255,155,61,.05);
}

.project-media:hover{
    transform:scale(1.01);
    border-color:rgba(255,155,61,.28);
    box-shadow:0 0 45px rgba(255,155,61,.18), 0 20px 60px rgba(0,0,0,.45);
}

.project-panel{
    margin-top:50px;
    border-radius:28px;
    padding:40px;
    transition:transform .35s ease, box-shadow .35s ease, border-color .35s ease, background .35s ease;
    position:relative;
    overflow:hidden;
}

.project-panel:hover{
    transform:translateY(-4px);
}

.project-blocks{
    margin-top:80px;
}

.project-block{
    margin-top:40px;
}

.model-viewer{
    width:100%;
    height:500px;
    border-radius:24px;
    overflow:hidden;
    background:#050505;
    margin-top:50px;
    position:relative;
    box-shadow:0 0 35px rgba(255,155,61,.12), inset 0 0 40px rgba(255,255,255,.02);
}

.model-block .model-viewer{
    margin-top:24px;
}

.model-description{
    margin-top:24px;
    color:var(--muted);
    line-height:1.8;
}

.model-viewer::before{
    content:'';
    position:absolute;
    inset:0;
    background:linear-gradient(135deg, rgba(255,255,255,.05), transparent 25%);
    pointer-events:none;
    z-index:2;
}

.viewer-loading{
    position:absolute;
    inset:0;
    display:flex;
    align-items:center;
    justify-content:center;
    color:white;
    font-size:18px;
    font-weight:600;
    background:rgba(0,0,0,0.35);
    backdrop-filter:blur(4px);
    z-index:5;
}

.viewer-loading::after{
    content:'';
    width:34px;
    height:34px;
    margin-left:16px;
    border-radius:50%;
    border:3px solid rgba(255,255,255,.18);
    border-top-color:var(--orange);
    animation:spin 1s linear infinite;
}

@keyframes spin{
    to{ transform:rotate(360deg); }
}

.contact-page{
    min-height:100vh;
    padding:180px 60px 120px;
    background:transparent;
}

.contact-layout{
    max-width:1200px;
    margin:0 auto;
    display:grid;
    grid-template-columns:1fr 1.2fr;
    gap:60px;
    align-items:start;
}

.contact-info p{
    margin-top:24px;
    color:#b0b0b0;
    line-height:1.8;
    font-size:1.1rem;
}

.contact-card{
    border-radius:28px;
    padding:40px;
}

.contact-card label{
    display:block;
    margin-bottom:8px;
    color:var(--text);
    font-weight:700;
}

.contact-card input,
.contact-card textarea{
    width:100%;
    margin-bottom:22px;
    padding:14px 16px;
    border-radius:14px;
    border:1px solid rgba(255,255,255,.08);
    background:#0b0b0f;
    color:var(--text);
    outline:none;
}

.contact-card textarea{
    min-height:180px;
    resize:vertical;
}

.contact-card input:focus,
.contact-card textarea:focus{
    border-color:var(--orange);
}

.flash-success{
    margin-bottom:24px;
    padding:14px 16px;
    border-radius:14px;
    background:rgba(34,197,94,.12);
    color:#86efac;
    border:1px solid rgba(34,197,94,.25);
}

.footer{
    background:#07070a;
    border-top:1px solid var(--line);
    padding:40px 60px;
    display:flex;
    justify-content:space-between;
    align-items:center;
    color:var(--muted);
}

.footer-links{
    display:flex;
    gap:24px;
}

.footer-links a{
    color:var(--text);
    text-decoration:none;
}

.footer-links a:hover{
    color:var(--orange);
}

.fade-up{
    opacity:0;
    transform:translateY(30px);
    animation:fadeUp .9s ease forwards;
}

.fade-delay-1{ animation-delay:.12s; }
.fade-delay-2{ animation-delay:.24s; }
.fade-delay-3{ animation-delay:.36s; }

@keyframes fadeUp{
    to{
        opacity:1;
        transform:translateY(0);
    }
}

.card::before,
.project-panel::before{
    content:'';
    position:absolute;
    inset:0;
    background:linear-gradient(135deg, rgba(255,255,255,.04), transparent 35%);
    opacity:0;
    transition:opacity .35s ease;
    pointer-events:none;
}

.card:hover::before,
.project-panel:hover::before{
    opacity:1;
}

.project-panel::after,
.card::after,
.model-viewer::after{
    content:'';
    position:absolute;
    inset:0;
    background:repeating-linear-gradient(0deg, rgba(255,255,255,.015) 0px, rgba(255,255,255,.015) 1px, transparent 1px, transparent 3px);
    opacity:.18;
    pointer-events:none;
    mix-blend-mode:soft-light;
}

.section-divider{
    position:relative;
    width:100%;
    height:100px;
    overflow:hidden;
}

.section-divider::before{
    content:'';
    position:absolute;
    left:50%;
    top:50%;
    width:70%;
    height:1px;
    transform:translate(-50%, -50%);
    background:linear-gradient(90deg, transparent, rgba(255,155,61,.75), transparent);
}

.section-divider::after{
    content:'';
    position:absolute;
    left:50%;
    top:50%;
    width:10px;
    height:10px;
    transform:translate(-50%, -50%) rotate(45deg);
    background:var(--orange);
}

@media (max-width:900px){
    .navbar{
        padding:18px 24px;
        flex-direction:column;
        gap:16px;
    }

    .nav-links{
        flex-wrap:wrap;
        justify-content:center;
        gap:18px;
    }

    .hero{
        padding:140px 24px 60px;
    }

    .hero-logo{
        width:190px;
    }

    .hero-buttons{
        flex-direction:column;
    }

    .about-section,
    .project-hero,
    .contact-page{
        padding:140px 24px 80px;
    }

    .about-content,
    .project-panel,
    .contact-card{
        padding:28px;
    }

    .portfolio-grid{
        grid-template-columns:1fr;
        padding:40px 24px;
    }

    .project-content h1,
    .contact-info h1,
    .portfolio-page-header h1{
        font-size:2.5rem;
    }

    .project-topbar{
        flex-direction:column;
        align-items:flex-start;
    }

    .contact-layout{
        grid-template-columns:1fr;
    }

    .footer{
        flex-direction:column;
        gap:20px;
        text-align:center;
    }

    .model-viewer{
        height:360px;
    }
}
.legal-page{
    min-height:100vh;
    
    padding:240px 40px 120px;
}

.legal-container{
    max-width:950px;
    margin:0 auto;
}

.legal-container h1{
    margin-top:18px;
    margin-bottom:20px;
    padding-top:80px;
    font-size:4rem;
    color:var(--orange);
    text-shadow:
        0 0 25px rgba(255,155,61,.18);
}

.legal-intro{
    color:#9ca3af;
    margin-bottom:50px;
    line-height:1.8;
    max-width:700px;
}

.legal-terminal-bar{
    display:flex;
    gap:10px;
    margin-bottom:28px;
}

.legal-terminal-bar span{
    width:12px;
    height:12px;
    border-radius:50%;
    background:rgba(255,155,61,.6);
    box-shadow:
        0 0 12px rgba(255,155,61,.45);
}

.legal-content{
    display:flex;
    flex-direction:column;
    gap:18px;
}

.legal-content p{
    color:#b0b0b0;
    line-height:1.8;
}