﻿
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{
  --green:#00f078;
  --cyan:#00f0f0;
  --grad:linear-gradient(135deg,#00f078,#00f0f0);
  --grad-text:linear-gradient(135deg,#00f078,#00c8f0);
  --bg:#181a1b;
  --bg2:#1f2223;
  --white:#ffffff;
  --off:#f4fffe;
  --text:#0d1a1a;
  --muted:#3a6060;
  --border:rgba(0,240,200,0.2);
  --shadow:0 4px 20px rgba(0,240,200,0.08);
  --shadow-lg:0 8px 36px rgba(0,240,200,0.14);
}
html{scroll-behavior:smooth}
body{font-family:'Outfit',sans-serif;color:var(--text);background:var(--white);line-height:1.65}

nav{position:fixed;top:0;left:0;right:0;z-index:999;background:var(--bg);border-bottom:1px solid rgba(0,240,120,0.12)}
.nav-inner{max-width:1200px;margin:0 auto;padding:0 2rem;display:flex;align-items:center;justify-content:space-between;height:66px}
.logo{display:flex;align-items:center;gap:10px;text-decoration:none;cursor:pointer}
.logo-img{width:36px;height:36px;border-radius:8px;object-fit:cover;border:1px solid rgba(0,240,240,0.3)}
.logo-text{font-family:'Playfair Display',serif;font-size:1.1rem;color:var(--white);font-weight:600}
.logo-text span{background:var(--grad-text);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.nav-links{display:flex;align-items:center;gap:0.1rem;list-style:none}
.nav-links a{color:rgba(255,255,255,0.55);text-decoration:none;font-size:0.88rem;font-weight:500;padding:0.5rem 0.9rem;border-radius:6px;transition:all 0.2s}
.nav-links a:hover,.nav-links a.active{color:var(--cyan);background:rgba(0,240,240,0.06)}
.nav-cta{background:var(--grad);color:var(--text);font-weight:700;font-size:0.85rem;padding:0.52rem 1.35rem;border-radius:7px;border:none;cursor:pointer;font-family:'Outfit',sans-serif;transition:opacity 0.2s}
.nav-cta:hover{opacity:0.85}

.hero{background:var(--bg);padding-top:66px}
.hero-main{max-width:1200px;margin:0 auto;padding:5rem 2rem 4rem;display:flex;align-items:center;gap:4rem}
.hero-content{flex:1}
.hero-badge{display:inline-flex;align-items:center;gap:8px;background:rgba(0,240,120,0.08);border:1px solid rgba(0,240,200,0.25);border-radius:100px;padding:0.38rem 1rem;font-size:0.75rem;color:var(--green);letter-spacing:0.07em;text-transform:uppercase;margin-bottom:1.75rem;font-weight:500}
.hero-badge::before{content:'';width:7px;height:7px;border-radius:50%;background:var(--green);animation:blink 2s infinite}
@keyframes blink{0%,100%{opacity:1}50%{opacity:0.3}}
@keyframes fadeUp{from{opacity:0;transform:translateY(22px)}to{opacity:1;transform:translateY(0)}}
@keyframes slideLeft{from{opacity:0;transform:translateX(-30px)}to{opacity:1;transform:translateX(0)}}
@keyframes slideRight{from{opacity:0;transform:translateX(30px)}to{opacity:1;transform:translateX(0)}}
@keyframes scaleIn{from{opacity:0;transform:scale(0.92)}to{opacity:1;transform:scale(1)}}
.hero h1{font-family:'Playfair Display',serif;font-size:clamp(2.5rem,5vw,3.8rem);color:var(--white);line-height:1.12;margin-bottom:1.4rem;font-weight:700}
.hero h1 em{font-style:normal;background:var(--grad-text);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.hero-sub{color:rgba(255,255,255,0.5);font-size:1rem;max-width:520px;margin-bottom:2.5rem;font-weight:300;line-height:1.8}
.hero-btns{display:flex;gap:1rem;flex-wrap:wrap}
.hero-content>*{animation:slideLeft 0.7s cubic-bezier(.22,1,.36,1) both}
.hero-badge{animation-delay:0.1s}
.hero h1{animation-delay:0.22s}
.hero-sub{animation-delay:0.34s}
.hero-btns{animation-delay:0.46s}
.hero-visual{animation:slideRight 0.75s 0.3s cubic-bezier(.22,1,.36,1) both}
.h-card:nth-child(1){animation:scaleIn 0.5s 0.5s both}
.h-card:nth-child(2){animation:scaleIn 0.5s 0.58s both}
.h-card:nth-child(3){animation:scaleIn 0.5s 0.66s both}
.h-card:nth-child(4){animation:scaleIn 0.5s 0.74s both}
.h-card:nth-child(5){animation:scaleIn 0.5s 0.82s both}
.h-card:nth-child(6){animation:scaleIn 0.5s 0.90s both}
.btn-teal{background:var(--grad);color:var(--text);font-weight:600;padding:0.85rem 2rem;border-radius:8px;border:none;cursor:pointer;font-family:'Outfit',sans-serif;font-size:0.95rem;transition:all 0.2s}
.btn-teal:hover{opacity:0.88;transform:translateY(-1px)}
.btn-outline{background:transparent;color:var(--white);border:1.5px solid rgba(0,240,200,0.2);padding:0.85rem 2rem;border-radius:8px;cursor:pointer;font-family:'Outfit',sans-serif;font-size:0.95rem;transition:all 0.2s}
.btn-outline:hover{border-color:var(--cyan);color:var(--cyan)}
.hero-visual{flex:0 0 400px;display:grid;grid-template-columns:1fr 1fr;gap:0.85rem}
.h-card{
  position:relative;
  background:linear-gradient(135deg,rgba(13,26,26,0.9),rgba(16,34,34,0.9));
  border:1px solid rgba(0,240,200,0.2);
  border-radius:14px;
  padding:1.35rem 1.2rem;
  box-shadow:0 8px 24px rgba(0,240,200,0.08);
  transition:transform 0.25s,box-shadow 0.25s,border-color 0.25s;
  overflow:hidden;
}
.h-card::after{
  content:'';
  position:absolute;
  inset:0;
  border-radius:14px;
  border:1px solid rgba(0,240,200,0.2);
  pointer-events:none;
  mix-blend-mode:screen;
}
.h-card::before{
  content:'';
  position:absolute;
  top:-20px;
  left:-20px;
  width:90px;
  height:90px;
  background:radial-gradient(circle,rgba(0,240,120,0.18),transparent 60%);
  opacity:0.8;
}
.h-card:hover{
  transform:translateY(-4px);
  border-color:rgba(0,240,200,0.5);
  box-shadow:0 10px 30px rgba(0,240,200,0.18);
}
.h-card .icon{
  font-size:1.6rem;
  margin-bottom:0.55rem;
  color:var(--green);
}
.h-card h4{color:var(--white);font-size:0.88rem;font-weight:600;margin-bottom:0.25rem}
.h-card p{color:rgba(255,255,255,0.45);font-size:0.75rem}
.hero-stats{background:var(--bg2);border-top:1px solid rgba(0,240,120,0.12)}
.stats-inner{max-width:1200px;margin:0 auto;padding:2rem;display:flex;justify-content:space-around;flex-wrap:wrap;gap:1rem}
.stat-num{font-family:'Playfair Display',serif;font-size:2.2rem;background:var(--grad-text);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;font-weight:700;line-height:1}
.stat-label{font-size:0.78rem;color:rgba(255,255,255,0.35);margin-top:5px;letter-spacing:0.05em;text-transform:uppercase}

.wrap{max-width:1200px;margin:0 auto;padding:5rem 2rem}
.sec-tag{display:inline-block;background:rgba(0,240,120,0.08);color:var(--green);border:1px solid rgba(0,240,200,0.2);border-radius:100px;padding:0.28rem 1rem;font-size:0.73rem;letter-spacing:0.1em;text-transform:uppercase;font-weight:600;margin-bottom:0.9rem}
.sec-title{font-family:'Playfair Display',serif;font-size:clamp(1.8rem,3vw,2.5rem);color:var(--text);font-weight:700;line-height:1.2;margin-bottom:0.6rem}
.sec-title.light{color:var(--white)}
.sec-sub{color:var(--muted);font-size:0.97rem;max-width:540px;line-height:1.75;font-weight:300}
.divider{width:48px;height:3px;background:var(--grad);border-radius:2px;margin:0.9rem 0 0}
.divider.center{margin:0.9rem auto 0}
.text-center{text-align:center}
.text-center .sec-sub{margin:0 auto}

.grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:1.25rem}
.card{position:relative;border-radius:18px;padding:2.35rem 2.2rem;min-height:220px;background:linear-gradient(#ffffff,#ffffff) padding-box,linear-gradient(135deg,rgba(0,240,120,0.8),rgba(0,240,240,0.8)) border-box;border:2.5px solid transparent;box-shadow:0 8px 26px rgba(0,240,200,0.12);transition:all 0.25s}
.card::before{content:'';position:absolute;top:0;left:0;right:0;height:3px;background:var(--grad);border-radius:16px 16px 0 0;opacity:0.7}
.card:hover{box-shadow:0 10px 30px rgba(0,240,200,0.2);transform:translateY(-4px)}
.card h3{font-family:'Playfair Display',serif;font-size:1.12rem;color:var(--text);margin-bottom:0.6rem;font-weight:700}
.card h3::after{content:'';display:block;width:28px;height:2px;background:var(--grad);margin-top:0.5rem;border-radius:2px}
.card p{font-size:0.9rem;color:var(--muted);line-height:1.75;font-weight:300}

.blog-controls{display:flex;gap:0.8rem;flex-wrap:wrap;align-items:center;margin-bottom:1.6rem}
.blog-controls input{flex:1;min-width:220px;background:var(--white);border:1.5px solid #c0eeee;border-radius:8px;padding:0.7rem 0.9rem;font-family:'Outfit',sans-serif;font-size:0.88rem;color:var(--text)}
.blog-cats{display:flex;gap:0.5rem;flex-wrap:wrap;list-style:none}
.cat-btn{background:var(--white);border:1.5px solid #c0eeee;color:var(--muted);padding:0.42rem 1rem;border-radius:100px;font-size:0.8rem;cursor:pointer;font-family:'Outfit',sans-serif;font-weight:500;transition:all 0.2s}
.cat-btn.active,.cat-btn:hover{background:var(--grad);color:var(--text);border-color:transparent}
.blog-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:1.25rem}
.blog-card{background:var(--white);border-radius:14px;border:1.5px solid #c0eeee;overflow:hidden;transition:all 0.25s;display:block;color:inherit;text-decoration:none}
.blog-card:hover{box-shadow:var(--shadow-lg);transform:translateY(-3px);border-color:var(--cyan)}
.blog-thumb{height:160px;background:linear-gradient(135deg,rgba(0,240,120,0.12),rgba(0,240,240,0.1)),var(--bg);background-size:cover;background-position:center}
.blog-body{padding:1.25rem}
.blog-meta{font-size:0.7rem;color:var(--green);text-transform:uppercase;letter-spacing:0.08em;font-weight:600;margin-bottom:0.45rem}
.blog-tags{display:flex;flex-wrap:wrap;gap:0.4rem;margin-top:0.75rem}
.blog-tag{font-size:0.7rem;padding:0.2rem 0.55rem;border-radius:999px;background:rgba(0,240,120,0.12);color:#006b44;border:1px solid rgba(0,240,200,0.3);text-transform:uppercase;letter-spacing:0.06em}

.newsletter-box{
  margin-top:2.2rem;
  display:grid;
  grid-template-columns:1.2fr 1fr;
  gap:1.5rem;
  padding:2rem;
  border-radius:18px;
  background:linear-gradient(135deg,rgba(0,240,120,0.12),rgba(0,240,240,0.08));
  border:1.5px solid rgba(0,240,200,0.3);
  align-items:center;
}
.newsletter-box h3{font-family:'Playfair Display',serif;font-size:1.35rem;margin-bottom:0.4rem}
.newsletter-box p{color:var(--muted);font-size:0.95rem}
.newsletter-form{display:flex;gap:0.6rem;flex-wrap:wrap}
.newsletter-form input{
  flex:1;
  min-width:220px;
  border-radius:10px;
  border:1.5px solid rgba(0,240,200,0.35);
  padding:0.8rem 0.9rem;
  font-family:'Outfit',sans-serif;
  font-size:0.9rem;
}

.admin-layout{
  display:grid;
  grid-template-columns:320px minmax(0,1fr);
  min-height:100vh;
  background:
    radial-gradient(circle at 8% 8%,rgba(0,240,200,0.12),transparent 30%),
    radial-gradient(circle at 90% 12%,rgba(0,240,120,0.08),transparent 26%),
    #f2f8f8;
}
.admin-sidebar{
  position:sticky;
  top:0;
  height:100vh;
  padding:1.1rem;
  display:flex;
  background:transparent;
}
.admin-sidebar::before{
  content:"";
  position:absolute;
  inset:0;
  pointer-events:none;
  background:linear-gradient(180deg,rgba(0,240,200,0.06),rgba(0,0,0,0));
}
.admin-sidebar-inner{
  width:100%;
  position:relative;
  z-index:1;
  border-radius:24px;
  border:1px solid rgba(0,240,200,0.25);
  background:
    radial-gradient(circle at 10% 10%,rgba(0,240,200,0.16),transparent 32%),
    linear-gradient(180deg,#081515 0%,#0c2323 100%);
  box-shadow:0 18px 40px rgba(6,20,20,0.28);
  padding:1.35rem 1.1rem;
  display:flex;
  flex-direction:column;
  gap:1.15rem;
}
.admin-logo{
  display:flex;
  align-items:flex-start;
  gap:0.75rem;
  text-decoration:none;
  color:var(--white);
}
.admin-logo img{
  width:44px;
  height:44px;
  border-radius:12px;
  object-fit:cover;
  border:1px solid rgba(0,240,200,0.25);
}
.admin-brand-copy{display:grid;gap:0.22rem}
.admin-brand-kicker{
  font-size:0.66rem;
  letter-spacing:0.14em;
  text-transform:uppercase;
  color:rgba(255,255,255,0.56);
}
.admin-brand-title{
  font-family:'Playfair Display',serif;
  font-size:1.1rem;
  line-height:1.1;
  color:#ecffff;
}
.admin-side-note{
  font-size:0.82rem;
  color:rgba(230,255,255,0.68);
  line-height:1.6;
  padding:0.72rem 0.78rem;
  background:rgba(0,240,200,0.08);
  border:1px solid rgba(0,240,200,0.22);
  border-radius:12px;
}
.admin-side-title{
  font-size:0.68rem;
  letter-spacing:0.12em;
  text-transform:uppercase;
  color:rgba(255,255,255,0.58);
  margin:0.3rem 0 0.45rem;
  padding-left:0.2rem;
}
.admin-nav{
  list-style:none;
  display:grid;
  gap:0.45rem;
}
.admin-nav a{
  display:flex;
  align-items:center;
  gap:0.55rem;
  padding:0.66rem 0.78rem;
  border-radius:12px;
  text-decoration:none;
  color:rgba(232,255,255,0.76);
  font-size:0.9rem;
  border:1px solid transparent;
  transition:all 0.2s ease;
}
.admin-nav a::before{
  content:"";
  width:7px;
  height:7px;
  border-radius:50%;
  background:rgba(0,240,200,0.38);
  flex:0 0 7px;
}
.admin-nav a.active,.admin-nav a:hover{
  border-color:rgba(0,240,200,0.28);
  background:linear-gradient(120deg,rgba(0,240,200,0.2),rgba(0,240,120,0.16));
  color:var(--white);
}
.admin-sidebar nav{
  flex:1;
  position:static;
  top:auto;
  left:auto;
  right:auto;
  z-index:auto;
  background:transparent;
  border:0;
}
.admin-side-footer{
  display:grid;
  gap:0.55rem;
}
.admin-side-home{
  text-align:center;
  text-decoration:none;
  border:1px solid rgba(255,255,255,0.28);
  color:rgba(255,255,255,0.9);
  padding:0.58rem 0.7rem;
  border-radius:10px;
  font-size:0.82rem;
}
.admin-side-home:hover{
  border-color:rgba(0,240,200,0.4);
  background:rgba(0,240,200,0.08);
}
.admin-sidebar .nav-cta{
  width:100%;
  text-align:center;
  margin-top:0;
  padding:0.8rem 0.95rem;
  border-radius:10px;
}
.admin-main{
  min-width:0;
  padding:2.5rem 2.4rem;
}
.admin-header{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:1rem;
  margin-bottom:1.6rem;
}
.admin-header h1{font-family:'Playfair Display',serif;font-size:2rem}
.admin-metrics{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(160px,1fr));
  gap:0.9rem;
  margin-bottom:1.3rem;
}
.metric-card{
  background:#ffffff;
  border:1.5px solid rgba(0,240,200,0.22);
  border-radius:14px;
  padding:0.9rem 1rem;
}
.metric-card .label{font-size:0.75rem;color:var(--muted);text-transform:uppercase;letter-spacing:0.07em}
.metric-card .value{font-family:'Playfair Display',serif;font-size:1.7rem;line-height:1.1;color:#072626;margin-top:0.3rem}
.admin-panel{
  background:#ffffff;
  border-radius:16px;
  border:2px solid rgba(0,240,200,0.2);
  padding:1.6rem;
  box-shadow:0 10px 30px rgba(0,240,200,0.12);
}
.admin-panel h2{font-family:'Playfair Display',serif;font-size:1.35rem;margin-bottom:0.9rem}
.admin-form{display:grid;gap:0.8rem}
.admin-form textarea{min-height:140px}
.admin-main .fg input,
.admin-main .fg textarea,
.admin-main .fg select{
  width:100%;
  background:#ffffff;
  border:1.5px solid rgba(0,240,200,0.28);
  border-radius:10px;
  padding:0.72rem 0.9rem;
  font-family:'Outfit',sans-serif;
  font-size:0.9rem;
  color:var(--text);
}
.admin-main .fg input:focus,
.admin-main .fg textarea:focus,
.admin-main .fg select:focus{
  outline:none;
  border-color:#00d7d7;
  box-shadow:0 0 0 3px rgba(0,240,200,0.12);
}
.admin-table{width:100%;border-collapse:collapse;font-size:0.9rem}
.admin-table th,.admin-table td{padding:0.6rem 0.4rem;border-bottom:1px solid rgba(0,240,200,0.15);text-align:left;vertical-align:top}
.admin-table tbody tr:hover{background:rgba(0,240,200,0.04)}
.admin-actions{display:flex;gap:0.4rem;flex-wrap:wrap}
.admin-actions button{border:1px solid rgba(0,240,200,0.2);background:rgba(0,240,200,0.05);border-radius:8px;padding:0.35rem 0.6rem;font-size:0.78rem;cursor:pointer}
.admin-actions button.primary{background:var(--grad);border-color:transparent;color:var(--text)}
.image-preview{margin-top:0.6rem;min-height:160px;border-radius:12px;border:1.5px dashed rgba(0,240,200,0.35);background:rgba(0,240,200,0.05);display:flex;align-items:center;justify-content:center;font-size:0.78rem;color:var(--muted);overflow:hidden;padding:0.75rem}
.image-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(120px,1fr));gap:0.6rem;width:100%}
.image-card{position:relative;border-radius:10px;overflow:hidden;border:1px solid rgba(0,240,200,0.25);background:#0d1a1a}
.image-card img{width:100%;height:90px;object-fit:cover;display:block}
.mini-note{font-size:0.75rem;color:var(--muted)}
.badge{display:inline-block;border-radius:999px;padding:0.2rem 0.6rem;font-size:0.75rem;font-weight:600}
.badge.draft{background:rgba(0,240,200,0.08);color:#007a70}
.badge.published{background:rgba(0,240,120,0.15);color:#006b44}

.blog-detail{padding-top:6.5rem}
.blog-detail-card{background:var(--white);border-radius:18px;border:1.5px solid #c0eeee;overflow:hidden;box-shadow:0 10px 30px rgba(0,240,200,0.12)}
.blog-detail-banner{height:260px;background:linear-gradient(135deg,rgba(0,240,120,0.18),rgba(0,240,240,0.12)),var(--bg);background-size:cover;background-position:center}
.blog-detail-body{padding:2.2rem}
.blog-back{display:inline-block;margin-bottom:1rem;color:var(--muted);text-decoration:none;font-size:0.9rem}
.blog-content{margin-top:1.5rem;display:grid;gap:1rem}
.blog-content p{color:var(--muted);line-height:1.85;font-size:0.98rem}
.blog-inline-image img{width:100%;height:auto;border-radius:14px;border:1px solid rgba(0,240,200,0.25);display:block}
.blog-gallery{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:0.8rem;margin-top:1.5rem}
.blog-gallery-item{height:140px;border-radius:12px;background-size:cover;background-position:center;border:1px solid rgba(0,240,200,0.25)}

.contact-grid{display:grid;grid-template-columns:1fr 1.6fr;gap:3rem;align-items:start}
.c-form{background:var(--off);border-radius:16px;padding:2.25rem;border:1px solid #c0eeee}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:0.9rem;margin-bottom:0.9rem}
.fg{margin-bottom:0.9rem}
.fg label{display:block;font-size:0.8rem;color:var(--text);font-weight:600;margin-bottom:0.38rem;letter-spacing:0.02em}
.fg input,.fg textarea{width:100%;background:var(--white);border:1.5px solid #c0eeee;border-radius:8px;padding:0.72rem 0.95rem;font-family:'Outfit',sans-serif;font-size:0.88rem;color:var(--text);outline:none;transition:border-color 0.2s}
.fg input:focus,.fg textarea:focus{border-color:var(--cyan)}
.fg textarea{resize:vertical;min-height:115px}
.sub-btn{width:100%;background:var(--bg);color:var(--white);border:none;padding:0.95rem;border-radius:8px;font-family:'Outfit',sans-serif;font-size:0.95rem;font-weight:600;cursor:pointer;transition:background 0.2s;letter-spacing:0.03em}
.sub-btn:hover{background:var(--grad);color:var(--text)}

.cta-strip{background:var(--grad);padding:4rem 2rem;text-align:center}
.cta-strip h2{font-family:'Playfair Display',serif;font-size:clamp(1.7rem,3vw,2.4rem);color:var(--text);margin-bottom:0.75rem;font-weight:700}
.cta-strip p{color:rgba(0,30,30,0.65);margin-bottom:2rem;font-size:0.97rem;font-weight:300}
.btn-black{background:var(--bg);color:var(--white);font-weight:600;padding:0.9rem 2.2rem;border-radius:8px;border:none;cursor:pointer;font-family:'Outfit',sans-serif;font-size:0.97rem;transition:all 0.2s}
.btn-black:hover{background:#252829;transform:translateY(-1px)}

footer{background:var(--bg);border-top:1px solid rgba(0,240,120,0.12)}
.foot-main{max-width:1200px;margin:0 auto;padding:4rem 2rem 2rem;display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:3rem}
.foot-brand p{color:rgba(255,255,255,0.38);font-size:0.83rem;line-height:1.8;margin-top:1rem;max-width:270px;font-weight:300}
.foot-col h4{color:var(--green);font-size:0.75rem;letter-spacing:0.1em;text-transform:uppercase;font-weight:600;margin-bottom:0.9rem}
.foot-col ul{list-style:none;display:flex;flex-direction:column;gap:0.55rem}
.foot-col ul li a{color:rgba(255,255,255,0.38);text-decoration:none;font-size:0.83rem;transition:color 0.2s;cursor:pointer}
.foot-col ul li a:hover{color:var(--cyan)}
.foot-bottom{max-width:1200px;margin:0 auto;padding:1.4rem 2rem;border-top:1px solid rgba(0,240,120,0.12);display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:1rem}
.foot-bottom p{color:rgba(255,255,255,0.25);font-size:0.78rem}
.foot-bottom span{color:var(--green)}

.toast{position:fixed;bottom:2rem;right:2rem;background:var(--bg2);color:var(--white);padding:1rem 1.5rem;border-radius:10px;border-left:4px solid var(--green);font-size:0.88rem;z-index:9999;transform:translateY(100px);opacity:0;transition:all 0.3s;border:1px solid rgba(0,240,200,0.25)}
.toast.show{transform:translateY(0);opacity:1}

.chat-toggle{position:fixed;right:20px;bottom:20px;width:56px;height:56px;border-radius:50%;border:1px solid rgba(0,240,200,0.25);background:#000;cursor:pointer;display:grid;place-items:center;box-shadow:0 8px 20px rgba(0,0,0,0.4);z-index:9999}
.chat-toggle img{width:30px;height:30px;border-radius:8px;object-fit:cover}
.chatbox{position:fixed;right:20px;bottom:88px;width:min(360px,calc(100vw - 2rem));background:var(--bg);border:1px solid rgba(0,240,200,0.25);border-radius:14px;box-shadow:0 18px 40px rgba(0,0,0,0.3);overflow:hidden;transform:scale(0.95);opacity:0;pointer-events:none;transition:all 0.2s;z-index:9999}
.chatbox.open{transform:scale(1);opacity:1;pointer-events:auto}
.chat-head{display:flex;align-items:center;justify-content:space-between;padding:0.85rem 1rem;border-bottom:1px solid rgba(0,240,200,0.2);background:rgba(0,240,200,0.08)}
.chat-title{display:flex;align-items:center;gap:0.6rem;color:var(--white)}
.chat-title img{width:26px;height:26px;border-radius:8px;object-fit:cover}
.chat-close{background:transparent;border:1px solid rgba(255,255,255,0.2);color:var(--white);border-radius:6px;padding:0.2rem 0.4rem;cursor:pointer}
.chat-messages{max-height:320px;overflow:auto;padding:0.9rem;display:grid;gap:0.5rem;background:var(--bg)}
.bubble{max-width:85%;padding:0.55rem 0.7rem;border-radius:10px;font-size:0.86rem;line-height:1.45;white-space:pre-wrap}
.bubble.user{justify-self:end;background:rgba(0,240,200,0.12);border:1px solid rgba(0,240,200,0.3);color:var(--white)}
.bubble.bot{justify-self:start;background:rgba(255,255,255,0.05);border:1px solid rgba(255,255,255,0.08);color:var(--white)}
.chat-input{display:flex;gap:0.5rem;padding:0.7rem;border-top:1px solid rgba(255,255,255,0.08);background:var(--bg2)}
.chat-input input{flex:1;border-radius:8px;border:1px solid rgba(255,255,255,0.2);background:var(--bg);color:var(--white);padding:0.55rem 0.7rem;font-family:'Outfit',sans-serif;font-size:0.85rem}
.chat-input button{background:var(--grad);border:none;border-radius:8px;padding:0.55rem 0.8rem;font-weight:600;color:var(--text);cursor:pointer}
.quick-row{display:flex;gap:0.4rem;flex-wrap:wrap;padding:0 0.8rem 0.7rem;background:var(--bg2)}
.quick{border:1px solid rgba(0,240,200,0.2);background:rgba(0,240,200,0.06);color:var(--white);border-radius:999px;padding:0.3rem 0.6rem;font-size:0.75rem;cursor:pointer}

.reveal{opacity:0;transform:translateY(32px);transition:opacity 0.65s cubic-bezier(.22,1,.36,1),transform 0.65s cubic-bezier(.22,1,.36,1)}
.reveal.visible{opacity:1;transform:translateY(0)}
.reveal-left{opacity:0;transform:translateX(-28px);transition:opacity 0.65s cubic-bezier(.22,1,.36,1),transform 0.65s cubic-bezier(.22,1,.36,1)}
.reveal-left.visible{opacity:1;transform:translateX(0)}
.reveal-right{opacity:0;transform:translateX(28px);transition:opacity 0.65s cubic-bezier(.22,1,.36,1),transform 0.65s cubic-bezier(.22,1,.36,1)}
.reveal-right.visible{opacity:1;transform:translateX(0)}
.reveal-scale{opacity:0;transform:scale(0.94);transition:opacity 0.55s cubic-bezier(.22,1,.36,1),transform 0.55s cubic-bezier(.22,1,.36,1)}
.reveal-scale.visible{opacity:1;transform:scale(1)}

@media(max-width:900px){
  .hero-main{flex-direction:column;padding-top:3rem}
  .hero-visual{flex:none;width:100%;grid-template-columns:repeat(4,1fr)}
  .contact-grid{grid-template-columns:1fr}
  .foot-main{grid-template-columns:1fr 1fr}
  .form-row{grid-template-columns:1fr}
  .card{min-height:unset;padding:1.8rem 1.6rem}
  .newsletter-box{grid-template-columns:1fr}
  .admin-layout{
    display:block;
    background:#f2f8f8;
  }
  .admin-sidebar{
    position:relative;
    width:100%;
    height:auto;
    padding:1rem 1rem 0.2rem;
  }
  .admin-sidebar::before{
    display:none;
  }
  .admin-sidebar-inner{
    border-radius:18px;
    padding:1.05rem 0.95rem;
  }
  .admin-main{
    padding:2rem 1.5rem;
  }
}
@media(max-width:600px){
  .nav-links{display:none}
  .nav-cta{display:none}
  .hamburger{display:flex}
  .hero-visual{grid-template-columns:1fr 1fr}
  .foot-main{grid-template-columns:1fr}
  .card{padding:1.6rem 1.4rem}
  .grid{grid-template-columns:1fr}
  .port-grid{grid-template-columns:1fr}
  .blog-grid{grid-template-columns:1fr}
  .process-steps{grid-template-columns:1fr}
}

/* Hamburger button */
.hamburger{display:none;flex-direction:column;justify-content:center;gap:5px;cursor:pointer;border:none;background:transparent;padding:6px 4px;border-radius:6px;flex-shrink:0}
.hamburger span{display:block;width:22px;height:2px;background:rgba(255,255,255,0.8);border-radius:2px;transition:all 0.25s}
.hamburger.open span:nth-child(1){transform:rotate(45deg) translate(5px,5px)}
.hamburger.open span:nth-child(2){opacity:0;transform:scaleX(0)}
.hamburger.open span:nth-child(3){transform:rotate(-45deg) translate(5px,-5px)}

/* Mobile nav overlay */
.mobile-nav{position:fixed;inset:66px 0 0 0;background:var(--bg);z-index:997;padding:1.5rem;display:flex;flex-direction:column;gap:0.4rem;transform:translateX(100%);transition:transform 0.3s cubic-bezier(.22,1,.36,1);border-top:1px solid rgba(0,240,200,0.12);overflow-y:auto}
.mobile-nav.open{transform:translateX(0)}
.mobile-nav a{display:block;color:rgba(255,255,255,0.72);text-decoration:none;font-size:1.05rem;font-weight:500;padding:0.85rem 1rem;border-radius:10px;border:1px solid transparent;transition:all 0.2s}
.mobile-nav a:hover,.mobile-nav a.active{color:var(--cyan);background:rgba(0,240,200,0.06);border-color:rgba(0,240,200,0.15)}
.mobile-nav .mob-cta{background:var(--grad);color:var(--text) !important;font-weight:700;text-align:center;border:none !important;margin-top:1rem;border-radius:10px}

/* Scroll to top button */
.scroll-top{position:fixed;right:20px;bottom:160px;width:42px;height:42px;border-radius:50%;background:var(--bg2);border:1px solid rgba(0,240,200,0.3);color:var(--cyan);cursor:pointer;align-items:center;justify-content:center;font-size:1.3rem;z-index:9998;transition:all 0.25s;display:none;line-height:1}
.scroll-top.visible{display:flex}
.scroll-top:hover{background:rgba(0,240,200,0.1);transform:translateY(-2px);box-shadow:0 4px 14px rgba(0,240,200,0.2)}

/* How We Work – process steps */
.process-steps{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1.25rem;margin-top:3rem}
.step-card{text-align:center;padding:2rem 1.5rem;border-radius:16px;border:1px solid rgba(0,240,200,0.16);background:linear-gradient(135deg,rgba(0,240,120,0.04),rgba(0,240,240,0.02));transition:all 0.25s}
.step-card:hover{border-color:rgba(0,240,200,0.38);transform:translateY(-3px);box-shadow:0 8px 24px rgba(0,240,200,0.1)}
.step-num{width:50px;height:50px;border-radius:50%;background:var(--grad);color:var(--text);font-weight:700;font-size:1.1rem;display:flex;align-items:center;justify-content:center;margin:0 auto 1.25rem;font-family:'Playfair Display',serif;box-shadow:0 4px 14px rgba(0,240,200,0.25)}
.step-card h4{font-family:'Playfair Display',serif;font-size:1.05rem;color:var(--text);margin-bottom:0.5rem;font-weight:700}
.step-card p{font-size:0.88rem;color:var(--muted);line-height:1.7}

/* Service card icon */
.card-icon{width:46px;height:46px;border-radius:12px;background:linear-gradient(135deg,rgba(0,240,120,0.1),rgba(0,240,240,0.07));border:1px solid rgba(0,240,200,0.22);display:flex;align-items:center;justify-content:center;font-size:1.5rem;margin-bottom:1.1rem}

/* Alternate section background */
.section-alt{background:linear-gradient(135deg,rgba(0,240,120,0.03) 0%,rgba(0,240,240,0.02) 100%);border-top:1px solid rgba(0,240,200,0.09);border-bottom:1px solid rgba(0,240,200,0.09)}

/* Nav right group */
.nav-right{display:flex;align-items:center;gap:0.75rem}

