styles.css 12 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547
  1. /* ------------ Base reset & palette ------------- */
  2. *,
  3. *::before,
  4. *::after {
  5. box-sizing: border-box;
  6. margin: 0;
  7. padding: 0;
  8. line-height: 1.4;
  9. font-family: system-ui, -apple-system, 'Segoe UI', Roboto, sans-serif;
  10. }
  11. :root {
  12. --primary: #0d6efd;
  13. --dark: #121418;
  14. --light: #f5f7fa;
  15. --accent: #00c27a;
  16. --page-radius: 24px;
  17. --page-radius-lg: 32px;
  18. --page-bg: #ffffff;
  19. --body-bg1: #ffe1cf;
  20. --body-bg2: #ffd8c2;
  21. }
  22. /* Body background & responsive outer margin "margin zone" */
  23. html, body { height: 100%; }
  24. body {
  25. background: url('background.jpg') center center / cover no-repeat fixed;
  26. padding: clamp(8px, 3vw, 48px);
  27. }
  28. body::before {
  29. content: "";
  30. position: fixed;
  31. inset: 0;
  32. background: rgba(0,0,0,0.3); /* adjust opacity as needed */
  33. z-index: -1;
  34. }
  35. /* The page surface */
  36. .page-shell {
  37. background: var(--page-bg);
  38. border-radius: var(--page-radius);
  39. overflow: hidden; /* clip hero to rounded edges */
  40. box-shadow:
  41. 0 0 0 1px rgba(0,0,0,.06),
  42. 0 10px 25px rgba(0,0,0,.08),
  43. 0 35px 80px rgba(0,0,0,.12);
  44. max-width: 1600px;
  45. margin-inline: auto;
  46. }
  47. @media (min-width: 768px) {
  48. .page-shell { border-radius: var(--page-radius-lg); }
  49. }
  50. /* ------------ Layout helpers ------------- */
  51. .container {
  52. width: min(90%, 1100px);
  53. margin-inline: auto;
  54. }
  55. .section-title {
  56. margin-bottom: 1rem;
  57. font-size: 1.85rem;
  58. color: var(--primary);
  59. text-align: center;
  60. }
  61. /* ------------ Navbar ------------- */
  62. .navbar {
  63. position: sticky;
  64. top: 0;
  65. background: rgba(255, 255, 255, 0.9);
  66. backdrop-filter: blur(6px);
  67. border-bottom: 1px solid #e1e5ea;
  68. z-index: 50;
  69. }
  70. .navbar .logo {
  71. font-size: 1.4rem;
  72. color: var(--dark);
  73. }
  74. .navbar .logo span { color: var(--primary); }
  75. .navbar nav ul {
  76. display: flex;
  77. gap: 1.2rem;
  78. list-style: none;
  79. }
  80. .navbar a {
  81. text-decoration: none;
  82. color: var(--dark);
  83. font-weight: 500;
  84. padding: 0.4rem 0.8rem;
  85. border-radius: 4px;
  86. transition: background-color 0.2s ease, color 0.2s ease;
  87. }
  88. .navbar a:hover {
  89. background-color: rgba(13, 110, 253, 0.1);
  90. color: var(--primary);
  91. }
  92. .navbar a:active {
  93. background-color: rgba(13, 110, 253, 0.2);
  94. color: var(--primary);
  95. }
  96. .navbar .container {
  97. display: flex;
  98. justify-content: space-between;
  99. align-items: center;
  100. padding: 0.7rem 0;
  101. }
  102. .navbar-nav {
  103. display: flex;
  104. align-items: center;
  105. justify-content: space-between;
  106. }
  107. .navbar-nav .nav-left ul {
  108. display: flex;
  109. gap: 1.2rem;
  110. list-style: none;
  111. margin: 0;
  112. padding: 0;
  113. }
  114. .navbar-nav .nav-left a {
  115. text-decoration: none;
  116. color: var(--dark);
  117. font-weight: 500;
  118. padding: 0.4rem 0.8rem;
  119. border-radius: 4px;
  120. transition: background-color 0.2s ease, color 0.2s ease;
  121. }
  122. .navbar-nav .nav-left a:hover {
  123. background-color: rgba(13, 110, 253, 0.1);
  124. color: var(--primary);
  125. }
  126. .email-icon {
  127. font-size: 1.8rem;
  128. text-decoration: none;
  129. color: var(--dark);
  130. margin-left: 1rem;
  131. transition: color 0.2s ease;
  132. }
  133. .email-icon:hover {
  134. color: var(--primary);
  135. }
  136. @media (max-width: 768px) {
  137. .navbar .container {
  138. flex-direction: column;
  139. align-items: flex-start;
  140. }
  141. .navbar-nav {
  142. flex-direction: column;
  143. width: 100%;
  144. }
  145. .navbar-nav .nav-left ul {
  146. flex-direction: column;
  147. gap: 0.5rem;
  148. width: 100%;
  149. }
  150. .navbar-nav .nav-left a {
  151. display: block;
  152. width: 100%;
  153. padding: 0.75rem;
  154. }
  155. .navbar .logo {
  156. margin-bottom: 0.5rem;
  157. }
  158. .email-icon {
  159. align-self: flex-end;
  160. margin: 0.5rem 0;
  161. }
  162. }
  163. /* ------------ Hero ------------- */
  164. /* ------------ Hero (Layered Tech) ------------- */
  165. .hero {
  166. position: relative;
  167. overflow: hidden; /* keeps layers inside rounded page-shell */
  168. color: #fff;
  169. padding: 5rem 0 6rem;
  170. text-align: center;
  171. }
  172. /* Background image layer */
  173. .hero::before {
  174. content: "";
  175. position: absolute;
  176. inset: 0;
  177. background:
  178. url('hero-banner.jpg') center/cover no-repeat; /* replace w/ your image; falls back if missing */
  179. filter: brightness(0.45) saturate(1.2); /* darken so text pops */
  180. z-index: 0;
  181. }
  182. /* Animated gradient overlay layer */
  183. .hero::after {
  184. content: "";
  185. position: absolute;
  186. inset: 0;
  187. background: linear-gradient(
  188. 135deg,
  189. rgba(13,110,253,0.85) 0%,
  190. rgba(77,141,255,0.65) 45%,
  191. rgba(0,194,122,0.70) 100%
  192. );
  193. background-size: 200% 200%;
  194. animation: heroGradient 16s ease-in-out infinite alternate;
  195. mix-blend-mode: screen; /* try 'overlay' or 'soft-light' if you prefer */
  196. z-index: 1;
  197. }
  198. @keyframes heroGradient {
  199. 0% { background-position: 0% 50%; }
  200. 100% { background-position: 100% 50%; }
  201. }
  202. /* Particle canvas sits above background layers, below content */
  203. #hero-particles {
  204. position: absolute;
  205. inset: 0;
  206. width: 100%;
  207. height: 100%;
  208. z-index: 2;
  209. pointer-events: none;
  210. }
  211. /* Content on top */
  212. .hero-content {
  213. position: relative;
  214. z-index: 3;
  215. }
  216. .hero h2 { font-size: 2.8rem; margin-bottom: 1rem; }
  217. .hero p { font-size: 1.2rem; margin-bottom: 2rem; max-width: 650px; margin-inline: auto; }
  218. .cta-btn {
  219. padding: 0.9rem 1.8rem;
  220. background: var(--accent);
  221. border: none;
  222. color: #fff;
  223. font-size: 1.05rem;
  224. border-radius: 6px;
  225. text-decoration: none;
  226. transition: transform 0.2s;
  227. }
  228. .cta-btn:hover { transform: translateY(-3px); }
  229. /* ------------ Services ------------- */
  230. .services { padding: 4rem 0 2rem; background: var(--light); }
  231. .service-grid {
  232. display: grid;
  233. gap: 2rem;
  234. grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
  235. }
  236. .service-grid article {
  237. background: #fff;
  238. padding: 1.8rem;
  239. border-radius: 8px;
  240. box-shadow: 0 4px 16px rgba(0, 0, 0, 0.05);
  241. transition: transform 0.25s;
  242. }
  243. .service-grid article:hover { transform: translateY(-6px); }
  244. .service-grid h4 { margin-bottom: 0.6rem; color: var(--primary); }
  245. .service-grid p { font-size: 0.95rem; }
  246. /* Service Icons */
  247. .service-icon {
  248. width: 32px;
  249. height: 32px;
  250. margin-inline: auto;
  251. margin-bottom: 0.5rem;
  252. color: var(--primary);
  253. }
  254. .service-icon svg {
  255. width: 100%;
  256. height: 100%;
  257. display: block;
  258. }
  259. /* ------------ Why Us ------------- */
  260. .why-us { padding: 4rem 0; }
  261. .why-list {
  262. display: grid;
  263. gap: 1rem;
  264. grid-template-columns: repeat(auto-fit, minmax(300px, 1fr));
  265. list-style: none;
  266. font-size: 1.05rem;
  267. }
  268. .why-list li { padding-left: 1.3rem; position: relative; }
  269. .why-list li::before {
  270. content: "✓";
  271. position: absolute;
  272. left: 0;
  273. color: var(--accent);
  274. }
  275. /* ------------ Testimonials ------------- */
  276. .testimonials { padding: 4rem 0 5rem; background: var(--light); }
  277. blockquote {
  278. background: #fff;
  279. padding: 1.5rem 2rem;
  280. border-left: 4px solid var(--primary);
  281. margin: 1.2rem 0;
  282. border-radius: 6px;
  283. box-shadow: 0 3px 10px rgba(0, 0, 0, 0.04);
  284. }
  285. blockquote cite {
  286. display: block;
  287. margin-top: 0.8rem;
  288. font-style: normal;
  289. font-size: 0.9rem;
  290. color: #555;
  291. }
  292. /* ------------ Floating Contact Form ------------- */
  293. :root {
  294. --flyout-right-margin: clamp(8px, 2vw, 24px);
  295. }
  296. /* … */
  297. #contact-flyout {
  298. position: fixed;
  299. top: 25%;
  300. right: var(--flyout-right-margin);
  301. width: 320px;
  302. z-index: 100;
  303. animation: bob 3.6s ease-in-out infinite;
  304. }
  305. @keyframes bob {
  306. 0%, 100% { transform: translateY(-8px); }
  307. 50% { transform: translateY(8px); }
  308. }
  309. .contact-form {
  310. background: #fff;
  311. border: 2px solid var(--primary);
  312. border-right: none;
  313. padding: 1.5rem 1.2rem 1rem;
  314. border-radius: 8px 0 0 8px;
  315. box-shadow: -4px 6px 16px rgba(0, 0, 0, 0.08);
  316. width: 100%;
  317. }
  318. .contact-form h4 { margin-bottom: 0.8rem; color: var(--primary); }
  319. .contact-form label {
  320. display: block;
  321. margin-bottom: 1rem;
  322. font-size: 0.9rem;
  323. }
  324. .contact-form input,
  325. .contact-form textarea {
  326. width: 100%;
  327. padding: 0.55rem 0.6rem;
  328. font-size: 0.9rem;
  329. border: 1px solid #ccc;
  330. border-radius: 4px;
  331. }
  332. .submit-btn {
  333. display: block;
  334. width: 100%;
  335. margin-top: 0.4rem;
  336. padding: 0.7rem 0;
  337. border: none;
  338. background: var(--primary);
  339. color: #fff;
  340. font-weight: 600;
  341. border-radius: 4px;
  342. cursor: pointer;
  343. transition: background 0.2s;
  344. }
  345. .submit-btn:hover { background: #005be0; }
  346. #closeFlyout {
  347. position: absolute;
  348. top: 4px;
  349. left: -32px;
  350. background: var(--primary);
  351. color: #fff;
  352. border: none;
  353. border-radius: 50%;
  354. width: 28px;
  355. height: 28px;
  356. font-size: 0.9rem;
  357. cursor: pointer;
  358. }
  359. /* ------------ Footer ------------- */
  360. .footer {
  361. background: var(--dark);
  362. color: #aaa;
  363. text-align: center;
  364. padding: 1.4rem 0;
  365. font-size: 0.85rem;
  366. }
  367. /* Respect motion preferences */
  368. @media (prefers-reduced-motion: reduce) {
  369. .hero::after {
  370. animation: none !important;
  371. background-position: 50% 50% !important;
  372. }
  373. #hero-particles { display: none !important; }
  374. }
  375. /* wiggle effect for contact flyout */
  376. #contact-flyout.wiggle {
  377. animation: wiggle 0.5s ease;
  378. }
  379. @keyframes wiggle {
  380. 0% { transform: translateY(0) rotate(0deg); }
  381. 15% { transform: translateY(-2px) rotate(-2deg); }
  382. 30% { transform: translateY(2px) rotate(2deg); }
  383. 45% { transform: translateY(-1px) rotate(-1deg); }
  384. 60% { transform: translateY(1px) rotate(1deg); }
  385. 75% { transform: translateY(-1px) rotate(-1deg); }
  386. 100% { transform: translateY(0) rotate(0deg); }
  387. }
  388. /* Submitting spinner */
  389. .btn-spinner {
  390. border: 3px solid #f3f3f3;
  391. border-top: 3px solid var(--primary);
  392. border-radius: 50%;
  393. width: 16px;
  394. height: 16px;
  395. animation: spin 0.8s linear infinite;
  396. display: inline-block;
  397. vertical-align: middle;
  398. }
  399. @keyframes spin {
  400. 0% { transform: rotate(0deg); }
  401. 100% { transform: rotate(360deg); }
  402. }
  403. /* Modal */
  404. .form-modal {
  405. position: fixed;
  406. inset: 0;
  407. background: rgba(0, 0, 0, 0.6);
  408. display: flex;
  409. justify-content: center;
  410. align-items: center;
  411. z-index: 9999;
  412. }
  413. .form-modal.hidden {
  414. display: none;
  415. }
  416. .form-modal-content {
  417. background: #fff;
  418. padding: 1.5rem 2rem;
  419. border-radius: 8px;
  420. text-align: center;
  421. animation: popin 0.3s ease;
  422. }
  423. @keyframes popin {
  424. 0% { transform: scale(0.8); opacity: 0; }
  425. 100% { transform: scale(1); opacity: 1; }
  426. }
  427. /* Wiggle (already in your CSS but repeated here for convenience) */
  428. /* Wiggle */
  429. #contact-flyout.wiggle {
  430. animation: wiggle 0.5s ease;
  431. }
  432. @keyframes wiggle {
  433. 0% { transform: translateY(0) rotate(0deg); }
  434. 15% { transform: translateY(-2px) rotate(-2deg); }
  435. 30% { transform: translateY(2px) rotate(2deg); }
  436. 45% { transform: translateY(-1px) rotate(-1deg); }
  437. 60% { transform: translateY(1px) rotate(1deg); }
  438. 75% { transform: translateY(-1px) rotate(-1deg); }
  439. 100% { transform: translateY(0) rotate(0deg); }
  440. }
  441. .btn-spinner {
  442. border: 3px solid #f3f3f3;
  443. border-top: 3px solid var(--primary);
  444. border-radius: 50%;
  445. width: 16px;
  446. height: 16px;
  447. animation: spin 0.8s linear infinite;
  448. display: inline-block;
  449. vertical-align: middle;
  450. }
  451. @keyframes spin {
  452. 0% { transform: rotate(0deg); }
  453. 100% { transform: rotate(360deg); }
  454. }
  455. .form-modal {
  456. position: fixed;
  457. inset: 0;
  458. background: rgba(0, 0, 0, 0.6);
  459. display: flex;
  460. justify-content: center;
  461. align-items: center;
  462. z-index: 9999;
  463. }
  464. .form-modal.hidden {
  465. display: none;
  466. }
  467. .form-modal-content {
  468. background: #fff;
  469. padding: 1.5rem 2rem;
  470. border-radius: 8px;
  471. text-align: center;
  472. animation: popin 0.3s ease;
  473. }
  474. @keyframes popin {
  475. 0% { transform: scale(0.8); opacity: 0; }
  476. 100% { transform: scale(1); opacity: 1; }
  477. }
  478. .honeypot {
  479. position: absolute;
  480. left: -9999px;
  481. top: -9999px;
  482. height: 0;
  483. width: 0;
  484. overflow: hidden;
  485. }