:root {
    --bg-primary: #faf8f5;
    --bg-secondary: #f2efe9;
    --bg-card: rgba(255,255,255,0.85);
    --text-primary: #1a1a2e;
    --text-secondary: #5a5a72;
    --accent-1: #c0792a;
    --accent-2: #a0621e;
    --accent-3: #d4a04a;
    --gradient-main: linear-gradient(135deg, #c0792a, #d4a04a, #e8c274);
    --gradient-alt: linear-gradient(135deg, #667eea, #764ba2);
    --glass-bg: rgba(255,255,255,0.7);
    --glass-border: rgba(192,121,42,0.12);
    --radius: 20px;
    --radius-sm: 12px;
    --shadow: 0 8px 40px rgba(0,0,0,0.06);
    --shadow-hover: 0 20px 60px rgba(192,121,42,0.12);
    --transition: 0.4s cubic-bezier(0.22, 1, 0.36, 1);
    --font-heading: 'Outfit', sans-serif;
    --font-body: 'Inter', sans-serif;
}
*, *::before, *::after { margin:0; padding:0; box-sizing:border-box; }
html { scroll-behavior: smooth; scroll-padding-top: 80px; }
body { font-family: var(--font-body); background: var(--bg-primary); color: var(--text-primary); overflow-x: hidden; line-height: 1.7; }
a { text-decoration: none; color: inherit; }
ul { list-style: none; }
.container { max-width: 1200px; margin: 0 auto; padding: 0 24px; }

/* Cursor Glow */
.cursor-glow {
    position: fixed; width: 500px; height: 500px; border-radius: 50%;
    background: radial-gradient(circle, rgba(212,160,74,0.07), transparent 70%);
    pointer-events: none; z-index: 0; transform: translate(-50%, -50%);
    transition: transform 0.1s ease;
}

/* Cursor Trail Sparkles */
.cursor-sparkle {
    position: fixed;
    pointer-events: none;
    z-index: 9999;
    border-radius: 50%;
    animation: sparkleFade 0.8s ease-out forwards;
}
@keyframes sparkleFade {
    0% { transform: translate(-50%, -50%) scale(1); opacity: 1; }
    100% { transform: translate(-50%, -50%) scale(0) translateY(-30px); opacity: 0; }
}

/* Cursor Ring */
.cursor-ring {
    position: fixed;
    width: 36px; height: 36px;
    border: 2px solid rgba(192,121,42,0.35);
    border-radius: 50%;
    pointer-events: none;
    z-index: 9998;
    transform: translate(-50%, -50%);
    transition: width 0.3s ease, height 0.3s ease, border-color 0.3s ease, background 0.3s ease;
}
.cursor-ring.hovering {
    width: 52px; height: 52px;
    border-color: rgba(192,121,42,0.6);
    background: rgba(192,121,42,0.06);
}

#particles-canvas { position: fixed; top:0; left:0; width:100%; height:100%; z-index:0; pointer-events:none; }

/* Navbar */
.navbar { position: fixed; top:0; left:0; width:100%; z-index:1000; padding:20px 0; transition: var(--transition); }
.navbar.scrolled { background: rgba(250,248,245,0.92); backdrop-filter: blur(24px) saturate(180%); border-bottom: 1px solid var(--glass-border); padding:12px 0; box-shadow: 0 2px 20px rgba(0,0,0,0.04); }
.nav-container { width:100%; padding:0 24px; display:flex; align-items:center; justify-content:space-between; }
.nav-logo { display:flex; align-items:center; gap:10px; z-index:1001; }
.logo-icon { font-size:28px; filter: drop-shadow(0 0 8px rgba(192,121,42,0.3)); }
.logo-img {
    width:52px; height:52px; border-radius:50%; object-fit:cover;
    border: 2px solid rgba(192,121,42,0.35);
    box-shadow: 0 0 14px rgba(192,121,42,0.15), 0 0 40px rgba(192,121,42,0.06);
    animation: logoPulse 3s ease-in-out infinite;
    transition: var(--transition);
}
.nav-logo:hover .logo-img {
    box-shadow: 0 0 20px rgba(192,121,42,0.3), 0 0 60px rgba(192,121,42,0.1);
    border-color: rgba(212,160,74,0.7);
    transform: scale(1.08);
}
.logo-text { font-family: var(--font-heading); font-weight:800; font-size:24px; letter-spacing:2.5px; color: var(--text-primary); }
.logo-accent { background: var(--gradient-main); -webkit-background-clip:text; -webkit-text-fill-color:transparent; background-clip:text; }
@keyframes logoPulse { 0%,100% { box-shadow: 0 0 14px rgba(192,121,42,0.15), 0 0 40px rgba(192,121,42,0.06); } 50% { box-shadow: 0 0 20px rgba(192,121,42,0.25), 0 0 50px rgba(192,121,42,0.1); } }
.nav-links { display:flex; gap:36px; }
.nav-link { font-size:13px; font-weight:500; color:var(--text-secondary); transition:var(--transition); position:relative; padding:4px 0; text-transform:uppercase; letter-spacing:1.5px; }
.nav-link::after { content:''; position:absolute; bottom:-4px; left:50%; width:0; height:2px; background:var(--gradient-main); transition:var(--transition); border-radius:2px; transform:translateX(-50%); }
.nav-link:hover, .nav-link.active { color:var(--accent-1); }
.nav-link:hover::after, .nav-link.active::after { width:100%; }
.nav-cta { padding:10px 28px; border-radius:50px; font-size:13px; font-weight:600; background:var(--gradient-main); color:#fff; transition:var(--transition); letter-spacing:1px; text-transform:uppercase; box-shadow: 0 4px 16px rgba(192,121,42,0.2); }
.nav-cta:hover { transform:translateY(-2px); box-shadow:0 8px 30px rgba(192,121,42,0.3); }
.nav-toggle { display:none; flex-direction:column; gap:5px; background:none; border:none; cursor:pointer; z-index:1001; }
.nav-toggle span { width:24px; height:2px; background:var(--text-primary); transition:var(--transition); }

/* Hero */
.hero { min-height:100vh; display:flex; align-items:center; justify-content:space-between; padding:120px 24px 80px; max-width:1200px; margin:0 auto; gap:60px; position:relative; z-index:1; }
.hero-content { flex:1; max-width:640px; }
.hero-badge { display:inline-flex; align-items:center; gap:8px; padding:10px 24px; background:rgba(192,121,42,0.08); border:1px solid rgba(192,121,42,0.15); border-radius:50px; font-size:13px; color:var(--accent-1); margin-bottom:32px; letter-spacing:1px; animation: slideDown 1s ease both; }
.hero-title { font-family:var(--font-heading); font-size:clamp(40px,5.5vw,76px); font-weight:900; line-height:1.05; margin-bottom:28px; color: var(--text-primary); }
.hero-title .line { display:block; overflow:hidden; }
.hero-title .line-inner { display:block; animation: revealLine 1s cubic-bezier(0.77,0,0.175,1) both; }
.hero-title .line:nth-child(2) .line-inner { animation-delay:0.15s; }
.gradient-text { background:var(--gradient-main); -webkit-background-clip:text; -webkit-text-fill-color:transparent; background-clip:text; }
.gradient-text-alt { background:var(--gradient-alt); -webkit-background-clip:text; -webkit-text-fill-color:transparent; background-clip:text; }
.hero-subtitle { font-size:17px; color:var(--text-secondary); line-height:1.9; margin-bottom:40px; animation: fadeUp 1s ease 0.4s both; }
.hero-buttons { display:flex; gap:16px; margin-bottom:56px; animation: fadeUp 1s ease 0.5s both; flex-wrap:wrap; }
.btn { display:inline-flex; align-items:center; gap:10px; padding:16px 36px; border-radius:50px; font-size:14px; font-weight:600; transition:var(--transition); cursor:pointer; border:none; font-family:var(--font-body); letter-spacing:0.5px; position:relative; overflow:hidden; }
.btn::before { content:''; position:absolute; top:0; left:-100%; width:100%; height:100%; background:linear-gradient(90deg,transparent,rgba(255,255,255,0.25),transparent); transition:0.5s; }
.btn:hover::before { left:100%; }
.btn-primary { background:var(--gradient-main); color:#fff; box-shadow:0 4px 24px rgba(192,121,42,0.2); }
.btn-primary:hover { transform:translateY(-3px); box-shadow:0 12px 40px rgba(192,121,42,0.3); }
.btn-outline { background:transparent; color:var(--text-primary); border:1.5px solid rgba(192,121,42,0.3); }
.btn-outline:hover { background:rgba(192,121,42,0.06); border-color:var(--accent-1); transform:translateY(-3px); }
.btn-large { padding:20px 44px; font-size:16px; }
.btn-full { width:100%; justify-content:center; }
.hero-stats { display:flex; align-items:center; gap:40px; animation: fadeUp 1s ease 0.6s both; }
.stat-number { font-family:var(--font-heading); font-size:40px; font-weight:800; background:var(--gradient-main); -webkit-background-clip:text; -webkit-text-fill-color:transparent; background-clip:text; }
.stat-plus { font-family:var(--font-heading); font-size:28px; font-weight:700; color:var(--accent-1); }
.stat-label { display:block; font-size:12px; color:var(--text-secondary); margin-top:4px; text-transform:uppercase; letter-spacing:1px; }
.stat-divider { width:1px; height:56px; background:linear-gradient(to bottom,transparent,rgba(192,121,42,0.2),transparent); }

/* Hero Visual */
.hero-visual { flex:1; max-width:500px; position:relative; height:500px; display:flex; align-items:center; justify-content:center; }
.hero-glow { position:absolute; width:400px; height:400px; border-radius:50%; background:radial-gradient(circle,rgba(212,160,74,0.1),transparent 70%); animation:breathe 5s ease-in-out infinite; }
.floating-card { position:absolute; padding:18px 28px; background:rgba(255,255,255,0.85); border:1px solid rgba(192,121,42,0.12); border-radius:16px; backdrop-filter:blur(24px); display:flex; align-items:center; gap:14px; font-size:14px; font-weight:500; box-shadow:0 8px 32px rgba(0,0,0,0.06); transition:var(--transition); color: var(--text-primary); }
.floating-card:hover { border-color:rgba(192,121,42,0.3); transform:scale(1.05); box-shadow: 0 12px 40px rgba(0,0,0,0.08); }
.card-icon { font-size:28px; }
.card-1 { top:60px; left:-20px; animation: floatCard 7s ease-in-out infinite; }
.card-2 { top:200px; right:-30px; animation: floatCard 7s ease-in-out infinite 1.5s; }
.card-3 { bottom:80px; left:40px; animation: floatCard 7s ease-in-out infinite 3s; }
.orbit-ring { position:absolute; width:300px; height:300px; border-radius:50%; border:1px dashed rgba(192,121,42,0.1); animation:spin 25s linear infinite; }
.orbit-ring-2 { width:420px; height:420px; border-color:rgba(102,126,234,0.06); animation-duration:35s; animation-direction:reverse; }

/* Sections */
.section { padding:120px 0; position:relative; z-index:1; }
.section-header { text-align:center; margin-bottom:72px; }
.section-tag { display:inline-block; padding:8px 22px; background:rgba(192,121,42,0.07); border:1px solid rgba(192,121,42,0.15); border-radius:50px; font-size:12px; font-weight:600; color:var(--accent-1); text-transform:uppercase; letter-spacing:3px; margin-bottom:24px; }
.section-title { font-family:var(--font-heading); font-size:clamp(30px,4vw,50px); font-weight:800; margin-bottom:18px; color: var(--text-primary); }
.section-desc { font-size:16px; color:var(--text-secondary); max-width:560px; margin:0 auto; line-height:1.8; }
.glass-card { background:rgba(255,255,255,0.8); border:1px solid rgba(192,121,42,0.1); border-radius:var(--radius); backdrop-filter:blur(20px); padding:36px; transition:var(--transition); box-shadow: 0 4px 24px rgba(0,0,0,0.04); }
.glass-card:hover { border-color:rgba(192,121,42,0.25); transform:translateY(-6px); box-shadow: var(--shadow-hover); }

/* About */
.about-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:28px; }
.about-card { text-align:center; }
.about-icon { font-size:44px; margin-bottom:24px; filter:drop-shadow(0 4px 8px rgba(192,121,42,0.15)); }
.about-card h3 { font-family:var(--font-heading); font-size:22px; font-weight:700; margin-bottom:14px; color: var(--text-primary); }
.about-card p { color:var(--text-secondary); font-size:14px; line-height:1.8; }

/* Services */
.services { background:var(--bg-secondary); }
.services-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:24px; }
.service-card { background:rgba(255,255,255,0.9); border:1px solid rgba(192,121,42,0.08); border-radius:var(--radius); padding:40px; transition:var(--transition); position:relative; overflow:hidden; box-shadow: 0 2px 16px rgba(0,0,0,0.03); }
.service-card::before { content:''; position:absolute; top:0; left:0; right:0; height:3px; background:var(--gradient-main); transform:scaleX(0); transition:var(--transition); transform-origin:left; }
.service-card:hover { transform:translateY(-8px); border-color:rgba(192,121,42,0.2); box-shadow: var(--shadow-hover); }
.service-card:hover::before { transform:scaleX(1); }
.service-card.featured { border-color:rgba(192,121,42,0.2); }
.service-card.featured::before { transform:scaleX(1); }
.featured-badge { position:absolute; top:16px; right:16px; padding:5px 16px; background:var(--gradient-main); border-radius:50px; font-size:10px; font-weight:700; text-transform:uppercase; letter-spacing:1.5px; color:#fff; }
.service-number { font-family:var(--font-heading); font-size:52px; font-weight:900; background:var(--gradient-main); -webkit-background-clip:text; -webkit-text-fill-color:transparent; background-clip:text; opacity:0.08; position:absolute; top:16px; right:24px; }
.service-icon { font-size:40px; margin-bottom:24px; }
.service-card h3 { font-family:var(--font-heading); font-size:20px; font-weight:700; margin-bottom:12px; color: var(--text-primary); }
.service-card p { color:var(--text-secondary); font-size:14px; margin-bottom:18px; line-height:1.8; }
.service-features { margin-bottom:22px; }
.service-features li { color:var(--text-secondary); font-size:13px; padding:5px 0 5px 20px; position:relative; }
.service-features li::before { content:'✦'; position:absolute; left:0; color:var(--accent-1); font-size:10px; }
.service-link { font-size:13px; font-weight:600; color:var(--accent-1); transition:var(--transition); letter-spacing:1px; text-transform:uppercase; }
.service-link:hover { color:var(--accent-2); letter-spacing:2px; }

/* Portfolio */
.portfolio-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:24px; }
.portfolio-card { border-radius:var(--radius); overflow:hidden; cursor:pointer; box-shadow: 0 4px 24px rgba(0,0,0,0.06); }
.portfolio-card.portfolio-large { grid-column:span 2; }
.portfolio-image { height:300px; position:relative; display:flex; align-items:flex-end; transition:0.6s cubic-bezier(0.22,1,0.36,1); }
.portfolio-large .portfolio-image { height:340px; }
.portfolio-overlay { padding:32px; width:100%; background:linear-gradient(transparent 10%,rgba(0,0,0,0.7)); transform:translateY(0); opacity:1; transition:0.5s cubic-bezier(0.22,1,0.36,1); }
.portfolio-card:hover .portfolio-overlay { background:linear-gradient(transparent,rgba(0,0,0,0.85)); }
.portfolio-card:hover .portfolio-image { transform:scale(1.05); }
.portfolio-category { display:inline-block; padding:4px 14px; background:rgba(212,160,74,0.25); border:1px solid rgba(212,160,74,0.4); border-radius:50px; font-size:11px; font-weight:600; margin-bottom:10px; color:#fff; text-transform:uppercase; letter-spacing:1px; }
.portfolio-overlay h3 { font-family:var(--font-heading); font-size:22px; font-weight:700; color:#fff; }
.portfolio-overlay p { font-size:14px; color:rgba(255,255,255,0.7); margin-top:6px; }

/* Testimonials */
.testimonials { background:var(--bg-secondary); }
.testimonials-slider { display:grid; grid-template-columns:repeat(3,1fr); gap:28px; }
.testimonial-stars { color:var(--accent-3); font-size:18px; letter-spacing:3px; margin-bottom:20px; }
.testimonial-text { font-size:15px; color:var(--text-secondary); line-height:1.9; margin-bottom:28px; font-style:italic; }
.testimonial-author { display:flex; align-items:center; gap:16px; }
.author-avatar { width:50px; height:50px; border-radius:50%; display:flex; align-items:center; justify-content:center; font-weight:700; font-size:14px; color:#fff; }
.testimonial-author h4 { font-family:var(--font-heading); font-size:16px; font-weight:600; color: var(--text-primary); }
.testimonial-author span { font-size:12px; color:var(--text-secondary); }

/* CTA */
.cta-box { text-align:center; padding:90px 40px; border-radius:28px; background:rgba(255,255,255,0.7); border:1px solid rgba(192,121,42,0.12); position:relative; overflow:hidden; box-shadow: 0 8px 40px rgba(0,0,0,0.04); }
.cta-glow { position:absolute; top:-120px; left:50%; transform:translateX(-50%); width:500px; height:500px; border-radius:50%; background:radial-gradient(circle,rgba(212,160,74,0.08),transparent 70%); animation:breathe 5s ease-in-out infinite; }
.cta-box h2 { font-family:var(--font-heading); font-size:clamp(28px,4vw,44px); font-weight:800; margin-bottom:18px; position:relative; color: var(--text-primary); }
.cta-box p { color:var(--text-secondary); font-size:17px; margin-bottom:36px; position:relative; }

/* Contact */
.contact-grid { display:grid; grid-template-columns:1fr 1.5fr; gap:40px; align-items:start; }
.contact-info { display:flex; flex-direction:column; gap:18px; }
.contact-item { display:flex; align-items:center; gap:18px; padding:22px 28px; }
.contact-icon { font-size:30px; }
.contact-item h4 { font-family:var(--font-heading); font-size:16px; font-weight:600; color: var(--text-primary); }
.contact-item p { font-size:14px; color:var(--text-secondary); }
.social-links { display:flex; gap:14px; margin-top:10px; }
.social-link { width:48px; height:48px; border-radius:50%; background:rgba(192,121,42,0.06); border:1px solid rgba(192,121,42,0.12); display:flex; align-items:center; justify-content:center; font-size:18px; transition:var(--transition); color: var(--text-secondary); }
.social-link:hover { background:var(--accent-1); border-color:var(--accent-1); color:#fff; transform:translateY(-4px) scale(1.1); box-shadow:0 8px 24px rgba(192,121,42,0.25); }
.contact-form { padding:40px; }
.form-row { display:grid; grid-template-columns:1fr 1fr; gap:18px; }
.form-group { margin-bottom:22px; }
.form-group label { display:block; font-size:12px; font-weight:600; margin-bottom:10px; color:var(--text-secondary); text-transform:uppercase; letter-spacing:1px; }
.form-group input, .form-group textarea { width:100%; padding:16px 20px; background:rgba(255,255,255,0.9); border:1px solid rgba(192,121,42,0.12); border-radius:var(--radius-sm); color:var(--text-primary); font-family:var(--font-body); font-size:14px; transition:var(--transition); outline:none; }
.form-group input:focus, .form-group textarea:focus { border-color:var(--accent-1); box-shadow:0 0 0 4px rgba(192,121,42,0.08); }
.form-group textarea { resize:vertical; min-height:130px; }
.form-group input::placeholder, .form-group textarea::placeholder { color:rgba(90,90,114,0.4); }

/* Footer */
.footer { padding:70px 0 0; border-top:1px solid var(--glass-border); position:relative; z-index:1; background: var(--bg-secondary); }
.footer-grid { display:grid; grid-template-columns:1.5fr 1fr 1fr 1fr; gap:48px; margin-bottom:56px; }
.footer-brand p { color:var(--text-secondary); font-size:14px; margin-top:18px; max-width:280px; line-height:1.8; }
.footer-links h4 { font-family:var(--font-heading); font-size:15px; font-weight:700; margin-bottom:20px; text-transform:uppercase; letter-spacing:1px; color: var(--text-primary); }
.footer-links a { display:block; color:var(--text-secondary); font-size:14px; padding:7px 0; transition:var(--transition); }
.footer-links a:hover { color:var(--accent-1); transform:translateX(6px); }
.footer-bottom { display:flex; justify-content:space-between; align-items:center; padding:28px 0; border-top:1px solid var(--glass-border); }
.footer-bottom p { font-size:13px; color:var(--text-secondary); }
.footer-bottom-links { display:flex; gap:28px; }
.footer-bottom-links a { font-size:13px; color:var(--text-secondary); transition:var(--transition); }
.footer-bottom-links a:hover { color:var(--accent-1); }

/* Animations */
@keyframes revealLine { from { transform:translateY(110%); } to { transform:translateY(0); } }
@keyframes slideDown { from { opacity:0; transform:translateY(-20px); } to { opacity:1; transform:translateY(0); } }
@keyframes fadeUp { from { opacity:0; transform:translateY(30px); } to { opacity:1; transform:translateY(0); } }
@keyframes floatCard { 0%,100% { transform:translateY(0) rotate(0deg); } 50% { transform:translateY(-24px) rotate(2deg); } }
@keyframes breathe { 0%,100% { transform:scale(1); opacity:0.5; } 50% { transform:scale(1.15); opacity:0.9; } }
@keyframes spin { from { transform:rotate(0deg); } to { transform:rotate(360deg); } }
@keyframes shimmer { 0% { background-position:-200% 0; } 100% { background-position:200% 0; } }

.reveal { opacity:0; transform:translateY(50px); transition:opacity 0.9s cubic-bezier(0.22,1,0.36,1), transform 0.9s cubic-bezier(0.22,1,0.36,1); }
.reveal.active { opacity:1; transform:translateY(0); }
.reveal-delay-1 { transition-delay:0.1s; }
.reveal-delay-2 { transition-delay:0.2s; }
.reveal-delay-3 { transition-delay:0.3s; }
.reveal-delay-4 { transition-delay:0.4s; }
.reveal-delay-5 { transition-delay:0.5s; }

/* Marquee */
.marquee-section { overflow:hidden; padding:40px 0; border-top:1px solid var(--glass-border); border-bottom:1px solid var(--glass-border); position:relative; z-index:1; background: var(--bg-secondary); }
.marquee-track { display:flex; gap:60px; animation:marquee 20s linear infinite; width:max-content; }
.marquee-item { font-family:var(--font-heading); font-size:24px; font-weight:700; color:rgba(192,121,42,0.15); white-space:nowrap; text-transform:uppercase; letter-spacing:4px; }
@keyframes marquee { 0% { transform:translateX(0); } 100% { transform:translateX(-50%); } }

/* Responsive */
@media (max-width:1024px) {
    .hero { flex-direction:column; text-align:center; padding-top:100px; }
    .hero-content { max-width:100%; }
    .hero-buttons { justify-content:center; }
    .hero-stats { justify-content:center; }
    .hero-visual { display:none; }
    .services-grid,.about-grid,.testimonials-slider { grid-template-columns:repeat(2,1fr); }
    .portfolio-grid { grid-template-columns:repeat(2,1fr); }
    .portfolio-card.portfolio-large { grid-column:span 1; }
    .footer-grid { grid-template-columns:repeat(2,1fr); }
}
@media (max-width:768px) {
    .nav-links,.nav-cta { display:none; }
    .nav-toggle { display:flex; }
    .nav-links.active { display:flex; flex-direction:column; position:fixed; top:0; left:0; width:100%; height:100vh; background:var(--bg-primary); align-items:center; justify-content:center; gap:28px; z-index:1000; }
    .nav-links.active .nav-link { font-size:22px; }
    .nav-toggle.active span:nth-child(1) { transform:rotate(45deg) translate(5px,5px); }
    .nav-toggle.active span:nth-child(2) { opacity:0; }
    .nav-toggle.active span:nth-child(3) { transform:rotate(-45deg) translate(5px,-5px); }
    .services-grid,.about-grid,.testimonials-slider,.portfolio-grid { grid-template-columns:1fr; }
    .contact-grid { grid-template-columns:1fr; }
    .form-row { grid-template-columns:1fr; }
    .hero-stats { flex-direction:column; gap:20px; }
    .stat-divider { width:50px; height:1px; }
    .footer-grid { grid-template-columns:1fr; }
    .section { padding:80px 0; }
}
