/* ============================================================
   TAMIMI FISH — Brand Colors: Deep Sea Blue #002B5B | Green #00A651
   ============================================================ */

:root {
    --navy:       #002B5B;
    --navy-dark:  #001830;
    --navy-mid:   #003A7A;
    --blue:       #1565C0;
    --blue-lt:    #1E88E5;
    --green:      #00A651;
    --green-dk:   #007A3B;
    --green-lt:   rgba(0,166,81,0.1);
    --sky:        #F0F7FF;
    --white:      #FFFFFF;
    --g100:       #F5F9FF;
    --g200:       #E4EFF8;
    --g300:       #C5D8EC;
    --g500:       #7A9BBC;
    --g700:       #3E5F80;
    --dark:       #0D1F35;

    --font:       'Montserrat', sans-serif;
    --font-serif: 'Playfair Display', serif;

    --sh-sm:  0 2px 10px rgba(0,43,91,.08);
    --sh-md:  0 8px 28px rgba(0,43,91,.12);
    --sh-lg:  0 16px 48px rgba(0,43,91,.16);
    --sh-xl:  0 28px 72px rgba(0,43,91,.22);

    --r:    12px;
    --r-lg: 20px;
    --r-xl: 32px;
    --ease: 0.3s ease;
    --pad:  clamp(20px, 5vw, 32px);
    --max:  1280px;
}

/* ---- RESET ---- */
*, *::before, *::after { margin:0; padding:0; box-sizing:border-box; }
html { scroll-behavior:smooth; font-size:16px; }
body { font-family:var(--font); color:var(--dark); background:var(--white); line-height:1.6; overflow-x:hidden; }
img  { max-width:100%; display:block; }
a    { text-decoration:none; color:inherit; }
ul   { list-style:none; }
button { font-family:var(--font); }

/* ---- UTILITIES ---- */
.container   { max-width:var(--max); margin:0 auto; padding:0 var(--pad); }
.section     { padding:clamp(60px,10vw,110px) 0; }

