/* =========================== Emaar Al Watan – Gold Light Theme Modern • Clean • Executive Full-screen (100vh) pages =========================== */ /* ---- 1) Reset ---- */ *, *::before, *::after { box-sizing: border-box; } html { -webkit-text-size-adjust: 100%; color-scheme: light; } body { margin: 0; } img, picture, video, canvas, svg { display: block; max-width: 100%; } input, button, textarea, select { font: inherit; } a { color: inherit; text-decoration: none; } :focus-visible { outline: 3px solid rgba(212, 185, 140, .55); outline-offset: 3px; border-radius: 10px; } /* ---- 2) Theme Tokens ---- */ :root { /* Background */ --bg-main: radial-gradient(1200px 700px at 50% -15%, rgba(255, 255, 255, .95), rgba(255, 255, 255, 0) 60%), radial-gradient(900px 520px at 12% 10%, rgba(212, 185, 140, .16), transparent 62%), radial-gradient(820px 520px at 90% 22%, rgba(0, 0, 0, .05), transparent 60%), linear-gradient(180deg, #f6f5f2, #efede8); /* Surfaces */ --bg-surface: rgba(255, 255, 255, .72); --bg-surface-2: rgba(255, 255, 255, .88); --bg-soft: rgba(17, 24, 39, .04); /* Border */ --border: rgba(17, 24, 39, .10); --border-2: rgba(17, 24, 39, .14); /* Text */ --text: #111827; --muted: rgba(17, 24, 39, .68); /* Accent (Gold) */ --accent: #d4b98c; --accent-2: #b88c3a; --accent-soft: rgba(212, 185, 140, .22); --accent-soft-2: rgba(184, 140, 58, .16); /* Shadow + Radius */ --shadow: 0 18px 45px rgba(17, 24, 39, .10); --shadow-soft: 0 10px 28px rgba(17, 24, 39, .08); --radius-xl: 22px; --radius-lg: 16px; /* Layout */ --container: 1120px; --pad: clamp(1rem, 2.2vw, 1.6rem); /* Motion */ --ease: cubic-bezier(.2, .8, .2, 1); --t-fast: 200ms; --t: 420ms; } /* ---- 3) Base Typography ---- */ html { scroll-behavior: smooth; color-scheme: light; /* ✅ كان dark وده بيبوّظ الفورم */ height: 100%; overflow: hidden; } body { height: 100%; overflow: hidden; font-family: "Cairo", system-ui, -apple-system, "Segoe UI", Roboto, Arial, sans-serif; background: var(--bg-main); color: var(--text); line-height: 1.65; } /* Better 100vh on mobile + prevent phantom scroll */ .page { height: 100dvh; min-height: 0; display: grid; grid-template-rows: auto 1fr auto; overflow: clip; } /* ---- 4) Layout ---- */ .container { width: min(var(--container), 100% - (var(--pad) * 2)); margin-inline: auto; } /* =========================== Header =========================== */ .site-header { position: sticky; top: 0; z-index: 50; backdrop-filter: blur(12px); background: rgba(246, 245, 242, .72); border-bottom: 1px solid var(--border); } .site-header.is-compact { background: rgba(246, 245, 242, .86); border-bottom-color: rgba(212, 185, 140, .22); } .header-inner { display: flex; align-items: center; justify-content: space-between; gap: 1rem; padding: .85rem 0; } .brand { display: inline-flex; align-items: center; gap: .75rem; min-width: 0; } .brand img { width: 90px; height: 70px; border-radius: 14px; background: radial-gradient(900px 180px at 50% 0%, rgba(255, 255, 255, .8), rgba(255, 255, 255, 0) 70%), linear-gradient(145deg, #ffffff, #f3efe6); border: 1px solid rgba(212, 185, 140, .38); box-shadow: 0 10px 24px rgba(17, 24, 39, .12); } .site-header.is-compact .brand img { width: 40px; height: 40px; } .brand-title { display: flex; flex-direction: column; line-height: 1.1; min-width: 0; } .brand-title strong { font-size: 1rem; letter-spacing: .2px; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; } .brand-title span { font-size: .86rem; color: var(--muted); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; } /* Desktop Nav */ .nav { display: flex; align-items: center; gap: .35rem; } .nav a { padding: .55rem .8rem; border-radius: 999px; color: rgba(17, 24, 39, .78); transition: background var(--t-fast) var(--ease), color var(--t-fast) var(--ease), border-color var(--t-fast) var(--ease), transform var(--t-fast) var(--ease); border: 1px solid transparent; } .nav a:hover { background: rgba(17, 24, 39, .05); transform: translateY(-1px); } .nav a[aria-current="page"] { background: linear-gradient(135deg, #546c3c, #384c25); color: #fff; } /* Main full-screen section */ .screen { min-height: 0; overflow: auto; -webkit-overflow-scrolling: touch; display: grid; place-items: center; padding: clamp(1rem, 2.2vh, 2rem) 0; } .screen-inner { width: 100%; display: grid; grid-template-columns: 1.1fr .9fr; gap: clamp(1rem, 3vw, 2rem); align-items: center; } @media (max-width: 900px) { .screen-inner { grid-template-columns: 1fr; } .nav { display: none; } } /* ---- 5) Components ---- */ .card { background: linear-gradient(180deg, rgba(255, 255, 255, .78), rgba(255, 255, 255, .68)); border: 1px solid var(--border); border-radius: var(--radius-xl); box-shadow: var(--shadow); padding: clamp(1rem, 2.4vw, 1.6rem); } .kicker { display: inline-flex; align-items: center; gap: .55rem; color: rgba(17, 24, 39, .70); font-size: .92rem; } .kicker::before { content: ""; width: 10px; height: 10px; border-radius: 999px; background: linear-gradient(135deg, #546c3c, #384c25); box-shadow: 0 10px 30px rgba(56, 76, 37, .35), 0 0 0 4px rgba(84, 108, 60, .18); } h1 { margin: .6rem 0 .6rem; font-size: clamp(2rem, 4vw, 3.1rem); line-height: 1.15; letter-spacing: .2px; } .lead { color: var(--muted); font-size: clamp(1rem, 1.45vw, 1.12rem); margin: 0 0 1.2rem; max-width: 60ch; } /* ====================== Buttons – Premium Style ====================== */ .btn { display: inline-flex; align-items: center; justify-content: center; gap: .55rem; padding: .8rem 1.15rem; border-radius: 999px; border: 1px solid rgba(68, 90, 48, .55); background: linear-gradient(135deg, #546c3c, #384c25); color: #fff; font-weight: 600; letter-spacing: .2px; cursor: pointer; transition: transform .2s var(--ease), box-shadow .2s var(--ease), background .2s var(--ease); } .btn:hover { transform: translateY(-3px); } /* ====================== PRIMARY (THE IMPORTANT ONE) ====================== */ .btn--primary { background: #445a30; color: #fff; font-weight: 700; transition: all .25s ease; } .btn--primary:hover { background: #445a30; } .meta-row { display: flex; flex-wrap: wrap; gap: .65rem; margin-top: 1rem; } .pill { padding: .52rem .75rem; border-radius: 999px; background: rgba(17, 24, 39, .04); border: 1px solid rgba(17, 24, 39, .10); color: rgba(17, 24, 39, .82); font-size: .9rem; } /* =========================== Language Toggle (Modern) =========================== */ .lang-toggle { display: inline-flex; align-items: center; gap: .55rem; padding: .45rem .65rem; border-radius: 999px; background: rgba(255, 255, 255, .78); border: 1px solid var(--border); backdrop-filter: blur(10px); box-shadow: var(--shadow-soft); transition: transform var(--t-fast) var(--ease), background var(--t-fast) var(--ease), border-color var(--t-fast) var(--ease); user-select: none; } .lang-toggle:hover { background: rgba(255, 255, 255, .92); border-color: rgba(212, 185, 140, .28); transform: translateY(-1px); } .lang-toggle__item { font-weight: 800; font-size: .9rem; letter-spacing: .3px; color: rgba(17, 24, 39, .72); padding: .35rem .55rem; border-radius: 999px; line-height: 1; } .lang-toggle__divider { width: 1px; height: 18px; background: rgba(17, 24, 39, .14); } .lang-toggle__item.is-active { color: #fff; background: linear-gradient(135deg, #546c3c, #384c25); box-shadow: 0 10px 26px rgba(184, 140, 58, .18); } /* =========================== Mobile Nav (Drawer) =========================== */ .nav-toggle { display: none; width: 44px; height: 44px; border-radius: 999px; border: 1px solid var(--border); background: rgba(255, 255, 255, .78); backdrop-filter: blur(10px); box-shadow: var(--shadow-soft); align-items: center; justify-content: center; gap: 5px; cursor: pointer; transition: transform var(--t-fast) var(--ease), background var(--t-fast) var(--ease), border-color var(--t-fast) var(--ease); } .nav-toggle:hover { background: rgba(255, 255, 255, .92); border-color: rgba(212, 185, 140, .28); transform: translateY(-1px); } .nav-toggle__bar { width: 18px; height: 2px; border-radius: 999px; background: rgba(17, 24, 39, .88); display: block; } @media (max-width: 900px) { .nav-toggle { display: inline-flex; } } /* Mobile menu wrapper */ .mobile-menu[hidden] { display: none; } .mobile-menu { position: fixed; inset: 0; z-index: 100; } .mobile-menu__backdrop { position: absolute; inset: 0; background: rgba(17, 24, 39, .35); backdrop-filter: blur(4px); opacity: 0; transition: opacity var(--t) var(--ease); } /* Drawer panel */ .mobile-menu__panel { position: absolute; top: 10px; bottom: 10px; width: min(360px, calc(100% - 20px)); background: rgba(255, 255, 255, .86); border: 1px solid var(--border); border-radius: var(--radius-xl); box-shadow: var(--shadow); padding: 1rem; transform: translateX(120%); transition: transform var(--t) var(--ease); } html[lang="ar"] .mobile-menu__panel { right: 10px; } html[lang="en"] .mobile-menu__panel { left: 10px; transform: translateX(-120%); } .mobile-menu__top { display: flex; align-items: center; justify-content: space-between; gap: 1rem; padding-bottom: .75rem; border-bottom: 1px solid var(--border); } .mobile-menu__top strong { font-size: 1.05rem; letter-spacing: .2px; color: rgba(17, 24, 39, .92); } .mobile-menu__close { width: 40px; height: 40px; border-radius: 999px; border: 1px solid var(--border); background: rgba(255, 255, 255, .8); color: rgba(17, 24, 39, .92); cursor: pointer; } .mobile-menu__nav { display: grid; gap: .25rem; padding: .9rem 0; } .mobile-menu__nav a { padding: .8rem .85rem; border-radius: 14px; border: 1px solid rgba(17, 24, 39, .10); background: rgba(17, 24, 39, .03); color: rgba(17, 24, 39, .92); transition: background var(--t-fast) var(--ease), border-color var(--t-fast) var(--ease), transform var(--t-fast) var(--ease); } .mobile-menu__nav a:hover { background: rgba(212, 185, 140, .16); border-color: rgba(212, 185, 140, .30); transform: translateY(-1px); } .mobile-menu__nav a[aria-current="page"] { /* background: rgba(212, 185, 140, .22); border-color: rgba(212, 185, 140, .38); */ } .mobile-menu__actions { display: grid; gap: .6rem; padding-top: .75rem; border-top: 1px solid var(--border); } /* Open state */ .mobile-menu.is-open .mobile-menu__backdrop { opacity: 1; } html[lang="ar"] .mobile-menu.is-open .mobile-menu__panel { transform: translateX(0); } html[lang="en"] .mobile-menu.is-open .mobile-menu__panel { transform: translateX(0); } /* ---- 6) RTL/LTR handling ---- */ html[lang="ar"] body { direction: rtl; text-align: right; } html[lang="en"] body { direction: ltr; text-align: left; } /* ---- 7) Motion (safe) ---- */ [data-animate] { opacity: 0; transform: translateY(10px); transition: opacity var(--t) var(--ease), transform var(--t) var(--ease); } [data-animate].is-in { opacity: 1; transform: none; } @media (prefers-reduced-motion: reduce) { * { transition: none !important; animation: none !important; } html { scroll-behavior: auto; } } /* =========================== Page Transitions =========================== */ .page { opacity: 1; transition: opacity 240ms var(--ease); } .page.is-leaving { opacity: 0; } .page.is-entering { opacity: 0; } .page.is-entering.is-ready { opacity: 1; } @media (max-width: 900px) { .lang-toggle { display: none; } .nav-toggle { margin-inline-start: auto; } } /* =========================== Hero Upgrade =========================== */ .hero-title { margin: .6rem 0 .6rem; font-size: clamp(2rem, 4vw, 3.2rem); line-height: 1.12; } .hero-title__accent { background: linear-gradient(135deg, rgba(184, 140, 58, 1), rgba(212, 185, 140, 1)); -webkit-background-clip: text; background-clip: text; color: transparent; } .hero-actions { display: flex; gap: .75rem; flex-wrap: wrap; margin-top: .25rem; } .hero-stats { margin: 1.1rem 0 0; display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: .65rem; } .stat { padding: .75rem .85rem; border-radius: 16px; background: rgba(17, 24, 39, .03); border: 1px solid rgba(17, 24, 39, .10); } .stat dt { font-size: .86rem; color: rgba(17, 24, 39, .68); margin: 0 0 .15rem; } .stat dd { margin: 0; font-weight: 800; letter-spacing: .2px; color: rgba(17, 24, 39, .92); } .hero-card .card-title { margin: 0 0 .5rem; font-size: 1.2rem; } .hero-card .card-text { margin: 0 0 .9rem; color: var(--muted); } .checklist { list-style: none; padding: 0; margin: 0 0 1rem; display: grid; gap: .55rem; } .checklist li { position: relative; padding-inline-start: 1.6rem; color: rgba(17, 24, 39, .86); } .checklist li::before { content: "✓"; position: absolute; inset-inline-start: 0; top: 0; width: 1.2rem; height: 1.2rem; display: grid; place-items: center; border-radius: 999px; background: rgba(212, 185, 140, .22); border: 1px solid rgba(212, 185, 140, .35); color: rgba(17, 24, 39, .92); font-weight: 900; font-size: .85rem; } /* =========================== Hero Card: Logo Banner =========================== */ .hero-card .card-banner { width: 100%; border-radius: 18px; padding: clamp(16px, 2vw, 20px); margin-bottom: .95rem; background: radial-gradient(900px 180px at 50% 0%, rgba(255, 255, 255, .85), rgba(255, 255, 255, 0) 70%), linear-gradient(145deg, #ffffff, #f3efe6); border: 1px solid rgba(17, 24, 39, .10); box-shadow: 0 8px 22px rgba(17, 24, 39, .08), inset 0 1px 0 rgba(255, 255, 255, .6); position: relative; overflow: visible; display: grid; place-items: center; } .hero-card .card-banner::after { content: ""; position: absolute; top: -60px; right: -70px; width: 280px; height: 280px; background: radial-gradient(circle, rgba(212, 185, 140, .20), transparent 70%); transform: rotate(18deg); pointer-events: none; } .hero-card .card-banner::before { content: ""; position: absolute; inset: 0; background: linear-gradient(120deg, transparent 40%, rgba(255, 255, 255, .28), transparent 60%); opacity: .45; pointer-events: none; } .hero-card .card-banner .banner-line { position: absolute; bottom: -7px; left: 18%; width: 64%; height: 2px; background: linear-gradient(90deg, transparent, rgba(184, 140, 58, .95), transparent); opacity: .9; pointer-events: none; } .hero-card .card-banner__logo { width: 100%; max-width: 680px; /* 👈 كبرنا العرض */ height: clamp(150px, 22vh, 240px); object-fit: contain; display: block; padding: clamp(4px, 1vw, 8px); filter: drop-shadow(0 14px 22px rgba(17, 24, 39, .18)) drop-shadow(0 2px 0 rgba(255, 255, 255, .45)); } @media (max-width: 480px) { .hero-card .card-banner { padding: 14px; border-radius: 16px; } .hero-card .card-banner__logo { height: 96px; } } @media (max-width: 900px) { .hero-stats { grid-template-columns: 1fr; } .screen { padding: 1.1rem 0; } .hero-title { font-size: clamp(1.75rem, 6vw, 2.3rem); } } /* Keep header nice on very small screens */ @media (max-width: 480px) { .brand-title span { display: none; } } /* =========================== About Page =========================== */ .about-grid { width: 100%; display: grid; grid-template-columns: 1.1fr .9fr; gap: clamp(1rem, 3vw, 2rem); align-items: center; } .about-grid>section { height: 100%; display: flex; flex-direction: column; justify-content: center; } .about-cards { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: .75rem; margin-top: 1rem; } .about-card { padding: 1rem; border-radius: var(--radius-lg); background: rgba(17, 24, 39, .03); border: 1px solid rgba(17, 24, 39, .10); } .about-card h3 { margin: 0 0 .35rem; font-size: 1.05rem; color: rgba(17, 24, 39, .92); } .about-card p { margin: 0; color: var(--muted); font-size: .95rem; } .about-panel { position: relative; } .about-panel .panel-title { margin: 0 0 .6rem; font-size: 1.2rem; } .about-list { list-style: none; padding: 0; margin: 0; display: grid; gap: .55rem; } .about-list li { padding: .75rem .85rem; border-radius: 16px; background: rgba(17, 24, 39, .03); border: 1px solid rgba(17, 24, 39, .10); color: rgba(17, 24, 39, .88); } @media (max-width: 900px) { .about-grid { grid-template-columns: 1fr; } .about-cards { grid-template-columns: 1fr; } } /* =========================== Services Page =========================== */ .services-grid { width: 100%; display: grid; grid-template-columns: 1.05fr .95fr; gap: clamp(1rem, 3vw, 2rem); align-items: center; } .services-cards { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: .75rem; } .service-card { border-radius: var(--radius-xl); background: rgba(255, 255, 255, .78); border: 1px solid rgba(17, 24, 39, .10); box-shadow: var(--shadow-soft); padding: 1rem; cursor: pointer; text-align: inherit; transition: transform var(--t-fast) var(--ease), background var(--t-fast) var(--ease), border-color var(--t-fast) var(--ease); } .service-card:hover { transform: translateY(-2px); background: rgba(255, 255, 255, .92); border-color: rgba(212, 185, 140, .32); } .service-card__tag { display: inline-flex; align-items: center; gap: .4rem; font-size: .88rem; color: rgba(17, 24, 39, .72); margin-bottom: .4rem; } .service-card__tag::before { content: ""; width: 10px; height: 10px; border-radius: 999px; background: linear-gradient(135deg, #546c3c, #384c25); box-shadow: 0 10px 30px rgba(56, 76, 37, .35), 0 0 0 4px rgba(84, 108, 60, .18); } .service-card__title { margin: .1rem 0 .35rem; font-size: 1.05rem; letter-spacing: .2px; color: rgba(17, 24, 39, .92); } .service-card__desc { margin: 0; color: var(--muted); font-size: .95rem; } .services-panel.card { padding: 1.1rem; } .services-panel h2 { margin: 0 0 .35rem; font-size: 1.2rem; } .services-panel p { margin: 0 0 .9rem; color: var(--muted); } .services-bullets { list-style: none; padding: 0; margin: 0; display: grid; gap: .55rem; } .services-bullets li { padding: .75rem .85rem; border-radius: 16px; background: rgba(17, 24, 39, .03); border: 1px solid rgba(17, 24, 39, .10); color: rgba(17, 24, 39, .88); } /* ===== Service Overlay (details) ===== */ .service-overlay[hidden] { display: none; } .service-overlay { position: fixed; inset: 0; z-index: 120; } .service-overlay__backdrop { position: absolute; inset: 0; background: rgba(17, 24, 39, .35); backdrop-filter: blur(6px); opacity: 0; transition: opacity var(--t) var(--ease); } .service-overlay__panel { position: absolute; top: 12px; bottom: 12px; width: min(760px, calc(100% - 24px)); left: 50%; transform: translate(-50%, 18px); border-radius: var(--radius-xl); background: rgba(255, 255, 255, .92); border: 1px solid rgba(17, 24, 39, .12); box-shadow: var(--shadow); padding: 1rem; opacity: 0; transition: opacity var(--t) var(--ease), transform var(--t) var(--ease); overflow: auto; } .service-overlay__top { display: flex; align-items: center; justify-content: space-between; gap: 1rem; padding-bottom: .75rem; border-bottom: 1px solid rgba(17, 24, 39, .10); margin-bottom: .85rem; } .service-overlay__top strong { font-size: 1.05rem; letter-spacing: .2px; color: rgba(17, 24, 39, .92); } .service-overlay__close { width: 40px; height: 40px; border-radius: 999px; border: 1px solid rgba(17, 24, 39, .14); background: rgba(17, 24, 39, .03); color: rgba(17, 24, 39, .92); cursor: pointer; } .service-overlay__content h3 { margin: .2rem 0 .35rem; font-size: 1.25rem; color: rgba(17, 24, 39, .92); } .service-overlay__content p { margin: 0 0 .9rem; color: var(--muted); } .service-overlay__content .checklist { margin-top: .7rem; } .service-overlay.is-open .service-overlay__backdrop { opacity: 1; } .service-overlay.is-open .service-overlay__panel { opacity: 1; transform: translate(-50%, 0); } @media (max-width: 900px) { .services-grid { grid-template-columns: 1fr; align-items: start; } .services-cards { grid-template-columns: 1fr; } } /* =========================== Projects Page =========================== */ .projects-grid { width: 100%; display: grid; grid-template-columns: 1.05fr .95fr; gap: clamp(1rem, 3vw, 2rem); align-items: center; } .projects-list { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: .75rem; } .project-card { border-radius: var(--radius-xl); overflow: hidden; background: rgba(255, 255, 255, .78); border: 1px solid rgba(17, 24, 39, .10); box-shadow: var(--shadow-soft); cursor: pointer; transition: transform var(--t-fast) var(--ease), border-color var(--t-fast) var(--ease), background var(--t-fast) var(--ease); text-align: inherit; } .project-card:hover { transform: translateY(-2px); border-color: rgba(212, 185, 140, .32); background: rgba(255, 255, 255, .92); } .project-thumb { aspect-ratio: 16/10; background: rgba(17, 24, 39, .06); position: relative; } .project-thumb img { width: 100%; height: 100%; object-fit: cover; filter: saturate(1.04) contrast(1.02); } .project-body { padding: .85rem .95rem 1rem; } .project-meta { display: inline-flex; align-items: center; gap: .45rem; color: rgba(17, 24, 39, .70); font-size: .88rem; } .project-meta::before { content: ""; width: 10px; height: 10px; border-radius: 999px; background: linear-gradient(135deg, #546c3c, #384c25); box-shadow: 0 10px 30px rgba(56, 76, 37, .35), 0 0 0 4px rgba(84, 108, 60, .18); } .project-title { margin: .35rem 0 .35rem; font-size: 1.05rem; color: rgba(17, 24, 39, .92); } .project-desc { margin: 0; color: var(--muted); font-size: .95rem; } /* Right panel */ .projects-panel.card { padding: 1.1rem; } .projects-panel h2 { margin: 0 0 .35rem; font-size: 1.2rem; } .projects-panel p { margin: 0 0 .9rem; color: var(--muted); } /* ===== Lightbox ===== */ .lightbox[hidden] { display: none; } .lightbox { position: fixed; inset: 0; z-index: 140; } .lightbox__backdrop { position: absolute; inset: 0; background: rgba(17, 24, 39, .45); backdrop-filter: blur(6px); opacity: 0; transition: opacity var(--t) var(--ease); } .lightbox__panel { position: absolute; top: 12px; bottom: 12px; width: min(980px, calc(100% - 24px)); left: 50%; transform: translate(-50%, 18px); border-radius: var(--radius-xl); background: rgba(255, 255, 255, .94); border: 1px solid rgba(17, 24, 39, .12); box-shadow: var(--shadow); padding: 1rem; opacity: 0; transition: opacity var(--t) var(--ease), transform var(--t) var(--ease); display: grid; grid-template-rows: auto 1fr auto; gap: .85rem; } .lightbox__top { display: flex; align-items: center; justify-content: space-between; gap: 1rem; padding-bottom: .75rem; border-bottom: 1px solid rgba(17, 24, 39, .10); } .lightbox__top strong { font-size: 1.05rem; letter-spacing: .2px; color: rgba(17, 24, 39, .92); } .lightbox__close { width: 40px; height: 40px; border-radius: 999px; border: 1px solid rgba(17, 24, 39, .14); background: rgba(17, 24, 39, .03); color: rgba(17, 24, 39, .92); cursor: pointer; } .lightbox__stage { display: grid; place-items: center; border-radius: 18px; overflow: hidden; background: rgba(17, 24, 39, .06); border: 1px solid rgba(17, 24, 39, .10); } .lightbox__stage img { width: 100%; height: 100%; object-fit: cover; max-height: 56vh; } .lightbox__bottom { display: flex; flex-wrap: wrap; align-items: center; justify-content: space-between; gap: .75rem; } .lightbox__caption { color: rgba(17, 24, 39, .78); } .lightbox__nav { display: flex; gap: .5rem; } .icon-btn { width: 42px; height: 42px; border-radius: 999px; border: 1px solid rgba(17, 24, 39, .14); background: rgba(17, 24, 39, .03); color: rgba(17, 24, 39, .92); cursor: pointer; display: grid; place-items: center; transition: transform var(--t-fast) var(--ease), background var(--t-fast) var(--ease), border-color var(--t-fast) var(--ease); } .icon-btn:hover { background: rgba(212, 185, 140, .16); border-color: rgba(212, 185, 140, .30); transform: translateY(-1px); } .lightbox.is-open .lightbox__backdrop { opacity: 1; } .lightbox.is-open .lightbox__panel { opacity: 1; transform: translate(-50%, 0); } @media (max-width: 900px) { .projects-grid { grid-template-columns: 1fr; align-items: start; } .projects-list { grid-template-columns: 1fr; } .lightbox__stage img { max-height: 50vh; } } /* =========================== Contact Page =========================== */ .contact-grid { width: 100%; display: grid; grid-template-columns: 1.05fr .95fr; gap: clamp(1rem, 3vw, 2rem); align-items: center; } .form { display: grid; gap: .75rem; margin-top: 1rem; } .field { display: grid; gap: .35rem; } .label { font-weight: 800; font-size: .95rem; color: rgba(17, 24, 39, .90); } .input, .textarea { width: 100%; border-radius: 16px; padding: .85rem .9rem; border: 1px solid rgba(17, 24, 39, .14); background: rgba(255, 255, 255, .86); color: rgba(17, 24, 39, .92); outline: none; transition: border-color var(--t-fast) var(--ease), background var(--t-fast) var(--ease), box-shadow var(--t-fast) var(--ease); } .textarea { min-height: 120px; resize: vertical; } .input:focus, .textarea:focus { border-color: rgba(212, 185, 140, .55); box-shadow: 0 0 0 4px rgba(212, 185, 140, .18); background: rgba(255, 255, 255, .96); } .help { margin: 0; color: rgba(17, 24, 39, .64); font-size: .9rem; } .form-actions { display: flex; gap: .75rem; flex-wrap: wrap; align-items: center; margin-top: .25rem; } .toast { border-radius: 16px; padding: .75rem .85rem; border: 1px solid rgba(17, 24, 39, .12); background: rgba(255, 255, 255, .86); color: rgba(17, 24, 39, .88); display: none; } .toast.is-show { display: block; } .map-wrapper { position: relative; width: 100%; border-radius: var(--radius-lg); overflow: hidden; box-shadow: var(--shadow-soft); margin-top: 1rem; } .map-wrapper iframe { width: 100%; height: 350px; border: 0; display: block; } .contact-cards { display: grid; gap: .75rem; } .contact-card { padding: 1rem; border-radius: var(--radius-xl); background: rgba(255, 255, 255, .78); border: 1px solid rgba(17, 24, 39, .10); } .contact-card h2 { margin: 0 0 .45rem; font-size: 1.15rem; color: rgba(17, 24, 39, .92); } .contact-card p { margin: 0 0 .8rem; color: var(--muted); } .quick-links { display: grid; gap: .55rem; margin: 0; padding: 0; list-style: none; } .quick-links a { display: flex; align-items: center; justify-content: space-between; gap: .75rem; padding: .8rem .85rem; border-radius: 16px; border: 1px solid rgba(17, 24, 39, .10); background: rgba(17, 24, 39, .03); transition: transform var(--t-fast) var(--ease), background var(--t-fast) var(--ease), border-color var(--t-fast) var(--ease); } .quick-links a:hover { transform: translateY(-1px); background: rgba(212, 185, 140, .16); border-color: rgba(212, 185, 140, .30); } .quick-links small { color: rgba(17, 24, 39, .62); } @media (max-width: 900px) { .contact-grid { grid-template-columns: 1fr; align-items: start; } } /* Safety */ @media (max-width: 900px) { .lang-toggle { display: none; } } /* =========================== Footer – Clean Light Version =========================== */ /* =========================== Modern Luxury Footer =========================== */ .site-footer { margin-top: auto; padding: 1rem 0; background: linear-gradient(to top, rgba(0, 0, 0, .03), transparent); border-top: 1px solid rgba(0, 0, 0, .06); } /* layout */ .footer-inner { display: flex; flex-direction: column; align-items: center; gap: .6rem; } /* brand */ .footer-brand { display: flex; align-items: center; gap: .4rem; font-weight: 700; letter-spacing: .3px; color: var(--text); } .footer-brand span { color: #384b26; font-weight: 800; } /* gold line */ .footer-divider { width: 110px; height: 2px; border-radius: 999px; background: linear-gradient(90deg, transparent, var(--accent), transparent); opacity: .6; } /* copyright */ .footer-copy { margin: 0; font-size: .85rem; color: var(--muted); }