.section-label {
    display:inline-flex; align-items:center; gap:10px;
    font-size:.72rem; font-weight:700; letter-spacing:.18em;
    text-transform:uppercase; color:var(--green); margin-bottom:14px;
}
.section-label::before { content:''; width:28px; height:2px; background:var(--green); }
.section-label.centered { justify-content:center; }
.section-label.centered::before { display:none; }
.section-label.centered::after  { content:''; width:28px; height:2px; background:var(--green); }
.section-label.light { color:#7DFFB0; }
.section-label.light::before, .section-label.light::after { background:#7DFFB0; }

.section-title  { font-size:clamp(1.9rem,3.8vw,2.75rem); font-weight:800; color:var(--navy); line-height:1.2; margin-bottom:18px; }
.section-title.centered { text-align:center; }
.section-title.light    { color:#fff; }

.section-sub { font-size:1rem; color:var(--g700); max-width:560px; line-height:1.75; }
.section-sub.centered   { text-align:center; margin:0 auto; }
.section-sub.light      { color:rgba(255,255,255,.7); }

.section-header { margin-bottom:56px; }

.body-text { color:var(--g700); line-height:1.82; font-size:.97rem; margin-bottom:18px; }

/* ---- BUTTONS ---- */
.btn {
    display:inline-flex; align-items:center; gap:8px;
    padding:13px 28px; font-size:.875rem; font-weight:700;
    border-radius:50px; border:none; cursor:pointer;
    transition:all var(--ease); white-space:nowrap;
    letter-spacing:.01em;
}
.btn-primary {
    background:var(--green); color:#fff;
}
.btn-primary:hover {
    background:var(--green-dk);
    transform:translateY(-2px);
    box-shadow:0 8px 24px rgba(0,166,81,.38);
}
.btn-ghost {
    background:rgba(255,255,255,.12);
    color:#fff;
    border:2px solid rgba(255,255,255,.5);
    backdrop-filter:blur(8px);
}
.btn-ghost:hover {
    background:rgba(255,255,255,.22);
    border-color:#fff;
    transform:translateY(-2px);
}
.btn-nav {
    background:var(--green); color:#fff;
    padding:10px 22px; font-size:.82rem; border-radius:50px;
}
.btn-nav:hover { background:var(--green-dk); }
.btn-block { width:100%; justify-content:center; padding:15px; font-size:.95rem; }

/* ============================================================
   NAVIGATION
   ============================================================ */
.navbar {
    position:fixed; top:0; left:0; right:0; z-index:900;
    padding:14px 0;
    transition:all var(--ease);
}
.navbar.scrolled {
    background:rgba(0,24,48,.96);
    backdrop-filter:blur(20px);
    padding:8px 0;
    box-shadow:0 4px 28px rgba(0,0,0,.35);
}
.nav-container {
    max-width:var(--max); margin:0 auto; padding:0 var(--pad);
    display:flex; align-items:center; justify-content:space-between; gap:32px;
}
.nav-logo { display:flex; align-items:center; gap:12px; }
.nav-logo img {
    height:50px; width:auto;
    border-radius:8px;
    background:#fff;
    padding:3px;
    box-shadow:0 2px 8px rgba(0,0,0,.2);
}
.nav-brand {
    font-size:1.2rem; font-weight:900; color:#fff;
    letter-spacing:.06em; line-height:1;
}
.nav-brand span { color:var(--green); }
.nav-menu { display:flex; align-items:center; gap:36px; }
.nav-links { display:flex; align-items:center; gap:28px; }
.nav-link {
    font-size:.85rem; font-weight:600; color:rgba(255,255,255,.8);
    transition:color var(--ease); position:relative; padding-bottom:4px;
}
.nav-link::after {
    content:''; position:absolute; bottom:0; left:0;
    width:0; height:2px; background:var(--green);
    transition:width var(--ease);
}
.nav-link:hover, .nav-link.active { color:#fff; }
.nav-link:hover::after, .nav-link.active::after { width:100%; }
.nav-toggle {
    display:none; flex-direction:column; gap:5px;
    background:none; border:none; cursor:pointer; padding:4px; z-index:910;
}
.nav-toggle span {
    display:block; width:24px; height:2px;
    background:#fff; border-radius:2px; transition:all var(--ease);
}

/* ============================================================
   HERO
   ============================================================ */
.hero {
    min-height:100vh;
    background:linear-gradient(150deg, #001020 0%, #001C3A 35%, #003060 70%, #004080 100%);
    display:flex; align-items:center; justify-content:center;
    position:relative; overflow:hidden;
    padding:clamp(100px,15vw,130px) var(--pad) 100px;
}
.hero::before {
    content:'';
    position:absolute; inset:0;
    background:
        radial-gradient(ellipse at 75% 40%, rgba(30,136,229,.18) 0%, transparent 55%),
        radial-gradient(ellipse at 25% 80%, rgba(0,166,81,.1) 0%, transparent 50%);
}
.hero-particles { position:absolute; inset:0; overflow:hidden; z-index:1; }
.particle {
    position:absolute; border-radius:50%;
    background:rgba(255,255,255,.55);
    animation:floatUp linear infinite;
}
@keyframes floatUp {
    0%   { transform:translateY(100vh) translateX(0);   opacity:0; }
    8%   { opacity:1; }
    92%  { opacity:.4; }
    100% { transform:translateY(-80px) translateX(var(--dx)); opacity:0; }
}
.hero-content { position:relative; z-index:2; text-align:center; max-width:820px; }
.hero-badge {
    display:inline-flex; align-items:center; gap:10px;
    background:rgba(255,255,255,.09);
    backdrop-filter:blur(12px);
    border:1px solid rgba(255,255,255,.18);
    color:rgba(255,255,255,.9);
    padding:8px 22px; border-radius:50px;
    font-size:.72rem; font-weight:700; letter-spacing:.14em;
    text-transform:uppercase; margin-bottom:30px;
}
.badge-dot {
    width:8px; height:8px; border-radius:50%; background:var(--green);
    animation:blink 2.2s ease-in-out infinite;
}
@keyframes blink { 0%,100%{opacity:1;transform:scale(1)} 50%{opacity:.4;transform:scale(1.5)} }

.hero-title {
    font-size:clamp(2.6rem,7vw,5.2rem);
    font-weight:900; color:#fff; line-height:1.1;
    letter-spacing:-.025em; margin-bottom:22px;
}
.hero-title-accent {
    background:linear-gradient(90deg, #00D4FF 0%, #00E676 50%, #1E88E5 100%);
    -webkit-background-clip:text; -webkit-text-fill-color:transparent;
    background-clip:text;
}
.hero-subtitle {
    font-size:clamp(.95rem,1.8vw,1.15rem);
    color:rgba(255,255,255,.7); line-height:1.75; margin-bottom:36px;
}
.hero-stats {
    display:flex; align-items:center; justify-content:center;
    gap:28px; margin-bottom:40px;
}
.hero-stat { text-align:center; }
.hero-stat-num { display:block; font-size:1.9rem; font-weight:900; color:#fff; line-height:1; }
.hero-stat-lbl { display:block; font-size:.68rem; font-weight:600; color:rgba(255,255,255,.55); text-transform:uppercase; letter-spacing:.08em; margin-top:4px; }
.hero-stat-sep  { width:1px; height:44px; background:rgba(255,255,255,.18); }
.hero-btns { display:flex; align-items:center; justify-content:center; gap:14px; flex-wrap:wrap; }
.hero-scroll {
    position:absolute; bottom:70px; left:50%; transform:translateX(-50%);
    z-index:2; display:flex; flex-direction:column; align-items:center; gap:8px;
    color:rgba(255,255,255,.4); font-size:.65rem; font-weight:600; letter-spacing:.12em; text-transform:uppercase;
}
.scroll-mouse {
    width:20px; height:32px;
    border:2px solid rgba(255,255,255,.3); border-radius:12px;
    display:flex; justify-content:center; padding-top:5px;
}
.scroll-dot {
    width:3px; height:6px; background:rgba(255,255,255,.5); border-radius:2px;
    animation:scrollAnim 1.6s ease-in-out infinite;
}
@keyframes scrollAnim { 0%{transform:translateY(0);opacity:1} 100%{transform:translateY(10px);opacity:0} }
.hero-wave { position:absolute; bottom:0; left:0; right:0; height:100px; }
.hero-wave svg { width:100%; height:100%; }

/* ============================================================
   ABOUT
   ============================================================ */
.about { background:var(--sky); }
.about-grid {
    display:grid; grid-template-columns:1fr 1.35fr; gap:72px; align-items:center;
}
.about-visual { position:relative; }
.about-logo-card {
    background:#fff; border-radius:var(--r-xl); padding:44px;
    box-shadow:var(--sh-xl); position:relative; overflow:hidden;
}
.about-logo-card::before {
    content:''; position:absolute; inset:0;
    background:linear-gradient(135deg,rgba(0,43,91,.025),rgba(0,166,81,.025));
}
.about-logo-card img { width:100%; max-width:360px; margin:0 auto; position:relative; z-index:1; }
.about-badge {
    position:absolute; bottom:-18px; right:28px;
    background:var(--green); color:#fff;
    padding:18px 22px; border-radius:16px;
    text-align:center; box-shadow:var(--sh-md);
}
.about-badge span { display:block; font-size:.7rem; font-weight:700; letter-spacing:.1em; text-transform:uppercase; opacity:.82; margin-bottom:4px; }
.about-badge strong { display:block; font-size:1.9rem; font-weight:900; line-height:1; }
.about-float-card {
    position:absolute; top:24px; left:-24px;
    background:#fff; border-radius:14px;
    padding:14px 18px; box-shadow:var(--sh-md);
    display:flex; align-items:center; gap:12px;
    border:1px solid var(--g200);
}
.about-float-card svg { width:28px; height:28px; flex-shrink:0; color:var(--blue-lt); }
.about-float-card strong { display:block; font-size:.88rem; font-weight:700; color:var(--navy); }
.about-float-card span  { display:block; font-size:.73rem; color:var(--g700); }

.about-features { display:grid; grid-template-columns:1fr 1fr; gap:14px; margin:28px 0 32px; }
.about-feat { display:flex; align-items:center; gap:10px; font-size:.86rem; font-weight:600; color:var(--navy); }
.feat-icon {
    width:34px; height:34px; background:var(--green-lt);
    border-radius:8px; display:flex; align-items:center; justify-content:center; flex-shrink:0;
}
.feat-icon svg { width:16px; height:16px; color:var(--green); }

/* ============================================================
   STATS BANNER
   ============================================================ */
.stats-banner {
    background:linear-gradient(135deg, var(--navy) 0%, #004090 100%);
    padding:clamp(40px,7vw,70px) 0;
}
.stats-grid { display:grid; grid-template-columns:repeat(4,1fr); gap:40px; text-align:center; }
.stat-block { color:#fff; }
.stat-emoji { font-size:2rem; margin-bottom:12px; }
.stat-count { font-size:clamp(2.4rem,5vw,3.4rem); font-weight:900; line-height:1; color:#fff; }
.stat-plus  { font-size:1rem; font-weight:700; color:var(--green); margin-bottom:6px; }
.stat-sub   { font-size:.72rem; font-weight:600; color:rgba(255,255,255,.5); text-transform:uppercase; letter-spacing:.1em; }

/* ============================================================
   PRODUCTS
   ============================================================ */
.products { background:var(--white); }
.filter-bar {
    display:flex; align-items:center; justify-content:center;
    flex-wrap:wrap; gap:10px; margin-bottom:48px;
}
.filter-btn {
    padding:10px 22px; font-size:.82rem; font-weight:700;
    color:var(--g700); background:var(--sky);
    border:1.5px solid var(--g300); border-radius:50px;
    cursor:pointer; transition:all var(--ease); letter-spacing:.02em;
}
.filter-btn:hover, .filter-btn.active {
    background:var(--navy); color:#fff; border-color:var(--navy);
}
.products-grid {
    display:grid;
    grid-template-columns:repeat(auto-fill, minmax(210px,1fr));
    gap:22px;
}
.p-card {
    background:#fff; border-radius:var(--r-lg);
    border:1.5px solid var(--g200);
    transition:all var(--ease); cursor:default;
    overflow:hidden;
}
.p-card:hover { transform:translateY(-6px); box-shadow:var(--sh-lg); border-color:transparent; }
.p-card-img {
    background:var(--g100); height:172px;
    display:flex; align-items:center; justify-content:center;
    overflow:hidden; padding:18px;
}
.p-card-img img {
    max-height:100%; max-width:100%;
    object-fit:contain;
    transition:transform .45s ease;
}
.p-card:hover .p-card-img img { transform:scale(1.1); }
.p-card-body { padding:14px 18px 18px; }
.p-card-name { font-size:.92rem; font-weight:700; color:var(--navy); margin-bottom:6px; }
.p-card-tag {
    display:inline-block; font-size:.66rem; font-weight:700;
    color:var(--green); background:var(--green-lt);
    padding:3px 10px; border-radius:50px;
    text-transform:uppercase; letter-spacing:.06em;
}

/* ============================================================
   VALUES
   ============================================================ */
.values { background:var(--navy); position:relative; overflow:hidden; }
.values-overlay {
    position:absolute; inset:0;
    background:
        radial-gradient(ellipse at 15% 60%, rgba(0,212,255,.1) 0%, transparent 45%),
        radial-gradient(ellipse at 85% 40%, rgba(0,166,81,.08) 0%, transparent 45%);
}
.values .container { position:relative; z-index:2; }
.values-grid { display:grid; grid-template-columns:repeat(5,1fr); gap:20px; }
.value-card {
    background:rgba(255,255,255,.07); border:1px solid rgba(255,255,255,.11);
    border-radius:var(--r-lg); padding:28px 20px; text-align:center;
    transition:all var(--ease); backdrop-filter:blur(8px);
}
.value-card:hover { background:rgba(255,255,255,.13); transform:translateY(-5px); box-shadow:0 16px 40px rgba(0,0,0,.25); }
.value-icon { width:60px; height:60px; margin:0 auto 18px; color:var(--green); }
.value-icon svg { width:100%; height:100%; }
.value-card h3 { font-size:1rem; font-weight:700; color:#fff; margin-bottom:10px; }
.value-card p  { font-size:.82rem; color:rgba(255,255,255,.6); line-height:1.65; }

/* ============================================================
   PROCESS
   ============================================================ */
.process { background:var(--sky); }
.process-row {
    display:flex; align-items:flex-start; justify-content:center;
    gap:0; flex-wrap:nowrap;
}
.process-step { flex:1; max-width:280px; text-align:center; padding:0 20px; }
.ps-num { font-size:.68rem; font-weight:800; letter-spacing:.18em; color:var(--green); margin-bottom:16px; }
.ps-icon {
    width:76px; height:76px; background:#fff; border-radius:50%;
    display:flex; align-items:center; justify-content:center;
    margin:0 auto 18px; box-shadow:var(--sh-md); color:var(--navy);
}
.ps-icon svg { width:34px; height:34px; }
.process-step h3 { font-size:1.05rem; font-weight:700; color:var(--navy); margin-bottom:10px; }
.process-step p  { font-size:.87rem; color:var(--g700); line-height:1.7; }
.process-arrow { flex-shrink:0; color:var(--g300); padding-top:56px; }
.process-arrow svg { width:44px; height:24px; }

/* ============================================================
   CONTACT
   ============================================================ */
.contact { background:#fff; }
.contact-grid { display:grid; grid-template-columns:1fr 1.3fr; gap:72px; align-items:start; }
.contact-items { display:flex; flex-direction:column; gap:18px; margin-top:32px; }
.contact-item  { display:flex; align-items:flex-start; gap:14px; }
.ci-icon {
    width:46px; height:46px; flex-shrink:0;
    background:rgba(0,43,91,.06); border-radius:12px;
    display:flex; align-items:center; justify-content:center; color:var(--navy);
}
.ci-icon svg { width:20px; height:20px; }
.ci-label { display:block; font-size:.7rem; font-weight:700; letter-spacing:.12em; text-transform:uppercase; color:var(--g500); margin-bottom:4px; }
.ci-value { font-size:.97rem; font-weight:700; color:var(--navy); }
a.ci-value:hover { color:var(--green); }

.contact-form-box {
    background:var(--sky); border-radius:var(--r-xl);
    padding:38px; box-shadow:var(--sh-md);
}
.form-row { margin-bottom:0; }
.two-col { display:grid; grid-template-columns:1fr 1fr; gap:16px; }
.form-group { display:flex; flex-direction:column; gap:6px; margin-bottom:18px; }
.form-group label { font-size:.78rem; font-weight:700; color:var(--navy); letter-spacing:.03em; }
.form-group input,
.form-group select,
.form-group textarea {
    padding:13px 15px; font-family:var(--font); font-size:.9rem;
    color:var(--dark); background:#fff;
    border:1.5px solid var(--g200); border-radius:10px;
    transition:all var(--ease); outline:none; width:100%;
}
.form-group input::placeholder,
.form-group textarea::placeholder { color:var(--g500); }
.form-group input:focus,
.form-group select:focus,
.form-group textarea:focus {
    border-color:var(--blue-lt);
    box-shadow:0 0 0 3.5px rgba(30,136,229,.14);
}
.form-group textarea { resize:vertical; min-height:110px; }
.form-msg { margin-top:14px; padding:12px 16px; border-radius:8px; font-size:.875rem; font-weight:600; }
.form-msg.success { background:rgba(0,166,81,.12); color:var(--green-dk); }
.form-msg.error   { background:rgba(220,53,69,.1);  color:#c0392b; }

/* ============================================================
   FOOTER
   ============================================================ */
.footer { background:var(--dark); color:rgba(255,255,255,.75); }
.footer-top { padding:clamp(50px,8vw,80px) 0 clamp(40px,6vw,60px); }
.footer-grid { display:grid; grid-template-columns:2fr 1fr 1fr 1.2fr; gap:48px; }
.footer-logo { width:72px; border-radius:8px; background:#fff; padding:3px; margin-bottom:14px; }
.footer-brand p { font-size:.87rem; line-height:1.75; color:rgba(255,255,255,.5); max-width:260px; margin-bottom:12px; }
.footer-email { font-size:.87rem; font-weight:700; color:var(--green); }
.footer-email:hover { text-decoration:underline; }
.footer-heading { font-size:.7rem; font-weight:800; letter-spacing:.15em; text-transform:uppercase; color:rgba(255,255,255,.35); margin-bottom:18px; }
.footer-list { display:flex; flex-direction:column; gap:10px; }
.footer-list a { font-size:.9rem; color:rgba(255,255,255,.55); transition:color var(--ease); }
.footer-list a:hover { color:#fff; }
.footer-text { font-size:.88rem; color:rgba(255,255,255,.5); line-height:1.6; margin-bottom:14px; }
.footer-bottom {
    border-top:1px solid rgba(255,255,255,.07);
    padding:22px 0; text-align:center;
}
.footer-bottom p { font-size:.78rem; color:rgba(255,255,255,.3); }

/* ============================================================
   BACK TO TOP
   ============================================================ */
.back-to-top {
    position:fixed; bottom:28px; right:28px; z-index:800;
    width:44px; height:44px; border-radius:50%;
    background:var(--navy); color:#fff;
    display:flex; align-items:center; justify-content:center;
    box-shadow:var(--sh-md); transition:all var(--ease);
    opacity:0; pointer-events:none; transform:translateY(12px);
}
.back-to-top svg { width:20px; height:20px; }
.back-to-top.visible { opacity:1; pointer-events:auto; transform:translateY(0); }
.back-to-top:hover { background:var(--green); transform:translateY(-3px); box-shadow:0 8px 24px rgba(0,166,81,.4); }

/* ============================================================
   SCROLL REVEAL
   ============================================================ */
[data-aos] { opacity:0; transform:translateY(28px); transition:opacity .65s ease, transform .65s ease; }
[data-aos].revealed { opacity:1; transform:translateY(0); }

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media (max-width:1100px) {
    .values-grid { grid-template-columns:repeat(3,1fr); }
    .footer-grid  { grid-template-columns:1fr 1fr; gap:36px; }
}

@media (max-width:900px) {
    .about-grid   { grid-template-columns:1fr; gap:48px; }
    .about-float-card { display:none; }
    .stats-grid   { grid-template-columns:repeat(2,1fr); gap:32px; }
    .contact-grid { grid-template-columns:1fr; gap:48px; }
}

@media (max-width:768px) {
    .nav-menu {
        display:none; position:fixed; top:0; right:0; bottom:0;
        width:270px; background:rgba(0,24,48,.98);
        backdrop-filter:blur(20px);
        padding:88px 30px 30px; flex-direction:column;
        align-items:flex-start; gap:28px;
        box-shadow:-8px 0 40px rgba(0,0,0,.4); z-index:905;
    }
    .nav-menu.open { display:flex; }
    .nav-links { flex-direction:column; align-items:flex-start; gap:22px; }
    .nav-link   { font-size:1.05rem; font-weight:700; }
    .nav-toggle { display:flex; }

    .hero-stats { gap:18px; }
    .values-grid { grid-template-columns:1fr 1fr; }

    .process-row { flex-direction:column; align-items:center; gap:0; }
    .process-step { max-width:320px; margin-bottom:8px; }
    .process-arrow { transform:rotate(90deg); padding-top:0; padding:4px 0; }
}

@media (max-width:580px) {
    .hero-title       { font-size:2.2rem; }
    .hero-stats       { flex-direction:column; gap:14px; }
    .hero-stat-sep    { display:none; }
    .filter-bar       { gap:7px; }
    .filter-btn       { padding:8px 14px; font-size:.78rem; }
    .products-grid    { grid-template-columns:repeat(2,1fr); gap:14px; }
    .values-grid      { grid-template-columns:1fr; }
    .footer-grid      { grid-template-columns:1fr; gap:28px; }
    .contact-form-box { padding:24px 20px; }
    .two-col          { grid-template-columns:1fr; }
    .about-badge      { bottom:-14px; right:14px; padding:14px 16px; }
    .about-badge strong { font-size:1.5rem; }
}
